/* ==========================================================================
   RankNova Labs · Design System
   Editorial-premium · Cream + Ink + Gold
   Built for Core Web Vitals: no frameworks, no animations on load
   ========================================================================== */

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

:root{
  --bg:#fbf8f1;
  --bg-soft:#f5f0e6;
  --bg-warm:#efe8d9;
  --ink:#0c0c0e;
  --ink-soft:#1a1a1e;
  --ink-muted:#4a4a52;
  --muted:#737078;
  --muted-2:#a09c98;
  --line:#d9d2c2;
  --line-soft:#e7e1d2;
  --gold:#b58838;
  --gold-deep:#8a6628;
  --gold-soft:#d4ad5d;
  --gold-glow:rgba(181,136,56,.08);
  --sage:#5e7a5d;
  --rust:#a04e3a;
  --serif:'Fraunces',Georgia,'Iowan Old Style',serif;
  --sans:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --mono:'JetBrains Mono','SF Mono',Menlo,monospace;
  --radius:6px;
  --transition:.2s cubic-bezier(.22,.61,.36,1);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--sans);
  font-size:16px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  font-feature-settings:'cv11','ss01';
  min-height:100vh;
  overflow-x:hidden;
}

/* paper grain — barely there */
body::before{
  content:'';position:fixed;inset:0;pointer-events:none;z-index:1;opacity:.025;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none;transition:color var(--transition)}
button{font-family:inherit;cursor:pointer;border:none;background:none}

/* TYPOGRAPHY ============================================================ */
.display{font-family:var(--serif);font-weight:300;letter-spacing:-.02em;font-variation-settings:'opsz' 144;line-height:1.05}
.display em{font-style:italic;color:var(--gold);font-weight:400}
h1{font-family:var(--serif);font-weight:300;letter-spacing:-.025em;font-variation-settings:'opsz' 144;line-height:1.05}
h2{font-family:var(--serif);font-weight:400;letter-spacing:-.02em;line-height:1.1}
h3{font-family:var(--serif);font-weight:500;letter-spacing:-.015em;line-height:1.2}
h4{font-family:var(--sans);font-weight:600;letter-spacing:-.005em;line-height:1.3}
.eyebrow{font-family:var(--mono);font-size:11px;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-deep);display:inline-block}
.lede{font-family:var(--serif);font-weight:300;line-height:1.4;color:var(--ink-soft);letter-spacing:-.005em}
.italic{font-style:italic}

/* LAYOUT ================================================================ */
.container{max-width:1180px;margin:0 auto;padding:0 32px;position:relative;z-index:2}
.container-narrow{max-width:880px;margin:0 auto;padding:0 32px;position:relative;z-index:2}
section{padding:96px 0}
.section-tight{padding:64px 0}

/* NAV =================================================================== */
.nav-bar{
  position:sticky;top:0;z-index:100;background:rgba(251,248,241,.85);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line-soft);
}
.nav-inner{
  max-width:1180px;margin:0 auto;padding:18px 32px;
  display:flex;align-items:center;justify-content:space-between;gap:24px;
}
.nav-brand{display:flex;align-items:center;gap:10px;font-family:var(--serif);font-size:19px;font-weight:500;letter-spacing:-.01em}
.nav-brand .logo{width:28px;height:28px}
.nav-brand:hover{color:var(--gold-deep)}
.nav-links{display:flex;gap:32px;list-style:none;align-items:center}
.nav-links a{font-size:14px;font-weight:500;color:var(--ink-muted);transition:color var(--transition);position:relative}
.nav-links a:hover{color:var(--ink)}
.nav-links a.active{color:var(--ink)}
.nav-links a.active::after{content:'';position:absolute;bottom:-6px;left:0;right:0;height:2px;background:var(--gold)}
.nav-cta{padding:10px 18px;background:var(--ink);color:var(--bg);border-radius:var(--radius);font-size:14px;font-weight:600;transition:all var(--transition)}
.nav-cta:hover{background:var(--gold);color:var(--ink)}
.nav-toggle{display:none;flex-direction:column;gap:5px;padding:8px}
.nav-toggle span{width:22px;height:2px;background:var(--ink);transition:all var(--transition)}

@media(max-width:880px){
  .nav-links{display:none;position:absolute;top:100%;left:0;right:0;background:var(--bg);flex-direction:column;padding:24px 32px;gap:18px;border-bottom:1px solid var(--line);box-shadow:0 8px 32px rgba(0,0,0,.04)}
  .nav-links.open{display:flex}
  .nav-toggle{display:flex}
  .nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav-toggle.open span:nth-child(2){opacity:0}
  .nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
}

/* HERO ================================================================== */
.hero{padding:120px 0 80px;position:relative}
.hero::after{content:'';position:absolute;top:30%;right:-15vw;width:50vw;height:50vw;background:radial-gradient(circle,var(--gold-glow) 0%,transparent 65%);pointer-events:none;z-index:0}
.hero h1{font-size:clamp(48px,7vw,84px);margin:28px 0 32px}
.hero .lede{font-size:clamp(18px,2.2vw,24px);max-width:780px;margin-bottom:48px}
.hero .lede strong{font-style:italic;color:var(--gold-deep);font-weight:500}

.hero-meta{
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:24px 0;margin-top:64px;display:grid;grid-template-columns:repeat(4,1fr);gap:0
}
.hero-meta .stat{padding:0 24px;border-right:1px solid var(--line-soft)}
.hero-meta .stat:first-child{padding-left:0}
.hero-meta .stat:last-child{border-right:none;padding-right:0}
.hero-meta .num{font-family:var(--serif);font-size:clamp(32px,4vw,44px);font-weight:500;line-height:1;display:block;margin-bottom:6px;letter-spacing:-.02em}
.hero-meta .num .unit{font-family:var(--mono);font-size:.5em;font-weight:400;color:var(--gold-deep);margin-left:4px;vertical-align:super}
.hero-meta .label{font-family:var(--mono);font-size:10px;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);line-height:1.4;display:block}

@media(max-width:768px){
  .hero{padding:64px 0 48px}
  .hero-meta{grid-template-columns:repeat(2,1fr);gap:24px}
  .hero-meta .stat{border-right:none;padding:16px 0;border-bottom:1px solid var(--line-soft)}
  .hero-meta .stat:nth-child(odd){padding-left:0;padding-right:16px;border-right:1px solid var(--line-soft)}
  .hero-meta .stat:nth-child(2),.hero-meta .stat:last-child{border-bottom:none}
}

/* BUTTONS =============================================================== */
.btn{
  display:inline-flex;align-items:center;gap:10px;padding:14px 28px;
  font-size:14px;font-weight:600;letter-spacing:.01em;border-radius:var(--radius);
  transition:all var(--transition);cursor:pointer;border:1px solid transparent;
  font-family:var(--sans);text-decoration:none;
}
.btn-primary{background:var(--ink);color:var(--bg)}
.btn-primary:hover{background:var(--gold);color:var(--ink);transform:translateY(-1px);box-shadow:0 8px 24px var(--gold-glow)}
.btn-gold{background:var(--gold);color:var(--ink)}
.btn-gold:hover{background:var(--gold-deep);color:var(--bg)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--ink);background:var(--ink);color:var(--bg)}
.btn-arrow::after{content:'→';transition:transform var(--transition)}
.btn-arrow:hover::after{transform:translateX(4px)}

/* SECTION HEADINGS ====================================================== */
.section-h{display:flex;align-items:baseline;gap:24px;margin-bottom:56px}
.section-h .num{font-family:var(--mono);font-size:11px;color:var(--gold-deep);letter-spacing:.2em;font-weight:500}
.section-h h2{font-size:clamp(32px,4vw,44px)}
.section-h .rule{flex:1;height:1px;background:var(--line);margin-bottom:8px}
.section-h .ann{font-family:var(--serif);font-style:italic;font-size:14px;color:var(--muted)}

@media(max-width:768px){.section-h{flex-wrap:wrap;gap:16px}.section-h .rule{order:99;flex-basis:100%;margin:0}}

/* CARDS ================================================================= */
.card{background:var(--bg-soft);border:1px solid var(--line-soft);border-radius:var(--radius);padding:32px;transition:all var(--transition)}
.card:hover{border-color:var(--gold);transform:translateY(-2px);box-shadow:0 12px 32px rgba(0,0,0,.04)}
.card-icon{width:40px;height:40px;border-radius:var(--radius);background:var(--ink);color:var(--bg);display:flex;align-items:center;justify-content:center;margin-bottom:20px;font-family:var(--serif);font-size:20px}
.card h3{font-size:22px;margin-bottom:12px}
.card p{color:var(--ink-muted);font-size:15px;line-height:1.6}

.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
@media(max-width:880px){.grid-3,.grid-4{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}

/* SERVICE CARDS ========================================================= */
.service-card{position:relative;padding:36px 32px;border:1px solid var(--line);border-radius:var(--radius);background:var(--bg);transition:all var(--transition);overflow:hidden}
.service-card::before{content:'';position:absolute;top:0;left:0;width:100%;height:3px;background:var(--gold);transform:scaleX(0);transform-origin:left;transition:transform var(--transition)}
.service-card:hover::before{transform:scaleX(1)}
.service-card:hover{border-color:var(--ink)}
.service-card .num{font-family:var(--mono);font-size:11px;color:var(--gold-deep);letter-spacing:.18em;margin-bottom:20px;display:block}
.service-card h3{font-size:24px;margin-bottom:14px}
.service-card p{color:var(--ink-muted);margin-bottom:20px;font-size:15px}
.service-card .price{font-family:var(--mono);font-size:13px;color:var(--ink);font-weight:500}
.service-card .price strong{font-family:var(--serif);font-size:17px}
.service-card a{color:var(--gold-deep);font-size:14px;font-weight:600;display:inline-flex;align-items:center;gap:6px;margin-top:8px}
.service-card a:hover{color:var(--ink)}

/* PILLS / TAGS ========================================================== */
.pill{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;border-radius:99px;font-size:12px;font-weight:500;background:var(--bg-warm);color:var(--ink-muted);border:1px solid var(--line-soft);font-family:var(--mono);letter-spacing:.04em}
.pill-gold{background:rgba(181,136,56,.08);color:var(--gold-deep);border-color:rgba(181,136,56,.2)}
.pill-sage{background:rgba(94,122,93,.08);color:var(--sage);border-color:rgba(94,122,93,.2)}

/* CASE STUDY ============================================================ */
.case{padding:32px;border:1px solid var(--line);border-radius:var(--radius);background:var(--bg-soft)}
.case .num{font-family:var(--serif);font-size:48px;font-weight:500;color:var(--gold);line-height:1;margin-bottom:8px;display:block;letter-spacing:-.02em}
.case .num .unit{font-family:var(--mono);font-size:.4em;color:var(--gold-deep);margin-left:4px;vertical-align:super;font-weight:400}
.case .label{font-family:var(--mono);font-size:10px;letter-spacing:.15em;color:var(--muted);text-transform:uppercase;display:block;margin-bottom:20px}
.case h4{font-size:18px;margin-bottom:8px;color:var(--ink)}
.case p{color:var(--ink-muted);font-size:14px}

/* PROCESS / METHODOLOGY ================================================= */
.method{
  padding:48px;border:1px solid var(--line);background:linear-gradient(135deg,var(--gold-glow) 0%,transparent 100%);
  border-radius:var(--radius);
}
.method-flow{display:flex;align-items:center;flex-wrap:wrap;gap:14px;font-family:var(--serif);font-size:18px;font-style:italic;color:var(--ink-muted)}
.method-step{display:inline-flex;align-items:center;padding:10px 18px;background:var(--bg);border:1px solid var(--line);border-radius:var(--radius);transition:all var(--transition)}
.method-step:hover{border-color:var(--gold);color:var(--ink)}
.method-step .letter{color:var(--gold-deep);font-weight:500;font-style:normal;margin-right:6px;font-size:20px}
.method-arrow{color:var(--gold);font-style:normal}

/* FAQ ================================================================== */
.faq-list{max-width:800px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--line-soft);padding:20px 0}
.faq-item summary{display:flex;justify-content:space-between;align-items:center;list-style:none;cursor:pointer;font-family:var(--serif);font-size:20px;font-weight:500;color:var(--ink)}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:'+';font-family:var(--serif);font-size:28px;color:var(--gold);font-weight:300;transition:transform var(--transition);line-height:1}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item summary:hover{color:var(--gold-deep)}
.faq-item .faq-body{padding:16px 0 8px;color:var(--ink-muted);font-size:15px;line-height:1.7;max-width:680px}
.faq-item .faq-body p{margin-bottom:10px}

/* FORMS ================================================================ */
.form-row{margin-bottom:20px}
.form-row label{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:var(--ink-muted);display:block;margin-bottom:8px;font-weight:500}
.form-row label .req{color:var(--rust);margin-left:2px}
.form-row input,.form-row select,.form-row textarea{
  width:100%;padding:14px 16px;border:1px solid var(--line);background:var(--bg);
  font-family:var(--sans);font-size:15px;color:var(--ink);border-radius:var(--radius);
  transition:all var(--transition);
}
.form-row input:focus,.form-row select:focus,.form-row textarea:focus{
  outline:none;border-color:var(--gold);background:var(--bg);
  box-shadow:0 0 0 3px var(--gold-glow);
}
.form-row textarea{resize:vertical;min-height:120px}
.form-row select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23737078' d='M6 8L0 0h12z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center;padding-right:40px}
.form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:20px}
@media(max-width:600px){.form-grid-2{grid-template-columns:1fr;gap:0}}
.form-success{padding:24px;background:rgba(94,122,93,.08);border:1px solid var(--sage);border-radius:var(--radius);color:var(--sage);font-weight:500;display:none}
.form-success.show{display:block}
.form-error{padding:16px;background:rgba(160,78,58,.08);border:1px solid var(--rust);border-radius:var(--radius);color:var(--rust);font-size:14px;display:none}
.form-error.show{display:block}

/* PRICING TABLES ======================================================== */
.pricing-toggle{display:inline-flex;background:var(--bg-warm);border:1px solid var(--line);border-radius:99px;padding:4px;margin-bottom:48px}
.pricing-toggle button{padding:10px 24px;border-radius:99px;font-size:14px;font-weight:600;color:var(--ink-muted);transition:all var(--transition);font-family:var(--sans)}
.pricing-toggle button.active{background:var(--ink);color:var(--bg)}
.pricing-card{padding:36px 32px;border:1px solid var(--line);border-radius:var(--radius);background:var(--bg);position:relative;transition:all var(--transition)}
.pricing-card.featured{border-color:var(--ink);background:var(--ink);color:var(--bg);transform:scale(1.02)}
.pricing-card.featured h3,.pricing-card.featured .price-display{color:var(--bg)}
.pricing-card.featured .price-period{color:var(--muted-2)}
.pricing-card.featured .pill{background:var(--gold);color:var(--ink);border-color:var(--gold)}
.pricing-card .pill{margin-bottom:16px}
.pricing-card h3{font-size:26px;margin-bottom:8px}
.pricing-card .desc{font-size:13px;color:var(--ink-muted);margin-bottom:24px}
.pricing-card.featured .desc{color:var(--muted-2)}
.pricing-card .price-display{font-family:var(--serif);font-size:48px;font-weight:500;line-height:1;letter-spacing:-.02em;margin-bottom:6px}
.pricing-card .price-display .currency{font-size:.5em;font-weight:400;color:var(--gold-deep);vertical-align:super}
.pricing-card .price-period{font-family:var(--mono);font-size:11px;letter-spacing:.1em;color:var(--muted);text-transform:uppercase;margin-bottom:32px;display:block}
.pricing-card ul{list-style:none;margin-bottom:32px}
.pricing-card ul li{padding:10px 0;border-bottom:1px solid var(--line-soft);font-size:14px;display:flex;align-items:flex-start;gap:10px}
.pricing-card.featured ul li{border-bottom-color:rgba(255,255,255,.08)}
.pricing-card ul li::before{content:'✓';color:var(--gold);font-weight:bold;flex-shrink:0}
.pricing-card.featured ul li::before{color:var(--gold-soft)}

/* FOOTER ================================================================ */
footer{
  background:var(--ink);color:var(--bg-warm);padding:64px 0 32px;
  border-top:1px solid var(--gold-deep);position:relative;z-index:2;margin-top:64px;
}
footer .container{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px}
footer .brand{font-family:var(--serif);font-size:22px;font-weight:500;color:var(--bg);margin-bottom:14px;display:flex;align-items:center;gap:10px}
footer .tagline{font-family:var(--serif);font-style:italic;font-size:15px;color:var(--muted-2);font-weight:300;line-height:1.5;max-width:340px}
footer h4{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.18em;color:var(--gold-soft);margin-bottom:18px;font-weight:500}
footer ul{list-style:none}
footer ul li{margin-bottom:8px}
footer a{color:var(--bg-warm);font-size:14px;transition:color var(--transition)}
footer a:hover{color:var(--gold-soft)}
footer .copy{padding-top:32px;border-top:1px solid rgba(255,255,255,.08);font-family:var(--mono);font-size:11px;color:var(--muted-2);letter-spacing:.05em;display:flex;justify-content:space-between;flex-wrap:wrap;gap:16px}
@media(max-width:880px){footer .container{grid-template-columns:1fr 1fr;gap:32px}}
@media(max-width:600px){footer .container{grid-template-columns:1fr}}

/* GEO SCORE TOOL ======================================================== */
.geo-tool{
  background:var(--bg-soft);border:1px solid var(--line);border-radius:var(--radius);
  padding:48px;position:relative;overflow:hidden;
}
.geo-tool::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--gold-deep),var(--gold),var(--gold-deep))}
.geo-step{display:none}
.geo-step.active{display:block;animation:fadeIn .3s ease}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.geo-progress{height:4px;background:var(--line-soft);border-radius:2px;margin-bottom:32px;overflow:hidden}
.geo-progress-fill{height:100%;background:var(--gold);transition:width .4s ease}
.geo-question{font-family:var(--serif);font-size:24px;font-weight:400;line-height:1.3;margin-bottom:8px;color:var(--ink)}
.geo-hint{color:var(--ink-muted);font-size:14px;margin-bottom:24px}
.geo-options{display:grid;gap:10px}
.geo-option{padding:16px 20px;border:1px solid var(--line);background:var(--bg);border-radius:var(--radius);cursor:pointer;transition:all var(--transition);font-size:15px;text-align:left;font-family:var(--sans);color:var(--ink);display:flex;align-items:center;gap:12px}
.geo-option:hover{border-color:var(--gold);background:var(--bg-warm)}
.geo-option.selected{border-color:var(--ink);background:var(--ink);color:var(--bg)}
.geo-option .pts{font-family:var(--mono);font-size:11px;color:var(--gold-deep);margin-left:auto}
.geo-option.selected .pts{color:var(--gold-soft)}
.geo-nav{display:flex;justify-content:space-between;margin-top:32px;padding-top:24px;border-top:1px solid var(--line-soft)}
.geo-result{text-align:center;padding:32px 0}
.geo-score-big{font-family:var(--serif);font-size:96px;font-weight:300;letter-spacing:-.04em;line-height:1;margin-bottom:8px}
.geo-score-big.bad{color:var(--rust)}
.geo-score-big.ok{color:var(--gold-deep)}
.geo-score-big.good{color:var(--sage)}
.geo-score-label{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:32px}
.geo-breakdown{text-align:left;background:var(--bg);border:1px solid var(--line-soft);border-radius:var(--radius);padding:32px;margin:32px 0}
.geo-breakdown h4{font-family:var(--serif);font-weight:500;font-size:18px;margin-bottom:16px}
.geo-bar-row{margin-bottom:14px}
.geo-bar-label{display:flex;justify-content:space-between;font-size:13px;margin-bottom:6px;color:var(--ink-muted)}
.geo-bar-label strong{color:var(--ink);font-weight:600}
.geo-bar-bg{height:6px;background:var(--line-soft);border-radius:3px;overflow:hidden}
.geo-bar-fill{height:100%;background:var(--gold);border-radius:3px;transition:width .8s ease}

/* LOCATION HERO ========================================================= */
.loc-hero{padding:80px 0 48px}
.loc-hero h1{font-size:clamp(40px,5.5vw,68px)}
.loc-meta{display:flex;flex-wrap:wrap;gap:8px;margin-top:24px}

/* TESTIMONIAL =========================================================== */
.testimonial{padding:48px;border:1px solid var(--line);border-left:3px solid var(--gold);background:var(--bg-soft);border-radius:var(--radius)}
.testimonial blockquote{font-family:var(--serif);font-size:22px;line-height:1.5;font-weight:400;font-style:italic;color:var(--ink);margin-bottom:24px}
.testimonial cite{font-style:normal;font-size:14px;color:var(--ink-muted);font-family:var(--sans);font-weight:500}
.testimonial cite span{display:block;font-size:13px;color:var(--muted);font-weight:400;margin-top:2px}

/* CTA STRIP ============================================================= */
.cta-strip{
  margin:64px 0;padding:64px;background:var(--ink);color:var(--bg);
  border-radius:var(--radius);text-align:center;position:relative;overflow:hidden;
}
.cta-strip::before{content:'';position:absolute;top:-50%;right:-10%;width:60%;height:200%;background:radial-gradient(ellipse,var(--gold-glow) 0%,transparent 60%);opacity:.6}
.cta-strip > *{position:relative;z-index:1}
.cta-strip h2{font-size:clamp(32px,4.5vw,48px);margin-bottom:16px;color:var(--bg)}
.cta-strip p{color:var(--muted-2);max-width:560px;margin:0 auto 32px;font-size:17px}
.cta-strip .btn-gold:hover{background:var(--bg);color:var(--ink)}

/* UTILITIES ============================================================= */
.text-center{text-align:center}
.mt-0{margin-top:0!important}.mt-1{margin-top:8px}.mt-2{margin-top:16px}.mt-3{margin-top:24px}.mt-4{margin-top:32px}.mt-6{margin-top:48px}.mt-8{margin-top:64px}
.mb-0{margin-bottom:0!important}.mb-1{margin-bottom:8px}.mb-2{margin-bottom:16px}.mb-3{margin-bottom:24px}.mb-4{margin-bottom:32px}.mb-6{margin-bottom:48px}.mb-8{margin-bottom:64px}
.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-2{gap:16px}.gap-3{gap:24px}.gap-4{gap:32px}.flex-wrap{flex-wrap:wrap}
.text-muted{color:var(--ink-muted)}
.text-gold{color:var(--gold-deep)}
.bg-soft{background:var(--bg-soft)}
.border-t{border-top:1px solid var(--line)}
.divider{height:1px;background:var(--line);margin:48px 0}

/* PRINT-FRIENDLY ======================================================== */
@media print{
  body::before{display:none}
  .nav-bar,.cta-strip,footer{display:none}
}

/* PREFERS REDUCED MOTION ================================================ */
@media(prefers-reduced-motion:reduce){
  *{animation-duration:0.01ms!important;transition-duration:0.01ms!important}
}
