/* ============================================================
   Furnatek — Brand tokens, base, layout, components
   Leading brand: Furnatek (navy / flame-orange / teal)
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Nunito+Sans:ital,opsz,wght@0,6..12,400;0,6..12,600;0,6..12,700;0,6..12,800;0,6..12,900;1,6..12,700&family=Inter:wght@400;500;600;700&family=Roboto+Mono:wght@400;500;600&display=swap');

:root{
  /* ---- Navy ---- */
  --navy-950:#061a30;
  --navy-900:#08233d;
  --navy-850:#0a2b4a;
  --navy-800:#0c3258;
  --navy:#003060;          /* brand primary */
  --navy-700:#114a7c;
  --navy-600:#1c5e97;
  --navy-500:#2f76b3;

  /* ---- Flame ---- */
  --flame-1:#fbb040;
  --flame-2:#f7901f;
  --flame-3:#f0701f;
  --flame-4:#e8491d;
  --flame:#f0701f;
  --grad-flame:linear-gradient(150deg,#fbb040 0%,#f4831e 48%,#e8491d 100%);
  --grad-flame-soft:linear-gradient(150deg,#fcc056 0%,#f58a28 100%);

  /* ---- Teal ---- */
  --teal:#50c0b0;
  --teal-600:#34a394;
  --teal-700:#28857a;

  /* ---- Neutrals (light) ---- */
  --paper:#ffffff;
  --mist:#f3f6fa;
  --mist-2:#eaf0f6;
  --line:#e3e9f0;
  --line-2:#d3dce6;
  --ink:#0f2132;
  --ink-2:#394c5e;
  --muted:#6a7c8e;

  /* ---- Status ---- */
  --st-green:#1aa251;
  --st-grey:#9aa6b2;
  --st-teal:#3bb7a6;
  --st-orange:#f0701f;
  --st-yellow:#f3b53b;
  --st-red:#e23c2e;

  /* ---- Type ---- */
  --display:'Nunito Sans',system-ui,sans-serif;
  --sans:'Inter',system-ui,sans-serif;
  --mono:'Roboto Mono',ui-monospace,monospace;

  /* ---- Layout ---- */
  --maxw:1240px;
  --pad:clamp(20px,5vw,64px);
  --radius:16px;
  --radius-sm:10px;
  --radius-lg:24px;

  --shadow-card:0 1px 2px rgba(15,33,50,.04),0 12px 30px -12px rgba(15,33,50,.16);
  --shadow-float:0 24px 70px -24px rgba(6,26,48,.55),0 2px 8px rgba(6,26,48,.18);
  --shadow-ui:0 1px 0 rgba(15,33,50,.02),0 18px 50px -18px rgba(10,43,74,.30);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;font-family:var(--sans);color:var(--ink);background:var(--paper);
  font-size:17px;line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
::selection{background:var(--flame-3);color:#fff}

/* ---- Typographic helpers ---- */
.eyebrow{
  font-family:var(--sans);font-weight:600;font-size:13px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--flame-3);display:inline-flex;align-items:center;gap:10px;
}
.eyebrow.on-dark{color:var(--flame-1)}
.eyebrow.teal{color:var(--teal-600)}
.eyebrow::before{content:"";width:22px;height:2px;background:var(--grad-flame);border-radius:2px}
.eyebrow.teal::before{background:var(--teal)}

h1,h2,h3,h4{font-family:var(--display);margin:0;line-height:1.04;letter-spacing:-.02em;font-weight:800;color:var(--ink)}
h2.section-title{font-size:clamp(30px,4.4vw,52px);font-weight:800;letter-spacing:-.025em}
.lead{font-size:clamp(17px,2vw,21px);line-height:1.55;color:var(--ink-2)}
.on-dark h2,.on-dark h1,.on-dark h3,.on-dark h4{color:#fff}
.on-dark .lead{color:rgba(255,255,255,.74)}

.container{max-width:var(--maxw);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad)}
section{position:relative;scroll-margin-top:88px}
.section-pad{padding:clamp(72px,9vw,128px) 0}

/* ---- Buttons ---- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-family:var(--sans);font-weight:600;font-size:15px;letter-spacing:.01em;
  padding:14px 24px;border-radius:12px;cursor:pointer;border:1px solid transparent;
  transition:transform .15s ease,box-shadow .2s ease,background .2s ease,color .2s ease;white-space:nowrap;
}
.btn svg{width:18px;height:18px}
.btn-primary{background:var(--grad-flame);color:#fff;box-shadow:0 10px 24px -10px rgba(232,73,29,.7)}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 16px 30px -10px rgba(232,73,29,.78)}
.btn-navy{background:var(--navy);color:#fff}
.btn-navy:hover{background:var(--navy-700);transform:translateY(-1px)}
.btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.28)}
.btn-ghost:hover{border-color:rgba(255,255,255,.6);background:rgba(255,255,255,.06)}
.btn-light{background:#fff;color:var(--navy);border-color:var(--line)}
.btn-light:hover{transform:translateY(-1px);box-shadow:var(--shadow-card)}
.btn-lg{padding:17px 30px;font-size:16px;border-radius:14px}

/* ---- Pills / chips ---- */
.pill{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:600;
  padding:7px 13px;border-radius:999px;background:var(--mist);color:var(--ink-2);border:1px solid var(--line)}
.pill.on-dark{background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.16);color:rgba(255,255,255,.85)}
.dot{width:8px;height:8px;border-radius:50%;display:inline-block}

/* ---- Generic card ---- */
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:30px;box-shadow:var(--shadow-card)}

/* ---- Reveal-on-scroll: visible by default; hidden only when JS is active ---- */
@media (prefers-reduced-motion:no-preference){
  html.js .reveal{opacity:0;transform:translateY(22px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
  html.js .reveal.in{opacity:1;transform:none}
  html.js .reveal.d1{transition-delay:.08s}html.js .reveal.d2{transition-delay:.16s}html.js .reveal.d3{transition-delay:.24s}html.js .reveal.d4{transition-delay:.32s}
  html.no-anim .reveal{opacity:1 !important;transform:none !important;transition:none !important}
}

/* ============================================================
   NAV
   ============================================================ */
.nav{position:fixed;top:0;left:0;right:0;z-index:60;transition:background .3s ease,box-shadow .3s ease,border-color .3s}
.nav__inner{display:flex;align-items:center;justify-content:space-between;height:74px;gap:24px}
.nav__brand{display:flex;align-items:center}
.nav__logo{height:30px;width:auto;transition:opacity .25s}
.nav__logo--navy{display:none}
.nav__links{display:flex;gap:30px;margin-left:auto;margin-right:8px}
.nav__links a{font-size:14.5px;font-weight:500;color:rgba(255,255,255,.82);transition:color .2s}
.nav__links a:hover{color:#fff}
.nav.scrolled{background:rgba(255,255,255,.9);backdrop-filter:blur(12px);box-shadow:0 1px 0 var(--line),0 8px 30px -18px rgba(15,33,50,.4)}
.nav.scrolled .nav__logo--white{display:none}
.nav.scrolled .nav__logo--navy{display:block}
.nav.scrolled .nav__links a{color:var(--ink-2)}
.nav.scrolled .nav__links a:hover{color:var(--navy)}
/* nav CTA cluster + Analytics button */
.nav__cta{display:flex;align-items:center;gap:14px}
.nav__analytics{display:inline-flex;align-items:center;gap:6px;font-size:14px;font-weight:600;
  color:var(--teal-600);border:1px solid rgba(80,192,176,.5);border-radius:999px;padding:7px 15px;
  transition:background .2s,border-color .2s,color .2s}
.nav__analytics svg{width:15px;height:15px}
.nav__analytics:hover{background:rgba(80,192,176,.12);border-color:var(--teal)}
.nav.scrolled .nav__analytics{color:var(--teal-700)}
.nav-only-mobile{display:none}

/* hamburger toggle */
.nav__toggle{display:none;flex-direction:column;justify-content:center;gap:5px;width:44px;height:44px;
  background:none;border:0;cursor:pointer;padding:11px;margin-left:8px}
.nav__toggle span{display:block;height:2px;width:100%;background:#fff;border-radius:2px;
  transition:transform .25s ease,opacity .2s ease}
.nav.scrolled .nav__toggle span{background:var(--navy)}
.nav--open .nav__toggle span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav--open .nav__toggle span:nth-child(2){opacity:0}
.nav--open .nav__toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

@media (max-width:900px){
  .nav__toggle{display:flex}
  .nav__cta{display:none}
  .nav__links{position:fixed;top:74px;left:0;right:0;flex-direction:column;align-items:stretch;gap:0;margin:0;
    background:rgba(255,255,255,.98);backdrop-filter:blur(12px);
    box-shadow:0 16px 36px -20px rgba(15,33,50,.55);border-top:1px solid var(--line);
    padding:8px 0 14px;transform:translateY(-14px);opacity:0;pointer-events:none;
    transition:opacity .22s ease,transform .22s ease}
  .nav--open .nav__links{transform:translateY(0);opacity:1;pointer-events:auto}
  .nav__links a{color:var(--ink-2);padding:14px 26px;font-size:16px}
  .nav__links a:hover{color:var(--navy);background:rgba(0,48,96,.04)}
  .nav-only-mobile{display:flex;align-items:center;gap:6px;margin:8px 20px 0;justify-content:center;
    font-weight:600;border-radius:12px;padding:14px 18px}
  .nav__menu-cta[href^="https"]{color:var(--teal-700);border:1px solid rgba(80,192,176,.5)}
  .nav__menu-cta[href="#demo"]{background:var(--grad-flame);color:#fff}
  .nav__menu-cta[href="#demo"]:hover{color:#fff}
}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;overflow:hidden;color:#fff;padding-top:118px;
  background:radial-gradient(120% 90% at 80% 8%,#0e3b66 0%,#0a2c4c 42%,#061a30 100%)}
.hero__grid-bg{position:absolute;inset:0;opacity:.5;pointer-events:none;
  background-image:linear-gradient(rgba(255,255,255,.045) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.045) 1px,transparent 1px);
  background-size:54px 54px;mask-image:radial-gradient(120% 80% at 70% 20%,#000 30%,transparent 75%)}
.hero__glow{position:absolute;right:-8%;top:18%;width:780px;height:780px;pointer-events:none;
  background:radial-gradient(circle,rgba(240,112,31,.34) 0%,rgba(232,73,29,.12) 36%,transparent 64%);filter:blur(8px)}
.hero__inner{position:relative;display:grid;grid-template-columns:1fr 1.3fr;gap:48px;align-items:center;padding-bottom:60px}
.hero__title{font-size:clamp(42px,5.6vw,74px);font-weight:900;letter-spacing:-.035em;color:#fff;line-height:1}
.grad-text{background:var(--grad-flame);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero__lead{max-width:548px;margin:24px 0 0;color:rgba(255,255,255,.74)}
.hero__lead em{font-style:italic;color:#fff;font-weight:500}
.hero__tagline{font-family:var(--display);font-style:italic;font-weight:700;color:var(--teal);
  font-size:clamp(18px,2vw,23px);margin:20px 0 0;letter-spacing:-.01em}
/* highlighted hero statement — sub-headline under the H1 */
.hero__statement{font-family:var(--display);font-weight:700;font-style:normal;color:#fff;
  font-size:clamp(20px,2.4vw,28px);line-height:1.2;letter-spacing:-.02em;margin:14px 0 0}
.hero__actions{display:flex;gap:14px;margin-top:32px;flex-wrap:wrap}
.hero__stats{display:flex;gap:14px 34px;margin-top:42px;flex-wrap:wrap}
.hstat b{display:block;font-family:var(--display);font-weight:800;font-size:23px;color:var(--flame-1);line-height:1.1}
.hstat span{font-size:13px;color:rgba(255,255,255,.6)}
.hero__app{position:relative;align-self:center;width:100%}
.hero__app .app{position:absolute;top:0;left:0;width:940px;transform-origin:top left;z-index:2}
.hero__app-shadow{position:absolute;inset:4% -3% -8% 3%;z-index:1;
  background:radial-gradient(60% 60% at 50% 50%,rgba(0,0,0,.5),transparent 70%);filter:blur(30px)}
.hero__trust{border-top:1px solid rgba(255,255,255,.1);background:rgba(4,16,30,.4)}
.hero__trust-inner{display:flex;align-items:center;justify-content:center;gap:18px;flex-wrap:wrap;
  padding:18px 0;font-size:13.5px;color:rgba(255,255,255,.6)}
.hero__trust-inner strong{color:rgba(255,255,255,.92);font-weight:600}
.hero__trust-inner i{width:4px;height:4px;border-radius:50%;background:rgba(255,255,255,.3)}
@media (max-width:980px){
  .hero__inner{grid-template-columns:1fr;gap:36px}
  .hero__app{max-width:600px;margin:0 auto}
}

/* ============================================================
   SECTION HEADS
   ============================================================ */
.sec-head{max-width:780px;margin:0 auto 56px;text-align:center}
.sec-head .eyebrow{margin-bottom:18px}
.sec-head .lead{margin:20px auto 0;max-width:680px}

/* icons (injected by app.js) */
.prob__ic,.feat__ic,.roi__ic{width:50px;height:50px;border-radius:13px;display:grid;place-items:center;flex:0 0 auto}
.prob__ic,.feat__ic{background:linear-gradient(150deg,#fff2e4,#ffe2cd);color:var(--flame-4);margin-bottom:8px}
.roi__ic{background:rgba(240,112,31,.16);color:var(--flame-1);margin-bottom:14px}
.prob__ic svg,.feat__ic svg,.roi__ic svg{width:25px;height:25px}

/* ============================================================
   PROBLEM
   ============================================================ */
.prob-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.prob{padding:26px}
.prob h3{font-size:19px;line-height:1.15;margin-bottom:10px}
.prob p{font-size:14.5px;color:var(--muted);line-height:1.55;margin:0}
@media (max-width:920px){.prob-grid{grid-template-columns:1fr 1fr}}
@media (max-width:520px){.prob-grid{grid-template-columns:1fr}}

/* ============================================================
   HOW IT WORKS (dark)
   ============================================================ */
.how{background:linear-gradient(180deg,#0a2c4c,#061a30);overflow:hidden}
.how__glow{position:absolute;left:50%;top:-10%;width:900px;height:520px;transform:translateX(-50%);pointer-events:none;
  background:radial-gradient(circle,rgba(240,112,31,.18),transparent 62%)}
.steps{position:relative;display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:8px}
.step{padding:30px;border:1px solid rgba(255,255,255,.12);border-radius:var(--radius);
  background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.02))}
.step__num{font-family:var(--display);font-weight:900;font-size:42px;line-height:1;letter-spacing:-.03em;
  background:var(--grad-flame);-webkit-background-clip:text;background-clip:text;color:transparent;margin-bottom:14px}
.step h3{font-size:21px;color:#fff;margin-bottom:8px}
.step p{color:rgba(255,255,255,.66);font-size:14.5px;line-height:1.6;margin:0 0 16px}
.step__tags{display:flex;gap:8px;flex-wrap:wrap}
@media (max-width:880px){.steps{grid-template-columns:1fr}}

/* ============================================================
   PLATFORM / SHOWCASE
   ============================================================ */
.showcase{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center;margin-top:20px}
.showcase__cards{display:flex;flex-direction:column;gap:18px}
.ui-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow-card)}
.ui-card__head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.ui-card__head h4{font-size:15px;font-weight:800}
.ui-card__meta{font-size:12px;color:var(--muted);font-weight:600}
.cam-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:2px}
.cam-list li{display:grid;grid-template-columns:1fr auto auto;align-items:center;gap:14px;padding:11px 4px;border-bottom:1px solid var(--mist-2);font-size:13.5px}
.cam-list li:last-child{border-bottom:0}
.cam-list__id{display:inline-flex;align-items:center;gap:9px;font-weight:600;color:var(--ink)}
.cam-list__t{font-size:13px;color:var(--ink-2);min-width:48px;text-align:right}
.ui-card--alert{display:flex;align-items:center;gap:16px;border-color:#f6d4bf;background:linear-gradient(180deg,#fff,#fff8f2)}
.alert-ic{width:44px;height:44px;flex:0 0 auto;border-radius:11px;background:rgba(240,112,31,.14);color:var(--flame-4);display:grid;place-items:center}
.alert-ic svg{width:22px;height:22px}
.ui-card--alert b{font-size:15px;display:block;margin-bottom:3px}
.ui-card--alert p{margin:0;font-size:12.5px;color:var(--muted);font-family:var(--mono)}
.showcase__panel h3{font-size:clamp(24px,2.6vw,32px);margin-bottom:22px}
.check-list{list-style:none;margin:0 0 28px;padding:0;display:flex;flex-direction:column;gap:14px}
.check-list li{display:flex;align-items:flex-start;gap:12px;font-size:16px;color:var(--ink-2);line-height:1.45}
.check-list svg{width:20px;height:20px;flex:0 0 auto;margin-top:2px;color:var(--teal-600)}
@media (max-width:880px){.showcase{grid-template-columns:1fr;gap:28px}}

/* ============================================================
   FEATURES
   ============================================================ */
.feat-sec{background:var(--mist);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.feat{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow-card)}
.feat h3{font-size:18px;margin-bottom:7px}
.feat p{font-size:14.5px;color:var(--muted);line-height:1.55;margin:0}
@media (max-width:880px){.feat-grid{grid-template-columns:1fr 1fr}}
@media (max-width:560px){.feat-grid{grid-template-columns:1fr}}

/* ============================================================
   ROI (dark)
   ============================================================ */
.roi{background:radial-gradient(120% 90% at 20% 0%,#0e3b66,#061a30 70%);overflow:hidden}
.roi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.roi__item{padding:30px;border:1px solid rgba(255,255,255,.12);border-radius:var(--radius);
  background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.015))}
.roi__item h3{font-size:21px;color:#fff;margin-bottom:9px}
.roi__item p{color:rgba(255,255,255,.66);font-size:14.5px;line-height:1.6;margin:0}
@media (max-width:880px){.roi-grid{grid-template-columns:1fr}}

/* ============================================================
   ANALYTICS
   ============================================================ */
.analytics-head{max-width:760px;margin:0 auto 40px;text-align:center}
.analytics-head .eyebrow{margin-bottom:18px}
.analytics-head .lead{margin:20px auto 0;max-width:660px}
.analytics-domain{display:inline-flex;align-items:center;gap:9px;margin-top:22px;font-family:var(--mono);
  font-size:14px;font-weight:500;color:var(--teal-700);background:#e9f7f4;border:1px solid #c9ece6;border-radius:999px;padding:8px 16px;
  cursor:pointer;text-decoration:none;transition:background .2s,border-color .2s,box-shadow .2s,transform .2s}
.analytics-domain:hover{background:#dff2ee;border-color:var(--teal);box-shadow:0 8px 20px -12px rgba(40,133,122,.5);transform:translateY(-1px)}
.analytics-domain__ext{width:15px;height:15px;margin-left:2px;opacity:.8}
.footer__domain-link{display:inline-flex;align-items:center;gap:8px;text-decoration:none;color:inherit;transition:color .2s}
.footer__domain-link:hover{color:var(--teal)}
.analytics-app{max-width:1060px;margin:0 auto}
.analytics-feats{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:36px}
.afeat{padding:20px;border-radius:var(--radius-sm);background:var(--mist);border:1px solid var(--line)}
.afeat b{display:block;font-size:15px;margin-bottom:5px;color:var(--ink)}
.afeat span{font-size:13px;color:var(--muted);line-height:1.5}
@media (max-width:880px){.analytics-feats{grid-template-columns:1fr 1fr}}

/* ============================================================
   DEMO CTA (dark)
   ============================================================ */
.demo{background:radial-gradient(110% 120% at 50% 0%,#0e3b66,#061a30 68%);overflow:hidden;text-align:center}
.demo__glow{position:absolute;left:50%;bottom:-30%;width:900px;height:600px;transform:translateX(-50%);pointer-events:none;
  background:radial-gradient(circle,rgba(240,112,31,.22),transparent 60%)}
.demo__inner{position:relative;max-width:720px;margin:0 auto}
.demo__inner .eyebrow{margin-bottom:18px}
.demo__inner .lead{margin:18px auto 0}
.demo-form{margin:36px auto 0;max-width:600px;display:flex;flex-direction:column;gap:14px}
.demo-form__row{display:flex;gap:14px}
.demo-form input{flex:1;min-width:0;font-family:var(--sans);font-size:15px;color:#fff;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.18);border-radius:11px;padding:14px 16px}
.demo-form input::placeholder{color:rgba(255,255,255,.5)}
.demo-form input:focus{outline:none;border-color:var(--flame-2);background:rgba(255,255,255,.1)}
.demo-form button{margin-top:6px;align-self:center}
.demo__tagline{font-family:var(--display);font-style:italic;font-weight:700;color:var(--teal);font-size:20px;margin:30px 0 0}
@media (max-width:560px){.demo-form__row{flex-direction:column}}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{background:#05182c;color:rgba(255,255,255,.62);padding:64px 0 36px}
.footer__inner{display:grid;grid-template-columns:1.4fr 2fr;gap:40px}
.footer__brand img{height:30px;margin-bottom:16px}
.footer__brand p{font-size:14.5px;max-width:280px;margin:0 0 18px}
.footer__domains{display:flex;flex-direction:column;gap:8px;font-family:var(--mono);font-size:13.5px;color:rgba(255,255,255,.8)}
.footer__domains span{display:inline-flex;align-items:center;gap:9px}
.footer__cols{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.footer__cols h5{font-family:var(--sans);font-size:12px;text-transform:uppercase;letter-spacing:.12em;color:rgba(255,255,255,.45);margin:0 0 14px;font-weight:600}
.footer__cols a{display:block;font-size:14.5px;color:rgba(255,255,255,.72);padding:5px 0}
.footer__cols a:hover{color:#fff}
.footer__legal{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;
  margin-top:48px;padding-top:24px;border-top:1px solid rgba(255,255,255,.1);font-size:12.5px;color:rgba(255,255,255,.42)}
@media (max-width:760px){.footer__inner{grid-template-columns:1fr;gap:32px}}

/* ============================================================
   HARDWARE
   ============================================================ */
.hardware{background:#fff}
.hw-grid{display:grid;grid-template-columns:.82fr 1.18fr;gap:clamp(32px,5vw,68px);align-items:center}
.hw-photo__frame{position:relative;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--line);
  box-shadow:var(--shadow-float);background:#0a2540;max-width:372px;margin:0 auto}
.hw-photo__frame img{width:100%;display:block}
.hw-photo__tag{position:absolute;left:14px;bottom:14px;display:inline-flex;align-items:center;gap:8px;
  background:rgba(8,20,32,.7);backdrop-filter:blur(6px);color:#fff;font-size:12px;font-weight:600;padding:7px 13px;border-radius:999px}
.hw-copy .eyebrow{margin-bottom:16px}
.hw-copy .lead{margin:20px 0 0}
.hw-list{list-style:none;margin:28px 0 0;padding:0;display:flex;flex-direction:column;gap:18px}
.hw-list li{display:flex;gap:14px;align-items:flex-start}
.hw-ic{width:46px;height:46px;flex:0 0 auto;border-radius:12px;background:linear-gradient(150deg,#fff2e4,#ffe2cd);
  color:var(--flame-4);display:grid;place-items:center}
.hw-ic svg{width:23px;height:23px}
.hw-list b{display:block;font-size:16.5px;color:var(--ink);margin-bottom:3px}
.hw-list span{font-size:14.5px;color:var(--muted);line-height:1.5}
@media (max-width:880px){.hw-grid{grid-template-columns:1fr;gap:36px}.hw-photo__frame{max-width:320px}}

/* ---- How it works 3D video ---- */
.how-video{position:relative;max-width:980px;margin:0 auto 46px;border-radius:var(--radius-lg);overflow:hidden;
  border:1px solid rgba(255,255,255,.14);box-shadow:var(--shadow-float);background:#04101e;line-height:0}
.how-video video{width:100%;height:auto;display:block}
.how-video__tag{position:absolute;left:16px;bottom:16px;display:inline-flex;align-items:center;gap:8px;line-height:1;
  background:rgba(8,20,32,.62);backdrop-filter:blur(6px);color:#fff;font-size:12px;font-weight:600;padding:7px 13px;border-radius:999px}

/* ============================================================
   SECURITY / DATA DIODE
   ============================================================ */
.security{background:var(--mist);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.diode{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:8px;
  background:radial-gradient(120% 120% at 50% 0,#0e3b66,#061a30 72%);border-radius:var(--radius-lg);
  padding:36px clamp(20px,4vw,48px);color:#fff;box-shadow:var(--shadow-ui);max-width:1000px;margin:0 auto 40px}
.diode__node{display:flex;flex-direction:column;gap:5px;padding:24px;border:1px solid rgba(255,255,255,.14);
  border-radius:var(--radius);background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.02));min-width:0}
.diode__badge{align-self:flex-start;font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  color:var(--flame-1);background:rgba(240,112,31,.16);padding:5px 11px;border-radius:999px}
.diode__badge.teal{color:var(--teal);background:rgba(80,192,176,.16)}
.diode__node h4{color:#fff;font-size:20px;margin-top:8px}
.diode__node p{margin:0;font-size:12.5px;color:rgba(255,255,255,.58);font-family:var(--mono)}
.diode__mod{display:inline-flex;align-items:center;gap:8px;margin-top:10px;font-size:13.5px;font-weight:600;color:rgba(255,255,255,.92)}
.diode__link{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:13px;padding:0 14px;min-width:210px}
.diode__label{font-size:12px;color:rgba(255,255,255,.7);font-weight:600;letter-spacing:.01em;white-space:nowrap}
.diode__wire{position:relative;width:100%;height:3px;border-radius:3px;background:rgba(255,255,255,.18)}
.diode__arrow{position:absolute;right:-7px;top:50%;transform:translateY(-50%);width:18px;height:18px;color:var(--flame-2)}
.diode__pulse{position:absolute;top:50%;left:0;width:16px;height:6px;border-radius:6px;transform:translateY(-50%);
  background:linear-gradient(90deg,transparent,var(--flame-1))}
@media (prefers-reduced-motion:no-preference){
  .diode__pulse{animation:flow 2.2s linear infinite}
  .diode__pulse:nth-child(2){animation-delay:.73s}
  .diode__pulse:nth-child(3){animation-delay:1.46s}
}
@keyframes flow{0%{left:-8%;opacity:0}12%{opacity:1}88%{opacity:1}100%{left:100%;opacity:0}}
.diode__block{display:inline-flex;align-items:center;gap:7px;font-size:11.5px;color:rgba(255,255,255,.52)}
.diode__block svg{width:14px;height:14px;color:var(--st-red);flex:0 0 auto}
.diode-feats{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
@media (max-width:880px){
  .diode{grid-template-columns:1fr;gap:16px;text-align:left}
  .diode__link{flex-direction:row;min-width:0;padding:4px 0;gap:14px;flex-wrap:wrap;justify-content:flex-start}
  .diode__wire{width:120px;flex:1 1 120px}
  .diode-feats{grid-template-columns:1fr 1fr}
}
@media (max-width:560px){.diode-feats{grid-template-columns:1fr}}

/* ===== Request-a-demo form status message ===== */
.demo-form__status{margin:14px 0 0;font-size:14.5px;font-weight:500;line-height:1.5;padding:10px 14px;border-radius:10px}
.demo-form__status.is-ok{color:#093;background:rgba(80,192,176,.16);border:1px solid rgba(80,192,176,.45)}
.demo-form__status.is-error{color:#ffd9c2;background:rgba(240,112,31,.14);border:1px solid rgba(240,112,31,.5)}
.demo-form button[type="submit"][disabled]{opacity:.6;cursor:progress}
