/* ============================================================
   СОЦІАЛЬНА СИНЕРГІЯ — редизайн 2026
   Editorial warmth · бірюза #105B68 · малина #E4205D · крем
   ============================================================ */

:root{
  --paper:      #FAF6EF;
  --paper-2:    #F3EDE2;
  --card:       #FFFDF8;
  --ink:        #10333B;
  --ink-soft:   rgba(16,51,59,.62);
  --ink-faint:  rgba(16,51,59,.42);
  --teal:       #105B68;
  --teal-deep:  #0A3841;
  --teal-ink:   #0D4652;
  --mint:       #46BDAC;
  --sky:        #B5E1E3;
  --rose:       #E4205D;
  --rose-deep:  #C21349;
  --rose-soft:  #FFC4D8;
  --hairline:   rgba(16,91,104,.14);
  --hairline-2: rgba(16,91,104,.08);
  --shadow-soft:    0 30px 80px -32px rgba(16,91,104,.22);
  --shadow-softer:  0 18px 50px -24px rgba(16,91,104,.16);
  --ease: cubic-bezier(.32,.72,0,1);
  --r-xl: 2rem;
  --r-lg: 1.5rem;
  --serif: "Playfair Display", Georgia, serif;
  --sans: "Onest", -apple-system, "Segoe UI", sans-serif;
}

*{ margin:0; padding:0; box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  font-family:var(--sans);
  background:var(--paper);
  color:var(--ink);
  line-height:1.6;
  font-size:16.5px;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
::selection{ background:var(--rose-soft); color:var(--teal-deep); }

img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }

/* — плівкове зерно поверх усього — */
body::after{
  content:""; position:fixed; inset:0; z-index:80; pointer-events:none;
  opacity:.035; mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='160' height='160' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E");
}

.wrap{ width:min(1180px, calc(100% - 48px)); margin:0 auto; }
.wrap-wide{ width:min(1320px, calc(100% - 48px)); margin:0 auto; }

/* ============ ТИПОГРАФІКА ============ */
.eyebrow{
  display:inline-flex; align-items:center; gap:8px;
  padding:7px 14px; border-radius:999px;
  border:1px solid var(--hairline);
  background:rgba(255,253,248,.7);
  font-size:10.5px; font-weight:600; letter-spacing:.22em; text-transform:uppercase;
  color:var(--teal);
}
.eyebrow .dot{ width:5px; height:5px; border-radius:50%; background:var(--rose); }

.h-display{
  font-family:var(--serif); font-weight:600;
  font-size:clamp(42px, 6.6vw, 84px);
  line-height:1.04; letter-spacing:-.015em;
  color:var(--teal-deep);
}
.h-section{
  font-family:var(--serif); font-weight:600;
  font-size:clamp(32px, 4.4vw, 54px);
  line-height:1.08; letter-spacing:-.012em;
  color:var(--teal-deep);
}
.accent-i{ font-style:italic; color:var(--rose); font-weight:500; }
.lead{ font-size:clamp(16px,1.6vw,19px); color:var(--ink-soft); line-height:1.75; }

/* ============ КНОПКИ ============ */
.btn{
  display:inline-flex; align-items:center; gap:12px;
  padding:8px 8px 8px 26px; border-radius:999px;
  font-weight:600; font-size:15.5px; border:none;
  transition:transform .6s var(--ease), box-shadow .6s var(--ease), background .6s var(--ease);
  will-change:transform;
}
.btn:active{ transform:scale(.98); }
.btn .btn-ico{
  width:38px; height:38px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:16px; line-height:1;
  transition:transform .6s var(--ease);
}
.btn:hover .btn-ico{ transform:translate(3px,-1px) scale(1.06); }

.btn-rose{ background:var(--rose); color:#fff; box-shadow:0 16px 36px -14px rgba(228,32,93,.5); }
.btn-rose:hover{ background:var(--rose-deep); transform:translateY(-2px); }
.btn-rose .btn-ico{ background:rgba(255,255,255,.18); color:#fff; }

.btn-teal{ background:var(--teal); color:#fff; box-shadow:0 16px 36px -14px rgba(16,91,104,.45); }
.btn-teal:hover{ background:var(--teal-ink); transform:translateY(-2px); }
.btn-teal .btn-ico{ background:rgba(255,255,255,.16); color:#fff; }

.btn-ghost{
  background:transparent; color:var(--teal);
  border:1px solid var(--hairline); padding:8px 8px 8px 26px;
}
.btn-ghost:hover{ background:rgba(16,91,104,.05); transform:translateY(-2px); }
.btn-ghost .btn-ico{ background:rgba(16,91,104,.08); color:var(--teal); }

.link-more{
  display:inline-flex; align-items:center; gap:10px;
  font-weight:600; font-size:15px; color:var(--teal);
  transition:gap .5s var(--ease);
}
.link-more:hover{ gap:15px; }
.link-more span.arr{ color:var(--rose); }

/* ============ НАВІГАЦІЯ ============ */
.nav-wrap{
  position:fixed; top:0; left:0; right:0; z-index:60;
  display:flex; justify-content:center;
  padding:18px 20px 0;
  pointer-events:none;
}
.nav{
  pointer-events:auto;
  display:flex; align-items:center; gap:26px;
  padding:9px 10px 9px 20px;
  border-radius:999px;
  background:rgba(250,246,239,.78);
  backdrop-filter:blur(18px); -webkit-backdrop-filter:blur(18px);
  border:1px solid rgba(16,91,104,.1);
  box-shadow:0 14px 44px -22px rgba(16,91,104,.28);
  transition:box-shadow .6s var(--ease), background .6s var(--ease);
  max-width:100%;
}
.nav.scrolled{ background:rgba(250,246,239,.92); box-shadow:0 18px 50px -20px rgba(16,91,104,.34); }
.nav-logo{ display:flex; align-items:center; gap:10px; flex:none; }
.nav-logo img{ width:34px; height:34px; }
.nav-logo span{
  font-size:12.5px; font-weight:700; line-height:1.15; letter-spacing:.02em;
  color:var(--teal-deep); text-transform:uppercase;
}
.nav-links{ display:flex; align-items:center; gap:4px; }
.nav-links a{
  padding:8px 13px; border-radius:999px;
  font-size:14.5px; font-weight:500; color:var(--ink-soft);
  transition:color .45s var(--ease), background .45s var(--ease);
  white-space:nowrap;
}
.nav-links a:hover{ color:var(--teal-deep); background:rgba(16,91,104,.06); }
.nav-cta{ flex:none; padding:6px 6px 6px 20px; font-size:14.5px; }
.nav-cta .btn-ico{ width:34px; height:34px; }

.burger{
  display:none; position:relative; width:44px; height:44px;
  border-radius:50%; border:1px solid var(--hairline);
  background:rgba(255,253,248,.8); flex:none;
}
.burger span{
  position:absolute; left:12px; right:12px; height:1.7px;
  background:var(--teal-deep); border-radius:2px;
  transition:transform .6s var(--ease), top .6s var(--ease);
}
.burger span:nth-child(1){ top:17px; }
.burger span:nth-child(2){ top:25px; }
.burger.open span:nth-child(1){ top:21px; transform:rotate(45deg); }
.burger.open span:nth-child(2){ top:21px; transform:rotate(-45deg); }

.mobile-menu{
  position:fixed; inset:0; z-index:55;
  background:rgba(250,246,239,.92);
  backdrop-filter:blur(28px); -webkit-backdrop-filter:blur(28px);
  display:flex; flex-direction:column; justify-content:center;
  padding:100px 34px 48px;
  opacity:0; visibility:hidden;
  transition:opacity .6s var(--ease), visibility .6s;
}
.mobile-menu.open{ opacity:1; visibility:visible; }
.mobile-menu a.mm-link{
  font-family:var(--serif); font-size:clamp(30px,7vw,44px); font-weight:600;
  color:var(--teal-deep); padding:8px 0;
  opacity:0; transform:translateY(28px);
  transition:opacity .7s var(--ease), transform .7s var(--ease), color .4s;
}
.mobile-menu a.mm-link:hover{ color:var(--rose); }
.mobile-menu.open a.mm-link{ opacity:1; transform:translateY(0); }
.mobile-menu .mm-cta{ margin-top:28px; opacity:0; transform:translateY(28px); transition:opacity .7s var(--ease) .3s, transform .7s var(--ease) .3s; }
.mobile-menu.open .mm-cta{ opacity:1; transform:translateY(0); }

/* ============ ГЕРОЙ ============ */
.hero{
  position:relative;
  padding:clamp(140px,17vh,190px) 0 clamp(60px,8vw,100px);
  overflow:hidden;
}
.hero-orbs{ position:absolute; inset:0; pointer-events:none; }
.hero-orbs i{ position:absolute; border-radius:50%; filter:blur(90px); opacity:.5; }
.hero-orbs i:nth-child(1){ width:520px; height:520px; background:var(--sky); top:-160px; right:-120px; }
.hero-orbs i:nth-child(2){ width:420px; height:420px; background:var(--rose-soft); bottom:-180px; left:-140px; opacity:.38; }
.hero-orbs i:nth-child(3){ width:300px; height:300px; background:rgba(70,189,172,.5); top:30%; left:38%; opacity:.25; }

.hero-grid{
  position:relative;
  display:grid; grid-template-columns:1.05fr .95fr;
  gap:clamp(40px,5vw,80px); align-items:center;
}
.hero-copy .eyebrow{ margin-bottom:26px; }
.hero-copy .h-display{ margin-bottom:26px; }
.hero-copy .lead{ max-width:52ch; margin-bottom:38px; }
.hero-ctas{ display:flex; align-items:center; gap:16px; flex-wrap:wrap; }

.hero-visual{ position:relative; }
.frame{
  background:rgba(16,91,104,.06);
  border:1px solid var(--hairline);
  padding:10px; border-radius:var(--r-xl);
}
.frame-core{
  border-radius:calc(var(--r-xl) - 10px);
  overflow:hidden; position:relative;
  box-shadow:inset 0 1px 1px rgba(255,255,255,.4);
}
.hero-visual .frame{ transform:rotate(1.6deg); box-shadow:var(--shadow-soft); }
.hero-visual .frame-core img{ width:100%; height:clamp(340px,44vw,520px); object-fit:cover; }

.hero-badge{
  position:absolute; left:-26px; bottom:34px;
  background:var(--card); border:1px solid var(--hairline);
  border-radius:20px; padding:16px 20px;
  box-shadow:var(--shadow-softer);
  display:flex; gap:13px; align-items:center;
  transform:rotate(-2deg);
  max-width:280px;
}
.hero-badge .hb-ico{
  width:44px; height:44px; flex:none; border-radius:14px;
  background:var(--rose-soft); color:var(--rose);
  display:flex; align-items:center; justify-content:center;
}
.hero-badge b{ display:block; font-size:14.5px; color:var(--teal-deep); line-height:1.3; }
.hero-badge small{ font-size:12.5px; color:var(--ink-soft); }

.hero-stats{
  position:relative; z-index:1;
  margin-top:clamp(50px,7vw,80px);
  display:grid; grid-template-columns:repeat(4,1fr);
  background:var(--card);
  border:1px solid var(--hairline);
  border-radius:var(--r-xl);
  box-shadow:var(--shadow-softer);
  overflow:hidden;
}
.stat{ padding:clamp(26px,2.8vw,34px) clamp(22px,2.4vw,30px); border-left:1px solid var(--hairline-2); }
.stat:first-child{ border-left:none; }
.stat b{
  display:inline-flex; align-items:baseline; gap:1px; white-space:nowrap;
  font-family:var(--serif); font-weight:600;
  font-size:clamp(44px,4.6vw,60px); color:var(--teal); line-height:.95;
  margin-bottom:12px;
}
.stat b em{ font-style:normal; color:var(--rose); font-size:.66em; }
.stat > span{ font-size:14px; color:var(--ink-soft); line-height:1.5; display:block; max-width:24ch; }

/* ============ БІГУЧИЙ РЯДОК ============ */
.ticker{
  border-block:1px solid var(--hairline-2);
  background:var(--paper-2);
  padding:18px 0; overflow:hidden; white-space:nowrap;
}
.ticker-track{ display:inline-flex; gap:0; animation:tick 38s linear infinite; }
.ticker span{
  font-family:var(--serif); font-style:italic; font-size:19px; color:var(--teal);
  padding:0 28px; position:relative;
}
.ticker span::after{
  content:"✿"; position:absolute; right:-9px; top:1px;
  font-style:normal; font-size:13px; color:var(--rose);
}
@keyframes tick{ to{ transform:translateX(-50%); } }

/* ============ СЕКЦІЇ ============ */
section{ position:relative; }
.section-pad{ padding:clamp(80px,11vw,150px) 0; }
.section-head{ max-width:760px; margin-bottom:clamp(44px,6vw,72px); }
.section-head .eyebrow{ margin-bottom:22px; }
.section-head .h-section{ margin-bottom:20px; }
.section-head .lead{ max-width:60ch; }
.section-head.center{ margin-inline:auto; text-align:center; }
.section-head.center .lead{ margin-inline:auto; }
.head-row{
  display:flex; align-items:flex-end; justify-content:space-between;
  gap:30px; flex-wrap:wrap;
}
.head-row .section-head{ margin-bottom:0; }
.head-row{ margin-bottom:clamp(44px,6vw,72px); }

/* ============ МІСІЯ / БАЧЕННЯ / ЦІЛЬ ============ */
.pillars{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.pillar{
  background:rgba(16,91,104,.05);
  border:1px solid var(--hairline-2);
  border-radius:var(--r-xl); padding:9px;
  transition:transform .7s var(--ease), box-shadow .7s var(--ease);
}
.pillar:hover{ transform:translateY(-6px); box-shadow:var(--shadow-softer); }
.pillar-core{
  background:var(--card); height:100%;
  border-radius:calc(var(--r-xl) - 9px);
  padding:34px 30px 38px;
  box-shadow:inset 0 1px 1px rgba(255,255,255,.6);
  border:1px solid rgba(255,255,255,.5);
}
.pillar .p-ico{
  width:52px; height:52px; border-radius:17px;
  display:flex; align-items:center; justify-content:center;
  margin-bottom:24px;
}
.pillar.t-sky .p-ico{ background:rgba(181,225,227,.55); color:var(--teal); }
.pillar.t-mint .p-ico{ background:rgba(70,189,172,.18); color:#1e8a7a; }
.pillar.t-rose .p-ico{ background:rgba(255,196,216,.5); color:var(--rose); }
.pillar h3{
  font-family:var(--serif); font-size:24px; font-weight:600;
  color:var(--teal-deep); margin-bottom:13px;
}
.pillar p{ font-size:15px; color:var(--ink-soft); line-height:1.7; }

/* напрями */
.directions{ margin-top:26px; display:flex; flex-wrap:wrap; gap:12px; }
.dir-chip{
  display:inline-flex; align-items:center; gap:9px;
  padding:11px 20px; border-radius:999px;
  background:var(--card); border:1px solid var(--hairline);
  font-size:14.5px; font-weight:500; color:var(--teal-ink);
  transition:transform .5s var(--ease), border-color .5s var(--ease);
}
.dir-chip:hover{ transform:translateY(-3px); border-color:var(--mint); }
.dir-chip i{ width:7px; height:7px; border-radius:50%; background:var(--mint); flex:none; }

/* ============ ІСТОРІЯ (цитата) ============ */
.story{ background:var(--teal-deep); color:#EAF3F1; overflow:hidden; position:relative; }
.story .story-orbs i{ position:absolute; border-radius:50%; filter:blur(110px); opacity:.2; pointer-events:none; }
.story .story-orbs i:nth-child(1){ width:480px; height:480px; background:var(--mint); top:-160px; right:-100px; }
.story .story-orbs i:nth-child(2){ width:380px; height:380px; background:var(--rose); bottom:-200px; left:-80px; opacity:.14; }
.story-grid{
  position:relative;
  display:grid; grid-template-columns:.9fr 1.1fr;
  gap:clamp(40px,6vw,90px); align-items:center;
}
.story .eyebrow{ border-color:rgba(255,255,255,.22); background:rgba(255,255,255,.06); color:var(--sky); }
.story h2{
  font-family:var(--serif); font-weight:600;
  font-size:clamp(30px,3.8vw,46px); line-height:1.14; letter-spacing:-.01em;
  color:#fff; margin:24px 0 22px;
}
.story p{ color:rgba(234,243,241,.78); font-size:16px; line-height:1.8; max-width:56ch; }
.story blockquote{
  position:relative;
  background:rgba(255,255,255,.055);
  border:1px solid rgba(255,255,255,.12);
  border-radius:var(--r-xl); padding:12px;
}
.story blockquote .bq-core{
  border-radius:calc(var(--r-xl) - 12px);
  background:rgba(255,255,255,.04);
  padding:clamp(30px,3.5vw,46px);
  box-shadow:inset 0 1px 1px rgba(255,255,255,.08);
}
.story blockquote .q-mark{
  font-family:var(--serif); font-size:70px; line-height:.6; color:var(--mint);
  display:block; margin-bottom:22px;
}
.story blockquote p{
  font-family:var(--serif); font-style:italic;
  font-size:clamp(19px,2vw,24px); line-height:1.55; color:#F4FAF8;
  max-width:none;
}
.story blockquote footer{ margin-top:26px; display:flex; align-items:center; gap:14px; }
.story blockquote footer .ava{
  width:46px; height:46px; border-radius:50%; overflow:hidden; flex:none;
  border:2px solid rgba(255,255,255,.25);
}
.story blockquote footer .ava img{ width:100%; height:100%; object-fit:cover; }
.story blockquote footer b{ display:block; font-size:15px; color:#fff; }
.story blockquote footer small{ font-size:13px; color:rgba(234,243,241,.6); }

/* ============ ПРОДУКТИ (бенто) ============ */
.products-grid{
  display:grid; grid-template-columns:repeat(12,1fr); gap:22px;
}
.prod{
  grid-column:span 6;
  background:rgba(16,91,104,.05);
  border:1px solid var(--hairline-2);
  border-radius:var(--r-xl); padding:9px;
  transition:transform .7s var(--ease), box-shadow .7s var(--ease);
}
.prod:hover{ transform:translateY(-6px); box-shadow:var(--shadow-soft); }
.prod-core{
  background:var(--card); border-radius:calc(var(--r-xl) - 9px);
  overflow:hidden; height:100%;
  display:flex; flex-direction:column;
  box-shadow:inset 0 1px 1px rgba(255,255,255,.6);
}
.prod-img{ position:relative; overflow:hidden; }
.prod-img img{
  width:100%; height:260px; object-fit:cover;
  transition:transform 1.1s var(--ease);
}
.prod:hover .prod-img img{ transform:scale(1.045); }
.prod-tag{
  position:absolute; top:16px; left:16px;
  padding:6px 13px; border-radius:999px;
  background:rgba(250,246,239,.88); backdrop-filter:blur(8px);
  font-size:10.5px; font-weight:700; letter-spacing:.16em; text-transform:uppercase;
  color:var(--teal);
}
.prod-body{ padding:30px 30px 34px; display:flex; flex-direction:column; gap:14px; flex:1; }
.prod-body h3{
  font-family:var(--serif); font-size:clamp(22px,2.2vw,28px);
  font-weight:600; color:var(--teal-deep); line-height:1.2;
}
.prod-body p{ font-size:15px; color:var(--ink-soft); line-height:1.72; }
.prod-facts{ display:flex; flex-wrap:wrap; gap:9px; margin-top:2px; }
.fact-pill{
  padding:7px 14px; border-radius:999px;
  background:rgba(70,189,172,.12); color:#177a6b;
  font-size:12.5px; font-weight:600;
}
.fact-pill.rose{ background:rgba(255,196,216,.4); color:var(--rose-deep); }
.fact-pill.sky{ background:rgba(181,225,227,.5); color:var(--teal); }
.prod-body .link-more{ margin-top:auto; padding-top:12px; }

/* ============ ПРОЄКТИ ============ */
.projects-band{ background:var(--paper-2); border-block:1px solid var(--hairline-2); }
.proj-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.proj{
  background:var(--card); border:1px solid var(--hairline-2);
  border-radius:var(--r-lg); overflow:hidden;
  display:flex; flex-direction:column;
  transition:transform .7s var(--ease), box-shadow .7s var(--ease);
}
.proj:hover{ transform:translateY(-6px); box-shadow:var(--shadow-softer); }
.proj-img{ overflow:hidden; position:relative; }
.proj-img img{ width:100%; height:190px; object-fit:cover; transition:transform 1.1s var(--ease); }
.proj:hover .proj-img img{ transform:scale(1.05); }
.proj-status{
  position:absolute; top:14px; left:14px;
  display:inline-flex; align-items:center; gap:7px;
  padding:6px 12px; border-radius:999px;
  background:rgba(250,246,239,.9); backdrop-filter:blur(8px);
  font-size:11px; font-weight:700; letter-spacing:.1em; text-transform:uppercase;
  color:var(--teal);
}
.proj-status i{ width:7px; height:7px; border-radius:50%; background:var(--mint); animation:pulse 2.2s infinite; }
@keyframes pulse{ 0%,100%{opacity:1;} 50%{opacity:.35;} }
.proj-body{ padding:24px 24px 28px; display:flex; flex-direction:column; gap:11px; flex:1; }
.proj-body h3{ font-size:17.5px; font-weight:700; color:var(--teal-deep); line-height:1.35; }
.proj-body p{ font-size:14px; color:var(--ink-soft); line-height:1.65; }
.proj-partner{ margin-top:auto; padding-top:10px; font-size:12.5px; font-weight:600; letter-spacing:.06em; color:var(--ink-faint); text-transform:uppercase; }
.proj-done-note{
  margin-top:34px; text-align:center; font-size:15px; color:var(--ink-soft);
}
.proj-done-note a{ color:var(--teal); font-weight:600; border-bottom:1px solid var(--mint); }

/* ============ ПОВІДОМЛЕННЯ / НОВИНИ ============ */
.news-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.news-card{
  border-radius:var(--r-lg); overflow:hidden;
  background:var(--card); border:1px solid var(--hairline-2);
  display:flex; flex-direction:column;
  transition:transform .7s var(--ease), box-shadow .7s var(--ease);
}
.news-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow-softer); }
.news-card .n-img{ overflow:hidden; }
.news-card .n-img img{ width:100%; height:200px; object-fit:cover; transition:transform 1.1s var(--ease); }
.news-card:hover .n-img img{ transform:scale(1.05); }
.news-card .n-body{ padding:24px 24px 28px; flex:1; display:flex; flex-direction:column; gap:12px; }
.news-card time{
  font-size:12px; font-weight:600; letter-spacing:.14em; text-transform:uppercase;
  color:var(--rose);
}
.news-card h3{ font-size:17px; font-weight:700; line-height:1.4; color:var(--teal-deep); }
.news-card p{ font-size:14px; color:var(--ink-soft); line-height:1.65; }
.news-card .link-more{ margin-top:auto; padding-top:8px; font-size:14px; }

/* ============ КОМАНДА ============ */
.team-scroll{
  display:flex; gap:20px; overflow-x:auto; padding:6px 6px 26px;
  scroll-snap-type:x mandatory;
  scrollbar-width:thin; scrollbar-color:var(--hairline) transparent;
}
.team-card{
  flex:0 0 232px; scroll-snap-align:start;
  background:rgba(16,91,104,.05); border:1px solid var(--hairline-2);
  border-radius:var(--r-lg); padding:8px;
  transition:transform .7s var(--ease), box-shadow .7s var(--ease);
}
.team-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow-softer); }
.team-core{
  background:var(--card); border-radius:calc(var(--r-lg) - 8px); overflow:hidden; height:100%;
}
.team-core img{
  width:100%; height:250px; object-fit:cover; object-position:center 18%;
  filter:saturate(.92);
  transition:filter .7s var(--ease);
}
.team-card:hover .team-core img{ filter:saturate(1.05); }
.team-info{ padding:16px 18px 20px; }
.team-info b{ display:block; font-size:15.5px; color:var(--teal-deep); line-height:1.3; margin-bottom:4px; }
.team-info span{ font-size:12.5px; color:var(--ink-soft); line-height:1.45; display:block; }

/* ============ ПАРТНЕРИ ============ */
.partners-band{ background:var(--paper-2); border-block:1px solid var(--hairline-2); }
.partners-grid{
  display:grid; grid-template-columns:repeat(5,1fr); gap:20px;
}
.partner-card{
  display:block; overflow:hidden;
  aspect-ratio:5/3;
  background:#fff;
  border:1px solid var(--hairline);
  border-radius:22px;
  box-shadow:0 12px 34px -22px rgba(16,91,104,.2);
  transition:transform .7s var(--ease), box-shadow .7s var(--ease), border-color .7s var(--ease);
}
.partner-card:hover{
  transform:translateY(-6px);
  box-shadow:var(--shadow-softer);
  border-color:var(--mint);
}
.partner-card img{
  width:100%; height:100%;
  object-fit:cover;
  filter:saturate(.97);
  transition:transform .7s var(--ease);
}
.partner-card:hover img{ transform:scale(1.04); }

/* ============ CTA ДОНАТ (індекс) ============ */
.donate-cta{ padding:clamp(80px,10vw,130px) 0; }
.dc-panel{
  position:relative; overflow:hidden;
  background:var(--teal-deep);
  border-radius:calc(var(--r-xl) + 8px); padding:12px;
  border:1px solid rgba(16,91,104,.3);
}
.dc-core{
  position:relative;
  border-radius:var(--r-xl);
  background:linear-gradient(135deg, rgba(70,189,172,.12), rgba(228,32,93,.1)), var(--teal-deep);
  border:1px solid rgba(255,255,255,.1);
  padding:clamp(44px,6vw,80px);
  display:grid; grid-template-columns:1.15fr .85fr; gap:clamp(30px,5vw,70px);
  align-items:center;
  box-shadow:inset 0 1px 1px rgba(255,255,255,.08);
}
.dc-core::before{
  content:""; position:absolute; width:440px; height:440px; border-radius:50%;
  background:var(--rose); filter:blur(150px); opacity:.16;
  right:-120px; top:-140px; pointer-events:none;
}
.dc-copy .eyebrow{ border-color:rgba(255,255,255,.22); background:rgba(255,255,255,.06); color:var(--rose-soft); margin-bottom:22px; }
.dc-copy h2{
  font-family:var(--serif); font-weight:600; color:#fff;
  font-size:clamp(30px,3.8vw,48px); line-height:1.12; margin-bottom:18px;
}
.dc-copy p{ color:rgba(234,243,241,.75); font-size:16px; line-height:1.75; max-width:50ch; }
.dc-side{ display:flex; flex-direction:column; gap:14px; }
.dc-amounts{ display:flex; flex-wrap:wrap; gap:10px; margin-bottom:6px; }
.dc-amounts a{
  padding:11px 20px; border-radius:999px;
  border:1px solid rgba(255,255,255,.2); color:#fff;
  font-weight:600; font-size:15px;
  transition:background .5s var(--ease), transform .5s var(--ease);
}
.dc-amounts a:hover{ background:rgba(255,255,255,.1); transform:translateY(-2px); }
.dc-side .btn{ align-self:flex-start; }
.dc-side small{ color:rgba(234,243,241,.55); font-size:13px; }

/* ============ ФУТЕР ============ */
footer.site{
  background:var(--teal-deep); color:rgba(234,243,241,.8);
  padding:clamp(64px,8vw,96px) 0 34px;
  position:relative; overflow:hidden;
}
.f-grid{
  display:grid; grid-template-columns:1.3fr .7fr .7fr .9fr;
  gap:clamp(30px,4vw,60px); margin-bottom:clamp(44px,6vw,64px);
}
.f-brand .f-logo{ display:flex; align-items:center; gap:12px; margin-bottom:20px; }
.f-brand .f-logo img{ width:40px; height:40px; filter:brightness(0) invert(1) opacity(.95); }
.f-brand .f-logo span{
  font-size:13px; font-weight:700; text-transform:uppercase; letter-spacing:.04em;
  color:#fff; line-height:1.2;
}
.f-brand p{
  font-family:var(--serif); font-style:italic;
  font-size:19px; line-height:1.6; color:rgba(234,243,241,.85);
  max-width:34ch;
}
footer.site h4{
  font-size:11.5px; font-weight:700; letter-spacing:.2em; text-transform:uppercase;
  color:var(--mint); margin-bottom:18px;
}
footer.site ul{ list-style:none; display:flex; flex-direction:column; gap:11px; }
footer.site ul a{ font-size:14.5px; color:rgba(234,243,241,.72); transition:color .4s; }
footer.site ul a:hover{ color:#fff; }
.f-contact a{ color:var(--sky); border-bottom:1px solid rgba(181,225,227,.3); }
.f-contact p{ font-size:13.5px; line-height:1.7; margin-bottom:14px; }
.f-report{
  margin-top:6px; padding:14px 16px; border-radius:14px;
  background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.08);
  font-size:12.5px; line-height:1.6;
}
.f-bottom{
  border-top:1px solid rgba(255,255,255,.1); padding-top:26px;
  display:flex; justify-content:space-between; align-items:center; gap:18px; flex-wrap:wrap;
  font-size:13px; color:rgba(234,243,241,.5);
}
.f-socials{ display:flex; gap:10px; }
.f-socials a{
  width:40px; height:40px; border-radius:50%;
  border:1px solid rgba(255,255,255,.16);
  display:flex; align-items:center; justify-content:center;
  color:rgba(234,243,241,.8);
  transition:background .5s var(--ease), transform .5s var(--ease);
}
.f-socials a:hover{ background:rgba(255,255,255,.1); transform:translateY(-3px); }

/* ============ REVEAL АНІМАЦІЇ ============ */
.reveal{
  opacity:0; transform:translateY(32px);
  filter:blur(6px);
  transition:opacity .9s var(--ease), transform .9s var(--ease), filter .9s var(--ease);
  transition-delay:var(--d, 0s);
}
.reveal.in{ opacity:1; transform:translateY(0); filter:blur(0); }
@media (prefers-reduced-motion:reduce){
  .reveal{ opacity:1; transform:none; filter:none; transition:none; }
  .ticker-track{ animation:none; }
}

/* ============================================================
   СТОРІНКА ДОНАТІВ
   ============================================================ */
.don-hero{
  position:relative;
  padding:clamp(140px,16vh,180px) 0 clamp(30px,4vw,50px);
  text-align:center; overflow:hidden;
}
.don-hero .eyebrow{ margin-bottom:24px; }
.don-hero .h-display{ font-size:clamp(38px,5.6vw,68px); margin-bottom:20px; }
.don-hero .lead{ max-width:58ch; margin:0 auto; }

.don-layout{
  display:grid; grid-template-columns:1.08fr .92fr;
  gap:clamp(26px,3.5vw,44px);
  align-items:start;
  padding-bottom:clamp(70px,9vw,120px);
}

/* — калькулятор — */
.don-widget{
  position:sticky; top:96px;
  background:rgba(16,91,104,.06);
  border:1px solid var(--hairline);
  border-radius:calc(var(--r-xl) + 6px); padding:11px;
  box-shadow:var(--shadow-soft);
}
.don-core{
  background:var(--card); border-radius:var(--r-xl);
  padding:clamp(28px,3.4vw,42px);
  box-shadow:inset 0 1px 1px rgba(255,255,255,.7);
  border:1px solid rgba(255,255,255,.6);
}
.don-core h2{
  font-family:var(--serif); font-weight:600; font-size:clamp(24px,2.6vw,32px);
  color:var(--teal-deep); margin-bottom:6px;
}
.don-core > p.sub{ font-size:14px; color:var(--ink-soft); margin-bottom:26px; }

.seg{
  display:grid; grid-template-columns:repeat(3,1fr);
  background:var(--paper-2); border:1px solid var(--hairline-2);
  border-radius:999px; padding:5px; gap:4px;
  margin-bottom:26px;
}
.seg button{
  border:none; background:transparent; border-radius:999px;
  padding:11px 6px; font-size:14px; font-weight:600; color:var(--ink-soft);
  transition:background .5s var(--ease), color .5s var(--ease), box-shadow .5s var(--ease);
}
.seg button.active{
  background:var(--teal); color:#fff;
  box-shadow:0 10px 24px -10px rgba(16,91,104,.55);
}

.don-label{
  font-size:11px; font-weight:700; letter-spacing:.18em; text-transform:uppercase;
  color:var(--teal); margin-bottom:13px; display:block;
}
.amounts{ display:grid; grid-template-columns:repeat(4,1fr); gap:10px; margin-bottom:16px; }
.amounts button{
  border:1px solid var(--hairline); background:var(--card);
  border-radius:16px; padding:15px 6px;
  font-size:16px; font-weight:700; color:var(--teal-ink);
  transition:all .5s var(--ease);
}
.amounts button small{ display:block; font-size:10.5px; font-weight:600; color:var(--ink-faint); letter-spacing:.06em; margin-top:2px; }
.amounts button:hover{ transform:translateY(-2px); border-color:var(--mint); }
.amounts button.active{
  background:var(--teal); border-color:var(--teal); color:#fff;
  box-shadow:0 14px 30px -12px rgba(16,91,104,.5);
}
.amounts button.active small{ color:rgba(255,255,255,.6); }

.custom-amount{ position:relative; margin-bottom:22px; }
.custom-amount input{
  width:100%; border:1px solid var(--hairline); background:var(--paper-2);
  border-radius:16px; padding:16px 64px 16px 20px;
  font-size:17px; font-weight:700; color:var(--teal-deep);
  font-family:inherit; outline:none;
  transition:border-color .4s var(--ease), background .4s var(--ease);
}
.custom-amount input:focus{ border-color:var(--mint); background:var(--card); }
.custom-amount input::placeholder{ color:var(--ink-faint); font-weight:500; }
.custom-amount .cur{
  position:absolute; right:20px; top:50%; transform:translateY(-50%);
  font-size:14px; font-weight:700; color:var(--ink-faint);
}

.don-slider{ margin-bottom:26px; }
.don-slider input[type=range]{
  -webkit-appearance:none; appearance:none; width:100%; height:6px;
  border-radius:99px; outline:none;
  background:linear-gradient(90deg, var(--mint) var(--fill,20%), rgba(16,91,104,.12) var(--fill,20%));
}
.don-slider input[type=range]::-webkit-slider-thumb{
  -webkit-appearance:none; width:26px; height:26px; border-radius:50%;
  background:var(--card); border:3px solid var(--teal);
  box-shadow:0 6px 16px -4px rgba(16,91,104,.4); cursor:grab;
  transition:transform .3s var(--ease);
}
.don-slider input[type=range]::-webkit-slider-thumb:hover{ transform:scale(1.12); }
.don-slider input[type=range]::-moz-range-thumb{
  width:22px; height:22px; border-radius:50%;
  background:var(--card); border:3px solid var(--teal); cursor:grab;
}
.slider-marks{ display:flex; justify-content:space-between; margin-top:8px; font-size:11.5px; color:var(--ink-faint); }

/* — блок впливу — */
.impact{
  border-radius:20px; overflow:hidden;
  background:rgba(70,189,172,.1);
  border:1px solid rgba(70,189,172,.28);
  padding:22px 24px;
  margin-bottom:24px;
  display:flex; gap:16px; align-items:flex-start;
  transition:background .5s var(--ease);
}
.impact .imp-ico{
  width:46px; height:46px; flex:none; border-radius:15px;
  background:var(--card); color:var(--rose);
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 8px 18px -8px rgba(16,91,104,.25);
}
.impact b{
  display:block; font-size:16px; color:var(--teal-deep); line-height:1.45; margin-bottom:5px;
  font-weight:700;
}
.impact b em{ font-style:normal; color:var(--rose); }
.impact span{ font-size:13px; color:var(--ink-soft); line-height:1.55; display:block; }
.impact .imp-year{
  margin-top:9px; display:inline-block;
  padding:6px 12px; border-radius:999px;
  background:rgba(228,32,93,.09); color:var(--rose-deep);
  font-size:12.5px; font-weight:600;
}

.don-submit{ width:100%; justify-content:center; padding:10px 10px; font-size:16.5px; }
.don-submit .btn-ico{ width:42px; height:42px; }
.don-legal{
  margin-top:16px; font-size:12px; color:var(--ink-faint); line-height:1.6; text-align:center;
}
.don-pay{
  margin-top:18px; display:flex; align-items:center; justify-content:center; gap:16px;
  opacity:.75;
}
.don-pay img{ height:24px; }
.don-pay span{ font-size:12px; color:var(--ink-faint); }

/* — права колонка донатів — */
.don-side{ display:flex; flex-direction:column; gap:22px; }
.side-card{
  background:rgba(16,91,104,.05); border:1px solid var(--hairline-2);
  border-radius:var(--r-xl); padding:9px;
}
.side-core{
  background:var(--card); border-radius:calc(var(--r-xl) - 9px);
  padding:30px 28px;
  box-shadow:inset 0 1px 1px rgba(255,255,255,.6);
}
.side-core h3{
  font-family:var(--serif); font-size:22px; font-weight:600;
  color:var(--teal-deep); margin-bottom:14px;
}
.side-core p{ font-size:14.5px; color:var(--ink-soft); line-height:1.7; }
.side-core .link-more{ margin-top:14px; }
.side-list{ list-style:none; display:flex; flex-direction:column; gap:13px; margin-top:6px; }
.side-list li{
  display:flex; gap:12px; align-items:flex-start;
  font-size:14.5px; color:var(--ink-soft); line-height:1.6;
}
.side-list li i{
  width:22px; height:22px; flex:none; margin-top:1px;
  border-radius:50%; background:rgba(70,189,172,.16); color:#1e8a7a;
  display:flex; align-items:center; justify-content:center; font-size:12px;
  font-style:normal;
}
.req-row{
  display:flex; justify-content:space-between; gap:14px;
  padding:11px 0; border-bottom:1px dashed var(--hairline);
  font-size:14px;
}
.req-row:last-of-type{ border-bottom:none; }
.req-row span{ color:var(--ink-faint); flex:none; }
.req-row b{ color:var(--teal-ink); text-align:right; font-weight:600; }

/* трастова смуга */
.trust-band{
  display:grid; grid-template-columns:repeat(3,1fr); gap:18px;
  margin-bottom:clamp(40px,5vw,60px);
}
.trust{
  display:flex; gap:14px; align-items:center;
  background:var(--card); border:1px solid var(--hairline-2);
  border-radius:18px; padding:18px 20px;
}
.trust .t-ico{
  width:42px; height:42px; flex:none; border-radius:14px;
  display:flex; align-items:center; justify-content:center;
}
.trust:nth-child(1) .t-ico{ background:rgba(181,225,227,.5); color:var(--teal); }
.trust:nth-child(2) .t-ico{ background:rgba(70,189,172,.16); color:#1e8a7a; }
.trust:nth-child(3) .t-ico{ background:rgba(255,196,216,.45); color:var(--rose); }
.trust b{ display:block; font-size:14px; color:var(--teal-deep); line-height:1.3; }
.trust small{ font-size:12px; color:var(--ink-soft); }

/* FAQ */
.faq{ max-width:760px; margin:0 auto; }
.faq-item{
  background:var(--card); border:1px solid var(--hairline-2);
  border-radius:20px; margin-bottom:14px; overflow:hidden;
}
.faq-item summary{
  list-style:none; cursor:pointer;
  padding:22px 26px;
  display:flex; justify-content:space-between; align-items:center; gap:16px;
  font-size:16px; font-weight:600; color:var(--teal-deep);
}
.faq-item summary::-webkit-details-marker{ display:none; }
.faq-item summary .fx{
  width:32px; height:32px; flex:none; border-radius:50%;
  border:1px solid var(--hairline);
  display:flex; align-items:center; justify-content:center;
  font-size:16px; color:var(--teal); font-weight:400;
  transition:transform .5s var(--ease), background .5s var(--ease);
}
.faq-item[open] summary .fx{ transform:rotate(45deg); background:rgba(228,32,93,.08); color:var(--rose); border-color:transparent; }
.faq-item .faq-body{ padding:0 26px 24px; font-size:14.5px; color:var(--ink-soft); line-height:1.75; }
.faq-item .faq-body a{ color:var(--teal); font-weight:600; border-bottom:1px solid var(--mint); }

/* тост */
.toast{
  position:fixed; left:50%; bottom:30px; transform:translate(-50%, 90px);
  z-index:90;
  background:var(--teal-deep); color:#fff;
  padding:16px 24px; border-radius:18px;
  font-size:14.5px; line-height:1.5; max-width:420px;
  box-shadow:0 24px 60px -20px rgba(10,56,65,.6);
  border:1px solid rgba(255,255,255,.12);
  opacity:0; transition:transform .7s var(--ease), opacity .7s var(--ease);
  pointer-events:none;
}
.toast.show{ transform:translate(-50%,0); opacity:1; }
.toast b{ color:var(--rose-soft); }

/* ============ АДАПТИВ ============ */
@media (max-width: 1060px){
  .nav-links{ display:none; }
  .burger{ display:block; }
  .nav{ gap:14px; }
  .hero-grid{ grid-template-columns:1fr; gap:44px; }
  .hero-visual .frame{ transform:rotate(0); }
  .hero-badge{ left:14px; }
  .pillars{ grid-template-columns:1fr; }
  .products-grid .prod{ grid-column:span 12; }
  .proj-grid, .news-grid{ grid-template-columns:1fr 1fr; }
  .partners-grid{ grid-template-columns:repeat(3,1fr); }
  .story-grid{ grid-template-columns:1fr; }
  .dc-core{ grid-template-columns:1fr; }
  .don-layout{ grid-template-columns:1fr; }
  .don-widget{ position:static; }
  .f-grid{ grid-template-columns:1fr 1fr; }
}
@media (max-width: 720px){
  body{ font-size:15.5px; }
  .wrap, .wrap-wide{ width:calc(100% - 32px); }
  .nav-cta{ display:none; }
  .hero{ padding-top:120px; }
  .hero-stats{ grid-template-columns:1fr 1fr; }
  .stat{ padding:24px 20px; }
  .stat:nth-child(odd){ border-left:none; }
  .stat:nth-child(even){ border-left:1px solid var(--hairline-2); }
  .stat:nth-child(n+3){ border-top:1px solid var(--hairline-2); }
  .stat b{ font-size:46px; }
  .proj-grid, .news-grid{ grid-template-columns:1fr; }
  .partners-grid{ grid-template-columns:1fr 1fr; }
  .amounts{ grid-template-columns:repeat(2,1fr); }
  .trust-band{ grid-template-columns:1fr; }
  .f-grid{ grid-template-columns:1fr; }
  .hero-visual .frame-core img{ height:300px; }
  .hero-badge{ position:static; transform:none; margin-top:14px; max-width:none; }
  .dc-side .btn{ align-self:stretch; justify-content:center; }
  .seg button{ font-size:12.5px; padding:10px 4px; }
}
