/* =========================================================
   КАПЕЛЬНИЦА — premium IV clinic
   ========================================================= */
:root{
  --blue:#2E80EC;
  --blue-600:#1F6AD0;
  --blue-50:#E6F0FD;
  --ink:#0B1220;
  --ink-2:#111827;
  --ink-3:#1E293B;
  --muted:#5B677A;
  --muted-2:#8995A6;
  --line:rgba(15,23,42,.08);
  --line-2:rgba(15,23,42,.14);
  --bg:#FFFFFF;
  --bg-soft:#F5F7FB;
  --bg-tint:#EEF3FB;
  --white:#FFFFFF;
  --radius:22px;
  --radius-lg:28px;
  --shadow-1:0 1px 0 rgba(15,23,42,.04), 0 8px 24px -12px rgba(15,23,42,.08);
  --shadow-2:0 20px 60px -30px rgba(15,23,42,.25), 0 4px 16px -8px rgba(15,23,42,.08);
  --shadow-glow:0 30px 80px -30px rgba(46,128,236,.35);
  --ease:cubic-bezier(.2,.7,.2,1);
}

*,*::before,*::after{ box-sizing:border-box; }
html,body{margin:0;padding:0;}
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  font-family:'Inter','SF Pro Display',-apple-system,BlinkMacSystemFont,system-ui,sans-serif;
  font-size:16px;
  line-height:1.55;
  color:var(--ink);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%; display:block;}
a{color:inherit; text-decoration:none;}
button{font:inherit; cursor:pointer; border:0; background:none; color:inherit;}
input,select,textarea{font:inherit; color:inherit;}

.serif{ font-family:'Instrument Serif',serif; font-style:italic; font-weight:400; letter-spacing:-.01em; }

.container{ width:100%; max-width:1240px; margin:0 auto; padding:0 28px; }

/* =================== HEADINGS / TYPE =================== */
.h1{
  font-size:clamp(40px, 5.6vw, 76px);
  line-height:1.02;
  letter-spacing:-0.035em;
  font-weight:500;
  margin:0 0 22px;
  color:var(--ink);
}
.h1__accent{
  background:linear-gradient(100deg,#2E80EC 0%, #5BA3F0 50%, #2E80EC 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.h2{
  font-size:clamp(32px, 4.2vw, 56px);
  line-height:1.05;
  letter-spacing:-0.03em;
  font-weight:500;
  margin:0 0 18px;
  color:var(--ink);
}
.h2--light{ color:#fff; }
.h2 .serif, .h1 .serif{ background:none; -webkit-text-fill-color:initial; color:inherit; }
.lede{
  font-size:clamp(16px,1.2vw,19px);
  color:var(--muted);
  max-width:560px;
  margin:0 0 32px;
}
.eyebrow{
  display:inline-flex; align-items:center; gap:8px;
  font-size:13px; font-weight:500; letter-spacing:.04em; text-transform:uppercase;
  color:var(--muted);
  padding:8px 14px;
  border:1px solid var(--line);
  border-radius:999px;
  background:rgba(255,255,255,.55);
  backdrop-filter:blur(8px);
  margin-bottom:22px;
  white-space:nowrap;
}
.eyebrow--center{ display:inline-flex; }
.eyebrow--light{ color:rgba(255,255,255,.85); border-color:rgba(255,255,255,.18); background:rgba(255,255,255,.06); }
.eyebrow__dot{
  width:6px; height:6px; border-radius:50%;
  background:var(--blue); box-shadow:0 0 0 4px rgba(46,128,236,.18);
  animation:pulse 2.4s infinite ease-in-out;
}
@keyframes pulse{ 0%,100%{box-shadow:0 0 0 4px rgba(46,128,236,.18);} 50%{box-shadow:0 0 0 7px rgba(46,128,236,0);} }

/* =================== BUTTONS =================== */
.btn{
  display:inline-flex; align-items:center; gap:10px;
  height:48px; padding:0 22px;
  border-radius:999px;
  font-weight:500; font-size:15px; letter-spacing:-.005em;
  transition:all .25s var(--ease);
  white-space:nowrap;
  position:relative; isolation:isolate;
}
.btn svg{ width:18px; height:18px; }
.btn--sm{ height:40px; padding:0 18px; font-size:14px; }
.btn--lg{ height:58px; padding:0 28px; font-size:16px; }
.btn--primary{
  background:var(--blue);
  color:#fff;
  box-shadow:0 1px 0 rgba(255,255,255,.18) inset, 0 10px 24px -10px rgba(46,128,236,.5);
}
.btn--primary:hover{ background:var(--blue-600); box-shadow:0 1px 0 rgba(255,255,255,.22) inset, 0 14px 32px -12px rgba(46,128,236,.6); transform:translateY(-1px); }
.btn--primary:active{ transform:translateY(0); }

.btn--dark{
  background:var(--ink);
  color:#fff;
  box-shadow:0 1px 0 rgba(255,255,255,.1) inset, 0 10px 24px -10px rgba(11,18,32,.6);
}
.btn--dark:hover{ background:#1a2540; transform:translateY(-1px); }

.btn--ghost{
  background:#fff;
  border:1px solid var(--line-2);
  color:var(--ink);
}
.btn--ghost:hover{ background:var(--bg-soft); border-color:var(--ink); }

.btn--white{
  background:#fff;
  color:var(--ink);
  box-shadow:0 1px 0 rgba(255,255,255,.8) inset, 0 10px 24px -10px rgba(11,18,32,.25);
}
.btn--white:hover{ background:var(--bg-soft); transform:translateY(-1px); }

.btn--whatsapp{
  background:#25D366; color:#0B1F12;
  box-shadow:0 1px 0 rgba(255,255,255,.25) inset, 0 10px 24px -10px rgba(37,211,102,.5);
}
.btn--whatsapp:hover{ background:#1FB955; transform:translateY(-1px); }

.round-btn{
  width:46px; height:46px; border-radius:50%;
  border:1px solid var(--line-2);
  background:#fff;
  display:inline-flex; align-items:center; justify-content:center;
  color:var(--ink);
  transition:.2s var(--ease);
}
.round-btn:hover{ background:var(--ink); color:#fff; border-color:var(--ink); }
.round-btn svg{ width:18px; height:18px; }

/* =================== NAV =================== */
.nav{
  position:sticky; top:0; z-index:50;
  padding:12px 0;
  background:rgba(255,255,255,.88);
  backdrop-filter:saturate(1.4) blur(18px);
  -webkit-backdrop-filter:saturate(1.4) blur(18px);
  border-bottom:1px solid transparent;
  transition:border-color .25s var(--ease), box-shadow .25s var(--ease);
}
.nav.is-scrolled{
  border-bottom-color:var(--line);
  box-shadow:0 6px 24px -16px rgba(15,23,42,.18);
}
.nav__inner{
  max-width:1240px; margin:0 auto; padding:0 28px;
  display:flex; align-items:center; gap:24px;
}
.brand{ display:inline-flex; align-items:center; gap:14px; color:var(--ink); }
.brand__logo{
  height:40px; width:auto; display:block;
  flex-shrink:0;
}
.brand__sub{
  font-size:11.5px; color:var(--muted); letter-spacing:.04em;
  line-height:1.25; max-width:140px;
  border-left:1px solid var(--line);
  padding-left:14px;
}
.brand--light{ color:#fff; }
.brand--light .brand__logo{
  filter:brightness(0) invert(1);
  height:48px;
}

.nav__links{ display:flex; gap:2px; margin-left:8px; }
.nav__links a{
  padding:8px 14px; border-radius:10px;
  font-size:14.5px; color:var(--ink-3); font-weight:500;
  transition:background .15s var(--ease), color .15s var(--ease);
}
.nav__links a:hover{ background:var(--bg-soft); color:var(--ink); }

.nav__cta{ display:flex; align-items:center; gap:12px; margin-left:auto; }
.phone{
  display:inline-flex; align-items:center; gap:8px;
  font-size:14.5px; font-weight:500;
  color:var(--ink-3);
  padding:8px 12px; border-radius:10px;
  transition:color .15s var(--ease), background .15s var(--ease);
}
.phone svg{ width:16px; height:16px; color:var(--blue); flex-shrink:0; }
.phone:hover{ color:var(--ink); background:var(--bg-soft); }

.nav__burger{
  display:none; width:40px; height:40px; border-radius:50%;
  border:1px solid var(--line-2); align-items:center; justify-content:center;
  flex-direction:column; gap:4px;
}
.nav__burger span{ display:block; width:16px; height:1.5px; background:var(--ink); transition:.25s; }
.nav__burger[aria-expanded="true"] span:nth-child(1){ transform:translateY(5.5px) rotate(45deg); }
.nav__burger[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.nav__burger[aria-expanded="true"] span:nth-child(3){ transform:translateY(-5.5px) rotate(-45deg); }

.nav__mobile{
  display:none;
  padding:8px 22px calc(22px + env(safe-area-inset-bottom));
  border-top:1px solid var(--line);
  background:rgba(255,255,255,.98);
  backdrop-filter:blur(20px);
  flex-direction:column; gap:0;
  max-height:calc(100vh - 60px);
  overflow-y:auto;
  -webkit-overflow-scrolling:touch;
}
.nav__mobile a:not(.btn){
  padding:14px 4px; font-size:16px; color:var(--ink-2);
  border-bottom:1px solid var(--line);
  font-weight:500;
}
.nav__mobile a.btn{
  border:0; width:100%;
  justify-content:center;
  height:52px;
}
.nav__mobile a.btn:first-of-type{ margin-top:18px; }
.nav__mobile a.btn + a.btn{ margin-top:10px; }
.nav.is-open .nav__mobile{ display:flex; animation:slideDown .28s var(--ease); }
@keyframes slideDown{ from{ opacity:0; transform:translateY(-6px);} to{ opacity:1; transform:none;} }
body.menu-open{ overflow:hidden; }

/* =================== HERO =================== */
.hero{
  position:relative;
  padding:80px 0 60px;
  overflow:hidden;
}
.hero__aurora{
  position:absolute; inset:0; pointer-events:none; z-index:0;
}
.blob{
  position:absolute; border-radius:50%; filter:blur(80px); opacity:.55;
}
.blob--1{ width:520px; height:520px; left:-10%; top:-10%; background:radial-gradient(circle,#dbe9ff 0%, transparent 60%); }
.blob--2{ width:600px; height:600px; right:-15%; top:5%; background:radial-gradient(circle,#cfe0ff 0%, transparent 65%); }
.blob--3{ width:480px; height:480px; left:30%; bottom:-30%; background:radial-gradient(circle,#e8f0ff 0%, transparent 60%); }
.grid-fade{
  position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(15,23,42,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(15,23,42,.04) 1px,transparent 1px);
  background-size:48px 48px;
  mask-image:radial-gradient(ellipse at 50% 30%, #000 30%, transparent 70%);
  -webkit-mask-image:radial-gradient(ellipse at 50% 30%, #000 30%, transparent 70%);
  opacity:.6;
}

.hero__grid{
  position:relative; z-index:1;
  display:grid; grid-template-columns:minmax(0,1.05fr) minmax(0,1fr);
  gap:80px;
  align-items:center;
  min-height:640px;
}
.hero__copy{ padding-top:10px; min-width:0; }
.hero__ctas{ display:flex; flex-wrap:wrap; gap:12px; margin-bottom:48px; }

.hero__stats{
  list-style:none; margin:0; padding:24px 0 0;
  display:grid; grid-template-columns:repeat(3,1fr); gap:8px;
  border-top:1px solid var(--line);
}
.hero__stats li{ display:flex; flex-direction:column; gap:4px; }
.stat__num{
  font-size:clamp(24px,2.2vw,32px);
  font-weight:500; letter-spacing:-.025em;
  color:var(--ink);
}
.stat__num i{ font-style:normal; color:var(--blue); font-weight:500; }
.stat__label{ font-size:13.5px; color:var(--muted); }

/* hero visual */
.hero__visual{ position:relative; align-self:stretch; min-height:600px; }
.visual{ position:absolute; inset:0; }
.visual__scene{
  position:absolute; inset:0;
  border-radius:36px; overflow:hidden;
  background:
    radial-gradient(120% 90% at 70% 20%, #fff 0%, #f1f6ff 40%, #dee9fb 100%);
  box-shadow:
    0 1px 0 rgba(255,255,255,.9) inset,
    0 60px 120px -40px rgba(43,90,180,.25),
    0 30px 80px -30px rgba(15,23,42,.18);
}
.scene__room{
  position:absolute; inset:0;
  background:
    linear-gradient(180deg, rgba(255,255,255,.4), rgba(255,255,255,0) 40%),
    radial-gradient(80% 60% at 80% 100%, #d2dff5 0%, transparent 70%);
}
.scene__window{
  position:absolute; left:8%; top:8%; width:38%; height:62%;
  border-radius:14px;
  background:
    linear-gradient(180deg, #eaf3ff 0%, #cadcf5 100%);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.6), 0 30px 60px -30px rgba(20,40,80,.15);
  overflow:hidden;
}
.scene__window::before, .scene__window::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg,transparent 49%, rgba(255,255,255,.55) 49.5%, rgba(255,255,255,.55) 50.5%, transparent 51%);
}
.scene__window::after{ background:linear-gradient(90deg,transparent 49%, rgba(255,255,255,.55) 49.5%, rgba(255,255,255,.55) 50.5%, transparent 51%); }
.scene__light{
  position:absolute; right:-10%; top:-10%; width:60%; height:60%;
  background:radial-gradient(circle at 50% 50%, rgba(255,255,255,.95) 0%, rgba(255,255,255,0) 65%);
  filter:blur(20px);
}
.scene__iv{
  position:absolute; right:8%; top:6%; height:88%;
  filter:drop-shadow(0 30px 30px rgba(20,40,80,.18));
}
.scene__drop{
  animation:drip 1.8s infinite ease-in;
  transform-origin:center;
}
@keyframes drip{
  0%{ transform:translateY(0); opacity:1;}
  60%{ transform:translateY(36px); opacity:1;}
  61%{ transform:translateY(36px); opacity:0;}
  100%{ transform:translateY(36px); opacity:0;}
}
.scene__plate{
  position:absolute; left:5%; right:5%; bottom:6%; height:24px;
  background:radial-gradient(ellipse, rgba(15,23,42,.18) 0%, transparent 70%);
  filter:blur(4px);
}

/* glass cards */
.glass{
  background:rgba(255,255,255,.66);
  border:1px solid rgba(255,255,255,.7);
  box-shadow:
    0 1px 0 rgba(255,255,255,.8) inset,
    0 18px 40px -20px rgba(15,23,42,.22),
    0 6px 18px -8px rgba(15,23,42,.06);
  backdrop-filter:blur(18px) saturate(1.4);
  -webkit-backdrop-filter:blur(18px) saturate(1.4);
  border-radius:var(--radius);
}

.float{
  position:absolute; padding:16px 18px;
  font-size:14px;
  animation:floatY 6s infinite ease-in-out;
}
.float__row{ display:flex; align-items:center; gap:8px; color:var(--ink-3); font-size:13px; font-weight:500; }
.float__row--meta{ justify-content:space-between; color:var(--muted); font-weight:400; margin-top:6px; }
.float__title{ font-weight:500; }
.float__big{
  font-size:32px; font-weight:500; letter-spacing:-.03em; margin:8px 0 6px;
  color:var(--ink);
}
.float__big small{ font-size:18px; color:var(--muted); font-weight:400; }
.float__bar{ height:6px; background:rgba(15,23,42,.06); border-radius:999px; overflow:hidden; }
.float__bar i{
  display:block; height:100%; width:var(--p,50%);
  background:linear-gradient(90deg, #2E80EC, #5BA3F0);
  border-radius:999px;
  animation:fill 2.4s ease forwards;
}
@keyframes fill{ from{width:0;} to{width:var(--p,50%);} }
.float__spark{ width:140px; height:30px; margin-top:4px; display:block; }
.float__caption{ font-size:13px; color:var(--muted); margin-top:4px; }
.float__avatars{ display:flex; align-items:center; }
.float__avatars span{
  width:28px; height:28px; border-radius:50%;
  border:2px solid #fff; background:#cfe0ff;
  margin-right:-8px;
  background-size:cover; background-position:center;
}
.float__avatars .more{ background:#0B1220; color:#fff; font-size:11px; display:inline-flex; align-items:center; justify-content:center; }
.dot{ width:8px; height:8px; border-radius:50%; }
.dot--live{ background:#2E80EC; box-shadow:0 0 0 4px rgba(46,128,236,.2); animation:pulse 2s infinite; }
.ico{ width:18px; height:18px; }
.badge{ display:inline-flex; align-items:center; gap:6px; font-size:12px; font-weight:500; padding:4px 10px; border-radius:999px; }
.badge--ok{ background:rgba(46,128,236,.1); color:var(--blue-600); }

.float--1{ left:-30px; top:80px; width:230px; animation-delay:.1s; }
.float--2{ right:-20px; top:30px; width:200px; animation-delay:.6s; }
.float--3{ left:-30px; bottom:70px; width:220px; animation-delay:1.0s; }
.float--4{ right:-10px; bottom:30px; width:200px; animation-delay:1.4s; }

@keyframes floatY{ 0%,100%{transform:translateY(0);} 50%{transform:translateY(-10px);} }

/* trust strip */
.hero__trust{
  margin-top:64px;
  display:grid; grid-template-columns:repeat(4,minmax(0,1fr)); gap:20px;
  padding:22px 28px;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.trust__item{
  display:flex; align-items:center; gap:10px;
  color:var(--muted); font-size:14px;
}
.trust__item svg{ width:18px; height:18px; color:var(--blue); flex-shrink:0; }

/* =================== SECTION =================== */
.section{ padding:120px 0; position:relative; }
.section--soft{ background:var(--bg-soft); }
.section--dark{
  background:#0B1220;
  color:#fff;
  overflow:hidden;
}
.section--dark .h2{ color:#fff; }
.section__bg{ position:absolute; inset:0; pointer-events:none; }
.dark-blob{
  position:absolute; width:600px; height:600px; border-radius:50%;
  background:radial-gradient(circle, rgba(46,128,236,.35) 0%, transparent 60%);
  filter:blur(60px); left:-10%; top:-20%;
}
.dark-blob--2{ left:auto; right:-15%; top:auto; bottom:-30%;
  background:radial-gradient(circle, rgba(91,163,240,.25) 0%, transparent 60%); }

.section__head{ text-align:center; max-width:760px; margin:0 auto 64px; }
.section__head--row{
  display:flex; justify-content:space-between; align-items:flex-end; gap:40px;
  max-width:none; text-align:left;
}
.section__head--row .section__lede{ text-align:left; margin:0; }
.section__head--left{ text-align:left; max-width:420px; margin:0; }
.section__lede{ font-size:17px; color:var(--muted); margin:0 auto; max-width:580px; }
.section__lede--right{ text-align:right; }
.section__lede--left{ text-align:left; }
.section__lede--light{ color:rgba(255,255,255,.7); }

/* =================== ADVANTAGES =================== */
.adv-grid{
  display:grid; grid-template-columns:repeat(3,1fr); gap:18px;
}
.adv{
  padding:32px;
  transition:transform .35s var(--ease), box-shadow .35s var(--ease);
  background:rgba(255,255,255,.7);
}
.adv:hover{
  transform:translateY(-6px);
  box-shadow:
    0 1px 0 rgba(255,255,255,.9) inset,
    0 30px 60px -28px rgba(46,128,236,.35),
    0 12px 30px -12px rgba(15,23,42,.12);
}
.adv__ico{
  width:54px; height:54px; border-radius:16px;
  background:linear-gradient(140deg, #EAF2FF, #fff);
  border:1px solid var(--line);
  display:inline-flex; align-items:center; justify-content:center;
  color:var(--blue);
  margin-bottom:22px;
}
.adv__ico svg{ width:24px; height:24px; }
.adv h3{ font-size:21px; letter-spacing:-.02em; font-weight:500; margin:0 0 10px; }
.adv p{ color:var(--muted); margin:0; font-size:15px; line-height:1.55; }

/* =================== SERVICES =================== */
.services{
  display:grid; grid-template-columns:repeat(3,1fr); gap:18px;
}
.service{
  position:relative;
  padding:32px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  display:flex; flex-direction:column;
  transition:transform .3s var(--ease), box-shadow .3s var(--ease), border-color .3s var(--ease);
  overflow:hidden;
}
.service::before{
  content:""; position:absolute; inset:0; pointer-events:none;
  background:radial-gradient(120% 100% at 0% 0%, rgba(46,128,236,.08), transparent 55%);
  opacity:0; transition:.4s var(--ease);
}
.service:hover{
  border-color:rgba(46,128,236,.3);
  transform:translateY(-4px);
  box-shadow:0 30px 60px -30px rgba(46,128,236,.28), 0 10px 24px -12px rgba(15,23,42,.08);
}
.service:hover::before{ opacity:1; }
.service__ico{
  width:54px; height:54px; border-radius:16px;
  background:linear-gradient(140deg, #EAF2FF, #fff);
  border:1px solid var(--line);
  display:inline-flex; align-items:center; justify-content:center;
  color:var(--blue);
  margin-bottom:22px;
  position:relative; z-index:1;
}
.service__ico svg{ width:24px; height:24px; }
.service h3{
  font-size:21px; letter-spacing:-.02em; font-weight:500;
  margin:0 0 12px; color:var(--ink);
  position:relative; z-index:1;
}
.service p{
  color:var(--muted); margin:0 0 22px;
  font-size:15px; line-height:1.55;
  position:relative; z-index:1;
  flex:1;
}
.service__link{
  display:inline-flex; align-items:center; gap:6px;
  font-size:14.5px; font-weight:500; color:var(--blue);
  align-self:flex-start;
  position:relative; z-index:1;
}
.service__link svg{ width:14px; height:14px; transition:.2s var(--ease); }
.service:hover .service__link svg{ transform:translateX(3px); }

/* =================== PROGRAMS =================== */
.programs{
  display:grid; grid-template-columns:repeat(4,1fr); gap:16px;
}
.program{
  position:relative;
  padding:26px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  display:flex; flex-direction:column; gap:18px;
  transition:.3s var(--ease);
  overflow:hidden;
  text-align:left;
  cursor:pointer;
  min-height:340px;
}
.program::before{
  content:""; position:absolute; inset:0; pointer-events:none;
  background:radial-gradient(140% 100% at 0% 0%, rgba(46,128,236,.08), transparent 50%);
  opacity:0; transition:.4s var(--ease);
}
.program:hover{
  border-color:rgba(46,128,236,.3);
  transform:translateY(-6px);
  box-shadow:0 30px 60px -30px rgba(46,128,236,.35);
}
.program:hover::before{ opacity:1; }
.program__visual{
  height:170px; border-radius:16px;
  position:relative; overflow:hidden;
  background:linear-gradient(160deg, #f4f8ff 0%, #e6efff 100%);
  display:flex; align-items:center; justify-content:center;
}
.program__visual::after{
  content:""; position:absolute; inset:0; pointer-events:none;
  background:radial-gradient(80% 90% at 20% 100%, rgba(255,255,255,.55), transparent 60%);
}
.program__img{
  width:auto; height:100%; max-width:90%;
  object-fit:contain;
  filter:drop-shadow(0 16px 24px rgba(15,23,42,.18));
  transition:transform .4s var(--ease);
  position:relative; z-index:1;
}
.program:hover .program__img{ transform:translateY(-4px) scale(1.04); }
.program__name{
  font-size:22px; font-weight:500; letter-spacing:-.02em; margin:0; color:var(--ink);
  display:flex; align-items:center; gap:8px; flex-wrap:wrap;
}
.program__name small{
  font-size:11px; padding:3px 8px; border-radius:999px;
  background:var(--bg-soft); color:var(--muted-2);
  letter-spacing:.04em; text-transform:uppercase; font-weight:500;
}
.program__desc{ color:var(--muted); font-size:14.5px; line-height:1.5; margin:0; flex:1; }
.program__foot{
  display:flex; align-items:center; justify-content:space-between;
  padding-top:14px; border-top:1px solid var(--line);
  font-size:13.5px; color:var(--muted);
  gap:12px;
}
.program__foot strong{ color:var(--ink); font-weight:500; }
.program__prices{
  display:inline-flex; align-items:baseline; gap:8px;
  min-width:0; flex-wrap:wrap;
}
.program__old{
  font-size:13px; color:var(--muted-2);
  text-decoration:line-through;
  font-weight:500;
  font-variant-numeric:tabular-nums;
}
.program__price{
  font-size:17px; font-weight:600; color:var(--ink);
  letter-spacing:-.02em;
  font-variant-numeric:tabular-nums;
}
.program__more{
  display:inline-flex; align-items:center; gap:6px;
  font-size:13.5px; font-weight:500; color:var(--blue);
}
.program__more svg{ width:14px; height:14px; transition:.2s; }
.program:hover .program__more svg{ transform:translateX(3px); }

/* =================== PRICE =================== */
.price-grid{
  display:grid; grid-template-columns:repeat(2,1fr); gap:18px;
  margin-bottom:36px;
}
.price-group{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:24px 26px;
  transition:.3s var(--ease);
}
.price-group:hover{
  border-color:rgba(46,128,236,.25);
  box-shadow:0 18px 40px -24px rgba(15,23,42,.18);
}
.price-group__title{
  font-size:13px; font-weight:500; letter-spacing:.06em; text-transform:uppercase;
  color:var(--blue-600); margin:0 0 16px;
}
.price-group__items{
  list-style:none; padding:0; margin:0;
  display:flex; flex-direction:column;
}
.price-group__items li{
  display:flex; align-items:baseline; justify-content:space-between; gap:14px;
  padding:12px 0;
  border-bottom:1px dashed var(--line);
  font-size:14.5px; color:var(--ink-3);
}
.price-group__items li:last-child{ border-bottom:0; }
.price-group__items li > span{ flex:1; }
.price-group__items li > b{
  font-weight:600; color:var(--ink); letter-spacing:-.01em; white-space:nowrap;
  font-variant-numeric:tabular-nums;
}
.price-cta{
  display:flex; flex-direction:column; align-items:center; gap:14px;
  text-align:center;
  padding:32px 20px;
  background:var(--bg-soft);
  border-radius:var(--radius);
  border:1px solid var(--line);
}
.price-cta p{ margin:0; color:var(--muted); font-size:15.5px; }

/* =================== ANALYSES (accordion) =================== */
.analyses{
  display:flex; flex-direction:column; gap:10px;
  max-width:840px; margin:0 auto 36px;
}
.analysis{
  background:#fff;
  border:1px solid var(--line);
  border-radius:18px;
  overflow:hidden;
  transition:.3s var(--ease);
}
.analysis[open]{
  border-color:rgba(46,128,236,.3);
  box-shadow:0 16px 40px -24px rgba(46,128,236,.22);
}
.analysis summary{
  display:flex; align-items:center; justify-content:space-between; gap:20px;
  padding:20px 24px;
  cursor:pointer; list-style:none;
}
.analysis summary::-webkit-details-marker{ display:none; }
.analysis__head{ display:flex; flex-direction:column; gap:4px; min-width:0; flex:1; }
.analysis__head h4{
  margin:0; font-size:17px; font-weight:500; letter-spacing:-.01em; color:var(--ink);
}
.analysis__head p{
  margin:0; font-size:13.5px; color:var(--muted);
  font-variant-numeric:tabular-nums;
}
.analysis__body{
  padding:0 24px 22px;
  max-height:480px;
  overflow-y:auto;
}
.analysis__body .price-group__items li{
  padding:10px 0;
  font-size:14px;
}
.analysis__body .price-group__items li > span{
  padding-right:14px;
}

/* =================== BRANCHES =================== */
.branches{
  display:grid; grid-template-columns:repeat(3,1fr); gap:14px;
}
.branch{
  display:flex; align-items:center; gap:14px;
  padding:20px 22px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:18px;
  text-decoration:none;
  transition:.3s var(--ease);
  color:var(--ink);
}
.branch:hover{
  border-color:rgba(46,128,236,.35);
  transform:translateY(-3px);
  box-shadow:0 24px 50px -28px rgba(46,128,236,.3);
}
.branch__num{
  flex-shrink:0;
  width:36px; height:36px; border-radius:10px;
  background:linear-gradient(140deg, #EAF2FF, #fff);
  border:1px solid var(--line);
  display:inline-flex; align-items:center; justify-content:center;
  color:var(--blue); font-weight:600; font-size:13px;
  font-variant-numeric:tabular-nums;
}
.branch__body{ flex:1; min-width:0; }
.branch__addr{
  font-size:15px; font-weight:500; color:var(--ink);
  line-height:1.35;
  margin-bottom:4px;
}
.branch__meta{
  font-size:13px; color:var(--muted);
}
.branch__arrow{
  flex-shrink:0;
  width:18px; height:18px; color:var(--muted-2);
  transition:.2s;
}
.branch:hover .branch__arrow{ color:var(--blue); transform:translate(2px,-2px); }

/* =================== TIMELINE =================== */
.timeline{
  list-style:none; padding:0; margin:0;
  display:grid; grid-template-columns:repeat(4,1fr); gap:18px;
  position:relative;
}
.timeline::before{
  content:""; position:absolute;
  top:38px; left:5%; right:5%; height:1px;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,.2) 20%, rgba(255,255,255,.2) 80%, transparent);
}
.timeline__step{ position:relative; }
.timeline__num{
  display:inline-flex; align-items:center; justify-content:center;
  width:54px; height:54px; border-radius:50%;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.18);
  color:rgba(255,255,255,.8);
  font-size:14px; font-weight:500; letter-spacing:.05em;
  position:relative; z-index:1;
  backdrop-filter:blur(10px);
  margin-bottom:24px;
}
.timeline__card{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.12);
  border-radius:var(--radius);
  padding:24px;
  backdrop-filter:blur(10px);
}
.timeline__ico{
  width:44px; height:44px; border-radius:12px;
  background:rgba(46,128,236,.15);
  border:1px solid rgba(46,128,236,.25);
  display:inline-flex; align-items:center; justify-content:center;
  color:#5BA3F0;
  margin-bottom:16px;
}
.timeline__ico svg{ width:20px; height:20px; }
.timeline__card h4{ font-size:19px; letter-spacing:-.02em; font-weight:500; margin:0 0 8px; color:#fff; }
.timeline__card p{ font-size:14px; color:rgba(255,255,255,.65); margin:0 0 14px; line-height:1.55; }
.timeline__time{
  display:inline-flex; align-items:center; gap:6px;
  font-size:12px; color:rgba(255,255,255,.5); font-weight:500;
  letter-spacing:.04em; text-transform:uppercase;
}

/* =================== ABOUT =================== */
.about__grid{
  display:grid; grid-template-columns:1fr 1fr; gap:80px;
  align-items:center;
}
.about__lede{ font-size:18px; color:var(--muted); margin:0 0 28px; max-width:480px; }
.about__list{ list-style:none; padding:0; margin:0 0 36px; display:flex; flex-direction:column; gap:14px; }
.about__list li{ display:flex; gap:14px; align-items:flex-start; font-size:15.5px; color:var(--ink-3); padding:12px 0; border-bottom:1px solid var(--line); }
.about__list li:last-child{ border-bottom:0; }
.about__list span{ font-size:13px; font-weight:500; color:var(--blue); letter-spacing:.04em; min-width:24px; }

.about__media{
  position:relative;
  display:grid; grid-template-columns:1.4fr 1fr; grid-template-rows:auto auto;
  gap:18px;
  min-height:560px;
}
.about__photo{
  border-radius:var(--radius-lg);
  overflow:hidden;
  position:relative;
  box-shadow:var(--shadow-2);
}
.about__photo--main{ grid-column:1; grid-row:1/3; }
.about__photo--small{ grid-column:2; grid-row:1; aspect-ratio:1; }
.photo-art{ width:100%; height:100%; position:relative; min-height:280px; }
.photo-art--room{
  background:
    radial-gradient(60% 50% at 30% 30%, rgba(255,255,255,.7), transparent 60%),
    linear-gradient(170deg, #cddbf0 0%, #eaf2ff 40%, #f4f7fc 70%, #d6e2f5 100%);
}
.photo-art--room::before{
  content:""; position:absolute; left:18%; top:14%; width:30%; height:60%;
  background:linear-gradient(180deg,#eaf3ff,#bcd0ee);
  border-radius:8px;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.6);
}
.photo-art--room::after{
  content:""; position:absolute; right:-5%; bottom:-5%; width:55%; height:55%;
  background:radial-gradient(circle at 30% 30%, #fff 0%, #dbe9ff 60%, transparent 100%);
  border-radius:50%;
  filter:blur(2px);
}
.photo-art--detail{
  background:
    radial-gradient(80% 80% at 70% 20%, #fff 0%, transparent 70%),
    linear-gradient(160deg, #2E80EC 0%, #1F6AD0 60%, #1a4fb0 100%);
}
.photo-art--detail::before{
  content:""; position:absolute; left:30%; top:10%; width:40%; height:80%;
  background:linear-gradient(180deg,rgba(255,255,255,.6),rgba(255,255,255,.1));
  border-radius:30px;
  filter:blur(.5px);
}
.about__badge{
  position:absolute; left:24px; bottom:24px;
  padding:16px 18px; max-width:280px;
}
.badge__title{ font-size:14px; font-weight:500; color:var(--ink); margin-bottom:4px; }
.badge__sub{ font-size:12.5px; color:var(--muted); }
.about__quote{
  grid-column:2; grid-row:2;
  padding:24px;
  font-size:14.5px; color:var(--ink-3);
}
.about__quote p{ margin:0 0 12px; line-height:1.5; }
.qico{ width:24px; height:24px; color:var(--blue); margin-bottom:8px; }
.quote__author{ font-size:13px; color:var(--muted); }

/* =================== REVIEWS =================== */
.reviews{ overflow:hidden; touch-action:pan-y; }
.reviews__nav{ display:flex; gap:10px; }
.reviews__track{
  display:flex; gap:20px;
  transition:transform .6s var(--ease);
  will-change:transform;
}
.review{
  flex:0 0 calc(33.333% - 14px);
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:28px;
  display:flex; flex-direction:column; gap:18px;
  min-height:280px;
}
.review__stars{ display:flex; gap:2px; color:#FFB400; }
.review__stars svg{ width:16px; height:16px; }
.review__text{ color:var(--ink-3); font-size:15.5px; line-height:1.55; margin:0; flex:1; }
.review__author{ display:flex; align-items:center; gap:12px; padding-top:14px; border-top:1px solid var(--line); }
.review__avatar{
  width:42px; height:42px; border-radius:50%;
  background-size:cover; background-position:center;
}
.review__name{ font-weight:500; font-size:15px; color:var(--ink); }
.review__meta{ font-size:13px; color:var(--muted); }

/* =================== FAQ =================== */
.faq__wrap{ display:grid; grid-template-columns:380px 1fr; gap:80px; align-items:start; }
.faq{ display:flex; flex-direction:column; gap:10px; }
.faq__item{
  background:#fff;
  border:1px solid var(--line);
  border-radius:18px;
  overflow:hidden;
  transition:.3s var(--ease);
}
.faq__item[open]{ border-color:rgba(46,128,236,.3); box-shadow:0 16px 40px -24px rgba(46,128,236,.25); }
.faq__item summary{
  display:flex; align-items:center; justify-content:space-between; gap:20px;
  padding:22px 24px; cursor:pointer; list-style:none;
  font-size:17px; font-weight:500; letter-spacing:-.01em;
  color:var(--ink);
}
.faq__item summary::-webkit-details-marker{ display:none; }
.faq__plus{
  display:inline-block; width:24px; height:24px; position:relative; flex-shrink:0;
}
.faq__plus::before, .faq__plus::after{
  content:""; position:absolute; left:50%; top:50%;
  width:12px; height:1.5px; background:var(--ink);
  transform:translate(-50%,-50%);
  transition:.3s var(--ease);
}
.faq__plus::after{ transform:translate(-50%,-50%) rotate(90deg); }
.faq__item[open] .faq__plus::after{ transform:translate(-50%,-50%) rotate(0deg); opacity:0; }
.faq__item[open] .faq__plus::before{ background:var(--blue); }
.faq__body{ padding:0 24px 22px; }
.faq__body p{ margin:0; font-size:15px; color:var(--muted); line-height:1.6; }

/* =================== CTA =================== */
.cta{
  position:relative;
  padding:140px 0;
  background:#0B1220;
  color:#fff;
  overflow:hidden;
}
.cta__bg{ position:absolute; inset:0; pointer-events:none; }
.cta__blob{
  position:absolute; width:700px; height:700px; border-radius:50%;
  background:radial-gradient(circle, rgba(46,128,236,.5) 0%, transparent 60%);
  filter:blur(80px); left:-15%; top:-30%;
}
.cta__blob--2{ left:auto; right:-20%; top:auto; bottom:-40%;
  background:radial-gradient(circle, rgba(91,163,240,.4) 0%, transparent 60%); }
.cta__inner{ position:relative; z-index:1; text-align:center; }
.cta__title{
  font-size:clamp(40px,5vw,72px); line-height:1.05; letter-spacing:-.035em;
  font-weight:500; margin:0 0 18px; color:#fff;
}
.cta__sub{ color:rgba(255,255,255,.7); font-size:18px; max-width:520px; margin:0 auto 40px; }
.cta__form{
  max-width:780px; margin:0 auto;
  padding:32px;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.14);
  border-radius:22px;
  text-align:left;
}
.cta__fields{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:14px;
}
.cta__fields label{
  display:flex; flex-direction:column; gap:7px;
  min-width:0;
}
.cta__fields span{ font-size:13px; color:rgba(255,255,255,.7); padding-left:2px; font-weight:500; letter-spacing:-.005em; }
.cta__fields input, .cta__fields select{
  width:100%;
  min-width:0;
  max-width:100%;
  height:54px; padding:0 18px;
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.18);
  border-radius:14px;
  color:#fff; font-size:15.5px; font-weight:500;
  outline:none;
  box-sizing:border-box;
  text-overflow:ellipsis;
  overflow:hidden;
  transition:border-color .2s var(--ease), background .2s var(--ease), box-shadow .2s var(--ease);
}
.cta__fields input::placeholder{ color:rgba(255,255,255,.45); font-weight:400; }
.cta__fields input:hover, .cta__fields select:hover{ background:rgba(255,255,255,.13); border-color:rgba(255,255,255,.28); }
.cta__fields input:focus, .cta__fields select:focus{
  border-color:var(--blue);
  background:rgba(255,255,255,.16);
  box-shadow:0 0 0 4px rgba(46,128,236,.18);
}
.cta__fields select{
  appearance:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-opacity='.75' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'><path d='M6 9l6 6 6-6'/></svg>");
  background-repeat:no-repeat; background-position:right 16px center;
  padding-right:42px;
  cursor:pointer;
}
.cta__fields select option{ background:#0B1220; color:#fff; }
.cta__buttons{ display:flex; gap:12px; justify-content:center; margin-top:22px; flex-wrap:wrap; }
.cta__buttons .btn{ min-width:200px; justify-content:center; }
.cta__buttons button[disabled]{ opacity:.7; cursor:not-allowed; }

.cta__status{
  margin-top:16px;
  padding:0 16px;
  font-size:14px; line-height:1.5;
  text-align:center;
  border-radius:12px;
  min-height:0;
  transition:all .25s var(--ease);
}
.cta__status:empty{ display:none; }
.cta__status--loading{
  background:rgba(255,255,255,.08);
  color:rgba(255,255,255,.8);
  padding:12px 16px;
}
.cta__status--success{
  background:rgba(22,163,74,.15);
  color:#7be0a0;
  padding:14px 18px;
  border:1px solid rgba(22,163,74,.35);
  font-weight:500;
}
.cta__status--error{
  background:rgba(239,68,68,.12);
  color:#ff9a9a;
  padding:12px 16px;
  border:1px solid rgba(239,68,68,.3);
}

.cta__legal{ font-size:12.5px; color:rgba(255,255,255,.5); margin:18px 0 0; text-align:center; }
.cta__legal a{ color:rgba(255,255,255,.75); text-decoration:underline; text-underline-offset:2px; }

/* =================== FOOTER =================== */
.footer{
  background:#0B1220;
  color:rgba(255,255,255,.7);
  padding:80px 0 30px;
  border-top:1px solid rgba(255,255,255,.08);
}
.footer__grid{
  display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:40px;
  padding-bottom:48px;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.footer__brand p{ margin:14px 0 0; color:rgba(255,255,255,.5); max-width:280px; font-size:14.5px; }
.footer__brand .brand{ color:#fff; }
.footer__col h5{ color:#fff; font-size:14px; font-weight:500; letter-spacing:.04em; text-transform:uppercase; margin:0 0 18px; }
.footer__col a, .footer__col p{ display:block; color:rgba(255,255,255,.6); font-size:14.5px; margin:0 0 10px; transition:.2s; }
.footer__col a:hover{ color:#fff; }
.footer__bottom{
  display:flex; justify-content:space-between; gap:24px;
  padding-top:24px; font-size:13px; color:rgba(255,255,255,.4);
  flex-wrap:wrap;
}

/* =================== MODAL =================== */
.modal{
  position:fixed; inset:0; z-index:100;
  display:flex; align-items:center; justify-content:center;
  padding:24px;
  visibility:hidden; opacity:0;
  transition:opacity .35s var(--ease), visibility .35s var(--ease);
}
.modal.is-open{ visibility:visible; opacity:1; }
.modal__backdrop{
  position:absolute; inset:0;
  background:rgba(11,18,32,.55);
  backdrop-filter:blur(14px);
}
.modal__shell{
  position:relative;
  max-width:680px; width:100%;
  max-height:88vh; overflow:auto;
  border-radius:28px;
  background:rgba(255,255,255,.96);
  padding:0;
  transform:translateY(20px) scale(.98);
  transition:transform .4s var(--ease);
}
.modal.is-open .modal__shell{ transform:translateY(0) scale(1); }
.modal__close{
  position:absolute; right:18px; top:18px; z-index:2;
  width:40px; height:40px; border-radius:50%;
  background:rgba(15,23,42,.06);
  display:inline-flex; align-items:center; justify-content:center;
  color:var(--ink);
  transition:.2s;
}
.modal__close:hover{ background:var(--ink); color:#fff; }
.modal__close svg{ width:18px; height:18px; }
.modal__body{ padding:0; }
.modal__head{
  padding:36px 36px 28px;
  background:linear-gradient(160deg, #eaf2ff 0%, #fff 100%);
  border-radius:28px 28px 0 0;
  position:relative; overflow:hidden;
}
.modal__head--img{
  display:grid; grid-template-columns:1fr auto; gap:24px; align-items:center;
}
.modal__head-text{ min-width:0; }
.modal__hero{
  width:180px; height:180px; object-fit:contain;
  filter:drop-shadow(0 20px 30px rgba(15,23,42,.22));
  position:relative; z-index:1;
}
.modal__prices{
  display:flex; align-items:center; gap:10px; flex-wrap:wrap;
  margin-top:16px; position:relative; z-index:1;
}
.modal__price{
  display:inline-flex; align-items:center;
  padding:9px 18px; border-radius:999px;
  background:var(--blue);
  color:#fff;
  font-weight:600; font-size:17px; letter-spacing:-.01em;
  font-variant-numeric:tabular-nums;
}
.modal__old{
  font-size:15px; color:var(--muted);
  text-decoration:line-through;
  font-weight:500;
  font-variant-numeric:tabular-nums;
}
.modal__save{
  display:inline-flex; align-items:center;
  padding:6px 12px; border-radius:999px;
  background:#16A34A; color:#fff;
  font-weight:600; font-size:13px; letter-spacing:-.005em;
}
.modal__head::after{
  content:""; position:absolute; right:-10%; top:-30%; width:60%; height:140%;
  background:radial-gradient(circle, rgba(255,255,255,.6) 0%, transparent 70%);
  filter:blur(10px);
}
.modal__cta--row{ display:flex; gap:12px; flex-wrap:wrap; }
.modal__cta--row .btn{ flex:1; min-width:200px; justify-content:center; }
.modal__eyebrow{
  font-size:12px; letter-spacing:.08em; text-transform:uppercase;
  color:var(--blue-600); font-weight:500; margin-bottom:10px; position:relative; z-index:1;
}
.modal__title{ font-size:36px; letter-spacing:-.03em; font-weight:500; margin:0 0 8px; color:var(--ink); position:relative; z-index:1; }
.modal__lede{ font-size:15.5px; color:var(--muted); margin:0; max-width:440px; position:relative; z-index:1; }
.modal__content{ padding:28px 36px 36px; display:grid; grid-template-columns:1fr 1fr; gap:24px; }
.modal__block{ padding:18px; border:1px solid var(--line); border-radius:16px; }
.modal__block h5{ font-size:12px; letter-spacing:.06em; text-transform:uppercase; color:var(--muted); margin:0 0 10px; font-weight:500; }
.modal__block ul{ list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:8px; }
.modal__block li{ display:flex; gap:8px; align-items:flex-start; font-size:14.5px; color:var(--ink-3); }
.modal__block li svg{ width:16px; height:16px; color:var(--blue); flex-shrink:0; margin-top:3px; }
.modal__meta{ display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.modal__meta div{ padding:14px 16px; background:var(--bg-soft); border-radius:14px; }
.modal__meta b{ display:block; font-size:13px; color:var(--muted); font-weight:500; margin-bottom:4px; }
.modal__meta span{ font-size:18px; font-weight:500; color:var(--ink); letter-spacing:-.01em; }
.modal__cta{ padding:0 36px 36px; }
.modal__cta .btn{ width:100%; justify-content:center; }

/* =================== LICENSE =================== */
.license{ display:flex; flex-direction:column; gap:32px; }

.license__card{
  display:grid; grid-template-columns:340px 1fr; gap:0;
  background:#fff;
  border:1px solid var(--line);
  border-radius:24px;
  overflow:hidden;
  box-shadow:var(--shadow-1);
}
.license__preview{
  position:relative;
  background:linear-gradient(160deg, #EAF2FF 0%, #F5F9FF 100%);
  display:flex; align-items:center; justify-content:center;
  padding:36px 28px;
  border-right:1px solid var(--line);
  overflow:hidden;
}
.license__preview::before{
  content:""; position:absolute; inset:0;
  background:
    radial-gradient(circle at 100% 0%, rgba(255,255,255,.7), transparent 50%),
    radial-gradient(circle at 0% 100%, rgba(46,128,236,.08), transparent 50%);
}
.license__doc{
  position:relative;
  width:210px; aspect-ratio:1/1.2;
  background:#fff;
  border:1px solid var(--line);
  border-radius:8px;
  padding:18px 18px 18px 24px;
  box-shadow:0 22px 50px -22px rgba(15,23,42,.28), 0 4px 12px -4px rgba(15,23,42,.1);
  transform:rotate(-3deg);
  overflow:hidden;
}
.license__doc-stripe{
  position:absolute; left:0; top:0; bottom:0; width:6px;
  background:linear-gradient(180deg, var(--blue), var(--blue-600));
}
.license__doc-lines{ display:flex; flex-direction:column; gap:7px; padding-top:24px; }
.license__doc-lines span{
  display:block; height:6px; border-radius:3px;
  background:linear-gradient(90deg, var(--line-2), var(--line));
  width:100%;
}
.license__seal{
  position:absolute; right:18px; bottom:18px;
  width:78px; height:78px;
  color:var(--blue);
  background:rgba(255,255,255,.92);
  border-radius:50%;
  padding:6px;
  box-shadow:0 8px 24px -10px rgba(46,128,236,.45);
  z-index:2;
}

.license__body{ padding:32px 36px; display:flex; flex-direction:column; }
.license__eyebrow{
  font-size:12px; letter-spacing:.08em; text-transform:uppercase;
  color:var(--blue-600); font-weight:600; margin-bottom:10px;
}
.license__title{
  font-size:26px; font-weight:500; letter-spacing:-.02em;
  margin:0 0 22px; color:var(--ink);
}
.license__meta{
  list-style:none; padding:0; margin:0 0 22px;
  display:grid; grid-template-columns:1fr 1fr; gap:14px 28px;
}
.license__meta li{
  display:flex; flex-direction:column; gap:4px;
  padding:12px 16px;
  background:var(--bg-soft);
  border-radius:12px;
}
.license__meta b{
  font-size:12px; color:var(--muted); font-weight:500;
  letter-spacing:.02em; text-transform:uppercase;
}
.license__meta span{ font-size:14.5px; color:var(--ink); font-weight:500; line-height:1.35; }

.license__scopes{
  display:flex; flex-wrap:wrap; gap:6px;
  margin-bottom:24px;
}
.license__scopes span{
  display:inline-flex; align-items:center;
  padding:6px 12px;
  background:var(--blue-50);
  color:var(--blue-600);
  border-radius:999px;
  font-size:12.5px; font-weight:500; letter-spacing:-.005em;
}

.license__cta{ display:flex; gap:12px; flex-wrap:wrap; margin-top:auto; }

.license__notes{
  display:grid; grid-template-columns:repeat(3, 1fr); gap:18px;
}
.license__note{
  display:flex; gap:16px; align-items:flex-start;
  padding:22px;
  background:var(--bg-soft);
  border-radius:18px;
  border:1px solid var(--line);
}
.license__note svg{
  width:24px; height:24px; flex-shrink:0;
  color:var(--blue);
  background:var(--blue-50);
  padding:8px; box-sizing:content-box;
  border-radius:10px;
}
.license__note b{ display:block; font-size:15.5px; color:var(--ink); margin-bottom:4px; letter-spacing:-.01em; }
.license__note p{ margin:0; font-size:13.5px; color:var(--muted); line-height:1.5; }

/* =================== REVEAL ANIM =================== */
.reveal{ opacity:0; transform:translateY(24px); transition:opacity .8s var(--ease), transform .8s var(--ease); }
.reveal.is-visible{ opacity:1; transform:none; }

/* =================== RESPONSIVE =================== */

/* tablet — < 1200 */
@media (max-width:1200px){
  .hero__grid{ gap:56px; }
  .float--1{ left:-10px; top:60px; width:215px; }
  .float--2{ right:-10px; top:20px; width:190px; }
  .float--3{ left:-10px; bottom:60px; width:210px; }
  .float--4{ right:-10px; bottom:20px; width:190px; }
}

@media (max-width:1100px){
  .nav__inner{ gap:18px; }
  .brand__sub{ display:none; }
  .brand{ gap:0; }
  .nav__links{ display:none; }
  .nav__burger{ display:inline-flex; }
  .phone span{ display:none; }
  .phone{ width:40px; height:40px; border-radius:50%; border:1px solid var(--line-2); justify-content:center; }
  .phone svg{ width:18px; height:18px; }
}

@media (max-width:1080px){
  .container{ padding:0 24px; }
  .nav__inner{ padding:0 24px; }
  .programs{ grid-template-columns:repeat(3,1fr); }
  .adv-grid{ grid-template-columns:repeat(2,1fr); }
  .review{ flex:0 0 calc(50% - 10px); }
  .hero__visual{ min-height:560px; }
  .about__grid{ gap:56px; }
}

/* tablet portrait / large phone — < 920 */
@media (max-width:920px){
  .hero{ padding:48px 0 56px; }
  .hero__grid{
    grid-template-columns:1fr;
    gap:40px;
    min-height:0;
  }
  .hero__copy{ padding-top:0; }
  .hero__visual{ min-height:0; height:auto; order:2; }

  /* Hero visual: convert absolute float cards into a clean 2-col grid below the IV scene */
  .visual{ position:relative; inset:auto; display:flex; flex-direction:column; gap:18px; }
  .visual__scene{
    position:relative; inset:auto;
    height:340px;
    border-radius:28px;
  }
  .scene__iv{ right:10%; top:4%; height:92%; }

  .float{
    position:relative; inset:auto;
    width:auto; animation:none; transform:none;
  }
  .visual::after{
    /* placeholder grid for the 4 cards */
    content:""; display:none;
  }
  /* Build a 2x2 grid wrapper around the 4 cards using their order */
  .visual{ }
  .visual > .float{ flex:0 0 auto; }
  .float--1, .float--2, .float--3, .float--4{
    width:auto;
  }
  /* layout: stack scene on top, then 2x2 grid of cards below */
  .visual{
    display:grid;
    grid-template-columns:1fr 1fr;
    grid-template-areas:
      "scene scene"
      "f1 f2"
      "f3 f4";
    gap:14px;
  }
  .visual__scene{ grid-area:scene; }
  .float--1{ grid-area:f1; }
  .float--2{ grid-area:f2; }
  .float--3{ grid-area:f3; }
  .float--4{ grid-area:f4; }

  .hero__stats{ grid-template-columns:repeat(3,minmax(0,1fr)); gap:16px 12px; padding-top:22px; }
  .hero__trust{ grid-template-columns:repeat(2,1fr); gap:14px; padding:18px 16px; margin-top:40px; }

  .section{ padding:80px 0; }
  .section__head{ margin:0 auto 48px; }
  .section__head--row{
    flex-direction:column;
    align-items:flex-start;
    gap:18px;
  }
  .section__head--row .reviews__nav{ align-self:flex-end; }
  .section__lede--right{ text-align:left; }

  .h1{ margin-bottom:18px; }
  .h2{ margin-bottom:14px; }
  .lede{ margin-bottom:28px; }
  .eyebrow{ margin-bottom:18px; }

  .adv{ padding:26px; }
  .services{ grid-template-columns:repeat(2,1fr); gap:14px; }
  .service{ padding:26px; }
  .programs{ grid-template-columns:repeat(2,1fr); gap:14px; }
  .program{ min-height:0; padding:22px; }
  .program__visual{ height:160px; }

  .timeline{ grid-template-columns:1fr 1fr; gap:18px; }
  .timeline::before{ display:none; }
  .timeline__num{ margin-bottom:16px; }

  .about__grid{ grid-template-columns:1fr; gap:48px; }
  .about__media{
    min-height:0;
    grid-template-columns:1fr;
    grid-auto-rows:auto;
    gap:16px;
  }
  .about__photo--main{ grid-column:1; grid-row:auto; aspect-ratio:4/3; }
  .about__photo--small{ grid-column:1; grid-row:auto; aspect-ratio:16/10; }
  .photo-art{ min-height:0; }
  .about__quote{ grid-column:1; grid-row:auto; padding:22px; }
  .about__badge{ left:18px; bottom:18px; padding:14px 16px; }

  .review{ flex:0 0 100%; padding:24px; min-height:0; }

  .faq__wrap{ grid-template-columns:1fr; gap:32px; }

  .footer{ padding:64px 0 28px; }
  .footer__grid{ grid-template-columns:1fr 1fr; gap:36px 28px; padding-bottom:36px; }

  .cta{ padding:96px 0; }
  .cta__form{ padding:20px; border-radius:24px; }
  .cta__fields{ grid-template-columns:1fr; gap:12px; }
  .cta__buttons{ flex-direction:column; gap:10px; }
  .cta__buttons .btn{ width:100%; justify-content:center; }

  .modal{ padding:16px; }
  .modal__shell{ max-height:92vh; border-radius:24px; }
  .modal__content{ grid-template-columns:1fr; padding:22px 22px; gap:16px; }
  .modal__head{ padding:26px 22px 22px; border-radius:24px 24px 0 0; }
  .modal__head--img{ grid-template-columns:1fr; gap:16px; }
  .modal__hero{ width:140px; height:140px; justify-self:center; }
  .modal__title{ font-size:28px; }
  .modal__cta{ padding:0 22px 22px; }
  .modal__meta{ grid-template-columns:1fr 1fr; }

  .price-grid{ grid-template-columns:1fr; gap:14px; }
  .price-group{ padding:22px; }

  .branches{ grid-template-columns:repeat(2,1fr); gap:12px; }
  .branch{ padding:18px; }

  .license__card{ grid-template-columns:1fr; }
  .license__preview{ border-right:0; border-bottom:1px solid var(--line); padding:32px 24px; }
  .license__body{ padding:28px 24px; }
  .license__notes{ grid-template-columns:1fr; gap:12px; }
  .license__meta{ grid-template-columns:1fr; gap:10px; }
}

/* phone — < 640 */
@media (max-width:640px){
  .container{ padding:0 18px; }
  .nav{ padding:10px 0; }
  .nav__inner{ padding:0 18px; gap:10px; }
  .brand__sub{ display:none; }
  .nav__cta{ gap:8px; }
  .btn--sm{ height:38px; padding:0 14px; font-size:13.5px; }

  .hero{ padding:32px 0 48px; }
  .hero__ctas{ flex-direction:column; align-items:stretch; gap:10px; margin-bottom:36px; }
  .hero__ctas .btn{ justify-content:center; width:100%; }
  .hero__stats{ grid-template-columns:1fr; gap:14px; padding-top:20px; }
  .stat__num{ font-size:24px; }
  .stat__label{ font-size:13px; }

  .visual__scene{ height:280px; border-radius:24px; }
  .visual{ gap:10px; grid-template-areas:
      "scene scene"
      "f1 f1"
      "f2 f2"
      "f3 f3"
      "f4 f4"; }
  .float{ padding:14px 16px; }
  .float__big{ font-size:28px; margin:6px 0 4px; }

  .hero__trust{
    grid-template-columns:1fr 1fr;
    gap:10px 12px;
    padding:14px;
    margin-top:32px;
    border-radius:18px;
    border:1px solid var(--line);
  }
  .trust__item{ font-size:13px; gap:8px; }
  .trust__item svg{ width:16px; height:16px; }

  .section{ padding:64px 0; }
  .section__head{ margin:0 auto 36px; }

  .h1{ font-size:clamp(34px,9vw,46px); }
  .h2{ font-size:clamp(28px,7.5vw,38px); }
  .lede, .section__lede, .about__lede{ font-size:16px; }

  .adv-grid{ grid-template-columns:1fr; gap:12px; }
  .adv{ padding:24px; }
  .adv h3{ font-size:19px; }

  .services{ grid-template-columns:1fr; gap:12px; }
  .service{ padding:24px; }
  .service h3{ font-size:20px; }

  .programs{ grid-template-columns:1fr; gap:12px; }
  .program{ padding:20px; }
  .program__visual{ height:160px; }
  .program__name{ font-size:20px; flex-wrap:wrap; }
  .program__price{ font-size:16px; }

  .branches{ grid-template-columns:1fr; gap:10px; }
  .branch{ padding:16px 18px; gap:12px; }
  .branch__addr{ font-size:14.5px; }

  .analysis summary{ padding:18px 18px; gap:12px; }
  .analysis__body{ padding:0 18px 18px; max-height:380px; }
  .analysis__head h4{ font-size:16px; }

  .timeline{ grid-template-columns:1fr; gap:14px; }
  .timeline__num{ width:48px; height:48px; font-size:13px; margin-bottom:14px; }
  .timeline__card{ padding:20px; }

  .about__photo--main{ aspect-ratio:5/4; }
  .about__photo--small{ aspect-ratio:16/10; }
  .about__badge{ left:14px; bottom:14px; right:14px; max-width:none; padding:12px 14px; }
  .badge__title{ font-size:13.5px; }
  .badge__sub{ font-size:12px; }
  .about__quote{ padding:20px; font-size:14px; }

  .reviews__nav{ gap:8px; }
  .round-btn{ width:42px; height:42px; }
  .review{ padding:22px; min-height:0; }
  .review__text{ font-size:15px; }

  .faq__item summary{ padding:18px 18px; font-size:15.5px; gap:12px; }
  .faq__body{ padding:0 18px 18px; }
  .faq__body p{ font-size:14.5px; }

  .cta{ padding:72px 0; }
  .cta__title{ font-size:clamp(30px,8vw,42px); }
  .cta__sub{ font-size:15.5px; margin-bottom:28px; }
  .cta__form{ padding:16px; border-radius:20px; }
  .cta__fields input, .cta__fields select{ height:48px; font-size:16px; /* 16px to prevent iOS auto-zoom */ }
  .cta__legal{ font-size:12px; }

  .footer{ padding:52px 0 24px; }
  .footer__grid{ grid-template-columns:1fr; gap:28px; padding-bottom:28px; }
  .footer__brand p{ max-width:none; }
  .footer__bottom{ flex-direction:column; gap:8px; align-items:flex-start; padding-top:20px; }

  .modal{ padding:12px; align-items:flex-end; }
  .modal__shell{ max-height:94vh; border-radius:22px 22px 16px 16px; }
  .modal__head{ padding:24px 20px 20px; border-radius:22px 22px 0 0; }
  .modal__title{ font-size:24px; }
  .modal__content{ padding:20px; }
  .modal__cta{ padding:0 20px 20px; }
  .modal__meta{ grid-template-columns:1fr; }
  .modal__price{ font-size:15px; padding:8px 14px; }
  .modal__old{ font-size:13px; }

  .program__prices{ gap:6px; }
  .program__old{ font-size:12px; }
  .program__price{ font-size:15.5px; }

  .license__body{ padding:24px 20px; }
  .license__title{ font-size:22px; }
  .license__doc{ width:160px; }
  .license__seal{ width:60px; height:60px; right:12px; bottom:12px; }
}

/* very small phone — < 380 */
@media (max-width:380px){
  .container{ padding:0 14px; }
  .nav__inner{ padding:0 14px; }
  .brand__logo{ height:34px; }
  .btn--lg{ height:54px; padding:0 22px; font-size:15px; }
  .h1{ font-size:32px; line-height:1.05; }
  .visual__scene{ height:240px; }
  .float__big{ font-size:26px; }
}

/* safe-area for iOS notch / gesture bar */
@supports(padding:max(0px)){
  .nav__inner{ padding-left:max(28px, env(safe-area-inset-left)); padding-right:max(28px, env(safe-area-inset-right)); }
  .container{ padding-left:max(28px, env(safe-area-inset-left)); padding-right:max(28px, env(safe-area-inset-right)); }
  @media (max-width:1080px){
    .container, .nav__inner{ padding-left:max(24px, env(safe-area-inset-left)); padding-right:max(24px, env(safe-area-inset-right)); }
  }
  @media (max-width:640px){
    .container, .nav__inner{ padding-left:max(18px, env(safe-area-inset-left)); padding-right:max(18px, env(safe-area-inset-right)); }
  }
}

/* prefers-reduced-motion */
@media (prefers-reduced-motion:reduce){
  *, *::before, *::after{
    animation-duration:.001ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.001ms !important;
    scroll-behavior:auto !important;
  }
  .reveal{ opacity:1; transform:none; }
  .scene__drop{ display:none; }
  .blob, .dark-blob, .cta__blob{ filter:blur(40px); }
}

/* touch-friendly hit areas */
@media (hover:none){
  .btn:hover{ transform:none; }
  .adv:hover{ transform:none; }
  .program:hover{ transform:none; }
  .nav__links a:hover{ background:transparent; }
}
