/* ============ ГИП-Сити — Landing ============ */
:root{
  /* type scale */
  --text-xs:clamp(.75rem,.7rem + .25vw,.875rem);
  --text-sm:clamp(.875rem,.8rem + .35vw,1rem);
  --text-base:clamp(1rem,.95rem + .25vw,1.0625rem);
  --text-lg:clamp(1.125rem,1rem + .6vw,1.375rem);
  --text-xl:clamp(1.5rem,1.2rem + 1.1vw,2.1rem);
  --text-2xl:clamp(2rem,1.3rem + 2.4vw,3.4rem);
  --text-3xl:clamp(2.6rem,1.4rem + 4vw,4.6rem);
  /* spacing */
  --s1:.25rem;--s2:.5rem;--s3:.75rem;--s4:1rem;--s5:1.25rem;--s6:1.5rem;
  --s8:2rem;--s10:2.5rem;--s12:3rem;--s16:4rem;--s20:5rem;--s24:6rem;--s32:8rem;
  /* radius / motion */
  --r-sm:8px;--r:14px;--r-lg:20px;--r-xl:28px;--r-full:999px;
  --tr:200ms cubic-bezier(.16,1,.3,1);
  --content:1180px;
  --font-body:'Inter','Helvetica Neue',sans-serif;
  --font-display:'Inter','Helvetica Neue',sans-serif;
}
/* ---- LIGHT (default) ---- */
:root,[data-theme="light"]{
  --bg:#f6f8f7; --surface:#ffffff; --surface-2:#f1f5f4; --surface-3:#e9efed;
  --border:rgba(13,40,38,.12); --divider:rgba(13,40,38,.08);
  --text:#0e2725; --text-muted:#566661; --text-faint:#8a988f;
  --text-inv:#f6f8f7;
  --primary:#01837a; --primary-h:#016b64; --primary-dim:rgba(1,131,122,.10);
  --primary-soft:rgba(1,131,122,.14);
  --accent:#E8843C; --accent-h:#d4711f; --accent-dim:rgba(232,132,60,.13);
  --ok:#1f8a55; --okBg:rgba(31,138,85,.12);
  --warn:#b9791a; --warnBg:rgba(185,121,26,.13);
  --err:#c5392f; --errBg:rgba(197,57,47,.12);
  --shadow-sm:0 1px 2px rgba(13,40,38,.06);
  --shadow:0 10px 30px rgba(13,40,38,.10);
  --shadow-lg:0 30px 70px rgba(13,40,38,.16);
  --hero-grid:rgba(1,131,122,.07);
  --frame:#dfe6e3;
}
/* ---- DARK ---- */
[data-theme="dark"]{
  --bg:#0c100f; --surface:#141816; --surface-2:#1a1f1d; --surface-3:#20272400;
  --border:rgba(255,255,255,.10); --divider:rgba(255,255,255,.06);
  --text:#e6e8e5; --text-muted:#9aa09b; --text-faint:#646b66;
  --text-inv:#0c100f;
  --primary:#2bbcb1; --primary-h:#3fcfc4; --primary-dim:rgba(43,188,177,.13);
  --primary-soft:rgba(43,188,177,.16);
  --accent:#f0974f; --accent-h:#f6ab6c; --accent-dim:rgba(240,151,79,.15);
  --ok:#4caf78; --okBg:rgba(76,175,120,.14);
  --warn:#e0a13a; --warnBg:rgba(224,161,58,.14);
  --err:#e0594f; --errBg:rgba(224,89,79,.14);
  --shadow-sm:0 1px 2px rgba(0,0,0,.4);
  --shadow:0 14px 36px rgba(0,0,0,.5);
  --shadow-lg:0 30px 80px rgba(0,0,0,.6);
  --hero-grid:rgba(43,188,177,.08);
  --frame:#222a27;
}
@media (prefers-color-scheme:dark){:root:not([data-theme]){color-scheme:dark}}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;scroll-behavior:smooth;scroll-padding-top:84px}
body{min-height:100dvh;font-family:var(--font-body);font-size:var(--text-base);
  line-height:1.6;color:var(--text);background:var(--bg);overflow-x:hidden}
img,svg,video{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{cursor:pointer;background:none;border:none;font:inherit;color:inherit}
h1,h2,h3,h4{line-height:1.12;letter-spacing:-.02em;text-wrap:balance;font-weight:700}
p{text-wrap:pretty}
::selection{background:var(--primary-soft)}
:focus-visible{outline:2px solid var(--primary);outline-offset:3px;border-radius:var(--r-sm)}
a,button,input,textarea{transition:color var(--tr),background var(--tr),border-color var(--tr),box-shadow var(--tr),transform var(--tr)}
.mono{font-variant-numeric:tabular-nums}

.wrap{width:100%;max-width:var(--content);margin-inline:auto;padding-inline:var(--s6)}
.eyebrow{display:inline-flex;align-items:center;gap:var(--s2);font-size:var(--text-xs);
  font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--primary)}
.section{padding-block:clamp(var(--s16),9vw,var(--s32))}
.section-head{max-width:720px;margin-bottom:var(--s12)}
.section-head.center{margin-inline:auto;text-align:center}
.section-head h2{font-size:var(--text-2xl);margin:var(--s4) 0 var(--s4)}
.section-head p{font-size:var(--text-lg);color:var(--text-muted);font-weight:400}

/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--s2);
  padding:13px 22px;border-radius:var(--r-full);font-size:var(--text-sm);font-weight:600;
  white-space:nowrap;border:1px solid transparent}
.btn svg{width:18px;height:18px}
.btn-primary{background:var(--primary);color:#fff}
.btn-primary:hover{background:var(--primary-h);transform:translateY(-2px);box-shadow:var(--shadow)}
.btn-accent{background:var(--accent);color:#fff}
.btn-accent:hover{background:var(--accent-h);transform:translateY(-2px);box-shadow:var(--shadow)}
.btn-ghost{background:transparent;color:var(--text);border-color:var(--border)}
.btn-ghost:hover{border-color:var(--primary);color:var(--primary)}
.btn-lg{padding:16px 30px;font-size:var(--text-base)}

/* ---------- HEADER ---------- */
.header{position:sticky;top:0;z-index:60;
  background:color-mix(in oklab,var(--bg) 82%,transparent);
  backdrop-filter:blur(14px);border-bottom:1px solid transparent;transition:border-color var(--tr),box-shadow var(--tr)}
.header.scrolled{border-color:var(--divider);box-shadow:var(--shadow-sm)}
.header .wrap{display:flex;align-items:center;justify-content:space-between;height:68px;padding-block:0}
.brand{display:flex;align-items:center;gap:11px;font-weight:700;font-size:var(--text-base);letter-spacing:-.01em;white-space:nowrap;flex:none}
.brand .logo{width:34px;height:34px;flex:none}
.nav-links{display:flex;align-items:center;gap:var(--s6)}
.nav-links a{font-size:var(--text-sm);font-weight:500;color:var(--text-muted)}
.nav-links a:hover{color:var(--text)}
.header-cta{display:flex;align-items:center;gap:var(--s3)}
.icon-btn{width:40px;height:40px;border-radius:var(--r-full);display:grid;place-items:center;
  color:var(--text-muted);border:1px solid var(--border)}
.icon-btn:hover{color:var(--primary);border-color:var(--primary)}
.burger{display:none}

/* ---------- HERO ---------- */
.hero{position:relative;padding-top:clamp(var(--s16),7vw,var(--s24));
  padding-bottom:clamp(var(--s12),5vw,var(--s20));overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;z-index:-1;
  background:
    radial-gradient(70% 55% at 70% -5%,var(--primary-dim),transparent 65%),
    linear-gradient(var(--hero-grid) 1px,transparent 1px),
    linear-gradient(90deg,var(--hero-grid) 1px,transparent 1px);
  background-size:auto,46px 46px,46px 46px;
  -webkit-mask-image:linear-gradient(180deg,#000 35%,transparent);
  mask-image:linear-gradient(180deg,#000 35%,transparent)}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(var(--s8),4vw,var(--s16));align-items:center}
.hero h1{font-size:var(--text-3xl);margin:var(--s5) 0}
.hero h1 .hl{color:var(--primary)}
.hero-lead{font-size:var(--text-lg);color:var(--text-muted);max-width:36ch;font-weight:400}
.hero-actions{display:flex;flex-wrap:wrap;gap:var(--s3);margin-top:var(--s8)}
.hero-trust{display:flex;flex-wrap:wrap;gap:var(--s5);margin-top:var(--s8);font-size:var(--text-sm);color:var(--text-muted)}
.hero-trust span{display:inline-flex;align-items:center;gap:7px}
.hero-trust svg{width:17px;height:17px;color:var(--ok);flex:none}

/* device frame */
.shot{border-radius:var(--r-lg);border:1px solid var(--frame);background:var(--surface);
  box-shadow:var(--shadow-lg);overflow:hidden}
.shot .bar{display:flex;align-items:center;gap:6px;padding:11px 14px;border-bottom:1px solid var(--divider);background:var(--surface-2)}
.shot .bar i{width:11px;height:11px;border-radius:50%;background:var(--text-faint);opacity:.5;display:block}
.shot .bar .url{margin-left:10px;font-size:12px;color:var(--text-faint);font-variant-numeric:tabular-nums}
.shot img{width:100%;display:block;background:var(--surface)}
.hero-shot{position:relative}
.hero-badge{position:absolute;bottom:-18px;left:-18px;background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r);box-shadow:var(--shadow);padding:12px 16px;display:flex;align-items:center;gap:11px;max-width:260px}
.hero-badge .dot{width:36px;height:36px;border-radius:10px;background:var(--accent-dim);color:var(--accent);display:grid;place-items:center;flex:none}
.hero-badge .dot svg{width:20px;height:20px}
.hero-badge b{font-size:var(--text-sm);display:block}
.hero-badge small{font-size:var(--text-xs);color:var(--text-muted)}

/* ---------- LOGOS / STATS STRIP ---------- */
.strip{border-block:1px solid var(--divider);background:var(--surface)}
.strip .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--s6);padding-block:var(--s10)}
.stat{text-align:center}
.stat b{display:block;font-size:var(--text-2xl);color:var(--primary);letter-spacing:-.03em;line-height:1}
.stat span{font-size:var(--text-sm);color:var(--text-muted);margin-top:6px;display:block}

/* ---------- PROBLEM ---------- */
.problem-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--s8)}
.before,.after{border-radius:var(--r-lg);padding:var(--s8);border:1px solid var(--border)}
.before{background:var(--surface)}
.after{background:var(--primary);color:#fff;border-color:transparent}
.before h3,.after h3{font-size:var(--text-lg);margin-bottom:var(--s5);display:flex;align-items:center;gap:10px}
.plist{list-style:none;display:flex;flex-direction:column;gap:var(--s4)}
.plist li{display:flex;gap:11px;font-size:var(--text-sm);line-height:1.5}
.plist li svg{width:20px;height:20px;flex:none;margin-top:1px}
.before .plist svg{color:var(--err)}
.after .plist svg{color:#fff}
.after .plist li{color:rgba(255,255,255,.92)}

/* ---------- AUDIENCE ---------- */
.aud-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s6)}
.aud{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:var(--s8);transition:transform var(--tr),box-shadow var(--tr),border-color var(--tr)}
.aud:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--primary)}
.aud .ico{width:52px;height:52px;border-radius:14px;background:var(--primary-dim);color:var(--primary);display:grid;place-items:center;margin-bottom:var(--s5)}
.aud .ico svg{width:26px;height:26px}
.aud h3{font-size:var(--text-lg);margin-bottom:var(--s3)}
.aud p{font-size:var(--text-sm);color:var(--text-muted)}

/* ---------- FEATURES (alternating) ---------- */
.feature{display:grid;grid-template-columns:1fr 1fr;gap:clamp(var(--s8),5vw,var(--s20));align-items:center;
  padding-block:clamp(var(--s12),6vw,var(--s24))}
.feature:not(:last-child){border-bottom:1px solid var(--divider)}
.feature.rev .f-text{order:2}
.f-text .eyebrow{margin-bottom:var(--s4)}
.f-text h3{font-size:var(--text-xl);margin-bottom:var(--s5)}
.f-text p{color:var(--text-muted);margin-bottom:var(--s6)}
.f-list{list-style:none;display:flex;flex-direction:column;gap:var(--s3)}
.f-list li{display:flex;gap:10px;font-size:var(--text-sm)}
.f-list li svg{width:19px;height:19px;color:var(--primary);flex:none;margin-top:2px}

/* status chips */
.chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:var(--s6)}
.chip{font-size:var(--text-xs);font-weight:600;padding:5px 11px;border-radius:var(--r-full)}
.chip.ok{background:var(--okBg);color:var(--ok)}
.chip.warn{background:var(--warnBg);color:var(--warn)}
.chip.err{background:var(--errBg);color:var(--err)}
.chip.pri{background:var(--primary-dim);color:var(--primary)}

/* ---------- CAPABILITIES GRID ---------- */
.cap-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s5)}
.cap{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:var(--s6);transition:transform var(--tr),border-color var(--tr)}
.cap:hover{transform:translateY(-3px);border-color:var(--primary)}
.cap .ico{width:44px;height:44px;border-radius:12px;background:var(--accent-dim);color:var(--accent);display:grid;place-items:center;margin-bottom:var(--s4)}
.cap .ico svg{width:22px;height:22px}
.cap h4{font-size:var(--text-base);margin-bottom:7px}
.cap p{font-size:var(--text-sm);color:var(--text-muted)}

/* ---------- SCREEN GALLERY ---------- */
.gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--s8)}
.gcard .shot{margin-bottom:var(--s4)}
.gcard h4{font-size:var(--text-base);margin-bottom:4px}
.gcard p{font-size:var(--text-sm);color:var(--text-muted)}

/* ---------- SECURITY ---------- */
.sec{background:var(--surface)}
.sec-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--s5)}
.sec-card{padding:var(--s6);border:1px solid var(--border);border-radius:var(--r);background:var(--bg)}
.sec-card .ico{color:var(--primary);margin-bottom:var(--s4)}
.sec-card .ico svg{width:26px;height:26px}
.sec-card h4{font-size:var(--text-base);margin-bottom:7px}
.sec-card p{font-size:var(--text-xs);color:var(--text-muted)}

/* ---------- PRICING ---------- */
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s6);align-items:stretch}
.plan{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:var(--s8);display:flex;flex-direction:column}
.plan.feat{border-color:var(--primary);box-shadow:var(--shadow);position:relative}
.plan.feat::before{content:"Популярный";position:absolute;top:-13px;left:50%;transform:translateX(-50%);
  background:var(--accent);color:#fff;font-size:var(--text-xs);font-weight:700;padding:5px 14px;border-radius:var(--r-full)}
.plan h3{font-size:var(--text-lg);margin-bottom:6px}
.plan .desc{font-size:var(--text-sm);color:var(--text-muted);min-height:40px}
.plan .price{margin:var(--s5) 0;font-size:var(--text-xl);font-weight:700}
.plan .price small{font-size:var(--text-sm);color:var(--text-muted);font-weight:500}
.plan ul{list-style:none;display:flex;flex-direction:column;gap:var(--s3);margin-bottom:var(--s8);flex:1}
.plan ul li{display:flex;gap:10px;font-size:var(--text-sm)}
.plan ul li svg{width:18px;height:18px;color:var(--primary);flex:none;margin-top:2px}
.price-note{text-align:center;margin-top:var(--s8);font-size:var(--text-sm);color:var(--text-muted)}

/* ---------- FAQ ---------- */
.faq{max-width:780px;margin-inline:auto}
.q{border-bottom:1px solid var(--divider)}
.q summary{display:flex;justify-content:space-between;align-items:center;gap:var(--s4);
  padding:var(--s5) 0;font-size:var(--text-base);font-weight:600;cursor:pointer;list-style:none}
.q summary::-webkit-details-marker{display:none}
.q summary .pm{width:24px;height:24px;flex:none;color:var(--primary);transition:transform var(--tr)}
.q[open] summary .pm{transform:rotate(45deg)}
.q p{padding-bottom:var(--s5);color:var(--text-muted);font-size:var(--text-sm);max-width:none}

/* ---------- CTA BANNER ---------- */
.cta{position:relative;overflow:hidden;border-radius:var(--r-xl);background:var(--primary);color:#fff;
  padding:clamp(var(--s12),6vw,var(--s24)) var(--s8);text-align:center}
.cta::before{content:"";position:absolute;inset:0;
  background:radial-gradient(60% 80% at 80% 0%,rgba(255,255,255,.12),transparent 60%),
  radial-gradient(50% 70% at 10% 100%,rgba(232,132,60,.30),transparent 60%)}
.cta>*{position:relative}
.cta h2{font-size:var(--text-2xl);margin-bottom:var(--s4)}
.cta p{font-size:var(--text-lg);color:rgba(255,255,255,.9);max-width:48ch;margin:0 auto var(--s8);font-weight:400}
.cta .btn-accent{background:#fff;color:var(--primary)}
.cta .btn-accent:hover{background:#fff;color:var(--primary-h)}
.cta .btn-ghost{border-color:rgba(255,255,255,.4);color:#fff}
.cta .btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.1);color:#fff}
.cta-actions{display:flex;flex-wrap:wrap;gap:var(--s3);justify-content:center}

/* ---------- FOOTER ---------- */
.footer{border-top:1px solid var(--divider);background:var(--surface);padding-block:var(--s16) var(--s10)}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:var(--s8);margin-bottom:var(--s12)}
.footer .brand{margin-bottom:var(--s4)}
.footer-about{font-size:var(--text-sm);color:var(--text-muted);max-width:34ch}
.footer h5{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.1em;color:var(--text-faint);margin-bottom:var(--s4)}
.footer-col a,.footer-col p{display:block;font-size:var(--text-sm);color:var(--text-muted);margin-bottom:10px}
.footer-col a:hover{color:var(--primary)}
.footer-legal{border-top:1px solid var(--divider);padding-top:var(--s6);display:flex;flex-wrap:wrap;justify-content:space-between;gap:var(--s4);
  font-size:var(--text-xs);color:var(--text-faint)}

/* reveal */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1)}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none}}

/* ---------- RESPONSIVE ---------- */
@media(max-width:960px){
  .hero-grid{grid-template-columns:1fr;gap:var(--s12)}
  .hero-lead{max-width:none}
  .strip .wrap{grid-template-columns:repeat(2,1fr);gap:var(--s8)}
  .problem-grid,.cap-grid,.sec-grid,.gallery,.price-grid,.aud-grid{grid-template-columns:1fr}
  .cap-grid,.sec-grid{grid-template-columns:repeat(2,1fr)}
  .feature{grid-template-columns:1fr;gap:var(--s8)}
  .feature.rev .f-text{order:0}
  .footer-grid{grid-template-columns:1fr 1fr}
  .nav-links{display:none}
}
@media(max-width:560px){
  .cap-grid,.sec-grid,.footer-grid{grid-template-columns:1fr}
  .header-cta .btn:not(.header-reg){display:none}
  .header-reg{padding:11px 16px;font-size:var(--text-xs)}
  .header .wrap{gap:var(--s3)}
  .hero-badge{display:none}
}
