/* =========================================================
   FORGEWORTH — premium black & gold landing page
   Design tokens
   ========================================================= */
:root{
  --bg:           #0a0a0b;
  --bg-2:         #0e0e10;
  --panel:        #121214;
  --panel-2:      #16161a;
  --line:         rgba(201,162,75,.16);
  --line-soft:    rgba(255,255,255,.07);

  --ink:          #f4f1ea;
  --ink-dim:      #b8b4ac;
  --ink-faint:    #837f78;

  --gold:         #c9a24b;
  --gold-2:       #e8c66b;
  --gold-3:       #f3dd9a;
  --gold-deep:    #9b7b32;
  --gold-grad:    linear-gradient(135deg,#9b7b32 0%,#e8c66b 38%,#f3dd9a 55%,#c9a24b 100%);

  --serif:        "Cormorant Garamond", Georgia, serif;
  --sans:         "Sora", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;

  --maxw:         1180px;
  --radius:       16px;
  --radius-lg:    22px;
  --ease:         cubic-bezier(.22,1,.36,1);
}

/* =========================================================
   Reset / base
   ========================================================= */
*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  font-family:var(--sans);
  background:var(--bg);
  color:var(--ink);
  line-height:1.65;
  font-weight:300;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
a{ color:inherit; text-decoration:none; }
img{ max-width:100%; display:block; }
button{ font-family:inherit; cursor:pointer; }
::selection{ background:rgba(232,198,107,.28); color:#fff; }

section{ position:relative; }

/* =========================================================
   Texture overlays
   ========================================================= */
.grain{
  position:fixed; inset:0; z-index:2; pointer-events:none; opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  mix-blend-mode:overlay;
}
.cursor-glow{
  position:fixed; top:0; left:0; width:520px; height:520px; z-index:1; pointer-events:none;
  transform:translate(-50%,-50%); border-radius:50%;
  background:radial-gradient(circle, rgba(201,162,75,.10) 0%, rgba(201,162,75,0) 60%);
  opacity:0; transition:opacity .4s ease;
  will-change:transform;
}
@media (hover:hover){ .cursor-glow.on{ opacity:1; } }

/* =========================================================
   Buttons
   ========================================================= */
.btn{
  --pad:.85rem 1.5rem;
  display:inline-flex; align-items:center; justify-content:center; gap:.5rem;
  padding:var(--pad); border-radius:999px; border:1px solid transparent;
  font-family:var(--sans); font-size:.92rem; font-weight:500; letter-spacing:.02em;
  position:relative; transition:transform .35s var(--ease), box-shadow .35s var(--ease), background .35s ease, color .35s ease;
  white-space:nowrap;
}
.btn--lg{ --pad:1.05rem 2rem; font-size:1rem; }
.btn--block{ width:100%; }
.btn--gold{
  background:var(--gold-grad); color:#1a1408; font-weight:600;
  box-shadow:0 8px 30px -10px rgba(201,162,75,.55), inset 0 1px 0 rgba(255,255,255,.35);
}
.btn--gold:hover{ transform:translateY(-2px); box-shadow:0 14px 40px -10px rgba(232,198,107,.7), inset 0 1px 0 rgba(255,255,255,.45); }
.btn--ghost{
  background:rgba(255,255,255,.02); color:var(--ink); border-color:var(--line);
  backdrop-filter:blur(6px);
}
.btn--ghost:hover{ transform:translateY(-2px); border-color:var(--gold); color:var(--gold-3); box-shadow:0 10px 30px -14px rgba(201,162,75,.5); }
.btn__spinner{ width:16px; height:16px; border-radius:50%; border:2px solid rgba(26,20,8,.35); border-top-color:#1a1408; display:none; animation:spin .7s linear infinite; }
.btn.is-loading .btn__label{ opacity:.5; }
.btn.is-loading .btn__spinner{ display:inline-block; }
@keyframes spin{ to{ transform:rotate(360deg); } }

.linkbtn{
  background:none; border:none; color:var(--gold-2); padding:0;
  font:inherit; text-decoration:underline; text-underline-offset:3px; text-decoration-color:rgba(232,198,107,.4);
}
.linkbtn:hover{ color:var(--gold-3); }

/* =========================================================
   Brand / logo
   ========================================================= */
.brand{ display:inline-flex; align-items:center; gap:.6rem; }
.brand__img{ height:120px; width:auto; }
.brand__fallback{ display:none; align-items:center; gap:.6rem; }
.brand__mark{
  display:inline-grid; place-items:center; width:38px; height:38px; border-radius:9px;
  border:1px solid var(--line); background:linear-gradient(160deg,#15130d,#0c0b08);
  font-family:var(--serif); font-weight:700; font-size:1.05rem; letter-spacing:.04em;
  background-clip:padding-box;
  color:transparent; -webkit-background-clip:text; background-image:var(--gold-grad);
  position:relative;
}
.brand__mark::after{
  content:""; position:absolute; inset:0; border-radius:9px; padding:1px;
  background:var(--gold-grad);
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor; mask-composite:exclude; opacity:.5;
}
.brand__word{
  font-family:var(--serif); font-weight:600; font-size:1.5rem; letter-spacing:.02em;
  background:var(--gold-grad); -webkit-background-clip:text; background-clip:text; color:transparent;
}
.brand__mark--sm{ width:32px; height:32px; font-size:.9rem; }
.brand__word--sm{ font-size:1.25rem; }

/* =========================================================
   Navigation
   ========================================================= */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:50;
  transition:background .4s ease, border-color .4s ease, backdrop-filter .4s ease;
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:rgba(10,10,11,.72); backdrop-filter:blur(14px) saturate(120%);
  border-bottom-color:var(--line-soft);
}
.nav__inner{
  max-width:var(--maxw); margin:0 auto; padding:1rem 1.5rem;
  display:flex; align-items:center; justify-content:space-between; gap:1rem;
}
.nav__links{ display:flex; gap:2rem; margin-left:auto; margin-right:1.5rem; }
.nav__links a{
  font-size:.92rem; color:var(--ink-dim); font-weight:400; position:relative; padding:.2rem 0;
  transition:color .3s ease;
}
.nav__links a::after{
  content:""; position:absolute; left:0; bottom:-2px; height:1px; width:0; background:var(--gold-grad); transition:width .35s var(--ease);
}
.nav__links a:hover{ color:var(--ink); }
.nav__links a:hover::after{ width:100%; }
.nav__toggle{ display:none; flex-direction:column; gap:5px; background:none; border:none; padding:6px; }
.nav__toggle span{ width:24px; height:2px; background:var(--gold-2); border-radius:2px; transition:.3s var(--ease); }
.nav__toggle.open span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav__toggle.open span:nth-child(2){ opacity:0; }
.nav__toggle.open span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* =========================================================
   Aurora background (ReactBits-style)
   ========================================================= */
.aurora{ position:absolute; inset:0; overflow:hidden; z-index:0; filter:blur(0); }
.aurora__blob{
  position:absolute; border-radius:50%; filter:blur(80px); opacity:.5; mix-blend-mode:screen;
  will-change:transform;
}
.aurora__blob--1{
  width:60vw; height:60vw; max-width:760px; max-height:760px; top:-18%; left:-10%;
  background:radial-gradient(circle at 30% 30%, rgba(232,198,107,.55), rgba(155,123,50,.10) 60%, transparent 72%);
  animation:drift1 22s ease-in-out infinite alternate;
}
.aurora__blob--2{
  width:46vw; height:46vw; max-width:560px; max-height:560px; top:8%; right:-12%;
  background:radial-gradient(circle at 50% 50%, rgba(201,162,75,.45), rgba(120,90,30,.08) 60%, transparent 72%);
  animation:drift2 26s ease-in-out infinite alternate;
}
.aurora__blob--3{
  width:52vw; height:52vw; max-width:620px; max-height:620px; bottom:-22%; left:24%;
  background:radial-gradient(circle at 50% 50%, rgba(243,221,154,.30), rgba(155,123,50,.06) 58%, transparent 70%);
  animation:drift3 30s ease-in-out infinite alternate;
}
.aurora--soft .aurora__blob{ opacity:.30; }
@keyframes drift1{ from{ transform:translate(0,0) scale(1); } to{ transform:translate(8%,10%) scale(1.15); } }
@keyframes drift2{ from{ transform:translate(0,0) scale(1.05); } to{ transform:translate(-10%,6%) scale(.9); } }
@keyframes drift3{ from{ transform:translate(0,0) scale(1); } to{ transform:translate(-6%,-8%) scale(1.12); } }

/* =========================================================
   Hero
   ========================================================= */
.hero{
  min-height:100svh; display:flex; align-items:center; justify-content:center;
  text-align:center; padding:11rem 1.5rem 5rem; overflow:hidden;
  background:radial-gradient(120% 90% at 50% -10%, #131211 0%, var(--bg) 55%);
}
.hero__grid-lines{
  position:absolute; inset:0; z-index:0; opacity:.4;
  background-image:linear-gradient(rgba(201,162,75,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(201,162,75,.05) 1px,transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(110% 80% at 50% 0%, #000 30%, transparent 75%);
  -webkit-mask-image:radial-gradient(110% 80% at 50% 0%, #000 30%, transparent 75%);
}
.hero__inner{ position:relative; z-index:3; max-width:920px; }
.hero__eyebrow{
  font-size:.8rem; letter-spacing:.32em; text-transform:uppercase; color:var(--gold-2);
  margin-bottom:1.6rem; font-weight:500;
}
.hero__title{
  font-family:var(--serif); font-weight:600; line-height:1.04;
  font-size:clamp(2.6rem,6.4vw,5.1rem); letter-spacing:-.01em; margin-bottom:1.6rem;
}
.hero__sub{
  font-size:clamp(1.02rem,1.6vw,1.22rem); color:var(--ink-dim); font-weight:300;
  max-width:680px; margin:0 auto 2.4rem;
}
.hero__cta{ display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; margin-bottom:1.8rem; }
.hero__trust{ font-size:.86rem; color:var(--ink-faint); letter-spacing:.01em; }
.hero__scroll{
  position:absolute; bottom:26px; left:50%; transform:translateX(-50%); z-index:3;
  width:24px; height:38px; border:1px solid var(--line); border-radius:14px; display:grid; place-items:start center; padding-top:7px;
}
.hero__scroll span{ width:3px; height:7px; border-radius:2px; background:var(--gold-2); animation:scrolldot 1.8s ease-in-out infinite; }
@keyframes scrolldot{ 0%{ opacity:0; transform:translateY(0);} 30%{opacity:1;} 100%{ opacity:0; transform:translateY(12px);} }

/* Shiny text (ReactBits-style sweep) */
.shiny{
  background:linear-gradient(110deg,var(--gold) 30%,#fff8e6 48%,var(--gold-3) 56%,var(--gold) 70%);
  background-size:220% auto; -webkit-background-clip:text; background-clip:text; color:transparent;
  animation:shine 5s linear infinite;
}
@keyframes shine{ to{ background-position:-220% center; } }

/* =========================================================
   Shared section heads
   ========================================================= */
.kicker{
  display:inline-block; font-size:.78rem; letter-spacing:.28em; text-transform:uppercase;
  color:var(--gold-2); font-weight:500; margin-bottom:1.1rem;
}
.section-title{
  font-family:var(--serif); font-weight:600; line-height:1.08;
  font-size:clamp(1.9rem,4vw,3.1rem); letter-spacing:-.01em; margin-bottom:1.1rem;
}
.section-lead{ color:var(--ink-dim); font-weight:300; font-size:clamp(1rem,1.4vw,1.15rem); max-width:640px; }
.prop__head{ max-width:var(--maxw); margin:0 auto 3.4rem; padding:0 1.5rem; text-align:center; }
.prop__head .section-lead{ margin-left:auto; margin-right:auto; }

/* =========================================================
   Insight strip
   ========================================================= */
.insight{ padding:7rem 1.5rem; background:linear-gradient(180deg,var(--bg),var(--bg-2)); }
.insight__inner{ max-width:860px; margin:0 auto; text-align:center; }
.insight__lead{ font-family:var(--serif); font-size:clamp(1.8rem,3.6vw,2.8rem); line-height:1.2; margin-bottom:1.4rem; }
.insight__lead em{ font-style:italic; color:var(--gold-3); }
.insight__body{ color:var(--ink-dim); font-size:clamp(1.02rem,1.5vw,1.2rem); font-weight:300; }
.insight__body strong{ color:var(--ink); font-weight:500; }

/* =========================================================
   Proposition cards
   ========================================================= */
.prop{ padding:6rem 1.5rem; }
.prop__grid{ max-width:var(--maxw); margin:0 auto; display:grid; grid-template-columns:repeat(3,1fr); gap:1.4rem; }
.card{
  position:relative; padding:2.4rem 2rem; border-radius:var(--radius-lg);
  background:linear-gradient(180deg,var(--panel),var(--panel-2)); border:1px solid var(--line-soft);
  overflow:hidden; transition:transform .4s var(--ease), border-color .4s ease;
}
.card:hover{ transform:translateY(-4px); border-color:var(--line); }
.card__num{ font-family:var(--serif); font-size:1rem; color:var(--gold-2); letter-spacing:.1em; }
.card h3{ font-family:var(--serif); font-size:1.6rem; font-weight:600; margin:1rem 0 .7rem; }
.card p{ color:var(--ink-dim); font-weight:300; font-size:.98rem; }

/* Spotlight follow effect */
.spotlight::before{
  content:""; position:absolute; inset:0; border-radius:inherit; opacity:0; transition:opacity .4s ease; pointer-events:none;
  background:radial-gradient(280px circle at var(--mx,50%) var(--my,50%), rgba(232,198,107,.12), transparent 60%);
}
.spotlight:hover::before{ opacity:1; }

/* =========================================================
   Services / tiers
   ========================================================= */
.services{ padding:6rem 1.5rem; background:linear-gradient(180deg,var(--bg-2),var(--bg)); }
.tiers{ max-width:var(--maxw); margin:0 auto; display:grid; grid-template-columns:repeat(3,1fr); gap:1.4rem; align-items:stretch; }
.tier{
  position:relative; display:flex; flex-direction:column; padding:2.4rem 2rem; border-radius:var(--radius-lg);
  background:linear-gradient(180deg,var(--panel),var(--panel-2)); border:1px solid var(--line-soft);
  overflow:hidden; transition:transform .4s var(--ease), border-color .4s ease;
}
.tier:hover{ transform:translateY(-5px); border-color:var(--line); }
.tier--featured{
  border-color:var(--line);
  background:
    linear-gradient(180deg, rgba(201,162,75,.08), rgba(201,162,75,.02)),
    linear-gradient(180deg,var(--panel),var(--panel-2));
  box-shadow:0 30px 80px -40px rgba(201,162,75,.4);
}
.tier--featured::after{
  content:""; position:absolute; inset:0; border-radius:inherit; padding:1px; pointer-events:none;
  background:linear-gradient(180deg,rgba(232,198,107,.5),rgba(232,198,107,0) 55%);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0); -webkit-mask-composite:xor; mask-composite:exclude;
}
.tier__flag{
  position:absolute; top:1.1rem; right:1.1rem; font-size:.7rem; letter-spacing:.14em; text-transform:uppercase;
  color:#1a1408; background:var(--gold-grad); padding:.32rem .7rem; border-radius:999px; font-weight:600;
}
.tier__step{ font-size:.78rem; letter-spacing:.18em; text-transform:uppercase; color:var(--gold-2); }
.tier__name{ font-family:var(--serif); font-size:1.55rem; font-weight:600; margin:.5rem 0 .8rem; }
.tier__price{ font-family:var(--serif); font-size:2.1rem; color:var(--ink); font-weight:600; margin-bottom:1.2rem; }
.tier__price span{ font-family:var(--sans); font-size:.8rem; color:var(--ink-faint); font-weight:300; letter-spacing:.05em; display:block; }
.tier__price small{ font-family:var(--sans); font-size:.9rem; color:var(--ink-faint); font-weight:300; }
.tier__desc{ color:var(--ink-dim); font-weight:300; font-size:.96rem; margin-bottom:1.4rem; }
.tier__list{ list-style:none; margin-bottom:1.8rem; display:grid; gap:.6rem; }
.tier__list li{ position:relative; padding-left:1.5rem; color:var(--ink-dim); font-size:.94rem; font-weight:300; }
.tier__list li::before{ content:"✓"; position:absolute; left:0; color:var(--gold-2); font-size:.85rem; }
.tier .btn{ margin-top:auto; }
.tiers__note{ max-width:var(--maxw); margin:1.8rem auto 0; text-align:center; color:var(--ink-faint); font-size:.86rem; }

/* =========================================================
   Method steps
   ========================================================= */
.method{ padding:6rem 1.5rem; }
.steps{ max-width:var(--maxw); margin:0 auto; list-style:none; display:grid; grid-template-columns:repeat(4,1fr); gap:1.4rem; counter-reset:s; }
.step{ position:relative; padding:2rem 1.6rem; border-left:1px solid var(--line); }
.step__num{
  display:grid; place-items:center; width:46px; height:46px; border-radius:50%; margin-bottom:1.2rem;
  border:1px solid var(--line); font-family:var(--serif); font-size:1.3rem; color:var(--gold-3);
  background:linear-gradient(160deg,#15130d,#0c0b08);
}
.step h3{ font-family:var(--serif); font-size:1.4rem; font-weight:600; margin-bottom:.5rem; }
.step p{ color:var(--ink-dim); font-weight:300; font-size:.94rem; }

/* =========================================================
   Who it's for
   ========================================================= */
.who{ padding:6rem 1.5rem; background:linear-gradient(180deg,var(--bg),var(--bg-2)); }
.who__inner{ max-width:var(--maxw); margin:0 auto; display:grid; grid-template-columns:1.1fr .9fr; gap:3.5rem; align-items:center; }
.who__points{ list-style:none; margin:1.8rem 0 2.2rem; display:grid; gap:.9rem; }
.who__points li{ display:flex; align-items:center; gap:.8rem; color:var(--ink-dim); font-weight:300; }
.who__points .dot{ width:8px; height:8px; border-radius:50%; background:var(--gold-grad); flex:none; box-shadow:0 0 12px rgba(232,198,107,.6); }
.who__panel{
  padding:2.4rem; border-radius:var(--radius-lg); border:1px solid var(--line-soft);
  background:linear-gradient(180deg,var(--panel),var(--panel-2));
}
.value-meter__label{ font-size:.8rem; letter-spacing:.2em; text-transform:uppercase; color:var(--ink-faint); margin-bottom:1.4rem; }
.value-meter__bar{ height:12px; border-radius:8px; background:rgba(255,255,255,.05); overflow:hidden; margin-bottom:.5rem; }
.value-meter__bar span{ display:block; height:100%; width:var(--w); background:rgba(255,255,255,.18); border-radius:8px; transform-origin:left; }
.value-meter__bar--gold span{ background:var(--gold-grad); box-shadow:0 0 18px rgba(232,198,107,.5); }
.value-meter__cap{ font-size:.84rem; color:var(--ink-faint); margin-bottom:1.8rem; }

/* =========================================================
   Enquire
   ========================================================= */
.enquire{ padding:6.5rem 1.5rem; overflow:hidden; background:radial-gradient(120% 80% at 50% 120%, #131211 0%, var(--bg) 55%); }
.enquire__inner{ position:relative; z-index:3; max-width:var(--maxw); margin:0 auto; display:grid; grid-template-columns:1fr 1fr; gap:3.5rem; align-items:start; }
.enquire__assure{ list-style:none; margin-top:2rem; display:grid; gap:.9rem; }
.enquire__assure li{ display:flex; align-items:center; gap:.7rem; color:var(--ink-dim); font-weight:300; }
.enquire__assure .tick{ color:var(--gold-2); font-weight:600; }

/* Form */
.form{
  background:linear-gradient(180deg,var(--panel),var(--panel-2)); border:1px solid var(--line);
  border-radius:var(--radius-lg); padding:2.2rem; box-shadow:0 40px 90px -50px rgba(0,0,0,.9);
}
.field{ margin-bottom:1.1rem; }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.field label{ display:block; font-size:.84rem; color:var(--ink-dim); margin-bottom:.45rem; letter-spacing:.01em; }
.field label small{ color:var(--ink-faint); }
.field input, .field textarea, .field select{
  width:100%; padding:.85rem 1rem; border-radius:12px; background:rgba(255,255,255,.03);
  border:1px solid var(--line-soft); color:var(--ink); font-family:var(--sans); font-size:.96rem; font-weight:300;
  transition:border-color .3s ease, box-shadow .3s ease, background .3s ease;
}
.field textarea{ resize:vertical; min-height:84px; }
.field input::placeholder, .field textarea::placeholder{ color:var(--ink-faint); }
.field input:focus, .field textarea:focus, .field select:focus{
  outline:none; border-color:var(--gold); background:rgba(232,198,107,.05);
  box-shadow:0 0 0 3px rgba(201,162,75,.14);
}
.field input:invalid:not(:placeholder-shown){ border-color:rgba(214,120,90,.5); }
.field.error input, .field.error select, .field.error textarea{ border-color:#d6785a; box-shadow:0 0 0 3px rgba(214,120,90,.14); }
.select-wrap{ position:relative; }
.select-wrap::after{ content:"▾"; position:absolute; right:1rem; top:50%; transform:translateY(-50%); color:var(--gold-2); pointer-events:none; font-size:.8rem; }
.field select{ appearance:none; -webkit-appearance:none; cursor:pointer; }
.field select option{ background:#141416; color:var(--ink); }
/* date input dark styling */
input[type="date"]::-webkit-calendar-picker-indicator{ filter:invert(.8) sepia(1) saturate(3) hue-rotate(5deg); cursor:pointer; }

.field-group-label{ font-size:.92rem; color:var(--ink); margin:1.6rem 0 .9rem; font-weight:400; }
.field-group-label span{ display:block; font-size:.8rem; color:var(--gold-2); font-weight:300; margin-top:.15rem; }

.form__status{ display:none; padding:.9rem 1rem; border-radius:12px; margin-bottom:1.2rem; font-size:.9rem; }
.form__status.show{ display:block; }
.form__status.success{ background:rgba(201,162,75,.12); border:1px solid var(--line); color:var(--gold-3); }
.form__status.fail{ background:rgba(214,120,90,.12); border:1px solid rgba(214,120,90,.4); color:#e8b3a0; }
.form__fineprint{ font-size:.78rem; color:var(--ink-faint); text-align:center; margin-top:.9rem; }

/* =========================================================
   Footer
   ========================================================= */
.footer{ padding:4.5rem 1.5rem 2rem; border-top:1px solid var(--line-soft); background:var(--bg-2); }
.footer__inner{ max-width:var(--maxw); margin:0 auto; display:grid; grid-template-columns:2fr 1fr 1fr; gap:2.5rem; }
.footer__brand{ display:flex; flex-direction:column; gap:.4rem; }
.footer__brand .brand__mark, .footer__brand .brand__word{ }
.footer__brand{ align-items:flex-start; }
.footer__tag{ color:var(--ink-faint); font-size:.9rem; font-weight:300; margin-top:.8rem; max-width:280px; }
.footer__col h4{ font-family:var(--sans); font-size:.82rem; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-faint); margin-bottom:1rem; font-weight:500; }
.footer__col a, .footer__col .linkbtn{ display:block; color:var(--ink-dim); font-size:.94rem; font-weight:300; margin-bottom:.6rem; text-decoration:none; text-align:left; }
.footer__col a:hover, .footer__col .linkbtn:hover{ color:var(--gold-3); }
.footer__base{
  max-width:var(--maxw); margin:3rem auto 0; padding-top:1.6rem; border-top:1px solid var(--line-soft);
  display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap; color:var(--ink-faint); font-size:.84rem;
}

/* =========================================================
   Scroll reveal
   ========================================================= */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .8s var(--ease), transform .8s var(--ease); }
.reveal.in{ opacity:1; transform:none; }

/* =========================================================
   Responsive
   ========================================================= */
@media (max-width:980px){
  .prop__grid, .tiers, .steps{ grid-template-columns:1fr 1fr; }
  .who__inner{ grid-template-columns:1fr; gap:2.5rem; }
  .enquire__inner{ grid-template-columns:1fr; gap:2.5rem; }
  .footer__inner{ grid-template-columns:1fr 1fr; }
}
@media (max-width:760px){
  .nav__links{ display:none; }
  .nav__cta{ display:none; }
  .nav__toggle{ display:flex; }
  .nav.menu-open .nav__links{
    display:flex; position:absolute; top:100%; left:0; right:0; flex-direction:column; gap:0;
    background:rgba(10,10,11,.96); backdrop-filter:blur(14px); border-bottom:1px solid var(--line-soft); padding:.5rem 1.5rem 1.2rem; margin:0;
  }
  .nav.menu-open .nav__links a{ padding:.9rem 0; border-bottom:1px solid var(--line-soft); }
  .nav.menu-open .nav__cta{ display:inline-flex; margin:.8rem 1.5rem; }
  .prop__grid, .tiers, .steps{ grid-template-columns:1fr; }
  .step{ border-left:none; border-top:1px solid var(--line); padding-top:1.6rem; }
  .footer__inner{ grid-template-columns:1fr; gap:2rem; }
  .field-row{ grid-template-columns:1fr; }
  .hero{ padding-top:7.5rem; }
  .form{ padding:1.6rem; }
}

/* ===== Work / Portfolio ===== */
.work{ padding:var(--section-pad) 1.5rem; max-width:var(--maxw); margin:0 auto; }
.work__grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(320px,1fr));
  gap:1.6rem;
  margin-top:1rem;
}
.work-card{
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:14px;
  overflow:hidden;
  display:flex; flex-direction:column;
  transition:border-color .3s, transform .3s;
}
.work-card:hover{ border-color:var(--gold-2); transform:translateY(-4px); }
.work-card__top{ position:relative; }
.work-card__industry{
  position:absolute; top:1rem; left:1rem; z-index:2;
  font-size:.7rem; letter-spacing:.18em; text-transform:uppercase;
  background:rgba(224,163,64,.15); color:var(--gold-2);
  border:1px solid rgba(224,163,64,.3);
  padding:.25rem .75rem; border-radius:20px; font-weight:500;
}
.work-card__visual{
  padding:2.4rem 1.5rem 1.2rem;
  background:linear-gradient(135deg,#111009 0%,#1a1505 100%);
  min-height:160px;
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:1rem;
}
.wv-label{
  font-size:.7rem; letter-spacing:.12em; text-transform:uppercase;
  color:var(--ink-dim); margin:0;
}
/* Bar chart */
.wv-bar-chart{ display:flex; align-items:flex-end; gap:6px; height:80px; }
.wv-bar{
  width:22px; border-radius:4px 4px 0 0;
  background:rgba(224,163,64,.25);
  transition:height .4s;
}
.wv-bar--gold{ background:var(--gold-2); }
.wv-bar span{ display:none; }
/* Journey steps */
.wv-journey{ display:flex; align-items:center; gap:4px; flex-wrap:wrap; justify-content:center; }
.wv-step{
  font-size:.72rem; padding:.3rem .65rem; border-radius:6px;
  border:1px solid var(--line); color:var(--ink-dim);
}
.wv-step--done{ border-color:rgba(224,163,64,.4); color:var(--gold-2); background:rgba(224,163,64,.08); }
.wv-step--active{ border-color:var(--gold-2); color:#fff; background:rgba(224,163,64,.18); font-weight:600; }
.wv-arrow{ color:var(--ink-dim); font-size:.8rem; }
/* Quote tool */
.wv-quote{ width:100%; max-width:220px; }
.wv-quote__row{ display:flex; justify-content:space-between; font-size:.8rem; padding:.35rem 0; color:var(--ink-dim); }
.wv-quote__divider{ border-top:1px solid var(--line); margin:.4rem 0; }
.wv-quote__total{ font-weight:600; color:#fff; }
.wv-gold{ color:var(--gold-2); }
/* Portal */
.wv-portal{ width:100%; max-width:220px; display:flex; flex-direction:column; gap:.5rem; }
.wv-portal__item{ font-size:.78rem; padding:.4rem .75rem; border-radius:6px; border:1px solid var(--line); color:var(--ink-dim); }
.wv-portal__item--done{ color:var(--gold-2); border-color:rgba(224,163,64,.3); text-decoration:line-through; opacity:.7; }
.wv-portal__item--active{ color:#fff; border-color:var(--gold-2); background:rgba(224,163,64,.1); font-weight:600; }
/* Metrics */
.wv-metrics{ display:flex; gap:1.2rem; }
.wv-metric{ display:flex; flex-direction:column; align-items:center; gap:.2rem; }
.wv-metric__val{ font-family:var(--serif); font-size:1.3rem; font-weight:600; }
.wv-metric__lbl{ font-size:.65rem; text-align:center; color:var(--ink-dim); letter-spacing:.05em; }
/* Card body */
.work-card__body{ padding:1.4rem 1.5rem 1.6rem; flex:1; display:flex; flex-direction:column; gap:.75rem; }
.work-card__body h3{ font-family:var(--serif); font-size:1.15rem; font-weight:600; line-height:1.2; margin:0; }
.work-card__body p{ font-size:.9rem; color:var(--ink-dim); line-height:1.65; margin:0; }
.work-card__tags{ display:flex; flex-wrap:wrap; gap:.4rem; list-style:none; padding:0; margin:auto 0 0; padding-top:.4rem; }
.work-card__tags li{
  font-size:.7rem; padding:.2rem .6rem; border-radius:20px;
  border:1px solid var(--line); color:var(--ink-dim); letter-spacing:.05em;
}
/* Demo link */
.work-card__demo{
  display:inline-flex; align-items:center; gap:.35rem;
  margin-top:.9rem; font-size:.8rem; font-weight:600;
  color:var(--gold); text-decoration:none; letter-spacing:.03em;
  transition:color .2s, gap .2s;
}
.work-card__demo:hover{ color:var(--gold-bright); gap:.55rem; }

/* CTA card */
.work-card--cta{
  background:linear-gradient(135deg,rgba(224,163,64,.08) 0%,rgba(201,98,42,.06) 100%);
  border-color:rgba(224,163,64,.25);
  align-items:center; justify-content:center;
}
.work-card__cta-inner{ padding:2.5rem 2rem; text-align:center; display:flex; flex-direction:column; gap:1rem; align-items:center; }
.work-card__cta-eyebrow{ font-size:.75rem; letter-spacing:.2em; text-transform:uppercase; color:var(--gold-2); margin:0; }
.work-card__cta-inner h3{ font-family:var(--serif); font-size:1.4rem; margin:0; }
.work-card__cta-inner p{ color:var(--ink-dim); font-size:.9rem; margin:0; }

/* Reduced motion */
@media (prefers-reduced-motion:reduce){
  *{ animation:none !important; transition:none !important; }
  .reveal{ opacity:1; transform:none; }
}
