/* ============================================================
   XORVA — Digital Identity Studio
   Brand system tokens carried directly from the XORVA brand
   identity file: Racing Green / Bone / Marigold Amber, on
   Schibsted Grotesk + Hanken Grotesk + JetBrains Mono.
   ============================================================ */

:root{
  /* ---- Core palette (from brand spec — do not alter ratios) ---- */
  --green:        #0E2A26;   /* primary — racing green. ~64% of any view */
  --green-deep:   #081D1A;   /* depth — shadows, layered panels, footers */
  --green-soft:   #16413A;   /* raised surfaces & cards on green */
  --green-line:   #245049;   /* hairlines on green */

  --bone:         #F3EEE3;   /* base warm off-white. ~28% of any view */
  --bone-dim:     #EBE3D4;   /* cards / surfaces on bone */
  --bone-line:    #DCD2BE;   /* hairline borders on bone */
  --bone-soft:    rgba(243,238,227,0.62); /* muted text on green */

  --amber:        #E9A23C;   /* the spark — CTAs, accents. ~8%, used sparingly */
  --amber-deep:   #BF5E27;   /* hover / secondary accent */

  --ink:          #15120D;   /* warm near-black text on bone */
  --ink-soft:     #5A5346;   /* muted body copy on bone */

  /* ---- Type ---- */
  --display: 'Schibsted Grotesk', system-ui, sans-serif;
  --body:    'Hanken Grotesk', system-ui, sans-serif;
  --mono:    'JetBrains Mono', ui-monospace, monospace;

  /* ---- Layout ---- */
  --maxw: 1240px;
  --nav-h: 76px;

  /* ---- Motion (refined, not flashy — per brand) ---- */
  --ease: cubic-bezier(.3,.7,.4,1);
  --fast: .18s;
  --med:  .35s;
}

/* ============================================================
   RESET & BASE
   ============================================================ */
*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
  scroll-behavior:smooth;
}
@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior:auto; }
  *,*::before,*::after{ animation-duration:0.01ms !important; animation-iteration-count:1 !important; transition-duration:0.01ms !important; scroll-behavior:auto !important; }
}
body{
  font-family:var(--body);
  background:var(--bone);
  color:var(--ink);
  font-size:17px;
  line-height:1.6;
  overflow-x:hidden;
}
img,svg{ display:block; max-width:100%; }
a{ color:inherit; }
button{ font:inherit; cursor:pointer; border:none; background:none; color:inherit; }
::selection{ background:var(--amber); color:var(--green-deep); }

.skip-link{
  position:absolute; left:16px; top:-60px; z-index:1000;
  background:var(--ink); color:var(--bone); font-family:var(--mono);
  font-size:13px; letter-spacing:.04em; padding:12px 18px; border-radius:6px;
  transition:top var(--fast) var(--ease);
}
.skip-link:focus{ top:16px; }

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

.wrap{ max-width:var(--maxw); margin:0 auto; padding:0 clamp(20px, 5vw, 56px); }

/* ============================================================
   REVEAL-ON-SCROLL
   ============================================================ */
.reveal{
  opacity:0;
  transform:translateY(28px);
  transition:opacity .7s var(--ease), transform .7s var(--ease);
}
.reveal.is-visible{ opacity:1; transform:translateY(0); }
.reveal[data-reveal-delay="1"]{ transition-delay:.08s; }
.reveal[data-reveal-delay="2"]{ transition-delay:.16s; }
.reveal[data-reveal-delay="3"]{ transition-delay:.24s; }

/* ============================================================
   PRELOADER — first-visit intro curtain (skipped on later
   in-session navigations via sessionStorage)
   ============================================================ */
.preloader{
  position:fixed; inset:0; z-index:9999;
  display:flex; align-items:center; justify-content:center;
  background:var(--green);
  transition:transform .9s var(--ease);
  will-change:transform;
}
.preloader-inner{
  display:flex; flex-direction:column; align-items:center; gap:18px;
  opacity:0; animation:preIn .7s var(--ease) .1s forwards;
}
.preloader-mark{ width:62px; height:62px; display:block; filter:drop-shadow(0 10px 26px rgba(8,29,26,.55)); }
.preloader-mark svg{ width:100%; height:100%; display:block; }
.preloader-mark .mark-back, .preloader-mark .mark-front{ fill:var(--amber); }
.preloader-mark .mark-halo{ fill:var(--green); }
.preloader-word{
  font-family:var(--display); font-weight:800; font-size:23px;
  letter-spacing:.05em; color:var(--bone);
}
.preloader-bar{ width:140px; height:2px; border-radius:2px; overflow:hidden; background:var(--green-line); }
.preloader-bar-fill{
  display:block; height:100%; width:100%;
  background:var(--amber); transform:scaleX(0); transform-origin:left;
  animation:preBar 1.25s var(--ease) .15s forwards;
}
.preloader-tag{
  font-family:var(--mono); font-size:10px; letter-spacing:.3em; text-transform:uppercase;
  color:var(--bone-soft);
}
.is-loaded .preloader{ transform:translateY(-100%); }     /* lift the curtain */
.preloader.is-instant{ display:none; }                    /* repeat visit: no intro */

@keyframes preIn{ from{ opacity:0; transform:translateY(10px); } to{ opacity:1; transform:translateY(0); } }
@keyframes preBar{ from{ transform:scaleX(0); } to{ transform:scaleX(1); } }

/* ============================================================
   TYPE SCALE  (brand spec: Display / Headline / Body / Label)
   ============================================================ */
.eyebrow{
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--mono); font-size:12px; letter-spacing:.2em;
  text-transform:uppercase; color:var(--amber-deep);
  margin-bottom:20px;
}
.eyebrow::before{
  content:""; display:inline-block; width:22px; height:3px;
  background:currentColor; border-radius:2px; transform:skewX(-20deg);
}
.on-green .eyebrow{ color:var(--amber); }

.lead{
  font-size:clamp(18px,1.9vw,22px); line-height:1.55;
  color:var(--ink-soft); max-width:60ch; font-weight:400;
}
.on-green .lead{ color:var(--bone-soft); }

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

/* ---- Spec-sheet section header (numbered, mono meta) ---- */
.spec-head{
  display:flex; align-items:baseline; gap:18px; flex-wrap:wrap;
  margin-bottom:48px;
}
.spec-no{
  font-family:var(--mono); font-size:12px; letter-spacing:.16em;
  text-transform:uppercase; color:var(--amber-deep);
  border:1px solid currentColor; padding:5px 10px; border-radius:2px;
}
.on-green .spec-no{ color:var(--amber); border-color:var(--green-line); }
.spec-title{
  font-family:var(--display); font-weight:800;
  font-size:clamp(32px,4.4vw,50px); letter-spacing:-0.025em; line-height:1;
}
.spec-meta{
  font-family:var(--mono); font-size:11.5px; letter-spacing:.14em;
  text-transform:uppercase; color:var(--ink-soft); margin-left:auto;
}
.on-green .spec-meta{ color:var(--bone-soft); }

/* ---- Buttons ---- */
.btn{
  font-family:var(--display); font-weight:600; font-size:15px; letter-spacing:.01em;
  padding:15px 28px; border-radius:5px; display:inline-flex; align-items:center; gap:10px;
  background:var(--amber); color:var(--green-deep);
  transition:background var(--fast) ease, transform var(--fast) ease, box-shadow var(--fast) ease, color var(--fast) ease;
  white-space:nowrap;
}
.btn:hover{ background:var(--amber-deep); color:var(--bone); transform:translateY(-2px); box-shadow:0 14px 28px -14px rgba(191,94,39,.55); }
.btn:active{ transform:translateY(0); }
.btn .arrow{ display:inline-block; transition:transform var(--fast) var(--ease); }
.btn:hover .arrow{ transform:translateX(4px); }

.btn-ghost{
  background:transparent; color:inherit;
  box-shadow:inset 0 0 0 1.5px currentColor;
}
.btn-ghost:hover{ background:transparent; color:var(--amber); box-shadow:inset 0 0 0 1.5px var(--amber); transform:translateY(-2px); }
.on-green .btn-ghost,
.cta .btn-ghost{ color:var(--bone); }
.on-green .btn-ghost:hover,
.cta .btn-ghost:hover{ color:var(--amber); }

.btn-sm{ padding:11px 20px; font-size:13.5px; }
.btn-lg{ padding:18px 34px; font-size:16.5px; }

/* ============================================================
   LOGO — woven X mark + wordmark (built from brand glyph specs)
   ============================================================ */
.x-mark svg, .x-word svg{ width:100%; height:100%; display:block; }
.x-mark{ display:inline-flex; flex:0 0 auto; }

/* Glyphs are now inlined as real <polygon>s (not <use>/<symbol>), so
   ordinary descendant selectors style them reliably per context.
   Signature "Woven": amber blades on a green ground, the halo polygon
   matching whatever surface the glyph sits on so the weave reads as a
   literal cut-through gap rather than a flat overlap. */
.mark-back, .mark-front{ fill:var(--amber); }
.mark-halo{ fill:var(--green); }

.nav-logo .x-mark, .footer-logo .x-mark, .x-mark-sm{
  border-radius:8px; background:var(--green-soft);
  align-items:center; justify-content:center;
}
.nav-logo .x-mark, .footer-logo .x-mark{ width:34px; height:34px; padding:7px; }
.x-mark-sm{ width:28px; height:28px; border-radius:7px; padding:6px; }
.nav-logo .mark-halo, .footer-logo .mark-halo, .x-mark-sm .mark-halo{ fill:var(--green-soft); }

/* Hero / CTA watermark — full-bleed glyph, low-opacity tonal depth (no tile) */
.hero-mark .mark-back, .hero-mark .mark-front{ fill:var(--green-soft); }
.hero-mark .mark-halo{ fill:var(--green); }
.cta-mark .mark-back, .cta-mark .mark-front{ fill:var(--green-line); }
.cta-mark .mark-halo{ fill:var(--green-deep); }

/* The wordmark "X" glyph — clean woven bars, set tight against ORVA */
.wordmark{
  display:inline-flex; align-items:flex-end; gap:0;
  font-family:var(--display); font-weight:800; font-size:21px;
  letter-spacing:-0.02em; line-height:.86; color:var(--green);
}
.x-word{ width:.62em; height:.78em; margin-right:-.05em; margin-bottom:.02em; }
.word-back{ fill:var(--green); }
.word-halo{ fill:var(--bone); }
.word-front{ fill:var(--amber); }

/* Footer wordmark — light, on the deep-green footer */
.footer-logo, .footer-logo .wordmark{ color:var(--bone); }
.footer-logo .word-back{ fill:var(--bone); }
.footer-logo .word-halo{ fill:var(--green-deep); }
.footer-logo .word-front{ fill:var(--amber); }

/* Nav sits transparently over the dark hero, then solidifies to a bone
   backdrop on scroll — flip the wordmark contrast to match. */
.nav-logo .wordmark{ color:var(--bone); }
.nav-logo .word-back{ fill:var(--bone); }
.nav-logo .word-halo{ fill:var(--green-deep); }
.nav-logo .word-front{ fill:var(--amber); }
.nav.is-solid .nav-logo .wordmark{ color:var(--green); }
.nav.is-solid .nav-logo .word-back{ fill:var(--green); }
.nav.is-solid .nav-logo .word-halo{ fill:var(--bone); }

.nav-logo, .footer-logo{
  display:inline-flex; align-items:center; gap:12px; text-decoration:none;
}
.studio-sign{
  display:flex; align-items:center; gap:12px; margin-top:36px;
  font-family:var(--mono); font-size:12px; letter-spacing:.14em;
  text-transform:uppercase; color:var(--ink-soft);
}

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:200;
  height:var(--nav-h);
}
.nav-inner{
  height:100%; display:flex; align-items:center; justify-content:space-between;
  background:rgba(243,238,227,0); border-bottom:1px solid transparent;
  transition:background var(--med) ease, border-color var(--med) ease, backdrop-filter var(--med) ease;
}
.nav.is-solid .nav-inner{
  background:rgba(243,238,227,0.86);
  -webkit-backdrop-filter:blur(14px) saturate(1.2);
  backdrop-filter:blur(14px) saturate(1.2);
  border-bottom:1px solid var(--bone-line);
}
/* Dissolve: fade + a small upward drift on scroll-down, rather than a hard
   slide. Keeps the bar from ever overlapping/clashing with hero content. */
.nav{ transition:transform var(--med) var(--ease), opacity var(--med) var(--ease); }
.nav.is-hidden{ opacity:0; transform:translateY(-14px); pointer-events:none; }

.nav-links{ display:flex; gap:6px; }
.nav-links a{
  font-family:var(--display); font-weight:500; font-size:15px;
  text-decoration:none; padding:9px 16px; border-radius:5px;
  color:var(--bone-soft); position:relative;
  transition:color var(--fast) ease, background var(--fast) ease;
}
/* Amber underline that wipes in from the left on hover */
.nav-links a::after{
  content:""; position:absolute; left:16px; right:16px; bottom:5px; height:1.5px;
  background:var(--amber); transform:scaleX(0); transform-origin:left;
  transition:transform var(--med) var(--ease);
}
.nav-links a:hover{ color:var(--bone); background:rgba(243,238,227,0.06); }
.nav-links a:hover::after{ transform:scaleX(1); }
.nav.is-solid .nav-links a{ color:var(--ink-soft); }
.nav.is-solid .nav-links a:hover{ color:var(--ink); background:transparent; }

.nav-actions{ display:flex; align-items:center; gap:14px; }

.nav-toggle{
  display:none; flex-direction:column; justify-content:center; gap:5px;
  width:40px; height:40px; border-radius:8px;
}
.nav-toggle span{
  display:block; width:20px; height:2px; background:var(--bone);
  margin:0 auto; transition:transform var(--fast) ease, opacity var(--fast) ease, background var(--med) ease;
}
.nav.is-solid .nav-toggle span{ background:var(--ink); }
.nav-toggle[aria-expanded="true"] span:first-child{ transform:translateY(3.5px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] span:last-child{ transform:translateY(-3.5px) rotate(-45deg); }

.mobile-nav{
  display:none; flex-direction:column; gap:2px;
  background:var(--bone); border-bottom:1px solid var(--bone-line);
  padding:0 clamp(20px,5vw,56px);
  max-height:0; overflow:hidden;
  transition:max-height var(--med) var(--ease), padding var(--med) var(--ease);
}
/* Padding only applies when open — otherwise the collapsed box can't shrink
   below its own vertical padding (border-box height floors at padding sum). */
.mobile-nav.is-open{ max-height:420px; padding:10px clamp(20px,5vw,56px) 22px; }
.mobile-nav a{
  font-family:var(--display); font-weight:600; font-size:18px;
  text-decoration:none; padding:13px 4px; border-bottom:1px solid var(--bone-line);
  color:var(--ink);
}
.mobile-nav a.btn{
  border:0; margin-top:14px; justify-content:center; text-align:center;
}

@media (max-width: 880px){
  .nav-links{ display:none; }
  .nav-toggle{ display:flex; }
  .mobile-nav{ display:flex; }
  .nav-actions .btn-sm{ display:none; }
}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative; overflow:hidden;
  min-height:100vh;
  display:flex; flex-direction:column; justify-content:center;
  background:var(--green); color:var(--bone);
  padding-top:var(--nav-h);
}
/* Ambient warm glow — slow drift adds depth without stealing the amber spark */
.hero::before{
  content:""; position:absolute; z-index:0; pointer-events:none;
  width:min(86vw,1100px); aspect-ratio:1; border-radius:50%;
  top:-26%; right:-14%;
  background:radial-gradient(circle, rgba(233,162,60,0.10), rgba(233,162,60,0) 62%);
  animation:heroGlow 16s ease-in-out infinite alternate;
}
.hero-mark{
  position:absolute; right:-8%; top:50%; transform:translateY(-50%);
  width:min(58vw, 760px); opacity:.07; pointer-events:none;
}
/* Float lives on the inner svg so it composes with the JS parallax on the
   wrapper div instead of fighting it for the transform property. */
.hero-mark svg{
  transform-origin:center;
  animation:heroFloat 13s ease-in-out infinite alternate;
}
.hero-inner{ position:relative; z-index:1; padding-top:64px; padding-bottom:64px; }

/* ---- Hero load sequence ----
   Content is visible by default (no-JS safe). The choreography only fires
   once <body> gets .is-loaded — which JS adds as the preloader lifts, so the
   hero reveals in sync with the curtain pulling up. */
.hero-headline{
  font-family:var(--display); font-weight:800;
  font-size:clamp(40px, 7.4vw, 92px);
  letter-spacing:-0.035em; line-height:1.02;
  max-width:18ch;
}
.hl-line{ display:block; overflow:hidden; padding-bottom:.04em; }
.hl-line > span{ display:block; }

.is-loaded .hero-eyebrow{ animation:heroRise .85s var(--ease) .1s both; }
.is-loaded .hl-line > span{ animation:heroLine 1s var(--ease) both; }
.is-loaded .hl-line:nth-child(1) > span{ animation-delay:.26s; }
.is-loaded .hl-line:nth-child(2) > span{ animation-delay:.39s; }
.is-loaded .hl-line:nth-child(3) > span{ animation-delay:.52s; }
.is-loaded .hero-foot{ animation:heroRise .9s var(--ease) .78s both; }
.is-loaded .hero-scroll{ animation:heroRise 1s var(--ease) 1s both; }

@keyframes heroRise{ from{ opacity:0; transform:translateY(26px); } to{ opacity:1; transform:translateY(0); } }
@keyframes heroLine{ from{ transform:translateY(105%); } to{ transform:translateY(0); } }
@keyframes heroGlow{
  0%{ transform:translate(0,0) scale(1); opacity:.6; }
  100%{ transform:translate(-5%,4%) scale(1.14); opacity:1; }
}
@keyframes heroFloat{
  0%{ transform:translateY(0) rotate(0deg); }
  100%{ transform:translateY(-2.5%) rotate(1.6deg); }
}

/* ============================================================
   AMBIENT BACKGROUNDS — slow, low-contrast warm drift on the
   dark sections, for depth without distraction. Light (bone)
   sections are left deliberately calm.
   ============================================================ */
.on-green{ position:relative; overflow:hidden; }
.on-green > .wrap{ position:relative; z-index:1; }
.on-green::before{
  content:""; position:absolute; z-index:0; pointer-events:none;
  width:min(72vw,860px); aspect-ratio:1; border-radius:50%;
  left:-14%; top:-20%;
  background:radial-gradient(circle, rgba(233,162,60,0.06), rgba(233,162,60,0) 64%);
  animation:ambientDrift 22s ease-in-out infinite alternate;
}
.process.on-green::before{
  left:auto; right:-16%; top:auto; bottom:-22%; animation-duration:27s;
}
.cta::before{
  content:""; position:absolute; z-index:0; pointer-events:none;
  width:min(60vw,640px); aspect-ratio:1; border-radius:50%;
  left:20%; top:-14%;
  background:radial-gradient(circle, rgba(233,162,60,0.07), rgba(233,162,60,0) 66%);
  animation:ambientDrift 24s ease-in-out infinite alternate;
}
/* CTA watermark drifts like the hero mark (parallax stays on the wrapper) */
.cta-mark svg{ transform-origin:center; animation:heroFloat 15s ease-in-out infinite alternate; }

@keyframes ambientDrift{
  0%{ transform:translate(0,0) scale(1); opacity:.45; }
  100%{ transform:translate(7%,6%) scale(1.18); opacity:1; }
}
.hero-foot{
  display:flex; justify-content:space-between; align-items:flex-end;
  gap:48px; margin-top:48px; flex-wrap:wrap;
}
.hero-sub{
  font-size:clamp(16px,1.7vw,19px); line-height:1.6; color:var(--bone-soft);
  max-width:46ch;
}
.hero-cta{ display:flex; gap:16px; flex-wrap:wrap; flex:0 0 auto; }
.cta .hero-cta,
.hero .btn-ghost{ color:var(--bone); }
.hero .btn-ghost:hover{ color:var(--amber); }

.hero-scroll{
  position:relative; z-index:1;
  display:flex; align-items:center; gap:14px;
  font-family:var(--mono); font-size:11.5px; letter-spacing:.2em; text-transform:uppercase;
  color:var(--bone-soft); padding-bottom:40px;
}
.scroll-line{
  display:inline-block; width:48px; height:1px; background:currentColor; position:relative; overflow:hidden;
}
.scroll-line::after{
  content:""; position:absolute; inset:0; background:var(--amber);
  transform:translateX(-100%);
  animation:scrollLine 2.4s var(--ease) infinite;
}
@keyframes scrollLine{
  0%{ transform:translateX(-100%); }
  50%{ transform:translateX(0); }
  100%{ transform:translateX(100%); }
}

/* ============================================================
   GENERIC SECTION
   ============================================================ */
.section{
  padding:clamp(80px, 12vw, 140px) 0;
  border-top:1px solid var(--bone-line);
  position:relative;
  scroll-margin-top:var(--nav-h);
}
.section.on-green{
  background:var(--green); color:var(--bone);
  border-top:1px solid var(--green-line);
}

/* ============================================================
   FEATURED WORK
   ============================================================ */
.work-grid{
  margin-top:56px;
  display:grid; grid-template-columns:repeat(2, 1fr);
  gap:clamp(24px, 3vw, 40px);
}
.work-card-link{ display:block; text-decoration:none; color:inherit; }
.work-card{
  border-radius:10px; overflow:hidden;
  background:var(--bone-dim);
  border:1px solid var(--bone-line);
  transition:transform var(--med) var(--ease), box-shadow var(--med) var(--ease), border-color var(--med) ease;
}
.work-card:hover{
  transform:translateY(-6px);
  box-shadow:0 36px 64px -32px rgba(21,18,13,.28);
  border-color:var(--bone-line);
}
.work-thumb{
  position:relative; aspect-ratio:4/5; overflow:hidden;
  display:flex; align-items:flex-end; padding:22px;
}
.work-thumb-label{
  font-family:var(--mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase;
  color:var(--ink-soft); background:rgba(243,238,227,.7);
  padding:8px 12px; border-radius:4px;
  -webkit-backdrop-filter:blur(6px); backdrop-filter:blur(6px);
}
.work-card-arrow{
  position:absolute; top:22px; right:22px;
  width:48px; height:48px; border-radius:50%;
  display:grid; place-items:center;
  background:var(--bone); color:var(--green);
  font-size:20px;
  transform:scale(.7) rotate(-40deg); opacity:0;
  transition:transform var(--med) var(--ease), opacity var(--fast) ease, background var(--fast) ease, color var(--fast) ease;
}
.work-card:hover .work-card-arrow{
  transform:scale(1) rotate(0deg); opacity:1;
}
.work-card:hover .work-thumb-label{ opacity:0; }
.work-card:hover .work-thumb::after{ transform:scale(1.06); }
.work-thumb::after{
  content:""; position:absolute; inset:0;
  background-color:var(--bone-dim);
  background-image:repeating-linear-gradient(135deg, transparent 0 13px, rgba(21,18,13,.05) 13px 14px);
  transition:transform 1.1s var(--ease);
  z-index:-1;
}
.work-meta{ padding:28px 28px 30px; }
.work-meta-top{
  display:flex; align-items:baseline; justify-content:space-between; gap:16px;
  flex-wrap:wrap; margin-bottom:14px;
}
.work-name{
  font-family:var(--display); font-weight:700; font-size:clamp(22px,2.4vw,28px);
  letter-spacing:-0.02em;
}
.placeholder-tag{
  font-family:var(--mono); font-size:12px; font-weight:400; letter-spacing:.04em;
  color:var(--amber-deep); text-transform:none;
}
.work-industry{
  font-family:var(--mono); font-size:11.5px; letter-spacing:.14em; text-transform:uppercase;
  color:var(--ink-soft); white-space:nowrap;
}
.work-desc{ color:var(--ink-soft); font-size:15.5px; line-height:1.6; max-width:48ch; margin-bottom:18px; }
.work-url{
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--mono); font-size:13px; letter-spacing:.06em; color:var(--ink);
  font-weight:600;
}
.work-url::before{ content:"↗"; color:var(--amber-deep); }

/* Cards aren't live links yet (sites not hosted). While a card is a <div>
   rather than an <a>: no click affordance, no "open" arrow, and the url line
   reads as a muted status. Swap <div class="work-card-link"> → <a … href>
   and all of this reverts automatically. */
div.work-card-link{ cursor:default; }
div.work-card-link .work-card-arrow{ display:none; }
.work-card:hover div.work-card-link .work-thumb-label{ opacity:1; }
div.work-card-link .work-url{
  font-weight:500; font-size:12px; letter-spacing:.1em; text-transform:uppercase;
  color:var(--ink-soft);
}
div.work-card-link .work-url::before{
  content:""; width:6px; height:6px; border-radius:50%;
  background:var(--amber); flex:0 0 auto;
}

@media (max-width: 760px){
  .work-grid{ grid-template-columns:1fr; }
}

/* ============================================================
   PHILOSOPHY
   ============================================================ */
.philosophy-lead{
  font-family:var(--display); font-weight:800;
  font-size:clamp(30px, 5.4vw, 64px);
  letter-spacing:-0.03em; line-height:1.08;
  max-width:18ch; margin-bottom:64px;
}
.philosophy-lead .accent{ color:var(--amber); }
.philosophy-grid{
  display:grid; grid-template-columns:repeat(2, 1fr);
  gap:1px; background:var(--green-line);
  border:1px solid var(--green-line); border-radius:10px; overflow:hidden;
}
.philosophy-block{
  position:relative; isolation:isolate;
  background:var(--green); padding:clamp(28px,4vw,44px);
  display:flex; flex-direction:column; gap:16px;
  transition:background var(--med) var(--ease);
}
/* Amber edge that wipes in from the top on hover — the "spark" landing on
   the cell the visitor is reading. */
.philosophy-block::before{
  content:""; position:absolute; left:0; top:0; bottom:0; width:2px;
  background:var(--amber); transform:scaleY(0); transform-origin:top;
  transition:transform var(--med) var(--ease);
}
.philosophy-block:hover{ background:var(--green-soft); }
.philosophy-block:hover::before{ transform:scaleY(1); }
/* Stagger the grid reveal so the four ideas land in sequence. */
.philosophy-block.reveal:nth-child(2){ transition-delay:.09s; }
.philosophy-block.reveal:nth-child(3){ transition-delay:.18s; }
.philosophy-block.reveal:nth-child(4){ transition-delay:.27s; }
.philosophy-no{
  font-family:var(--mono); font-size:13px; letter-spacing:.16em; color:var(--amber);
  display:inline-block;
  transition:transform var(--med) var(--ease), letter-spacing var(--med) var(--ease);
}
.philosophy-block:hover .philosophy-no{ transform:translateX(4px); letter-spacing:.26em; }
.philosophy-block h3{
  font-family:var(--display); font-weight:700; font-size:clamp(20px,2.2vw,25px);
  letter-spacing:-0.015em; line-height:1.2;
  transition:transform var(--med) var(--ease);
}
.philosophy-block:hover h3{ transform:translateX(4px); }
.philosophy-block p{ color:var(--bone-soft); font-size:15.5px; line-height:1.65; max-width:52ch; }
.philosophy-close{
  font-family:var(--display); font-weight:600; font-size:clamp(20px,2.6vw,28px);
  letter-spacing:-0.015em; line-height:1.4; max-width:38ch;
  margin-top:64px; color:var(--bone);
}

@media (max-width: 760px){
  .philosophy-grid{ grid-template-columns:1fr; }
}

/* ============================================================
   CAPABILITIES
   ============================================================ */
.cap-list{ margin-top:56px; border-top:1px solid var(--bone-line); }
.cap-row{
  display:grid; grid-template-columns:64px 1fr auto;
  gap:32px; align-items:center;
  padding:34px 0; border-bottom:1px solid var(--bone-line);
  transition:padding var(--med) var(--ease);
}
.cap-row:hover{ padding-left:14px; }
.cap-no{
  font-family:var(--mono); font-size:13px; letter-spacing:.1em; color:var(--amber-deep);
}
.cap-body h3{
  font-family:var(--display); font-weight:700; font-size:clamp(22px,2.6vw,30px);
  letter-spacing:-0.02em; margin-bottom:8px;
  transition:color var(--fast) ease;
}
.cap-row:hover .cap-body h3{ color:var(--amber-deep); }
.cap-body p{ color:var(--ink-soft); font-size:15.5px; max-width:58ch; line-height:1.6; }
.cap-status{
  font-family:var(--mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase;
  color:var(--ink-soft); white-space:nowrap; text-align:right;
}

@media (max-width: 700px){
  .cap-row{ grid-template-columns:40px 1fr; }
  .cap-status{ grid-column:2; text-align:left; margin-top:6px; }
}

/* ============================================================
   PROCESS
   ============================================================ */
.process-rail{
  margin-top:56px; display:flex; flex-direction:column;
  border-top:1px solid var(--green-line);
}
.process-step{
  display:grid; grid-template-columns:280px 1fr;
  gap:40px; padding:36px 0; border-bottom:1px solid var(--green-line);
  cursor:default; transition:background var(--med) ease, padding var(--med) var(--ease);
}
.process-step:hover, .process-step.is-active{
  padding-left:18px; background:rgba(233,162,60,0.04);
}
.process-head{ display:flex; align-items:baseline; gap:16px; }
.process-no{
  font-family:var(--mono); font-size:13px; letter-spacing:.12em; color:var(--bone-soft);
  transition:color var(--fast) ease;
}
.process-step:hover .process-no, .process-step.is-active .process-no{ color:var(--amber); }
.process-head h3{
  font-family:var(--display); font-weight:800; font-size:clamp(26px,3vw,38px);
  letter-spacing:-0.025em;
  position:relative;
}
.process-head h3::after{
  content:""; position:absolute; left:0; bottom:-6px; height:2px; width:0;
  background:var(--amber); transition:width var(--med) var(--ease);
}
.process-step:hover .process-head h3::after,
.process-step.is-active .process-head h3::after{ width:100%; }
.process-step p{ color:var(--bone-soft); font-size:15.5px; line-height:1.65; max-width:62ch; align-self:center; }

@media (max-width: 760px){
  .process-step{ grid-template-columns:1fr; gap:14px; }
}

/* ============================================================
   STUDIO
   ============================================================ */
.studio-grid{
  display:grid; grid-template-columns:0.9fr 1.4fr; gap:clamp(40px,6vw,90px);
}
.studio-intro{ display:flex; flex-direction:column; gap:18px; align-items:flex-start; }
.studio-intro .spec-title{ max-width:8ch; }
.studio-lead{
  font-family:var(--display); font-weight:600; font-size:clamp(20px,2.6vw,27px);
  letter-spacing:-0.015em; line-height:1.45; color:var(--ink); margin-bottom:8px;
}
.studio-copy p{ color:var(--ink-soft); font-size:16.5px; line-height:1.7; max-width:64ch; margin-bottom:22px; }
.studio-copy p:last-of-type{ margin-bottom:0; }

@media (max-width: 880px){
  .studio-grid{ grid-template-columns:1fr; gap:32px; }
}

/* ============================================================
   FINAL CTA
   ============================================================ */
.cta{
  position:relative; overflow:hidden;
  background:var(--green-deep); color:var(--bone);
  padding:clamp(110px,16vw,200px) 0;
  text-align:center;
  border-top:1px solid var(--green-line);
}
.cta-mark{
  position:absolute; left:50%; top:50%; transform:translate(-50%,-50%);
  width:min(70vw, 820px); opacity:.05; pointer-events:none;
}
.cta-inner{ position:relative; z-index:1; display:flex; flex-direction:column; align-items:center; }
.cta .eyebrow{ color:var(--amber); }
.cta-headline{
  font-family:var(--display); font-weight:800;
  font-size:clamp(34px,6vw,72px); letter-spacing:-0.03em; line-height:1.08;
  max-width:20ch;
}
.cta-headline .accent{ color:var(--amber); }
.cta-sub{
  margin-top:26px; max-width:52ch; color:var(--bone-soft);
  font-size:clamp(16px,1.7vw,18.5px); line-height:1.6;
}
.cta-actions{ margin-top:42px; display:flex; gap:16px; flex-wrap:wrap; justify-content:center; }
.cta .btn-ghost{ box-shadow:inset 0 0 0 1.5px var(--bone-soft); }
.cta .btn-ghost:hover{ box-shadow:inset 0 0 0 1.5px var(--amber); }

/* ---- Enquiry form (Supabase-ready; see js/main.js submitEnquiry) ---- */
.cta-form{ width:100%; max-width:660px; margin:46px auto 0; text-align:left; }
.form-row{ display:grid; grid-template-columns:1fr 1fr; gap:18px; margin-bottom:18px; }
.field{ display:flex; flex-direction:column; gap:8px; }
.field label{
  font-family:var(--mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase;
  color:var(--bone-soft);
}
.field input,
.field textarea,
.field select{
  width:100%; font-family:var(--body); font-size:16px; color:var(--bone);
  background:rgba(243,238,227,0.04);
  border:1px solid var(--green-line); border-radius:8px;
  padding:14px 16px;
  transition:border-color var(--fast) ease, background var(--fast) ease, box-shadow var(--fast) ease;
}
.field textarea{ resize:vertical; min-height:120px; line-height:1.55; }
.field input::placeholder,
.field textarea::placeholder{ color:rgba(243,238,227,0.32); }
.field input:focus,
.field textarea:focus,
.field select:focus{
  outline:none; border-color:var(--amber);
  background:rgba(243,238,227,0.06);
  box-shadow:0 0 0 3px rgba(233,162,60,0.16);
}
.field input:invalid:not(:placeholder-shown),
.field textarea:invalid:not(:placeholder-shown){ border-color:var(--amber-deep); }
.select-wrap{ position:relative; }
.select-wrap::after{
  content:""; position:absolute; right:16px; top:50%; width:9px; height:9px;
  border-right:2px solid var(--bone-soft); border-bottom:2px solid var(--bone-soft);
  transform:translateY(-70%) rotate(45deg); pointer-events:none;
}
.field select{ appearance:none; -webkit-appearance:none; cursor:pointer; padding-right:40px; }
.field select option{ color:var(--ink); }

.form-foot{ display:flex; align-items:center; gap:18px 26px; flex-wrap:wrap; margin-top:26px; }
.form-foot .btn{ display:inline-flex; align-items:center; gap:10px; }
.form-note{ font-size:13.5px; color:var(--bone-soft); max-width:34ch; line-height:1.5; }
.form-note a{ color:var(--bone); text-decoration:underline; text-underline-offset:3px; }
.form-note a:hover{ color:var(--amber); }
.form-error{ margin-top:16px; color:var(--amber); font-size:14px; }
.cta-form.is-sending [data-submit]{ opacity:.65; pointer-events:none; }

/* success state */
.cta-success{
  width:100%; max-width:560px; margin:46px auto 0; text-align:center;
  display:flex; flex-direction:column; align-items:center; gap:16px;
  opacity:0; transform:translateY(14px);
  transition:opacity .6s var(--ease), transform .6s var(--ease);
}
.cta-success.is-in{ opacity:1; transform:translateY(0); }
.cta-success-mark{
  width:54px; height:54px; border-radius:50%; display:grid; place-items:center;
  font-size:24px; background:var(--amber); color:var(--green-deep);
}
.cta-success-title{
  font-family:var(--display); font-weight:800; font-size:clamp(24px,3.2vw,34px);
  letter-spacing:-0.02em; color:var(--bone);
}
.cta-success-text{ color:var(--bone-soft); font-size:16px; line-height:1.6; max-width:46ch; }

@media (max-width:600px){
  .form-row{ grid-template-columns:1fr; gap:18px; }
}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{
  background:var(--green-deep); color:var(--bone);
  padding:80px 0 36px;
}
.footer-top{
  display:flex; justify-content:space-between; align-items:flex-end; flex-wrap:wrap; gap:24px;
  padding-bottom:48px; border-bottom:1px solid var(--green-line);
}
.footer-tag{
  font-family:var(--display); font-weight:500; font-size:clamp(18px,2vw,22px);
  letter-spacing:-0.01em; color:var(--bone-soft); max-width:30ch; text-align:right;
}
.footer-cols{
  display:grid; grid-template-columns:repeat(3, minmax(0,1fr));
  gap:32px; padding:48px 0; border-bottom:1px solid var(--green-line);
}
.footer-col{ display:flex; flex-direction:column; gap:13px; }
.footer-col-title{
  font-family:var(--mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase;
  color:var(--amber); margin-bottom:6px;
}
.footer-col a{
  font-family:var(--display); font-size:15.5px; text-decoration:none;
  color:var(--bone-soft); transition:color var(--fast) ease;
  width:fit-content;
}
.footer-col a:hover{ color:var(--bone); }
.footer-bottom{
  display:flex; justify-content:space-between; flex-wrap:wrap; gap:12px;
  padding-top:30px;
  font-family:var(--mono); font-size:11.5px; letter-spacing:.08em; color:var(--bone-soft);
}
.footer-credit{ color:var(--bone-soft); }

@media (max-width: 760px){
  .footer-top{ flex-direction:column; align-items:flex-start; }
  .footer-tag{ text-align:left; }
  .footer-cols{ grid-template-columns:1fr 1fr; }
  /* Stack left-aligned so the wrapped credit line can't run under the
     fixed back-to-top button sitting at the viewport's bottom-right. */
  .footer-bottom{ flex-direction:column; align-items:flex-start; gap:8px; }
}
@media (max-width: 480px){
  .footer-cols{ grid-template-columns:1fr; }
}

/* ============================================================
   BACK TO TOP
   ============================================================ */
.to-top{
  position:fixed; right:24px; bottom:24px; z-index:150;
  width:48px; height:48px; border-radius:50%;
  background:var(--green); color:var(--bone-soft);
  display:grid; place-items:center; font-size:18px;
  box-shadow:0 14px 30px -12px rgba(8,29,26,.45);
  opacity:0; transform:translateY(12px) scale(.9); pointer-events:none;
  transition:opacity var(--fast) ease, transform var(--fast) var(--ease), color var(--fast) ease, background var(--fast) ease;
}
.to-top.is-visible{ opacity:1; transform:translateY(0) scale(1); pointer-events:auto; }
.to-top:hover{ background:var(--amber); color:var(--green-deep); }
