/* =========================================================
   hiveia — applied AI studio
   ========================================================= */

:root{
  --ink:#0b0b0c;
  --ink-soft:#22232a;
  --paper:#f6f5f1;        /* warm off-white */
  --paper-pure:#ffffff;
  --mint:#99ffcc;
  --mint-deep:#34d9a0;
  --muted:#8a8a86;
  --line:rgba(11,11,12,.12);
  --line-inv:rgba(255,255,255,.16);

  --maxw:1320px;
  --pad:clamp(20px,5vw,72px);

  --f-display:"Space Grotesk",system-ui,sans-serif;
  --f-body:"Inter",system-ui,sans-serif;
  --f-mono:"Space Mono",ui-monospace,monospace;

  --ease:cubic-bezier(.16,1,.3,1);
}

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

body{
  font-family:var(--f-body);
  background:var(--paper);
  color:var(--ink);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
  line-height:1.5;
}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
::selection{background:var(--mint);color:var(--ink)}

/* film grain overlay */
.grain{
  position:fixed;inset:0;z-index:9998;pointer-events:none;opacity:.04;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* custom cursor (desktop fine pointers only) */
.cursor{
  position:fixed;top:0;left:0;width:9px;height:9px;border-radius:50%;
  background:var(--ink);z-index:9999;pointer-events:none;
  transform:translate(-50%,-50%);transition:width .25s var(--ease),height .25s var(--ease),background .25s var(--ease),opacity .3s;
  mix-blend-mode:difference;opacity:0;
}
.cursor.is-hover{width:46px;height:46px;background:var(--mint)}
@media (hover:hover) and (pointer:fine){.cursor{opacity:1}}
@media (hover:none){.cursor{display:none}}

/* =================== shared type =================== */
.eyebrow{
  font-family:var(--f-mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;
  display:inline-flex;align-items:center;gap:.55em;color:var(--ink);
}
.eyebrow--muted{color:var(--muted)}
.eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--mint-deep);box-shadow:0 0 0 4px rgba(52,217,160,.18)}

.section-index{
  font-family:var(--f-mono);font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--muted);margin-bottom:1.4rem;
}
.section-index--inv{color:rgba(255,255,255,.55)}

.h-section{
  font-family:var(--f-display);font-weight:600;line-height:.98;letter-spacing:-.02em;
  font-size:clamp(2.4rem,6vw,5rem);
}

.hl{
  background:linear-gradient(transparent 8%, var(--mint) 8%, var(--mint) 92%, transparent 92%);
  padding:0 .06em;
  box-decoration-break:clone;-webkit-box-decoration-break:clone;
}
.hl-text{position:relative;white-space:nowrap}
.hl-text::after{
  content:"";position:absolute;left:-.04em;right:-.04em;bottom:.06em;height:.34em;
  background:var(--mint);z-index:-1;border-radius:1px;
}

/* =================== buttons =================== */
.btn{
  --bg:var(--ink);--fg:var(--paper);
  display:inline-flex;align-items:center;gap:.6em;
  background:var(--bg);color:var(--fg);
  font-family:var(--f-display);font-weight:500;font-size:.95rem;
  padding:.85em 1.3em;border-radius:100px;border:1px solid var(--bg);
  cursor:pointer;transition:transform .4s var(--ease),background .3s,color .3s,border-color .3s;
  will-change:transform;
}
.btn svg{transition:transform .4s var(--ease)}
.btn:hover{transform:translateY(-2px)}
.btn:hover svg{transform:translate(2px,-2px)}
.btn--sm{font-size:.82rem;padding:.6em 1.05em}
.btn--lg{font-size:1.05rem;padding:1em 1.7em}
.btn--ghost{--bg:transparent;--fg:var(--ink);border-color:var(--line)}
.btn--ghost:hover{border-color:var(--ink)}

/* =================== brand wordmark =================== */
.brand{display:inline-flex;align-items:baseline;gap:.6rem;line-height:1}
.brand__mark{font-family:var(--f-display);font-size:1.5rem;letter-spacing:-.01em;display:inline-block;line-height:1}
.brand__hive{
  font-weight:700;color:var(--ink);
  background:linear-gradient(transparent 56%, var(--mint) 56%, var(--mint) 90%, transparent 90%);
}
.brand__ia{font-weight:400;color:var(--ink)}
.brand__tag{font-family:var(--f-mono);font-size:.66rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
@media (max-width:560px){.brand__tag{display:none}}

/* =================== NAV =================== */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;transition:transform .5s var(--ease)}
.nav.is-hidden{transform:translateY(-110%)}
.nav__inner{
  max-width:var(--maxw);margin:0 auto;padding:18px var(--pad);
  display:flex;align-items:center;justify-content:space-between;gap:1.5rem;
}
.nav::before{
  content:"";position:absolute;inset:0;backdrop-filter:blur(12px);
  background:linear-gradient(var(--paper),rgba(246,245,241,.6));
  opacity:0;transition:opacity .4s;z-index:-1;border-bottom:1px solid transparent;
}
.nav.is-scrolled::before{opacity:1;border-bottom-color:var(--line)}
.nav__links{display:flex;gap:2rem}
.nav__links a{
  font-family:var(--f-mono);font-size:.8rem;letter-spacing:.04em;position:relative;padding:4px 0;color:var(--ink-soft);
}
.nav__links a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1.5px;background:var(--ink);transition:width .35s var(--ease)}
.nav__links a:hover::after{width:100%}
@media (max-width:880px){.nav__links,.nav .btn--sm{display:none}}

.nav__burger{display:none;background:none;border:0;flex-direction:column;gap:5px;cursor:pointer;padding:8px}
.nav__burger span{width:24px;height:2px;background:var(--ink);transition:.3s var(--ease)}
.nav__burger[aria-expanded="true"] span:first-child{transform:translateY(7px) rotate(45deg)}
.nav__burger[aria-expanded="true"] span:last-child{transform:translateY(-7px) rotate(-45deg)}
@media (max-width:880px){.nav__burger{display:flex}}

.nav__mobile{
  position:fixed;inset:0;background:var(--paper);z-index:99;
  display:flex;flex-direction:column;justify-content:center;gap:.4rem;padding:var(--pad);
  transform:translateY(-100%);transition:transform .55s var(--ease);
}
.nav__mobile.is-open{transform:translateY(0)}
.nav__mobile a{font-family:var(--f-display);font-weight:600;font-size:clamp(2rem,9vw,3.2rem);letter-spacing:-.02em;line-height:1.25}
.nav__mobile-cta{color:var(--mint-deep)}

/* =================== HERO =================== */
.hero{
  max-width:var(--maxw);margin:0 auto;padding:clamp(120px,18vh,200px) var(--pad) clamp(40px,6vh,72px);
  min-height:100svh;display:flex;flex-direction:column;justify-content:center;position:relative;
}
.hero__meta{display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;margin-bottom:clamp(1.5rem,5vh,3rem)}
.hero__title{
  font-family:var(--f-display);font-weight:600;
  font-size:clamp(2.9rem,10.5vw,9.5rem);line-height:.92;letter-spacing:-.035em;
}
.hero__title .line{display:block;overflow:hidden}
.hero__bottom{
  display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(1.5rem,4vw,4rem);align-items:end;
  margin-top:clamp(2.5rem,7vh,4.5rem);
}
.hero__lede{font-size:clamp(1.05rem,1.5vw,1.3rem);max-width:46ch;color:var(--ink-soft)}
.hero__cta{display:flex;gap:.8rem;flex-wrap:wrap;justify-self:end}
@media (max-width:760px){.hero__bottom{grid-template-columns:1fr}.hero__cta{justify-self:start}}

.hero__scroll{position:absolute;left:var(--pad);bottom:clamp(20px,4vh,40px);display:flex;align-items:center;gap:.7rem;font-family:var(--f-mono);font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.hero__scroll-line{width:46px;height:1px;background:var(--ink);position:relative;overflow:hidden}
.hero__scroll-line::after{content:"";position:absolute;inset:0;background:var(--mint-deep);animation:scrollline 2.2s var(--ease) infinite}
@keyframes scrollline{0%{transform:translateX(-100%)}60%,100%{transform:translateX(100%)}}
@media (max-width:760px){.hero__scroll{display:none}}

/* =================== MARQUEE =================== */
.trust{padding:clamp(2rem,5vh,3.5rem) 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.trust__label{text-align:center;font-family:var(--f-mono);font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:2rem}
.marquee{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.marquee__track{display:flex;width:max-content;animation:marquee 38s linear infinite}
.marquee:hover .marquee__track{animation-play-state:paused}
.marquee__group{display:flex;align-items:center;gap:clamp(2.5rem,5vw,5rem);padding-right:clamp(2.5rem,5vw,5rem)}
.marquee__group img{height:30px;width:auto;opacity:.55;filter:grayscale(1);transition:opacity .3s,filter .3s}
.marquee__group img:hover{opacity:1;filter:grayscale(0)}
@keyframes marquee{to{transform:translateX(-50%)}}

/* =================== STATEMENT =================== */
.statement{max-width:var(--maxw);margin:0 auto;padding:clamp(5rem,12vh,9rem) var(--pad)}
.statement__text{
  font-family:var(--f-display);font-weight:500;letter-spacing:-.02em;line-height:1.12;
  font-size:clamp(1.7rem,4.2vw,3.6rem);max-width:18ch;margin:0 0 clamp(2.5rem,6vh,4rem);
}
.statement__text em{font-style:italic;font-family:var(--f-body);font-weight:400}
.statement__cols{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.5rem,4vw,4rem);max-width:880px;margin-left:auto}
.statement__cols p{font-size:1.05rem;color:var(--ink-soft)}
@media (max-width:680px){.statement__cols{grid-template-columns:1fr}}

/* =================== STATS =================== */
.stats{
  max-width:var(--maxw);margin:0 auto;padding:0 var(--pad) clamp(4rem,10vh,7rem);
  display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);
  border:1px solid var(--line);border-radius:18px;overflow:hidden;
}
.stat{background:var(--paper);padding:clamp(1.6rem,3vw,2.6rem);display:flex;flex-direction:column;gap:.4rem}
.stat__num{font-family:var(--f-display);font-weight:600;font-size:clamp(2.2rem,5vw,3.4rem);line-height:1;letter-spacing:-.02em;display:inline-block}
.stat__plus{display:none}
.stat__label{font-family:var(--f-mono);font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}
@media (max-width:760px){.stats{grid-template-columns:1fr 1fr}}
@media (max-width:420px){.stats{grid-template-columns:1fr}}

/* =================== SERVICES =================== */
.services{max-width:var(--maxw);margin:0 auto;padding:clamp(4rem,10vh,7rem) var(--pad)}
.services__head{margin-bottom:clamp(2.5rem,6vh,4rem)}
.svc-list{border-top:1px solid var(--line)}
.svc{
  display:grid;grid-template-columns:64px 1fr auto;gap:clamp(1rem,3vw,3rem);align-items:start;
  padding:clamp(1.8rem,4vh,3rem) 0;border-bottom:1px solid var(--line);position:relative;
  transition:padding-left .5s var(--ease);
}
.svc::before{content:"";position:absolute;left:-100%;top:0;bottom:0;right:-100%;background:rgba(11,11,12,.02);opacity:0;transition:opacity .4s;z-index:-1}
.svc:hover{padding-left:18px}
.svc:hover::before{opacity:1}
.svc__no{font-family:var(--f-mono);font-size:.85rem;color:var(--mint-deep);padding-top:.5rem}
.svc__body h3{font-family:var(--f-display);font-weight:600;font-size:clamp(1.5rem,3.4vw,2.5rem);letter-spacing:-.02em;line-height:1.04;margin-bottom:.8rem}
.svc__body p{max-width:54ch;color:var(--ink-soft);font-size:1.02rem;margin-bottom:1.2rem}
.svc__tags{list-style:none;display:flex;flex-wrap:wrap;gap:.5rem}
.svc__tags li{font-family:var(--f-mono);font-size:.72rem;letter-spacing:.02em;padding:.4em .8em;border:1px solid var(--line);border-radius:100px;color:var(--ink-soft)}
.svc__aas{font-family:var(--f-mono);font-size:.72rem;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);white-space:nowrap;padding-top:.6rem}
@media (max-width:860px){
  .svc{grid-template-columns:40px 1fr}
  .svc__aas{grid-column:2;padding-top:.4rem}
}

/* =================== APPROACH =================== */
.approach{max-width:var(--maxw);margin:0 auto;padding:clamp(4rem,10vh,7rem) var(--pad)}
.approach__head{margin-bottom:clamp(2.5rem,6vh,4rem)}
.process{list-style:none;display:grid;grid-template-columns:repeat(5,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:18px;overflow:hidden}
.proc{background:var(--paper);padding:clamp(1.4rem,2.4vw,2.2rem);display:flex;flex-direction:column;gap:.7rem;min-height:240px;transition:background .4s}
.proc:hover{background:var(--paper-pure)}
.proc__no{font-family:var(--f-mono);font-size:.8rem;color:var(--mint-deep)}
.proc h3{font-family:var(--f-display);font-weight:600;font-size:1.4rem;letter-spacing:-.01em;margin-top:auto}
.proc p{font-size:.92rem;color:var(--ink-soft)}
@media (max-width:980px){.process{grid-template-columns:1fr 1fr}.proc{min-height:auto}}
@media (max-width:480px){.process{grid-template-columns:1fr}}

/* =================== WORK / CLIENTS =================== */
.work{max-width:var(--maxw);margin:0 auto;padding:clamp(4rem,10vh,7rem) var(--pad)}
.work__head{margin-bottom:clamp(2.5rem,6vh,4rem)}
.logo-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);
  border:1px solid var(--line);border-radius:18px;overflow:hidden;
}
.logo-cell{background:var(--paper-pure);aspect-ratio:16/9;display:flex;align-items:center;justify-content:center;padding:clamp(1rem,3vw,2rem);transition:background .35s}
.logo-cell:hover{background:var(--paper)}
.logo-cell img{max-height:42px;width:auto;max-width:74%;opacity:.78;filter:grayscale(1);transition:opacity .35s,filter .35s,transform .35s var(--ease)}
.logo-cell:hover img{opacity:1;filter:grayscale(0);transform:scale(1.05)}
@media (max-width:860px){.logo-grid{grid-template-columns:repeat(3,1fr)}.logo-cell--wide{grid-column:auto}}
@media (max-width:520px){.logo-grid{grid-template-columns:repeat(2,1fr)}}

.work__delivered{margin-top:clamp(2.5rem,6vh,4rem);text-align:center}
.work__delivered-label{font-family:var(--f-mono);font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:1.8rem}
.logo-row{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:clamp(2rem,5vw,4.5rem)}
.logo-row img{height:38px;width:auto;opacity:.7;filter:grayscale(1);transition:opacity .35s,filter .35s}
.logo-row img:hover{opacity:1;filter:grayscale(0)}

/* =================== ETHOS (dark) =================== */
.ethos{background:var(--ink);color:var(--paper);margin-top:clamp(2rem,5vh,4rem)}
.ethos>*{max-width:var(--maxw);margin-left:auto;margin-right:auto}
.ethos{padding:clamp(5rem,12vh,9rem) 0}
.ethos__head,.ethos__cols{padding-left:var(--pad);padding-right:var(--pad)}
.ethos__head{margin-bottom:clamp(2.5rem,6vh,4rem)}
.ethos__head .h-section{color:var(--paper)}
.ethos__cols{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,5rem)}
.ethos__title{font-family:var(--f-display);font-weight:600;font-size:1.6rem;margin-bottom:1.6rem;letter-spacing:-.01em}
.ethos__col--dont .ethos__title{color:var(--muted)}
.ethos__list{list-style:none}
.ethos__list li{
  font-family:var(--f-display);font-weight:500;font-size:clamp(1.3rem,2.6vw,2rem);letter-spacing:-.01em;
  padding:.7rem 0;border-bottom:1px solid var(--line-inv);display:flex;align-items:center;gap:1rem;
  transition:padding-left .4s var(--ease),color .3s;
}
.ethos__list li::before{content:"+";color:var(--mint);font-family:var(--f-mono);font-size:1rem}
.ethos__list--dont li{color:rgba(246,245,241,.5)}
.ethos__list--dont li::before{content:"–";color:var(--muted)}
.ethos__list li:hover{padding-left:10px}
@media (max-width:680px){.ethos__cols{grid-template-columns:1fr;gap:2.5rem}}

/* =================== CONTACT =================== */
.contact{max-width:var(--maxw);margin:0 auto;padding:clamp(5rem,13vh,10rem) var(--pad);text-align:center}
.contact__title{font-family:var(--f-display);font-weight:600;font-size:clamp(2.6rem,8vw,7rem);line-height:.96;letter-spacing:-.03em;margin:0 0 clamp(2rem,5vh,3rem)}
.contact__email{
  display:inline-block;font-family:var(--f-display);font-weight:500;
  font-size:clamp(1.4rem,4vw,2.6rem);letter-spacing:-.01em;position:relative;padding-bottom:.1em;
}
.contact__email::after{content:"";position:absolute;left:0;bottom:0;width:100%;height:2px;background:var(--ink);transform:scaleX(0);transform-origin:left;transition:transform .45s var(--ease)}
.contact__email:hover::after{transform:scaleX(1)}
.contact__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;max-width:760px;margin:clamp(3rem,7vh,5rem) auto 0;text-align:left}
.contact__grid>div{display:flex;flex-direction:column;gap:.4rem}
.contact__k{font-family:var(--f-mono);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.contact__grid a:hover{color:var(--mint-deep)}
@media (max-width:680px){.contact__grid{grid-template-columns:1fr;text-align:center}.contact__grid>div{align-items:center}}

/* =================== FOOTER =================== */
.footer{background:var(--ink);color:var(--paper);padding:clamp(3rem,6vh,4.5rem) var(--pad) 2.5rem}
.footer__top{max-width:var(--maxw);margin:0 auto;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;padding-bottom:2.5rem;border-bottom:1px solid var(--line-inv)}
.brand--footer .brand__mark{font-size:2rem;color:var(--paper)}
.brand--footer .brand__hive{color:var(--paper)}
.brand--footer .brand__ia{color:var(--paper)}
.footer__line{font-family:var(--f-display);font-size:1.05rem;color:rgba(246,245,241,.7)}
.footer__bottom{max-width:var(--maxw);margin:2rem auto 0;display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;font-family:var(--f-mono);font-size:.74rem;letter-spacing:.04em;color:var(--muted)}

/* =================== reveal animation =================== */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.is-in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}.marquee__track,.hero__scroll-line::after{animation:none}}
