/* ============================================================
   AUTOMERA — premium studio site
   Faithful re-build of aircenter.space:
   pure white, thin black Onest type, oversized + wide tracking,
   massive whitespace, a 3D twisting ribbed tower hero (CSS 3D),
   scroll reveal, subtle parallax, line-by-line headline reveal.
   Style per ui-ux-pro-max: "Exaggerated Minimalism", monochrome.
   ============================================================ */

:root{
  --paper:#ffffff;
  --paper-2:#f4f3f1;
  --ink:#0a0a0a;
  --ink-2:#1d1d1f;
  --muted:#8a8a8a;
  --line:#e7e6e3;
  --ease:cubic-bezier(.22,.61,.36,1);
  --pad:clamp(20px,5vw,96px);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'Onest',-apple-system,BlinkMacSystemFont,sans-serif;
  background:var(--paper);
  color:var(--ink);
  font-weight:400;
  line-height:1.45;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
.not-ready *{transition:none!important;animation:none!important}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
::selection{background:var(--ink);color:#fff}
:focus-visible{outline:2px solid var(--ink);outline-offset:3px}

/* ---------- type ---------- */
.eyebrow{
  font-size:12px;font-weight:500;letter-spacing:.24em;text-transform:uppercase;
  color:var(--muted);display:inline-flex;align-items:center;gap:14px;
}
.eyebrow::before{content:"";width:30px;height:1px;background:currentColor;opacity:.6}

.display{
  font-weight:300;
  font-size:clamp(44px,9.5vw,168px);
  line-height:.92;
  letter-spacing:-.045em;
}
h2.section-title{
  font-weight:300;
  font-size:clamp(34px,6.4vw,108px);
  line-height:.98;
  letter-spacing:-.04em;
}
.lead{
  font-size:clamp(17px,1.45vw,21px);
  font-weight:400;line-height:1.6;
  color:#52514f;max-width:48ch;
}

/* ============================================================
   NAV
   ============================================================ */
header.nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:24px var(--pad);
  transition:background .4s var(--ease),padding .4s var(--ease),border-color .4s;
  border-bottom:1px solid transparent;
}
header.nav.scrolled{background:rgba(255,255,255,.82);backdrop-filter:blur(14px);
  border-color:var(--line);padding:16px var(--pad)}
.brand{font-weight:500;font-size:21px;letter-spacing:.4em;padding-left:.4em}
.nav-links{display:flex;gap:42px;font-size:13.5px;font-weight:500;letter-spacing:.02em}
.nav-links a{color:var(--ink-2);position:relative;padding:4px 0}
.nav-links a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1px;background:var(--ink);transition:width .35s var(--ease)}
.nav-links a:hover::after{width:100%}
.nav-cta{
  font-size:13.5px;font-weight:500;letter-spacing:.04em;cursor:pointer;
  border:1px solid var(--ink);border-radius:100px;padding:11px 24px;
  transition:background .35s var(--ease),color .35s;
}
.nav-cta:hover{background:var(--ink);color:#fff}
@media(max-width:900px){.nav-links{display:none}}

/* ============================================================
   HERO — AIR layout: giant justified wordmark + centred
   rotating 3D twisting tower + top tagline + side label
   ============================================================ */
.hero{position:relative;min-height:100svh;overflow:hidden;background:var(--paper)}

/* top-centred tagline */
.hero-tagline{position:absolute;top:clamp(78px,12vh,118px);right:var(--pad);
  z-index:4;text-align:right;text-transform:uppercase;font-weight:400;line-height:1.5;
  font-size:clamp(13px,1.15vw,17px);letter-spacing:.14em;color:var(--ink)}

/* small side label (Class A Premium Business Center analogue) */
.hero-label{position:absolute;bottom:clamp(96px,17vh,150px);right:var(--pad);
  z-index:4;text-align:right;text-transform:uppercase;line-height:1.8;
  font-size:11px;letter-spacing:.2em;color:var(--muted)}
@media(max-width:900px){.hero-label{display:none}}

/* faint halo behind the tower for depth on white */
.tower-glow{position:absolute;left:50%;top:47%;width:min(58vw,720px);height:min(82vh,760px);
  transform:translate(-50%,-50%);z-index:1;pointer-events:none;
  background:radial-gradient(closest-side,rgba(255,255,255,.6),rgba(255,255,255,0) 70%)}

/* giant wordmark, justified edge-to-edge, vertically centred — IN FRONT of tower */
.bigword{position:absolute;inset:0;z-index:3;display:flex;align-items:center;
  justify-content:space-between;padding:0 var(--pad);pointer-events:none;user-select:none}
/* letters FLY IN from far below with overshoot, big stagger */
.bigword span{font-weight:300;font-size:clamp(40px,14.5vw,232px);line-height:1;letter-spacing:-.01em;
  color:var(--ink);will-change:transform,opacity;
  transform:translateY(230px) scale(.72);opacity:0;filter:blur(6px);
  transition:transform 1.25s cubic-bezier(.16,1,.3,1),opacity .9s ease,filter .9s ease}
.bigword.in span{transform:none;opacity:1;filter:none}
.bigword.in span:nth-child(2){transition-delay:.07s}.bigword.in span:nth-child(3){transition-delay:.14s}
.bigword.in span:nth-child(4){transition-delay:.21s}.bigword.in span:nth-child(5){transition-delay:.28s}
.bigword.in span:nth-child(6){transition-delay:.35s}.bigword.in span:nth-child(7){transition-delay:.42s}
.bigword.in span:nth-child(8){transition-delay:.49s}
/* once interactive, JS drives transform — keep it snappy */
.bigword.live span{transition:transform .12s linear,opacity .25s linear,filter .25s}

/* 3D twisting tower, centred, BEHIND the letters, thicker + angled */
.stage{position:absolute;inset:0;z-index:2;perspective:2000px;perspective-origin:50% 46%;pointer-events:none}
.tower-wrap{position:absolute;left:50%;top:49%;transform-style:preserve-3d;
  transform:translate(-50%,-50%) rotateX(var(--tiltX,-4deg));will-change:transform}
.tower-axis{transform-style:preserve-3d;transform:rotateZ(-21deg)}   /* the angle */
.tower{position:absolute;left:0;top:0;width:0;height:0;transform-style:preserve-3d;
  animation:spin 34s linear infinite}
@keyframes spin{to{transform:rotateY(360deg)}}
.blade{position:absolute;left:0;top:0;border-radius:46px;
  background:linear-gradient(90deg,#efeeec 0%,#ffffff 22%,#dad9d6 50%,#ffffff 78%,#e8e7e4 100%);
  box-shadow:0 2px 4px rgba(0,0,0,.06), inset 0 1px 0 rgba(255,255,255,.9);
  backface-visibility:visible}
.tower-shadow{position:absolute;left:50%;top:80%;width:min(46vw,560px);height:100px;
  transform:translateX(-50%);z-index:1;
  background:radial-gradient(50% 50% at 50% 50%,rgba(0,0,0,.10),transparent 70%);filter:blur(8px)}

/* scroll cue bottom-centre */
.scrollcue{position:absolute;bottom:clamp(26px,5vh,52px);left:50%;transform:translateX(-50%);z-index:4;
  font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--muted);
  display:flex;align-items:center;gap:11px}
.scrollcue .dot{width:6px;height:6px;border-radius:50%;background:var(--ink);
  animation:pulse 2.6s var(--ease) infinite}
@keyframes pulse{0%,100%{opacity:.25;transform:scale(.7)}50%{opacity:1;transform:scale(1.25)}}

.hero-inner{position:relative;z-index:3;width:100%;max-width:1500px;margin:0 auto}
.hero .display{margin-bottom:30px;max-width:14ch}
.hero-foot{display:flex;justify-content:space-between;align-items:flex-end;gap:30px;flex-wrap:wrap}

/* ============================================================
   SECTIONS
   ============================================================ */
section{position:relative}
.band{padding:clamp(96px,15vh,220px) var(--pad)}
.band.alt{background:var(--paper-2)}
.wrap{max-width:1500px;margin:0 auto}
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,8vw,150px);align-items:start}
@media(max-width:920px){.split{grid-template-columns:1fr;gap:44px}}

.stack-head{font-weight:300;font-size:clamp(48px,11vw,180px);line-height:.86;letter-spacing:-.05em}
.stack-head span{display:block}

/* media frames (real architectural renders feel — built with CSS) */
.frame{position:relative;overflow:hidden;background:#efeeec;border-radius:2px;aspect-ratio:3/4}
.frame.wide{aspect-ratio:16/10}
.frame .mini-stage{position:absolute;inset:0;perspective:1400px;perspective-origin:50% 42%}
.frame figcaption{position:absolute;left:22px;bottom:18px;font-size:12.5px;letter-spacing:.04em;
  color:var(--muted);z-index:3}

/* ============================================================
   STATS
   ============================================================ */
.stats{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--line);margin-top:clamp(54px,8vh,96px)}
.stat{padding:clamp(30px,4vw,52px) clamp(22px,2vw,40px) 0;border-right:1px solid var(--line)}
.stat:last-child{border-right:none}
.stat .num{font-weight:300;font-size:clamp(46px,6vw,92px);line-height:1;letter-spacing:-.04em}
.stat .lbl{margin-top:16px;font-size:13.5px;color:var(--muted);letter-spacing:.02em;line-height:1.5}
@media(max-width:760px){.stats{grid-template-columns:1fr 1fr}.stat:nth-child(2){border-right:none}
  .stat{border-bottom:1px solid var(--line);padding-bottom:30px}}

/* ============================================================
   SERVICES LIST
   ============================================================ */
.svc-row{display:grid;grid-template-columns:64px 1fr auto;gap:30px;align-items:center;
  padding:38px 0;border-top:1px solid var(--line);transition:padding-left .45s var(--ease)}
.svc-row:last-child{border-bottom:1px solid var(--line)}
.svc-row:hover{padding-left:20px}
.svc-row .n{font-variant-numeric:tabular-nums;color:var(--muted);font-size:14px}
.svc-row .t{font-weight:300;font-size:clamp(26px,3.4vw,52px);letter-spacing:-.03em}
.svc-row .d{color:var(--muted);max-width:34ch;font-size:14.5px;line-height:1.5}
.svc-row .arrow{font-size:22px;opacity:0;transform:translateX(-10px);transition:.45s var(--ease)}
.svc-row:hover .arrow{opacity:1;transform:none}
@media(max-width:760px){.svc-row{grid-template-columns:1fr;gap:8px}.svc-row .d,.svc-row .arrow{display:none}}

/* ============================================================
   INVERTED FEATURE (lobby / status — dark)
   ============================================================ */
.dark{background:#0a0a0a;color:#fff}
.dark .lead{color:rgba(255,255,255,.66)}
.dark .eyebrow{color:rgba(255,255,255,.5)}
.feature{position:relative;min-height:92svh;display:flex;align-items:flex-end;
  padding:var(--pad) var(--pad) clamp(70px,12vh,130px);overflow:hidden}
.feature .feat-stage{position:absolute;inset:0;z-index:0;perspective:1700px;perspective-origin:35% 50%;opacity:.9}
.feature .feat-inner{position:relative;z-index:2;max-width:660px}
.feature .section-title{margin:16px 0 26px}
.feature .blade{background:linear-gradient(90deg,#3a3a3c,#161617 22%,#4a4a4d 50%,#101011 78%,#2c2c2e);
  box-shadow:0 1px 3px rgba(0,0,0,.4),inset 0 1px 0 rgba(255,255,255,.06)}

/* ============================================================
   CTA / FOOTER
   ============================================================ */
.cta{padding:clamp(110px,20vh,260px) var(--pad);text-align:center}
.cta .display{margin:0 auto 44px;max-width:16ch}
.btn-big{display:inline-flex;align-items:center;gap:14px;cursor:pointer;
  background:var(--ink);color:#fff;border-radius:100px;padding:21px 40px;
  font-size:16px;font-weight:500;letter-spacing:.02em;transition:transform .4s var(--ease),background .4s}
.btn-big:hover{transform:translateY(-3px);background:#000}
.btn-big .arrow{transition:transform .4s var(--ease)}
.btn-big:hover .arrow{transform:translateX(6px)}

footer{background:#0a0a0a;color:#fff;padding:clamp(80px,11vh,130px) var(--pad) 42px}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:50px;margin-bottom:90px}
@media(max-width:760px){.foot-grid{grid-template-columns:1fr;gap:42px}}
.foot-brand{font-weight:500;font-size:34px;letter-spacing:.34em;margin-bottom:22px}
.foot-col h4{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.45);margin-bottom:22px;font-weight:500}
.foot-col a{display:block;padding:9px 0;color:rgba(255,255,255,.74);font-size:15px;transition:color .3s}
.foot-col a:hover{color:#fff}
.foot-bottom{display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;
  font-size:12.5px;color:rgba(255,255,255,.4);border-top:1px solid rgba(255,255,255,.12);padding-top:26px}
.disclaimer{font-size:10.5px;line-height:1.8;color:rgba(255,255,255,.28);letter-spacing:.05em;text-transform:uppercase;max-width:78ch;margin-top:28px}

/* ============================================================
   MOTION HELPERS
   ============================================================ */
.reveal{opacity:0;transform:translateY(56px) scale(.985);transition:opacity 1s var(--ease),transform 1.15s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}
.lines span{display:block;overflow:hidden;padding-bottom:.04em}
.lines span i{display:block;font-style:normal;transform:translateY(108%);transition:transform 1.1s var(--ease)}
.lines.in span i{transform:none}
.lines.in span:nth-child(2) i{transition-delay:.1s}
.lines.in span:nth-child(3) i{transition-delay:.2s}
.parallax{will-change:transform}

/* marquee */
.marquee{overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:24px 0;white-space:nowrap}
.marquee .track{display:inline-block;animation:slide 32s linear infinite}
.marquee span{font-weight:300;font-size:clamp(26px,3.6vw,52px);letter-spacing:-.02em;padding:0 38px;color:#cfcecb}
.marquee span b{color:var(--ink);font-weight:300}
@keyframes slide{to{transform:translateX(-50%)}}

/* fab + modal */
.fab{position:fixed;right:var(--pad);bottom:26px;z-index:45;cursor:pointer;
  background:var(--ink);color:#fff;border-radius:100px;padding:15px 26px;font-size:14px;font-weight:500;
  box-shadow:0 18px 40px -16px rgba(0,0,0,.4);transform:translateY(130px);transition:transform .5s var(--ease),background .35s}
.fab.show{transform:none}
.fab:hover{background:#000}
.modal{position:fixed;inset:0;z-index:100;display:none;align-items:center;justify-content:center;padding:24px}
.modal.open{display:flex}
.modal-bg{position:absolute;inset:0;background:rgba(10,10,10,.45);backdrop-filter:blur(6px)}
.modal-card{position:relative;background:#fff;border:1px solid var(--line);border-radius:8px;width:min(460px,100%);
  padding:clamp(30px,5vw,48px);box-shadow:0 40px 90px -30px rgba(0,0,0,.35)}
.modal-card h3{font-weight:300;font-size:34px;letter-spacing:-.02em;margin-bottom:10px}
.modal-card p.sub{color:var(--muted);font-size:15px;margin-bottom:30px}
.field{width:100%;background:transparent;border:none;border-bottom:1px solid var(--line);color:var(--ink);
  font-family:inherit;font-size:16px;padding:14px 2px;margin-bottom:22px;outline:none;transition:border-color .3s}
.field::placeholder{color:#b3b2af}.field:focus{border-color:var(--ink)}
.modal-submit{width:100%;background:var(--ink);color:#fff;border:none;border-radius:100px;padding:17px;
  font-family:inherit;font-size:15px;font-weight:500;cursor:pointer;transition:background .3s}
.modal-submit:hover{background:#000}
.modal-consent{font-size:12px;color:var(--muted);margin-top:18px;line-height:1.5}
.modal-close{position:absolute;top:16px;right:18px;font-size:26px;color:var(--muted);cursor:pointer;background:none;border:none;line-height:1}
.modal-close:hover{color:var(--ink)}
.modal-thanks{display:none;text-align:center}.modal-thanks.show{display:block}
.modal-thanks .check{width:54px;height:54px;border-radius:50%;border:1px solid var(--ink);display:flex;align-items:center;justify-content:center;font-size:24px;margin:0 auto 22px}

@media(prefers-reduced-motion:reduce){
  *{animation:none!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
  .lines span i{transform:none}
}

/* ============================================================
   PAGE COMPONENTS (services / work / about)
   ============================================================ */
.page-top{padding:clamp(150px,22vh,260px) var(--pad) clamp(50px,8vh,90px)}
.page-top .display{max-width:15ch;margin-top:18px}
.page-top .lead{margin-top:34px}

/* pricing */
.pricing{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);
  border:1px solid var(--line);margin-top:clamp(40px,6vh,70px)}
.price-card{background:var(--paper);padding:clamp(34px,3.5vw,52px)}
.price-card.pop{background:var(--ink);color:#fff}
.price-card .tier{font-size:13px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.price-card.pop .tier{color:rgba(255,255,255,.6)}
.price-card .amt{font-weight:300;font-size:clamp(34px,3.4vw,52px);letter-spacing:-.03em;margin:18px 0 4px}
.price-card .per{font-size:13.5px;color:var(--muted);margin-bottom:24px}
.price-card .desc{font-size:15px;color:#52514f;line-height:1.55;margin-bottom:28px;min-height:3em}
.price-card.pop .desc{color:rgba(255,255,255,.7)}
.price-card ul{list-style:none;border-top:1px solid var(--line);padding-top:24px;margin-bottom:30px}
.price-card.pop ul{border-color:rgba(255,255,255,.16)}
.price-card li{font-size:14.5px;padding:9px 0 9px 26px;position:relative;color:var(--ink-2)}
.price-card.pop li{color:rgba(255,255,255,.85)}
.price-card li::before{content:"";position:absolute;left:0;top:15px;width:11px;height:7px;
  border-left:1.5px solid var(--ink);border-bottom:1.5px solid var(--ink);transform:rotate(-45deg)}
.price-card.pop li::before{border-color:#fff}
.price-card .badge{display:inline-block;font-size:11px;letter-spacing:.16em;text-transform:uppercase;
  background:#fff;color:#000;border-radius:100px;padding:5px 12px;margin-bottom:14px}
.price-btn{display:block;text-align:center;border:1px solid var(--ink);border-radius:100px;
  padding:15px;font-size:14.5px;font-weight:500;cursor:pointer;transition:.35s var(--ease);width:100%;background:none;font-family:inherit;color:inherit}
.price-btn:hover{background:var(--ink);color:#fff}
.price-card.pop .price-btn{border-color:#fff;background:#fff;color:#000}
.price-card.pop .price-btn:hover{background:transparent;color:#fff}
@media(max-width:920px){.pricing{grid-template-columns:1fr}}

/* included list */
.incl{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);border:1px solid var(--line);margin-top:clamp(40px,6vh,64px)}
.incl .item{background:var(--paper);padding:clamp(28px,3vw,44px)}
.incl .item h4{font-weight:400;font-size:clamp(20px,2vw,26px);letter-spacing:-.02em;margin-bottom:14px}
.incl .item p{font-size:15px;color:#52514f;line-height:1.6;max-width:42ch}
@media(max-width:720px){.incl{grid-template-columns:1fr}}

/* work list */
.work-list{margin-top:clamp(40px,6vh,70px);border-top:1px solid var(--line)}
.work-row{display:grid;grid-template-columns:auto 1fr auto;gap:clamp(20px,4vw,60px);align-items:center;
  padding:clamp(28px,4vh,48px) 0;border-bottom:1px solid var(--line);cursor:pointer;
  transition:padding-left .45s var(--ease)}
.work-row:hover{padding-left:18px}
.work-row .cat{font-size:12.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);white-space:nowrap;min-width:200px}
.work-row .name{font-weight:300;font-size:clamp(30px,5vw,72px);letter-spacing:-.035em;line-height:1}
.work-row .go{font-size:22px;opacity:.25;transition:.45s var(--ease)}
.work-row:hover .go{opacity:1;transform:translateX(6px)}
@media(max-width:820px){.work-row{grid-template-columns:1fr;gap:8px}.work-row .cat{min-width:0}.work-row .go{display:none}}

/* live preview modal */
.preview{position:fixed;inset:0;z-index:110;display:none;flex-direction:column;background:rgba(10,10,10,.6);backdrop-filter:blur(8px);padding:clamp(16px,3vw,40px)}
.preview.open{display:flex}
.preview-bar{display:flex;justify-content:space-between;align-items:center;color:#fff;padding:8px 4px 16px}
.preview-bar .pt{font-size:14px;letter-spacing:.04em}
.preview-bar a.ext{font-size:13px;color:rgba(255,255,255,.8);margin-right:18px}
.preview-bar a.ext:hover{color:#fff}
.preview-close{background:none;border:none;color:#fff;font-size:26px;cursor:pointer;line-height:1}
.preview-frame{flex:1;background:#fff;border-radius:6px;overflow:hidden;box-shadow:0 30px 80px -20px rgba(0,0,0,.5)}
.preview-frame iframe{width:100%;height:100%;border:0;display:block}

/* process */
.process{margin-top:clamp(46px,7vh,80px)}
.proc-row{display:grid;grid-template-columns:120px 1fr;gap:clamp(20px,4vw,60px);
  padding:clamp(30px,4vh,52px) 0;border-top:1px solid var(--line);align-items:baseline}
.proc-row:last-child{border-bottom:1px solid var(--line)}
.proc-row .pn{font-weight:300;font-size:clamp(28px,3vw,46px);letter-spacing:-.03em;color:var(--muted)}
.proc-row .ph{font-weight:400;font-size:clamp(22px,2.4vw,34px);letter-spacing:-.02em;margin-bottom:12px}
.proc-row .pp{font-size:15.5px;color:#52514f;line-height:1.6;max-width:52ch}
@media(max-width:720px){.proc-row{grid-template-columns:1fr;gap:10px}}

/* partners marquee variant already styled via .marquee */
.partners span{color:#c9c8c5}.partners span b{color:var(--ink)}

/* ============================================================
   INTRO — full-screen WebGL shader (ported from the shadcn
   shader-animation component) on black, then fades to the page
   ============================================================ */
#intro{position:fixed;inset:0;z-index:200;overflow:hidden;background:#000;
  display:flex;align-items:center;justify-content:center;
  transition:opacity .7s ease, transform .7s cubic-bezier(.7,0,.84,0), filter .7s ease;
  will-change:opacity,transform}
/* on exit: zoom through the shader + blur as it dissolves into the landing page */
#intro.done{opacity:0;pointer-events:none;transform:scale(1.22);filter:blur(8px)}
#introShader{position:absolute;inset:0;width:100%;height:100%;display:block}
.intro-word{position:relative;z-index:2;color:#fff;text-align:center;pointer-events:none;
  font-family:'DM Sans',system-ui,sans-serif;font-weight:500;letter-spacing:-.04em;line-height:1;
  font-size:clamp(40px,9vw,140px);
  text-shadow:0 8px 60px rgba(0,0,0,.5);
  opacity:0;transform:translateY(28px) scale(.96);
  animation:introWord 1.4s var(--ease) .5s forwards}
.intro-word .iw-tag{display:block;margin-top:22px;font-weight:400;font-size:clamp(11px,1.1vw,15px);
  letter-spacing:.28em;text-transform:uppercase;color:rgba(255,255,255,.6)}
@keyframes introWord{to{opacity:1;transform:none}}
#intro.done .intro-word{opacity:0;transform:translateY(-20px);transition:opacity .6s ease,transform .6s ease}

.intro-skip{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);z-index:3;
  font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.8);
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.28);border-radius:100px;
  padding:10px 22px;cursor:pointer;font-family:inherit;transition:opacity .5s,background .3s}
.intro-skip:hover{background:rgba(255,255,255,.18);color:#fff}
#intro.done .intro-skip{opacity:0}

/* ============================================================
   CUSTOM CURSOR (fromanother-style)
   ============================================================ */
.cursor{position:fixed;top:0;left:0;width:9px;height:9px;border-radius:50%;
  background:var(--ink);pointer-events:none;z-index:300;transform:translate(-50%,-50%);
  mix-blend-mode:difference;transition:width .28s var(--ease),height .28s var(--ease),opacity .3s;opacity:0}
.cursor.show{opacity:1}
.cursor.big{width:54px;height:54px;background:#fff}
@media(hover:none),(pointer:coarse){.cursor{display:none}}

/* hover-scale + image reveal feel for cards/frames */
.price-card,.incl .item,.frame{will-change:transform}
.frame{transition:transform .6s var(--ease)}
.work-row .name{transition:transform .45s var(--ease),opacity .45s}
.reveal img,.frame.reveal{overflow:hidden}

/* ============================================================
   LIVE BACKGROUND SHADER (Services page) — white-ish clouds
   ============================================================ */
#bgShader{position:fixed;inset:0;width:100%;height:100%;z-index:-1;display:block}
body.bg-live{background:transparent}
/* one continuous cloudscape — no section background breaks */
.bg-live .band,.bg-live .band.alt{background:transparent}

/* consistent frosted-glass tiles so the page reads as one system */
.bg-live .incl{border-color:rgba(255,255,255,.5)}
.bg-live .incl .item{background:rgba(255,255,255,.55);backdrop-filter:blur(12px)}
.bg-live .pricing{border-color:rgba(255,255,255,.5)}
.bg-live .price-card{background:rgba(255,255,255,.6);backdrop-filter:blur(12px)}
.bg-live .price-card.pop{background:rgba(14,14,16,.86);backdrop-filter:blur(12px)}
.bg-live .stats,.bg-live .stat{background:transparent}
.bg-live .svc-row{border-color:rgba(20,20,20,.18)}
.bg-live .incl,.bg-live .stats{border-color:rgba(20,20,20,.16)}
.bg-live header.nav.scrolled{background:rgba(255,255,255,.62)}

/* hairline halo keeps text crisp as orbs/clouds drift underneath */
.bg-live .lead,.bg-live .eyebrow,.bg-live .price-card .desc,.bg-live .stat .lbl,
.bg-live .incl .item p,.bg-live p{text-shadow:0 1px 10px rgba(248,248,246,.85)}
.bg-live .display,.bg-live .section-title,.bg-live .svc-row .t,.bg-live .stack-head{
  text-shadow:0 2px 26px rgba(248,248,246,.6)}

/* ============================================================
   LIQUID GLASS BUTTONS (ported from liquid-glass-button cmpt)
   layered inset-shadow glass rim + glass backdrop + hover scale
   ============================================================ */
.nav-cta,.btn-big,.price-btn,.modal-submit,.fab,.intro-skip{
  position:relative;
  background:transparent !important;
  border:none !important;
  color:var(--ink) !important;
  border-radius:9999px;
  isolation:isolate;
  box-shadow:
    0 0 6px rgba(0,0,0,.03), 0 2px 6px rgba(0,0,0,.08),
    inset 3px 3px .5px -3px rgba(0,0,0,.9), inset -3px -3px .5px -3px rgba(0,0,0,.85),
    inset 1px 1px 1px -.5px rgba(0,0,0,.6), inset -1px -1px 1px -.5px rgba(0,0,0,.6),
    inset 0 0 6px 6px rgba(0,0,0,.12), inset 0 0 2px 2px rgba(0,0,0,.06),
    0 0 12px rgba(255,255,255,.15);
  backdrop-filter:blur(3px) saturate(1.1);
  backdrop-filter:url("#container-glass");   /* Firefox: real glass distortion; others keep blur */
  transition:transform .3s var(--ease),box-shadow .3s,filter .2s;
}
.nav-cta:hover,.btn-big:hover,.price-btn:hover,.modal-submit:hover,.fab:hover,.intro-skip:hover{
  transform:scale(1.05);filter:brightness(1.05);
  background:transparent !important;color:var(--ink) !important;
}
.nav-cta:active,.btn-big:active,.price-btn:active,.modal-submit:active,.fab:active{
  transform:scale(.97);filter:brightness(.96)}

/* dark-glass variant: light text + light rim for buttons on dark surfaces */
.price-card.pop .price-btn,.intro-skip{
  color:#fff !important;
  box-shadow:
    0 0 8px rgba(0,0,0,.03), 0 2px 6px rgba(0,0,0,.08),
    inset 3px 3px .5px -3.5px rgba(255,255,255,.09), inset -3px -3px .5px -3.5px rgba(255,255,255,.85),
    inset 1px 1px 1px -.5px rgba(255,255,255,.6), inset -1px -1px 1px -.5px rgba(255,255,255,.6),
    inset 0 0 6px 6px rgba(255,255,255,.12), inset 0 0 2px 2px rgba(255,255,255,.06),
    0 0 12px rgba(0,0,0,.15);
}
.price-card.pop .price-btn:hover,.intro-skip:hover{color:#fff !important}
/* keep the arrow inline with btn-big text */
.btn-big .arrow{color:inherit}

/* nav menu links (Home/Services/Our Work/About) as liquid-glass pills too */
.nav-links{gap:14px}
.nav-links a{
  position:relative;padding:9px 18px;border-radius:9999px;color:var(--ink) !important;
  box-shadow:
    0 0 6px rgba(0,0,0,.03), 0 2px 6px rgba(0,0,0,.08),
    inset 3px 3px .5px -3px rgba(0,0,0,.9), inset -3px -3px .5px -3px rgba(0,0,0,.85),
    inset 1px 1px 1px -.5px rgba(0,0,0,.6), inset -1px -1px 1px -.5px rgba(0,0,0,.6),
    inset 0 0 6px 6px rgba(0,0,0,.12), inset 0 0 2px 2px rgba(0,0,0,.06),
    0 0 12px rgba(255,255,255,.15);
  backdrop-filter:blur(3px) saturate(1.1);
  backdrop-filter:url("#container-glass");
  transition:transform .3s var(--ease),filter .2s;
}
.nav-links a::after{display:none}   /* drop the underline — pills now */
.nav-links a:hover{transform:scale(1.05);filter:brightness(1.05);color:var(--ink) !important}
.nav-links a:active{transform:scale(.97)}
@media(max-width:980px){.nav-links a{padding:8px 14px}}

/* ============================================================
   NATURE SCENE (About) — sunset over layered mountains, CSS/SVG
   ============================================================ */
.nature-band{padding:0 var(--pad) clamp(40px,8vh,90px)}
.nature-scene{position:relative;height:min(78vh,620px);border-radius:4px;overflow:hidden;
  box-shadow:0 40px 90px -50px rgba(0,0,0,.5)}
.ns-sky{position:absolute;inset:0;background:linear-gradient(180deg,
  #1d2b52 0%,#39406f 16%,#6a4a73 33%,#b65f63 47%,#dd7d54 61%,
  #f0a259 73%,#f8c878 84%,#fde3a6 94%,#ffeec6 100%)}
.ns-sun{position:absolute;left:50%;top:46%;width:min(26vw,260px);aspect-ratio:1;transform:translate(-50%,-50%);
  border-radius:50%;background:radial-gradient(circle,#fff7e4 0%,#ffe2a0 32%,#ffc06e 55%,rgba(255,175,105,0) 72%);
  box-shadow:0 0 160px 60px rgba(255,190,120,.5)}
.ns-haze{position:absolute;left:0;right:0;top:52%;height:34%;
  background:linear-gradient(180deg,rgba(255,210,150,0),rgba(255,195,140,.5));filter:blur(10px)}
.ns-mtn{position:absolute;left:0;right:0;bottom:0;width:100%;height:auto;display:block}
.ns-birds{position:absolute;left:18%;top:26%;color:rgba(40,30,40,.55);font-size:13px;letter-spacing:6px}
.ns-caption{position:absolute;left:var(--pad);bottom:clamp(26px,5vh,52px);z-index:3;color:#fff;
  text-shadow:0 2px 24px rgba(0,0,0,.4)}
.ns-caption .eyebrow{color:rgba(255,255,255,.8)}
.ns-caption h2{font-weight:300;font-size:clamp(30px,5vw,72px);letter-spacing:-.03em;margin-top:14px;line-height:1}

/* ============================================================
   OUR WORK — horizontal scroll carousel of live previews
   ============================================================ */
.work-carousel{position:relative;margin-top:clamp(40px,6vh,70px)}
.wc-track{display:flex;gap:clamp(20px,2.5vw,36px);overflow-x:auto;scroll-snap-type:x mandatory;
  scroll-behavior:smooth;padding:6px 2px 22px;-webkit-overflow-scrolling:touch}
.wc-track::-webkit-scrollbar{height:6px}
.wc-track::-webkit-scrollbar-track{background:transparent}
.wc-track::-webkit-scrollbar-thumb{background:var(--line);border-radius:3px}
.wc-card{flex:0 0 520px;max-width:88vw;scroll-snap-align:center;cursor:pointer}
.wc-frame{position:relative;width:100%;aspect-ratio:16/10;border-radius:6px;overflow:hidden;
  background:#efeeec;border:1px solid var(--line);box-shadow:0 30px 60px -38px rgba(0,0,0,.5);
  transition:transform .5s var(--ease),box-shadow .5s}
.wc-card:hover .wc-frame{transform:translateY(-6px);box-shadow:0 40px 70px -34px rgba(0,0,0,.55)}
.wc-frame iframe{position:absolute;top:0;left:0;width:1440px;height:900px;border:0;
  transform:scale(.3611);transform-origin:top left;pointer-events:none}
.wc-overlay{position:absolute;inset:0;z-index:2;display:flex;align-items:center;justify-content:center;
  background:rgba(10,10,10,0);opacity:0;transition:.4s var(--ease)}
.wc-card:hover .wc-overlay{background:rgba(10,10,10,.32);opacity:1}
.wc-overlay span{color:#fff;font-size:13.5px;letter-spacing:.04em;border:1px solid rgba(255,255,255,.6);
  border-radius:100px;padding:11px 22px;backdrop-filter:blur(4px)}
.wc-meta{display:flex;justify-content:space-between;align-items:baseline;gap:16px;margin-top:18px}
.wc-cat{font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.wc-name{font-weight:300;font-size:clamp(20px,2.2vw,30px);letter-spacing:-.02em}
.wc-nav{display:flex;gap:12px;margin-top:26px}
.wc-arrow{width:52px;height:52px;border-radius:50%;border:1px solid var(--ink);background:transparent;
  color:var(--ink);cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;
  transition:background .3s,color .3s,opacity .3s}
.wc-arrow:hover{background:var(--ink);color:#fff}
.wc-arrow:disabled{opacity:.25;cursor:default;background:transparent;color:var(--ink)}

/* ============================================================
   YOUTUBE VIDEO BACKGROUND (About page)
   ============================================================ */
.yt-bg{position:fixed;inset:0;z-index:-2;overflow:hidden;pointer-events:none;background:#0a0a0a}
.yt-bg iframe{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:100vw;height:56.25vw;            /* 16:9 */
  min-width:177.78vh;min-height:100vh;   /* cover the viewport, crop overflow */
  border:0}
/* light scrim so the dark page text stays readable over the footage */
.yt-scrim{position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(247,247,245,.62),rgba(247,247,245,.5) 40%,rgba(247,247,245,.55))}
/* on the video page keep the footer opaque (covers video at page end) */
.bg-live footer{position:relative;z-index:1}

/* opaque cover hides the player's load flash + play/pause UI until playing */
.yt-cover{position:absolute;inset:0;z-index:2;background:var(--paper-2);
  transition:opacity 1.1s ease;will-change:opacity}
.yt-bg.playing .yt-cover{opacity:0}

/* native <video> background covers the viewport */
.yt-bg video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}

/* ============================================================
   OUR WORK — scroll/drag morph arc (coverflow of live previews)
   ============================================================ */
.morph{position:relative;margin-top:clamp(26px,4vh,50px)}
.morph-hint{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);
  text-align:center;margin-bottom:8px}
.morph-stage{position:relative;height:min(60vh,470px);perspective:1700px;transform-style:preserve-3d;
  touch-action:pan-y;cursor:grab}
.morph-stage:active{cursor:grabbing}
.mc-card{position:absolute;top:48%;left:50%;width:min(50vw,520px);aspect-ratio:16/10;
  transform-style:preserve-3d;will-change:transform,opacity;
  transition:transform .85s var(--ease),opacity .6s var(--ease)}
.mc-flip{position:relative;width:100%;height:100%;transform-style:preserve-3d;transition:transform .7s var(--ease)}
.mc-card.is-active:hover .mc-flip{transform:rotateY(180deg)}
.mc-face{position:absolute;inset:0;border-radius:9px;overflow:hidden;backface-visibility:hidden;
  border:1px solid var(--line);background:#efeeec;box-shadow:0 44px 80px -44px rgba(0,0,0,.6)}
.mc-front iframe{position:absolute;top:0;left:0;width:1440px;height:900px;border:0;
  transform:scale(.3611);transform-origin:top left;pointer-events:none}
.mc-shade{position:absolute;inset:0;background:rgba(8,8,10,.28);transition:background .5s var(--ease)}
.mc-card.is-active .mc-shade{background:rgba(8,8,10,0)}
.mc-back{transform:rotateY(180deg);background:#0e0e10;color:#fff;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px}
.mc-back .v{font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:#9a9a9e}
.mc-back .d{font-weight:300;font-size:clamp(22px,2.4vw,30px);letter-spacing:-.02em}
.morph-cap{text-align:center;margin-top:clamp(22px,4vh,40px);min-height:62px}
.morph-cap .mc-cat{display:block;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.morph-cap .mc-name{font-weight:300;font-size:clamp(26px,4vw,52px);letter-spacing:-.03em;line-height:1}
.morph .wc-nav{justify-content:center}

/* scroll-driven morph: pin the stage and scrub through cards on scroll */
.morph-scroll{position:relative;height:320vh}
.morph-pin{position:sticky;top:0;height:100vh;display:flex;align-items:center;overflow:hidden}
.morph-pin .wrap{width:100%}
.mc-card{transition:transform .3s var(--ease),opacity .4s var(--ease)}  /* shorter for scrub */

/* ---- fix clipped descenders (g, y, p) in headline reveal masks ---- */
.lines span{padding-bottom:.2em;margin-bottom:-.14em}

/* ---- bigger work cards (~2x) so all detail is visible ---- */
.morph-stage{height:min(82vh,720px)}
.mc-card{width:min(92vw,1040px)}
.mc-front iframe{transform:scale(.722)}   /* 1040/1440; JS keeps it exact on resize */

/* ============================================================
   MORE MOTION / FLOW
   ============================================================ */
/* slow Ken-Burns drift gives the video backgrounds life */
.yt-bg video{transform-origin:center;animation:kenburns 40s ease-in-out infinite alternate}
@keyframes kenburns{from{transform:scale(1.03)}to{transform:scale(1.15) translateY(-1.5%)}}

/* every scroll reveal now focuses in (blur -> sharp) for a softer, flowing feel */
.reveal{opacity:0;transform:translateY(54px) scale(.985);filter:blur(9px);
  transition:opacity 1s var(--ease),transform 1.15s var(--ease),filter 1s var(--ease)}
.reveal.in{opacity:1;transform:none;filter:none}

/* gentle float on the work hint + breathing scrim */
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
.morph-hint{animation:floaty 4.2s ease-in-out infinite}
@keyframes scrimBreathe{0%,100%{opacity:1}50%{opacity:.9}}
.yt-scrim{animation:scrimBreathe 14s ease-in-out infinite}

/* active work card gets a soft glow ring to draw the eye */
.mc-card.is-active .mc-face{box-shadow:0 50px 90px -44px rgba(0,0,0,.6),0 0 0 1px rgba(255,255,255,.5)}

@media(prefers-reduced-motion:reduce){
  .yt-bg video,.morph-hint,.yt-scrim{animation:none!important}
  .reveal{opacity:1;transform:none;filter:none}
}

/* ============================================================
   OUR WORK — 3-row parallax portfolio (scroll-driven tilt + slide)
   ============================================================ */
.parallax{height:300vh;position:relative}
.parallax-pin{position:sticky;top:0;height:100vh;overflow:hidden;perspective:1000px;
  display:flex;flex-direction:column;justify-content:center;align-items:center}
.parallax-grid{transform-style:preserve-3d;will-change:transform,opacity;
  display:flex;flex-direction:column;gap:clamp(16px,2.2vw,38px)}
.prow{display:flex;gap:clamp(16px,1.8vw,36px);justify-content:center;will-change:transform}
.prow.prow-rev{flex-direction:row-reverse}
.pcard{position:relative;flex:0 0 clamp(260px,29vw,460px);aspect-ratio:16/10;border-radius:10px;
  overflow:hidden;cursor:pointer;border:1px solid rgba(255,255,255,.45);
  box-shadow:0 30px 60px -36px rgba(0,0,0,.6);transition:transform .45s var(--ease),box-shadow .45s}
.pcard img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:left top}
.pcard:hover{transform:translateY(-16px);box-shadow:0 54px 84px -34px rgba(0,0,0,.72)}
.pcard .pcap{position:absolute;left:0;right:0;bottom:0;padding:18px 18px 16px;color:#fff;
  font-size:14px;font-weight:500;letter-spacing:.01em;
  background:linear-gradient(0deg,rgba(0,0,0,.78),rgba(0,0,0,0));
  opacity:0;transform:translateY(8px);transition:opacity .4s var(--ease),transform .4s var(--ease)}
.pcard:hover .pcap{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.parallax{height:auto}.parallax-pin{position:static;height:auto;padding:8vh 0}.parallax-grid{transform:none!important;opacity:1!important}.prow{flex-wrap:wrap;transform:none!important}}

/* ============================================================
   LIQUID METAL HERO (home) — WebGL molten-chrome background
   ============================================================ */
.lmhero{position:relative;min-height:100svh;display:flex;align-items:center;justify-content:center;
  overflow:hidden;background:#070708;color:#fff;text-align:center}
.lmhero canvas{position:absolute;inset:0;width:100%;height:100%;display:block;z-index:0}
.lmhero::after{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:radial-gradient(70% 70% at 50% 50%,rgba(0,0,0,.12),rgba(0,0,0,.66))}
.lmhero-inner{position:relative;z-index:2;max-width:920px;padding:10vh var(--pad);
  display:flex;flex-direction:column;align-items:center;gap:24px}
.lm-badge{font-size:12px;letter-spacing:.2em;text-transform:uppercase;padding:9px 18px;
  border:1px solid rgba(255,255,255,.28);border-radius:100px;background:rgba(255,255,255,.08);backdrop-filter:blur(6px)}
.lm-title{font-weight:300;font-size:clamp(40px,7.2vw,96px);letter-spacing:-.035em;line-height:1;
  text-shadow:0 10px 50px rgba(0,0,0,.4)}
.lm-sub{font-size:clamp(17px,1.6vw,22px);color:rgba(255,255,255,.86);max-width:48ch;line-height:1.6}
.lm-btns{display:flex;gap:14px;flex-wrap:wrap;justify-content:center;margin-top:4px}
.lm-primary{background:#fff;color:#000;border:none;border-radius:100px;padding:16px 32px;font-family:inherit;
  font-weight:600;font-size:15px;cursor:pointer;transition:transform .3s var(--ease)}
.lm-primary:hover{transform:scale(1.05)}
.lm-secondary{display:inline-flex;align-items:center;background:transparent;color:#fff;
  border:1px solid rgba(255,255,255,.4);border-radius:100px;padding:16px 32px;font-weight:500;font-size:15px;
  cursor:pointer;transition:background .3s,border-color .3s}
.lm-secondary:hover{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.7)}
.lm-card{margin-top:24px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);
  backdrop-filter:blur(12px);border-radius:16px;padding:26px clamp(22px,3vw,44px);box-shadow:0 30px 70px -40px rgba(0,0,0,.7)}
.lm-feats{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.lm-feats div{font-size:15px;color:rgba(255,255,255,.92);font-weight:500}
@media(max-width:760px){.lm-feats{grid-template-columns:1fr;gap:14px}}

/* ============================================================
   ABOUT — dark "TuringLanding" background (monochrome glows
   over the video), light text
   ============================================================ */
.about-dark{background:#0a0a0a;color:#fff}
.about-dark .yt-bg{background:#0a0a0a}
.about-dark .yt-cover{background:#0a0a0a}
.about-dark .yt-scrim{animation:none;background:
  radial-gradient(58% 80% at 12% 16%, rgba(255,255,255,.12), transparent 60%),
  radial-gradient(52% 72% at 88% 84%, rgba(255,255,255,.08), transparent 62%),
  linear-gradient(180deg, rgba(8,8,10,.6), rgba(8,8,10,.84))}
.about-dark .band,.about-dark .band.alt{background:transparent}
.about-dark footer{position:relative;z-index:1}

/* text -> light */
.about-dark .display,.about-dark .section-title,.about-dark h1,.about-dark h2,.about-dark h3,
.about-dark .proc-row .ph,.about-dark .stat .num{color:#fff}
.about-dark .lead,.about-dark .proc-row .pp{color:rgba(255,255,255,.74)}
.about-dark .eyebrow,.about-dark .stat .lbl{color:rgba(255,255,255,.56)}
.about-dark .stats,.about-dark .stat{border-color:rgba(255,255,255,.16)!important}
.about-dark .proc-row{border-color:rgba(255,255,255,.14)}
.about-dark .frame{background:transparent;border:none;overflow:visible}
.about-dark .frame figcaption{color:rgba(255,255,255,.5)}

/* nav + buttons -> dark-glass (light rim, white text) */
.about-dark .brand{color:#fff}
.about-dark header.nav.scrolled{background:rgba(10,10,10,.5);border-color:rgba(255,255,255,.12)}
.about-dark .nav-links a,.about-dark .nav-cta,.about-dark .btn-big,.about-dark .fab{
  color:#fff !important;
  box-shadow:0 0 8px rgba(0,0,0,.03),0 2px 6px rgba(0,0,0,.08),
    inset 3px 3px .5px -3.5px rgba(255,255,255,.09),inset -3px -3px .5px -3.5px rgba(255,255,255,.85),
    inset 1px 1px 1px -.5px rgba(255,255,255,.6),inset -1px -1px 1px -.5px rgba(255,255,255,.6),
    inset 0 0 6px 6px rgba(255,255,255,.12),inset 0 0 2px 2px rgba(255,255,255,.06),0 0 12px rgba(0,0,0,.15)}

/* ---- brand logo lockup (nav + footer) ---- */
.brand{display:inline-flex;align-items:center;gap:11px;padding-left:0}
.brand-logo{height:30px;width:auto;display:block}
.foot-brand{display:flex;align-items:center;gap:14px}
.foot-logo{height:46px;width:auto;display:block}
@media(max-width:560px){.brand-logo{height:26px}}

/* ---- logo centred under the giant AUTOMERA on the home hero ---- */
.hero-logo-wrap{position:absolute;left:0;right:0;top:62%;z-index:3;
  display:flex;justify-content:center;pointer-events:none}
.hero-logo{height:clamp(46px,7vw,104px);width:auto;opacity:0;transform:translateY(20px);
  filter:drop-shadow(0 14px 32px rgba(0,0,0,.14));
  animation:heroLogoIn 1s var(--ease) 1.4s forwards}
@keyframes heroLogoIn{to{opacity:1;transform:none}}
@media(prefers-reduced-motion:reduce){.hero-logo{opacity:1;transform:none;animation:none}}

/* restore the floating CTA to fixed bottom-right (the liquid-glass rule
   had forced position:relative, dropping it into the page bottom-left) */
.fab{position:fixed}

/* bigger hero logo under the wordmark */
.hero-logo{height:clamp(70px,11vw,168px)}

/* ---- reveal-wave interactive image (hover to reveal colour) ---- */
.rw-canvas{position:absolute;inset:0;width:100%;height:100%;display:block;cursor:crosshair}

/* fix: place hero logo clearly BELOW the AUTOMERA word (was overlapping it) */
.hero-logo-wrap{top:auto;bottom:13%}
.hero-logo{height:clamp(58px,8.5vw,130px);filter:drop-shadow(0 12px 30px rgba(0,0,0,.22))}
@media(max-width:560px){.hero-logo{height:clamp(48px,12vw,90px)}.hero-logo-wrap{bottom:15%}}

/* ============================================================
   SERVICES readability — darken the muted/grey text so it
   reads against the moving grey cloud background
   ============================================================ */
.bg-live .lead,
.bg-live .svc-row .d,
.bg-live .svc-row .n,
.bg-live .stat .lbl,
.bg-live .incl .item p,
.bg-live .price-card .desc,
.bg-live p{color:#15151a}
.bg-live .eyebrow{color:#2c2c30}
.bg-live .svc-row .t{color:#0a0a0a}
/* keep the dark "most popular" card's own light text */
.bg-live .price-card.pop .desc,.bg-live .price-card.pop li{color:rgba(255,255,255,.85)}
/* stronger white halo so the now-dark text stays crisp over darker cloud patches */
.bg-live .lead,.bg-live .eyebrow,.bg-live .svc-row .d,.bg-live .svc-row .n,
.bg-live .svc-row .t,.bg-live .stat .lbl,.bg-live .incl .item p,.bg-live p{
  text-shadow:0 1px 12px rgba(249,249,247,.95),0 0 5px rgba(249,249,247,.8)}
.bg-live .display,.bg-live .section-title,.bg-live .stack-head{
  text-shadow:0 2px 24px rgba(249,249,247,.7)}

/* ============================================================
   OUR WORK — animated flow-field background (canvas)
   ============================================================ */
#flowfield{position:fixed;inset:0;width:100%;height:100%;z-index:-1;display:block;background:var(--paper-2)}

/* ============================================================
   MOBILE / iOS — menu, responsive layout, flowing
   ============================================================ */
*{-webkit-tap-highlight-color:transparent}
html,body{overscroll-behavior-y:none}

/* hamburger */
.nav-burger{display:none;flex-direction:column;justify-content:center;gap:5px;
  width:42px;height:42px;background:none;border:none;cursor:pointer;padding:0;z-index:62}
.nav-burger span{display:block;width:24px;height:2px;background:var(--ink);margin:0 auto;border-radius:2px;
  transition:transform .35s var(--ease),opacity .25s}
.nav-burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-burger.open span:nth-child(2){opacity:0}
.nav-burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.about-dark .nav-burger span{background:#fff}

/* full-screen mobile menu */
.mobile-menu{position:fixed;inset:0;z-index:61;background:#0a0a0a;color:#fff;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;
  opacity:0;visibility:hidden;transform:translateY(-10px);
  transition:opacity .4s var(--ease),transform .4s var(--ease),visibility .4s}
.mobile-menu.open{opacity:1;visibility:visible;transform:none}
.mobile-menu a{color:#fff;font-weight:300;font-size:clamp(32px,9vw,52px);letter-spacing:-.02em;padding:10px 0;text-decoration:none}
.mobile-menu .mm-cta{margin-top:26px;background:#fff;color:#000;border:none;border-radius:100px;
  padding:16px 34px;font-family:inherit;font-size:16px;font-weight:600;cursor:pointer}

@media(max-width:900px){
  .nav-burger{display:flex}
  .nav-cta{display:none}
  header.nav,header.nav.scrolled{padding:14px var(--pad)}
}

/* giant wordmark safety on small phones */
@media(max-width:480px){
  .bigword{padding:0 12px}
  .bigword span{font-size:12.5vw}
}

/* parallax portfolio -> simple stacked grid on phones (no pin/tilt jank) */
@media(max-width:760px){
  .parallax{height:auto}
  .parallax-pin{position:static;display:block;height:auto;padding:6vh var(--pad);overflow:visible}
  .parallax-grid{transform:none!important;opacity:1!important;width:100%;gap:12px}
  .prow,.prow.prow-rev{width:100%;flex-direction:row;flex-wrap:wrap;justify-content:center;transform:none!important;gap:12px}
  .pcard{flex:0 0 calc(50% - 6px);max-width:none}
  .pcard .pcap{opacity:1;transform:none;font-size:10.5px;padding:9px 10px}
}

/* liquid-metal buttons full-width on small screens */
@media(max-width:600px){
  .lm-card{padding:20px}
  .lm-btns{width:100%}
  .lm-primary,.lm-secondary{flex:1 1 auto;text-align:center;justify-content:center}
  .split{gap:36px}
}

/* iOS: -webkit-backdrop-filter for the frosted/glass elements */
header.nav.scrolled{-webkit-backdrop-filter:blur(14px)}
.modal-bg,.preview{-webkit-backdrop-filter:blur(6px)}
.lm-badge,.lm-card{-webkit-backdrop-filter:blur(10px)}
.bg-live .incl .item,.bg-live .price-card{-webkit-backdrop-filter:blur(12px)}
.preview-bar .pt,.wc-overlay span,.pcard .pcap{-webkit-backdrop-filter:blur(4px)}

/* ============================================================
   FLOW / POLISH — fab fix, scroll progress, page transitions
   ============================================================ */
/* hide the floating CTA once the (dark) footer is in view */
.fab.atfooter{transform:translateY(150px)!important;opacity:0!important;pointer-events:none}

/* thin scroll-progress line at the very top */
.scroll-prog{position:fixed;top:0;left:0;height:2px;width:0;z-index:58;
  background:var(--ink);transition:width .12s linear;pointer-events:none}
.about-dark .scroll-prog{background:#fff}

/* seamless page-to-page fade */
.page-fade{position:fixed;inset:0;z-index:300;background:var(--paper-2);
  opacity:0;pointer-events:none;transition:opacity .42s ease}
.page-fade.show{opacity:1;pointer-events:all}
@media(prefers-reduced-motion:reduce){.page-fade{display:none}}

/* ============================================================
   AI ASSISTANT — chat widget (automation showcase)
   ============================================================ */
.chat-fab{position:fixed;left:var(--pad);bottom:26px;z-index:46;width:56px;height:56px;border-radius:50%;
  background:var(--ink);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;
  box-shadow:0 18px 40px -16px rgba(0,0,0,.5);transition:transform .3s var(--ease),opacity .4s}
.chat-fab:hover{transform:scale(1.07)}
.chat-fab svg{width:24px;height:24px}
.about-dark .chat-fab{background:#fff;color:#000}
.chat-fab .badge-dot{position:absolute;top:2px;right:2px;width:12px;height:12px;border-radius:50%;
  background:#39c07a;border:2px solid var(--paper)}
.about-dark .chat-fab .badge-dot{border-color:#0a0a0a}

.chat-panel{position:fixed;left:var(--pad);bottom:96px;z-index:47;
  width:min(380px,calc(100vw - 2*var(--pad)));height:min(560px,72vh);
  background:#fff;border:1px solid var(--line);border-radius:18px;overflow:hidden;
  display:flex;flex-direction:column;box-shadow:0 50px 100px -30px rgba(0,0,0,.45);
  opacity:0;transform:translateY(18px) scale(.98);pointer-events:none;
  transition:opacity .35s var(--ease),transform .35s var(--ease)}
.chat-panel.open{opacity:1;transform:none;pointer-events:auto}
.chat-head{padding:16px 18px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:11px}
.chat-head .av{width:34px;height:34px;border-radius:50%;background:var(--ink);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:15px}
.chat-head .ct{font-weight:500;font-size:14.5px;line-height:1.2}
.chat-head .cs{font-size:11.5px;color:#39a86c;display:flex;align-items:center;gap:5px}
.chat-head .cs::before{content:"";width:7px;height:7px;border-radius:50%;background:#39c07a}
.chat-head .cx{margin-left:auto;background:none;border:none;font-size:24px;color:var(--muted);cursor:pointer;line-height:1}
.chat-body{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:10px;background:var(--paper-2);-webkit-overflow-scrolling:touch}
.msg{max-width:86%;padding:11px 14px;border-radius:15px;font-size:14px;line-height:1.5;white-space:pre-wrap}
.msg.bot{background:#fff;border:1px solid var(--line);align-self:flex-start;border-bottom-left-radius:4px;color:var(--ink)}
.msg.user{background:var(--ink);color:#fff;align-self:flex-end;border-bottom-right-radius:4px}
.chat-chips{display:flex;flex-wrap:wrap;gap:7px;padding:0 16px 10px;background:var(--paper-2)}
.chat-chips button{font-size:12px;border:1px solid var(--line);background:#fff;border-radius:100px;padding:7px 12px;cursor:pointer;transition:background .2s,color .2s;color:var(--ink)}
.chat-chips button:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.chat-input{display:flex;align-items:center;gap:8px;padding:12px 14px;border-top:1px solid var(--line);background:#fff}
.chat-input input{flex:1;border:none;outline:none;font-family:inherit;font-size:14px;background:transparent;color:var(--ink)}
.chat-input button{background:var(--ink);color:#fff;border:none;border-radius:50%;width:36px;height:36px;cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center}
.chat-input button svg{width:17px;height:17px}
.typing span{display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--muted);margin:0 2px;animation:typ 1s infinite}
.typing span:nth-child(2){animation-delay:.15s}.typing span:nth-child(3){animation-delay:.3s}
@keyframes typ{0%,60%,100%{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-3px)}}
@media(max-width:520px){.chat-panel{height:70vh;bottom:90px;left:12px;right:12px;width:auto}.chat-fab{left:14px;bottom:20px}}

/* services page: no text-glow on the words (per request) */
.bg-live.no-glow .display,.bg-live.no-glow .section-title,.bg-live.no-glow .lead,
.bg-live.no-glow .eyebrow,.bg-live.no-glow .price-card .desc,.bg-live.no-glow .svc-row .t,
.bg-live.no-glow .stack-head,.bg-live.no-glow .stat .lbl,.bg-live.no-glow .incl .item p,
.bg-live.no-glow .incl .item h4,.bg-live.no-glow .tier,.bg-live.no-glow .amt,
.bg-live.no-glow .per,.bg-live.no-glow p{text-shadow:none!important}

/* woven-light particle panel (About page) */
.woven-canvas{position:absolute;inset:0;width:100%;height:100%;display:block;z-index:1}

/* partners row (About page) */
.partner-row{display:flex;flex-wrap:wrap;gap:clamp(28px,5vw,70px);align-items:baseline}
.partner-row span{font-weight:300;font-size:clamp(22px,2.8vw,44px);letter-spacing:-.02em;color:var(--muted);transition:color .3s}
.about-dark .partner-row span{color:rgba(255,255,255,.6)}
.partner-row span:hover,.about-dark .partner-row span:hover{color:#fff}
@media(max-width:700px){.partner-row{flex-direction:column;gap:16px}}

/* ============================================================
   SCROLL-BUILD STORY — wireframe assembles into a finished site
   ============================================================ */
.scrollbuild{position:relative;height:360vh}
.sb-sticky{position:sticky;top:0;height:100vh;display:flex;align-items:center;overflow:hidden}
.sb-grid{display:grid;grid-template-columns:.82fr 1.18fr;gap:clamp(40px,6vw,90px);align-items:center;width:100%}
.sb-copy .section-title{margin:18px 0 40px}
.sb-steps{list-style:none;display:flex;flex-direction:column;gap:18px}
.sb-steps li{display:flex;align-items:center;gap:16px;font-size:clamp(18px,1.7vw,24px);color:var(--muted);transition:color .4s var(--ease)}
.sb-steps li .sb-n{font-size:13px;letter-spacing:.1em;opacity:.55;transition:opacity .4s,color .4s}
.scrollbuild[data-stage="1"] .sb-steps li[data-step="1"],.scrollbuild[data-stage="2"] .sb-steps li[data-step="2"],
.scrollbuild[data-stage="3"] .sb-steps li[data-step="3"],.scrollbuild[data-stage="4"] .sb-steps li[data-step="4"]{color:var(--ink)}
.scrollbuild[data-stage="1"] .sb-steps li[data-step="1"] .sb-n,.scrollbuild[data-stage="2"] .sb-steps li[data-step="2"] .sb-n,
.scrollbuild[data-stage="3"] .sb-steps li[data-step="3"] .sb-n,.scrollbuild[data-stage="4"] .sb-steps li[data-step="4"] .sb-n{opacity:1}
.sb-progress{margin-top:40px;height:2px;background:var(--line);border-radius:2px;overflow:hidden}
.sb-progress i{display:block;height:100%;width:calc(var(--p,0)*100%);background:var(--ink)}

.sb-browser{border:1px solid var(--line);border-radius:12px;overflow:hidden;background:#fff;
  box-shadow:0 40px 90px -40px rgba(0,0,0,.28);transition:transform .6s var(--ease),box-shadow .6s var(--ease)}
.scrollbuild[data-stage="4"] .sb-browser{transform:translateY(-6px);box-shadow:0 60px 120px -42px rgba(0,0,0,.36)}
.sb-bar{display:flex;align-items:center;gap:8px;padding:12px 16px;border-bottom:1px solid var(--line);background:#fafafa}
.sb-dot{width:10px;height:10px;border-radius:50%;background:#dcdcda}
.sb-url{margin-left:14px;font-size:12px;color:var(--muted);background:#f0f0ee;padding:5px 14px;border-radius:100px;opacity:0;transition:opacity .5s}
.scrollbuild[data-stage="3"] .sb-url,.scrollbuild[data-stage="4"] .sb-url{opacity:1}
.sb-live{margin-left:auto;display:flex;align-items:center;gap:6px;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:#1f9d55;opacity:0;transition:opacity .5s}
.sb-live::before{content:"";width:7px;height:7px;border-radius:50%;background:#22c55e;animation:sbpulse 2s infinite}
.scrollbuild[data-stage="4"] .sb-live{opacity:1}
@keyframes sbpulse{0%{box-shadow:0 0 0 0 rgba(34,197,94,.5)}70%{box-shadow:0 0 0 7px rgba(34,197,94,0)}100%{box-shadow:0 0 0 0 rgba(34,197,94,0)}}
.sb-screen{padding:clamp(18px,2.2vw,32px);display:flex;flex-direction:column;gap:clamp(13px,1.7vw,22px);min-height:clamp(300px,44vh,440px);background:#fff}
.sb-nav,.sb-hero,.sb-img,.sb-card,.sb-h1,.sb-h2,.sb-btn,.sb-logo,.sb-links span{border:1px dashed #d6d6d3;border-radius:6px;background:transparent;transition:all .5s var(--ease)}
.sb-nav{display:flex;align-items:center;justify-content:space-between;padding:10px 14px}
.sb-logo{width:36px;height:14px}
.sb-links{display:flex;gap:8px;border:none}
.sb-links span{width:34px;height:9px}
.sb-hero{display:flex;flex-direction:column;gap:12px;padding:clamp(16px,1.8vw,26px);align-items:flex-start;border-radius:8px}
.sb-h1{width:78%;height:clamp(20px,2.4vw,32px)}
.sb-h2{width:54%;height:12px}
.sb-btn{width:120px;height:34px;border-radius:100px;margin-top:6px}
.sb-img{flex:1;min-height:84px;border-radius:8px}
.sb-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.sb-card{height:60px;border-radius:8px}
.scrollbuild[data-stage="2"] :is(.sb-img,.sb-card,.sb-h1,.sb-h2,.sb-btn,.sb-logo,.sb-links span),
.scrollbuild[data-stage="3"] :is(.sb-img,.sb-card,.sb-h1,.sb-h2,.sb-btn,.sb-logo,.sb-links span),
.scrollbuild[data-stage="4"] :is(.sb-img,.sb-card,.sb-h1,.sb-h2,.sb-btn,.sb-logo,.sb-links span){border-style:solid;border-color:transparent;background:#ececea}
.scrollbuild[data-stage="2"] .sb-nav,.scrollbuild[data-stage="3"] .sb-nav,.scrollbuild[data-stage="4"] .sb-nav{border:none;border-bottom:1px solid #eee;border-radius:0}
.scrollbuild[data-stage="2"] .sb-hero,.scrollbuild[data-stage="3"] .sb-hero,.scrollbuild[data-stage="4"] .sb-hero{border-color:transparent;background:#f6f6f4}
.scrollbuild[data-stage="3"] .sb-h1,.scrollbuild[data-stage="4"] .sb-h1{background:var(--ink)!important}
.scrollbuild[data-stage="3"] .sb-h2,.scrollbuild[data-stage="4"] .sb-h2{background:#bdbdba!important}
.scrollbuild[data-stage="3"] .sb-btn,.scrollbuild[data-stage="4"] .sb-btn{background:var(--ink)!important}
.scrollbuild[data-stage="3"] .sb-logo,.scrollbuild[data-stage="4"] .sb-logo{background:var(--ink)!important}
.scrollbuild[data-stage="3"] .sb-img,.scrollbuild[data-stage="4"] .sb-img{background:linear-gradient(120deg,#1a1a1a,#3a3a3a 60%,#0f0f0f)!important}
.scrollbuild[data-stage="3"] .sb-links span,.scrollbuild[data-stage="4"] .sb-links span{background:#cdcdca!important}
.scrollbuild[data-stage="3"] .sb-card,.scrollbuild[data-stage="4"] .sb-card{background:#f1f1ef;border:1px solid #ececea}
@media(max-width:860px){.sb-grid{grid-template-columns:1fr;gap:34px}.sb-steps{flex-direction:row;flex-wrap:wrap;gap:14px}.scrollbuild{height:300vh}}
@media(prefers-reduced-motion:reduce){.scrollbuild{height:auto}.sb-sticky{position:static;height:auto;padding:80px 0}}
