/*
Theme Name: Toronto SEO Services
Theme URI: https://torontoseoservices.digital
Author: Toronto SEO Services
Description: Premium luxury SEO agency WordPress theme. Gold and cream design with Cormorant Garamond typography.
Version: 1.0.0
License: Proprietary
Text Domain: toronto-seo-services
*/

/* ── TOKENS ──────────────────────────────────────────────── */
:root{
  --cream:#F5F3EE;
  --cream2:#EDE9DF;
  --dark:#0B0B15;
  --dark2:#12121F;
  --text:#0B0B15;
  --muted:#6A6977;
  --light:#AAA8B8;
  --violet:#CA8A04;
  --violet2:#D4A853;
  --pink:#92700A;
  --green:#00B87D;
  --gold:#CA8A04;
  --border:rgba(11,11,21,.07);
  --bdark:rgba(255,255,255,.08);
  --r:16px;--r2:24px;
  --sh:0 4px 32px rgba(11,11,21,.09);
  --sh2:0 24px 80px rgba(11,11,21,.14);
}

/* ── BASE ────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;font-size:16px;}
body{
  background:var(--cream);
  color:var(--text);
  font-family:'Inter',sans-serif;
  font-weight:400;
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  cursor:none;
}
img{max-width:100%;height:auto;display:block;}
a{text-decoration:none;color:inherit;}
ul{list-style:none;}
::selection{background:var(--violet);color:#fff;}
::-webkit-scrollbar{width:5px;}
::-webkit-scrollbar-track{background:var(--cream);}
::-webkit-scrollbar-thumb{background:var(--violet);border-radius:3px;}

/* ── GRAIN ───────────────────────────────────────────────── */
body::after{
  content:'';
  position:fixed;inset:0;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E");
  opacity:.032;
  pointer-events:none;
  z-index:9000;
}

/* ── PROGRESS BAR ────────────────────────────────────────── */
#progress{
  position:fixed;top:0;left:0;
  height:2px;width:100%;
  background:linear-gradient(90deg,#CA8A04,#D4A853);
  z-index:9999;
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .1s linear;
  will-change:transform;
}

/* ── CURSOR ──────────────────────────────────────────────── */
#cur{
  width:10px;height:10px;
  background:var(--violet);
  border-radius:50%;
  position:fixed;
  left:0;top:0;
  pointer-events:none;
  z-index:8999;
  will-change:transform;
  transition:background .2s,width .2s,height .2s;
  mix-blend-mode:multiply;
}
#cur2{
  width:40px;height:40px;
  border:1.5px solid var(--violet);
  border-radius:50%;
  position:fixed;
  left:0;top:0;
  pointer-events:none;
  z-index:8998;
  will-change:transform;
  opacity:.4;
  transition:width .3s,height .3s,opacity .3s;
}
body.hov #cur{width:60px;height:60px;background:rgba(202,138,4,.15);}
body.hov #cur2{opacity:0;}

/* ── PRELOADER ───────────────────────────────────────────── */
#pre{
  position:fixed;inset:0;
  background:var(--dark);
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  z-index:9998;
  transition:clip-path .8s cubic-bezier(.86,0,.07,1);
  clip-path:inset(0 0 0 0);
}
#pre.out{clip-path:inset(0 0 100% 0);}
.pre-logo{
  font-family:'Playfair Display',serif;
  font-size:2.4rem;font-weight:700;
  color:#fff;letter-spacing:-.03em;
  opacity:0;animation:fu .5s ease forwards .1s;
}
.pre-logo em{font-style:italic;color:var(--violet);}
.pre-count{
  font-family:'JetBrains Mono',monospace;
  font-size:4rem;font-weight:400;
  color:#fff;
  margin-top:12px;
  opacity:0;animation:fu .5s ease forwards .2s;
}
@keyframes fu{from{opacity:0;transform:translateY(20px);}to{opacity:1;transform:none;}}

/* ── NAV ─────────────────────────────────────────────────── */
nav{
  position:fixed;top:0;left:0;right:0;
  z-index:900;
  padding:22px 80px;
  display:flex;align-items:center;justify-content:space-between;
  background:rgba(250,250,249,.92);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid rgba(28,25,23,.07);
  transition:padding .4s,box-shadow .4s;
}
nav.on{
  padding:14px 80px;
  box-shadow:0 4px 24px rgba(28,25,23,.06);
}
.nlogo-wrap{display:flex;align-items:center;gap:11px;text-decoration:none;}
.nlogo-icon{flex-shrink:0;}
.nlogo-text{display:flex;flex-direction:column;line-height:1;gap:3px;}
.nlogo-main{
  font-family:'Cormorant Garamond',serif;
  font-size:1.25rem;font-weight:600;
  letter-spacing:-.02em;color:#1C1917;line-height:1;
}
.nlogo-main em{font-style:italic;color:#CA8A04;}
.nlogo-sub{
  font-family:'Montserrat',sans-serif;
  font-size:.46rem;font-weight:700;
  letter-spacing:.26em;text-transform:uppercase;
  color:#AAA8B8;
}
.nlinks{display:flex;align-items:center;gap:8px;}
.nlinks a{
  font-family:'Montserrat',sans-serif;
  font-size:.62rem;font-weight:600;
  color:#6A6977;
  letter-spacing:.1em;
  text-transform:uppercase;
  padding:8px 16px;
  border-radius:6px;
  transition:color .25s,background .25s;
  position:relative;
}
.nlinks a:hover{color:#1C1917;background:rgba(28,25,23,.05);}
.nlinks a.active{color:#CA8A04;}
/* Gold dot indicator for active */
.nlinks a.active::before{
  content:'';
  position:absolute;bottom:4px;left:50%;transform:translateX(-50%);
  width:4px;height:4px;border-radius:50%;
  background:#CA8A04;
}
/* Separator dots between links */
.nlinks .nsep{
  width:3px;height:3px;border-radius:50%;
  background:rgba(28,25,23,.12);
  flex-shrink:0;
}
/* Nav phone number */
.nav-phone{
  font-family:'Montserrat',sans-serif;
  font-size:.74rem;font-weight:700;
  letter-spacing:.04em;
  color:#1C1917;
  display:flex;align-items:center;gap:7px;
  white-space:nowrap;
}
.nav-phone svg{flex-shrink:0;}
.ncta{
  font-family:'Montserrat',sans-serif;
  font-size:.6rem;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;
  background:#CA8A04;
  color:#1C1917;
  padding:11px 22px;
  border-radius:4px;
  transition:background .25s,transform .2s,box-shadow .25s;
  cursor:pointer;
  white-space:nowrap;
}
.ncta:hover{background:#1C1917;transform:translateY(-2px);box-shadow:0 8px 28px rgba(202,138,4,.3);}
/* Nav right group — all pushed to right */
.nav-right{
  display:flex;align-items:center;gap:24px;
  margin-left:auto;
}
/* Divider between phone and CTA */
.nav-divider{width:1px;height:20px;background:rgba(28,25,23,.12);}
/* Push nlinks + nav-right to the right */
.nlinks{margin-left:auto;}

/* ── HERO — GOLD & CREAM LUXURY ─────────────────────────── */
.hero{
  display:grid;
  grid-template-columns:46fr 54fr;
  height:100vh;
  min-height:720px;
}

/* LEFT PANEL */
.h-left{
  background:#FAFAF9;
  display:flex;flex-direction:column;justify-content:center;
  padding:110px 60px 64px 80px;
  position:relative;z-index:2;
  overflow:hidden;
}
/* Decorative large number behind content */
.h-left::before{
  content:'01';
  position:absolute;
  right:-20px;top:50%;
  transform:translateY(-50%);
  font-family:'Cormorant Garamond',serif;
  font-size:28rem;font-weight:700;
  line-height:1;
  color:rgba(28,25,23,.04);
  pointer-events:none;
  user-select:none;
  letter-spacing:-.06em;
}
/* Gold separator line */
.h-left::after{
  content:'';
  position:absolute;top:15%;bottom:15%;right:0;
  width:1px;
  background:linear-gradient(to bottom,transparent,#CA8A04 30%,#CA8A04 70%,transparent);
  opacity:.4;
}

/* Skill ticker */
.h-ticker-wrap{
  overflow:hidden;
  margin-bottom:28px;
  opacity:0;animation:fu .6s ease forwards .1s;
}
.h-ticker{
  display:flex;gap:40px;
  animation:tickerScroll 18s linear infinite;
  width:max-content;
  font-size:0.6rem;font-weight:600;letter-spacing:.14em;
  text-transform:uppercase;color:var(--light);
}
@keyframes tickerScroll{from{transform:translateX(0);}to{transform:translateX(-50%);}}
.h-sep{margin:0 10px;color:var(--border);}
.h-ticker span{white-space:nowrap;}

/* Eyebrow */
.h-tag{
  display:inline-flex;align-items:center;gap:10px;
  margin-bottom:24px;
  font-family:'Montserrat',sans-serif;
  font-size:0.58rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;
  color:#CA8A04;
  opacity:0;animation:fu .5s ease forwards .3s;
}
.h-tag::before{content:'';width:24px;height:1px;background:#CA8A04;}

/* H1 — Cormorant luxury */
.h-h1{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(3rem,4.8vw,6rem);
  font-weight:600;
  line-height:1.04;
  letter-spacing:-.02em;
  color:#1C1917;
  margin-bottom:24px;
}
.h-h1 em{
  font-style:italic;
  font-weight:400;
  color:#CA8A04;
}
.h-word{
  display:block;
  opacity:0;
  transform:translateY(24px);
  transition:opacity .6s cubic-bezier(.22,1,.36,1),transform .6s cubic-bezier(.22,1,.36,1);
}
.h-word.on{opacity:1;transform:none;}

/* Sub */
.h-sub{
  font-family:'Montserrat',sans-serif;
  font-size:0.82rem;color:#6A6977;
  line-height:1.9;max-width:360px;
  margin-bottom:40px;font-weight:400;
  opacity:0;animation:fu .5s ease forwards 1s;
}

/* Buttons */
.h-btns{
  display:flex;align-items:center;gap:14px;
  margin-bottom:52px;
  opacity:0;animation:fu .5s ease forwards 1.15s;
}
.h-btn-p{
  display:inline-flex;align-items:center;gap:8px;
  background:#1C1917;color:#FAFAF9;
  padding:14px 32px;border-radius:4px;
  font-family:'Montserrat',sans-serif;
  font-size:0.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  position:relative;overflow:hidden;
  transition:box-shadow .4s ease;
  cursor:pointer;
}
.h-btn-p::before{
  content:'';position:absolute;inset:0;
  background:#CA8A04;
  transform:scaleX(0);transform-origin:left;
  transition:transform .45s cubic-bezier(.22,1,.36,1);
}
.h-btn-p:hover::before{transform:scaleX(1);}
.h-btn-p span{position:relative;z-index:1;}
.h-btn-p:hover{box-shadow:0 12px 40px rgba(202,138,4,.3);}
.h-btn-g{
  display:inline-flex;align-items:center;gap:6px;
  background:transparent;
  border:1px solid rgba(28,25,23,.18);color:#44403C;
  padding:14px 28px;border-radius:4px;
  font-family:'Montserrat',sans-serif;
  font-size:0.72rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
  transition:border-color .3s,color .3s;
  cursor:pointer;
}
.h-btn-g:hover{border-color:#CA8A04;color:#CA8A04;}

/* Stats */
.h-stats{
  display:flex;gap:0;
  border-top:1px solid rgba(28,25,23,.08);
  padding-top:28px;
  opacity:0;animation:fu .5s ease forwards 1.3s;
}
.h-stat{flex:1;}
.h-stat:not(:last-child){
  border-right:1px solid rgba(28,25,23,.08);
  padding-right:24px;margin-right:24px;
}
.h-snum{
  font-family:'Cormorant Garamond',serif;
  font-size:2rem;font-weight:600;
  letter-spacing:-.03em;color:#1C1917;
  line-height:1;margin-bottom:5px;
}
.h-slabel{
  font-family:'Montserrat',sans-serif;
  font-size:0.58rem;color:#AAA8B8;
  font-weight:600;letter-spacing:.1em;text-transform:uppercase;
}

/* RIGHT PANEL */
.h-right{
  position:relative;
  overflow:hidden;
  background:#1C1917;
}

/* Photo */
.h-photo{
  position:absolute;
  top:0;left:0;
  width:100%;height:100%;
}
.h-photo img{
  width:100%;height:100%;
  object-fit:cover;
  object-position:center 25%;
  animation:hZoom 14s ease-in-out infinite alternate;
}
@keyframes hZoom{from{transform:scale(1);}to{transform:scale(1.06);}}

/* Overlay — warm dark + gold vignette */
.h-overlay{
  position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(28,25,23,.55) 0%,rgba(28,25,23,.2) 60%,rgba(202,138,4,.08) 100%);
}

/* Glass rank card */
.h-card{
  position:absolute;
  bottom:48px;left:36px;
  background:#1C1917;
  backdrop-filter:none;-webkit-backdrop-filter:none;
  border:1px solid rgba(202,138,4,.25);
  border-top:2px solid #CA8A04;
  border-radius:16px;padding:20px 22px;width:280px;
  box-shadow:0 16px 48px rgba(28,25,23,.35);
  opacity:0;animation:fu .7s ease forwards .9s;
}
.h-card-hd{
  display:flex;justify-content:space-between;align-items:center;
  margin-bottom:14px;
}
.h-card-title{
  font-family:'Montserrat',sans-serif;
  font-size:0.58rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  color:rgba(250,250,249,.6);
}
.h-live{display:flex;align-items:center;gap:5px;font-size:.62rem;color:#4ADE80;font-weight:600;}
.h-live-dot{
  width:5px;height:5px;border-radius:50%;background:#4ADE80;
  animation:livePulse 2s infinite;
}
@keyframes livePulse{0%,100%{opacity:1;transform:scale(1);}50%{opacity:.4;transform:scale(1.3);}}
.h-card-rows{display:flex;flex-direction:column;gap:7px;margin-bottom:14px;}
.h-row{
  display:flex;align-items:center;gap:10px;
  padding:9px 12px;
  background:rgba(250,250,249,.06);
  border-radius:8px;
  transition:background .2s;
}
.h-row:hover{background:rgba(250,250,249,.1);}
.h-kw{flex:1;font-size:.72rem;color:rgba(250,250,249,.85);font-family:'Montserrat',sans-serif;}
.h-pos{
  font-family:'JetBrains Mono',monospace;
  font-size:.72rem;font-weight:500;color:#CA8A04;
  min-width:22px;text-align:center;
}
.h-chg{font-size:.65rem;font-weight:700;color:#4ADE80;}
.h-card-ft{
  display:flex;justify-content:space-between;
  padding-top:12px;border-top:1px solid rgba(250,250,249,.07);
  font-size:.66rem;color:rgba(250,250,249,.28);
  font-family:'Montserrat',sans-serif;
}
.h-card-ft strong{color:#CA8A04;}

/* Award badge — top right */
.h-award{
  position:absolute;top:84px;right:32px;
  background:#1C1917;
  backdrop-filter:none;-webkit-backdrop-filter:none;
  border:1px solid rgba(202,138,4,.35);
  border-top:2px solid #CA8A04;
  border-radius:12px;padding:16px 20px;
  text-align:center;
  box-shadow:0 8px 24px rgba(28,25,23,.3);
  opacity:0;
  animation:fu .5s ease forwards 1.1s;
}
.h-award-num{
  font-family:'Cormorant Garamond',serif;
  font-size:2.4rem;font-weight:700;color:#CA8A04;line-height:1;
}
.h-award-label{
  font-family:'Montserrat',sans-serif;
  font-size:0.58rem;color:rgba(250,250,249,.75);
  margin-top:6px;line-height:1.5;
  letter-spacing:.06em;text-transform:uppercase;
}

/* Scroll indicator */
.h-scroll-ind{
  position:absolute;bottom:28px;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:6px;
  z-index:3;
  opacity:0;animation:fu .6s ease forwards 1.5s;
}
.h-scroll-line{
  width:1px;height:44px;
  background:linear-gradient(to bottom,var(--violet),transparent);
  animation:scrollDraw 2s ease infinite;
}
@keyframes scrollDraw{
  0%{transform:scaleY(0);transform-origin:top;}
  50%{transform:scaleY(1);transform-origin:top;}
  51%{transform:scaleY(1);transform-origin:bottom;}
  100%{transform:scaleY(0);transform-origin:bottom;}
}
.h-scroll-txt{font-size:.56rem;letter-spacing:.18em;text-transform:uppercase;color:var(--light);}

/* Button styles (used globally too) */
.btn-mag{
  display:inline-flex;align-items:center;gap:10px;
  background:var(--dark);color:#fff;
  padding:16px 36px;border-radius:100px;
  font-size:.82rem;font-weight:600;letter-spacing:.04em;
  transition:background .25s,box-shadow .25s;
  position:relative;overflow:hidden;
}
.btn-mag::before{
  content:'';position:absolute;inset:0;
  background:var(--violet);
  transform:scaleX(0);transform-origin:left;
  transition:transform .35s ease;
}
.btn-mag:hover::before{transform:scaleX(1);}
.btn-mag span{position:relative;z-index:1;}
.btn-mag:hover{box-shadow:0 12px 36px rgba(202,138,4,.4);}
.btn-outline{
  display:inline-flex;align-items:center;gap:8px;
  color:var(--muted);font-size:.82rem;font-weight:500;
  padding:16px 24px;border-radius:100px;
  border:1.5px solid var(--border);
  transition:border-color .2s,color .2s;
}
.btn-outline:hover{border-color:var(--violet);color:var(--violet);}

/* ── MARQUEE STRIP ───────────────────────────────────────── */
.marquee-strip{
  background:#F0EDE6;
  padding:18px 0;
  overflow:hidden;
  border-top:1px solid rgba(28,25,23,.08);
  border-bottom:1px solid rgba(28,25,23,.08);
}
.marquee-track{
  display:flex;gap:0;
  animation:marquee 24s linear infinite;
  width:max-content;
}
@keyframes marquee{from{transform:translateX(0);}to{transform:translateX(-50%);}}
.marquee-item{
  display:flex;align-items:center;gap:28px;
  padding:0 28px;
  font-family:'Montserrat',sans-serif;
  font-size:.62rem;
  font-weight:700;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:rgba(28,25,23,.62);
  white-space:nowrap;
}
.marquee-item strong{color:#CA8A04;}
.marquee-dot{
  width:4px;height:4px;
  background:#CA8A04;
  border-radius:50%;
  flex-shrink:0;
  opacity:.5;
}

/* ── SERVICES ────────────────────────────────────────────── */
/* ── SERVICES — GLASS CARD GRID ─────────────────────────── */
.services{
  padding:120px 80px;
  background:linear-gradient(155deg,#FAFAF9 0%,#F5EFE4 50%,#FAFAF9 100%);
  position:relative;overflow:hidden;
}
.services::before{
  content:'';position:absolute;
  width:700px;height:700px;
  background:radial-gradient(circle,rgba(202,138,4,.07) 0%,transparent 65%);
  top:-200px;right:-150px;pointer-events:none;
}
.services::after{
  content:'';position:absolute;
  width:500px;height:500px;
  background:radial-gradient(circle,rgba(202,138,4,.05) 0%,transparent 65%);
  bottom:-150px;left:-100px;pointer-events:none;
}
.svc-hd{
  display:grid;grid-template-columns:1fr 1fr;
  gap:60px;align-items:end;
  margin-bottom:72px;
  position:relative;z-index:1;
}
.sec-tag{
  font-family:'Montserrat',sans-serif;
  font-size:.58rem;font-weight:700;
  letter-spacing:.2em;text-transform:uppercase;
  color:#CA8A04;
  display:flex;align-items:center;gap:10px;
  margin-bottom:16px;
}
.sec-tag::before{content:'';width:20px;height:1px;background:#CA8A04;}
.sec-h2{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2.4rem,4vw,4rem);
  font-weight:600;letter-spacing:-.03em;line-height:1.06;
  color:#1C1917;
}
.sec-h2 em{font-style:italic;color:#CA8A04;}
.svc-hd-right{
  font-family:'Montserrat',sans-serif;
  font-size:.84rem;color:#6A6977;line-height:1.85;padding-bottom:4px;
}

/* Glass cards grid */
.svc-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:20px;position:relative;z-index:1;
}
.svc-card{
  background:linear-gradient(145deg,#FFFFFF 0%,#FAF8F5 100%);
  border:1px solid rgba(28,25,23,.07);
  border-radius:20px;
  padding:36px 32px 32px;
  position:relative;overflow:hidden;
  display:flex;flex-direction:column;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,1),
    inset 0 -1px 0 rgba(28,25,23,.03),
    0 4px 24px rgba(28,25,23,.06);
  transition:transform .45s cubic-bezier(.22,1,.36,1),box-shadow .45s cubic-bezier(.22,1,.36,1),border-color .3s;
  cursor:default;
}
/* Gold shimmer top line */
.svc-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent 0%,#CA8A04 40%,#D4A853 60%,transparent 100%);
  opacity:0;transition:opacity .4s;
}
/* Glass shine sweep on hover */
.svc-card::after{
  content:'';position:absolute;
  top:0;left:-80%;width:50%;height:100%;
  background:linear-gradient(105deg,transparent 40%,rgba(255,255,255,.45) 50%,transparent 60%);
  transform:skewX(-15deg);
  transition:left .7s cubic-bezier(.22,1,.36,1);
  pointer-events:none;
}
.svc-card:hover{
  transform:translateY(-8px);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,1),
    0 28px 64px rgba(28,25,23,.1),
    0 0 0 1px rgba(202,138,4,.18);
  border-color:rgba(202,138,4,.22);
}
.svc-card:hover::before{opacity:1;}
.svc-card:hover::after{left:130%;}
.svc-num{
  font-family:'JetBrains Mono',monospace;
  font-size:.58rem;font-weight:500;color:#CA8A04;
  position:absolute;top:24px;right:24px;opacity:.5;
}
.svc-icon{
  width:48px;height:48px;
  background:linear-gradient(135deg,rgba(202,138,4,.1),rgba(202,138,4,.04));
  border:1px solid rgba(202,138,4,.14);
  border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  margin-bottom:22px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.9),0 2px 8px rgba(202,138,4,.07);
}
.svc-icon svg{width:22px;height:22px;stroke:#CA8A04;fill:none;stroke-width:1.75;stroke-linecap:round;stroke-linejoin:round;}
.svc-title{
  font-family:'Cormorant Garamond',serif;
  font-size:1.35rem;font-weight:600;color:#1C1917;
  margin-bottom:12px;line-height:1.2;
  transition:color .3s;
}
.svc-card:hover .svc-title{color:#CA8A04;}
.svc-desc{
  font-family:'Montserrat',sans-serif;
  font-size:.74rem;color:#6A6977;
  line-height:1.85;margin-bottom:22px;flex:1;
}
.svc-pills{display:flex;flex-wrap:wrap;gap:6px;}
.svc-tag-pill{
  font-family:'Montserrat',sans-serif;
  font-size:.54rem;font-weight:700;
  letter-spacing:.08em;text-transform:uppercase;
  background:rgba(202,138,4,.07);
  border:1px solid rgba(202,138,4,.12);
  color:#92700A;
  padding:4px 10px;border-radius:100px;
}

/* ── MANIFESTO — LIGHT LUXURY ────────────────────────────── */
.manifesto{
  padding:120px 80px;
  background:linear-gradient(150deg,#FAFAF9 0%,#F5EEE2 45%,#FAFAF9 100%);
  display:grid;grid-template-columns:1fr 1fr;
  gap:80px;align-items:center;
  position:relative;overflow:hidden;
}
.manifesto::before{
  content:'';position:absolute;
  width:700px;height:700px;
  background:radial-gradient(circle,rgba(202,138,4,.07) 0%,transparent 60%);
  top:-200px;left:-250px;pointer-events:none;
}
.manifesto::after{
  content:'';position:absolute;
  width:500px;height:500px;
  background:radial-gradient(circle,rgba(202,138,4,.05) 0%,transparent 60%);
  bottom:-150px;right:100px;pointer-events:none;
}
.manifesto-left{position:relative;z-index:1;}
.manifesto-deco{
  font-family:'Cormorant Garamond',serif;
  font-size:9rem;font-weight:700;
  color:rgba(202,138,4,.12);
  line-height:.75;display:block;
  margin-bottom:-8px;user-select:none;
}
.manifesto-tag{
  font-family:'Montserrat',sans-serif;
  font-size:.58rem;font-weight:700;
  letter-spacing:.2em;text-transform:uppercase;
  color:#CA8A04;
  display:flex;align-items:center;gap:10px;
  margin-bottom:24px;
}
.manifesto-tag::before{content:'';width:20px;height:1px;background:#CA8A04;}
.manifesto-q{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2rem,3.2vw,3.2rem);
  font-weight:400;font-style:italic;
  color:#1C1917;line-height:1.28;margin-bottom:24px;
}
.manifesto-q strong{
  font-weight:700;font-style:normal;display:block;
  background:linear-gradient(90deg,#CA8A04 0%,#D4A853 40%,#CA8A04 80%);
  background-size:200% auto;
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  animation:goldShimmer 4s linear infinite;
}
@keyframes goldShimmer{from{background-position:0%}to{background-position:200%}}
.manifesto-body{
  font-family:'Montserrat',sans-serif;
  font-size:.8rem;color:#6A6977;
  line-height:1.9;margin-bottom:36px;
}
/* Principle cards */
.manifesto-principles{display:flex;flex-direction:column;gap:12px;margin-bottom:40px;}
.manifesto-principle{
  display:flex;align-items:flex-start;gap:14px;
  padding:16px 20px;
  background:linear-gradient(145deg,#FFFFFF,#FAF8F4);
  border:1px solid rgba(28,25,23,.07);
  border-radius:14px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,1),0 2px 12px rgba(28,25,23,.05);
  transition:transform .3s,border-color .3s,box-shadow .3s;
  cursor:default;
}
.manifesto-principle:hover{
  transform:translateX(6px);
  border-color:rgba(202,138,4,.22);
  box-shadow:inset 0 1px 0 rgba(255,255,255,1),0 8px 24px rgba(28,25,23,.07);
}
.mp-icon{
  width:34px;height:34px;flex-shrink:0;
  background:linear-gradient(135deg,rgba(202,138,4,.1),rgba(202,138,4,.04));
  border:1px solid rgba(202,138,4,.14);border-radius:9px;
  display:flex;align-items:center;justify-content:center;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.8);
}
.mp-icon svg{width:15px;height:15px;stroke:#CA8A04;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;}
.mp-title{font-family:'Cormorant Garamond',serif;font-size:1rem;font-weight:600;color:#1C1917;line-height:1.2;margin-bottom:2px;}
.mp-desc{font-family:'Montserrat',sans-serif;font-size:.66rem;color:#AAA8B8;line-height:1.6;}
/* CTA */
.manifesto-cta{
  display:inline-flex;align-items:center;gap:10px;
  background:#1C1917;color:#FAFAF9;
  border-radius:4px;padding:14px 28px;
  font-family:'Montserrat',sans-serif;
  font-size:.64rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;
  transition:background .3s,box-shadow .3s;cursor:pointer;
  position:relative;overflow:hidden;
}
.manifesto-cta::before{
  content:'';position:absolute;inset:0;
  background:#CA8A04;
  transform:scaleX(0);transform-origin:left;
  transition:transform .4s cubic-bezier(.22,1,.36,1);
}
.manifesto-cta span,.manifesto-cta svg{position:relative;z-index:1;}
.manifesto-cta svg{transition:transform .2s;}
.manifesto-cta:hover::before{transform:scaleX(1);}
.manifesto-cta:hover svg{transform:translateX(4px);}
.manifesto-cta:hover{box-shadow:0 10px 30px rgba(202,138,4,.3);}
/* Photo */
.manifesto-right{position:relative;z-index:1;}

/* ── DATA CARDS (replaces photo) ─────────────────────────── */
.mf-cards{
  position:relative;
  height:540px;
}
.mc{
  position:absolute;
  background:#1C1917;
  border:1px solid rgba(202,138,4,.18);
  border-radius:20px;
  padding:22px 24px;
  box-shadow:
    inset 0 1px 0 rgba(202,138,4,.12),
    0 24px 60px rgba(28,25,23,.18);
  animation:mcFloat 5s ease-in-out infinite alternate;
}
.mc1{width:222px;left:0;top:0;animation-delay:0s;}
.mc2{width:222px;left:0;bottom:0;animation-delay:2s;}
.mc3{width:262px;right:0;top:0;animation-delay:1s;}
.mc4{width:262px;right:0;bottom:0;animation-delay:3s;}
@keyframes mcFloat{from{transform:translateY(0);}to{transform:translateY(-10px);}}

/* Card label */
.mc-label{
  font-family:'Montserrat',sans-serif;
  font-size:.54rem;font-weight:700;
  letter-spacing:.18em;text-transform:uppercase;
  color:rgba(202,138,4,.55);
  margin-bottom:10px;
}
/* Card big number */
.mc-num{
  font-family:'Cormorant Garamond',serif;
  font-size:2.4rem;font-weight:700;
  color:#FAFAF9;letter-spacing:-.04em;
  line-height:1;margin-bottom:6px;
}
.mc-num span{color:#CA8A04;}
/* Card subtitle */
.mc-sub{
  font-family:'Montserrat',sans-serif;
  font-size:.64rem;color:rgba(250,250,249,.35);
  margin-bottom:18px;
}

/* Keyword tags */
.mc-tags{display:flex;flex-direction:column;gap:7px;margin-top:14px;}
.mc-tag{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(202,138,4,.1);
  border:1px solid rgba(202,138,4,.18);
  border-radius:6px;
  padding:6px 12px;
  font-family:'JetBrains Mono',monospace;
  font-size:.68rem;color:rgba(250,250,249,.7);
}
.mc-tag-pos{
  font-weight:700;color:#CA8A04;min-width:20px;
}

/* Bar chart */
.mc-bars{
  display:flex;align-items:flex-end;gap:5px;
  height:56px;margin-top:16px;
}
.mc-bar{
  flex:1;border-radius:3px 3px 0 0;
  background:rgba(202,138,4,.18);
  transition:background .3s;
}
.mc-bar.active{background:#CA8A04;}
.mc-bar:nth-child(1){height:22%;}
.mc-bar:nth-child(2){height:35%;}
.mc-bar:nth-child(3){height:48%;}
.mc-bar:nth-child(4){height:62%;}
.mc-bar:nth-child(5){height:78%;}
.mc-bar:nth-child(6){height:100%;}

/* Line chart */
.mc-line-wrap{margin-top:16px;position:relative;}
.mc-line-wrap svg{width:100%;display:block;}

/* Card divider */
.mc-divider{
  height:1px;
  background:rgba(202,138,4,.1);
  margin:14px 0;
}
/* Bar fill animation */
@keyframes barFill{from{height:0%;}to{}}
.mc-bar{animation:barFill .8s cubic-bezier(.22,1,.36,1) both;}
.mc-bar:nth-child(1){animation-delay:.1s;}
.mc-bar:nth-child(2){animation-delay:.2s;}
.mc-bar:nth-child(3){animation-delay:.3s;}
.mc-bar:nth-child(4){animation-delay:.4s;}
.mc-bar:nth-child(5){animation-delay:.5s;}
.mc-bar:nth-child(6){animation-delay:.6s;}
/* Line draw animation */
.mc-line-wrap polyline{
  stroke-dasharray:400;
  stroke-dashoffset:400;
  animation:lineDraw 1.4s cubic-bezier(.22,1,.36,1) forwards .4s;
}
@keyframes lineDraw{to{stroke-dashoffset:0;}}
/* Progress bar fill */
@keyframes progFill{from{width:0%;}to{}}
.mc2 .prog-bar-inner{animation:progFill 1.2s cubic-bezier(.22,1,.36,1) forwards .3s;}
/* Card entrance */
.mc{opacity:0;animation:mcFloat 5s ease-in-out infinite alternate,mcIn .6s ease forwards;}
.mc1{animation-delay:0s,.9s;}
.mc2{animation-delay:2s,1.1s;}
.mc3{animation-delay:1s,1.3s;}
.mc4{animation-delay:3s,1.5s;}
@keyframes mcIn{from{opacity:0;transform:translateY(20px);}to{opacity:1;transform:translateY(0);}}

/* Live dot */
.mc-live{
  display:flex;align-items:center;gap:6px;
  font-family:'Montserrat',sans-serif;
  font-size:.58rem;font-weight:700;color:#4ADE80;
  margin-bottom:14px;
}
.mc-live-dot{
  width:6px;height:6px;border-radius:50%;background:#4ADE80;
  animation:livePulse 2s infinite;
}

/* ── CASE STUDIES ────────────────────────────────────────── */
/* ── CASE STUDIES — ENHANCED ─────────────────────────────── */
.cases{
  padding:120px 80px;
  background:var(--cream);
  position:relative;overflow:hidden;
}
.cases::before{
  content:'';position:absolute;
  width:500px;height:500px;
  background:radial-gradient(circle,rgba(202,138,4,.05) 0%,transparent 65%);
  bottom:-150px;left:-100px;pointer-events:none;
}
.cases-hd{
  display:flex;align-items:flex-end;
  justify-content:space-between;
  margin-bottom:56px;
  position:relative;z-index:1;
}
.cases-link{
  font-family:'Montserrat',sans-serif;
  font-size:.72rem;font-weight:700;
  letter-spacing:.08em;text-transform:uppercase;
  color:#CA8A04;
  display:flex;align-items:center;gap:8px;
  padding:10px 20px;
  border:1px solid rgba(202,138,4,.3);
  border-radius:100px;
  transition:background .25s,gap .2s,box-shadow .25s;
}
.cases-link:hover{
  background:rgba(202,138,4,.08);
  gap:14px;
  box-shadow:0 4px 16px rgba(202,138,4,.15);
}
.cases-grid{
  display:grid;
  grid-template-columns:1.4fr 1fr;
  grid-template-rows:auto auto;
  gap:20px;
  position:relative;z-index:1;
}

/* Base card */
.case-card{
  position:relative;
  border-radius:22px;
  overflow:hidden;
  cursor:default;
  /* Gold shimmer line on top — hidden by default */
  box-shadow:0 0 0 1px rgba(28,25,23,.06),0 8px 32px rgba(28,25,23,.08);
  transition:box-shadow .45s cubic-bezier(.22,1,.36,1),transform .45s cubic-bezier(.22,1,.36,1);
}
.case-card::before{
  content:'';
  position:absolute;top:0;left:0;right:0;
  height:2px;z-index:3;
  background:linear-gradient(90deg,transparent,#CA8A04,#D4A853,transparent);
  opacity:0;
  transition:opacity .4s;
}
.case-card:hover{
  transform:translateY(-5px);
  box-shadow:0 0 0 1px rgba(202,138,4,.2),0 32px 80px rgba(28,25,23,.15);
}
.case-card:hover::before{opacity:1;}
.case-card.big{grid-row:span 2;}

/* Photo */
.case-card img{
  width:100%;height:100%;
  object-fit:cover;
  min-height:280px;
  transition:transform .7s cubic-bezier(.22,1,.36,1),filter .5s;
}
.case-card.big img{min-height:560px;}
.case-card:hover img{transform:scale(1.06);filter:brightness(1.05) saturate(1.1);}

/* Overlay — richer gradient */
.case-overlay{
  position:absolute;inset:0;
  background:
    linear-gradient(to top,
      rgba(11,11,21,.95) 0%,
      rgba(11,11,21,.55) 40%,
      rgba(11,11,21,.1) 70%,
      transparent 100%);
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:28px 32px;
  transition:background .4s;
}
.case-card:hover .case-overlay{
  background:
    linear-gradient(to top,
      rgba(11,11,21,.98) 0%,
      rgba(11,11,21,.65) 45%,
      rgba(11,11,21,.15) 75%,
      transparent 100%);
}

/* Industry tag — gold pill */
.case-industry{
  font-family:'Montserrat',sans-serif;
  font-size:.58rem;font-weight:700;
  letter-spacing:.14em;text-transform:uppercase;
  color:#CA8A04;
  background:rgba(202,138,4,.12);
  border:1px solid rgba(202,138,4,.25);
  border-radius:100px;
  padding:4px 12px;
  display:inline-block;
  margin-bottom:12px;
  align-self:flex-start;
}

/* Title */
.case-title{
  font-family:'Cormorant Garamond',serif;
  font-size:1.35rem;font-weight:600;
  color:#fff;line-height:1.25;
  margin-bottom:20px;
  transition:color .3s;
}
.case-card.big .case-title{font-size:2rem;}
.case-card:hover .case-title{color:#FAFAF9;}

/* Metrics — glass panel */
.case-metrics{
  display:flex;gap:0;
  margin-bottom:20px;
  background:rgba(250,250,249,.07);
  border:1px solid rgba(250,250,249,.1);
  border-radius:12px;
  padding:12px 16px;
  backdrop-filter:blur(8px);
}
.case-metric-item{
  flex:1;
  padding:0 16px;
}
.case-metric-item:not(:last-child){
  border-right:1px solid rgba(250,250,249,.1);
}
.case-metric-item:first-child{padding-left:0;}
.case-m-val{
  font-family:'Cormorant Garamond',serif;
  font-size:1.8rem;font-weight:700;
  color:#CA8A04;
  letter-spacing:-.03em;line-height:1;
}
.case-card.big .case-m-val{font-size:2.2rem;}
.case-m-key{
  font-family:'Montserrat',sans-serif;
  font-size:.6rem;color:rgba(250,250,249,.45);
  margin-top:4px;letter-spacing:.06em;text-transform:uppercase;
}

/* Read more link */
.case-more{
  display:inline-flex;align-items:center;gap:8px;
  font-family:'Montserrat',sans-serif;
  font-size:.68rem;font-weight:700;
  letter-spacing:.08em;text-transform:uppercase;
  color:rgba(250,250,249,.45);
  transition:color .25s,gap .25s;
}
.case-more svg{
  width:14px;height:14px;
  stroke:currentColor;stroke-width:2.5;
  stroke-linecap:round;stroke-linejoin:round;
  transition:transform .25s;
}
.case-card:hover .case-more{color:#CA8A04;gap:12px;}
.case-card:hover .case-more svg{transform:translateX(4px);}

/* ── TEAM ────────────────────────────────────────────────── */
.team{padding:120px 80px;background:var(--cream2);}
.team-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
  margin-top:64px;
}
.team-card{
  position:relative;
  border-radius:var(--r2);
  overflow:hidden;
  cursor:default;
}
.team-card img{
  width:100%;
  aspect-ratio:3/4;
  object-fit:cover;
  object-position:top;
  transition:transform .5s ease,filter .5s;
}
.team-card:hover img{transform:scale(1.04);filter:grayscale(15%);}
.team-info{
  position:absolute;bottom:0;left:0;right:0;
  padding:28px 24px;
  background:linear-gradient(to top,rgba(11,11,21,.85),transparent);
}
.team-name{
  font-family:'Playfair Display',serif;
  font-size:1.1rem;font-weight:600;
  color:#fff;margin-bottom:4px;
}
.team-role{font-size:.75rem;color:rgba(255,255,255,.55);}
.team-hover{
  position:absolute;inset:0;
  background:rgba(202,138,4,.92);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:32px;
  opacity:0;
  transition:opacity .35s ease;
}
.team-card:hover .team-hover{opacity:1;}
.team-hover-name{
  font-family:'Playfair Display',serif;
  font-size:1.3rem;font-weight:600;
  color:#fff;margin-bottom:8px;
}
.team-hover-role{font-size:.75rem;color:rgba(255,255,255,.6);margin-bottom:24px;}
.team-hover-spec{
  font-size:.82rem;color:rgba(255,255,255,.85);
  line-height:1.7;text-align:center;
  max-width:240px;
}
.team-skills{display:flex;flex-wrap:wrap;gap:6px;margin-top:20px;justify-content:center;}
.team-skill{
  font-size:.65rem;font-weight:600;
  background:rgba(255,255,255,.15);
  color:#fff;
  padding:3px 10px;border-radius:100px;
}

/* ── TESTIMONIAL ─────────────────────────────────────────── */
/* ── TESTIMONIALS — DARK LUXURY ──────────────────────────── */
.testi{
  padding:120px 80px;
  background:#1C1917;
  position:relative;
  overflow:hidden;
}
/* Subtle grain on dark bg */
.testi::after{
  content:'';position:absolute;inset:0;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='4'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E");
  opacity:.025;pointer-events:none;z-index:0;
}
/* Gold ambient glow */
.testi::before{
  content:'';position:absolute;
  width:600px;height:600px;
  background:radial-gradient(circle,rgba(202,138,4,.06) 0%,transparent 70%);
  top:-100px;left:50%;transform:translateX(-50%);
  pointer-events:none;z-index:0;
}
.testi-wrap{max-width:1280px;margin:0 auto;position:relative;z-index:1;}

/* Section header */
.testi-hd{text-align:center;margin-bottom:72px;}
.testi-label{
  font-family:'Montserrat',sans-serif;
  font-size:.58rem;font-weight:700;
  letter-spacing:.22em;text-transform:uppercase;
  color:#CA8A04;
  display:flex;align-items:center;justify-content:center;gap:10px;
  margin-bottom:20px;
}
.testi-label::before,.testi-label::after{content:'';width:28px;height:1px;background:#CA8A04;opacity:.5;}
.testi-hd-title{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2.2rem,3.5vw,3.6rem);
  font-weight:600;font-style:italic;
  color:#FAFAF9;line-height:1.1;
}
.testi-hd-title em{font-style:normal;color:#CA8A04;}

/* Featured quote */
.testi-featured{
  background:rgba(250,250,249,.04);
  border:1px solid rgba(202,138,4,.18);
  border-radius:20px;
  padding:56px 64px;
  margin-bottom:32px;
  position:relative;
  overflow:hidden;
}
.testi-featured::before{
  content:'\201C';
  position:absolute;top:-20px;left:32px;
  font-family:'Cormorant Garamond',serif;
  font-size:12rem;font-weight:700;
  color:rgba(202,138,4,.08);
  line-height:1;pointer-events:none;
}
.testi-feat-stars{
  display:flex;gap:4px;margin-bottom:24px;
}
.testi-star{
  color:#CA8A04;font-size:1rem;
}
.testi-feat-q{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(1.3rem,2.2vw,1.9rem);
  font-weight:400;font-style:italic;
  color:rgba(250,250,249,.88);
  line-height:1.55;
  margin-bottom:36px;
  position:relative;z-index:1;
}
.testi-feat-author{
  display:flex;align-items:center;gap:14px;
}
.testi-feat-av{
  width:48px;height:48px;border-radius:50%;
  object-fit:cover;object-position:top;
  border:2px solid rgba(202,138,4,.3);
  flex-shrink:0;
}
.testi-feat-name{
  font-family:'Montserrat',sans-serif;
  font-size:.78rem;font-weight:700;
  color:#FAFAF9;
}
.testi-feat-role{
  font-family:'Montserrat',sans-serif;
  font-size:.64rem;color:rgba(250,250,249,.4);
  margin-top:3px;
}
.testi-feat-badge{
  margin-left:auto;
  background:rgba(202,138,4,.12);
  border:1px solid rgba(202,138,4,.2);
  border-radius:100px;
  padding:5px 14px;
  font-family:'Montserrat',sans-serif;
  font-size:.58rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;
  color:#CA8A04;
}

/* 3 review cards */
.testi-cards{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:20px;
}
.testi-card{
  background:rgba(250,250,249,.03);
  border:1px solid rgba(250,250,249,.07);
  border-radius:16px;
  padding:28px;
  transition:background .3s,border-color .3s,transform .3s;
  cursor:default;
}
.testi-card:hover{
  background:rgba(250,250,249,.06);
  border-color:rgba(202,138,4,.2);
  transform:translateY(-4px);
}
.testi-card-stars{display:flex;gap:3px;margin-bottom:18px;}
.testi-card-q{
  font-family:'Cormorant Garamond',serif;
  font-size:1.05rem;font-style:italic;
  color:rgba(250,250,249,.75);
  line-height:1.65;
  margin-bottom:24px;
}
.testi-card-author{
  display:flex;align-items:center;gap:12px;
  padding-top:20px;
  border-top:1px solid rgba(250,250,249,.07);
}
.testi-card-av{
  width:38px;height:38px;border-radius:50%;
  background:linear-gradient(135deg,#CA8A04,#92700A);
  display:flex;align-items:center;justify-content:center;
  font-family:'Cormorant Garamond',serif;
  font-size:.9rem;font-weight:700;color:#fff;
  flex-shrink:0;
}
.testi-card-name{
  font-family:'Montserrat',sans-serif;
  font-size:.72rem;font-weight:700;color:#FAFAF9;
}
.testi-card-role{
  font-family:'Montserrat',sans-serif;
  font-size:.6rem;color:rgba(250,250,249,.35);margin-top:2px;
}
.testi-card-platform{
  margin-left:auto;
  display:flex;align-items:center;
  opacity:.7;
}
.testi-feat-badge{
  display:flex;align-items:center;gap:6px;
}

/* Rating summary bar */
.testi-summary{
  display:flex;align-items:center;justify-content:center;gap:48px;
  margin-top:60px;
  padding-top:48px;
  border-top:1px solid rgba(250,250,249,.07);
}
.testi-sum-item{text-align:center;}
.testi-sum-num{
  font-family:'Cormorant Garamond',serif;
  font-size:2.4rem;font-weight:700;
  color:#CA8A04;line-height:1;margin-bottom:4px;
}
.testi-sum-label{
  font-family:'Montserrat',sans-serif;
  font-size:.58rem;color:rgba(250,250,249,.35);
  font-weight:600;letter-spacing:.1em;text-transform:uppercase;
}
.testi-sum-sep{
  width:1px;height:48px;
  background:rgba(250,250,249,.08);
}

/* ── RESULTS STRIP ───────────────────────────────────────── */
/* ── FAQ ─────────────────────────────────────────────────── */
.faq{
  padding:120px 80px;
  background:var(--cream);
  position:relative;overflow:hidden;
}
.faq::before{
  content:'';position:absolute;
  width:600px;height:600px;
  background:radial-gradient(circle,rgba(202,138,4,.05) 0%,transparent 65%);
  top:-200px;right:-100px;pointer-events:none;
}
.faq-in{max-width:800px;margin:0 auto;position:relative;z-index:1;}
.faq-hd{text-align:center;margin-bottom:64px;}
.faq-list{display:flex;flex-direction:column;gap:0;}
.faq-item{
  border-bottom:1px solid rgba(28,25,23,.08);
}
.faq-item:first-child{border-top:1px solid rgba(28,25,23,.08);}
.faq-btn{
  width:100%;
  display:flex;align-items:center;justify-content:space-between;
  gap:24px;
  padding:24px 0;
  background:none;border:none;cursor:pointer;
  text-align:left;
}
.faq-q{
  font-family:'Cormorant Garamond',serif;
  font-size:1.1rem;font-weight:600;
  color:#1C1917;line-height:1.3;
  transition:color .25s;
}
.faq-btn:hover .faq-q{color:#CA8A04;}
.faq-icon{
  flex-shrink:0;
  width:28px;height:28px;
  border:1.5px solid rgba(202,138,4,.3);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  transition:background .25s,border-color .25s,transform .35s;
}
.faq-icon svg{
  width:12px;height:12px;
  stroke:#CA8A04;stroke-width:2.5;
  stroke-linecap:round;stroke-linejoin:round;
  transition:transform .35s cubic-bezier(.22,1,.36,1);
}
.faq-item.open .faq-icon{background:#CA8A04;border-color:#CA8A04;}
.faq-item.open .faq-icon svg{stroke:#fff;transform:rotate(180deg);}
.faq-item.open .faq-q{color:#CA8A04;}
.faq-body{
  max-height:0;overflow:hidden;
  transition:max-height .45s cubic-bezier(.22,1,.36,1),padding .35s;
  padding:0;
}
.faq-item.open .faq-body{max-height:400px;padding-bottom:24px;}
.faq-a{
  font-family:'Montserrat',sans-serif;
  font-size:.84rem;color:#6A6977;
  line-height:1.85;
}
.faq-a strong{color:#1C1917;font-weight:700;}

/* ── RESULTS ─────────────────────────────────────────────── */
.results{
  padding:100px 80px;
  background:var(--dark);
}
.results-in{
  max-width:1280px;margin:0 auto;
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:2px;
}
.res-item{
  padding:56px 40px;
  background:rgba(255,255,255,.025);
  border:1px solid rgba(255,255,255,.05);
  text-align:center;
  transition:background .3s;
}
.res-item:hover{background:rgba(202,138,4,.08);}
.res-num{
  font-family:'Playfair Display',serif;
  font-size:clamp(2.8rem,4vw,4.5rem);
  font-weight:800;
  letter-spacing:-.05em;
  line-height:1;
  margin-bottom:12px;
}
.res-num.v{
  background:linear-gradient(135deg,#D4A853,#CA8A04);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.res-num.g{
  background:linear-gradient(135deg,#34D399,#00B87D);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.res-num.p{
  background:linear-gradient(135deg,#F472B6,#FF3E6C);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.res-num.y{
  background:linear-gradient(135deg,#FCD34D,#F59E0B);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.res-label{font-size:.78rem;color:rgba(255,255,255,.65);font-weight:500;}

/* ── PRICING ─────────────────────────────────────────────── */
.pricing{padding:120px 80px;background:var(--cream);}
.price-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:20px;margin-top:64px;
}
.pc{
  background:var(--cream2);
  border:1px solid var(--border);
  border-radius:var(--r2);
  padding:44px 36px;
  position:relative;
  transition:transform .3s,box-shadow .3s;
}
.pc:hover{transform:translateY(-6px);box-shadow:var(--sh2);}
.pc.hi{background:var(--dark);border-color:transparent;}
.pc-badge{
  position:absolute;top:-13px;left:50%;transform:translateX(-50%);
  background:linear-gradient(90deg,var(--violet),var(--pink));
  color:#fff;
  font-size:.65rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;
  padding:5px 16px;border-radius:100px;
  white-space:nowrap;
}
.pc-plan{
  font-size:.7rem;font-weight:700;
  letter-spacing:.14em;text-transform:uppercase;
  color:var(--muted);
  margin-bottom:24px;
}
.pc.hi .pc-plan{color:rgba(255,255,255,.4);}
.pc-price{
  display:flex;align-items:baseline;gap:2px;
  margin-bottom:4px;
}
.pc-dollar{font-size:1rem;font-weight:500;color:var(--muted);margin-top:6px;}
.pc.hi .pc-dollar{color:rgba(255,255,255,.35);}
.pc-num{
  font-family:'Playfair Display',serif;
  font-size:3.8rem;font-weight:800;
  letter-spacing:-.05em;line-height:1;
}
.pc.hi .pc-num{color:#fff;}
.pc-per{font-size:.8rem;color:var(--muted);margin-bottom:32px;}
.pc.hi .pc-per{color:rgba(255,255,255,.35);}
.pc-div{height:1px;background:var(--border);margin-bottom:28px;}
.pc.hi .pc-div{background:rgba(255,255,255,.08);}
.pc-feats{display:flex;flex-direction:column;gap:13px;margin-bottom:36px;}
.pc-feat{display:flex;align-items:center;gap:10px;font-size:.83rem;}
.pc.hi .pc-feat{color:rgba(255,255,255,.8);}
.pc-check{
  width:20px;height:20px;border-radius:50%;
  background:rgba(0,184,125,.15);
  display:flex;align-items:center;justify-content:center;
  font-size:.68rem;flex-shrink:0;
}
.pc.hi .pc-check{background:rgba(0,184,125,.2);}
.pc-btn{
  width:100%;padding:14px;
  border-radius:100px;
  font-size:.82rem;font-weight:600;
  letter-spacing:.03em;
  cursor:pointer;border:none;
  transition:transform .2s,box-shadow .2s,background .2s;
}
.pc-btn.dk{background:var(--dark);color:#fff;}
.pc-btn.dk:hover{background:var(--violet);box-shadow:0 8px 28px rgba(202,138,4,.4);}
.pc-btn.gr{background:linear-gradient(90deg,var(--violet),var(--pink));color:#fff;}
.pc-btn.gr:hover{box-shadow:0 8px 28px rgba(202,138,4,.5);transform:translateY(-2px);}
.pc-btn.bd{background:transparent;border:1.5px solid var(--border);color:var(--text);}
.pc-btn.bd:hover{border-color:var(--violet);color:var(--violet);}

/* ── CTA ─────────────────────────────────────────────────── */
.cta{
  display:grid;grid-template-columns:1fr 1fr;
  min-height:600px;
}
.cta-left{
  background:var(--dark);
  padding:100px 80px;
  display:flex;flex-direction:column;justify-content:center;
  position:relative;overflow:hidden;
}
.cta-left::before{
  content:'';position:absolute;
  width:400px;height:400px;
  background:var(--violet);
  border-radius:50%;filter:blur(140px);
  opacity:.12;bottom:-100px;left:-100px;
}
.cta-left > *{position:relative;z-index:1;}
.cta-tag{
  font-size:.68rem;font-weight:700;
  letter-spacing:.16em;text-transform:uppercase;
  color:rgba(255,255,255,.3);
  display:flex;align-items:center;gap:10px;
  margin-bottom:24px;
}
.cta-tag::before{content:'';width:20px;height:1px;background:rgba(255,255,255,.3);}
.cta-h2{
  font-family:'Playfair Display',serif;
  font-size:clamp(2rem,3.5vw,3.2rem);
  font-weight:700;
  color:#fff;
  letter-spacing:-.04em;
  line-height:1.1;
  margin-bottom:20px;
}
.cta-h2 em{font-style:italic;color:var(--violet);}
.cta-sub{
  font-size:.88rem;
  color:rgba(255,255,255,.45);
  line-height:1.8;
  margin-bottom:44px;
  max-width:380px;
}
.cta-form{display:flex;flex-direction:column;gap:12px;max-width:380px;}
.cta-inp{
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.1);
  border-radius:100px;
  padding:15px 24px;
  font-size:.85rem;color:#fff;
  outline:none;
  transition:border-color .2s,background .2s;
}
.cta-inp::placeholder{color:rgba(255,255,255,.25);}
.cta-inp:focus{border-color:var(--violet);background:rgba(255,255,255,.1);}
.cta-sbtn{
  background:linear-gradient(90deg,var(--violet),var(--pink));
  color:#fff;border:none;
  padding:16px 28px;
  border-radius:100px;
  font-size:.85rem;font-weight:600;
  cursor:pointer;
  transition:transform .2s,box-shadow .2s;
  align-self:flex-start;
}
.cta-sbtn:hover{transform:translateY(-3px);box-shadow:0 12px 36px rgba(202,138,4,.5);}
.cta-note{margin-top:14px;font-size:.72rem;color:rgba(255,255,255,.25);}
.cta-right{position:relative;overflow:hidden;}
.cta-right img{
  width:100%;height:100%;
  object-fit:cover;
}
.cta-right-overlay{
  position:absolute;inset:0;
  background:rgba(11,11,21,.3);
}

/* ── FOOTER ──────────────────────────────────────────────── */
footer{
  background:var(--dark2);
  padding:80px 80px 36px;
  border-top:1px solid rgba(255,255,255,.04);
}
.ft{
  display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;
  gap:60px;margin-bottom:64px;
}
.ft-logo{
  font-family:'Playfair Display',serif;
  font-size:1.4rem;font-weight:700;
  color:#fff;margin-bottom:14px;
}
.ft-logo em{font-style:italic;color:var(--violet);}
.ft-desc{font-size:.82rem;color:rgba(255,255,255,.62);line-height:1.8;max-width:260px;margin-bottom:28px;}
.ft-socials{display:flex;gap:10px;}
.ft-soc{
  width:38px;height:38px;
  background:rgba(255,255,255,.05);
  border-radius:10px;
  display:flex;align-items:center;justify-content:center;
  font-size:.85rem;color:rgba(255,255,255,.65);
  transition:background .2s,color .2s;cursor:pointer;
}
.ft-soc:hover{background:var(--violet);color:#fff;}
.ft-col-title{
  font-size:.68rem;font-weight:700;
  letter-spacing:.14em;text-transform:uppercase;
  color:rgba(255,255,255,.58);
  margin-bottom:20px;
}
.ft-links{display:flex;flex-direction:column;gap:10px;}
.ft-links a{font-size:.82rem;color:rgba(255,255,255,.45);transition:color .2s;}
.ft-links a:hover{color:#fff;}
.ft-bot{
  display:flex;align-items:center;justify-content:space-between;
  padding-top:28px;
  border-top:1px solid rgba(255,255,255,.05);
  font-size:.73rem;color:rgba(255,255,255,.2);
}

/* ── REVEAL ──────────────────────────────────────────────── */
.rv{opacity:0;transform:translateY(36px);transition:opacity .9s cubic-bezier(.22,1,.36,1),transform .9s cubic-bezier(.22,1,.36,1);}
.rv.on{opacity:1;transform:none;}
.d1{transition-delay:.1s!important}
.d2{transition-delay:.2s!important}
.d3{transition-delay:.3s!important}
.d4{transition-delay:.4s!important}

/* ── RESPONSIVE ──────────────────────────────────────────── */
/* ── TABLET 1024px ──────────────────────────────────────── */
@media(max-width:1024px){
  /* Nav */
  nav,nav.on{padding:14px 32px;}
  .nav-phone{display:none;}
  .nav-divider{display:none;}
  .nlinks{gap:4px;}
  .nlinks a{padding:7px 12px;font-size:.58rem;}

  /* Hero — photo top, content below */
  .hero{grid-template-columns:1fr;grid-template-rows:380px auto;height:auto;min-height:auto;}
  .h-right{display:block;order:1;height:380px;}
  .h-photo img{object-position:center 35%;}
  .h-left{order:2;padding:48px 40px 64px;}
  .h-h1{font-size:clamp(2.4rem,5vw,3.8rem);}
  .h-stats{gap:0;}
  .h-stat:not(:last-child){padding-right:16px;margin-right:16px;}
  /* Rank card — solid dark strip below photo */
  .h-right{overflow:visible;}
  .h-card{
    display:block;
    position:absolute;
    top:380px;bottom:auto;
    left:0;right:0;transform:none;
    width:100%;
    border-radius:0 0 16px 16px;
    background:#1C1917;
    backdrop-filter:none;-webkit-backdrop-filter:none;
    border:none;
    border-top:2px solid #CA8A04;
    padding:16px 20px;
    opacity:1;animation:none;
    box-shadow:0 8px 24px rgba(28,25,23,.25);
  }
  .h-card .h-card-title{color:rgba(250,250,249,.6);}
  .h-card .h-kw{color:rgba(250,250,249,.85);}
  .h-card .h-card-ft{color:rgba(250,250,249,.45);}
  .h-card-rows{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:10px;}
  .h-row{background:rgba(250,250,249,.07);padding:8px 10px;}
  .h-kw{font-size:.66rem;}
  .h-left{margin-top:150px;}
  .h-chip,.h-vert-label,.h-scroll-ind{display:none;}
  /* Award badge — solid dark, below nav */
  .h-award{
    display:block;
    top:60px;right:16px;
    background:#1C1917;
    backdrop-filter:none;-webkit-backdrop-filter:none;
    border:1px solid rgba(202,138,4,.35);
    border-top:2px solid #CA8A04;
    border-radius:12px;
    padding:12px 16px;
    box-shadow:0 8px 24px rgba(28,25,23,.3);
    opacity:1;animation:none;
  }
  .h-award-num{font-size:1.8rem;}
  .h-award-label{color:rgba(250,250,249,.7);font-size:.54rem;}

  /* Sections */
  .services,.manifesto,.cases,.team,.testi,.pricing,.results{padding:80px 40px;}
  .cta-left{padding:80px 40px;}
  footer{padding:60px 40px 28px;}

  /* Services */
  .svc-hd{grid-template-columns:1fr;gap:16px;margin-bottom:48px;}
  .svc-grid{grid-template-columns:1fr 1fr;}

  /* Manifesto — stack, show data cards as 2x2 grid */
  .manifesto{grid-template-columns:1fr;gap:40px;}
  .manifesto-right{display:block!important;opacity:1!important;transform:none!important;}
  .mf-cards{
    position:static!important;height:auto!important;
    display:grid!important;grid-template-columns:1fr 1fr;
    gap:14px;
  }
  .mc{
    position:static!important;
    width:auto!important;left:auto!important;right:auto!important;
    top:auto!important;bottom:auto!important;
    opacity:1!important;
    animation:mcFloat 5s ease-in-out infinite alternate!important;
  }
  .mc1{animation-delay:0s!important;}
  .mc2{animation-delay:1s!important;}
  .mc3{animation-delay:.5s!important;}
  .mc4{animation-delay:1.5s!important;}

  /* Cases */
  .cases-grid{grid-template-columns:1fr;}
  .case-card.big{grid-row:span 1;}

  /* Team */
  .team-grid{grid-template-columns:1fr 1fr;}

  /* Testimonials */
  .testi-cards{grid-template-columns:1fr 1fr;}
  .testi-featured{padding:36px 32px;}
  .testi-summary{gap:24px;}

  /* Results */
  .results-in{grid-template-columns:1fr 1fr;}

  /* Pricing */
  .price-grid{grid-template-columns:1fr 1fr;}
  .pc.hi{transform:none;}

  /* CTA */
  .cta{grid-template-columns:1fr;}
  .cta-right{display:none;}

  /* Footer */
  .ft{grid-template-columns:1fr 1fr;gap:36px;}
}

/* ── MOBILE 640px ───────────────────────────────────────── */
@media(max-width:640px){
  /* Nav — logo + CTA only (standard mobile) */
  nav,nav.on{padding:14px 20px;}
  .nlinks{display:none;}
  .nav-phone{display:none;}
  .nav-divider{display:none;}
  .nav-right{gap:0;}
  .ncta{padding:9px 16px;font-size:.58rem;letter-spacing:.08em;}
  .nlogo-sub{display:none;}

  /* Hero */
  .hero{grid-template-rows:260px auto;}
  .h-right{height:260px;overflow:visible;}
  .h-right{height:260px;overflow:visible;}
  .h-card{
    display:block;
    position:absolute;
    top:260px;bottom:auto;
    left:0;right:0;transform:none;
    width:100%;border-radius:0 0 14px 14px;
    background:#1C1917;
    backdrop-filter:none;-webkit-backdrop-filter:none;
    border:none;border-top:2px solid #CA8A04;
    padding:14px 16px;
    opacity:1;animation:none;
    box-shadow:0 8px 20px rgba(28,25,23,.2);
  }
  .h-card .h-card-title{color:rgba(250,250,249,.6);}
  .h-card .h-kw{color:rgba(250,250,249,.85);}
  .h-card-rows{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-bottom:8px;}
  .h-row{background:rgba(250,250,249,.07);padding:7px 8px;}
  .h-kw{font-size:.62rem;}
  .h-pos{font-size:.68rem;}
  .h-chg{font-size:.6rem;}
  .h-left{margin-top:125px;padding-top:0;}
  /* Award badge mobile */
  .h-award{
    display:block;
    top:52px;right:12px;
    background:#1C1917;
    backdrop-filter:none;-webkit-backdrop-filter:none;
    border:1px solid rgba(202,138,4,.3);
    border-top:2px solid #CA8A04;
    border-radius:10px;
    padding:10px 14px;
    box-shadow:0 6px 20px rgba(28,25,23,.25);
    opacity:1;animation:none;
  }
  .h-award-num{font-size:1.5rem;}
  .h-award-label{color:rgba(250,250,249,.7);font-size:.5rem;margin-top:4px;}
  .h-left{padding:32px 20px 48px;}
  .h-h1{font-size:1.9rem;line-height:1.1;}
  .h-sub{font-size:.8rem;max-width:100%;}
  .h-stats{flex-wrap:wrap;gap:0;row-gap:16px;}
  .h-stat{min-width:50%;padding-right:0!important;margin-right:0!important;border-right:none!important;}
  .h-snum{font-size:1.5rem;}
  .h-btns{flex-direction:column;align-items:flex-start;}
  .h-btn-p,.h-btn-g{width:100%;justify-content:center;}

  /* Marquee */
  .marquee-strip{padding:14px 0;}

  /* Sections */
  .services,.manifesto,.cases,.team,.testi,.pricing,.results,.faq{padding:60px 20px;}
  .cta-left{padding:60px 20px;}
  footer{padding:48px 20px 24px;}

  /* Services */
  .svc-hd{margin-bottom:32px;}
  .svc-grid{grid-template-columns:1fr;}
  .svc-card{padding:26px 22px 22px;}
  .sec-h2{font-size:2rem;}

  /* Manifesto */
  .manifesto-deco{font-size:5rem;}
  .manifesto-q{font-size:1.65rem;}
  .manifesto-principles{gap:10px;}
  .manifesto-principle{padding:14px 16px;}
  .manifesto-right{display:block!important;opacity:1!important;transform:none!important;}
  .mf-cards{
    position:static!important;height:auto!important;
    display:grid!important;grid-template-columns:1fr 1fr;
    gap:10px;
  }
  .mc{
    position:static!important;width:auto!important;
    left:auto!important;right:auto!important;
    top:auto!important;bottom:auto!important;
    opacity:1!important;
    animation:mcFloat 5s ease-in-out infinite alternate!important;
    padding:16px 14px;
  }
  .mc-num{font-size:1.6rem;}
  .mc-label{font-size:.48rem;letter-spacing:.12em;}
  .mc-tags{gap:5px;}
  .mc-tag{padding:5px 8px;font-size:.6rem;}

  /* Cases */
  .cases-hd{flex-direction:column;align-items:flex-start;gap:12px;}
  .case-title{font-size:1.1rem;}
  .case-card.big .case-title{font-size:1.3rem;}

  /* Team */
  .team-grid{grid-template-columns:1fr 1fr;}
  .team-card img{aspect-ratio:3/4;}

  /* Testimonials */
  .testi-cards{grid-template-columns:1fr;}
  .testi-featured{padding:24px 20px;}
  .testi-feat-q{font-size:1rem;}
  .testi-hd-title{font-size:1.8rem;}
  .testi-summary{flex-wrap:wrap;gap:16px;}
  .testi-sum-sep{display:none;}
  .testi-sum-item{min-width:calc(50% - 8px);}

  /* Results */
  .results-in{grid-template-columns:1fr 1fr;}
  .res-item{padding:32px 16px;}
  .results{padding:60px 20px;}

  /* Pricing */
  .price-grid{grid-template-columns:1fr;}
  .pc.hi{transform:none;}
  .pc-badge{font-size:.56rem;}

  /* Process */
  .process-steps{grid-template-columns:1fr 1fr;gap:32px;}
  .process-steps::before{display:none;}

  /* Footer */
  .ft{grid-template-columns:1fr;}
  .ft-bot{flex-direction:column;gap:8px;text-align:center;}

  /* CTA */
  .cta-form{gap:10px;}
  .cta-sbtn{align-self:stretch;text-align:center;justify-content:center;}
}

/* ── PROCESS SECTION ─────────────────────────────────────── */
.tss-process{
  padding:120px 80px;
  background:var(--dark);
  position:relative;overflow:hidden;
}
.tss-process::before{
  content:'';position:absolute;
  width:700px;height:700px;
  background:radial-gradient(circle,rgba(202,138,4,.07) 0%,transparent 65%);
  top:-200px;left:50%;transform:translateX(-50%);
  pointer-events:none;
}
.tss-proc-inner{max-width:1280px;margin:0 auto;position:relative;z-index:1;}
.tss-proc-hd{text-align:center;margin-bottom:72px;}
.tss-proc-steps{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:2px;
  position:relative;
}
.tss-proc-card{
  background:rgba(250,250,249,.03);
  border:1px solid rgba(250,250,249,.07);
  border-radius:0;
  padding:44px 32px 40px;
  position:relative;
  overflow:hidden;
  transition:background .35s,border-color .35s,transform .35s;
  cursor:default;
}
.tss-proc-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent,#CA8A04,#D4A853,transparent);
  opacity:0;transition:opacity .4s;
}
.tss-proc-card:hover{background:rgba(202,138,4,.06);border-color:rgba(202,138,4,.2);}
.tss-proc-card:hover::before{opacity:1;}
.tss-proc-card:first-child{border-radius:16px 0 0 16px;}
.tss-proc-card:last-child{border-radius:0 16px 16px 0;}
.tss-proc-ghost{
  font-family:'Cormorant Garamond',serif;
  font-size:6rem;font-weight:700;line-height:1;
  color:rgba(202,138,4,.08);
  position:absolute;top:-10px;right:16px;
  user-select:none;pointer-events:none;
  letter-spacing:-.04em;
}
.tss-proc-icon-wrap{
  width:44px;height:44px;
  background:rgba(202,138,4,.1);
  border:1px solid rgba(202,138,4,.2);
  border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  margin-bottom:20px;
  position:relative;z-index:1;
}
.tss-proc-card-title{
  font-family:'Cormorant Garamond',serif;
  font-size:1.2rem;font-weight:600;
  color:#FAFAF9;line-height:1.3;
  margin-bottom:14px;
  position:relative;z-index:1;
}
.tss-proc-card-desc{
  font-family:'Montserrat',sans-serif;
  font-size:.72rem;color:rgba(250,250,249,.45);
  line-height:1.9;
  position:relative;z-index:1;
}
.tss-proc-arrow{
  position:absolute;bottom:20px;right:20px;
  font-size:1.2rem;color:rgba(202,138,4,.3);
  transition:color .3s,transform .3s;
}
.tss-proc-card:hover .tss-proc-arrow{color:#CA8A04;transform:translateX(4px);}

@media(max-width:1024px){
  .tss-process{padding:80px 40px;}
  .tss-proc-steps{grid-template-columns:1fr 1fr;gap:16px;}
  .tss-proc-card,.tss-proc-card:first-child,.tss-proc-card:last-child{border-radius:16px;}
}
@media(max-width:640px){
  .tss-process{padding:60px 20px;}
  .tss-proc-steps{grid-template-columns:1fr;}
  .tss-proc-hd{margin-bottom:40px;}
  .tss-proc-ghost{font-size:4rem;}
}

/* ── INDUSTRIES & AREAS SECTION ──────────────────────────── */
.tss-areas{
  padding:120px 80px;
  background:linear-gradient(155deg,#FAFAF9 0%,#F5EEE2 50%,#FAFAF9 100%);
  position:relative;overflow:hidden;
}
.tss-areas::before{
  content:'';position:absolute;
  width:600px;height:600px;
  background:radial-gradient(circle,rgba(202,138,4,.06) 0%,transparent 65%);
  bottom:-200px;right:-100px;pointer-events:none;
}
.tss-areas-inner{max-width:1280px;margin:0 auto;position:relative;z-index:1;}
.tss-areas-hd{margin-bottom:64px;}
.tss-areas-sub{
  font-family:'Montserrat',sans-serif;
  font-size:.84rem;color:#6A6977;line-height:1.85;
  margin-top:16px;max-width:560px;
}
.tss-areas-body{
  display:grid;grid-template-columns:1fr 1px 1fr;
  gap:64px;align-items:start;
}
.tss-areas-divider{background:rgba(28,25,23,.08);}
.tss-areas-col-label{
  display:flex;align-items:center;gap:10px;
  font-family:'Montserrat',sans-serif;
  font-size:.58rem;font-weight:700;
  letter-spacing:.18em;text-transform:uppercase;
  color:#CA8A04;
  margin-bottom:28px;
}
.tss-areas-tags{display:flex;flex-wrap:wrap;gap:10px;}
.tss-area-tag{
  font-family:'Montserrat',sans-serif;
  font-size:.7rem;font-weight:600;
  color:#44403C;
  background:#FFFFFF;
  border:1px solid rgba(28,25,23,.1);
  border-radius:100px;
  padding:8px 18px;
  transition:background .25s,border-color .25s,color .25s,box-shadow .25s;
  cursor:default;
  box-shadow:0 2px 8px rgba(28,25,23,.05);
}
.tss-area-tag:hover{
  background:rgba(202,138,4,.08);
  border-color:rgba(202,138,4,.3);
  color:#CA8A04;
  box-shadow:0 4px 16px rgba(202,138,4,.12);
}
.tss-area-tag--loc{
  background:rgba(202,138,4,.06);
  border-color:rgba(202,138,4,.18);
  color:#92700A;
}
.tss-area-tag--loc:hover{
  background:rgba(202,138,4,.15);
  border-color:#CA8A04;
  color:#1C1917;
}
@media(max-width:1024px){
  .tss-areas{padding:80px 40px;}
  .tss-areas-body{grid-template-columns:1fr;gap:40px;}
  .tss-areas-divider{height:1px;width:100%;}
}
@media(max-width:640px){
  .tss-areas{padding:60px 20px;}
  .tss-areas-hd{margin-bottom:40px;}
  .tss-area-tag{font-size:.64rem;padding:7px 14px;}
}

/* ── SPLIT SECTION MOBILE ────────────────────────────────── */
@media(max-width:1024px){.tss-split-section{grid-template-columns:1fr!important;}}
@media(max-width:640px){.tss-split-section>div{padding:64px 24px!important;}}

/* ── PROCESS GRID MOBILE ─────────────────────────────────── */
@media(max-width:1024px){#how-we-work div[style*="repeat(4,1fr)"]{grid-template-columns:1fr 1fr!important;}}
@media(max-width:640px){#how-we-work div[style*="repeat(4,1fr)"]{grid-template-columns:1fr!important;}#how-we-work{padding:60px 20px!important;}}

/* ── HAMBURGER BUTTON ────────────────────────────────────── */
.nav-burger{
  display:none;
  flex-direction:column;justify-content:center;align-items:center;
  gap:5px;
  width:40px;height:40px;
  background:none;border:none;cursor:pointer;padding:4px;
  flex-shrink:0;
}
.nav-burger span{
  display:block;width:22px;height:2px;
  background:#1C1917;border-radius:2px;
  transition:transform .3s,opacity .3s;
}
.nav-burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.nav-burger.open span:nth-child(2){opacity:0;}
.nav-burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

/* ── MOBILE MENU ─────────────────────────────────────────── */
.mobile-menu{
  display:none;
  position:fixed;top:0;left:0;right:0;bottom:0;
  background:rgba(250,250,249,.98);
  backdrop-filter:blur(20px);
  z-index:800;
  opacity:0;
  transform:translateY(-12px);
  transition:opacity .3s,transform .3s;
  pointer-events:none;
}
.mobile-menu.open{
  opacity:1;transform:none;pointer-events:all;
}
.mobile-menu-inner{
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  height:100%;
  gap:8px;padding:80px 24px 40px;
}
.mobile-menu-inner a{
  font-family:'Montserrat',sans-serif;
  font-size:1rem;font-weight:600;
  letter-spacing:.08em;text-transform:uppercase;
  color:#1C1917;
  padding:14px 0;
  border-bottom:1px solid rgba(28,25,23,.07);
  width:100%;text-align:center;
  transition:color .2s;
  text-decoration:none;
}
.mobile-menu-inner a:hover{color:#CA8A04;}
.mobile-menu-inner .nsep{display:none;}
.mobile-cta{
  margin-top:16px!important;
  background:#CA8A04!important;color:#fff!important;
  border-radius:4px!important;border:none!important;
  padding:14px 32px!important;
}
.mobile-phone{
  margin-top:12px;
  font-family:'Montserrat',sans-serif;
  font-size:.82rem;font-weight:700;
  color:#1C1917;
  display:flex;align-items:center;gap:8px;
}

@media(max-width:1024px){
  .nav-burger{display:flex;}
  .mobile-menu{display:block;}
}

/* ── PAGE EDITOR EXTRA CONTENT ───────────────────────────── */
.tss-page-extra{font-family:'Inter',sans-serif;font-size:.92rem;color:#6A6977;line-height:1.85;}
.tss-page-extra h1,.tss-page-extra h2,.tss-page-extra h3{font-family:'Cormorant Garamond',serif;font-weight:600;color:#1C1917;letter-spacing:-.02em;margin-bottom:16px;margin-top:40px;}
.tss-page-extra h1{font-size:clamp(2rem,3.5vw,3.5rem);}
.tss-page-extra h2{font-size:clamp(1.6rem,2.5vw,2.5rem);}
.tss-page-extra h3{font-size:1.3rem;}
.tss-page-extra p{margin-bottom:20px;max-width:720px;}
.tss-page-extra a{color:#CA8A04;text-decoration:underline;}
.tss-page-extra ul,.tss-page-extra ol{padding-left:24px;margin-bottom:20px;}
.tss-page-extra li{margin-bottom:8px;}
.tss-page-extra img{border-radius:16px;max-width:100%;height:auto;margin:24px 0;}
.tss-page-extra strong{color:#1C1917;font-weight:700;}
.tss-page-extra .wp-block-button__link{background:#CA8A04;color:#fff;padding:14px 32px;border-radius:4px;font-family:'Montserrat',sans-serif;font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;text-decoration:none;}
@media(max-width:640px){.tss-page-extra{padding:0 4px;}}