@import url('fonts.css');

/* =========================================================
   PRACTICAL SPACE CABINETRY — "JOINERY ENGINE"
   Dark, tactile, 3D-led. Full redesign.
   ========================================================= */

:root{
  /* warm near-black surfaces */
  --bg:    #141009;
  --bg-2:  #1B1610;
  --bg-3:  #241D14;
  --bg-4:  #2E2519;

  /* bone text */
  --bone:      #ECE3D1;
  --bone-soft: #B3A892;
  --bone-mute: #7C7261;

  /* molten copper accent */
  --cu:     #E07B33;
  --cu-hi:  #F4A koš* ; /* placeholder removed below */
  --cu-bright: #F6A martin; /* removed below */

  /* lines */
  --line:   rgba(236,227,209,.10);
  --line-2: rgba(236,227,209,.20);
  --line-3: rgba(236,227,209,.34);

  /* fonts */
  --display: 'Cabinet Grotesk', 'Arial Narrow', sans-serif;
  --sans:    'General Sans', -apple-system, BlinkMacSystemFont, sans-serif;
  --mono:    'Space Mono', ui-monospace, monospace;

  --maxw: 1360px;
  --ease: cubic-bezier(.22,.61,.36,1);
  --ease-io: cubic-bezier(.16,1,.3,1);
}
:root{
  --cu-hi: #F4A45A;
  --cu-bright: #FFB969;
  --cu-deep: #A8520F;
  --glow: 0 0 0 1px rgba(224,123,51,.0), 0 8px 40px -12px rgba(224,123,51,.55);
}

/* ---------- reset ---------- */
*,*::before,*::after{box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto;}}
body{
  margin:0;background:var(--bg);color:var(--bone);
  font-family:var(--sans);font-size:17px;line-height:1.62;font-weight:400;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg,canvas,video{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;color:inherit;}
::selection{background:var(--cu);color:#180d04;}

/* film grain + warm vignette */
body::after{
  content:"";position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.05;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
body::before{
  content:"";position:fixed;inset:0;z-index:1;pointer-events:none;
  background:radial-gradient(120% 90% at 50% -10%, rgba(224,123,51,.06), transparent 55%),
             radial-gradient(140% 120% at 50% 120%, rgba(0,0,0,.5), transparent 60%);
}
.page{position:relative;z-index:2;}

/* ---------- type ---------- */
h1,h2,h3,h4{font-family:var(--display);font-weight:800;line-height:.96;letter-spacing:-.02em;margin:0;text-transform:none;}
.display{font-family:var(--display);font-weight:800;font-size:clamp(3rem,10vw,9rem);line-height:.9;letter-spacing:-.035em;}
.h1{font-size:clamp(2.6rem,6vw,5.4rem);letter-spacing:-.03em;}
.h2{font-size:clamp(2.1rem,4.4vw,4rem);letter-spacing:-.028em;}
.h3{font-size:clamp(1.4rem,2.3vw,2.1rem);letter-spacing:-.02em;font-weight:700;}
.cu{color:var(--cu);}
.outline{color:transparent;-webkit-text-stroke:1.4px var(--bone);}
p{margin:0 0 1.1em;}
strong{font-weight:600;color:var(--bone);}
.lede{font-size:clamp(1.05rem,1.5vw,1.3rem);line-height:1.55;color:var(--bone-soft);max-width:56ch;}

/* HUD label (bracketed mono) */
.hud{font-family:var(--mono);font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--cu);display:inline-flex;align-items:center;gap:.7ch;}
.hud::before{content:"[";opacity:.6;}
.hud::after{content:"]";opacity:.6;}
.hud--mute{color:var(--bone-mute);}
.tick{font-family:var(--mono);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--bone-mute);}

/* ---------- layout ---------- */
.wrap{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:clamp(20px,5vw,64px);}
.section{padding-block:clamp(80px,12vw,170px);position:relative;}
.eyebrow{display:flex;align-items:center;gap:1rem;margin-bottom:1.6rem;}
.eyebrow .ln{height:1px;width:46px;background:var(--cu);opacity:.7;}

/* measurement rule divider */
.rule{height:24px;border-top:1px solid var(--line-2);background-image:repeating-linear-gradient(90deg,var(--line-2) 0 1px,transparent 1px 28px);opacity:.5;}

/* ---------- buttons ---------- */
.btn{
  --bg:var(--cu);--fg:#1a0e04;
  position:relative;display:inline-flex;align-items:center;gap:.7em;
  padding:1.02em 1.7em;border-radius:2px;font-weight:600;font-size:.94rem;
  letter-spacing:.01em;border:1px solid var(--cu);cursor:pointer;overflow:hidden;
  background:var(--bg);color:var(--fg);transition:color .4s var(--ease),border-color .4s;
  isolation:isolate;
}
.btn .arr{transition:transform .4s var(--ease);}
.btn::before{content:"";position:absolute;inset:0;z-index:-1;background:var(--bg-2);transform:translateY(101%);transition:transform .45s var(--ease);}
.btn:hover{color:var(--cu);border-color:var(--cu);}
.btn:hover::before{transform:translateY(0);}
.btn:hover .arr{transform:translate(4px,-4px);}
.btn--ghost{--bg:transparent;--fg:var(--bone);border-color:var(--line-3);}
.btn--ghost::before{background:var(--cu);}
.btn--ghost:hover{color:#1a0e04;border-color:var(--cu);}
.btn:focus-visible,a:focus-visible,button:focus-visible{outline:2px solid var(--cu-hi);outline-offset:3px;}

.tlink{position:relative;font-weight:600;display:inline-flex;align-items:center;gap:.5em;color:var(--bone);}
.tlink .arr{color:var(--cu);transition:transform .35s var(--ease);}
.tlink::after{content:"";position:absolute;left:0;bottom:-3px;height:1.5px;width:100%;background:var(--cu);transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease);}
.tlink:hover::after{transform:scaleX(1);}
.tlink:hover .arr{transform:translateX(4px);}

/* ---------- custom cursor ---------- */
@media (hover:hover) and (pointer:fine){
  *{cursor:none;}
  .cursor{position:fixed;top:0;left:0;z-index:9000;pointer-events:none;mix-blend-mode:difference;}
  .cursor .dot{position:fixed;width:7px;height:7px;border-radius:50%;background:#fff;transform:translate(-50%,-50%);}
  .cursor .ring{position:fixed;width:38px;height:38px;border:1px solid rgba(255,255,255,.7);border-radius:50%;transform:translate(-50%,-50%);transition:width .25s var(--ease),height .25s var(--ease),background .25s,border-color .25s;}
  .cursor.hot .ring{width:62px;height:62px;background:rgba(224,123,51,.18);border-color:var(--cu);}
  .cursor.hot .dot{opacity:0;}
}

/* ===========================================================
   HEADER
   =========================================================== */
.site-header{position:fixed;inset:0 0 auto 0;z-index:60;transition:background .4s,border-color .4s,backdrop-filter .4s;border-bottom:1px solid transparent;}
.site-header.scrolled{background:rgba(20,16,9,.72);backdrop-filter:blur(16px) saturate(1.2);border-bottom-color:var(--line);}
.nav{display:flex;align-items:center;justify-content:space-between;height:82px;}
.brand{display:flex;align-items:center;gap:.7rem;font-family:var(--display);font-weight:800;font-size:1.16rem;letter-spacing:-.02em;}
.brand small{display:block;font-family:var(--mono);font-size:.54rem;letter-spacing:.26em;color:var(--bone-mute);text-transform:uppercase;margin-top:2px;font-weight:400;}
.nav-links{display:flex;align-items:center;gap:2.2rem;}
.nav-links a{font-size:.92rem;font-weight:500;color:var(--bone-soft);position:relative;transition:color .25s;}
.nav-links a:hover,.nav-links a[aria-current="page"]{color:var(--bone);}
.nav-links a::after{content:"";position:absolute;left:0;right:0;bottom:-7px;height:2px;background:var(--cu);transform:scaleX(0);transform-origin:left;transition:transform .3s var(--ease);}
.nav-links a:hover::after,.nav-links a[aria-current="page"]::after{transform:scaleX(1);}
.nav-cta{display:flex;align-items:center;gap:1.1rem;}
.menu-btn{display:none;width:48px;height:48px;border-radius:2px;border:1px solid var(--line-2);background:transparent;align-items:center;justify-content:center;}
.menu-btn span,.menu-btn span::before,.menu-btn span::after{content:"";display:block;width:20px;height:1.6px;background:var(--bone);position:relative;transition:.3s;}
.menu-btn span::before{position:absolute;top:-6px;}.menu-btn span::after{position:absolute;top:6px;}
.mobile-nav{position:fixed;inset:0;z-index:55;background:var(--bg);transform:translateY(-100%);transition:transform .5s var(--ease);display:flex;flex-direction:column;padding:100px clamp(20px,6vw,56px) 40px;}
.mobile-nav.open{transform:translateY(0);}
.mobile-nav a{font-family:var(--display);font-weight:700;font-size:2.2rem;padding:.55rem 0;border-bottom:1px solid var(--line);}

/* ===========================================================
   HERO  (full-screen 3D canvas + overlay copy)
   =========================================================== */
.hero{position:relative;height:100svh;min-height:660px;width:100%;overflow:hidden;}
#hero-canvas{position:absolute;inset:0;width:100%;height:100%;z-index:0;}
.hero-grad{position:absolute;inset:0;z-index:1;pointer-events:none;background:
   linear-gradient(90deg, rgba(20,16,9,.66) 0%, rgba(20,16,9,.3) 36%, transparent 60%),
   radial-gradient(80% 60% at 70% 40%, transparent, rgba(20,16,9,.5) 90%),
   linear-gradient(180deg, rgba(20,16,9,.55) 0%, transparent 26%, transparent 60%, rgba(20,16,9,.92) 100%);}
.hero-ui{position:absolute;inset:0;z-index:2;display:flex;flex-direction:column;justify-content:flex-end;pointer-events:none;}
.hero-ui .wrap{pointer-events:none;padding-bottom:clamp(34px,6vw,72px);}
.hero-ui a,.hero-ui button{pointer-events:auto;}
.hero h1{font-size:clamp(2.7rem,7.2vw,7rem);line-height:.88;letter-spacing:-.04em;margin-bottom:1.2rem;}
.hero h1 .line{display:block;overflow:hidden;}
.hero h1 .line > span{display:block;transform:translateY(110%);transition:transform 1s var(--ease);}
.hero.ready h1 .line > span{transform:translateY(0);}
.hero.ready h1 .line:nth-child(2) > span{transition-delay:.08s;}
.hero.ready h1 .line:nth-child(3) > span{transition-delay:.16s;}
.hero-row{display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;flex-wrap:wrap;}
.hero-actions{display:flex;gap:1rem;align-items:center;flex-wrap:wrap;}
.hero-readout{font-family:var(--mono);font-size:.74rem;line-height:1.8;color:var(--bone-soft);text-align:right;}
.hero-readout b{color:var(--cu);font-weight:700;}
.hero-top{position:absolute;top:clamp(96px,12vh,130px);left:0;right:0;z-index:2;}
.hero-top .wrap{display:flex;justify-content:space-between;gap:1rem;}
.hero-eyebrow{max-width:30ch;}
.scroll-cue{position:absolute;left:50%;bottom:22px;transform:translateX(-50%);z-index:3;font-family:var(--mono);font-size:.64rem;letter-spacing:.22em;text-transform:uppercase;color:var(--bone-mute);display:flex;flex-direction:column;align-items:center;gap:8px;}
.scroll-cue .bar{width:1px;height:42px;background:linear-gradient(var(--cu),transparent);animation:cue 1.8s var(--ease) infinite;}
@keyframes cue{0%{transform:scaleY(0);transform-origin:top;}45%{transform:scaleY(1);transform-origin:top;}55%{transform:scaleY(1);transform-origin:bottom;}100%{transform:scaleY(0);transform-origin:bottom;}}

/* exploded-view spec callouts (fade in during scroll) */
.spec-callout{position:absolute;z-index:3;max-width:200px;font-family:var(--mono);font-size:.68rem;line-height:1.5;letter-spacing:.04em;color:var(--bone);opacity:0;transform:translateY(8px);transition:opacity .5s var(--ease),transform .5s var(--ease);pointer-events:none;}
.spec-callout.on{opacity:1;transform:none;}
.spec-callout .k{color:var(--cu);text-transform:uppercase;letter-spacing:.16em;display:block;margin-bottom:3px;}
.spec-callout::before{content:"";position:absolute;width:6px;height:6px;border-radius:50%;background:var(--cu);left:-16px;top:5px;box-shadow:0 0 12px var(--cu);}
.spec-callout::after{content:"";position:absolute;left:-13px;top:8px;width:13px;height:1px;background:var(--cu);opacity:.5;}

/* finish configurator — physical swatch chips */
.finish-bar{display:flex;align-items:flex-end;gap:14px;margin:1.2rem 0 1.5rem;pointer-events:auto;transition:opacity .45s var(--ease),transform .45s var(--ease);}
.finish-bar.hidden{opacity:0;transform:translateY(10px);pointer-events:none;}
.finish-lab{font-family:var(--mono);font-size:.66rem;letter-spacing:.2em;color:var(--bone-mute);align-self:center;margin-right:2px;}
.swatch{position:relative;display:flex;flex-direction:column;align-items:center;gap:7px;background:transparent;border:0;padding:0;cursor:pointer;}
.swatch .sw-fill{width:46px;height:46px;border-radius:3px;background-size:cover;background-position:center;border:1px solid var(--line-2);box-shadow:inset 0 0 0 1px rgba(0,0,0,.35),0 8px 18px -8px rgba(0,0,0,.7);transition:transform .35s var(--ease),box-shadow .35s,border-color .35s;}
.swatch .sw-name{font-family:var(--mono);font-size:.56rem;letter-spacing:.1em;text-transform:uppercase;color:var(--bone-mute);white-space:nowrap;transition:color .3s;}
.swatch:hover .sw-fill{transform:translateY(-3px);border-color:var(--line-3);}
.swatch:hover .sw-name{color:var(--bone-soft);}
.swatch.is-active .sw-fill{border-color:var(--cu);box-shadow:0 0 0 1px var(--cu),0 10px 24px -8px rgba(224,123,51,.5);transform:translateY(-3px);}
.swatch.is-active .sw-name{color:var(--cu);}
.swatch:focus-visible{outline:none;}
.swatch:focus-visible .sw-fill{outline:2px solid var(--cu-hi);outline-offset:3px;}
@media (max-width:640px){
  .finish-bar{gap:9px;flex-wrap:wrap;}
  .finish-lab{flex-basis:100%;margin:0 0 2px;}
  .swatch .sw-fill{width:38px;height:38px;}
  .swatch .sw-name{font-size:.5rem;letter-spacing:.05em;}
}

/* drag hint chip on canvas */
.drag-hint{position:absolute;z-index:3;right:clamp(20px,5vw,64px);top:50%;transform:translateY(-50%);font-family:var(--mono);font-size:.64rem;letter-spacing:.18em;text-transform:uppercase;color:var(--bone-mute);border:1px solid var(--line);border-radius:999px;padding:.5rem .9rem;background:rgba(20,16,9,.4);backdrop-filter:blur(6px);display:flex;align-items:center;gap:.6rem;}
.drag-hint .d{width:6px;height:6px;border-radius:50%;background:var(--cu);}

/* ===========================================================
   MARQUEE
   =========================================================== */
.marquee{border-block:1px solid var(--line);padding-block:22px;overflow:hidden;background:var(--bg-2);-webkit-mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);}
.marquee-track{display:flex;gap:2.6rem;width:max-content;animation:mq 34s linear infinite;}
.marquee:hover .marquee-track{animation-play-state:paused;}
.marquee-item{font-family:var(--display);font-weight:700;font-size:1.5rem;color:var(--bone);display:flex;align-items:center;gap:2.6rem;white-space:nowrap;letter-spacing:-.01em;}
.marquee-item::after{content:"✦";color:var(--cu);font-size:.85rem;}
@keyframes mq{to{transform:translateX(-50%);}}
@media (prefers-reduced-motion:reduce){.marquee-track{animation:none;}}

/* ===========================================================
   SECTION HEADER
   =========================================================== */
.sec-head{display:grid;grid-template-columns:1fr auto;gap:2rem;align-items:end;margin-bottom:clamp(40px,6vw,72px);}
.sec-head .idx{font-family:var(--mono);font-size:.8rem;color:var(--cu);align-self:start;}
.sec-head h2{margin-top:.4rem;}
.sec-head p{color:var(--bone-soft);max-width:40ch;margin:0;}

/* ===========================================================
   EXPLODED / SPEC pinned section
   =========================================================== */
.spec{position:relative;background:var(--bg-2);border-block:1px solid var(--line);}
.spec-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,80px);align-items:center;}
.spec-list{counter-reset:s;display:grid;gap:1px;background:var(--line);border:1px solid var(--line);border-radius:3px;overflow:hidden;}
.spec-row{background:var(--bg-2);padding:24px 26px;display:grid;grid-template-columns:auto 1fr auto;gap:1.2rem;align-items:center;transition:background .3s;}
.spec-row:hover{background:var(--bg-3);}
.spec-row .n{font-family:var(--mono);font-size:.78rem;color:var(--cu);}
.spec-row h3{font-size:1.18rem;font-weight:700;letter-spacing:-.01em;}
.spec-row p{margin:.2rem 0 0;font-size:.92rem;color:var(--bone-soft);}
.spec-row .val{font-family:var(--mono);font-size:.8rem;color:var(--bone-mute);white-space:nowrap;}
.spec-media{position:relative;border:1px solid var(--line-2);border-radius:4px;overflow:hidden;aspect-ratio:4/5;background:var(--bg);}
.spec-media img{width:100%;height:100%;object-fit:cover;opacity:.92;}
.spec-media .cnr{position:absolute;width:14px;height:14px;border-color:var(--cu);}

/* ===========================================================
   CAPABILITIES / what we make — big stacked rows
   =========================================================== */
/* list (left) + sticky preview (right) */
.cap{display:grid;grid-template-columns:1.02fr .98fr;gap:clamp(30px,5vw,72px);align-items:start;margin-top:clamp(30px,4vw,56px);}
.cap-list{display:grid;}
.cap-row{position:relative;display:grid;grid-template-columns:auto 1fr auto;gap:clamp(18px,3vw,44px);align-items:center;padding-block:clamp(22px,2.6vw,34px);border-top:1px solid var(--line);text-decoration:none;transition:padding-left .45s var(--ease),opacity .4s;}
.cap-row:last-child{border-bottom:1px solid var(--line);}
.cap-n{font-family:var(--mono);font-size:.8rem;color:var(--bone-mute);align-self:start;padding-top:.35em;transition:color .4s;}
.cap-body{display:flex;flex-direction:column;gap:.55rem;}
.cap-t{font-family:var(--display);font-weight:800;font-size:clamp(1.6rem,3.1vw,2.75rem);letter-spacing:-.02em;line-height:1.02;color:var(--bone);transition:color .4s;}
.cap-d{max-width:46ch;color:var(--bone-soft);font-size:.95rem;line-height:1.5;opacity:.72;transition:opacity .4s;}
.cap-go{width:52px;height:52px;border:1px solid var(--line-2);border-radius:50%;display:grid;place-items:center;color:var(--cu);align-self:center;flex:none;transition:background .4s,color .4s,transform .55s var(--ease);}
.cap-thumb{display:none;}
/* active + hover + keyboard-focus — calm, readable (no cursor-chasing, no outline text) */
.cap-row:hover,.cap-row:focus-visible,.cap-row.is-active{padding-left:14px;}
.cap-row:hover .cap-n,.cap-row:focus-visible .cap-n,.cap-row.is-active .cap-n{color:var(--cu);}
.cap-row:hover .cap-t,.cap-row:focus-visible .cap-t,.cap-row.is-active .cap-t{color:var(--cu);}
.cap-row:hover .cap-d,.cap-row:focus-visible .cap-d,.cap-row.is-active .cap-d{opacity:1;}
.cap-row:hover .cap-go,.cap-row:focus-visible .cap-go,.cap-row.is-active .cap-go{background:var(--cu);color:#1a0e04;transform:rotate(-45deg);}
.cap-list:hover .cap-row:not(:hover){opacity:.45;}
/* sticky preview panel */
.cap-media{position:sticky;top:clamp(88px,12vh,120px);}
.cap-frame{position:relative;aspect-ratio:4/5;border-radius:8px;overflow:hidden;border:1px solid var(--line-2);background:#171310;box-shadow:0 44px 90px -34px rgba(0,0,0,.78);}
.cap-frame > img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transform:scale(1.07);transition:opacity .6s var(--ease),transform 1.3s var(--ease);}
.cap-frame > img.is-active{opacity:1;transform:scale(1);}
.cap-tag{position:absolute;left:16px;bottom:16px;z-index:2;display:flex;align-items:baseline;gap:12px;padding:9px 15px;background:rgba(20,16,9,.5);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--line-2);border-radius:5px;}
.cap-tag-n{font-family:var(--mono);font-size:.72rem;letter-spacing:.08em;color:var(--cu);}
.cap-tag-t{font-family:var(--display);font-weight:700;font-size:1rem;color:var(--bone);}
@media (prefers-reduced-motion:reduce){.cap-frame > img{transition:opacity .2s linear;transform:none;}.cap-frame > img.is-active{transform:none;}}

/* ===========================================================
   PORTFOLIO — horizontal scroll track (pinned)
   =========================================================== */
.work{background:var(--bg);overflow:hidden;}
.work-head{display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;flex-wrap:wrap;margin-bottom:40px;}
.h-track-vp{position:relative;}
.h-track{display:flex;gap:24px;will-change:transform;padding-inline:clamp(20px,5vw,64px);}
.wcard{position:relative;flex:none;width:min(74vw,520px);border-radius:5px;overflow:hidden;border:1px solid var(--line);background:var(--bg-3);}
.wcard .ph{aspect-ratio:4/5;overflow:hidden;}
.wcard .ph img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease),filter .5s;filter:saturate(.92) brightness(.92);}
.wcard:hover .ph img{transform:scale(1.05);filter:saturate(1) brightness(1);}
.wcard .meta{position:absolute;left:0;right:0;bottom:0;padding:22px 24px;background:linear-gradient(transparent,rgba(20,16,9,.92));}
.wcard .meta .t{font-family:var(--display);font-weight:700;font-size:1.5rem;letter-spacing:-.02em;}
.wcard .meta .m{font-family:var(--mono);font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:var(--cu);margin-top:4px;}
.wcard .tagn{position:absolute;top:16px;left:16px;font-family:var(--mono);font-size:.66rem;letter-spacing:.1em;color:var(--bone);background:rgba(20,16,9,.6);backdrop-filter:blur(6px);border:1px solid var(--line);padding:.3rem .6rem;border-radius:999px;}

/* ===========================================================
   STAT / NUMBERS
   =========================================================== */
.nums{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:4px;overflow:hidden;}
.num{background:var(--bg);padding:36px 30px;}
.num .v{font-family:var(--display);font-weight:800;font-size:clamp(2.6rem,5vw,4.4rem);line-height:1;letter-spacing:-.03em;}
.num .v .u{color:var(--cu);}
.num .k{font-family:var(--mono);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--bone-mute);margin-top:.8rem;}

/* ===========================================================
   PROCESS strip
   =========================================================== */
.flow{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:4px;overflow:hidden;}
.flow-step{background:var(--bg);padding:30px 26px 40px;position:relative;transition:background .35s;}
.flow-step:hover{background:var(--bg-2);}
.flow-step .s{font-family:var(--mono);font-size:.74rem;color:var(--cu);}
.flow-step .pico{width:40px;height:40px;color:var(--cu);margin:22px 0 18px;}
.flow-step h3{font-size:1.2rem;font-weight:700;margin-bottom:.5rem;}
.flow-step p{font-size:.9rem;color:var(--bone-soft);margin:0;}

/* ===========================================================
   CTA
   =========================================================== */
.cta{position:relative;border:1px solid var(--line-2);border-radius:6px;overflow:hidden;padding:clamp(44px,7vw,96px);background:
   radial-gradient(110% 140% at 100% 0%, rgba(224,123,51,.22), transparent 55%),var(--bg-2);isolation:isolate;}
.cta::before{content:"";position:absolute;inset:0;z-index:-1;background-image:repeating-linear-gradient(90deg,var(--line) 0 1px,transparent 1px 46px);opacity:.4;}
.cta h2{max-width:16ch;margin-bottom:1.4rem;}
.cta .lede{margin-bottom:2rem;}

/* ===========================================================
   FOOTER
   =========================================================== */
.site-footer{background:#0E0B06;border-top:1px solid var(--line);padding-block:clamp(60px,8vw,100px) 34px;}
.foot-top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:36px;}
.foot-brand p{color:var(--bone-mute);font-size:.94rem;margin-top:1rem;max-width:32ch;}
.foot-col h4{font-family:var(--mono);font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--cu);font-weight:700;margin-bottom:1.1rem;}
.foot-col a{display:block;color:var(--bone-soft);padding:.32rem 0;font-size:.95rem;transition:color .2s,padding-left .25s;}
.foot-col a:hover{color:var(--bone);padding-left:5px;}
.foot-addr{display:block;color:var(--bone-soft);padding:.32rem 0;font-size:.95rem;}
.foot-bottom{display:flex;justify-content:space-between;gap:1rem;margin-top:52px;padding-top:24px;border-top:1px solid var(--line);flex-wrap:wrap;font-family:var(--mono);font-size:.74rem;letter-spacing:.04em;color:var(--bone-mute);}
.giant{font-family:var(--display);font-weight:800;font-size:clamp(3rem,16vw,15rem);line-height:.8;letter-spacing:-.05em;color:transparent;-webkit-text-stroke:1px var(--line-3);margin-top:60px;text-align:center;user-select:none;}

/* ===========================================================
   REVEAL
   =========================================================== */
[data-reveal]{opacity:0;transform:translateY(30px);transition:opacity .9s var(--ease-io),transform .9s var(--ease-io);}
[data-reveal].in{opacity:1;transform:none;}
[data-reveal][data-d="1"]{transition-delay:.08s;}
[data-reveal][data-d="2"]{transition-delay:.16s;}
[data-reveal][data-d="3"]{transition-delay:.24s;}
[data-reveal][data-d="4"]{transition-delay:.32s;}
@media (prefers-reduced-motion:reduce){[data-reveal]{opacity:1!important;transform:none!important;}.cursor{display:none!important;}*{cursor:auto!important;}}

/* ===========================================================
   RESPONSIVE
   =========================================================== */
@media (max-width:1000px){
  .spec-grid{grid-template-columns:1fr;}
  .nums{grid-template-columns:1fr 1fr;}
  .flow{grid-template-columns:1fr 1fr;}
  .foot-top{grid-template-columns:1fr 1fr;}
  /* capabilities: drop the sticky preview, show inline photo per row */
  .cap{grid-template-columns:1fr;gap:0;}
  .cap-media{display:none;}
  .cap-row{grid-template-columns:auto 1fr;grid-template-areas:"n body" "img img";padding-block:clamp(22px,4vw,32px);}
  .cap-n{grid-area:n;}
  .cap-body{grid-area:body;}
  .cap-go{display:none;}
  .cap-thumb{grid-area:img;display:block;width:100%;aspect-ratio:16/10;object-fit:cover;border-radius:6px;margin-top:16px;border:1px solid var(--line-2);}
  .cap-row:hover,.cap-row.is-active{padding-left:0;}
  .cap-list:hover .cap-row:not(:hover){opacity:1;}
}
@media (max-width:640px){
  body{font-size:16px;}
  .nav-links{display:none;}
  .menu-btn{display:flex;}
  .nav-cta .btn{display:none;}
  .nums,.flow{grid-template-columns:1fr;}
  .foot-top{grid-template-columns:1fr;gap:28px;}
  .hero-readout{display:none;}
  .drag-hint{display:none;}
  .scroll-cue{display:none;}
  .hero-grad{background:
     linear-gradient(180deg, rgba(20,16,9,.78) 0%, transparent 34%, rgba(20,16,9,.45) 55%, rgba(20,16,9,.96) 100%);}
  *{cursor:auto!important;}
  .cursor{display:none!important;}
}
