/* =========================================================================
   Rockfort.ai — Homepage
   Built on the Rockfort design system (rockfort-design-system_2.html)
   ========================================================================= */

:root{
  /* ---- Brand ---- */
  --blue:#2478FF; --blue-ink:#155FE0; --blue-soft:#E9F1FF;
  --navy:#0B1B3A; --navy-soft:#13294F;
  --amber:#FF9A3D; --amber-deep:#E0791C; --amber-soft:#FFF1E2;

  /* ---- Neutrals ---- */
  --ink:#0A0E1A; --ink-2:#1A1F2E; --ink-3:#3A4255; --ink-4:#5A6478;
  --line:#E6E9F0; --line-2:#D6DBE5; --bg:#FFFFFF; --bg-soft:#F6F7FB;

  /* ---- Product colors ---- */
  --red:#E5484D; --red-soft:#FFF0F0;
  --green:#0F9B6E; --green-soft:#EAFBF3;
  --purple:#7C5CFF; --purple-ink:#5B3FD4; --purple-soft:#F1ECFF;

  /* ---- System ---- */
  --radius:14px;
  --shadow-card:0 1px 0 rgba(10,14,26,.04),0 12px 32px -12px rgba(10,14,26,.10);
  --shadow-lg:0 2px 0 rgba(10,14,26,.04),0 40px 80px -36px rgba(10,14,26,.30);
  --ease:cubic-bezier(.22,.61,.36,1);
  --wrap:1080px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;overflow-x:hidden}
body{
  font-family:'Inter',system-ui,sans-serif;
  font-size:17px;line-height:1.55;color:var(--ink);background:var(--bg);
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
}

h1,h2,h3,h4{font-family:'Space Grotesk','Inter',sans-serif;letter-spacing:-.02em;color:var(--ink);font-weight:600}
h1{font-size:clamp(32px,5.2vw,58px);line-height:1.06;letter-spacing:-.03em;font-weight:500}
h2{font-size:clamp(26px,3.4vw,38px);line-height:1.14;letter-spacing:-.01em;font-weight:600}
h3{font-size:clamp(20px,2.2vw,23px);letter-spacing:-.01em}
p{color:var(--ink-3)}
a{color:inherit}
img{max-width:100%;display:block}
.mono{font-family:'JetBrains Mono',monospace}

.wrap{max-width:var(--wrap);margin:0 auto;padding:0 28px}

/* Eyebrow — amber mono label with a short underline accent (no pill) */
.eyebrow{
  font-family:'JetBrains Mono',monospace;font-size:12px;letter-spacing:.16em;
  text-transform:uppercase;font-weight:700;line-height:1.35;text-align:center;
  display:inline-flex;flex-direction:column;align-items:center;gap:11px;max-width:100%;
  color:var(--amber-deep);
}
.eyebrow::after{content:"";width:30px;height:2px;border-radius:2px;background:currentColor;opacity:.6}
.eyebrow-amber{} /* retained for markup compatibility */

/* =========================================================================
   Buttons
   ========================================================================= */
.btn{
  display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:15px;
  padding:13px 22px;border-radius:10px;text-decoration:none;border:1px solid transparent;
  transition:transform .08s,background .15s,border-color .15s,color .15s,box-shadow .15s;
  cursor:pointer;font-family:'Inter',sans-serif;white-space:nowrap;
}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--blue);color:#fff;box-shadow:0 8px 20px -8px rgba(36,120,255,.55)}
.btn-primary:hover{background:var(--blue-ink)}
.btn-dark{background:var(--ink);color:#fff}
.btn-dark:hover{background:var(--navy-soft)}
.btn-ghost{background:#fff;color:var(--ink);border-color:var(--line-2)}
.btn-ghost:hover{border-color:var(--ink)}
/* Amber — the single warm spotlight, reserved for the highest-priority action */
.btn-amber{background:var(--amber);color:#3b2200;box-shadow:0 10px 24px -10px rgba(255,154,61,.55)}
.btn-amber:hover{background:var(--amber-deep);color:#fff}
.btn-sm{padding:9px 16px;font-size:14px}
.arrow{transition:transform .15s}.btn:hover .arrow{transform:translateX(3px)}

/* =========================================================================
   Nav
   ========================================================================= */
.nav{position:sticky;top:0;z-index:50;backdrop-filter:saturate(140%) blur(12px);
  background:rgba(255,255,255,.82);border-bottom:1px solid transparent;transition:border-color .2s,box-shadow .2s}
.nav.scrolled{border-bottom-color:var(--line);box-shadow:0 4px 20px -16px rgba(10,14,26,.4)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:66px;
  max-width:var(--wrap);margin:0 auto;padding:0 28px}
.nav-logo{height:24px;width:auto;display:block}
.nav-links{display:flex;gap:30px;align-items:center}
.nav-links a{color:var(--ink-3);text-decoration:none;font-size:14px;font-weight:500;transition:color .15s}
.nav-links a:hover{color:var(--ink)}
.nav-cta{display:flex;align-items:center;gap:10px}
.nav-burger{display:none;background:none;border:0;cursor:pointer;width:30px;height:30px}
.nav-burger span{display:block;height:2px;background:var(--ink);border-radius:2px;margin:5px 0;transition:.2s}
.nav-mobile{display:none}

/* =========================================================================
   Hero
   ========================================================================= */
.hero{position:relative;overflow:hidden;background:var(--navy);color:#fff;
  border-bottom:1px solid var(--line)}
.hero-bg{position:absolute;inset:0;pointer-events:none;overflow:hidden;isolation:isolate}

/* Design-system streaked hero image, tinted to brand blue */
.hero-img{position:absolute;inset:0;background:url("../assets/hero-bg.jpg") center 38%/cover no-repeat;
  transform:scale(1.02)}
.hero-tint{position:absolute;inset:0;background:var(--blue);mix-blend-mode:color;opacity:.22}
.hero-tint2{position:absolute;inset:0;background:var(--navy);mix-blend-mode:multiply;opacity:.20}
.hero-grid{position:absolute;inset:0;
  background-image:linear-gradient(to right,rgba(255,255,255,.10) 1px,transparent 1px),
    linear-gradient(to bottom,rgba(255,255,255,.10) 1px,transparent 1px);
  background-size:54px 54px;
  mask-image:radial-gradient(ellipse 95% 80% at 50% 100%,#000 25%,transparent 78%);
  -webkit-mask-image:radial-gradient(ellipse 95% 80% at 50% 100%,#000 25%,transparent 78%)}
.hero-scrim{position:absolute;inset:0;
  background:
    radial-gradient(ellipse 70% 52% at 50% 48%,rgba(8,11,22,.50),transparent 78%),
    linear-gradient(180deg,rgba(8,11,22,.66) 0%,rgba(8,11,22,.08) 24%,rgba(8,11,22,.10) 58%,rgba(8,11,22,.80) 100%)}

.hero-bg .grid{position:absolute;inset:0;
  background-image:linear-gradient(to right,rgba(255,255,255,.055) 1px,transparent 1px),
    linear-gradient(to bottom,rgba(255,255,255,.055) 1px,transparent 1px);
  background-size:56px 56px;
  mask-image:radial-gradient(ellipse 75% 70% at 50% 0%,#000 30%,transparent 78%);
  -webkit-mask-image:radial-gradient(ellipse 75% 70% at 50% 0%,#000 30%,transparent 78%)}
.hero-bg .glow{position:absolute;left:50%;top:-160px;width:900px;height:560px;transform:translateX(-50%);
  background:radial-gradient(ellipse at center,rgba(36,120,255,.42),transparent 62%);filter:blur(20px)}
.hero-bg .glow-2{position:absolute;right:-160px;bottom:-120px;width:520px;height:420px;
  background:radial-gradient(ellipse at center,rgba(255,154,61,.20),transparent 64%);filter:blur(24px)}

.hero-inner{position:relative;z-index:2;max-width:940px;margin:0 auto;text-align:center;
  padding:clamp(70px,11vw,120px) 28px 0}
.hero .eyebrow,.anim-section .eyebrow,.cta .eyebrow{
  color:var(--amber);
  text-shadow:0 0 2px rgba(5,9,18,.95),0 1px 3px rgba(5,9,18,.95),0 2px 18px rgba(5,9,18,.8)}
.hero .eyebrow::after,.anim-section .eyebrow::after,.cta .eyebrow::after{
  box-shadow:0 0 8px rgba(5,9,18,.7)}
.hero h1{margin:22px auto 0;color:#F5F8FF;text-wrap:balance}
.hero h1 em{font-style:normal;
  background:linear-gradient(180deg,#7FB0FF,#C7DBFF);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero-sub{margin:24px auto 0;font-size:clamp(17px,2vw,20px);line-height:1.5;
  color:rgba(245,248,255,.84);max-width:600px}
.hero-actions{margin-top:34px;display:flex;gap:13px;justify-content:center;flex-wrap:wrap}
.hero .btn-primary{background:#fff;color:var(--ink);box-shadow:0 12px 30px -12px rgba(0,0,0,.6)}
.hero .btn-primary:hover{background:#E9EEF8}
.hero .btn-ghost{background:transparent;color:#F5F8FF;border-color:rgba(245,248,255,.28)}
.hero .btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.07)}
.hero-note{margin-top:18px;font-size:13.5px;color:rgba(245,248,255,.6);
  display:inline-flex;align-items:center;gap:9px}
.hero-note .dot{width:6px;height:6px;border-radius:50%;background:var(--amber);flex:0 0 auto;
  box-shadow:0 0 0 4px rgba(255,154,61,.18)}

/* Trust bar */
.trustbar{position:relative;z-index:2;margin-top:clamp(54px,7vw,84px);
  border-top:1px solid rgba(255,255,255,.10);background:rgba(8,12,24,.30)}
.trustbar-inner{max-width:var(--wrap);margin:0 auto;padding:18px 28px;
  display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:14px 30px}
.trustbar-item{display:inline-flex;align-items:center;gap:10px;
  font-family:'JetBrains Mono',monospace;font-size:12.5px;letter-spacing:.02em;
  color:rgba(245,248,255,.82)}
.trustbar-item svg{width:15px;height:15px;color:#7FB0FF;flex:0 0 auto}
.trustbar-sep{width:1px;height:14px;background:rgba(255,255,255,.16)}

/* =========================================================================
   Section scaffolding
   ========================================================================= */
section{padding:clamp(64px,8vw,100px) 0}
.section-head{max-width:680px;margin:0 auto 48px;text-align:center}
.section-head.left{margin-left:0;text-align:left}
.section-head h2{margin:14px 0 16px}
.section-head p{font-size:1.08rem;color:var(--ink-3);line-height:1.55}
.section-head .eyebrow{justify-content:center}
.section-head.left .eyebrow{justify-content:flex-start}

/* =========================================================================
   Product animation
   ========================================================================= */
.anim-section{background:var(--ink);color:#fff;border-block:1px solid var(--ink)}
.anim-section h2{color:#F5F8FF}
.anim-section .section-head{max-width:960px}
.oneline-d{white-space:nowrap}
.anim-section .section-head p{color:rgba(245,248,255,.66)}
.anim-frame-wrap{max-width:1120px;margin:0 auto;border-radius:18px;overflow:hidden;
  border:1px solid rgba(255,255,255,.10);box-shadow:0 50px 100px -50px rgba(0,0,0,.9);
  background:#070b12;aspect-ratio:1200/675}
.anim-frame{width:100%;height:100%;border:0;display:block}
.anim-legend{display:flex;flex-wrap:wrap;justify-content:center;gap:14px;margin-top:30px}
.anim-pill{display:inline-flex;align-items:center;gap:9px;padding:8px 15px;border-radius:999px;
  border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.03);
  font-size:13.5px;font-weight:500;color:rgba(245,248,255,.86)}
.anim-pill .d{width:8px;height:8px;border-radius:50%}
.anim-pill .d.red{background:var(--red)}.anim-pill .d.green{background:var(--green)}
.anim-pill .d.purple{background:var(--purple)}
.anim-pill b{font-weight:600;color:#fff}
.anim-pill span{color:rgba(245,248,255,.6)}

/* =========================================================================
   Logos strip
   ========================================================================= */
.logos{padding:clamp(46px,6vw,68px) 0;background:var(--bg-soft);border-bottom:1px solid var(--line)}
.logos-label{text-align:center;font-family:'JetBrains Mono',monospace;font-size:12px;
  letter-spacing:.1em;text-transform:uppercase;color:var(--ink-4);margin-bottom:30px}
.logos-row{display:flex;flex-wrap:wrap;align-items:stretch;justify-content:center;gap:14px}
.logo-tile{background:#fff;border:1px solid var(--line);border-radius:14px;
  height:78px;min-width:172px;flex:0 1 auto;display:grid;place-items:center;padding:16px 26px;
  box-shadow:var(--shadow-card);transition:transform .15s,border-color .15s}
.logo-tile:hover{transform:translateY(-2px);border-color:var(--line-2)}
.logo-tile img{max-height:40px;max-width:152px;width:auto;object-fit:contain;display:block}
.logo-tile img.li-incubrix{max-height:46px;border-radius:6px}
.logo-tile img.li-willbazaar{max-height:48px}

/* =========================================================================
   Problem — before / after
   ========================================================================= */
.compare{display:grid;grid-template-columns:1fr 1fr;gap:18px;max-width:920px;margin:0 auto}
.compare-col{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:#fff}
.compare-col .hd{padding:15px 22px;font-family:'JetBrains Mono',monospace;font-size:12px;
  letter-spacing:.08em;text-transform:uppercase;font-weight:600;border-bottom:1px solid var(--line)}
.compare-col.without .hd{background:var(--red-soft);color:var(--red)}
.compare-col.with .hd{background:var(--green-soft);color:var(--green)}
.compare-col ul{list-style:none;padding:8px 22px 18px}
.compare-col li{display:flex;gap:12px;align-items:flex-start;padding:13px 0;font-size:15px;
  color:var(--ink-2);border-bottom:1px solid var(--line)}
.compare-col li:last-child{border-bottom:0}
.compare-col li .ic{flex:0 0 20px;width:20px;height:20px;border-radius:6px;display:grid;
  place-items:center;margin-top:1px}
.compare-col li .ic svg{width:13px;height:13px;stroke-width:2.6}
.compare-col.without li .ic{background:var(--red-soft);color:var(--red)}
.compare-col.with li .ic{background:var(--green-soft);color:var(--green)}

/* =========================================================================
   Why Now
   ========================================================================= */
.whynow{background:var(--bg-soft)}
.whynow-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:8px}
.gap-card{background:#fff;border:1px solid var(--line);border-radius:18px;padding:28px;
  box-shadow:var(--shadow-card);position:relative;transition:transform .15s,border-color .15s}
.gap-card:hover{transform:translateY(-3px);border-color:var(--line-2)}
.gap-card .x{width:34px;height:34px;border-radius:9px;background:var(--red-soft);color:var(--red);
  display:grid;place-items:center;margin-bottom:18px}
.gap-card .x svg{width:18px;height:18px;stroke-width:2.4}
.gap-card h3{font-size:18px;margin-bottom:9px}
.gap-card p{font-size:14.5px;line-height:1.55}
.whynow-note{max-width:760px;margin:40px auto 0;text-align:center;font-size:1.05rem;color:var(--ink-2);
  line-height:1.6}
.whynow-note b{color:var(--ink);font-weight:600}

/* =========================================================================
   Supported stack
   ========================================================================= */
.stack-head{display:flex;align-items:baseline;justify-content:space-between;gap:24px 40px;
  margin-bottom:26px;flex-wrap:wrap}
.stack-eyebrow{font-family:'JetBrains Mono',monospace;font-size:13px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--ink);font-weight:500}
.stack-head p{font-size:1.02rem;color:var(--ink-3);text-align:right;margin-left:auto;max-width:42ch}
.stack-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:1px;background:var(--line);
  border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.sg-cell{background:#fff;display:grid;place-items:center;min-height:120px;padding:20px 14px;
  text-align:center;font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:18px;
  letter-spacing:-.01em;color:var(--ink);transition:background .15s,color .15s}
.sg-cell:hover{background:var(--bg-soft);color:var(--blue-ink)}
/* Tighten the gap between the stack grid and the reviews section */
#stack{padding-bottom:clamp(36px,4vw,52px)}
.reviews-section{padding-top:clamp(36px,4vw,52px)}

/* =========================================================================
   Reviews
   ========================================================================= */
.reviews{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.review{background:#fff;border:1px solid var(--line);border-radius:18px;padding:28px;
  box-shadow:var(--shadow-card);display:flex;flex-direction:column}
.review .quote{font-size:15.5px;line-height:1.6;color:var(--ink-2);flex:1}
.review .quote::before{content:"“";font-family:'Space Grotesk';font-size:46px;line-height:0;
  color:var(--blue);opacity:.32;display:block;height:22px}
.review .who{margin-top:22px;padding-top:18px;border-top:1px solid var(--line);
  display:flex;align-items:center;gap:13px}
.review .ava{width:40px;height:40px;border-radius:50%;background:var(--navy);color:#fff;
  display:grid;place-items:center;font-family:'Space Grotesk';font-weight:600;font-size:15px;flex:0 0 auto}
.review .who .nm{font-weight:600;font-size:14.5px;color:var(--ink)}
.review .who .rl{font-size:12.5px;color:var(--ink-4)}

/* =========================================================================
   FAQ
   ========================================================================= */
.faq{background:var(--bg-soft)}
.faq-list{max-width:780px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{width:100%;background:none;border:0;cursor:pointer;text-align:left;
  display:flex;align-items:center;justify-content:space-between;gap:20px;
  padding:24px 4px;font-family:'Space Grotesk',sans-serif;font-weight:500;font-size:18px;
  letter-spacing:-.01em;color:var(--ink)}
.faq-q .pm{flex:0 0 auto;width:24px;height:24px;position:relative}
.faq-q .pm::before,.faq-q .pm::after{content:"";position:absolute;background:var(--ink-3);
  border-radius:2px;transition:.2s var(--ease)}
.faq-q .pm::before{top:11px;left:3px;width:18px;height:2px}
.faq-q .pm::after{top:3px;left:11px;width:2px;height:18px}
.faq-item.open .faq-q .pm::after{transform:rotate(90deg);opacity:0}
.faq-item.open .faq-q{color:var(--blue-ink)}
.faq-a{overflow:hidden;max-height:0;transition:max-height .3s var(--ease)}
.faq-a-inner{padding:0 40px 26px 4px;font-size:15.5px;line-height:1.65;color:var(--ink-3)}

/* =========================================================================
   Closing CTA
   ========================================================================= */
.cta{position:relative;overflow:hidden;background:var(--navy);color:#fff;text-align:center}
.cta .hero-bg .grid{mask-image:radial-gradient(ellipse 70% 90% at 50% 50%,#000 30%,transparent 76%);
  -webkit-mask-image:radial-gradient(ellipse 70% 90% at 50% 50%,#000 30%,transparent 76%)}
.cta-inner{position:relative;z-index:2;max-width:680px;margin:0 auto;padding:clamp(72px,9vw,110px) 28px}
.cta h2{color:#F5F8FF;font-size:clamp(28px,4vw,44px)}
.cta p{color:rgba(245,248,255,.78);margin-top:16px;font-size:1.08rem}
.cta-actions{margin-top:32px;display:flex;gap:13px;justify-content:center;flex-wrap:wrap}
.cta .btn-primary{background:#fff;color:var(--ink)}.cta .btn-primary:hover{background:#E9EEF8}
.cta .btn-ghost{background:transparent;color:#F5F8FF;border-color:rgba(245,248,255,.28)}
.cta .btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.07)}

/* =========================================================================
   Footer
   ========================================================================= */
footer{background:var(--ink);color:rgba(245,248,255,.6);padding:64px 0 34px}
.footer-top{display:grid;grid-template-columns:1.7fr 1fr 1fr 1fr;gap:40px}
.footer-brand img{height:24px;margin-bottom:20px}
.footer-tagline{font-size:13.5px;line-height:1.55;color:rgba(245,248,255,.55);max-width:36ch}
.footer-contact{font-size:13.5px;color:rgba(245,248,255,.5);margin-top:14px}
.footer-contact a{color:inherit;text-decoration:none;transition:color .15s}
.footer-contact a:hover{color:#fff}
.footer-col h4{font-family:'Space Grotesk',sans-serif;font-size:15px;font-weight:600;
  letter-spacing:-.01em;color:#F5F8FF;margin-bottom:18px}
.footer-col a{display:block;color:rgba(245,248,255,.6);text-decoration:none;font-size:14px;
  margin-bottom:13px;transition:color .15s}
.footer-col a:hover{color:#fff}
.footer-social a{display:flex;align-items:center;gap:10px;width:fit-content}
.footer-social svg{width:16px;height:16px;flex:0 0 auto;opacity:.85;transition:opacity .15s}
.footer-social a:hover svg{opacity:1}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);margin-top:48px;padding-top:26px;text-align:center}
.footer-bottom p{font-size:13px;color:rgba(245,248,255,.42)}

/* =========================================================================
   Scroll reveal
   ========================================================================= */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal[data-delay="1"]{transition-delay:.08s}
.reveal[data-delay="2"]{transition-delay:.16s}
.reveal[data-delay="3"]{transition-delay:.24s}
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  html{scroll-behavior:auto}
}

/* =========================================================================
   Responsive
   ========================================================================= */
@media(max-width:880px){
  .whynow-cards,.reviews{grid-template-columns:1fr}
  .compare{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr 1fr;gap:36px 28px}
  .footer-brand{grid-column:1 / -1}
  .stack-grid{grid-template-columns:repeat(3,1fr)}
  .stack-head{flex-direction:column;align-items:flex-start}
  .stack-head p{text-align:left;margin-left:0}
}
@media(max-width:720px){
  .nav-links{display:none}
  .nav-cta .btn-ghost{display:none}
  .nav-burger{display:block}
  .nav.menu-open .nav-mobile{display:flex}
  .nav-mobile{display:none;position:absolute;top:66px;left:0;right:0;background:#fff;
    border-bottom:1px solid var(--line);flex-direction:column;padding:14px 28px 22px;gap:4px}
  .nav-mobile a{padding:12px 0;font-size:16px;font-weight:500;color:var(--ink-2);text-decoration:none;
    border-bottom:1px solid var(--line)}
  .nav-mobile .btn{margin-top:14px;justify-content:center}
  .trustbar-sep{display:none}
  .anim-frame-wrap{aspect-ratio:4/5}
  .stack-grid{grid-template-columns:repeat(2,1fr)}
  .sg-cell{min-height:96px;font-size:16px}
  .eyebrow{font-size:10px;letter-spacing:.1em;gap:9px}
  .oneline-d{white-space:normal}
  .footer-top{grid-template-columns:1fr;gap:32px}
  .footer-brand{grid-column:auto}
}

/* =========================================================================
   MULTI-PAGE ADDITIONS
   ========================================================================= */

/* ---- Nav: Solutions dropdown ---- */
.nav-dd{position:relative;display:flex;align-items:center}
.nav-dd::after{content:"";position:absolute;top:100%;left:-10px;right:-10px;height:16px}
.nav-dd-btn{display:inline-flex;align-items:center;gap:5px;background:none;border:0;cursor:pointer;
  font-family:'Inter',sans-serif;font-size:14px;font-weight:500;color:var(--ink-3);padding:0;transition:color .15s}
.nav-dd-btn:hover{color:var(--ink)}
.nav-dd-btn .chev{width:15px;height:15px;transition:transform .2s}
.nav-dd:hover .chev,.nav-dd.open .chev{transform:rotate(180deg)}
.nav-dd-menu{position:absolute;top:calc(100% + 12px);left:50%;transform:translateX(-50%) translateY(6px);
  width:340px;background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow-lg);
  padding:8px;opacity:0;visibility:hidden;transition:opacity .18s var(--ease),transform .18s var(--ease);z-index:60}
.nav-dd:hover .nav-dd-menu,.nav-dd.open .nav-dd-menu{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.nav-dd-menu a{display:flex;gap:13px;align-items:flex-start;padding:12px;border-radius:11px;text-decoration:none;transition:background .15s}
.nav-dd-menu a:hover{background:var(--bg-soft)}
.nav-dd-menu b{display:block;font-family:'Space Grotesk',sans-serif;font-size:14.5px;color:var(--ink);font-weight:600;letter-spacing:-.01em}
.nav-dd-menu small{display:block;font-size:12px;color:var(--ink-4);margin-top:3px;line-height:1.4}
.dd-ico{width:32px;height:32px;border-radius:9px;display:grid;place-items:center;flex:0 0 auto;margin-top:1px}
.dd-ico svg{width:18px;height:18px}
.dd-ico.red{background:var(--red-soft);color:var(--red)}
.dd-ico.green{background:var(--green-soft);color:var(--green)}
.dd-ico.purple{background:var(--purple-soft);color:var(--purple-ink)}

/* ---- Product accent themes ---- */
.theme-red{--accent:var(--red);--accent-soft:var(--red-soft);--accent-ink:#B83236}
.theme-green{--accent:var(--green);--accent-soft:var(--green-soft);--accent-ink:#0A7D56}
.theme-purple{--accent:var(--purple);--accent-soft:var(--purple-soft);--accent-ink:var(--purple-ink)}

/* =========================================================================
   Navy textured fold — shared brand treatment (grid + repurposed hero image)
   ========================================================================= */
.navy-fold{position:relative;overflow:hidden;background:var(--navy);color:#fff;
  isolation:isolate;border-bottom:1px solid var(--line)}
.nf-bg{position:absolute;inset:0;pointer-events:none;overflow:hidden;z-index:0}
.nf-img{position:absolute;inset:0;
  background:url("../assets/hero-bg.jpg") center 30%/cover no-repeat;
  opacity:.16;mix-blend-mode:luminosity;
  mask-image:linear-gradient(180deg,#000,transparent 92%);
  -webkit-mask-image:linear-gradient(180deg,#000,transparent 92%)}
.nf-grid{position:absolute;inset:0;
  background-image:linear-gradient(to right,rgba(255,255,255,.06) 1px,transparent 1px),
    linear-gradient(to bottom,rgba(255,255,255,.06) 1px,transparent 1px);
  background-size:54px 54px;
  mask-image:radial-gradient(ellipse 90% 85% at 78% 0%,#000 35%,transparent 80%);
  -webkit-mask-image:radial-gradient(ellipse 90% 85% at 78% 0%,#000 35%,transparent 80%)}
.nf-glow{position:absolute;top:-120px;right:-60px;width:620px;height:480px;
  background:radial-gradient(ellipse at center,color-mix(in srgb,var(--accent,#2478FF) 42%,transparent),transparent 60%);
  filter:blur(34px);opacity:.7}
.nf-scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,11,22,.30),rgba(8,11,22,.62))}
.navy-fold > .wrap,.navy-fold > .nf-wrap{position:relative;z-index:1}

/* ---- Solution page hero (navy, textured) ---- */
.phero{position:relative;overflow:hidden;background:var(--navy);color:#fff;isolation:isolate;border-bottom:1px solid var(--line)}
.phero-inner{position:relative;z-index:1;display:grid;grid-template-columns:1.04fr .96fr;gap:54px;align-items:center;
  padding:clamp(58px,7vw,96px) 0}
.pbadge{display:inline-flex;align-items:center;gap:8px;font-family:'JetBrains Mono',monospace;font-size:11px;
  font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#fff;
  background:color-mix(in srgb,var(--accent) 22%,transparent);
  border:1px solid color-mix(in srgb,var(--accent) 50%,transparent);
  padding:6px 13px;border-radius:999px;margin-bottom:22px}
.pbadge .d{width:8px;height:8px;border-radius:50%;background:var(--accent);
  box-shadow:0 0 0 4px color-mix(in srgb,var(--accent) 22%,transparent)}
.phero h1{font-size:clamp(32px,4.6vw,52px);line-height:1.06;letter-spacing:-.03em;font-weight:500;color:#F5F8FF}
.phero-sub{margin-top:22px;font-size:clamp(16px,1.5vw,18px);line-height:1.6;color:rgba(245,248,255,.82);max-width:54ch}
.phero-actions{margin-top:30px;display:flex;gap:13px;flex-wrap:wrap}
.phero .btn-ghost{background:transparent;color:#F5F8FF;border-color:rgba(245,248,255,.28)}
.phero .btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.07)}
.phero-micro{margin-top:18px;font-size:13px;color:rgba(245,248,255,.6);display:inline-flex;align-items:center;gap:9px}
.phero-micro .d{width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 4px color-mix(in srgb,var(--accent) 22%,transparent)}

/* ---- Hero visual frame ---- */
.pvis{position:relative;background:#0b111c;border:1px solid rgba(148,163,184,.22);border-radius:18px;
  box-shadow:0 40px 80px -44px rgba(10,14,26,.55);overflow:hidden;aspect-ratio:7/5;color:#eef2f8}
.pvis-grid{position:absolute;inset:0;opacity:.5;
  background-image:linear-gradient(rgba(148,163,184,.07) 1px,transparent 1px),linear-gradient(90deg,rgba(148,163,184,.07) 1px,transparent 1px);
  background-size:34px 34px;mask:radial-gradient(ellipse 90% 90% at 50% 0%,#000,transparent 80%)}
.pvis-glow{position:absolute;inset:0;background:radial-gradient(ellipse 70% 60% at 50% 12%,color-mix(in srgb,var(--accent) 30%,transparent),transparent 60%)}
.pvis-inner{position:absolute;inset:0;padding:22px;display:flex;flex-direction:column;gap:12px;z-index:1}
.pv-head{display:flex;align-items:center;justify-content:space-between;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.06em;color:#8b97ad;text-transform:uppercase}
.pv-dot{display:inline-flex;align-items:center;gap:7px}
.pv-dot i{width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 4px color-mix(in srgb,var(--accent) 18%,transparent);animation:pv-pulse 2.2s infinite}
@keyframes pv-pulse{0%,100%{opacity:1}50%{opacity:.4}}
.pv-row{display:flex;align-items:center;gap:12px;padding:12px 14px;background:rgba(255,255,255,.03);
  border:1px solid rgba(148,163,184,.16);border-radius:10px;font-size:13px;opacity:0;animation:pv-in .5s var(--ease) forwards}
.pv-row:nth-child(1){animation-delay:.15s}.pv-row:nth-child(2){animation-delay:.45s}
.pv-row:nth-child(3){animation-delay:.75s}.pv-row:nth-child(4){animation-delay:1.05s}
@keyframes pv-in{from{opacity:0;transform:translateX(-10px)}to{opacity:1;transform:none}}
.pv-row .ic{width:26px;height:26px;border-radius:7px;display:grid;place-items:center;flex:0 0 auto;
  background:color-mix(in srgb,var(--accent) 16%,transparent);color:var(--accent)}
.pv-row .ic svg{width:15px;height:15px}
.pv-row .nm{flex:1;color:#cdd5e3}
.pv-tag{font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:600;letter-spacing:.06em;
  padding:3px 8px;border-radius:5px;background:color-mix(in srgb,var(--accent) 18%,transparent);color:var(--accent)}
.pv-tag.warn{background:rgba(251,191,36,.16);color:#fbbf24}
.pv-tag.bad{background:rgba(248,113,113,.16);color:#f87171}
.pv-scan{position:absolute;left:0;right:0;height:120px;z-index:2;pointer-events:none;
  background:linear-gradient(180deg,transparent,color-mix(in srgb,var(--accent) 18%,transparent),transparent);
  animation:pv-sweep 3.4s var(--ease) infinite}
@keyframes pv-sweep{0%{top:-120px}100%{top:100%}}

/* Shield flow visual */
.pflow{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:center;gap:22px;padding:26px;z-index:1}
.pflow-lane{position:relative;display:flex;align-items:center;justify-content:space-between;gap:10px}
.pflow-node{display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center;font-size:11px;color:#8b97ad;font-family:'JetBrains Mono',monospace}
.pflow-node .box{width:66px;height:50px;border-radius:10px;border:1px solid rgba(148,163,184,.2);background:rgba(255,255,255,.03);display:grid;place-items:center;color:#cdd5e3}
.pflow-node.shield .box{border-color:color-mix(in srgb,var(--accent) 50%,transparent);background:color-mix(in srgb,var(--accent) 12%,transparent);color:var(--accent);box-shadow:0 0 0 4px color-mix(in srgb,var(--accent) 10%,transparent)}
.pflow-node .box svg{width:22px;height:22px}
.pflow-track{position:absolute;left:74px;right:74px;top:25px;height:2px;background:rgba(148,163,184,.2)}
.pflow-dot{position:absolute;top:-3px;width:8px;height:8px;border-radius:50%;background:var(--blue)}
.pflow-dot.d1{animation:pflow 2.6s linear infinite}
.pflow-dot.d2{animation:pflow 2.6s linear .9s infinite}
.pflow-dot.d3{animation:pflow 2.6s linear 1.8s infinite}
@keyframes pflow{0%{left:0;opacity:0;background:var(--blue)}10%{opacity:1}48%{left:calc(50% - 4px);background:var(--blue)}54%{background:var(--accent)}90%{opacity:1}100%{left:100%;opacity:0;background:var(--accent)}}
.pflow-chips{display:flex;gap:8px;flex-wrap:wrap;justify-content:center}
.pflow-chip{font-family:'JetBrains Mono',monospace;font-size:10.5px;padding:4px 9px;border-radius:6px;border:1px solid rgba(148,163,184,.18);color:#8b97ad}
.pflow-chip.masked{color:var(--accent);border-color:color-mix(in srgb,var(--accent) 40%,transparent);background:color-mix(in srgb,var(--accent) 10%,transparent)}

/* ---- Section helpers ---- */
.sec-soft{background:var(--bg-soft);border-block:1px solid var(--line)}
.sec-dark{position:relative;overflow:hidden;background:var(--navy);color:#fff;isolation:isolate}
.sec-dark.ink{background:var(--ink)}
.sec-dark::before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background-image:linear-gradient(to right,rgba(255,255,255,.05) 1px,transparent 1px),
    linear-gradient(to bottom,rgba(255,255,255,.05) 1px,transparent 1px);
  background-size:52px 52px;
  mask-image:radial-gradient(ellipse 80% 90% at 50% 0%,#000 30%,transparent 78%);
  -webkit-mask-image:radial-gradient(ellipse 80% 90% at 50% 0%,#000 30%,transparent 78%)}
.sec-dark::after{content:"";position:absolute;left:50%;top:-140px;width:760px;height:420px;transform:translateX(-50%);z-index:0;pointer-events:none;
  background:radial-gradient(ellipse at center,color-mix(in srgb,var(--accent,#2478FF) 26%,transparent),transparent 62%);filter:blur(30px);opacity:.6}
.sec-dark > *{position:relative;z-index:1}
.sec-dark .section-head h2,.sec-dark h2,.sec-dark h3{color:#F5F8FF}
.sec-dark .section-head p,.sec-dark p,.sec-dark .lead{color:rgba(245,248,255,.72)}
.sec-dark .checklist li{color:rgba(245,248,255,.85)}
.sec-dark .checklist li .ck{background:color-mix(in srgb,var(--accent) 26%,transparent);color:#fff}
.sec-dark .step,.sec-dark .info-block,.sec-dark .trust-card,.sec-dark .proof-card{
  background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.12);box-shadow:none}
.sec-dark .step p,.sec-dark .info-block p,.sec-dark .trust-card p,.sec-dark .proof-card .q{color:rgba(245,248,255,.74)}
.sec-dark .step h3,.sec-dark .info-block h3,.sec-dark .trust-card h3{color:#F5F8FF}
.sec-dark .step-num{background:color-mix(in srgb,var(--accent) 24%,transparent);color:#fff}

/* ---- Navy page-hero band (Pricing / About / Security / Privacy) ---- */
.navy-fold .page-head{padding:clamp(64px,8vw,104px) 0 clamp(40px,5vw,60px)}
.navy-fold .page-head h1{color:#F5F8FF}
.navy-fold .page-head p,.navy-fold .page-head .lead{color:rgba(245,248,255,.8)}
.navy-fold .eyebrow,.sec-dark .eyebrow{color:var(--amber);
  text-shadow:0 0 2px rgba(5,9,18,.9),0 1px 3px rgba(5,9,18,.9)}
.narrow{max-width:760px;margin-left:auto;margin-right:auto}
.lead{font-size:clamp(17px,1.6vw,19px);line-height:1.65;color:var(--ink-3)}

/* ---- Steps (how it works) ---- */
.steps{display:grid;gap:16px;max-width:880px;margin:0 auto;counter-reset:step}
.step{position:relative;display:grid;grid-template-columns:auto 1fr;gap:22px;background:#fff;
  border:1px solid var(--line);border-radius:16px;padding:26px 28px;box-shadow:var(--shadow-card)}
.step-num{width:40px;height:40px;border-radius:11px;background:var(--accent-soft);color:var(--accent-ink);
  display:grid;place-items:center;font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:18px;flex:0 0 auto}
.step h3{font-size:18px;margin-bottom:8px}
.step p{font-size:15px;line-height:1.6}
.step .checklist{margin-top:14px}

/* ---- Checklist ---- */
.checklist{list-style:none;display:grid;gap:11px}
.checklist li{display:flex;gap:11px;align-items:flex-start;font-size:15px;color:var(--ink-2);line-height:1.5}
.checklist li .ck{flex:0 0 20px;width:20px;height:20px;border-radius:6px;background:var(--accent-soft);color:var(--accent-ink);
  display:grid;place-items:center;margin-top:1px}
.checklist li .ck svg{width:13px;height:13px;stroke-width:2.6}
.get-grid{max-width:880px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:14px 40px}
.get-grid .checklist{gap:16px}

/* ---- Proof / quote cards ---- */
.proof-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;max-width:920px;margin:0 auto}
.proof-card{background:#fff;border:1px solid var(--line);border-radius:18px;padding:28px;box-shadow:var(--shadow-card)}
.proof-card .pl{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--accent-ink);margin-bottom:14px}
.proof-card .q{font-size:15.5px;line-height:1.6;color:var(--ink-2)}
.proof-card .by{margin-top:16px;font-size:13.5px;color:var(--ink-4);font-weight:500}

/* ---- Pricing ---- */
.tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;align-items:stretch}
.tier{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:18px;
  padding:30px;box-shadow:var(--shadow-card);position:relative;transition:transform .15s,border-color .15s}
.tier:hover{transform:translateY(-3px)}
.tier.featured{border-color:var(--blue);box-shadow:0 2px 0 rgba(36,120,255,.1),0 24px 50px -24px rgba(36,120,255,.35)}
.tier-flag{position:absolute;top:-11px;left:30px;font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;background:var(--blue);color:#fff;padding:5px 11px;border-radius:6px}
.tier h3{font-size:20px;margin-bottom:8px}
.tier .desc{font-size:14px;color:var(--ink-3);line-height:1.55;min-height:66px}
.tier .checklist{margin:22px 0 26px;font-size:14px}
.tier .checklist li{font-size:14px}
.tier .checklist li .ck{background:var(--blue-soft);color:var(--blue-ink)}
.tier .btn{margin-top:auto;justify-content:center;width:100%}

/* ---- Security / trust cards ---- */
.trust-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.trust-card{background:#fff;border:1px solid var(--line);border-radius:18px;padding:28px;box-shadow:var(--shadow-card)}
.trust-card .tt{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.trust-card .tt .dot{width:9px;height:9px;border-radius:50%}
.trust-card .tt.red .dot{background:var(--red)}.trust-card .tt.green .dot{background:var(--green)}.trust-card .tt.purple .dot{background:var(--purple)}
.trust-card h3{font-size:17px}
.trust-card p{font-size:14.5px;line-height:1.6}
.info-list{max-width:820px;margin:0 auto;display:grid;gap:16px}
.info-block{background:#fff;border:1px solid var(--line);border-radius:16px;padding:24px 26px;box-shadow:var(--shadow-card)}
.info-block h3{font-size:17px;margin-bottom:8px}
.info-block p{font-size:14.5px;line-height:1.6}

/* ---- About prose ---- */
.about-block{max-width:760px;margin:0 auto}
.about-block + .about-block{margin-top:clamp(48px,6vw,72px)}
.about-block h2{margin-bottom:18px}
.about-block p{font-size:clamp(16px,1.5vw,18px);line-height:1.7;color:var(--ink-3)}
.about-block p + p{margin-top:18px}
.about-block strong{color:var(--ink);font-weight:600}
.about-pillars{display:grid;gap:16px;margin-top:8px}
.about-pillar{background:#fff;border:1px solid var(--line);border-radius:16px;padding:24px 26px;box-shadow:var(--shadow-card);
  border-left:3px solid var(--pc,var(--blue))}
.about-pillar.red{--pc:var(--red)}.about-pillar.green{--pc:var(--green)}.about-pillar.purple{--pc:var(--purple)}
.about-pillar h3{font-size:17px;margin-bottom:7px}
.about-pillar p{font-size:15px;line-height:1.6;margin:0}

/* ---- Legal / privacy ---- */
.legal{max-width:760px;margin:0 auto}
.legal .updated{font-family:'JetBrains Mono',monospace;font-size:12.5px;color:var(--ink-4);margin-bottom:8px}
.legal h2{font-size:21px;margin:38px 0 12px;letter-spacing:-.01em}
.legal h3{font-size:16px;margin:22px 0 8px;color:var(--ink)}
.legal p{font-size:15.5px;line-height:1.7;color:var(--ink-3);margin-bottom:12px}
.legal ul{margin:0 0 14px 0;padding-left:0;list-style:none;display:grid;gap:9px}
.legal ul li{position:relative;padding-left:20px;font-size:15.5px;line-height:1.6;color:var(--ink-3)}
.legal ul li::before{content:"";position:absolute;left:2px;top:10px;width:6px;height:6px;border-radius:50%;background:var(--blue)}
.legal a{color:var(--blue-ink);text-decoration:none}.legal a:hover{text-decoration:underline}
.legal strong{color:var(--ink)}

/* page-top spacing for hero-less pages */
.page-head{text-align:center;padding:clamp(60px,8vw,96px) 0 0}
.page-head .eyebrow{margin:0 auto}
.page-head h1{font-size:clamp(32px,4.6vw,52px);line-height:1.05;letter-spacing:-.03em;font-weight:500;margin-top:20px}
.page-head p{margin:20px auto 0;max-width:620px}

/* ---- responsive ---- */
@media(max-width:880px){
  .phero-inner{grid-template-columns:1fr;gap:36px}
  .pvis{order:-1}
  .tiers,.trust-cards{grid-template-columns:1fr}
  .proof-grid{grid-template-columns:1fr}
  .get-grid{grid-template-columns:1fr;gap:14px}
}
@media(max-width:720px){
  .step{grid-template-columns:1fr;gap:14px}
}

/* ---- Customer stories (before / after) ---- */
.stories{display:grid;gap:20px;max-width:940px;margin:0 auto}
.story{background:#fff;border:1px solid var(--line);border-radius:18px;padding:30px 32px;box-shadow:var(--shadow-card)}
.story h3{font-size:19px;margin-bottom:16px;letter-spacing:-.01em}
.story .q{font-size:16px;line-height:1.6;color:var(--ink-2);padding-left:18px;border-left:3px solid var(--blue);margin-bottom:10px}
.story .by{font-size:13px;color:var(--ink-4);font-weight:500;margin-bottom:22px}
.ba{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.ba .cell{border:1px solid var(--line);border-radius:12px;padding:18px 20px;background:var(--bg-soft)}
.ba .lbl{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.08em;text-transform:uppercase;font-weight:600;margin-bottom:9px;display:inline-flex;align-items:center;gap:8px}
.ba .lbl::before{content:"";width:7px;height:7px;border-radius:50%}
.ba .before .lbl{color:var(--red)}.ba .before .lbl::before{background:var(--red)}
.ba .after .lbl{color:var(--green)}.ba .after .lbl::before{background:var(--green)}
.ba p{font-size:14px;line-height:1.6;margin:0;color:var(--ink-3)}
@media(max-width:720px){.ba{grid-template-columns:1fr}}

/* Hero key points — scannable value summary under a tightened subhead */
.phero-sub.tight{max-width:48ch}
.phero-points{margin-top:24px;display:grid;gap:13px}
.phero-point{display:flex;align-items:center;gap:13px;font-size:14.5px;line-height:1.4;color:rgba(245,248,255,.8)}
.phero-point .pp-ic{width:32px;height:32px;border-radius:9px;flex:0 0 auto;display:grid;place-items:center;
  background:color-mix(in srgb,var(--accent) 18%,transparent);color:var(--accent);
  border:1px solid color-mix(in srgb,var(--accent) 38%,transparent)}
.phero-point .pp-ic svg{width:17px;height:17px}
.phero-point b{font-weight:600;color:#F5F8FF}
