@font-face{
  font-family:'Space Grotesk';
  src:url('../assets/fonts/SpaceGrotesk.woff2') format('woff2'),
      url('../assets/fonts/SpaceGrotesk.woff') format('woff');
  font-weight:300 700;
  font-style:normal;
  font-display:swap;
}

@font-face{
  font-family:'Inter';
  src:url('../assets/fonts/Inter.woff2') format('woff2'),
      url('../assets/fonts/Inter.woff') format('woff');
  font-weight:100 900;
  font-style:normal;
  font-display:swap;
}

:root{
    --base:#0F1722;
    --panel:#16202E;
    --panel-2:#1B2735;
    --amber:#E9A23B;
    --honey:#C8821E;
    --offwhite:#F4F1EA;
    --grey:#9AA3AE;
    --line:rgba(244,241,234,0.10);
    --line-strong:rgba(244,241,234,0.18);
    --maxw:1140px;
    --display:'Space Grotesk',system-ui,sans-serif;
    --body:'Inter',system-ui,sans-serif;
  }

  *{box-sizing:border-box;margin:0;padding:0}
  html{scroll-behavior:smooth}
  @media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}

  body{
    background:var(--base);
    color:var(--offwhite);
    font-family:var(--body);
    font-size:18px;
    line-height:1.65;
    -webkit-font-smoothing:antialiased;
    overflow-x:hidden;
  }

  a{color:inherit;text-decoration:none}
  ::selection{background:var(--amber);color:var(--base)}

  /* ---------- layout primitives ---------- */
  .wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
  .band{padding:104px 0}
  .band--tight{padding:84px 0}
  .band--panel{background:var(--panel)}
  .band--panel2{background:var(--panel-2)}

  .eyebrow{
    font-family:var(--display);
    font-size:0.78rem;
    font-weight:600;
    letter-spacing:0.18em;
    text-transform:uppercase;
    color:var(--offwhite);
    display:inline-flex;
    align-items:center;
    gap:10px;
    margin-bottom:22px;
  }
  .eyebrow::before{
    content:"";
    width:14px;height:14px;
    background:var(--amber);
    -webkit-clip-path:polygon(25% 0,75% 0,100% 50%,75% 100%,25% 100%,0 50%);
    clip-path:polygon(25% 0,75% 0,100% 50%,75% 100%,25% 100%,0 50%);
    opacity:0.9;
  }

  h1,h2,h3{font-family:var(--display);font-weight:600;line-height:1.08;letter-spacing:-0.01em}
  h2{font-size:clamp(1.9rem,4vw,2.9rem);max-width:18ch;margin-bottom:22px}
  h3{font-size:1.18rem;letter-spacing:0;margin-bottom:10px}
  p{max-width:62ch}
  .lead{color:var(--grey);font-size:1.12rem;max-width:60ch}

  .amber{color:var(--amber)}

  /* ---------- buttons ---------- */
  .btn{
    display:inline-flex;align-items:center;gap:9px;
    font-family:var(--display);font-weight:600;font-size:1rem;
    padding:15px 26px;border-radius:2px;
    transition:transform .18s ease,background .18s ease,border-color .18s ease;
    cursor:pointer;border:1px solid transparent;
  }
  .btn--primary{background:var(--amber);color:var(--base)}
  .btn--primary:hover{background:var(--honey)}
  .btn--ghost{border-color:var(--line-strong);color:var(--offwhite)}
  .btn--ghost:hover{border-color:var(--amber);color:var(--amber)}
  .btn:focus-visible{outline:3px solid var(--amber);outline-offset:3px}
  .btn .arr{transition:transform .18s ease}
  .btn:hover .arr{transform:translateX(3px)}
  @media (prefers-reduced-motion:reduce){.btn,.btn .arr{transition:none}}

  a:focus-visible{outline:3px solid var(--amber);outline-offset:3px;border-radius:2px}

  /* ---------- header ---------- */
  header{
    position:sticky;top:0;z-index:50;
    background:rgba(15,23,34,0.82);
    backdrop-filter:blur(10px);
    border-bottom:1px solid var(--line);
  }
  .nav{display:flex;align-items:center;justify-content:space-between;height:66px}
  .brand{display:flex;align-items:center;gap:11px;font-family:var(--display);font-weight:700;font-size:1.22rem;letter-spacing:-0.01em}
  .brand .mark{
    width:26px;height:29px;display:inline-block;
    background:var(--amber);
    -webkit-clip-path:polygon(25% 0,75% 0,100% 50%,75% 100%,25% 100%,0 50%);
    clip-path:polygon(25% 0,75% 0,100% 50%,75% 100%,25% 100%,0 50%);
  }
  .brand small{color:var(--grey);font-weight:500;font-size:0.62em;letter-spacing:0.05em}
  .nav-links{display:flex;align-items:center;gap:30px;font-size:0.95rem;color:var(--grey);font-family:var(--display);font-weight:500}
  .nav-links a:hover{color:var(--offwhite)}
  .nav .btn{padding:10px 20px;font-size:0.92rem}
  @media(max-width:820px){.nav-links a:not(.btn){display:none}}

  /* ---------- hex background ---------- */
  .hexbg{position:absolute;inset:0;z-index:0;opacity:0.5;pointer-events:none;background-image:url(../assets/svg/hex-pattern.svg);background-size:135px 78px;background-repeat:repeat;-webkit-mask-image:radial-gradient(62% 62% at 50% 58%,#000 0%,rgba(0,0,0,0) 100%);mask-image:radial-gradient(62% 62% at 50% 58%,#000 0%,rgba(0,0,0,0) 100%)}
  .hexbg svg{width:100%;height:100%}

  /* ---------- hero ---------- */
  .hero{position:relative;overflow:hidden;padding:130px 0 120px;border-bottom:1px solid var(--line)}
  .hero .wrap{position:relative;z-index:1}
  .hero h1{font-size:clamp(2.5rem,4.6vw,3.8rem);max-width:20ch;font-weight:700;margin-bottom:28px}
  .hero .sub{font-size:clamp(1.1rem,2vw,1.32rem);color:var(--offwhite);max-width:56ch;margin-bottom:38px;line-height:1.5}
  .hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:30px}
  .hero .support{color:var(--grey);font-size:1rem;max-width:46ch}
  .hero .support .amber{font-weight:500}

  /* ---------- problem ---------- */
  .problem h2{max-width:20ch}
  .problem .body p{margin-top:20px;color:var(--grey);font-size:1.12rem}
  .problem .body p:first-child{color:var(--offwhite)}
  .problem .kicker{color:var(--offwhite);font-size:1.2rem;font-weight:500;margin-top:26px}

  /* ---------- applied intelligence + diagram ---------- */
  .ai-grid{display:grid;grid-template-columns:1.05fr 0.95fr;gap:64px;align-items:center}
  @media(max-width:900px){.ai-grid{grid-template-columns:1fr;gap:48px}}
  .ai-copy p{color:var(--grey);font-size:1.1rem;margin-top:18px}
  .pull{
    margin-top:30px;padding:22px 26px;border-left:2px solid var(--amber);
    background:rgba(233,162,59,0.06);font-family:var(--display);
    font-size:1.18rem;line-height:1.4;color:var(--offwhite);max-width:46ch;
  }

  .diagram{display:flex;flex-direction:column;align-items:center;gap:0}
  .di-inputs{display:flex;flex-wrap:wrap;justify-content:center;gap:12px;max-width:420px}
  .di-node{
    display:flex;align-items:center;gap:9px;
    padding:11px 16px;border:1px solid var(--line-strong);border-radius:2px;
    background:var(--base);font-family:var(--display);font-weight:500;font-size:0.95rem;
  }
  .band--panel .di-node{background:var(--panel-2)}
  .di-node .hx{
    width:11px;height:10px;background:var(--amber);flex:none;
    -webkit-clip-path:polygon(25% 0,75% 0,100% 50%,75% 100%,25% 100%,0 50%);
    clip-path:polygon(25% 0,75% 0,100% 50%,75% 100%,25% 100%,0 50%);
  }
  .di-funnel{width:2px;height:40px;background:linear-gradient(var(--line-strong),var(--amber));margin:6px 0}
  .di-out{
    text-align:center;padding:24px 30px;border:1px solid var(--amber);border-radius:2px;
    background:rgba(233,162,59,0.07);max-width:340px;
  }
  .di-out .lbl{font-family:var(--display);font-size:0.72rem;letter-spacing:0.16em;text-transform:uppercase;color:var(--amber);margin-bottom:8px}
  .di-out strong{font-family:var(--display);font-weight:600;font-size:1.22rem;line-height:1.25;display:block}

  /* ---------- how we work ---------- */
  .steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:3px;overflow:hidden;margin-top:48px}
  @media(max-width:840px){.steps{grid-template-columns:1fr 1fr}}
  @media(max-width:520px){.steps{grid-template-columns:1fr}}
  .step{background:var(--base);padding:34px 28px;position:relative}
  .band--panel .step{background:var(--panel)}
  .step .num{font-family:var(--display);font-weight:700;font-size:0.92rem;color:var(--amber);letter-spacing:0.1em;margin-bottom:18px;display:flex;align-items:center;gap:9px}
  .step .num::after{content:"";flex:1;height:1px;background:var(--line)}
  .step p{color:var(--grey);font-size:0.98rem}
  .work-close{margin-top:34px;color:var(--grey);font-size:1.08rem;max-width:58ch}

  /* ---------- what we do ---------- */
  .cap-intro{margin-bottom:46px}
  .caps{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
  @media(max-width:900px){.caps{grid-template-columns:1fr 1fr}}
  @media(max-width:600px){.caps{grid-template-columns:1fr}}
  .cap{
    padding:30px 28px;border:1px solid var(--line);border-radius:3px;background:var(--panel);
    transition:transform .2s ease,border-color .2s ease;position:relative;
  }
  .band--panel .cap{background:var(--base)}
  .cap:hover{transform:translateY(-4px);border-color:var(--line-strong)}
  @media (prefers-reduced-motion:reduce){.cap{transition:none}.cap:hover{transform:none}}
  .cap .ico{
    width:46px;height:40px;margin-bottom:20px;display:flex;align-items:center;justify-content:center;
    background:rgba(233,162,59,0.08);
    -webkit-clip-path:polygon(25% 0,75% 0,100% 50%,75% 100%,25% 100%,0 50%);
    clip-path:polygon(25% 0,75% 0,100% 50%,75% 100%,25% 100%,0 50%);
  }
  .cap .ico svg{width:23px;height:23px;stroke:var(--amber);fill:none;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
  .cap p{color:var(--grey);font-size:0.98rem}

  /* ---------- who we help ---------- */
  .who-grid{display:grid;grid-template-columns:0.85fr 1.15fr;gap:56px;align-items:start}
  @media(max-width:880px){.who-grid{grid-template-columns:1fr;gap:36px}}
  .who-intro p{color:var(--grey);font-size:1.08rem;margin-top:18px}
  .checklist{list-style:none;display:grid;gap:14px}
  .checklist li{display:flex;gap:14px;align-items:flex-start;font-size:1.04rem;line-height:1.45}
  .checklist .hx{
    width:13px;height:11px;margin-top:5px;flex:none;background:var(--amber);
    -webkit-clip-path:polygon(25% 0,75% 0,100% 50%,75% 100%,25% 100%,0 50%);
    clip-path:polygon(25% 0,75% 0,100% 50%,75% 100%,25% 100%,0 50%);
  }
  .who-note{margin-top:30px;font-family:var(--display);font-size:1.12rem;color:var(--offwhite);max-width:54ch;line-height:1.4}

  /* ---------- what changes ---------- */
  .changes p{font-size:1.14rem;color:var(--grey);margin-top:20px;max-width:64ch}
  .changes p strong{color:var(--offwhite);font-weight:500}
  .changes .first{color:var(--offwhite)}

  /* ---------- advise & build ---------- */
  .build .lead{margin-bottom:8px}
  .build p{color:var(--grey);font-size:1.1rem;margin-top:20px;max-width:64ch}
  .build .rev{color:var(--offwhite)}

  /* ---------- name ---------- */
  .name-grid{display:grid;grid-template-columns:1fr 0.7fr;gap:56px;align-items:center}
  @media(max-width:880px){.name-grid{grid-template-columns:1fr;gap:40px}}
  .name p{color:var(--grey);font-size:1.08rem;margin-top:18px}
  .name .port{margin-top:26px;font-size:0.95rem;color:var(--grey);border-top:1px solid var(--line);padding-top:20px}
  .name .port code{font-family:var(--display);color:var(--amber);font-weight:600}
  .hivewrap{display:flex;justify-content:center}
  .hivewrap svg{width:100%;max-width:280px;height:auto}

  /* ---------- final cta ---------- */
  .final{position:relative;overflow:hidden;text-align:center;padding:120px 0;border-top:1px solid var(--line)}
  .final .wrap{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center}
  .final h2{max-width:22ch;margin-left:auto;margin-right:auto}
  .final p{color:var(--grey);font-size:1.12rem;margin:0 auto 34px;text-align:center}
  .final .support{color:var(--grey);margin-top:20px;font-size:0.98rem}

  /* ---------- footer ---------- */
  footer{background:#0B121B;border-top:1px solid var(--line);padding:48px 0}
  .foot{display:flex;flex-wrap:wrap;justify-content:space-between;gap:24px;align-items:center}
  .foot .pos{font-family:var(--display);font-weight:500;color:var(--offwhite);font-size:0.98rem}
  .foot .flinks{display:flex;gap:24px;color:var(--grey);font-size:0.92rem;font-family:var(--display)}
  .foot .flinks a:hover{color:var(--amber)}
  .foot .legal{width:100%;color:var(--offwhite);font-size:0.82rem;border-top:1px solid var(--line);padding-top:22px;margin-top:8px}
  .foot .legal div{margin-top:4px}

  /* ---------- reveal animation ---------- */
  .reveal{opacity:0;transform:translateY(22px);transition:opacity .6s ease,transform .6s ease}
  .reveal.in{opacity:1;transform:none}
  @media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

  /* ---------- real brand assets ---------- */
  .brand img{height:33px;width:auto;display:block}
  .brand small{align-self:center}
  .hero-photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 62%;z-index:0}
  .hero-shade{position:absolute;inset:0;z-index:0;background:
    linear-gradient(90deg,rgba(15,23,34,0.95) 0%,rgba(15,23,34,0.88) 40%,rgba(15,23,34,0.58) 74%,rgba(15,23,34,0.40) 100%),
    linear-gradient(0deg,rgba(15,23,34,0.86) 0%,rgba(15,23,34,0.12) 46%)}
  .name-photo-wrap{display:flex;justify-content:center;position:relative}
  .name-photo{width:100%;max-width:330px;aspect-ratio:1.1547;object-fit:cover;filter:saturate(1.04);
    -webkit-clip-path:polygon(25% 0,75% 0,100% 50%,75% 100%,25% 100%,0 50%);
    clip-path:polygon(25% 0,75% 0,100% 50%,75% 100%,25% 100%,0 50%)}
  .foot-logo{height:30px;width:auto;display:block;margin-bottom:14px}


  /* ---------- distro additions ---------- */
  .cap .ico img{width:23px;height:23px;display:block}

  /* ---------- data ownership ---------- */
  .data-own p{color:var(--grey);font-size:1.1rem;margin-top:20px;max-width:64ch}
  .data-own .lead{color:var(--offwhite);margin-top:0}
  .manifesto{border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
  .manifesto .wrap{max-width:840px}
  .manifesto h2{color:var(--amber);max-width:14ch}
  .manifesto p{font-size:1.12rem;color:var(--grey);margin-top:18px}
  .manifesto p strong{color:var(--offwhite);font-weight:500}
  .manifesto .close{font-family:var(--display);color:var(--offwhite);font-size:1.16rem;line-height:1.45;margin-top:26px;max-width:58ch}