/* ============================================================
   QuickScale Media — Design System
   Aesthetic: confident, blue-collar-friendly marketing agency.
   Tokens, components, and section styles port the Claude Design
   prototype 1:1 (Archivo + Hanken Grotesk, #FCCC18 yellow on navy + near-black).
   8-pt spacing · 60/30/10 color · soft elevation · AA contrast.
   ============================================================ */

/* ---------- Tokens ---------- */
:root{
  /* Color story: off-white neutral (60) · near-black (30) · yellow (10) */
  --bg:#faf8f3;          /* page background (off-white, not glare white) */
  --cream:#f3eee2;       /* alternating band */
  --cream-2:#efe9da;
  --card:#fff;
  --ink:#1b1813;         /* near-black text + dark sections */
  --ink-soft:#4a4438;    /* body text */
  --muted:#6f6757;       /* secondary text */
  --muted-2:#8a8068;     /* tertiary / labels on light */
  --placeholder:#a89f88;
  --border:#ece6d8;
  --border-2:#e7e1d3;
  --border-3:#e3ddcd;    /* inputs */
  --yellow:#FCCC18;      /* brand accent (from logo) */
  --yellow-600:#e8b70f;  /* hover */
  --yellow-tint:#FEF3C7; /* icon tiles */
  --gold:#b89200;        /* dark gold text on light */
  --star:#FCCC18;
  --green:#1b8a4c;       /* affirmative ticks */
  --danger:#d6492f;
  --dark:#14213f;        /* navy — dark sections (proof band, lead form, etc.) */
  --darker:#0d1730;      /* deep navy — footer */
  --navy-line:#223c77;   /* navy outline buttons + icon strokes */
  --navy-tile:#274068;   /* navy icon tiles / step accents */
  --on-dark:#f5f1e8;
  --on-dark-soft:#c9c1b0;
  --on-dark-mute:#b5ac99;

  --radius-xl:20px;
  --radius-lg:18px;
  --radius:16px;
  --radius-sm:12px;
  --radius-input:10px;
  --radius-pill:999px;

  --shadow-card:0 1px 2px rgba(0,0,0,.04);
  --shadow-hover:0 16px 36px rgba(27,24,19,.12);
  --shadow-media:0 24px 60px rgba(27,24,19,.16);
  --shadow-media-sm:0 20px 50px rgba(27,24,19,.14);
  --shadow-form:0 16px 44px rgba(27,24,19,.1);
  --shadow-cta:0 6px 20px rgba(252,204,24,.38);

  --maxw:1180px;
  --gutter:clamp(18px,5vw,40px);

  --ff-display:'Archivo',system-ui,-apple-system,'Segoe UI',sans-serif;
  --ff-body:'Hanken Grotesk',system-ui,-apple-system,'Segoe UI',sans-serif;

  --header-h:70px;
}

/* ---------- Reset / base ---------- */
*{box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;}
body{
  margin:0;
  background:var(--bg);
  color:var(--ink-soft);
  font-family:var(--ff-body);
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img,svg{display:block;max-width:100%;}
button{font-family:inherit;}
input{font-family:inherit;}
a{color:inherit;}
::placeholder{color:var(--placeholder);opacity:1;}
::selection{background:var(--yellow);color:var(--ink);}

/* Skip link */
.skip-link{
  position:absolute;left:-9999px;top:0;z-index:100;
  background:var(--ink);color:#fff;padding:12px 18px;border-radius:0 0 10px 0;
  font-family:var(--ff-display);font-weight:700;text-decoration:none;
}
.skip-link:focus{left:0;}

/* Visible focus for keyboard users (works on light + dark) */
:focus-visible{outline:3px solid var(--yellow);outline-offset:2px;border-radius:4px;}

.visually-hidden{
  position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;
  overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0;
}

/* ---------- Layout ---------- */
.wrap{width:100%;max-width:var(--maxw);margin-inline:auto;}
.section{padding:clamp(48px,7vw,96px) var(--gutter);}
.section--hero{padding:clamp(40px,6vw,80px) var(--gutter) clamp(36px,5vw,64px);}
.section--proof{padding:clamp(40px,5vw,72px) var(--gutter);}
.section--stats{padding:clamp(36px,4vw,56px) var(--gutter);}
.section--values{padding:clamp(48px,7vw,88px) var(--gutter);}
.section--band{padding:clamp(44px,6vw,80px) var(--gutter);}
.section--intro{padding:clamp(44px,6vw,80px) var(--gutter) clamp(24px,3vw,40px);}
.section--flush-top{padding-top:clamp(16px,3vw,32px);}
.bg-cream{background:var(--cream);}
.bg-dark{background:var(--dark);color:var(--on-dark);}
.bg-yellow{background:var(--yellow);}

.split{display:flex;flex-wrap:wrap;gap:clamp(28px,4vw,56px);align-items:center;}
.split--top{align-items:flex-start;}
.col{flex:1 1 320px;min-width:300px;}
.col--narrow{flex:1 1 300px;min-width:280px;}

/* ---------- Typography ---------- */
.eyebrow{display:flex;align-items:center;gap:10px;margin:0 0 16px;}
.eyebrow::before{content:"";width:26px;height:3px;background:var(--yellow);border-radius:2px;flex:none;}
.eyebrow span{
  font-family:var(--ff-display);font-weight:700;font-size:12.5px;
  letter-spacing:.13em;text-transform:uppercase;color:var(--muted);
}

.h1,.h1-page{
  font-family:var(--ff-display);font-weight:900;color:var(--ink);margin:0 0 18px;
  letter-spacing:-.025em;line-height:1.0;
}
.h1{font-size:clamp(34px,5.4vw,66px);}
.h1-page{font-size:clamp(32px,4.6vw,58px);line-height:1.02;}
.h2{font-family:var(--ff-display);font-weight:800;color:var(--ink);margin:0 0 16px;letter-spacing:-.02em;line-height:1.08;font-size:clamp(26px,3.2vw,40px);}
.h2--xl{font-size:clamp(28px,3.6vw,44px);line-height:1.06;}
.h2--sm{font-size:clamp(24px,3vw,38px);line-height:1.1;}
.h3{font-family:var(--ff-display);font-weight:800;font-size:18px;color:var(--ink);margin:0 0 7px;line-height:1.25;}

.lead{font-size:clamp(16px,1.5vw,19px);line-height:1.6;color:var(--ink-soft);margin:0;}
.p{font-size:17px;line-height:1.6;color:var(--ink-soft);margin:0;}
.muted{color:var(--muted);}
.measure{max-width:60ch;}
.measure-54{max-width:54ch;}
.measure-48{max-width:48ch;}
/* Legal / long-form prose (Privacy, Terms) */
.prose{max-width:760px;}
.prose h2{font-family:var(--ff-display);font-weight:800;font-size:clamp(20px,2.4vw,26px);color:var(--ink);letter-spacing:-.01em;margin:34px 0 12px;}
.prose h3{font-family:var(--ff-display);font-weight:700;font-size:18px;color:var(--ink);margin:24px 0 8px;}
.prose p{font-size:16px;line-height:1.65;color:var(--ink-soft);margin:0 0 16px;}
.prose ul{margin:0 0 16px;padding-left:22px;}
.prose li{font-size:16px;line-height:1.6;color:var(--ink-soft);margin:0 0 8px;}
.prose a{color:var(--gold);text-decoration:underline;}
.prose strong{color:var(--ink);}
.prose .legal-meta{font-size:14px;color:var(--muted);margin-bottom:24px;}
.center{text-align:center;}
.center-x{margin-inline:auto;}
.actions{display:flex;flex-wrap:wrap;gap:12px;align-items:center;}
.mt-8{margin-top:8px;}.mt-16{margin-top:16px;}.mt-24{margin-top:24px;}.mt-26{margin-top:26px;}.mt-28{margin-top:28px;}
.mb-12{margin-bottom:12px;}.mb-16{margin-bottom:16px;}.mb-18{margin-bottom:18px;}.mb-20{margin-bottom:20px;}.mb-22{margin-bottom:22px;}.mb-26{margin-bottom:26px;}.mb-28{margin-bottom:28px;}.mb-40{margin-bottom:40px;}
.mark{background:linear-gradient(180deg,transparent 62%,var(--yellow) 62%);}
em.em{font-style:normal;font-weight:600;color:var(--ink);}

.rating{color:var(--star);font-size:16px;letter-spacing:2px;}
.rating--lg{font-size:18px;letter-spacing:3px;}
.rating-row{display:flex;align-items:center;gap:10px;margin-top:24px;}
.rating-row span:last-child{font-size:14px;color:var(--muted);}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-family:var(--ff-display);font-weight:800;font-size:16px;line-height:1;
  border:none;border-radius:var(--radius-sm);cursor:pointer;text-decoration:none;
  padding:16px 26px;min-height:44px;
  transition:transform .15s,box-shadow .15s,background .15s,color .15s;
}
.btn--primary{background:var(--yellow);color:var(--ink);box-shadow:var(--shadow-cta);}
.btn--primary:hover{background:var(--yellow-600);transform:translateY(-2px);box-shadow:0 12px 28px rgba(252,204,24,.5);}
.btn--primary:active{transform:translateY(0);}
.btn--outline{background:none;color:var(--ink);border:2px solid var(--navy-line);padding:14px 22px;font-weight:700;}
.btn--outline:hover{background:var(--dark);color:var(--bg);}
.btn--sm{padding:12px 20px;font-size:15px;font-weight:700;}
.btn--header{padding:11px 18px;font-size:14px;border-radius:var(--radius-sm);box-shadow:0 4px 14px rgba(252,204,24,.34);}
.btn--header:hover{box-shadow:0 8px 20px rgba(252,204,24,.45);}
.btn--block{width:100%;padding:16px;box-shadow:0 6px 18px rgba(252,204,24,.34);}
.btn--block:hover{box-shadow:0 12px 26px rgba(252,204,24,.46);}

/* ---------- Header / nav ---------- */
.site-header{
  position:sticky;top:0;z-index:40;
  background:rgba(250,248,243,.86);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  border-bottom:1px solid var(--border);
}
.site-header__inner{
  max-width:var(--maxw);margin:0 auto;width:100%;
  display:flex;align-items:center;justify-content:space-between;
  padding:14px var(--gutter);
}
.brand{display:flex;align-items:center;gap:10px;text-decoration:none;background:none;border:none;cursor:pointer;padding:0;}
.brand__logo{height:clamp(30px,3.4vw,40px);width:auto;display:block;}
.brand__mark{
  width:30px;height:30px;border-radius:8px;background:var(--yellow);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--ff-display);font-weight:900;font-size:17px;color:var(--ink);
}
.brand__name{font-family:var(--ff-display);font-weight:800;font-size:18px;letter-spacing:-.01em;color:var(--ink);}
.brand__name b{color:var(--gold);font-weight:800;}

.nav{display:none;align-items:center;gap:clamp(12px,2.4vw,30px);}
.nav__link{
  background:none;border:none;cursor:pointer;text-decoration:none;
  font-family:var(--ff-body);font-size:15px;font-weight:600;color:var(--muted);
  padding:4px 0;border-bottom:2px solid transparent;transition:color .15s;
}
.nav__link:hover{color:var(--ink);}
.nav__link[aria-current="page"]{color:var(--ink);font-weight:700;border-bottom-color:var(--yellow);}

.navtoggle{
  display:inline-flex;flex-direction:column;gap:5px;background:none;border:none;
  cursor:pointer;padding:8px;
}
.navtoggle span{width:22px;height:2px;background:var(--ink);border-radius:2px;transition:transform .2s,opacity .2s;}
.navtoggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.navtoggle[aria-expanded="true"] span:nth-child(2){opacity:0;}
.navtoggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

.drawer{display:none;border-top:1px solid var(--border);background:var(--bg);padding:10px var(--gutter) 18px;}
.drawer.is-open{display:flex;flex-direction:column;gap:4px;animation:fadeUp .25s ease-out both;}
.drawer__link{
  background:none;border:none;cursor:pointer;text-align:left;text-decoration:none;
  font-family:var(--ff-display);font-size:18px;font-weight:600;color:var(--muted);
  padding:12px 0;border-bottom:1px solid var(--border);
}
.drawer__link[aria-current="page"]{color:var(--ink);font-weight:800;}
.drawer .btn{margin-top:8px;}

/* ---------- Media placeholders (swap for real photos/video) ---------- */
.media{
  position:relative;border-radius:var(--radius-xl);overflow:hidden;
  border:1px solid var(--border-2);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:12px;text-align:center;color:var(--muted-2);
  background:repeating-linear-gradient(135deg,#f1ecdf,#f1ecdf 12px,#e9e2d1 12px,#e9e2d1 24px);
}
.media--hero{box-shadow:var(--shadow-media);}
.media--soft{box-shadow:var(--shadow-media-sm);}
.media--dark{
  border-color:#3a3528;color:var(--muted-2);
  background:repeating-linear-gradient(135deg,#26231b,#26231b 11px,#211e17 11px,#211e17 22px);
}
.media--dashed{border:2px dashed #d8cfb8;color:#9a917c;}
.ar-4-3{aspect-ratio:4/3;}
.ar-16-10{aspect-ratio:16/10;}
.ar-16-7{aspect-ratio:16/7;}
.ar-3-4{aspect-ratio:3/4;}
.ar-1-1{aspect-ratio:1;}

.play{
  width:64px;height:64px;border-radius:50%;background:var(--yellow);
  display:flex;align-items:center;justify-content:center;color:var(--ink);font-size:22px;
  box-shadow:0 8px 24px rgba(0,0,0,.18);
}
.play--sm{width:50px;height:50px;font-size:18px;}
.media__kicker{font-family:var(--ff-display);font-weight:700;font-size:12px;letter-spacing:.1em;text-transform:uppercase;}
.media__note{font-size:12px;color:var(--placeholder);}
.media__badge{
  position:absolute;top:14px;left:14px;background:var(--dark);color:var(--on-dark);
  font-family:var(--ff-display);font-weight:700;font-size:10px;letter-spacing:.08em;
  padding:5px 10px;border-radius:var(--radius-pill);
}

/* photo placeholder (square-ish) */
.photo{
  border-radius:var(--radius);border:1px solid #e2dac8;
  background:repeating-linear-gradient(135deg,#ece6d8,#ece6d8 10px,#e3dcc9 10px,#e3dcc9 20px);
  display:flex;align-items:center;justify-content:center;color:var(--placeholder);font-size:11px;
}

/* ---------- Checks / lists ---------- */
.checks{display:flex;flex-direction:column;gap:10px;}
.check{display:flex;align-items:center;gap:10px;font-size:15.5px;color:var(--ink);}
.check .tick{color:var(--green);font-weight:800;flex:none;}
.check--lg{font-size:16px;}
.check--lg .tick{font-size:18px;}

/* icon tile */
.itile{width:44px;height:44px;border-radius:11px;background:var(--yellow-tint);display:flex;align-items:center;justify-content:center;margin-bottom:14px;flex:none;}
.itile--lg{width:46px;height:46px;border-radius:12px;}
.itile--dark{background:var(--navy-tile);}

/* ---------- Cards ---------- */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px;}
.cards--wide{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));}
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow-card);transition:transform .18s,box-shadow .18s;}
.card--hover:hover{transform:translateY(-5px);box-shadow:var(--shadow-hover);}
.card p{font-size:14.5px;line-height:1.55;color:var(--muted);margin:0;}
.card--belief{padding:26px;}
.card__num{font-family:var(--ff-display);font-weight:900;font-size:28px;color:var(--yellow);margin-bottom:12px;}
.card--belief h3{font-size:19px;margin-bottom:8px;}
.card--belief p{font-size:15px;line-height:1.6;}

/* ---------- Proof band (dark) ---------- */
.proof__quote{font-family:var(--ff-display);font-weight:700;font-size:clamp(22px,2.6vw,32px);line-height:1.25;letter-spacing:-.01em;color:#fff;margin:0 0 18px;}
.proof__kicker{font-family:var(--ff-display);font-weight:700;font-size:12.5px;letter-spacing:.13em;text-transform:uppercase;color:#d8c98f;margin-bottom:14px;}
.person{display:flex;align-items:center;gap:12px;}
.person__avatar{width:46px;height:46px;border-radius:50%;flex:none;background:repeating-linear-gradient(135deg,#3a352b,#3a352b 8px,#332e25 8px,#332e25 16px);border:1px solid #4a4336;}
.person__name{font-weight:700;color:#fff;font-size:15px;}
.person__role{font-size:13px;color:var(--on-dark-mute);}
.beforeafter{flex:1 1 280px;min-width:260px;display:flex;gap:14px;}
.ba-cell{flex:1;border-radius:14px;aspect-ratio:3/4;display:flex;align-items:center;justify-content:center;font-family:var(--ff-display);font-weight:700;font-size:11px;letter-spacing:.1em;}
.ba-cell--before{border:1px solid #3a3528;background:repeating-linear-gradient(135deg,#26231b,#26231b 10px,#211e17 10px,#211e17 20px);color:var(--muted-2);}
.ba-cell--after{border:1px solid #5a4d20;background:repeating-linear-gradient(135deg,#2e2814,#2e2814 10px,#29230f 10px,#29230f 20px);color:#d8c98f;}

.logos{max-width:var(--maxw);margin:clamp(28px,4vw,44px) auto 0;border-top:1px solid #2f2a20;padding-top:24px;display:flex;flex-wrap:wrap;align-items:center;gap:16px;}
.logos__label{font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted-2);font-family:var(--ff-display);font-weight:700;}
.logos__row{flex:1;display:flex;flex-wrap:wrap;gap:14px;min-width:200px;}
.logo-chip{flex:1;min-width:90px;height:40px;border-radius:8px;border:1px dashed #4a4336;background:repeating-linear-gradient(135deg,#211e17,#211e17 9px,#1d1a14 9px,#1d1a14 18px);display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:10px;}

/* ---------- Stats (yellow) ---------- */
.stats{display:flex;flex-wrap:wrap;justify-content:space-around;gap:24px;text-align:center;}
.stat{flex:1 1 160px;}
.stat__num{font-family:var(--ff-display);font-weight:900;font-size:clamp(34px,4.4vw,52px);color:var(--ink);line-height:1;letter-spacing:-.02em;display:block;}
.stat__label{font-weight:600;font-size:14px;color:#5a4f1f;margin-top:6px;}

/* ---------- Testimonials carousel ---------- */
.tcarousel{max-width:820px;margin:0 auto;text-align:center;}
.tcarousel__kicker{font-family:var(--ff-display);font-weight:700;font-size:12.5px;letter-spacing:.13em;text-transform:uppercase;color:var(--muted);margin-bottom:18px;}
.tstage{min-height:160px;display:flex;flex-direction:column;align-items:center;justify-content:center;}
.tslide{display:none;flex-direction:column;align-items:center;}
.tslide.is-active{display:flex;animation:fadeUp .35s ease-out both;}
.tquote{font-family:var(--ff-display);font-weight:700;font-size:clamp(20px,2.5vw,28px);line-height:1.3;letter-spacing:-.01em;color:var(--ink);margin:14px 0 18px;}
.tmeta{font-size:15px;color:var(--muted);}
.tmeta b{color:var(--ink);font-weight:600;}
.tnav{display:flex;align-items:center;justify-content:center;gap:18px;margin-top:24px;}
.tarrow{width:42px;height:42px;border-radius:50%;border:1.5px solid #d8cfb8;background:#fff;cursor:pointer;font-size:16px;color:var(--ink);display:flex;align-items:center;justify-content:center;transition:background .15s,border-color .15s,color .15s;}
.tarrow:hover{background:var(--ink);color:#fff;border-color:var(--ink);}
.tdots{display:flex;align-items:center;gap:8px;}
.tdot{height:8px;width:8px;border-radius:4px;border:none;cursor:pointer;padding:0;background:#d8cfb8;transition:all .2s;}
.tdot[aria-current="true"]{width:24px;background:var(--ink);}

/* ---------- Team ---------- */
.team-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:24px;}
.member{display:flex;gap:18px;align-items:center;}
.member__photo{width:96px;height:96px;flex:none;border-radius:var(--radius-lg);}
.member__name{font-family:var(--ff-display);font-weight:800;font-size:20px;color:var(--ink);}
.member__role{font-size:14px;color:var(--gold);font-weight:600;margin-bottom:8px;}
.member p{font-size:14.5px;line-height:1.55;color:var(--muted);margin:0;max-width:36ch;}
/* team teaser (compact two-up) */
.teaser-people{flex:1 1 280px;min-width:260px;display:flex;gap:16px;}
.teaser-person{flex:1;text-align:center;}
.teaser-person .photo{aspect-ratio:1;margin-bottom:10px;}
.teaser-person__name{font-family:var(--ff-display);font-weight:800;font-size:15px;color:var(--ink);}
.teaser-person__role{font-size:13px;color:var(--muted);}

/* ---------- Lead-gen form section ---------- */
.steplist{display:flex;flex-direction:column;gap:14px;}
.stepline{display:flex;gap:12px;align-items:flex-start;}
.numdot{width:24px;height:24px;border-radius:50%;background:var(--yellow);color:var(--ink);font-weight:800;display:flex;align-items:center;justify-content:center;font-size:13px;flex:none;}
.form-mascot{height:clamp(150px,26vw,230px);width:auto;display:block;margin-top:28px;filter:drop-shadow(0 12px 30px rgba(0,0,0,.4));}
.numdot--alt{background:var(--navy-tile);color:var(--yellow);}
.stepline span:last-child{font-size:15.5px;color:var(--border-2);}

.form{background:#fff;border-radius:var(--radius-lg);padding:clamp(22px,3vw,30px);box-shadow:0 20px 50px rgba(0,0,0,.25);}
.form--bordered{border:1px solid var(--border);box-shadow:var(--shadow-form);padding:clamp(24px,3vw,34px);}
.form__title{font-family:var(--ff-display);font-weight:800;font-size:19px;color:var(--ink);margin-bottom:16px;}
.form__title--lg{font-size:20px;margin-bottom:18px;}
.form__fields{display:flex;flex-direction:column;gap:14px;}
.form__row{display:flex;gap:12px;flex-wrap:wrap;}
.form__row > div{flex:1 1 130px;}
.field label{display:block;font-size:13px;font-weight:600;color:var(--muted);margin-bottom:6px;}
.input{width:100%;font-family:var(--ff-body);font-size:16px;color:var(--ink);background:#fff;border:1.5px solid var(--border-3);border-radius:var(--radius-input);padding:14px;outline:none;transition:border-color .15s,box-shadow .15s;}
.input:focus{border-color:var(--yellow);box-shadow:0 0 0 3px rgba(252,204,24,.25);}
.input[aria-invalid="true"]{border-color:var(--danger);box-shadow:0 0 0 3px rgba(214,73,47,.12);}
.error{color:var(--danger);font-size:13px;margin-top:6px;}
.error:empty{display:none;}
.consent{display:flex;gap:10px;align-items:flex-start;cursor:pointer;padding:2px 0;text-align:left;width:100%;position:relative;}
.consent__cb{position:absolute;opacity:0;width:0;height:0;margin:0;}
.checkbox{width:20px;height:20px;flex:none;border-radius:5px;margin-top:1px;border:1.5px solid #c9c1ae;background:#fff;display:flex;align-items:center;justify-content:center;transition:all .15s;}
.consent__cb:checked + .checkbox{border-color:var(--yellow);background:var(--yellow);}
.consent__cb:checked + .checkbox svg{display:block;}
.consent__cb:focus-visible + .checkbox{outline:3px solid var(--yellow);outline-offset:2px;}
.checkbox svg{display:none;}
.consent__text{font-size:12.5px;line-height:1.4;color:#8a857c;}
.formnote{font-size:12.5px;color:#8a857c;text-align:center;}
.formnote .formlink{color:#6f6757;text-decoration:underline;}
.formnote .formlink:hover{color:var(--ink);}
/* Honeypot: visually hidden + out of tab order (tabindex=-1 in markup) */
.hp{position:absolute!important;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden;}
/* Footer legal links */
.footer-legal{display:flex;gap:16px;}
.footer-legal a{color:var(--muted);text-decoration:none;}
.footer-legal a:hover{color:var(--yellow);}

.success{background:#fff;border-radius:var(--radius-lg);padding:36px 28px;text-align:center;animation:pop .4s ease-out both;}
.success--bordered{border:1px solid var(--border);box-shadow:var(--shadow-form);padding:40px 28px;}
.success__icon{width:64px;height:64px;border-radius:50%;background:#e7f6ec;display:flex;align-items:center;justify-content:center;margin:0 auto 18px;}
.success h3{font-family:var(--ff-display);font-weight:800;font-size:24px;color:var(--ink);margin:0 0 10px;}
.success p{font-size:15.5px;line-height:1.6;color:var(--muted);margin:0 0 22px;}
.success strong{color:var(--ink);}
[hidden]{display:none!important;}

/* ---------- Services pillars ---------- */
.pillars{display:flex;flex-direction:column;gap:18px;}
.pillar{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:clamp(22px,3vw,32px);display:flex;flex-wrap:wrap;gap:clamp(18px,3vw,40px);align-items:flex-start;}
.pillar--feature{background:var(--dark);align-items:center;position:relative;overflow:hidden;border:none;}
.pillar__main{flex:1 1 260px;min-width:240px;}
.pillar__side{flex:1 1 220px;min-width:200px;display:flex;flex-direction:column;gap:10px;}
.pillar h2{font-size:clamp(22px,2.4vw,28px);letter-spacing:-.01em;margin-bottom:10px;}
.pillar p{font-size:16px;line-height:1.6;color:var(--muted);margin:0;}
.pillar--feature h2{color:#fff;}
.pillar--feature p{color:var(--on-dark-soft);margin-bottom:16px;}
.pillar__badge{position:absolute;top:18px;right:18px;background:var(--yellow);color:var(--ink);font-family:var(--ff-display);font-weight:800;font-size:10px;letter-spacing:.08em;padding:5px 11px;border-radius:var(--radius-pill);}
.tags{display:flex;flex-wrap:wrap;gap:8px;}
.tag{font-size:13px;color:var(--border-2);background:#26231b;border:1px solid #3a3528;border-radius:var(--radius-pill);padding:6px 12px;}

/* ---------- FAQ ---------- */
.faq__main{flex:1.4 1 320px;min-width:300px;}
.faq{display:flex;flex-direction:column;gap:12px;}
.faq__item{background:#fff;border:1px solid var(--border);border-radius:14px;overflow:hidden;}
.faq__q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px;background:none;border:none;cursor:pointer;padding:18px 20px;text-align:left;font-family:var(--ff-display);font-weight:700;font-size:16px;color:var(--ink);}
.faq__sign{font-family:var(--ff-display);font-weight:700;font-size:22px;color:var(--star);line-height:1;flex:none;transition:transform .2s;}
.faq__q[aria-expanded="true"] .faq__sign{transform:rotate(45deg);}
/* Open by default so answers are present + readable without JS; the script
   collapses non-active items by setting aria-expanded="false". */
.faq__a{max-height:420px;opacity:1;overflow:hidden;transition:max-height .3s ease,opacity .3s ease;}
.faq__q[aria-expanded="false"] + .faq__a{max-height:0;opacity:0;}
.faq__a-inner{padding:0 20px 18px;font-size:15px;line-height:1.6;color:var(--muted);}
.faq__aside{flex:1 1 260px;min-width:250px;background:var(--dark);border-radius:var(--radius-lg);padding:28px;color:var(--on-dark);position:sticky;top:90px;}
.faq__aside h3{font-family:var(--ff-display);font-weight:800;font-size:22px;color:#fff;margin:0 0 10px;}
.faq__aside p{font-size:15px;line-height:1.6;color:var(--on-dark-soft);margin:0 0 20px;}

/* ---------- Process ---------- */
.steps{flex:1 1 280px;min-width:260px;display:flex;flex-direction:column;gap:12px;}
.step{display:flex;align-items:center;gap:14px;width:100%;cursor:pointer;text-align:left;background:transparent;border:1px solid var(--border-2);border-radius:14px;padding:16px 18px;transition:all .18s;}
.step[aria-selected="true"]{background:#fff;border-color:var(--yellow);box-shadow:0 8px 22px rgba(27,24,19,.08);}
.step__chip{width:40px;height:40px;flex:none;border-radius:11px;display:flex;align-items:center;justify-content:center;font-family:var(--ff-display);font-weight:800;font-size:17px;background:var(--cream-2);color:var(--muted-2);transition:all .18s;}
.step[aria-selected="true"] .step__chip{background:var(--yellow);color:var(--ink);}
.step__text{display:flex;flex-direction:column;gap:3px;}
.step__title{font-family:var(--ff-display);font-weight:800;font-size:16px;color:var(--muted);}
.step[aria-selected="true"] .step__title{color:var(--ink);}
.step__tag{font-size:13px;color:var(--muted-2);}
.stepdetail{flex:1.3 1 320px;min-width:300px;}
.steppanel{display:none;height:100%;}
.steppanel.is-active{display:block;}
.stepdetail__card{background:#fff;border:1px solid var(--border);border-radius:var(--radius-xl);padding:clamp(24px,3vw,36px);box-shadow:0 12px 36px rgba(27,24,19,.08);height:100%;animation:fadeUp .35s ease-out both;}
.stepdetail__head{display:flex;align-items:center;gap:12px;margin-bottom:18px;}
.stepdetail__num{font-family:var(--ff-display);font-weight:900;font-size:46px;color:var(--yellow);line-height:1;}
.stepdetail__card h2{font-size:clamp(22px,2.6vw,30px);margin:0;letter-spacing:-.01em;}
.stepdetail__card p{font-size:16.5px;line-height:1.65;color:var(--ink-soft);margin:0 0 22px;max-width:52ch;}

/* ---------- CTA bar ---------- */
.ctabar{max-width:var(--maxw);margin:clamp(32px,4vw,48px) auto 0;background:var(--dark);border-radius:var(--radius-lg);padding:clamp(24px,3vw,36px);display:flex;flex-wrap:wrap;gap:20px;align-items:center;justify-content:space-between;}
.ctabar__title{font-family:var(--ff-display);font-weight:800;font-size:clamp(20px,2.4vw,28px);color:#fff;letter-spacing:-.01em;}

/* ---------- Contact NAP ---------- */
.nap{border-top:1px solid var(--border);padding-top:22px;display:flex;flex-direction:column;gap:12px;}
.nap__item{display:flex;align-items:center;gap:12px;}
.nap__icon{width:38px;height:38px;border-radius:var(--radius-input);background:var(--cream);display:flex;align-items:center;justify-content:center;flex:none;}
.nap__label{font-size:13px;color:var(--muted-2);}
.nap__value{font-size:15px;color:var(--ink);font-weight:600;text-decoration:none;}
a.nap__value:hover{color:var(--gold);}

/* ---------- Footer ---------- */
.site-footer{background:var(--darker);color:var(--on-dark-mute);padding:clamp(36px,5vw,56px) var(--gutter) 28px;}
.site-footer__top{max-width:var(--maxw);margin:0 auto;display:flex;flex-wrap:wrap;gap:32px;justify-content:space-between;}
.site-footer__about{flex:1 1 240px;min-width:220px;}
.footer-brand{display:flex;align-items:center;gap:10px;margin-bottom:14px;}
.footer-brand__logo{height:38px;width:auto;display:block;}
.footer-brand__mark{width:28px;height:28px;border-radius:7px;background:var(--yellow);display:flex;align-items:center;justify-content:center;font-family:var(--ff-display);font-weight:900;font-size:16px;color:var(--ink);}
.footer-brand__name{font-family:var(--ff-display);font-weight:800;font-size:17px;color:#fff;}
.site-footer__about p{font-size:14px;line-height:1.6;margin:0 0 14px;max-width:34ch;}
.socials{display:flex;gap:10px;}
.social{width:34px;height:34px;border-radius:9px;border:1px solid #2f2c24;display:flex;align-items:center;justify-content:center;transition:border-color .15s,transform .15s;}
.social:hover{border-color:var(--yellow);transform:translateY(-2px);}
.footer-cols{display:flex;flex-wrap:wrap;gap:40px;}
.footer-col{display:flex;flex-direction:column;gap:10px;}
.footer-col__h{font-family:var(--ff-display);font-weight:700;font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:2px;}
.footer-col a{font-size:14px;color:var(--on-dark-mute);text-decoration:none;transition:color .15s;}
.footer-col a:hover{color:var(--yellow);}
.footer-col span{font-size:14px;color:var(--on-dark-mute);}
.site-footer__bottom{max-width:var(--maxw);margin:28px auto 0;border-top:1px solid #2f2c24;padding-top:18px;display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between;font-size:13px;color:var(--muted);}
.site-footer__bottom b{font-family:var(--ff-display);font-weight:700;color:var(--muted-2);}

/* ---------- Sticky mobile CTA ---------- */
.mobilebar{position:sticky;bottom:0;z-index:50;background:#fff;border-top:1px solid var(--border);box-shadow:0 -6px 20px rgba(0,0,0,.08);padding:10px 16px;}
.mobilebar .btn{width:100%;}

/* anchor offset for sticky header */
#book{scroll-margin-top:84px;}

/* ---------- Animations ---------- */
@keyframes fadeUp{from{opacity:0;transform:translateY(18px);}to{opacity:1;transform:none;}}
@keyframes pop{from{opacity:0;transform:scale(.92);}to{opacity:1;transform:scale(1);}}
.reveal{animation:fadeUp .5s ease-out both;}
.reveal--pop{animation:pop .6s ease-out both;}

/* ---------- Responsive (mobile-first → enhance) ---------- */
@media (min-width:769px){
  .nav{display:flex;}
  .navtoggle{display:none;}
  .drawer{display:none!important;}
  .mobilebar{display:none;}
}

@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto;}
  *{animation:none!important;transition:none!important;}
}

/* ---------- Cookie / analytics consent banner ---------- */
.qs-consent{
  position:fixed;left:16px;right:16px;bottom:16px;z-index:60;
  max-width:600px;margin-inline:auto;
  display:flex;flex-wrap:wrap;align-items:center;gap:12px 18px;
  background:var(--ink);color:#fff;
  border-radius:var(--radius);box-shadow:var(--shadow-media);
  padding:16px 20px;
}
.qs-consent__text{flex:1 1 240px;margin:0;font-size:14px;line-height:1.55;color:var(--on-dark-soft,#d9d4c8);}
.qs-consent__text a{color:var(--yellow);text-decoration:underline;}
.qs-consent__actions{display:flex;gap:10px;flex:0 0 auto;}
.qs-consent .btn{padding:10px 18px;font-size:14px;}
.qs-consent__decline{
  font-family:var(--ff-display);font-weight:700;font-size:14px;color:#fff;cursor:pointer;
  background:none;border:2px solid rgba(255,255,255,.4);border-radius:var(--radius-sm);padding:8px 16px;
}
.qs-consent__decline:hover{border-color:#fff;}
@media (max-width:768px){
  .qs-consent{bottom:78px;left:12px;right:12px;padding:14px 16px;}  /* clear the sticky mobile CTA */
}
