/* =====================================================================
   FrameWorks Limited — Design System
   ---------------------------------------------------------------------
   Tokens, primitives, and components for the production multi-page site.
   ===================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,300;9..144,400;9..144,500;9..144,600&family=Inter:wght@400;500;600;700&display=swap');

/* ---------- Tokens ---------- */
:root{
  /* Color */
  --bg:            #0b0c0d;
  --bg-2:          #0f1011;
  --bg-3:          #131517;
  --panel:         #161a1d;
  --panel-2:       #1c2024;
  --ivory:         #f7f5ef;
  --ivory-2:       #efece3;
  --text:          #f7f5ef;
  --text-on-light: #14161a;
  --muted:         #a8a89f;
  --soft:          #d8d5cc;
  --gold:          #c5a160;
  --gold-2:        #e1c37d;
  --gold-deep:     #9c783e;
  --line:          rgba(255,255,255,.10);
  --line-strong:   rgba(255,255,255,.18);
  --line-gold:     rgba(197,161,96,.42);
  --line-on-light: rgba(20,22,26,.12);

  /* Spacing scale (4-pt base, 8-pt rhythm) */
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 24px;
  --space-6: 32px;
  --space-7: 48px;
  --space-8: 64px;
  --space-9: 96px;
  --space-10: 128px;

  /* Section rhythm */
  --section-y: clamp(80px, 11vw, 150px);
  --section-x: clamp(20px, 6vw, 96px);
  --container: 1320px;
  --container-narrow: 980px;

  /* Radius */
  --r-1: 2px;
  --r-2: 4px;
  --r-3: 8px;
  --r-4: 14px;
  --r-pill: 999px;

  /* Shadows */
  --shadow-sm: 0 4px 14px rgba(0,0,0,.25);
  --shadow-md: 0 16px 40px rgba(0,0,0,.35);
  --shadow-lg: 0 30px 90px rgba(0,0,0,.50);

  /* Type */
  --font-display: 'Fraunces', 'Times New Roman', serif;
  --font-sans:    'Inter', -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;

  /* Motion */
  --ease-out: cubic-bezier(.2,.7,.2,1);
  --ease-in-out: cubic-bezier(.65,0,.35,1);
  --t-fast: .18s;
  --t-base: .28s;
  --t-slow: .55s;
  --t-reveal: .8s;

  /* Z layers */
  --z-noise: 5;
  --z-header: 50;
  --z-overlay: 60;
}

/* ---------- Reset / Base ---------- */
*{box-sizing:border-box}
html{scroll-behavior:smooth; -webkit-text-size-adjust:100%}
body{
  margin:0;
  background:
    radial-gradient(ellipse at 18% -8%, rgba(197,161,96,.10), transparent 36%),
    radial-gradient(ellipse at 82% 8%, rgba(255,255,255,.05), transparent 30%),
    var(--bg);
  color:var(--text);
  font-family:var(--font-sans);
  font-size:16px;
  line-height:1.55;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
a{color:inherit; text-decoration:none}
img,svg,video{max-width:100%; display:block}
button{font:inherit; cursor:pointer}
:focus{outline:none}
:focus-visible{
  outline:2px solid var(--gold-2);
  outline-offset:3px;
  border-radius:2px;
}

/* Skip link */
.skip-link{
  position:absolute; left:-9999px; top:8px;
  background:var(--ivory); color:var(--text-on-light);
  padding:10px 14px; z-index:200; font-weight:600;
}
.skip-link:focus{left:8px}

/* Decorative noise (does not eat clicks) */
.noise{
  position:fixed; inset:0;
  opacity:.06; pointer-events:none; z-index:var(--z-noise);
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='.7'/%3E%3C/svg%3E");
  mix-blend-mode:overlay;
}

/* ---------- Type scale ---------- */
h1,h2,h3,h4,h5,p{margin:0}
h1,h2,h3,h4{
  font-family:var(--font-display);
  font-weight:400;
  letter-spacing:-.02em;
  color:var(--text);
}
h1{ font-size:clamp(48px, 7.4vw, 112px); line-height:.96; letter-spacing:-.035em; }
h2{ font-size:clamp(34px, 4.4vw, 68px); line-height:1.02; letter-spacing:-.028em; }
h3{ font-size:clamp(22px, 1.8vw, 28px); line-height:1.18; letter-spacing:-.012em; }
h4{ font-size:clamp(18px, 1.2vw, 21px); line-height:1.25; }

.eyebrow{
  font-family:var(--font-sans);
  color:var(--gold-2);
  text-transform:uppercase;
  letter-spacing:.24em;
  font-size:11.5px;
  font-weight:600;
  margin:0 0 var(--space-5);
  display:inline-block;
}
.eyebrow.with-rule:before{
  content:""; display:inline-block;
  width:32px; height:1px; background:var(--gold);
  vertical-align:middle; margin-right:14px; opacity:.7;
}

.lede{
  font-family:var(--font-sans);
  color:var(--soft);
  font-size:clamp(17px, 1.4vw, 22px);
  line-height:1.55;
  max-width:62ch;
}

p{font-family:var(--font-sans)}

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

/* ---------- Layout primitives ---------- */
.container{
  max-width:var(--container);
  margin-inline:auto;
  padding-inline:var(--section-x);
  width:100%;
}
.container-narrow{
  max-width:var(--container-narrow);
  margin-inline:auto;
  padding-inline:var(--section-x);
  width:100%;
}
.section{ padding-block:var(--section-y); }
.section--tight{ padding-block:calc(var(--section-y) * .65); }
.section--flush-top{ padding-top:0; }
.section--flush-bottom{ padding-bottom:0; }
.section-heading{ max-width:780px; margin-bottom:var(--space-7); }
.section-heading p:not(.eyebrow){ color:var(--muted); font-size:18px; max-width:62ch; }

.divider{
  height:1px;
  background:linear-gradient(90deg, transparent, var(--line-strong), transparent);
  border:0; margin:0;
}

/* ---------- Header / Nav ---------- */
.site-header{
  position:fixed; top:0; left:0; right:0;
  z-index:var(--z-header);
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:18px clamp(20px, 4vw, 64px);
  background:linear-gradient(to bottom, rgba(11,12,13,.85), rgba(11,12,13,.4) 60%, transparent);
  transition:background var(--t-base) var(--ease-out), border-color var(--t-base) var(--ease-out);
  border-bottom:1px solid transparent;
}
.site-header.is-scrolled{
  background:rgba(11,12,13,.86);
  backdrop-filter:blur(18px);
  -webkit-backdrop-filter:blur(18px);
  border-bottom-color:var(--line);
}
.brand{
  display:inline-flex; align-items:center; gap:10px;
}
.brand img{ width:218px; height:auto; }
.nav{
  display:flex; align-items:center; gap:28px;
  font-size:13px; color:var(--soft);
}
.nav a{
  position:relative;
  opacity:.78;
  transition:opacity var(--t-fast) var(--ease-out), color var(--t-fast) var(--ease-out);
  padding:6px 2px;
}
.nav a:hover{ opacity:1; color:var(--gold-2); }
.nav a[aria-current="page"]{
  opacity:1; color:var(--gold-2);
}
.nav a[aria-current="page"]:after{
  content:""; position:absolute; left:2px; right:2px; bottom:-2px;
  height:1px; background:var(--gold);
}
.nav-cta{
  border:1px solid var(--line-gold);
  color:var(--gold-2)!important;
  padding:10px 18px;
  opacity:1!important;
  transition:background var(--t-fast) var(--ease-out), color var(--t-fast) var(--ease-out), border-color var(--t-fast) var(--ease-out);
}
.nav-cta:hover{
  background:var(--gold);
  border-color:var(--gold);
  color:#0b0c0d!important;
}
.nav-cta:after{ display:none!important; }
.nav-toggle{
  display:none;
  background:transparent;
  border:1px solid var(--line);
  padding:10px 11px;
  border-radius:var(--r-2);
}
.nav-toggle span{
  display:block; width:20px; height:1.5px; background:var(--text);
  margin:4px 0; transition:transform var(--t-fast) var(--ease-out), opacity var(--t-fast) var(--ease-out);
}
.nav-toggle[aria-expanded="true"] span:nth-child(1){ transform:translateY(5.5px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.nav-toggle[aria-expanded="true"] span:nth-child(3){ transform:translateY(-5.5px) rotate(-45deg); }

/* ---------- Buttons ---------- */
.button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  min-height:48px;
  padding:0 22px;
  border:1px solid var(--line-strong);
  background:transparent;
  color:var(--text);
  font-weight:600;
  font-size:14px;
  letter-spacing:.01em;
  border-radius:var(--r-2);
  transition:transform var(--t-fast) var(--ease-out), background var(--t-fast) var(--ease-out), border-color var(--t-fast) var(--ease-out), color var(--t-fast) var(--ease-out);
}
.button .arrow{ display:inline-block; transition:transform var(--t-fast) var(--ease-out); }
.button:hover .arrow{ transform:translateX(4px); }

.button.primary{
  background:var(--gold);
  border-color:var(--gold);
  color:#0a0a0a;
}
.button.primary:hover{ background:var(--gold-2); border-color:var(--gold-2); transform:translateY(-2px); }

.button.ghost{
  background:transparent;
  border-color:var(--line-strong);
  color:var(--text);
}
.button.ghost:hover{ border-color:var(--gold); color:var(--gold-2); transform:translateY(-2px); }

.button.invert{
  background:var(--ivory);
  border-color:var(--ivory);
  color:var(--text-on-light);
}
.button.invert:hover{ background:#fff; border-color:#fff; transform:translateY(-2px); }

.button.lg{ min-height:54px; padding:0 26px; font-size:15px; }

/* ---------- Hero (cinematic, image-bg) ---------- */
.hero{
  position:relative;
  min-height:100vh;
  padding:160px var(--section-x) 96px;
  display:grid;
  align-items:center;
  isolation:isolate;
  overflow:hidden;
}
.hero-media{
  position:absolute; inset:0; z-index:-2;
  background-size:cover; background-position:center;
  filter:saturate(.92);
}
.hero-media:after{
  content:""; position:absolute; inset:0;
  background:
    linear-gradient(180deg, rgba(11,12,13,.55) 0%, rgba(11,12,13,.35) 35%, rgba(11,12,13,.85) 90%, var(--bg) 100%),
    linear-gradient(90deg, rgba(11,12,13,.85) 0%, rgba(11,12,13,.45) 50%, rgba(11,12,13,.6) 100%);
  z-index:1;
}
.hero-vignette{
  position:absolute; inset:0; z-index:-1; pointer-events:none;
  background:radial-gradient(ellipse at 30% 50%, transparent 30%, rgba(11,12,13,.55) 100%);
}
.hero-grid{
  display:grid;
  grid-template-columns:minmax(0, 1.1fr) minmax(320px, .55fr);
  gap:clamp(32px, 5vw, 80px);
  align-items:center;
  max-width:var(--container);
  margin:0 auto;
  width:100%;
}
.hero-copy h1{ max-width:14ch; margin-bottom:28px; }
.hero-copy h1 em{
  font-style:italic;
  font-weight:400;
  color:var(--gold-2);
  background:linear-gradient(180deg, var(--gold-2), var(--gold));
  -webkit-background-clip:text; background-clip:text;
  -webkit-text-fill-color:transparent;
}
.hero-actions{ display:flex; gap:14px; flex-wrap:wrap; margin-top:36px; }
.hero-meta{
  margin-top:54px;
  display:flex; gap:36px; flex-wrap:wrap;
  color:var(--muted);
  font-size:13px;
  letter-spacing:.06em;
}
.hero-meta strong{ display:block; color:var(--text); font-size:24px; font-weight:500; font-family:var(--font-display); margin-bottom:4px; }

/* ---------- Hero side panel (Execution Relay) ---------- */
.hero-panel{
  border:1px solid var(--line);
  background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.018));
  box-shadow:var(--shadow-lg);
  padding:28px;
  backdrop-filter:blur(22px);
  -webkit-backdrop-filter:blur(22px);
  border-radius:var(--r-3);
}
.panel-top{
  display:flex; align-items:center; justify-content:space-between; gap:16px;
  color:var(--gold-2); text-transform:uppercase; letter-spacing:.18em;
  font-size:11px; font-weight:600; margin-bottom:24px;
}
.panel-top img{ width:46px; height:auto; }
.relay-map{ display:grid; gap:8px; }
.relay-map div{
  display:flex; align-items:center; justify-content:space-between;
  border:1px solid rgba(255,255,255,.08);
  padding:14px 16px;
  background:rgba(0,0,0,.22);
  border-radius:var(--r-2);
  transition:border-color var(--t-fast) var(--ease-out), background var(--t-fast) var(--ease-out);
}
.relay-map div:hover{ border-color:var(--line-gold); background:rgba(0,0,0,.34); }
.relay-map strong{ color:var(--gold-2); font-weight:500; letter-spacing:.18em; font-size:11px; }
.relay-map span{ color:var(--soft); font-size:13px; letter-spacing:.04em; }
.hero-panel > p{ color:var(--muted); margin-top:22px; font-size:14px; line-height:1.55; }

/* ---------- Marquee ---------- */
.intro-band{
  border-block:1px solid var(--line);
  background:#0d0e10;
  overflow:hidden;
  position:relative;
}
.intro-band:before, .intro-band:after{
  content:""; position:absolute; top:0; bottom:0; width:120px; z-index:2; pointer-events:none;
}
.intro-band:before{ left:0; background:linear-gradient(90deg, #0d0e10, transparent); }
.intro-band:after{ right:0; background:linear-gradient(-90deg, #0d0e10, transparent); }
.marquee{
  display:flex; gap:48px; white-space:nowrap;
  padding:18px 0;
  width:max-content;
  animation:marquee 38s linear infinite;
}
.marquee span{
  color:var(--muted); text-transform:uppercase;
  letter-spacing:.22em; font-size:11.5px; font-weight:500;
}
.marquee span:before{
  content:"·"; color:var(--gold); margin-right:48px;
}
@keyframes marquee{ to{ transform:translateX(-50%); } }

/* ---------- Service cards ---------- */
.service-grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:18px;
}
.service-card{
  position:relative;
  min-height:420px;
  padding:30px;
  background:linear-gradient(180deg, rgba(255,255,255,.055), rgba(255,255,255,.018));
  border:1px solid var(--line);
  border-radius:var(--r-3);
  display:flex; flex-direction:column;
  overflow:hidden;
  transition:transform var(--t-base) var(--ease-out), border-color var(--t-base) var(--ease-out), background var(--t-base) var(--ease-out);
}
.service-card:hover{ transform:translateY(-4px); border-color:var(--line-gold); }
.service-card:after{
  content:""; position:absolute; left:0; right:0; bottom:0; height:1px;
  background:linear-gradient(90deg, transparent, var(--gold), transparent); opacity:.8;
}
.card-index{
  color:var(--gold-2); font-size:11.5px; letter-spacing:.22em;
  font-weight:600; text-transform:uppercase;
}
.service-card h3{ margin-top:auto; margin-bottom:14px; padding-top:90px; }
.service-card p, .service-card li{ color:var(--muted); font-size:14.5px; line-height:1.6; }
.service-card ul{ list-style:none; padding:0; margin:18px 0 0; border-top:1px solid var(--line); padding-top:16px; }
.service-card li{ display:flex; gap:10px; margin-bottom:8px; }
.service-card li:before{ content:"—"; color:var(--gold); }

/* ---------- Process panel ---------- */
.dark-panel{
  background:linear-gradient(180deg, rgba(197,161,96,.04), transparent), #0e1012;
  border-block:1px solid var(--line);
}
.process-grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:1px;
  background:var(--line);
  border:1px solid var(--line);
  border-radius:var(--r-3);
  overflow:hidden;
}
.process-step{
  background:#111315;
  padding:34px;
  min-height:300px;
  display:flex; flex-direction:column;
}
.process-step span{
  color:var(--gold-2); letter-spacing:.22em; font-size:11.5px;
  font-weight:600; text-transform:uppercase;
}
.process-step h3{ margin-top:auto; padding-top:64px; margin-bottom:14px; }
.process-step p{ color:var(--muted); font-size:14.5px; }

/* ---------- Case / Use case grid ---------- */
.case-layout{
  display:grid;
  grid-template-columns:1.2fr .8fr;
  gap:18px;
}
.case-card{
  position:relative;
  background:#f3f0e8;
  color:var(--text-on-light);
  padding:36px;
  min-height:280px;
  display:flex; flex-direction:column; justify-content:flex-end;
  border-radius:var(--r-3);
  overflow:hidden;
  isolation:isolate;
  transition:transform var(--t-base) var(--ease-out);
}
.case-card:hover{ transform:translateY(-3px); }
.case-card.large{
  min-height:560px;
  grid-row:span 2;
  color:var(--text);
  background:#0e0f10;
}
.case-card-media{
  position:absolute; inset:0; z-index:-1;
  background-size:cover; background-position:center;
}
.case-card-media:after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(11,12,13,.15) 0%, rgba(11,12,13,.7) 70%, rgba(11,12,13,.92) 100%);
}
.case-type{
  color:var(--gold); text-transform:uppercase; letter-spacing:.22em;
  font-size:11.5px; font-weight:600; margin-bottom:10px;
}
.case-card.large .case-type{ color:var(--gold-2); }
.case-card h3{ color:inherit; margin-bottom:12px; max-width:32ch; }
.case-card p{ font-size:15px; line-height:1.6; max-width:54ch; }
.case-card.large p{ color:var(--soft); }

/* ---------- Plans / engagements ---------- */
.plan-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:18px;
}
.plan{
  position:relative;
  padding:36px;
  border:1px solid var(--line);
  background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.01));
  border-radius:var(--r-3);
  display:flex; flex-direction:column;
  min-height:430px;
  transition:transform var(--t-base) var(--ease-out), border-color var(--t-base) var(--ease-out);
}
.plan:hover{ transform:translateY(-3px); border-color:var(--line-gold); }
.plan.featured{
  background:linear-gradient(180deg, rgba(197,161,96,.14), rgba(197,161,96,.02));
  border-color:var(--line-gold);
}
.badge{
  position:absolute; top:18px; right:18px;
  color:#0b0c0d; background:var(--gold);
  padding:6px 10px; font-size:10.5px; font-weight:700;
  letter-spacing:.18em; text-transform:uppercase;
  border-radius:var(--r-1);
}
.price{
  color:var(--gold-2); font-size:12.5px; letter-spacing:.22em;
  text-transform:uppercase; font-weight:600; margin-bottom:18px;
}
.plan h3{ margin-bottom:10px; }
.plan > p{ color:var(--muted); font-size:14.5px; }
.plan ul{ list-style:none; padding:0; margin-top:auto; padding-top:24px; border-top:1px solid var(--line); }
.plan li{ color:var(--soft); font-size:14px; padding:8px 0; display:flex; gap:12px; }
.plan li:before{ content:"—"; color:var(--gold); }

/* ---------- Proof / Quote ---------- */
.proof-inner{
  max-width:1000px;
  margin:auto;
  text-align:center;
  border:1px solid var(--line);
  background:linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.012));
  padding:64px clamp(24px, 6vw, 82px);
  border-radius:var(--r-3);
}
.proof-inner img{ width:60px; margin:0 auto 26px; opacity:.95; }
blockquote{
  margin:0;
  font-family:var(--font-display);
  font-size:clamp(26px, 3.4vw, 46px);
  line-height:1.12;
  letter-spacing:-.02em;
  font-weight:400;
}
blockquote cite{
  display:block;
  margin-top:28px;
  color:var(--muted);
  font-size:12.5px;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-style:normal;
  font-family:var(--font-sans);
  font-weight:600;
}

/* ---------- Contact ---------- */
.contact-card{
  max-width:var(--container);
  margin:auto;
  display:grid;
  grid-template-columns:1fr .9fr;
  gap:48px;
  padding:clamp(28px, 4vw, 56px);
  background:var(--ivory);
  color:var(--text-on-light);
  border-radius:var(--r-3);
}
.contact-card .eyebrow{ color:var(--gold-deep); }
.contact-card h2{ color:var(--text-on-light); }
.contact-card p{ color:#4f4e4a; }
.contact-form{ display:grid; gap:16px; }
.contact-form label{
  display:grid; gap:8px;
  font-weight:600; font-size:12.5px;
  letter-spacing:.06em; text-transform:uppercase;
  color:var(--text-on-light);
}
.contact-form input, .contact-form textarea, .contact-form select{
  width:100%;
  border:1px solid var(--line-on-light);
  background:#fff;
  padding:14px 16px;
  font:inherit;
  font-size:15px;
  border-radius:var(--r-2);
  color:var(--text-on-light);
  transition:border-color var(--t-fast) var(--ease-out), box-shadow var(--t-fast) var(--ease-out);
}
.contact-form input:focus, .contact-form textarea:focus, .contact-form select:focus{
  border-color:var(--gold);
  box-shadow:0 0 0 3px rgba(197,161,96,.18);
  outline:none;
}
.contact-form textarea{ resize:vertical; min-height:140px; }
.contact-form input[aria-invalid="true"], .contact-form textarea[aria-invalid="true"], .contact-form select[aria-invalid="true"]{
  border-color:#a23b3b; box-shadow:0 0 0 3px rgba(162,59,59,.15);
}
.field-error{
  color:#a23b3b; font-size:12px; font-weight:500; letter-spacing:0; text-transform:none;
  min-height:14px;
}
.form-note{ font-size:12px; color:#7a7a72; margin:0; }
.form-status{
  margin-top:8px; padding:14px 16px; border-radius:var(--r-2);
  font-size:14px; display:none;
}
.form-status.is-success{ display:block; background:#eef3e9; color:#2e4a25; border:1px solid #b9cea7; }
.form-status.is-error{ display:block; background:#f8e8e6; color:#6e2625; border:1px solid #d8a6a3; }

/* ---------- Footer ---------- */
.footer{
  border-top:1px solid var(--line);
  padding:72px var(--section-x) 32px;
  background:#0a0b0c;
}
.footer-inner{
  max-width:var(--container);
  margin:auto;
  display:grid;
  grid-template-columns:1.4fr 1fr 1fr 1fr;
  gap:48px;
}
.footer-brand img{ width:220px; margin-bottom:18px; }
.footer-brand p{ color:var(--muted); font-size:14px; max-width:38ch; }
.footer-col h5{
  text-transform:uppercase; letter-spacing:.22em;
  font-size:11px; color:var(--gold-2); font-weight:600;
  font-family:var(--font-sans);
  margin-bottom:18px;
}
.footer-col ul{ list-style:none; padding:0; margin:0; display:grid; gap:10px; }
.footer-col a{
  color:var(--soft); font-size:14px; opacity:.85;
  transition:color var(--t-fast) var(--ease-out), opacity var(--t-fast) var(--ease-out);
}
.footer-col a:hover{ color:var(--gold-2); opacity:1; }
.footer-base{
  max-width:var(--container);
  margin:48px auto 0;
  padding-top:24px;
  border-top:1px solid var(--line);
  display:flex; justify-content:space-between; align-items:center; gap:18px; flex-wrap:wrap;
  color:var(--muted); font-size:12.5px;
}

/* ---------- Reveal motion ---------- */
.reveal{
  opacity:0;
  transform:translateY(20px);
  transition:opacity var(--t-reveal) var(--ease-out), transform var(--t-reveal) var(--ease-out);
  will-change:opacity, transform;
}
.reveal.is-visible{ opacity:1; transform:none; }
.delay-1{ transition-delay:.08s; }
.delay-2{ transition-delay:.16s; }
.delay-3{ transition-delay:.24s; }
.delay-4{ transition-delay:.32s; }
.delay-5{ transition-delay:.4s; }

@media (prefers-reduced-motion: reduce){
  *, *:before, *:after{
    animation-duration:.001ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.001ms !important;
    scroll-behavior:auto !important;
  }
  .reveal{ opacity:1; transform:none; }
  .marquee{ animation:none; }
}

/* ===================================================================
   Page: Services — extra patterns
   =================================================================== */
.page-hero{
  position:relative;
  padding:170px var(--section-x) 96px;
  isolation:isolate;
  overflow:hidden;
  border-bottom:1px solid var(--line);
}
.page-hero-media{
  position:absolute; inset:0; z-index:-2;
  background-size:cover; background-position:center;
  filter:saturate(.95) brightness(.85);
}
.page-hero-media:after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(11,12,13,.7) 0%, rgba(11,12,13,.55) 30%, var(--bg) 100%);
}
.page-hero-inner{
  max-width:var(--container); margin:auto;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:48px;
  align-items:end;
}
.page-hero h1{
  font-size:clamp(44px, 6.4vw, 96px);
  line-height:1;
}
.page-hero .lede{ color:var(--soft); }

/* Service detail rows */
.service-row{
  display:grid;
  grid-template-columns:1fr 1.2fr;
  gap:64px;
  padding-block:var(--space-9);
  border-bottom:1px solid var(--line);
  align-items:start;
}
.service-row:last-child{ border-bottom:0; }
.service-row .stamp{
  font-family:var(--font-display);
  font-size:clamp(80px, 9vw, 140px);
  line-height:.9;
  color:transparent;
  -webkit-text-stroke:1px var(--line-gold);
  letter-spacing:-.02em;
}
.service-row h2{ font-size:clamp(32px, 3.4vw, 48px); margin-bottom:14px; }
.service-row .sub{ color:var(--muted); margin-bottom:24px; }
.feature-list{
  list-style:none; padding:0; margin:0;
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:14px 24px;
}
.feature-list li{
  color:var(--soft);
  font-size:14.5px;
  padding:14px 0 14px 22px;
  border-top:1px solid var(--line);
  position:relative;
}
.feature-list li:before{
  content:""; position:absolute; left:0; top:20px;
  width:8px; height:1px; background:var(--gold);
}
.service-meta{
  display:flex; gap:24px; flex-wrap:wrap;
  margin-top:32px;
  color:var(--muted);
  font-size:13px;
  letter-spacing:.04em;
}
.service-meta span strong{
  display:block; color:var(--gold-2);
  font-family:var(--font-display); font-size:22px; font-weight:400;
  margin-bottom:2px;
}

/* FAQ */
.faq{
  display:grid;
  gap:0;
  border-top:1px solid var(--line);
}
.faq details{
  border-bottom:1px solid var(--line);
  padding:24px 0;
  transition:padding var(--t-base) var(--ease-out);
}
.faq summary{
  list-style:none;
  cursor:pointer;
  display:flex; justify-content:space-between; align-items:center;
  font-family:var(--font-display);
  font-size:clamp(20px, 1.8vw, 26px);
  letter-spacing:-.01em;
  gap:24px;
}
.faq summary::-webkit-details-marker{ display:none; }
.faq summary:after{
  content:"+"; color:var(--gold-2);
  font-family:var(--font-sans); font-size:24px;
  transition:transform var(--t-base) var(--ease-out);
}
.faq details[open] summary:after{ content:"−"; }
.faq details > p{
  margin-top:14px;
  color:var(--muted);
  max-width:72ch;
  font-size:15.5px;
  line-height:1.65;
}

/* ===================================================================
   Page: Process — timeline & principles
   =================================================================== */
.process-timeline{
  display:grid;
  gap:0;
  position:relative;
  margin-top:32px;
}
.process-timeline:before{
  content:""; position:absolute; left:34px; top:24px; bottom:24px;
  width:1px; background:linear-gradient(180deg, var(--gold), transparent 70%);
  opacity:.7;
}
.timeline-step{
  display:grid;
  grid-template-columns:80px 1fr 1fr;
  gap:32px;
  padding-block:36px;
  border-bottom:1px solid var(--line);
  align-items:start;
}
.timeline-step:last-child{ border-bottom:0; }
.timeline-step .num{
  position:relative;
  width:68px; height:68px;
  display:grid; place-items:center;
  background:#0e1012;
  border:1px solid var(--line-gold);
  color:var(--gold-2);
  font-family:var(--font-display);
  font-size:22px;
  border-radius:50%;
  z-index:1;
}
.timeline-step h3{
  font-size:clamp(22px, 2.2vw, 30px);
  margin-bottom:10px;
}
.timeline-step .step-meta{
  color:var(--muted);
  font-size:13px; letter-spacing:.16em; text-transform:uppercase;
  margin-bottom:6px;
}
.timeline-step p{ color:var(--soft); font-size:15px; line-height:1.65; max-width:60ch; }
.timeline-step ul{
  list-style:none; padding:0; margin:0;
  display:grid; gap:8px;
}
.timeline-step li{
  color:var(--muted); font-size:14px; padding-left:16px; position:relative;
}
.timeline-step li:before{
  content:""; position:absolute; left:0; top:10px;
  width:6px; height:1px; background:var(--gold);
}

/* Principles grid */
.principle-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:18px;
}
.principle{
  border:1px solid var(--line);
  background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.012));
  padding:28px;
  border-radius:var(--r-3);
  min-height:220px;
  display:flex; flex-direction:column;
}
.principle h4{
  font-family:var(--font-display);
  font-size:22px; font-weight:400;
  margin-bottom:12px;
}
.principle p{ color:var(--muted); font-size:14.5px; line-height:1.6; }
.principle .num{
  color:var(--gold-2); font-size:11px;
  letter-spacing:.22em; text-transform:uppercase; font-weight:600;
  margin-bottom:auto;
}

/* ===================================================================
   Page: Work — case study showcase
   =================================================================== */
.work-grid{
  display:grid;
  grid-template-columns:repeat(6, 1fr);
  gap:18px;
}
.work-item{
  position:relative;
  border-radius:var(--r-3);
  overflow:hidden;
  isolation:isolate;
  background:#0e0f10;
  min-height:380px;
  display:flex; flex-direction:column; justify-content:flex-end;
  padding:28px;
  transition:transform var(--t-base) var(--ease-out);
  border:1px solid var(--line);
}
.work-item:hover{ transform:translateY(-4px); }
.work-item.span-4{ grid-column:span 4; min-height:520px; }
.work-item.span-3{ grid-column:span 3; min-height:460px; }
.work-item.span-2{ grid-column:span 2; min-height:380px; }
.work-item-media{
  position:absolute; inset:0; z-index:-1;
  background-size:cover; background-position:center;
  transition:transform var(--t-slow) var(--ease-out);
}
.work-item:hover .work-item-media{ transform:scale(1.03); }
.work-item-media:after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(11,12,13,.1) 0%, rgba(11,12,13,.7) 65%, rgba(11,12,13,.92) 100%);
}
.work-item .case-type{ color:var(--gold-2); }
.work-item h3{ color:var(--text); margin-bottom:12px; max-width:24ch; }
.work-item p{ color:var(--soft); font-size:14.5px; line-height:1.55; max-width:50ch; }
.work-metrics{
  display:flex; gap:32px; margin-top:18px; flex-wrap:wrap;
  border-top:1px solid var(--line); padding-top:16px;
}
.work-metrics div strong{
  display:block; color:var(--gold-2);
  font-family:var(--font-display); font-size:24px; font-weight:400; margin-bottom:2px;
}
.work-metrics div span{ font-size:11.5px; color:var(--muted); letter-spacing:.18em; text-transform:uppercase; }

/* ===================================================================
   Page: About
   =================================================================== */
.about-hero{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:64px;
  align-items:center;
}
.about-hero-img{
  position:relative;
  border-radius:var(--r-3);
  overflow:hidden;
  border:1px solid var(--line);
  aspect-ratio:4/5;
  background:#0e0f10;
}
.about-hero-img img{
  width:100%; height:100%; object-fit:cover; display:block;
}
.about-hero-img:after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, transparent 30%, rgba(11,12,13,.45));
  pointer-events:none;
}

.stack-grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:18px;
}
.stack-card{
  border:1px solid var(--line);
  background:linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.008));
  padding:24px;
  border-radius:var(--r-3);
}
.stack-card h4{
  font-family:var(--font-sans);
  font-size:11.5px;
  letter-spacing:.22em; text-transform:uppercase;
  color:var(--gold-2);
  margin-bottom:14px;
  font-weight:600;
}
.stack-card ul{ list-style:none; padding:0; margin:0; display:grid; gap:6px; }
.stack-card li{ color:var(--soft); font-size:14px; }

/* ===================================================================
   Page: Journal
   =================================================================== */
.journal-grid{
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:24px;
}
.journal-card{
  background:#0f1113;
  border:1px solid var(--line);
  padding:32px;
  border-radius:var(--r-3);
  display:flex; flex-direction:column;
  min-height:300px;
  transition:border-color var(--t-base) var(--ease-out), transform var(--t-base) var(--ease-out);
}
.journal-card:hover{ border-color:var(--line-gold); transform:translateY(-3px); }
.journal-card .meta{
  color:var(--muted); font-size:11.5px;
  letter-spacing:.22em; text-transform:uppercase;
  display:flex; gap:14px;
}
.journal-card .meta span:first-child{ color:var(--gold-2); }
.journal-card h3{
  margin:18px 0 14px;
  font-size:clamp(24px, 2.4vw, 30px);
}
.journal-card p{ color:var(--muted); font-size:14.5px; line-height:1.6; }
.journal-card .read-more{
  margin-top:auto; padding-top:24px;
  color:var(--gold-2); font-size:13px;
  letter-spacing:.16em; text-transform:uppercase; font-weight:600;
}
.journal-card .read-more .arrow{ transition:transform var(--t-fast) var(--ease-out); display:inline-block; margin-left:6px; }
.journal-card:hover .read-more .arrow{ transform:translateX(4px); }

/* ===================================================================
   CTA bands (used across pages)
   =================================================================== */
.cta-band{
  position:relative;
  padding:clamp(60px, 8vw, 110px) var(--section-x);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  isolation:isolate; overflow:hidden;
}
.cta-band-media{
  position:absolute; inset:0; z-index:-1;
  background-size:cover; background-position:center;
  filter:saturate(.85) brightness(.5);
}
.cta-band-media:after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(90deg, rgba(11,12,13,.8), rgba(11,12,13,.4));
}
.cta-inner{
  max-width:var(--container); margin:auto;
  display:grid; grid-template-columns:1.4fr 1fr;
  gap:48px; align-items:center;
}
.cta-inner h2{ max-width:18ch; }
.cta-actions{ display:flex; gap:14px; flex-wrap:wrap; justify-content:flex-end; }

/* ===================================================================
   Misc utility
   =================================================================== */
.split-2{ display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:start; }
.text-balance{ text-wrap:balance; }
.media-frame{
  border-radius:var(--r-3);
  overflow:hidden;
  border:1px solid var(--line);
  background:#0e0f10;
}
.media-frame img{
  width:100%; height:100%; object-fit:cover; display:block;
}
.tag{
  display:inline-flex; align-items:center;
  padding:6px 12px;
  border:1px solid var(--line-gold);
  color:var(--gold-2);
  border-radius:var(--r-pill);
  font-size:11px; letter-spacing:.18em; text-transform:uppercase;
  font-weight:600;
}

/* ===================================================================
   Responsive
   =================================================================== */
@media (max-width:1100px){
  .hero-grid{ grid-template-columns:1fr; }
  .hero-panel{ max-width:520px; }
  .service-grid, .process-grid, .stack-grid{ grid-template-columns:repeat(2, 1fr); }
  .case-layout{ grid-template-columns:1fr; }
  .case-card.large{ min-height:430px; grid-row:auto; }
  .plan-grid{ grid-template-columns:1fr; }
  .footer-inner{ grid-template-columns:1fr 1fr; gap:36px; }
  .page-hero-inner{ grid-template-columns:1fr; gap:24px; }
  .work-grid{ grid-template-columns:repeat(2, 1fr); }
  .work-item.span-4, .work-item.span-3, .work-item.span-2{ grid-column:span 2; min-height:420px; }
  .about-hero{ grid-template-columns:1fr; gap:32px; }
  .about-hero-img{ aspect-ratio:16/10; max-height:520px; }
  .service-row{ grid-template-columns:1fr; gap:24px; padding-block:var(--space-8); }
  .service-row .stamp{ font-size:80px; }
  .feature-list{ grid-template-columns:1fr; }
  .principle-grid{ grid-template-columns:1fr 1fr; }
  .journal-grid{ grid-template-columns:1fr; }
  .cta-inner{ grid-template-columns:1fr; }
  .cta-actions{ justify-content:flex-start; }
  .timeline-step{ grid-template-columns:60px 1fr; }
  .timeline-step ul{ grid-column:1 / -1; padding-left:92px; }
  .contact-card{ grid-template-columns:1fr; gap:24px; }
}
@media (max-width:760px){
  .brand img{ width:178px; }
  .nav-toggle{ display:block; }
  .nav{
    position:absolute; top:74px; left:14px; right:14px;
    display:none;
    flex-direction:column; align-items:stretch; gap:0;
    padding:14px; background:#101113;
    border:1px solid var(--line);
    border-radius:var(--r-3);
    box-shadow:var(--shadow-lg);
  }
  .nav.is-open{ display:flex; }
  .nav a{ padding:14px 12px; opacity:1; border-bottom:1px solid var(--line); }
  .nav a:last-child{ border-bottom:0; }
  .nav-cta{ margin-top:8px; text-align:center; }
  .hero{ padding:130px 20px 70px; min-height:auto; }
  .hero-meta{ gap:18px; margin-top:36px; }
  .service-grid, .process-grid, .stack-grid, .principle-grid{ grid-template-columns:1fr; }
  .service-card{ min-height:auto; }
  .service-card h3{ padding-top:46px; }
  .process-step{ min-height:auto; padding:24px; }
  .process-step h3{ padding-top:36px; }
  .work-grid{ grid-template-columns:1fr; }
  .work-item, .work-item.span-4, .work-item.span-3, .work-item.span-2{ grid-column:auto; min-height:340px; }
  .footer-inner{ grid-template-columns:1fr; }
  .footer-base{ flex-direction:column; align-items:flex-start; }
  .timeline-step{ grid-template-columns:48px 1fr; gap:16px; padding-block:24px; }
  .timeline-step .num{ width:48px; height:48px; font-size:18px; }
  .timeline-step ul{ padding-left:64px; }
  .process-timeline:before{ left:24px; }
  .split-2{ grid-template-columns:1fr; gap:24px; }
  .case-card{ padding:24px; }
  .plan, .principle, .service-card{ padding:24px; }
}
