/* ============================================================
   ZNAYOMSTVA / BADORA — design system (з макета badora.html)
   Підключається ПІСЛЯ style.css і переозначає глобальні
   компоненти (.btn, .site-header, .site-footer, .hero, .sticky-cta).
   Власна токен-система (--rose/--violet/--ink-*) НЕ конфліктує з
   --c-rose/--c-violet старого style.css.
   Уся анімація — transform/opacity; є prefers-reduced-motion.
   ============================================================ */

/* Fixel — заголовковий шрифт (variable, укр. розкладка).
   Поки публічного CDN немає — заголовки коректно падають на Onest.
   Поклади FixelVariable.woff2 у /assets/fonts/ і розкоментуй: */
/* @font-face{ font-family:"Fixel"; font-style:normal; font-weight:400 700; font-display:swap;
  src:url("/assets/fonts/FixelVariable.woff2") format("woff2-variations"); } */

:root{
  /* brand */
  --rose:#FF6B9D; --rose-l:#FF8AB3; --violet:#7C5CBF; --lavender:#cdbbef;
  /* ink */
  --ink-900:#0f0f1a; --ink-800:#1a1a2e; --ink-600:#374151; --ink-400:#6b7280;
  /* paper */
  --paper:#fafafd; --paper-2:#f8f7fb;
  /* tints */
  --rose-tint:#fff0f5; --rose-tint-2:#ffe3ee; --violet-tint:#f3eefc; --blue-tint:#e8f6fd; --green-tint:#e9f8f0;
  --green:#1f9d61;
  /* gradients */
  --grad-signature:linear-gradient(135deg, var(--rose) 0%, var(--violet) 100%);
  --grad-violet:linear-gradient(135deg, #8e6fd4 0%, #5f43a0 100%);
  --grad-soft:linear-gradient(160deg,#fff4f8 0%,#f3eefc 60%,#eef3ff 100%);
  /* radii */
  --r-8:8px; --r-12:12px; --r-16:16px; --r-22:22px; --r-pill:999px;
  /* spacing */
  --s-1:4px; --s-2:8px; --s-3:12px; --s-4:16px; --s-5:24px; --s-6:32px; --s-7:48px; --s-8:64px; --s-9:96px; --s-10:128px;
  /* shadows */
  --sh-sm:0 1px 2px rgba(15,15,26,.05), 0 1px 1px rgba(15,15,26,.04);
  --sh-md:0 2px 4px rgba(15,15,26,.04), 0 10px 22px rgba(124,92,191,.08);
  --sh-lg:0 4px 10px rgba(15,15,26,.05), 0 28px 60px rgba(124,92,191,.16);
  --sh-cta:0 10px 26px rgba(255,107,157,.40), 0 2px 6px rgba(124,92,191,.25);
  --ring:0 0 0 3px rgba(124,92,191,.30);
  /* layout */
  --maxw:1200px; --header-h:64px;
  --font-display:"Fixel","Onest", system-ui, -apple-system, sans-serif;
  --font-text:"Onest", system-ui, -apple-system, "Segoe UI", sans-serif;
}

/* base overrides — нова типографіка на всьому сайті */
body{ background:var(--paper); color:var(--ink-800); font-family:var(--font-text); font-size:16px; line-height:1.6; -webkit-font-smoothing:antialiased; overflow-x:hidden; }
h1,h2,h3,h4{ font-family:var(--font-display); color:var(--ink-900); margin:0; line-height:1.14; letter-spacing:-.02em; font-weight:600; text-wrap:balance; overflow-wrap:break-word; }
.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:20px }
.eyebrow{ font-family:var(--font-text); font-weight:700; font-size:12px; letter-spacing:.14em; text-transform:uppercase; color:var(--violet) }
:focus-visible{ outline:none; box-shadow:var(--ring); border-radius:var(--r-8) }

/* ============================================================ BUTTONS */
.btn{ display:inline-flex; align-items:center; justify-content:center; gap:8px; font-family:var(--font-text);
  font-weight:600; font-size:16px; line-height:1.25; padding:12px 22px; min-height:50px; border-radius:13px;
  text-align:center; white-space:normal; max-width:100%; border:0; cursor:pointer;
  transition:transform .18s ease, box-shadow .18s ease, background .18s ease; }
.btn:active{ transform:translateY(1px) scale(.99) }
.btn-lg{ padding:14px 28px; min-height:56px; font-size:17px }
.btn-sm{ padding:9px 16px; min-height:42px; font-size:14px }
.btn-block{ display:flex; width:100% }
.btn-primary{ color:#fff; background:var(--grad-signature); box-shadow:var(--sh-cta) }
.btn-primary:hover{ transform:translateY(-2px); box-shadow:0 14px 32px rgba(255,107,157,.5) }
.btn-tg{ color:#fff; background:#229ED9; box-shadow:0 8px 20px rgba(34,158,217,.32) }
.btn-tg:hover{ transform:translateY(-2px); box-shadow:0 12px 26px rgba(34,158,217,.42) }
.btn-ghost{ color:var(--ink-800); background:#fff; border:1.5px solid rgba(15,15,26,.10); box-shadow:var(--sh-sm) }
.btn-ghost:hover{ border-color:var(--violet); color:var(--violet); transform:translateY(-2px); box-shadow:var(--sh-md) }
.btn-soft{ color:var(--violet); background:var(--violet-tint) }
.btn-soft:hover{ background:#ebe2fb }
.btn:disabled,.btn[aria-disabled="true"]{ opacity:.5; pointer-events:none; box-shadow:none }
.tg-ic{ width:21px; height:21px; flex:none; display:inline-block; vertical-align:middle; filter:drop-shadow(0 1px 1.5px rgba(15,15,26,.18)) }
.btn-lg .tg-ic{ width:23px; height:23px }
.rating-star{ flex:none; width:1.2em; height:1.2em; vertical-align:middle; margin-left:.1em; filter:drop-shadow(0 2px 6px rgba(255,107,157,.5)) }

/* shimmering signature CTA */
.bdr-cta-shine{ position:relative; overflow:hidden; isolation:isolate }
.bdr-cta-shine::after{ content:""; position:absolute; inset:0; z-index:0;
  background:linear-gradient(110deg, transparent 28%, rgba(255,255,255,.55) 48%, rgba(255,255,255,0) 68%);
  transform:translateX(-130%); animation:shine 3.4s cubic-bezier(.4,0,.2,1) infinite; }
@keyframes shine{ 0%{transform:translateX(-130%)} 55%,100%{transform:translateX(130%)} }
.btn.is-loading{ color:transparent !important; pointer-events:none }
.btn.is-loading::before{ content:""; position:absolute; width:18px; height:18px; border-radius:50%;
  border:2.5px solid rgba(255,255,255,.45); border-top-color:#fff; animation:spin .7s linear infinite }
.btn-ghost.is-loading::before{ border-color:rgba(124,92,191,.3); border-top-color:var(--violet) }
@keyframes spin{ to{transform:rotate(360deg)} }

/* ============================================================ LIVING BACKGROUND */
.bg-fx{ position:fixed; inset:-50px; z-index:-1; overflow:hidden; pointer-events:none; contain:strict }
.bg-fx .blob{ position:absolute; border-radius:50%; filter:blur(64px); opacity:.5; will-change:transform }
.bg-fx .b1{ width:48vw; height:48vw; left:-10vw; top:-8vw; background:radial-gradient(circle at 50% 50%, #ffb1cd 0%, rgba(255,177,205,0) 70%); animation:drift1 28s ease-in-out infinite }
.bg-fx .b2{ width:42vw; height:42vw; right:-8vw; top:6vw; background:radial-gradient(circle at 50% 50%, #cdbbef 0%, rgba(205,187,239,0) 70%); animation:drift2 34s ease-in-out infinite }
.bg-fx .b3{ width:40vw; height:40vw; left:26vw; bottom:-14vw; background:radial-gradient(circle at 50% 50%, #bfe0fb 0%, rgba(191,224,251,0) 72%); animation:drift3 31s ease-in-out infinite }
.bg-fx .grain{ position:absolute; inset:0; opacity:.045; 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='0.8' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E") }
@keyframes drift1{ 0%,100%{transform:translate(0,0) scale(1)} 50%{transform:translate(6vw,4vh) scale(1.12)} }
@keyframes drift2{ 0%,100%{transform:translate(0,0) scale(1)} 50%{transform:translate(-5vw,5vh) scale(1.08)} }
@keyframes drift3{ 0%,100%{transform:translate(0,0) scale(1)} 50%{transform:translate(4vw,-5vh) scale(1.1)} }

/* ============================================================ BADGES */
.badge{ display:inline-flex; align-items:center; gap:6px; font-weight:600; font-size:13px; padding:6px 12px; border-radius:var(--r-12); background:#fff; box-shadow:var(--sh-sm); color:var(--ink-600) }
.badge .dot{ width:7px; height:7px; border-radius:50%; background:var(--green) }
.badge-rose{ background:var(--rose-tint); color:#c43d6e }
.badge-violet{ background:var(--violet-tint); color:#5f43a0 }
.badge-blue{ background:var(--blue-tint); color:#1372a0 }
.badge-green{ background:var(--green-tint); color:#157a48 }
.online-pill{ display:inline-flex; align-items:center; gap:7px; font-size:13px; font-weight:600; color:var(--ink-600); background:#fff; border:1px solid rgba(15,15,26,.06); padding:6px 13px; border-radius:var(--r-12); box-shadow:var(--sh-sm) }
.online-pill .live{ position:relative; width:8px; height:8px; border-radius:50%; background:var(--green) }
.online-pill .live::after{ content:""; position:absolute; inset:-4px; border-radius:50%; background:var(--green); opacity:.4; animation:ping 1.8s ease-out infinite }
@keyframes ping{ 0%{transform:scale(.6); opacity:.5} 100%{transform:scale(2.2); opacity:0} }

/* ============================================================ HEADER + DRAWER */
.site-header{ position:sticky; top:0; z-index:60; height:var(--header-h);
  background:rgba(250,250,253,.82); backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(15,15,26,.06); }
.site-header .header-inner{ height:100%; display:flex; align-items:center; gap:16px }
.brand{ display:inline-flex; align-items:center; font-family:var(--font-display); font-weight:700; font-size:21px; color:var(--ink-900); letter-spacing:-.03em }
.brand-word{ white-space:nowrap }
.brand-dot{ display:inline-block; width:7px; height:7px; border-radius:50%; background:var(--grad-signature); margin-left:2px; vertical-align:baseline }
@media (min-width:768px){ .brand{ font-size:23px } }
@media (max-width:560px){ .online-pill{ display:none } }
.nav-desktop{ display:none; margin-left:8px; gap:4px }
.nav-desktop a{ font-size:15px; font-weight:500; color:var(--ink-600); padding:9px 14px; border-radius:var(--r-12); transition:.15s }
.nav-desktop a:hover{ color:var(--ink-900); background:var(--violet-tint) }
.nav-desktop a.active{ color:var(--violet); background:var(--violet-tint); font-weight:600 }
.header-actions{ margin-left:auto; display:flex; align-items:center; gap:10px }
.header-cta{ display:none }
.burger{ width:42px; height:42px; border-radius:12px; display:grid; place-items:center; background:#fff; box-shadow:var(--sh-sm); border:1px solid rgba(15,15,26,.06) }
.burger span{ display:block; width:18px; height:2px; background:var(--ink-800); border-radius:2px; position:relative }
.burger span::before,.burger span::after{ content:""; position:absolute; left:0; width:18px; height:2px; background:var(--ink-800); border-radius:2px; transition:.2s }
.burger span::before{ top:-6px } .burger span::after{ top:6px }
.drawer-overlay{ position:fixed; inset:0; z-index:70; background:rgba(15,15,26,.45); backdrop-filter:blur(2px); opacity:0; visibility:hidden }
.drawer-overlay.open{ opacity:1; visibility:visible }
.drawer{ position:fixed; top:0; right:0; bottom:0; z-index:71; width:min(86vw,340px); background:#fff;
  transform:translateX(100%); transition:transform .3s cubic-bezier(.4,0,.2,1); padding:18px; display:flex; flex-direction:column; box-shadow:-20px 0 60px rgba(15,15,26,.2) }
.drawer.open{ transform:translateX(0) }
.drawer-head{ display:flex; align-items:center; justify-content:space-between; margin-bottom:8px }
.drawer-close{ width:42px; height:42px; border-radius:12px; background:var(--paper-2); display:grid; place-items:center; font-size:20px; color:var(--ink-600); border:0 }
.drawer nav{ display:flex; flex-direction:column; gap:2px; margin-top:14px }
.drawer nav a{ font-size:18px; font-weight:600; color:var(--ink-800); padding:14px 14px; border-radius:var(--r-12); display:flex; align-items:center; gap:12px; transition:.15s }
.drawer nav a:hover,.drawer nav a.active{ background:var(--violet-tint); color:var(--violet) }
.drawer nav a .ic{ font-size:20px }
.drawer-foot{ margin-top:auto; display:flex; flex-direction:column; gap:10px; padding-top:16px }

/* ============================================================ SECTIONS */
.section{ padding-block:var(--s-8) }
.section-head{ max-width:680px; margin-bottom:var(--s-6) }
.section-head.center{ margin-inline:auto; text-align:center }
.section-head h2{ font-size:clamp(24px,5vw,36px); margin-top:10px }
.section-head p{ color:var(--ink-400); font-size:17px; margin-top:12px }
.lede{ color:var(--ink-600); font-size:17px }

/* ============================================================ HERO */
.hero{ position:relative; padding-top:var(--s-7); padding-bottom:var(--s-7); overflow:hidden }
.hero::before{ content:""; position:absolute; inset:0; z-index:-2; background:var(--grad-soft) }
.hero::after{ content:""; position:absolute; z-index:-1; width:520px; height:520px; right:-180px; top:-160px; border-radius:50%;
  background:radial-gradient(circle at 30% 30%, rgba(255,107,157,.30), rgba(124,92,191,0) 70%); filter:blur(6px) }
.hero-blob{ position:absolute; z-index:-1; width:380px; height:380px; left:-160px; bottom:-140px; border-radius:50%;
  background:radial-gradient(circle at 50% 50%, rgba(205,187,239,.45), rgba(255,255,255,0) 70%) }
.hero-grid{ display:grid; gap:var(--s-7) }
.hero h1{ font-size:clamp(28px,7vw,48px); font-weight:600; letter-spacing:-.02em }
.hero h1 .accent{ background:var(--grad-signature); -webkit-background-clip:text; background-clip:text; color:transparent }
.hero-sub{ color:var(--ink-600); font-size:clamp(16px,4.4vw,19px); margin-top:18px; max-width:46ch; text-wrap:pretty }
.hero-cta-row{ display:flex; flex-direction:column; gap:12px; margin-top:26px; max-width:440px }
.trust-row{ display:flex; flex-wrap:wrap; gap:14px; margin-top:22px }
.trust-item{ display:flex; align-items:center; gap:8px; font-size:14px; font-weight:600; color:var(--ink-600) }
.trust-item .ic{ width:26px; height:26px; border-radius:8px; display:grid; place-items:center; background:var(--green-tint); color:var(--green); font-size:14px }
.trust-item .ic.v{ background:var(--violet-tint); color:var(--violet) }
.trust-item .ic.b{ background:var(--blue-tint); color:#229ED9 }
.stat-row{ display:flex; gap:22px; margin-top:30px; flex-wrap:wrap; align-items:flex-start }
.stat{ display:flex; flex-direction:column }
.stat .num{ font-family:var(--font-display); font-weight:600; font-size:clamp(26px,7vw,34px); color:var(--ink-900); line-height:1.1; min-height:1.2em; display:inline-flex; align-items:center }
.stat .lbl{ font-size:13px; color:var(--ink-400); margin-top:6px; font-weight:500 }

/* phone mockup */
.hero-visual{ position:relative }
.phone{ position:relative; z-index:2; width:min(300px,82vw); margin-inline:auto; aspect-ratio:300/610;
  background:var(--ink-900); border:1px solid rgba(124,92,191,.3); border-radius:40px; padding:10px;
  box-shadow:0 2px 6px rgba(15,15,26,.2), 0 16px 36px rgba(124,92,191,.3), 0 40px 80px rgba(15,15,26,.22), inset 0 0 0 1.5px rgba(255,255,255,.05);
  will-change:transform; animation:phoneFloat 6s ease-in-out infinite; }
.phone-shot{ position:absolute; inset:10px; width:calc(100% - 20px); height:calc(100% - 20px); object-fit:cover; object-position:50% 0; border-radius:31px; display:block; background:#15151f }
.phone-fx{ position:absolute; inset:-12% -20%; z-index:0; pointer-events:none; overflow:hidden }
.fx-glow{ position:absolute; left:50%; top:47%; width:74%; aspect-ratio:1; transform:translate(-50%,-50%); border-radius:50%;
  background:radial-gradient(circle at 50% 50%, rgba(236,72,153,.55) 0%, rgba(139,92,246,.34) 42%, rgba(139,92,246,0) 70%);
  filter:blur(28px); will-change:transform,opacity; animation:fxPulse 4.6s ease-in-out infinite }
.fx-heart{ position:absolute; bottom:5%; left:var(--l); color:var(--c,#ec4899); font-size:calc(var(--s)*1px); line-height:1; opacity:0; will-change:transform,opacity; animation:fxFloat var(--dur) ease-in var(--delay) infinite; filter:drop-shadow(0 3px 7px rgba(236,72,153,.4)) }
.fx-bokeh{ position:absolute; bottom:var(--b,8%); left:var(--l); width:calc(var(--s)*1px); height:calc(var(--s)*1px); border-radius:50%; background:radial-gradient(circle at 35% 35%, rgba(255,255,255,.55), var(--c,rgba(236,72,153,.4)) 60%, transparent 73%); opacity:0; filter:blur(2px); will-change:transform,opacity; animation:fxFloat var(--dur) linear var(--delay) infinite }
.fx-spark{ position:absolute; left:var(--l); top:var(--t); width:5px; height:5px; border-radius:50%; background:#fff; opacity:0; will-change:transform,opacity; animation:fxSpark var(--dur) ease-in-out var(--delay) infinite; filter:drop-shadow(0 0 5px rgba(236,72,153,.9)) }
@keyframes fxPulse{ 0%,100%{transform:translate(-50%,-50%) scale(.9); opacity:.5} 50%{transform:translate(-50%,-50%) scale(1.12); opacity:.82} }
@keyframes fxFloat{ 0%{transform:translate(0,0) rotate(-8deg); opacity:0} 12%{opacity:var(--o,.8)} 25%{transform:translate(16px,-150px) rotate(6deg)} 50%{transform:translate(-14px,-320px) rotate(-5deg)} 75%{transform:translate(13px,-480px) rotate(7deg)} 88%{opacity:var(--o,.8)} 100%{transform:translate(-8px,-650px) rotate(-6deg); opacity:0} }
@keyframes fxSpark{ 0%,100%{transform:scale(.4); opacity:0} 50%{transform:scale(1.2); opacity:.95} }
@keyframes phoneFloat{ 0%,100%{transform:translateY(0) rotate(0deg)} 50%{transform:translateY(-10px) rotate(.6deg)} }

/* ============================================================ DARK STATS BAND */
.band-dark{ background:radial-gradient(120% 140% at 80% 0%, #221c33 0%, var(--ink-900) 60%); color:#fff }
.band-dark h2{ color:#fff }
.stat-cards{ display:grid; grid-template-columns:repeat(2,1fr); gap:14px }
.stat-card{ background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.08); border-radius:var(--r-16); padding:20px }
.stat-card .num{ font-family:var(--font-display); font-weight:600; font-size:clamp(26px,8vw,38px); line-height:1; background:linear-gradient(120deg,#fff,var(--lavender)); -webkit-background-clip:text; background-clip:text; color:transparent }
.stat-card .lbl{ color:rgba(255,255,255,.6); font-size:13px; margin-top:8px; font-weight:500 }

/* ============================================================ STEPS */
.steps{ display:grid; gap:16px }
.step-card{ position:relative; background:#fff; border-radius:var(--r-22); padding:26px 24px 24px; box-shadow:var(--sh-md); border:1px solid rgba(15,15,26,.04); overflow:hidden }
.step-card .stepnum{ position:absolute; right:18px; top:8px; font-family:var(--font-display); font-weight:700; font-size:84px; line-height:1; color:transparent; -webkit-text-stroke:2px rgba(124,92,191,.12) }
.step-ic{ width:52px; height:52px; border-radius:15px; display:grid; place-items:center; font-size:24px; margin-bottom:16px }
.step-ic.r{ background:var(--rose-tint); color:var(--rose) } .step-ic.v{ background:var(--violet-tint); color:var(--violet) } .step-ic.b{ background:var(--blue-tint); color:#229ED9 }
.step-card h3{ font-size:21px; margin-bottom:8px } .step-card p{ color:var(--ink-400); font-size:15px }

/* ============================================================ CITY GRID */
.city-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:12px }
.city-card{ display:flex; align-items:center; gap:12px; background:#fff; border-radius:var(--r-16); padding:14px 16px; box-shadow:var(--sh-sm); border:1px solid rgba(15,15,26,.05); transition:transform .18s, box-shadow .18s; min-width:0 }
.city-card:hover{ transform:translateY(-3px); box-shadow:var(--sh-md); border-color:rgba(124,92,191,.2) }
.city-card .coa{ width:44px; height:44px; flex:none; display:grid; place-items:center }
.city-card .coa svg{ width:100%; height:100%; display:block; filter:drop-shadow(0 1px 1.5px rgba(15,15,26,.14)) }
.city-card .ct-name{ font-weight:600; font-size:15px; color:var(--ink-900); white-space:nowrap; overflow:hidden; text-overflow:ellipsis }
.city-card .ct-count{ font-size:12.5px; color:var(--ink-400) }
.city-card .arrow{ margin-left:auto; color:var(--violet); opacity:0; transform:translateX(-4px); transition:.18s }
.city-card:hover .arrow{ opacity:1; transform:translateX(0) }
.city-more{ margin-top:20px; text-align:center }

/* ============================================================ FEATURES */
.feat-grid{ display:grid; gap:14px }
.feat-card{ background:#fff; border-radius:var(--r-16); padding:22px; box-shadow:var(--sh-sm); border:1px solid rgba(15,15,26,.05); display:flex; gap:16px; transition:transform .18s, box-shadow .18s }
.feat-card:hover{ transform:translateY(-3px); box-shadow:var(--sh-md) }
.feat-card .fic{ width:46px; height:46px; flex:none; border-radius:13px; display:grid; place-items:center; font-size:21px }
.feat-card h3{ font-size:18px; margin-bottom:6px } .feat-card p{ color:var(--ink-400); font-size:14.5px }

/* ============================================================ TESTIMONIALS */
.tcards{ display:grid; gap:16px }
.tcard{ background:#fff; border-radius:var(--r-22); padding:24px; box-shadow:var(--sh-md); border:1px solid rgba(15,15,26,.04) }
.tcard .stars{ color:var(--rose); font-size:15px; letter-spacing:2px; margin-bottom:12px }
.tcard p{ color:var(--ink-600); font-size:15.5px; line-height:1.6; text-wrap:pretty }
.tcard .who{ display:flex; align-items:center; gap:11px; margin-top:18px }
.tcard .who .av{ width:42px; height:42px; border-radius:50%; display:grid; place-items:center; color:#fff; font-weight:700; font-family:var(--font-text) }
.tcard .who .nm{ font-weight:600; font-size:14px; color:var(--ink-900) } .tcard .who .loc{ font-size:12.5px; color:var(--ink-400) }

/* ============================================================ FAQ */
.faq{ display:flex; flex-direction:column; gap:10px; max-width:760px; margin-inline:auto }
.faq-item{ background:#fff; border-radius:var(--r-16); border:1px solid rgba(15,15,26,.06); overflow:hidden; transition:box-shadow .2s }
.faq-item.open{ box-shadow:var(--sh-md); border-color:rgba(124,92,191,.18) }
.faq-q{ width:100%; display:flex; align-items:center; gap:14px; text-align:left; padding:18px 20px; font-weight:600; font-size:16px; color:var(--ink-900); background:none; border:0; cursor:pointer; font-family:var(--font-text) }
.faq-q .pm{ margin-left:auto; width:26px; height:26px; flex:none; border-radius:8px; background:var(--violet-tint); color:var(--violet); display:grid; place-items:center; font-size:18px; transition:transform .25s }
.faq-item.open .faq-q .pm{ transform:rotate(45deg) }
.faq-a{ max-height:0; overflow:hidden; transition:max-height .3s ease }
.faq-a .inner{ padding:0 20px 20px; color:var(--ink-400); font-size:15px }

/* ============================================================ CTA STRIP */
.cta-strip{ position:relative; border-radius:var(--r-22); padding:40px 28px; text-align:center; overflow:hidden; background:var(--grad-signature); color:#fff; box-shadow:var(--sh-lg) }
.cta-strip::after{ content:""; position:absolute; width:300px; height:300px; right:-100px; top:-120px; border-radius:50%; background:rgba(255,255,255,.12) }
.cta-strip h2{ color:#fff; font-size:clamp(23px,5vw,34px); position:relative }
.cta-strip p{ color:rgba(255,255,255,.88); margin-top:12px; position:relative; font-size:16px }
.cta-strip .btn{ margin-top:22px; position:relative; background:#fff; color:var(--violet) }
.cta-strip .btn:hover{ transform:translateY(-2px) }

/* ============================================================ FOOTER */
.site-footer{ background:var(--ink-900); color:#fff; padding-block:var(--s-8) var(--s-6); margin-top:var(--s-8) }
.site-footer .footer-grid{ display:grid; gap:32px; grid-template-columns:1fr }
.footer-brand .brand{ color:#fff }
.footer-brand p{ color:rgba(255,255,255,.55); font-size:14px; margin-top:14px; max-width:34ch }
.site-footer .footer-col h4{ color:rgba(255,255,255,.5); font-family:var(--font-text); font-size:13px; letter-spacing:.08em; text-transform:uppercase; margin-bottom:14px }
.site-footer .footer-col a{ display:block; color:rgba(255,255,255,.72); font-size:14.5px; padding:6px 0; transition:.15s }
.site-footer .footer-col a:hover{ color:#fff }
.site-footer .footer-bottom{ border-top:1px solid rgba(255,255,255,.1); margin-top:36px; padding-top:22px; display:flex; flex-wrap:wrap; gap:12px; justify-content:space-between; color:rgba(255,255,255,.45); font-size:13px }
.site-footer .footer-bottom a{ color:rgba(255,255,255,.55) }

/* ============================================================ STICKY MOBILE CTA */
.sticky-cta{ position:fixed; left:0; right:0; bottom:0; z-index:55; padding:12px 16px calc(12px + env(safe-area-inset-bottom));
  background:rgba(250,250,253,.9); backdrop-filter:blur(14px); border-top:1px solid rgba(15,15,26,.08);
  transform:translateY(120%); transition:transform .3s cubic-bezier(.4,0,.2,1); box-shadow:0 -6px 20px rgba(15,15,26,.06);
  width:auto; height:auto; border-radius:0; font-size:inherit; }
.sticky-cta.show{ transform:translateY(0) }
.sticky-cta .inner{ max-width:var(--maxw); margin-inline:auto; display:flex; align-items:center; gap:12px }
.sticky-cta .txt{ font-size:13px; line-height:1.25; color:var(--ink-600); font-weight:500 }
.sticky-cta .txt b{ display:block; color:var(--ink-900); font-size:15px; font-family:var(--font-display); font-weight:600 }
.sticky-cta .btn{ margin-left:auto; flex:none }

/* ============================================================ CITY PAGE / PROFILES / FORM / MODAL */
.profile-grid{ display:grid; gap:14px; grid-template-columns:1fr }
.profile-card{ background:#fff; border-radius:var(--r-22); padding:18px; box-shadow:var(--sh-md); border:1px solid rgba(15,15,26,.04); display:flex; gap:16px; transition:transform .18s,box-shadow .18s }
.profile-card:hover{ transform:translateY(-3px); box-shadow:var(--sh-lg) }
.profile-card .pav{ width:64px; height:64px; flex:none; border-radius:18px; display:grid; place-items:center; color:#fff; font-weight:700; font-size:22px; font-family:var(--font-display) }
.profile-card .ptop{ display:flex; align-items:center; gap:8px; flex-wrap:wrap }
.profile-card .pname{ font-weight:700; font-size:16px; color:var(--ink-900); font-family:var(--font-text) }
.profile-card .page{ color:var(--ink-400); font-weight:500 }
.profile-card .pbio{ color:var(--ink-600); font-size:14.5px; margin-top:6px; text-wrap:pretty; overflow-wrap:anywhere }
.profile-card .ptags{ display:flex; flex-wrap:wrap; gap:6px; margin-top:12px }
.ptag{ font-size:12px; font-weight:600; color:var(--violet); background:var(--violet-tint); padding:4px 10px; border-radius:var(--r-12) }
.profile-card .pverif{ margin-left:auto; color:#229ED9; font-size:18px }
.profile-card .pcontact{ margin-top:14px }
.contact-btn{ display:inline-flex; align-items:center; gap:7px; font-weight:600; font-size:13.5px; color:var(--violet); background:var(--violet-tint); border:0; border-radius:var(--r-12); padding:9px 14px; cursor:pointer; transition:background .15s }
.contact-btn:hover{ background:#ebe2fb }
.contact-shown{ display:inline-flex; align-items:center; gap:8px; font-weight:600; font-size:14px; color:var(--ink-900); background:var(--blue-tint); border-radius:var(--r-12); padding:9px 14px }
.contact-shown a{ color:#229ED9 }
.contact-shown a:hover{ text-decoration:underline }
.form-card{ background:#fff; border-radius:var(--r-22); padding:26px; box-shadow:var(--sh-md); border:1px solid rgba(15,15,26,.05); max-width:560px }
.field{ margin-bottom:18px }
.field label{ display:block; font-size:14px; font-weight:600; color:var(--ink-800); margin-bottom:7px }
.field label .req{ color:var(--rose) }
.input,.textarea,.select{ width:100%; font-family:inherit; font-size:15.5px; color:var(--ink-900); background:var(--paper-2); border:1.5px solid rgba(15,15,26,.10); border-radius:var(--r-12); padding:13px 15px; transition:border .15s, box-shadow .15s, background .15s }
.textarea{ resize:vertical; min-height:96px; line-height:1.5 }
.input::placeholder,.textarea::placeholder{ color:#9aa0ab }
.input:focus,.textarea:focus,.select:focus{ outline:none; background:#fff; border-color:var(--violet); box-shadow:var(--ring) }
.field.invalid .input,.field.invalid .textarea,.field.invalid .select{ border-color:#e0496b; background:#fff5f7 }
.field .err{ display:none; color:#d23a5e; font-size:13px; margin-top:6px; font-weight:500 }
.field.invalid .err{ display:block }
.row2{ display:grid; gap:14px; grid-template-columns:1fr }
.form-note{ font-size:12.5px; color:var(--ink-400); margin-top:4px }
.consent{ display:flex; gap:10px; align-items:flex-start; font-size:13.5px; color:var(--ink-600) }
.consent input{ margin-top:3px; width:18px; height:18px; accent-color:var(--violet); flex:none }
.modal-overlay{ position:fixed; inset:0; z-index:90; background:rgba(15,15,26,.55); backdrop-filter:blur(3px); display:grid; place-items:center; padding:20px; opacity:0; visibility:hidden }
.modal-overlay.open{ opacity:1; visibility:visible }
.modal{ background:#fff; border-radius:var(--r-22); padding:34px 28px; max-width:400px; width:100%; text-align:center; box-shadow:var(--sh-lg); transform:translateY(16px) scale(.97); transition:transform .3s cubic-bezier(.34,1.56,.64,1) }
.modal-overlay.open .modal{ transform:translateY(0) scale(1) }
.modal .check{ width:74px; height:74px; margin:0 auto 18px; border-radius:50%; background:var(--green-tint); color:var(--green); display:grid; place-items:center; font-size:36px; animation:pop .4s cubic-bezier(.34,1.56,.64,1) }
@keyframes pop{ from{transform:scale(.4); opacity:0} }
.modal h3{ font-size:24px; margin-bottom:10px } .modal p{ color:var(--ink-400); font-size:15px; margin-bottom:22px }

/* ============================================================ KARTA */
.map-legend{ display:flex; flex-wrap:wrap; gap:16px; align-items:center; margin-bottom:22px }
.legend-scale{ display:flex; align-items:center; gap:8px; font-size:13px; color:var(--ink-400); font-weight:500 }
.legend-bar{ width:120px; height:10px; border-radius:5px; background:linear-gradient(90deg,#ffe3ee,var(--rose),var(--violet)) }
.legend-key{ display:flex; align-items:center; gap:7px; font-size:13px; color:var(--ink-600); font-weight:500 }
.legend-key .sw{ width:14px; height:14px; border-radius:4px }
.map-wrap{ position:relative; background:#fff; border-radius:var(--r-22); padding:18px; box-shadow:var(--sh-md); border:1px solid rgba(15,15,26,.05); overflow:auto }
.uamap-slot{ min-height:600px; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:8px; text-align:center; border-radius:var(--r-16); border:2px dashed rgba(124,92,191,.3); background:linear-gradient(155deg, rgba(255,177,205,.10), rgba(205,187,239,.12) 55%, rgba(191,224,251,.10)) }
.uamap-ph{ font-family:ui-monospace,"SF Mono",Menlo,monospace; font-size:15px; font-weight:600; color:var(--violet); letter-spacing:.02em }
.uamap-ph-sub{ font-family:ui-monospace,"SF Mono",Menlo,monospace; font-size:12px; color:var(--ink-400) }
.uamap .reg{ cursor:pointer }
.uamap .reg[data-occ]{ cursor:not-allowed }
.uamap .obl{ stroke:#fff; stroke-width:3; stroke-linejoin:round; transition:filter .16s ease, stroke-width .16s ease }
.uamap .reg:hover .obl{ filter:brightness(1.07) drop-shadow(0 5px 12px rgba(124,92,191,.4)); stroke-width:3.6 }
.uamap .reg[data-occ]:hover .obl{ filter:none; stroke-width:3 }
.uamap .reg:focus-visible .obl{ stroke:var(--violet); stroke-width:4 }
.uamap .lbl{ fill:#fff; font-family:var(--font-text); font-weight:700; pointer-events:none }
.uamap .lbl.dark{ fill:var(--ink-800) }
.uamap .lbl-sub{ fill:rgba(255,255,255,.9); font-family:var(--font-text); font-weight:600; pointer-events:none }
.uamap .lbl-sub.dark{ fill:var(--ink-400) }
.uamap .flame{ pointer-events:none }
.pulse-ring{ fill:none; stroke:var(--rose); stroke-width:3; transform-box:fill-box; transform-origin:center; pointer-events:none; animation:mappulse 2.2s ease-out infinite }
@keyframes mappulse{ 0%{transform:scale(.55); opacity:.75} 100%{transform:scale(1.5); opacity:0} }
.map-tooltip{ position:fixed; z-index:80; pointer-events:none; background:var(--ink-900); color:#fff; padding:10px 13px; border-radius:12px; font-size:13px; box-shadow:var(--sh-lg); opacity:0; transform:translateY(6px); transition:opacity .12s, transform .12s; white-space:nowrap; max-width:240px }
.map-tooltip.show{ opacity:1; transform:translateY(0) }
.map-tooltip .tt-name{ font-weight:700; font-family:var(--font-text); font-size:14px }
.map-tooltip .tt-count{ color:var(--lavender); font-size:12px; margin-top:2px }
.map-tooltip .tt-go{ color:rgba(255,255,255,.55); font-size:11px; margin-top:4px }
.region-cards{ display:grid; grid-template-columns:repeat(2,1fr); gap:10px; margin-top:24px }
.region-card{ display:flex; align-items:center; gap:12px; background:#fff; border-radius:var(--r-12); padding:12px 14px; box-shadow:var(--sh-sm); border:1px solid rgba(15,15,26,.05); transition:transform .16s, box-shadow .16s }
.region-card:hover{ transform:translateY(-2px); box-shadow:var(--sh-md) }
.region-card .coa{ width:46px; height:46px; flex:none; display:grid; place-items:center }
.region-card .coa svg{ width:100%; height:100%; display:block; filter:drop-shadow(0 1px 1.5px rgba(15,15,26,.14)) }
.region-card .rinfo{ min-width:0; flex:1 }
.region-card .rname{ font-weight:600; font-size:14px; color:var(--ink-900); display:block; line-height:1.2 }
.region-card .rcount{ font-size:12px; color:var(--ink-400) }
.region-card .rarrow{ margin-left:auto; flex:none; color:var(--violet); opacity:0; transform:translateX(-4px); transition:.16s }
.region-card:hover .rarrow{ opacity:1; transform:translateX(0) }
.region-card.occ{ opacity:.9 }
.region-card.occ .rname{ color:var(--ink-400) }
.region-card.occ .coa svg{ filter:grayscale(1); opacity:.45 }

/* ============================================================ BLOG */
.blog-grid{ display:grid; gap:18px; grid-template-columns:1fr }
.post-card{ background:#fff; border-radius:var(--r-22); overflow:hidden; box-shadow:var(--sh-md); border:1px solid rgba(15,15,26,.04); transition:transform .18s, box-shadow .18s; display:flex; flex-direction:column }
.post-card:hover{ transform:translateY(-4px); box-shadow:var(--sh-lg) }
.post-thumb{ aspect-ratio:16/9; background-size:cover; background-position:center; position:relative }
.post-thumb .pcat{ position:absolute; left:14px; top:14px; font-size:12px; font-weight:600; background:rgba(255,255,255,.92); padding:5px 11px; border-radius:var(--r-12); color:var(--violet) }
.post-body{ padding:20px; flex:1; display:flex; flex-direction:column }
.post-body .pmeta{ font-size:12.5px; color:var(--ink-400); margin-bottom:9px }
.post-body h3{ font-size:20px; margin-bottom:9px; line-height:1.2 }
.post-body p{ color:var(--ink-400); font-size:14.5px; flex:1 }
.post-body .plink{ margin-top:14px; font-weight:600; font-size:14px; color:var(--violet) }

/* ============================================================ REVEAL */
.reveal{ opacity:1; transform:none }
.reveal.armed{ transform:translateY(22px) }
@keyframes revealIn{ from{transform:translateY(22px)} to{transform:none} }
.reveal.in{ animation:revealIn .55s cubic-bezier(.2,.6,.2,1) }

/* ============================================================ RESPONSIVE */
@media (min-width:768px){
  .wrap{ padding-inline:32px }
  .stat-cards{ grid-template-columns:repeat(4,1fr) }
  .steps{ grid-template-columns:repeat(3,1fr) }
  .city-grid{ grid-template-columns:repeat(3,1fr) }
  .feat-grid{ grid-template-columns:repeat(2,1fr) }
  .tcards{ grid-template-columns:repeat(3,1fr) }
  .profile-grid{ grid-template-columns:repeat(2,1fr) }
  .row2{ grid-template-columns:1fr 1fr }
  .region-cards{ grid-template-columns:repeat(3,1fr) }
  .blog-grid{ grid-template-columns:repeat(2,1fr) }
  .site-footer .footer-grid{ grid-template-columns:2fr 1fr 1fr 1fr }
  .hero-cta-row{ flex-direction:row }
  .nav-desktop{ display:flex } .header-cta{ display:inline-flex } .burger{ display:none }
  .sticky-cta{ display:none }
}
@media (min-width:992px){
  .hero-grid{ grid-template-columns:1.05fr .95fr; align-items:center }
  .hero-content{ padding-right:20px }
  .city-grid{ grid-template-columns:repeat(4,1fr) }
  .feat-grid{ grid-template-columns:repeat(4,1fr) }
  .blog-grid{ grid-template-columns:repeat(3,1fr) }
  .section{ padding-block:var(--s-9) }
  .region-cards{ grid-template-columns:repeat(4,1fr) }
}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{ animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.001ms !important }
  .reveal,.reveal.armed{ opacity:1 !important; transform:none !important }
}
