@charset "UTF-8";
/* ═══════════════════════════════════════════════════════════════════
   Qiangrun — shared site stylesheet
   Industrial reskin: warm graphite / raw-iron base (#1a1816 →
   #221f1c → #2b2723), molten-orange (#f26b1d) as the single FUNCTIONAL
   accent (active / CTA / brand), pill + circle geometry, compact bold
   type, heavy shadows for elevation on dark.

   Ported from the former warm-white index stylesheet; every "inverted"
   dark panel (topbar / inquiry / footer / captions) has been rebuilt
   for a dark base instead of being driven by var(--fg). Layout grids,
   spacing and breakpoints are unchanged so HTML positions stay put.

   Token contract: design-systems/spotify/tokens.css (:root verbatim).
   ═══════════════════════════════════════════════════════════════════ */

/* ── Industrial tokens (dark steel base + molten-orange accent) ────────────────── */
:root{
  --bg:#1a1816;
  --surface:#221f1c;
  --surface-warm:#2b2723;

  --fg:#f3f0ea;
  --fg-2:#ffffff;
  --muted:#a39c92;
  --meta:#c6bfb4;

  --border:#3a342c;
  --border-soft:rgba(255,255,255,0.07);

  --accent:#f26b1d;
  --accent-on:#1a1206;
  --accent-hover:#ff7e34;
  --accent-active:color-mix(in oklab, var(--accent), black 12%);

  --success:#54b06e;
  --warn:#e0b341;
  --danger:#d65a4d;

  --font-display:"SpotifyMixUITitle","CircularSp","Helvetica Neue",Helvetica,Arial,sans-serif;
  --font-body:"SpotifyMixUI","CircularSp","Helvetica Neue",Helvetica,Arial,sans-serif;
  --font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;

  --text-xs:10px; --text-sm:12px; --text-base:16px; --text-lg:18px;
  --text-xl:20px; --text-2xl:24px; --text-3xl:24px; --text-4xl:24px;

  --leading-body:1.50; --leading-tight:1.00; --tracking-display:normal;

  --space-1:4px; --space-2:8px; --space-3:12px; --space-4:16px;
  --space-5:20px; --space-6:24px; --space-8:32px; --space-12:48px;

  --section-y-desktop:64px; --section-y-tablet:40px; --section-y-phone:24px;

  --radius-sm:2px; --radius-md:2px; --radius-lg:3px; --radius-pill:2px;

  --elev-flat:none;
  --elev-ring:0 0 0 1px var(--border);
  --elev-raised:rgba(0,0,0,0.5) 0 3px 9px;

  --focus-ring:0 0 0 3px rgba(242,107,29,0.42);

  --motion-fast:150ms; --motion-base:200ms; --ease-standard:ease;

  --container-max:1280px;
  --container-gutter-desktop:24px; --container-gutter-tablet:16px; --container-gutter-phone:16px;
}

/* ── aliases consumed by the ported class system ────────────────────── */
:root{
  --surface-2:var(--surface-warm);   /* #2b2723 lifted surface / button bg */
  --fg-soft:var(--meta);             /* #cbcbcb near-white */
  --line:var(--border-soft);         /* hairline on dark */
  --line-2:var(--border);            /* #4d4d4d stronger rule */
  --accent-ink:var(--accent-on);     /* black text on green */
  --accent-deep:var(--accent-hover); /* green hover */
  --shadow-pop:rgba(0,0,0,0.6) 0 6px 18px;    /* dialog / dropdown — tight matte */
  --maxw:1240px;
  --gutter:clamp(16px,4.2vw,44px);
  --sec-y:clamp(52px,7vw,100px);
}

/* ── base ───────────────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--fg);font-family:var(--font-body);font-size:16px;line-height:1.55;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img{display:block;max-width:100%}
a{color:var(--fg);text-decoration:none}
h1,h2,h3,h4{margin:0;font-family:var(--font-display);font-weight:700;line-height:1.08;letter-spacing:-0.01em}
p{margin:0}
button,input,select,textarea{font:inherit;color:inherit}
:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
::selection{background:var(--accent);color:var(--accent-on)}

/* ── layout helpers ─────────────────────────────────────────────────── */
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--gutter)}
.mono{font-family:var(--font-mono)}
.tnum{font-variant-numeric:tabular-nums}

.kicker{display:inline-flex;align-items:center;gap:10px;font-family:var(--font-mono);font-size:12px;font-weight:600;letter-spacing:0.14em;text-transform:uppercase;color:var(--muted)}
.kicker .idx{color:var(--accent)}

.sec{padding-block:var(--sec-y)}
.sec-head{display:grid;grid-template-columns:1fr auto;align-items:end;gap:24px 40px;padding-top:18px;border-top:1px solid var(--border);margin-bottom:clamp(28px,4vw,52px)}
.sec-head h2{font-size:clamp(28px,4.4vw,46px);max-width:18ch;margin-top:14px}
.sec-head .lead{color:var(--muted);font-size:clamp(15px,1.4vw,18px);max-width:46ch;margin-top:14px}
.sec-link{font-family:var(--font-mono);font-size:12px;font-weight:600;letter-spacing:0.1em;text-transform:uppercase;white-space:nowrap;border-bottom:1px solid currentColor;padding-bottom:3px;transition:color var(--motion-fast)}
.sec-link::after{content:" →"}
.sec-link:hover{color:var(--accent)}
@media (max-width:700px){.sec-head{grid-template-columns:1fr}.sec-link{justify-self:start}}

/* ── buttons (pill) ─────────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;min-height:46px;padding:0 26px;font-family:var(--font-body);font-weight:700;font-size:14px;letter-spacing:0.12em;text-transform:uppercase;border:1px solid transparent;border-radius:var(--radius-pill);cursor:pointer;transition:background var(--motion-fast),color var(--motion-fast),border-color var(--motion-fast),transform var(--motion-fast)}
.btn-primary{background:var(--accent);border-color:var(--accent);color:var(--accent-on)}
.btn-primary:hover{background:var(--accent-hover);border-color:var(--accent-hover);transform:scale(1.03)}
.btn-ghost{background:transparent;color:var(--fg);border-color:color-mix(in oklab,var(--fg),transparent 70%)}
.btn-ghost:hover{background:color-mix(in oklab,var(--fg),transparent 90%);border-color:var(--fg)}
.btn-arrow::after{content:"→";font-family:var(--font-body)}
.link-arrow{display:inline-flex;align-items:center;gap:7px;font-family:var(--font-mono);font-size:12.5px;font-weight:600;letter-spacing:0.08em;text-transform:uppercase;border-bottom:1px solid var(--fg);padding-bottom:2px;transition:color var(--motion-fast),border-color var(--motion-fast)}
.link-arrow::after{content:"→"}
.link-arrow:hover{color:var(--accent);border-color:var(--accent)}

/* ── topbar (dark, was inverted) ────────────────────────────────────── */
.topbar{background:#0e0f12;color:var(--muted)}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;gap:16px;min-height:38px;font-family:var(--font-mono);font-size:12px}
.topbar a{color:inherit}
.topbar a:hover{color:var(--fg)}
.topbar-l{display:flex;gap:22px;align-items:center}
.topbar-langs{display:flex;gap:12px}
.topbar-langs span{cursor:pointer;opacity:.55}
.topbar-langs span:hover{opacity:1}
.topbar-langs .on{opacity:1;color:var(--fg)}
@media (max-width:720px){.topbar-l .opt{display:none}}

/* ── topnav + mega ──────────────────────────────────────────────────── */
.nav{position:sticky;top:0;z-index:60;background:color-mix(in oklab,var(--surface),transparent 8%);-webkit-backdrop-filter:saturate(140%) blur(10px);backdrop-filter:saturate(140%) blur(10px);border-bottom:1px solid var(--border)}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;min-height:70px;gap:20px}
.brand{display:flex;align-items:center;gap:12px}
.brand-mark{width:36px;height:36px;background:var(--accent);color:var(--accent-on);border-radius:var(--radius-md);display:grid;place-items:center;font-family:var(--font-mono);font-weight:700;font-size:14px;letter-spacing:-0.02em}
.brand-name{font-family:var(--font-display);font-weight:700;font-size:18px;line-height:1.05}
.brand-sub{display:block;font-family:var(--font-mono);font-size:11px;font-weight:500;color:var(--muted);letter-spacing:0.02em;text-transform:none}
.nav-main{display:flex;align-items:stretch;gap:4px}
.nav-main>a,.nav-item>a{display:inline-flex;align-items:center;gap:6px;height:70px;padding-inline:14px;font-family:var(--font-body);font-weight:700;font-size:13.5px;letter-spacing:0.04em;text-transform:uppercase;transition:color var(--motion-fast)}
.nav-main>a:hover,.nav-item>a:hover,.nav-main a.on{color:var(--accent)}
.nav-item{position:relative;display:inline-flex;align-items:center}
.nav-item.mega>a::after{content:"";width:6px;height:6px;border-right:1.5px solid currentColor;border-bottom:1.5px solid currentColor;transform:rotate(45deg) translateY(-2px);opacity:.55}
.nav-cta{display:flex;align-items:center;gap:10px}
.nav-cta .btn{min-height:42px}
.burger{display:none}
/* nav unify fix — .nav-item.mega wrapper must not absorb dropdown-panel (.mega) styling */
.nav .nav-item.mega{position:relative;inset:auto;width:auto;min-width:0;padding:0;background:none;border:0;border-radius:0;box-shadow:none;opacity:1;transform:none;pointer-events:auto;z-index:auto}
/* desktop: anchor dropdown panel to the bar/container so a wide panel never overflows the viewport */
@media (min-width:1041px){.nav .nav-item.mega{position:static}.nav .nav-item.mega>.mega{left:max(16px,calc((100vw - 1200px) / 2));right:max(16px,calc((100vw - 1200px) / 2));width:auto}}

.mega{position:absolute;top:70px;left:0;width:min(900px,calc(100vw - 2*var(--gutter)));background:var(--surface-2);border:1px solid var(--border);border-top:2px solid var(--accent);border-radius:0 0 var(--radius-lg) var(--radius-lg);box-shadow:var(--shadow-pop);padding:22px;opacity:0;pointer-events:none;transform:translateY(7px);transition:opacity var(--motion-fast),transform var(--motion-fast);z-index:80}
.mega::before{content:"";position:absolute;left:0;right:0;top:-16px;height:16px}
.nav-item:hover .mega,.nav-item:focus-within .mega{opacity:1;pointer-events:auto;transform:translateY(0)}
.mega-grid{display:grid;grid-template-columns:1.15fr 1fr 1fr;gap:20px}
.mega-feat{display:flex;flex-direction:column;border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden;background:var(--surface);transition:border-color var(--motion-fast),box-shadow var(--motion-fast)}
.mega-feat:hover{border-color:var(--muted);box-shadow:var(--elev-raised)}
.mega-feat-img{aspect-ratio:16/10;overflow:hidden;background:var(--bg)}
.mega-feat-img img{width:100%;height:100%;object-fit:cover;filter:contrast(1.03) saturate(.95)}
.mega-feat-txt{padding:14px 16px 16px;display:flex;flex-direction:column;gap:6px}
.mega-feat-txt strong{font-family:var(--font-display);font-size:17px;letter-spacing:-0.01em}
.mega-feat-txt p{color:var(--muted);font-size:13px;line-height:1.45}
.mega-col h4{font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:0.1em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.mega-col a{display:flex;justify-content:space-between;gap:14px;padding:9px 0;border-top:1px solid var(--line);font-size:14px;font-weight:500}
.mega-col a:hover{color:var(--accent)}
.mega-col a span{font-family:var(--font-mono);font-size:11px;color:var(--muted);white-space:nowrap}
.mega-note{grid-column:span 1;background:var(--accent);color:var(--accent-on);border-radius:var(--radius-md);padding:16px;display:flex;flex-direction:column;gap:8px;font-weight:600;transition:background var(--motion-fast)}
.mega-note:hover{background:var(--accent-hover);color:var(--accent-on)}
.mega-note .k{font-family:var(--font-mono);font-size:11px;letter-spacing:0.1em;text-transform:uppercase;color:color-mix(in oklab,var(--accent-on),transparent 38%)}

/* ── hero / equipment carousel ──────────────────────────────────────── */
.hero{padding-block:clamp(38px,5.8vw,72px) clamp(30px,3.2vw,44px)}
.hero-grid{display:grid;grid-template-columns:minmax(0,.88fr) minmax(520px,1.12fr);gap:clamp(30px,4.8vw,70px);align-items:center}
.hero h1{font-size:clamp(40px,6.4vw,80px);line-height:0.98;letter-spacing:-0.035em}
.hero h1 .l2{color:var(--muted)}
.hero h1 u{text-decoration:none;box-shadow:inset 0 -0.13em 0 var(--accent)}
.hero-lead{margin-top:26px;max-width:50ch;color:var(--muted);font-size:clamp(15px,1.5vw,18px)}
.hero-cta{display:flex;flex-wrap:wrap;gap:12px;margin-top:30px}
.hero-trust{margin-top:26px;display:flex;flex-wrap:wrap;gap:10px 18px;font-family:var(--font-mono);font-size:12px;letter-spacing:0.04em;color:var(--fg-soft)}
.hero-trust span{display:inline-flex;align-items:center;gap:18px}
.hero-trust span::after{content:"·";color:var(--border)}
.hero-trust span:last-child::after{content:""}
.hero-carousel{position:relative;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface-2);min-height:clamp(420px,42vw,620px);overflow:hidden}
.hero-carousel::before{content:"";position:absolute;inset:0;z-index:2;pointer-events:none;border-radius:inherit;box-shadow:inset 0 0 0 1px var(--border-soft)}
.hero-slide{position:absolute;inset:0;opacity:0;visibility:hidden;transition:opacity .35s ease}
.hero-slide.on{opacity:1;visibility:visible}
.hero-slide img{width:100%;height:100%;object-fit:cover;filter:contrast(1.05) saturate(.95)}
.hero-caption{position:absolute;left:0;right:96px;bottom:0;z-index:3;display:grid;gap:8px;background:color-mix(in oklab,#000,transparent 12%);color:var(--fg);padding:clamp(16px,2vw,24px)}
.hero-caption .ey{font-family:var(--font-mono);font-size:11px;letter-spacing:0.12em;text-transform:uppercase;color:color-mix(in oklab,var(--fg),transparent 42%)}
.hero-caption strong{font-family:var(--font-display);font-size:clamp(20px,2.2vw,30px);line-height:1.08;letter-spacing:-0.025em}
.hero-controls{position:absolute;z-index:4;right:0;bottom:0;display:grid;grid-template-columns:repeat(2,48px);grid-auto-rows:48px;border-left:1px solid color-mix(in oklab,var(--fg),transparent 82%);border-top:1px solid color-mix(in oklab,var(--fg),transparent 82%)}
.hero-ctrl{display:grid;place-items:center;width:48px;height:48px;background:color-mix(in oklab,#000,transparent 22%);border:0;border-right:1px solid color-mix(in oklab,var(--fg),transparent 84%);color:var(--fg);cursor:pointer;font-family:var(--font-mono);font-size:18px;line-height:1;transition:background var(--motion-fast),color var(--motion-fast)}
.hero-ctrl:hover,.hero-ctrl:focus-visible{background:var(--accent);color:var(--accent-on);outline:0}
.hero-dots{position:absolute;z-index:4;top:16px;right:16px;display:grid;gap:8px}
.hero-dot{width:46px;height:34px;display:grid;place-items:center;border:1px solid color-mix(in oklab,var(--fg),transparent 64%);background:color-mix(in oklab,#000,transparent 30%);color:var(--fg);cursor:pointer;font-family:var(--font-mono);font-size:11px;letter-spacing:0.08em;border-radius:var(--radius-md)}
.hero-dot.on{background:var(--accent);border-color:var(--accent);color:var(--accent-on)}
@media (max-width:920px){.hero-grid{grid-template-columns:1fr;gap:28px}.hero-carousel{min-height:auto;aspect-ratio:16/11;order:-1}.hero-caption{right:0;padding-right:112px}}
@media (max-width:560px){.hero-carousel{aspect-ratio:4/5}.hero-caption{right:0;padding:14px;padding-bottom:62px}.hero-dots{top:10px;right:10px;gap:6px}.hero-dot{width:38px;height:30px}.hero-controls{grid-template-columns:repeat(2,46px);grid-auto-rows:46px}.hero-ctrl{width:46px;height:46px}}

/* ── full-screen home hero — carousel as full-bleed backdrop ─────────── */
.hero-full{position:relative;display:flex;align-items:flex-end;min-height:max(560px,calc(100svh - 108px));padding:0;overflow:hidden;background:#000;isolation:isolate}
.hero-full .hero-carousel{position:absolute;inset:0;z-index:0;min-height:0;border:0;border-radius:0;background:#000;aspect-ratio:auto}
.hero-full .hero-carousel::before{display:none}
.hero-full .hero-slide{transition:opacity .6s ease}
.hero-full .hero-slide img{filter:contrast(1.05) saturate(.9) brightness(.9)}
.hero-full .hero-slide::after{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;background:linear-gradient(to top,color-mix(in oklab,#000,transparent 6%),color-mix(in oklab,#000,transparent 40%) 30%,color-mix(in oklab,#000,transparent 80%) 62%,transparent 100%),linear-gradient(to right,color-mix(in oklab,#000,transparent 26%),transparent 54%)}
.hero-full .hero-overlay{position:relative;z-index:3;width:100%;padding-block:clamp(36px,6.4vh,92px)}
.hero-full .hero-overlay .wrap{display:grid;justify-items:start}
.hero-full .hero-overlay .kicker{color:var(--accent)}
.hero-full .hero-overlay h1{margin-top:18px;font-size:clamp(40px,6.2vw,82px);color:#fff;max-width:17ch}
.hero-full .hero-overlay h1 .l2{color:color-mix(in oklab,#fff,transparent 24%)}
.hero-full .hero-overlay h1 u{box-shadow:inset 0 -0.13em 0 var(--accent)}
.hero-full .hero-overlay .hero-lead{color:color-mix(in oklab,#fff,transparent 14%);max-width:56ch}
.hero-full .hero-overlay .hero-trust{color:color-mix(in oklab,#fff,transparent 32%)}
.hero-full .hero-overlay .hero-trust span::after{color:color-mix(in oklab,#fff,transparent 64%)}
.hero-full .hero-caption{left:auto;right:0;bottom:56px;width:auto;max-width:min(420px,44vw);background:color-mix(in oklab,#000,transparent 24%);-webkit-backdrop-filter:blur(7px);backdrop-filter:blur(7px);border-left:2px solid var(--accent);color:#fff;padding:13px 20px;z-index:2}
.hero-full .hero-caption .ey{color:color-mix(in oklab,#fff,transparent 40%)}
.hero-full .hero-caption strong{font-size:clamp(15px,1.4vw,20px)}
.hero-full .hero-dots{z-index:4}
.hero-full .hero-controls{z-index:4}
@media (max-width:1180px){.hero-full .hero-caption{display:none}}
@media (max-width:920px){.hero-full{min-height:max(520px,calc(100svh - 96px))}.hero-full .hero-overlay h1{max-width:none}}
@media (max-width:560px){.hero-full{min-height:max(470px,calc(100svh - 88px))}.hero-full .hero-overlay .hero-lead{max-width:none}}

/* ── stat strip ─────────────────────────────────────────────────────── */
.stats{border-block:1px solid var(--border)}
.stats .wrap{display:grid;grid-template-columns:repeat(4,1fr)}
.stat{padding:clamp(24px,3vw,38px) 0;padding-right:28px;border-left:1px solid var(--line);margin-left:-1px;padding-left:28px}
.stat:first-child{border-left:0;padding-left:0;margin-left:0}
.stat-n{font-family:var(--font-display);font-weight:700;font-size:clamp(34px,4.6vw,56px);line-height:1;letter-spacing:-0.035em}
.stat-n sup{font-size:0.42em;font-weight:650;vertical-align:super;margin-left:1px;color:var(--accent)}
.stat-l{margin-top:12px;font-family:var(--font-mono);font-size:12px;letter-spacing:0.04em;color:var(--muted);line-height:1.4}
@media (max-width:760px){.stats .wrap{grid-template-columns:1fr 1fr}.stat{padding-inline:22px}.stat:nth-child(odd){border-left:0;padding-left:0;margin-left:0}.stat:nth-child(n+3){border-top:1px solid var(--line)}}
@media (max-width:420px){.stats .wrap{grid-template-columns:1fr}.stat{border-left:0;padding-left:0;margin-left:0;padding-block:22px}.stat:not(:first-child){border-top:1px solid var(--line)}}

/* ── product families ───────────────────────────────────────────────── */
.fam-grid{display:grid;grid-template-columns:1.08fr 0.92fr;gap:clamp(24px,3vw,44px);align-items:stretch}
.fam-feat{display:flex;flex-direction:column;border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;background:var(--surface);transition:border-color var(--motion-fast),box-shadow var(--motion-fast)}
.fam-feat:hover{border-color:var(--muted);box-shadow:var(--elev-raised)}
.fam-feat-img{aspect-ratio:16/10;overflow:hidden;background:var(--surface-2)}
.fam-feat-img img{width:100%;height:100%;object-fit:cover;filter:contrast(1.04) saturate(.95)}
.fam-feat-body{padding:clamp(20px,2.4vw,30px);display:flex;flex-direction:column;gap:12px;flex:1}
.fam-feat-body .tag{font-family:var(--font-mono);font-size:11px;letter-spacing:0.12em;text-transform:uppercase;color:var(--accent)}
.fam-feat-body h3{font-size:clamp(24px,2.8vw,34px)}
.fam-feat-body p{color:var(--muted);font-size:15px}
.fam-feat-body .link-arrow{margin-top:auto;align-self:flex-start}
.fam-list{display:flex;flex-direction:column;border-top:1px solid var(--border)}
.fam-row{display:grid;grid-template-columns:44px 1fr auto;align-items:center;gap:16px;padding:clamp(18px,2vw,26px) 4px;border-bottom:1px solid var(--line-2);transition:padding-left var(--motion-fast),color var(--motion-fast)}
.fam-row:hover{padding-left:12px;color:var(--accent)}
.fam-row .ri{font-family:var(--font-mono);font-size:13px;color:var(--muted)}
.fam-row:hover .ri{color:var(--accent)}
.fam-row h3{font-size:clamp(18px,2vw,23px);letter-spacing:-0.015em}
.fam-row .rr{font-family:var(--font-mono);font-size:12px;color:var(--muted);text-align:right;line-height:1.3}
.fam-row:hover .rr{color:inherit}
@media (max-width:880px){.fam-grid{grid-template-columns:1fr}}
@media (max-width:460px){.fam-row{grid-template-columns:32px 1fr}.fam-row .rr{grid-column:2;text-align:left;margin-top:4px}}

/* ── selected equipment (flagship + catalogue rows) ─────────────────── */
.flag{display:grid;width:100%;min-width:0;grid-template-columns:1.1fr 0.9fr;border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;background:var(--surface);margin-bottom:28px}
.flag>*{min-width:0}
.flag-img{overflow:hidden;background:var(--surface-2);min-height:280px;min-width:0}
.flag-img img{width:100%;height:100%;object-fit:cover;filter:contrast(1.04) saturate(.95)}
.flag-body{padding:clamp(24px,3vw,40px);display:flex;flex-direction:column;gap:16px}
.flag-body .tag{display:inline-flex;align-self:flex-start;gap:8px;font-family:var(--font-mono);font-size:11px;letter-spacing:0.12em;text-transform:uppercase;background:var(--accent);color:var(--accent-on);padding:5px 12px;border-radius:var(--radius-pill)}
.flag-body h3{font-size:clamp(26px,3.2vw,40px)}
.flag-body p{color:var(--muted);font-size:15px;max-width:44ch}
.flag-specs{display:grid;grid-template-columns:repeat(2,1fr);border-top:1px solid var(--line);margin-top:4px}
.flag-specs div{padding:12px 0;border-bottom:1px solid var(--line)}
.flag-specs div:nth-child(odd){padding-right:18px}
.flag-specs div:nth-child(even){padding-left:18px;border-left:1px solid var(--line)}
.flag-specs dt{font-family:var(--font-mono);font-size:11px;letter-spacing:0.06em;text-transform:uppercase;color:var(--muted)}
.flag-specs dd{margin:4px 0 0;font-family:var(--font-display);font-weight:700;font-size:18px;letter-spacing:-0.02em}
.flag-body .btn{align-self:flex-start;margin-top:4px}
@media (max-width:820px){.flag{grid-template-columns:1fr}.flag-img{min-height:0;aspect-ratio:16/9}}

.cat-list{border-top:1px solid var(--border)}
.cat-row{display:grid;grid-template-columns:96px 1fr auto auto;align-items:center;gap:clamp(14px,2vw,28px);padding:18px 4px;border-bottom:1px solid var(--line);transition:padding-left var(--motion-fast)}
.cat-row:hover{padding-left:12px}
.cat-thumb{width:96px;height:66px;overflow:hidden;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-md)}
.cat-thumb img{width:100%;height:100%;object-fit:cover;filter:contrast(1.04) saturate(.95)}
.cat-name h3{font-size:clamp(17px,1.9vw,22px);letter-spacing:-0.015em}
.cat-name p{color:var(--muted);font-size:13px;margin-top:3px}
.cat-specs{display:flex;gap:18px;font-family:var(--font-mono);font-size:12px;color:var(--muted)}
.cat-specs b{color:var(--fg);font-weight:650}
.cat-row .go{font-family:var(--font-mono);font-size:12px;font-weight:600;letter-spacing:0.06em;text-transform:uppercase;color:var(--muted);white-space:nowrap}
.cat-row:hover .go{color:var(--accent)}
.cat-row .go::after{content:" →"}
@media (max-width:920px){.cat-specs{display:none}}
@media (max-width:560px){.cat-row{grid-template-columns:72px 1fr;row-gap:6px}.cat-thumb{width:72px;height:54px}.cat-row .go{grid-column:2}}

/* ── solutions (tab filter) ─────────────────────────────────────────── */
.sol{background:var(--surface);border-block:1px solid var(--border)}
.sol-tabs{display:flex;flex-wrap:wrap;gap:0;border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden;margin-bottom:36px;background:var(--surface-2)}
.sol-tab{flex:1 1 auto;min-width:max-content;padding:14px 18px;background:transparent;border:0;border-right:1px solid var(--border);font-family:var(--font-mono);font-size:12px;font-weight:600;letter-spacing:0.06em;text-transform:uppercase;color:var(--muted);cursor:pointer;transition:background var(--motion-fast),color var(--motion-fast)}
.sol-tab:last-child{border-right:0}
.sol-tab:hover{color:var(--fg)}
.sol-tab.on{background:var(--accent);color:var(--accent-on)}
.sol-panel{display:none;grid-template-columns:5fr 6fr;gap:clamp(24px,4vw,52px);align-items:center}
.sol-panel.on{display:grid}
.sol-txt .k{font-family:var(--font-mono);font-size:11px;letter-spacing:0.12em;text-transform:uppercase;color:var(--accent)}
.sol-txt h3{font-size:clamp(24px,3vw,36px);margin:12px 0 12px}
.sol-txt>p{color:var(--muted);font-size:15px;max-width:46ch}
.sol-steps{margin-top:22px;border-top:1px solid var(--border)}
.sol-step{display:grid;grid-template-columns:40px 1fr;gap:14px;padding:15px 0;border-bottom:1px solid var(--border)}
.sol-step .n{font-family:var(--font-mono);font-size:13px;color:var(--accent)}
.sol-step b{font-weight:650;color:var(--fg)}
.sol-step span{color:var(--muted)}
.sol-cta{margin-top:24px;display:flex;flex-wrap:wrap;gap:12px}
.sol-fig{aspect-ratio:4/3;overflow:hidden;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface-2)}
.sol-fig img{width:100%;height:100%;object-fit:cover;filter:contrast(1.04) saturate(.95)}
@media (max-width:880px){.sol-panel.on{grid-template-columns:1fr}.sol-fig{order:-1;aspect-ratio:16/9}}

/* ── company / proof ────────────────────────────────────────────────── */
.co-grid{display:grid;grid-template-columns:5fr 6fr;gap:clamp(28px,4vw,60px);align-items:center}
.co-txt h2{font-size:clamp(26px,3.6vw,42px);margin:14px 0 18px}
.co-txt p{color:var(--muted);font-size:15px}
.co-txt p + p{margin-top:14px}
.co-keys{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--border);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden;margin:28px 0}
.co-key{background:var(--surface);padding:18px 18px}
.co-key .v{font-family:var(--font-display);font-weight:700;font-size:22px;letter-spacing:-0.02em}
.co-key .l{font-family:var(--font-mono);font-size:11.5px;color:var(--muted);margin-top:5px;letter-spacing:0.03em}
.co-cta{display:flex;flex-wrap:wrap;gap:12px}
.co-visual{display:grid;grid-template-columns:1.4fr 1fr;grid-template-rows:auto auto;gap:14px}
.co-img{overflow:hidden;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface-2)}
.co-img.main{grid-row:1 / 3}
.co-img img{width:100%;height:100%;object-fit:cover;filter:contrast(1.04) saturate(.95)}
.co-certs{border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px;display:flex;flex-direction:column;gap:12px;background:var(--surface)}
.co-cert b{font-family:var(--font-display);font-weight:700;font-size:14px}
.co-cert span{display:block;font-family:var(--font-mono);font-size:11px;color:var(--muted);margin-top:2px}
.co-cert + .co-cert{border-top:1px solid var(--line);padding-top:12px}
@media (max-width:900px){.co-grid{grid-template-columns:1fr}}
@media (max-width:460px){.co-keys{grid-template-columns:1fr}}

/* ── news ───────────────────────────────────────────────────────────── */
.news-grid{display:grid;grid-template-columns:1.15fr 1fr;gap:clamp(24px,3vw,44px);align-items:start}
.news-feat{border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;background:var(--surface);display:flex;flex-direction:column;transition:border-color var(--motion-fast),box-shadow var(--motion-fast)}
.news-feat:hover{border-color:var(--muted);box-shadow:var(--elev-raised)}
.news-feat-img{aspect-ratio:16/9;overflow:hidden;background:var(--surface-2)}
.news-feat-img img{width:100%;height:100%;object-fit:cover;filter:contrast(1.03) saturate(.95)}
.news-feat-body{padding:clamp(20px,2.4vw,28px);display:flex;flex-direction:column;gap:12px}
.news-meta{display:flex;gap:14px;font-family:var(--font-mono);font-size:11.5px;letter-spacing:0.04em;text-transform:uppercase;color:var(--muted)}
.news-meta .cat{color:var(--accent)}
.news-feat-body h3{font-size:clamp(20px,2.4vw,28px)}
.news-rows{border-top:1px solid var(--border)}
.news-row{display:block;padding:clamp(16px,2vw,22px) 4px;border-bottom:1px solid var(--line);transition:padding-left var(--motion-fast)}
.news-row:hover{padding-left:12px}
.news-row h3{font-size:clamp(16px,1.8vw,20px);margin-top:8px;line-height:1.2}
.news-row:hover h3{color:var(--accent)}
@media (max-width:860px){.news-grid{grid-template-columns:1fr}}

/* ── inquiry (dark panel, was inverted) ─────────────────────────────── */
.iq{background:var(--surface);color:var(--fg)}
.iq-grid{display:grid;grid-template-columns:5fr 6fr;gap:clamp(28px,4vw,60px)}
.iq .k{font-family:var(--font-mono);font-size:12px;letter-spacing:0.14em;text-transform:uppercase;color:var(--accent)}
.iq h2{color:var(--fg);font-size:clamp(28px,4vw,46px);margin:16px 0 18px}
.iq-lead{color:var(--muted);font-size:16px;max-width:44ch}
.iq-contacts{margin-top:30px;border-top:1px solid var(--border)}
.iq-c{display:grid;grid-template-columns:110px 1fr;gap:16px;padding:14px 0;border-bottom:1px solid var(--border)}
.iq-c .l{font-family:var(--font-mono);font-size:11px;letter-spacing:0.08em;text-transform:uppercase;color:var(--muted)}
.iq-c .v{font-size:15px;min-width:0;overflow-wrap:anywhere}
.iq-c .v.big{font-family:var(--font-display);font-weight:650;font-size:19px}
.iq-form{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:clamp(20px,3vw,32px)}
.fg2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.fr.full{grid-column:1 / -1}
.fr label{display:block;font-family:var(--font-mono);font-size:11px;letter-spacing:0.06em;text-transform:uppercase;color:var(--muted);margin-bottom:7px}
.fr input,.fr select,.fr textarea{width:100%;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--fg);padding:11px 12px;font-size:14px;transition:border-color var(--motion-fast),box-shadow var(--motion-fast)}
.fr input::placeholder,.fr textarea::placeholder{color:var(--muted)}
.fr input:focus,.fr select:focus,.fr textarea:focus{outline:none;border-color:var(--accent);box-shadow:var(--focus-ring)}
.fr textarea{resize:vertical;min-height:96px}
.fr select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23b3b3b3' d='M6 8L0 0h12z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:34px}
.fr-actions{grid-column:1 / -1;display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:14px;margin-top:4px}
.fr-note{font-family:var(--font-mono);font-size:11px;color:var(--muted)}
@media (max-width:860px){.iq-grid{grid-template-columns:1fr}.fg2{grid-template-columns:1fr}}

/* ── footer (dark, was inverted) ────────────────────────────────────── */
.foot{background:#000;color:var(--muted);padding-top:clamp(48px,6vw,80px);border-top:1px solid var(--border)}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.5fr;gap:32px;padding-bottom:clamp(36px,4vw,56px)}
.foot .brand-name,.foot h4{color:var(--fg)}
.foot h4{font-family:var(--font-mono);font-size:12px;font-weight:600;letter-spacing:0.08em;text-transform:uppercase;margin-bottom:18px}
.foot-brand p{font-size:14px;margin:18px 0;max-width:38ch}
.foot ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:11px}
.foot ul a{color:var(--muted);font-size:14px}
.foot ul a:hover{color:var(--fg)}
.foot-c{margin-bottom:14px;font-size:14px}
.foot-c .l{display:block;font-family:var(--font-mono);font-size:11px;letter-spacing:0.05em;text-transform:uppercase;color:var(--muted);margin-bottom:3px}
.foot-c .v{color:var(--meta);overflow-wrap:anywhere}
.foot-bottom{border-top:1px solid color-mix(in oklab,var(--fg),transparent 88%);padding:22px 0;display:flex;flex-wrap:wrap;justify-content:space-between;gap:14px;font-family:var(--font-mono);font-size:11.5px;color:var(--muted)}
.foot-langs{display:flex;gap:16px}
.foot-langs a{color:var(--muted)}
.foot-langs a:hover{color:var(--fg)}
@media (max-width:880px){.foot-grid{grid-template-columns:1fr 1fr}.foot-brand{grid-column:1 / -1}}
@media (max-width:460px){.foot-grid{grid-template-columns:1fr}}

/* ── mobile nav ─────────────────────────────────────────────────────── */
@media (max-width:1040px){
  .nav-main{position:fixed;inset:108px 0 auto 0;flex-direction:column;align-items:stretch;gap:0;background:var(--surface);border-bottom:1px solid var(--border);padding:8px var(--gutter) 20px;transform:translateY(-12px);opacity:0;pointer-events:none;transition:opacity .18s,transform .18s;max-height:calc(100vh - 108px);overflow:auto}
  .nav-main.open{transform:translateY(0);opacity:1;pointer-events:auto}
  .nav-main>a,.nav-item>a{height:52px;padding-inline:0;border-bottom:1px solid var(--line)}
  .nav-item{display:block}
  .nav-item.mega>a::after{margin-left:auto}
  .mega{position:static;width:auto;opacity:1;pointer-events:auto;transform:none;border:0;border-top:0;border-radius:0;box-shadow:none;background:transparent;padding:0 0 14px}
  .mega-grid{grid-template-columns:1fr;gap:10px}
  .mega-feat{display:none}
  .burger{display:inline-grid;place-items:center;width:44px;height:44px;background:transparent;border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer}
  .burger span,.burger span::before,.burger span::after{content:"";display:block;width:18px;height:2px;background:var(--fg);position:relative}
  .burger span::before{position:absolute;top:-6px}
  .burger span::after{position:absolute;top:6px}
  .nav-cta .btn-quote{display:none}
}

@media (prefers-reduced-motion:reduce){*,*::before,*::after{transition-duration:.01ms !important;scroll-behavior:auto !important}}
