
:root {
  --gold: #D4AF37;
  --gold-dim: rgba(212,175,55,0.12);
  --gold-glow: rgba(212,175,55,0.3);
  --red: #C0392B;
  --green: #27AE60;
  --bg:  #0f0f11;
  --bg2: #161619;
  --bg3: #1e1e23;
  --border: rgba(255,255,255,0.07);
  --border-gold: rgba(212,175,55,0.28);
  --text:   #EDEAE4;
  --text-2: #8F8C87;
  --text-3: #4e4c49;
  --radius: 10px;
  --radius-sm: 6px;
  --ease: 0.2s cubic-bezier(0.4,0,0.2,1);
}

*,*::before,*::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }

body {
  font-family:'DM Sans',sans-serif;
  background:var(--bg);
  color:var(--text);
  line-height:1.6;
  overflow-x:hidden;
  min-height:100vh;
}

/* ── SECTIONS ───────────────────────────────── */
.section { display:none; min-height:100vh; flex-direction:column; }
.section.active { display:flex; }

/* ── NAV ─────────────────────────────────────── */
.nav {
  position:fixed; top:0; left:0; right:0; z-index:200;
  height:56px; padding:0 32px;
  display:flex; align-items:center; justify-content:space-between;
  background:rgba(15,15,17,0.85);
  backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);
}
.nav-logo {
  font-family:'Playfair Display',serif;
  font-size:1.2rem; font-weight:800;
  color:var(--gold); cursor:pointer;
  text-decoration:none; letter-spacing:-0.01em;
}
.nav-links { display:flex; gap:4px; align-items:center; }
.nav-link {
  background:none; border:none; cursor:pointer;
  padding:6px 13px; border-radius:var(--radius-sm);
  font-family:'DM Sans',sans-serif; font-size:0.85rem; font-weight:500;
  color:var(--text-2); transition:var(--ease);
}
.nav-link:hover { color:var(--text); background:var(--bg3); }
.nav-cta {
  background:var(--gold); color:#111; border:none; cursor:pointer;
  padding:7px 16px; border-radius:var(--radius-sm);
  font-family:'DM Sans',sans-serif; font-size:0.85rem; font-weight:700;
  transition:var(--ease); margin-left:6px;
}
.nav-cta:hover { background:#c9a630; }
.burger { display:none; flex-direction:column; gap:5px; cursor:pointer; background:none; border:none; padding:6px; z-index:3000; position:relative; }
.burger span { display:block; width:22px; height:2px; background:var(--text); border-radius:2px; transition:var(--ease); }
.burger.open span:nth-child(1) { transform:rotate(45deg) translate(5px,5px); }
.burger.open span:nth-child(2) { opacity:0; transform:translateX(-4px); }
.burger.open span:nth-child(3) { transform:rotate(-45deg) translate(5px,-5px); }

/* Mobile menu overlay — lives outside nav stacking context */
.mobile-menu {
  display:none;
  position:fixed; inset:0; z-index:2500;
  background:var(--bg);
  flex-direction:column; align-items:center; justify-content:center; gap:6px;
}
.mobile-menu.open { display:flex; }
.mobile-menu .mm-link {
  background:none; border:none; cursor:pointer;
  font-family:'DM Sans',sans-serif; font-size:1.15rem; font-weight:500;
  color:var(--text-2); padding:14px 48px; border-radius:var(--radius-sm);
  transition:var(--ease); width:100%; max-width:300px; text-align:center;
}
.mobile-menu .mm-link:hover { color:var(--text); background:var(--bg3); }
.mobile-menu .mm-cta {
  margin-top:10px; background:var(--gold); color:#111; border:none; cursor:pointer;
  font-family:'DM Sans',sans-serif; font-size:1.15rem; font-weight:700;
  padding:14px 48px; border-radius:var(--radius-sm);
  transition:var(--ease); width:100%; max-width:300px; text-align:center;
}
.mobile-menu .mm-cta:hover { background:#c9a630; }
.mobile-menu .mm-close {
  position:absolute; top:16px; right:20px;
  background:none; border:none; cursor:pointer;
  color:var(--text-3); font-size:1.6rem; line-height:1; padding:8px;
  transition:var(--ease);
}
.mobile-menu .mm-close:hover { color:var(--text); }

/* ── BUTTONS ─────────────────────────────────── */
.btn-primary {
  background:var(--gold); color:#111; border:none; cursor:pointer;
  padding:13px 30px; border-radius:var(--radius-sm);
  font-family:'DM Sans',sans-serif; font-size:0.95rem; font-weight:700;
  transition:var(--ease); display:inline-flex; align-items:center; gap:8px;
}
.btn-primary:hover { background:#c9a630; }
.btn-secondary {
  background:transparent; color:var(--text-2);
  border:1px solid var(--border); cursor:pointer;
  padding:13px 30px; border-radius:var(--radius-sm);
  font-family:'DM Sans',sans-serif; font-size:0.95rem; font-weight:500;
  transition:var(--ease);
}
.btn-secondary:hover { border-color:rgba(255,255,255,0.15); color:var(--text); }

/* ── HOMEPAGE ────────────────────────────────── */
#homepage {
  background: radial-gradient(ellipse 70% 45% at 50% -5%, rgba(212,175,55,0.1) 0%, transparent 55%), var(--bg);
}
.hero {
  padding:130px 24px 80px;
  display:flex; flex-direction:column; align-items:center;
  text-align:center; flex:1;
}
.hero-kicker {
  font-size:0.9rem; color:var(--text-2); max-width:580px;
  line-height:1.65; margin-bottom:32px; font-weight:400;
  animation: fadeUp 0.5s 0.16s ease both;
}
.hero-title {
  font-family:'Playfair Display',serif;
  font-size:clamp(2.8rem, 6.5vw, 5rem);
  font-weight:800; line-height:1.06;
  max-width:780px; margin-bottom:20px;
  animation: fadeUp 0.5s 0.08s ease both;
}
.hero-title .accent { color:var(--gold); }
.hero-actions { display:flex; gap:12px; flex-wrap:wrap; justify-content:center; animation: fadeUp 0.5s 0.24s ease both; }
.hero-divider {
  width:100%; max-width:860px; margin-top:64px;
  border-top:1px solid var(--border);
  padding-top:40px;
  display:flex; gap:48px; justify-content:center;
  animation: fadeUp 0.5s 0.32s ease both;
}
.hero-stat { text-align:center; }
.hero-stat-num {
  font-family:'Playfair Display',serif; font-size:2rem; font-weight:800;
  color:var(--gold); display:block; line-height:1;
}
.hero-stat-label { font-size:0.75rem; color:var(--text-3); text-transform:uppercase; letter-spacing:0.07em; margin-top:5px; }

/* Shared section labels (used in other sections) */
.section-eyebrow { font-size:0.72rem; font-weight:600; letter-spacing:0.1em; text-transform:uppercase; color:var(--gold); margin-bottom:10px; display:block; }
.section-heading { font-family:'Playfair Display',serif; font-size:clamp(1.7rem,3.5vw,2.4rem); font-weight:800; margin-bottom:40px; }

/* ── QUIZ ────────────────────────────────────── */
#quiz, #filament-quiz { background:var(--bg); padding-top:56px; }
.quiz-wrap { max-width:620px; margin:0 auto; padding:56px 24px 60px; flex:1; display:flex; flex-direction:column; }

.progress-track { height:2px; background:var(--bg3); border-radius:2px; margin-bottom:10px; }
.progress-fill { height:100%; background:var(--gold); border-radius:2px; transition:width 0.45s cubic-bezier(0.4,0,0.2,1); }
.progress-meta { display:flex; justify-content:space-between; align-items:center; font-size:0.78rem; color:var(--text-3); margin-bottom:48px; }
.progress-step { font-weight:600; color:var(--text-2); }
.exit-btn { background:none; border:none; cursor:pointer; color:var(--text-3); font-family:'DM Sans',sans-serif; font-size:0.78rem; transition:var(--ease); }
.exit-btn:hover { color:var(--text-2); }

.q-number { font-size:0.72rem; font-weight:600; letter-spacing:0.1em; text-transform:uppercase; color:var(--gold); margin-bottom:12px; }
.q-text { font-family:'Playfair Display',serif; font-size:clamp(1.4rem,3.8vw,1.95rem); font-weight:700; line-height:1.25; margin-bottom:32px; }
.q-hint { font-size:0.82rem; color:var(--text-3); margin-top:-22px; margin-bottom:24px; line-height:1.5; }

.answers-grid { display:flex; flex-direction:column; gap:8px; }
.answers-grid.two-col { display:grid; grid-template-columns:1fr 1fr; gap:8px; }
.answers-grid.three-col { display:grid; grid-template-columns:1fr 1fr 1fr; gap:8px; }

.answer-btn {
  width:100%; text-align:left; background:var(--bg2);
  border:1px solid var(--border); color:var(--text);
  cursor:pointer; padding:14px 18px; border-radius:var(--radius-sm);
  font-family:'DM Sans',sans-serif; font-size:0.9rem; font-weight:400;
  transition:var(--ease);
  animation: fadeUp 0.25s ease both;
}
.answer-btn:hover { border-color:rgba(255,255,255,0.14); background:var(--bg3); }
.answer-btn.selected { border-color:var(--gold); background:var(--gold-dim); color:var(--text); }

.dynamic-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(185px,1fr)); gap:8px; }
.dyn-btn {
  background:var(--bg2); border:1px solid var(--border);
  color:var(--text-2); cursor:pointer; padding:13px 16px;
  border-radius:var(--radius-sm); font-family:'DM Sans',sans-serif;
  font-size:0.85rem; font-weight:500; transition:var(--ease); text-align:left;
  display:flex; align-items:center; gap:10px;
}
.dyn-btn:hover { border-color:rgba(255,255,255,0.14); color:var(--text); }
.dyn-btn.selected { border-color:var(--gold); background:var(--gold-dim); color:var(--text); }
.dyn-dot {
  width:14px; height:14px; border-radius:50%; border:1.5px solid var(--text-3);
  flex-shrink:0; transition:var(--ease); display:flex; align-items:center; justify-content:center;
}
.dyn-btn.selected .dyn-dot { background:var(--gold); border-color:var(--gold); }
.dyn-btn.selected .dyn-dot::after { content:''; display:block; width:5px; height:5px; border-radius:50%; background:#111; }

.quiz-foot { display:flex; justify-content:space-between; align-items:center; margin-top:32px; padding-top:24px; border-top:1px solid var(--border); }
.btn-back { background:none; border:none; cursor:pointer; color:var(--text-3); font-family:'DM Sans',sans-serif; font-size:0.875rem; padding:8px 4px; transition:var(--ease); display:flex; align-items:center; gap:6px; }
.btn-back:hover { color:var(--text-2); }
.btn-next { background:var(--gold); color:#111; border:none; cursor:pointer; padding:11px 26px; border-radius:var(--radius-sm); font-family:'DM Sans',sans-serif; font-size:0.875rem; font-weight:700; transition:var(--ease); }
.btn-next:hover { background:#c9a630; }
.btn-next:disabled { opacity:0.3; cursor:not-allowed; }

/* ── RESULTS ─────────────────────────────────── */
#results { background:var(--bg); padding-top:56px; }
.results-top { max-width:1120px; margin:0 auto; padding:52px 24px 0; }
.results-eyebrow { font-size:0.72rem; font-weight:600; letter-spacing:0.1em; text-transform:uppercase; color:var(--gold); margin-bottom:10px; }
.results-heading { font-family:'Playfair Display',serif; font-size:clamp(1.8rem,4vw,2.6rem); font-weight:800; margin-bottom:6px; }
.results-sub { color:var(--text-2); font-size:0.9rem; margin-bottom:28px; }
.results-bar { display:flex; gap:8px; flex-wrap:wrap; margin-bottom:40px; }
.act-btn {
  background:var(--bg3); border:1px solid var(--border); color:var(--text-2);
  cursor:pointer; padding:8px 16px; border-radius:var(--radius-sm);
  font-family:'DM Sans',sans-serif; font-size:0.8rem; font-weight:500;
  transition:var(--ease);
}
.act-btn:hover { border-color:rgba(255,255,255,0.14); color:var(--text); }
.act-btn.copied { border-color:var(--gold); color:var(--gold); }

/* Podium */
/* AI Overview */
.ai-overview-wrap { max-width:1120px; margin:0 auto 32px; padding:0 24px; }
.ai-overview-header { display:flex; align-items:center; gap:10px; margin-bottom:10px; }
.ai-overview-eyebrow { font-size:0.72rem; font-weight:700; letter-spacing:0.12em; text-transform:uppercase; color:var(--gold); }
.ai-overview-badge { font-size:0.68rem; font-weight:600; color:var(--text-3); border:1px solid var(--border); border-radius:20px; padding:2px 9px; letter-spacing:0.04em; }
.ai-overview-body { background:var(--bg2); border:1px solid var(--border); border-radius:12px; padding:18px 20px; min-height:52px; display:flex; align-items:center; }
.ai-overview-loading { display:flex; gap:6px; align-items:center; }
.ai-dot { width:7px; height:7px; border-radius:50%; background:var(--gold); opacity:0.4; animation:aiPulse 1.2s ease-in-out infinite; }
.ai-dot:nth-child(2) { animation-delay:0.2s; }
.ai-dot:nth-child(3) { animation-delay:0.4s; }
@keyframes aiPulse { 0%,100% { opacity:0.2; transform:scale(0.85); } 50% { opacity:1; transform:scale(1.1); } }
.ai-overview-text { font-size:0.9rem; line-height:1.65; color:var(--text-2); margin:0; }
.podium-wrap { max-width:1120px; margin:0 auto; padding:0 24px; }
.podium-label { font-size:0.72rem; font-weight:600; letter-spacing:0.1em; text-transform:uppercase; color:var(--text-3); margin-bottom:16px; display:block; }
.podium { display:grid; grid-template-columns:1fr; gap:14px; }
@media(min-width:768px){ .podium { grid-template-columns:repeat(3,1fr); } }

.p-card {
  background:var(--bg2); border:1px solid var(--border);
  border-radius:var(--radius); overflow:hidden;
  transition:var(--ease);
  animation: fadeUp 0.4s ease both;
}
.p-card:hover { border-color:rgba(255,255,255,0.12); }
.p-card.rank-1 { border-color:var(--border-gold); }
.p-card.rank-2 { animation-delay:0.06s; }
.p-card.rank-3 { animation-delay:0.12s; }

.p-head {
  padding:16px 18px 0;
  display:flex; align-items:center; justify-content:space-between;
}
.p-rank {
  font-size:0.7rem; font-weight:700; letter-spacing:0.08em; text-transform:uppercase;
  color:var(--text-3); background:var(--bg3); border:1px solid var(--border);
  padding:3px 10px; border-radius:100px;
}
.rank-1 .p-rank { color:var(--gold); background:var(--gold-dim); border-color:var(--border-gold); }
.p-pct { font-family:'Playfair Display',serif; font-size:1.4rem; font-weight:800; color:var(--gold); }
.rank-2 .p-pct, .rank-3 .p-pct { color:var(--text-2); }

.p-body { padding:14px 18px; }
.p-name { font-size:1rem; font-weight:700; margin-bottom:3px; }
.p-price { font-size:0.85rem; color:var(--text-2); margin-bottom:16px; }
.p-price .was { color:var(--text-3); font-size:0.78rem; text-decoration:line-through; margin-left:6px; }

/* Match bars */
.mbars { display:flex; flex-direction:column; gap:6px; margin-bottom:14px; }
.mbar-row { display:flex; align-items:center; gap:10px; }
.mbar-label { font-size:0.68rem; color:var(--text-3); width:76px; flex-shrink:0; text-transform:uppercase; letter-spacing:0.04em; }
.mbar-track { flex:1; height:3px; background:var(--bg3); border-radius:3px; overflow:hidden; }
.mbar-fill { height:100%; background:var(--gold); border-radius:3px; width:0; transition:width 0.75s cubic-bezier(0.4,0,0.2,1); }
.rank-2 .mbar-fill, .rank-3 .mbar-fill { background:var(--text-3); }

.p-tags { display:flex; flex-wrap:wrap; gap:5px; margin-bottom:14px; }
.ptag {
  font-size:0.7rem; font-weight:500; background:var(--bg3);
  border:1px solid var(--border); padding:3px 9px; border-radius:100px; color:var(--text-2);
}
.ptag.g { background:rgba(39,174,96,0.1); border-color:rgba(39,174,96,0.2); color:#4ade80; }
.ptag.w { background:rgba(212,175,55,0.1); border-color:var(--border-gold); color:var(--gold); }

.p-foot { padding:0 18px 14px; display:flex; gap:7px; }
.btn-detail {
  flex:1; background:var(--bg3); border:1px solid var(--border); color:var(--text-2);
  cursor:pointer; padding:9px 0; border-radius:var(--radius-sm);
  font-family:'DM Sans',sans-serif; font-size:0.8rem; font-weight:500; transition:var(--ease);
}
.btn-detail:hover { border-color:rgba(255,255,255,0.14); color:var(--text); }
.btn-add-cmp {
  flex:1; background:transparent; border:1px solid var(--border-gold); color:var(--gold);
  cursor:pointer; padding:9px 0; border-radius:var(--radius-sm);
  font-family:'DM Sans',sans-serif; font-size:0.8rem; font-weight:600; transition:var(--ease);
}
.btn-add-cmp:hover { background:var(--gold-dim); }

.why-toggle {
  width:100%; background:none; border:none; border-top:1px solid var(--border);
  color:var(--text-3); cursor:pointer; padding:10px 18px;
  font-family:'DM Sans',sans-serif; font-size:0.75rem; font-weight:500;
  display:flex; align-items:center; justify-content:space-between;
  transition:var(--ease);
}
.why-toggle:hover { color:var(--text-2); }
.why-arrow { transition:transform 0.2s ease; }
.why-toggle.open .why-arrow { transform:rotate(180deg); }
.why-body { display:none; padding:10px 18px 14px; }
.why-body.open { display:block; }
.why-item { font-size:0.78rem; color:var(--text-2); padding:3px 0; display:flex; align-items:flex-start; gap:8px; }
.why-item::before { content:'—'; color:var(--gold); flex-shrink:0; font-size:0.7rem; margin-top:2px; }

/* All results */
.all-wrap { max-width:1120px; margin:0 auto; padding:32px 24px 80px; }
.all-label { font-size:0.78rem; color:var(--text-3); margin-bottom:16px; }
.results-list { display:grid; grid-template-columns:repeat(auto-fill,minmax(260px,1fr)); gap:12px; }
.r-card {
  background:var(--bg2); border:1px solid var(--border);
  border-radius:var(--radius); padding:18px; cursor:pointer;
  transition:var(--ease); animation:fadeUp 0.35s ease both;
}
.r-card:hover { border-color:rgba(255,255,255,0.12); }
.r-card-top { display:flex; justify-content:space-between; align-items:flex-start; margin-bottom:6px; }
.r-card-name { font-size:0.9rem; font-weight:600; }
.r-card-pct { font-family:'Playfair Display',serif; font-size:1.1rem; font-weight:800; color:var(--text-2); }
.r-card-price { font-size:0.82rem; color:var(--text-2); margin-bottom:10px; }
.mini-bar { height:2px; background:var(--bg3); border-radius:2px; overflow:hidden; }
.mini-fill { height:100%; background:var(--text-3); border-radius:2px; transition:width 0.9s ease; }

/* ── DATABASE ────────────────────────────────── */
#database { background:var(--bg); padding-top:56px; }
.db-wrap { max-width:1120px; margin:0 auto; padding:52px 24px; }
.db-top { margin-bottom:28px; }
.db-search-row { display:flex; gap:10px; margin-top:20px; flex-wrap:wrap; align-items:center; }
.db-search {
  flex:1; min-width:200px; background:var(--bg2); border:1px solid var(--border);
  color:var(--text); padding:10px 16px; border-radius:var(--radius-sm);
  font-family:'DM Sans',sans-serif; font-size:0.875rem; outline:none; transition:var(--ease);
}
.db-search:focus { border-color:rgba(255,255,255,0.14); }
.db-search::placeholder { color:var(--text-3); }
.db-count { font-size:0.82rem; color:var(--text-3); }

.db-filters { display:flex; gap:10px; flex-wrap:wrap; margin-bottom:28px; align-items:flex-end; }
.filter-grp { display:flex; flex-direction:column; gap:5px; }
.filter-lbl { font-size:0.68rem; color:var(--text-3); text-transform:uppercase; letter-spacing:0.07em; font-weight:600; }
.filter-pills { display:flex; flex-wrap:wrap; gap:6px; }
.fpill {
  background:var(--bg2); border:1px solid var(--border); color:var(--text-2);
  cursor:pointer; padding:6px 13px; border-radius:100px;
  font-family:'DM Sans',sans-serif; font-size:0.78rem; font-weight:500; transition:var(--ease);
}
.fpill:hover { border-color:rgba(255,255,255,0.13); color:var(--text); }
.fpill.active { background:var(--gold-dim); border-color:var(--border-gold); color:var(--gold); }
.f-select {
  background:var(--bg2); border:1px solid var(--border); color:var(--text);
  padding:8px 13px; border-radius:var(--radius-sm);
  font-family:'DM Sans',sans-serif; font-size:0.82rem; outline:none;
  cursor:pointer; transition:var(--ease); min-width:125px;
}
.f-select:hover, .f-select:focus { border-color:rgba(255,255,255,0.13); }

.db-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(270px,1fr)); gap:14px; }
.db-card {
  background:var(--bg2); border:1px solid var(--border);
  border-radius:var(--radius); padding:20px; cursor:pointer; transition:var(--ease);
}
.db-card:hover { border-color:rgba(255,255,255,0.12); }
.db-card-head { display:flex; justify-content:space-between; align-items:flex-start; margin-bottom:6px; }
.db-brand { font-size:0.68rem; text-transform:uppercase; letter-spacing:0.07em; color:var(--text-3); font-weight:600; margin-bottom:3px; }
.db-name { font-size:0.92rem; font-weight:600; }
.db-price { font-size:1.1rem; font-weight:700; color:var(--gold); }
.db-sale { font-size:0.75rem; color:var(--text-3); text-decoration:line-through; }
.db-meta { font-size:0.75rem; color:var(--text-3); margin:6px 0 10px; }
.db-tags { display:flex; flex-wrap:wrap; gap:5px; }
.dtag {
  font-size:0.68rem; font-weight:500; background:var(--bg3);
  border:1px solid var(--border); padding:3px 8px; border-radius:100px; color:var(--text-2);
}
.dtag.enc { background:rgba(39,174,96,0.08); border-color:rgba(39,174,96,0.18); color:#4ade80; }
.dtag.mc { background:rgba(120,100,220,0.08); border-color:rgba(120,100,220,0.2); color:#a78bfa; }
.dtag.rat { background:var(--gold-dim); border-color:var(--border-gold); color:var(--gold); }
.dtag.new-badge { background:rgba(232,99,58,0.12); border-color:rgba(232,99,58,0.3); color:#e8633a; font-weight:600; }

/* ── COMPARISON ──────────────────────────────── */
#comparison { background:var(--bg); padding-top:56px; }
.cmp-wrap { max-width:1280px; margin:0 auto; padding:52px 24px 80px; }
.cmp-add-row { display:flex; gap:10px; margin:20px 0 18px; flex-wrap:wrap; align-items:center; }
.cmp-select {
  background:var(--bg2); border:1px solid var(--border); color:var(--text);
  padding:9px 14px; border-radius:var(--radius-sm); font-family:'DM Sans',sans-serif;
  font-size:0.85rem; outline:none; flex:1; min-width:200px; max-width:340px;
}
.cmp-select:focus { border-color:rgba(255,255,255,0.14); }
.btn-cmp-add {
  background:var(--gold); color:#111; border:none; cursor:pointer;
  padding:9px 18px; border-radius:var(--radius-sm);
  font-family:'DM Sans',sans-serif; font-size:0.85rem; font-weight:700; transition:var(--ease);
}
.btn-cmp-add:hover { background:#c9a630; }
.cmp-chips { display:flex; flex-wrap:wrap; gap:7px; margin-bottom:20px; }
.cmp-chip {
  background:var(--bg3); border:1px solid var(--border-gold); color:var(--text);
  padding:5px 12px; border-radius:100px; font-size:0.78rem; font-weight:500;
  display:flex; align-items:center; gap:8px;
}
.chip-rm { background:none; border:none; cursor:pointer; color:var(--text-3); font-size:0.85rem; padding:0; line-height:1; transition:var(--ease); }
.chip-rm:hover { color:var(--red); }
.cmp-tbl-wrap { overflow-x:auto; border:1px solid var(--border); border-radius:var(--radius); }
.cmp-tbl { width:100%; border-collapse:collapse; font-size:0.85rem; }
.cmp-tbl th, .cmp-tbl td { padding:11px 16px; text-align:left; vertical-align:top; border-bottom:1px solid var(--border); }
.cmp-tbl thead tr { background:var(--bg3); }
.cmp-tbl thead th { font-weight:600; font-size:0.75rem; text-transform:uppercase; letter-spacing:0.06em; color:var(--text-2); }
.cmp-tbl thead th:first-child { color:var(--text-3); font-size:0.68rem; }
.cmp-tbl tbody tr:nth-child(even) { background:rgba(22,22,25,0.5); }
.cmp-tbl tbody td:first-child { color:var(--text-3); font-size:0.75rem; font-weight:600; text-transform:uppercase; letter-spacing:0.06em; white-space:nowrap; }
.cmp-tbl .hi { color:var(--gold); font-weight:600; }
.cmp-tbl .good { color:#4ade80; }
.cmp-tbl .warn { color:var(--gold); }
.cmp-tbl .bad { color:#f87171; }

/* ── MODAL ───────────────────────────────────── */
.modal-bg {
  position:fixed; inset:0; z-index:500;
  background:rgba(0,0,0,0.75); backdrop-filter:blur(10px);
  display:flex; align-items:flex-end; justify-content:center;
  padding:0; opacity:0; visibility:hidden; transition:var(--ease);
}
@media(min-width:600px){
  .modal-bg { align-items:center; padding:24px; }
}
.modal-bg.open { opacity:1; visibility:visible; }
.modal {
  background:var(--bg2); border:1px solid var(--border);
  border-radius:var(--radius) var(--radius) 0 0;
  width:100%; max-width:600px; max-height:92vh;
  overflow-y:auto; transform:translateY(100%); transition:var(--ease);
}
@media(min-width:600px){
  .modal { border-radius:var(--radius); max-height:88vh; transform:translateY(16px); }
}
.modal-bg.open .modal { transform:translateY(0); }
.modal-hd {
  padding:24px 24px 18px; display:flex; align-items:flex-start; justify-content:space-between;
  border-bottom:1px solid var(--border); position:sticky; top:0; background:var(--bg2); z-index:2;
}
.modal-name { font-family:'Playfair Display',serif; font-size:1.3rem; font-weight:700; }
.modal-px { font-size:1.1rem; font-weight:700; color:var(--gold); margin-top:3px; }
.modal-x { background:none; border:none; cursor:pointer; color:var(--text-3); font-size:1.2rem; padding:4px; transition:var(--ease); }
.modal-x:hover { color:var(--text); }
.modal-bd { padding:22px 24px; }
.m-sec { margin-bottom:22px; }
.m-sec-title { font-size:0.7rem; font-weight:700; text-transform:uppercase; letter-spacing:0.09em; color:var(--gold); margin-bottom:10px; }
.m-grid { display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.m-spec { background:var(--bg3); border-radius:var(--radius-sm); padding:11px 14px; }
.m-spec-lbl { font-size:0.68rem; color:var(--text-3); text-transform:uppercase; letter-spacing:0.06em; margin-bottom:3px; }
.m-spec-val { font-size:0.9rem; font-weight:600; }
.m-rating { display:flex; align-items:center; gap:14px; background:var(--bg3); border-radius:var(--radius-sm); padding:14px; margin-bottom:10px; }
.m-rating-num { font-family:'Playfair Display',serif; font-size:2.2rem; font-weight:800; color:var(--gold); line-height:1; }
.m-rating-lbl { font-size:0.75rem; color:var(--text-3); margin-top:3px; }
.m-notes { font-size:0.875rem; color:var(--text-2); line-height:1.65; }
.m-mats { display:flex; flex-wrap:wrap; gap:6px; }
.m-mat { background:var(--bg3); border:1px solid var(--border); padding:4px 11px; border-radius:100px; font-size:0.78rem; color:var(--text-2); }
.m-info-box {
  display:flex; align-items:center; gap:0;
  background:var(--bg3); border:1px solid var(--border);
  border-radius:var(--radius-sm); margin-bottom:20px; overflow:hidden;
}
.m-info-item { flex:1; padding:10px 14px; }
.m-info-lbl { font-size:0.65rem; color:var(--text-3); text-transform:uppercase; letter-spacing:0.07em; font-weight:600; display:block; margin-bottom:3px; }
.m-info-val { font-size:0.85rem; font-weight:600; color:var(--text); }
.m-info-divider { width:1px; background:var(--border); align-self:stretch; flex-shrink:0; }
.modal-ft { padding:16px 24px 22px; border-top:1px solid var(--border); display:flex; gap:10px; }

/* ── STATIC PAGES ────────────────────────────── */
.static-page { padding:110px 24px 80px; max-width:680px; margin:0 auto; width:100%; box-sizing:border-box; overflow-x:hidden; }
.static-page h1 { font-family:'Playfair Display',serif; font-size:2.2rem; margin-bottom:14px; }
.static-page p { color:var(--text-2); line-height:1.8; margin-bottom:14px; font-size:0.95rem; }
.static-page h2 { font-size:1.15rem; font-weight:600; margin:28px 0 10px; }

/* ── FILAMENT RESULTS ────────────────────────── */
#filament-results { background:var(--bg); padding-top:56px; }
.fil-wrap { max-width:860px; margin:0 auto; padding:52px 24px 80px; }
.fil-card {
  background:var(--bg2); border:1px solid var(--border);
  border-radius:var(--radius); padding:22px; margin-bottom:12px;
  animation:fadeUp 0.35s ease both;
}
.fil-top { display:flex; justify-content:space-between; align-items:flex-start; margin-bottom:8px; }
.fil-name { font-size:1.05rem; font-weight:700; }
.fil-diff { font-size:0.75rem; background:var(--bg3); border:1px solid var(--border); padding:3px 10px; border-radius:100px; color:var(--text-2); }
.fil-desc { font-size:0.875rem; color:var(--text-2); margin-bottom:12px; line-height:1.6; }
.fil-specs { display:flex; gap:20px; flex-wrap:wrap; }
.fil-spec { font-size:0.8rem; color:var(--text-2); }
.fil-spec strong { color:var(--text); }
.str-bar { display:inline-block; width:8px; height:8px; border-radius:1px; margin-right:1px; }
.str-bar.on { background:var(--gold); }
.str-bar.off { background:var(--bg3); border:1px solid var(--border); }

/* ── QUIZ MENU ───────────────────────────────── */
#quizzes { background:var(--bg); padding-top:56px; }
.qz-wrap { max-width:860px; margin:0 auto; padding:64px 24px; }
.qz-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); gap:14px; margin-top:32px; }
.qz-card {
  background:var(--bg2); border:1px solid var(--border);
  border-radius:var(--radius); padding:28px; cursor:pointer; transition:var(--ease);
}
.qz-card:hover { border-color:rgba(255,255,255,0.12); }
.qz-label { font-size:0.68rem; font-weight:700; letter-spacing:0.1em; text-transform:uppercase; color:var(--text-3); margin-bottom:10px; }
.qz-title { font-size:1.1rem; font-weight:700; margin-bottom:8px; }
.qz-desc { font-size:0.83rem; color:var(--text-2); line-height:1.6; }

/* ── TOAST ───────────────────────────────────── */
.toast {
  position:fixed; bottom:28px; left:50%; transform:translateX(-50%) translateY(12px);
  background:var(--bg3); border:1px solid var(--border);
  color:var(--text); padding:10px 20px; border-radius:var(--radius-sm);
  font-size:0.82rem; font-weight:500;
  opacity:0; visibility:hidden; transition:all 0.25s ease; z-index:600; white-space:nowrap;
}
.toast.show { opacity:1; visibility:visible; transform:translateX(-50%) translateY(0); }

/* ── FOOTER ──────────────────────────────────── */
.footer { background:var(--bg2); border-top:1px solid var(--border); padding:28px 24px; text-align:center; }
.footer-text { font-size:0.78rem; color:var(--text-3); }
.footer-links { display:flex; gap:14px; justify-content:center; margin-top:8px; }
.footer-lnk { font-size:0.78rem; color:var(--text-3); cursor:pointer; background:none; border:none; font-family:'DM Sans',sans-serif; transition:var(--ease); }
.footer-lnk:hover { color:var(--text-2); }
.footer-tos { font-size:0.72rem; color:var(--text-3); margin-top:10px; }
.footer-tos-link { background:none; border:none; cursor:pointer; color:var(--text-3); font-family:'DM Sans',sans-serif; font-size:inherit; text-decoration:underline; padding:0; transition:var(--ease); }
.footer-tos-link:hover { color:var(--text-2); }

/* ── BROWSE TABS (Printers / Filaments) ──────── */
.browse-tabs {
  display:flex; gap:2px; margin-top:20px;
  background:var(--bg3); border:1px solid var(--border);
  border-radius:var(--radius-sm); padding:3px; width:fit-content;
}
.btab {
  background:none; border:none; cursor:pointer;
  padding:7px 20px; border-radius:calc(var(--radius-sm) - 2px);
  font-family:'DM Sans',sans-serif; font-size:0.85rem; font-weight:500;
  color:var(--text-3); transition:var(--ease);
}
.btab:hover { color:var(--text-2); }
.btab.active { background:var(--bg2); color:var(--text); border:1px solid var(--border); }

/* Filament browse grid */
.fil-db-grid {
  display:grid; grid-template-columns:repeat(auto-fill,minmax(290px,1fr)); gap:14px;
}
.fil-db-card {
  background:var(--bg2); border:1px solid var(--border);
  border-radius:var(--radius); padding:22px; transition:var(--ease);
}
.fil-db-card:hover { border-color:rgba(255,255,255,0.12); }
.fdc-head { display:flex; justify-content:space-between; align-items:flex-start; margin-bottom:10px; }
.fdc-name { font-size:1rem; font-weight:700; }
.fdc-diff {
  font-size:0.68rem; font-weight:600; text-transform:uppercase; letter-spacing:0.07em;
  padding:3px 9px; border-radius:100px; border:1px solid var(--border);
  background:var(--bg3); color:var(--text-2);
}
.fdc-diff.beg { color:#4ade80; background:rgba(39,174,96,0.08); border-color:rgba(39,174,96,0.18); }
.fdc-diff.int { color:var(--gold); background:var(--gold-dim); border-color:var(--border-gold); }
.fdc-diff.adv { color:#f87171; background:rgba(239,68,68,0.08); border-color:rgba(239,68,68,0.18); }
.fdc-desc { font-size:0.83rem; color:var(--text-2); line-height:1.6; margin-bottom:14px; }
.fdc-specs {
  display:grid; grid-template-columns:1fr 1fr; gap:8px; margin-bottom:14px;
}
.fdc-spec { background:var(--bg3); border-radius:var(--radius-sm); padding:9px 12px; }
.fdc-spec-lbl { font-size:0.65rem; color:var(--text-3); text-transform:uppercase; letter-spacing:0.06em; margin-bottom:3px; }
.fdc-spec-val { font-size:0.85rem; font-weight:600; }
.fdc-bars { display:flex; flex-direction:column; gap:6px; margin-bottom:14px; }
.fdc-bar-row { display:flex; align-items:center; gap:10px; }
.fdc-bar-lbl { font-size:0.68rem; color:var(--text-3); width:70px; flex-shrink:0; text-transform:uppercase; letter-spacing:0.04em; }
.fdc-bar-track { flex:1; height:3px; background:var(--bg3); border-radius:3px; overflow:hidden; }
.fdc-bar-fill { height:100%; background:var(--gold); border-radius:3px; }
.fdc-tags { display:flex; flex-wrap:wrap; gap:5px; }
.fdc-tag { font-size:0.68rem; font-weight:500; background:var(--bg3); border:1px solid var(--border); padding:3px 9px; border-radius:100px; color:var(--text-2); }
.fdc-tag.g { background:rgba(39,174,96,0.08); border-color:rgba(39,174,96,0.18); color:#4ade80; }
.fdc-tag.r { background:rgba(239,68,68,0.08); border-color:rgba(239,68,68,0.18); color:#f87171; }

/* ── RESULT TABS ─────────────────────────────── */
.results-tabs {
  display:flex; gap:2px; margin-top:20px;
  background:var(--bg3); border:1px solid var(--border);
  border-radius:var(--radius-sm); padding:3px; width:fit-content;
}
.rtab {
  background:none; border:none; cursor:pointer;
  padding:7px 18px; border-radius:calc(var(--radius-sm) - 2px);
  font-family:'DM Sans',sans-serif; font-size:0.82rem; font-weight:500;
  color:var(--text-3); transition:var(--ease);
}
.rtab:hover { color:var(--text-2); }
.rtab.active { background:var(--bg2); color:var(--text); border:1px solid var(--border); }
.rtab-desc {
  font-size:0.78rem; color:var(--text-3); margin-top:10px;
}

/* ── ANIMATIONS ──────────────────────────────── */
@keyframes fadeUp {
  from { opacity:0; transform:translateY(14px); }
  to   { opacity:1; transform:translateY(0); }
}

/* ── RESPONSIVE ──────────────────────────────── */
@media(max-width:640px){
  .nav-links { display:none; }
  .burger { display:flex; }
  .answers-grid.two-col { grid-template-columns:1fr; }
  .answers-grid.three-col { grid-template-columns:1fr 1fr; }
  .m-grid { grid-template-columns:1fr; }
  .hero-divider { gap:20px; flex-wrap:wrap; }
}
@media(max-width:900px) and (min-width:641px){
  .nav-link { padding:6px 9px; font-size:0.8rem; }
  .nav-cta  { padding:7px 12px; font-size:0.8rem; }
}
/* ── BLOG ────────────────────────────────────── */
#blog { background:var(--bg); padding-top:56px; }
.blog-wrap { max-width:1100px; margin:0 auto; padding:52px 24px 80px; }
.blog-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(320px,1fr)); gap:20px; margin-top:32px; }
.blog-card {
  background:var(--bg2); border:1px solid var(--border);
  border-radius:var(--radius); overflow:hidden; cursor:pointer; transition:var(--ease);
}
.blog-card:hover { border-color:rgba(255,255,255,0.12); transform:translateY(-2px); }
.blog-card-top { padding:22px 22px 16px; }
.blog-tag { font-size:0.68rem; font-weight:700; letter-spacing:0.09em; text-transform:uppercase; color:var(--gold); margin-bottom:10px; display:block; }
.blog-title { font-family:'Playfair Display',serif; font-size:1.15rem; font-weight:700; line-height:1.3; margin-bottom:8px; }
.blog-excerpt { font-size:0.82rem; color:var(--text-2); line-height:1.6; }
.blog-card-foot { padding:12px 22px; border-top:1px solid var(--border); display:flex; justify-content:space-between; align-items:center; }
.blog-date { font-size:0.72rem; color:var(--text-3); }
.blog-read { font-size:0.72rem; color:var(--gold); font-weight:600; }

/* Blog post view */
#blog-post { background:var(--bg); padding-top:56px; }
.post-wrap { max-width:700px; margin:0 auto; padding:52px 24px 80px; }
.post-back { background:none; border:none; cursor:pointer; color:var(--text-3); font-family:'DM Sans',sans-serif; font-size:0.85rem; padding:0; margin-bottom:32px; display:flex; align-items:center; gap:6px; transition:var(--ease); }
.post-back:hover { color:var(--text-2); }
.post-tag { font-size:0.72rem; font-weight:700; letter-spacing:0.09em; text-transform:uppercase; color:var(--gold); margin-bottom:12px; display:block; }
.post-title { font-family:'Playfair Display',serif; font-size:clamp(1.7rem,4vw,2.4rem); font-weight:800; line-height:1.15; margin-bottom:10px; }
.post-meta { font-size:0.78rem; color:var(--text-3); margin-bottom:36px; padding-bottom:28px; border-bottom:1px solid var(--border); }
.post-body h2 { font-family:'Playfair Display',serif; font-size:1.3rem; font-weight:700; margin:32px 0 12px; }
.post-body h3 { font-size:1rem; font-weight:600; margin:24px 0 8px; color:var(--text-2); }
.post-body p { font-size:0.925rem; color:var(--text-2); line-height:1.8; margin-bottom:14px; }
.post-body ul { margin:0 0 14px 0; padding-left:20px; display:flex; flex-direction:column; gap:6px; }
.post-body li { font-size:0.925rem; color:var(--text-2); line-height:1.6; }
.post-body strong { color:var(--text); font-weight:600; }
.post-body a { color:var(--gold); text-decoration:underline; }
.post-body a:hover { color:#c9a630; }
.post-callout { background:var(--bg3); border-left:3px solid var(--gold); border-radius:0 var(--radius-sm) var(--radius-sm) 0; padding:16px 18px; margin:20px 0; font-size:0.9rem; color:var(--text); line-height:1.6; }
.post-table { width:100%; border-collapse:collapse; margin:20px 0; font-size:0.85rem; border:1px solid var(--border); border-radius:var(--radius-sm); overflow:hidden; }
.post-table th { background:var(--bg3); color:var(--gold); font-weight:600; font-size:0.78rem; text-transform:uppercase; letter-spacing:0.06em; padding:10px 14px; text-align:left; border-bottom:1px solid var(--border); }
.post-table td { padding:10px 14px; border-bottom:1px solid var(--border); color:var(--text-2); }
.post-table tr:last-child td { border-bottom:none; font-weight:700; color:var(--text); }
.post-table tr:nth-child(even) td { background:rgba(22,22,25,0.4); }
.post-sources { margin-top:40px; padding-top:24px; border-top:1px solid var(--border); }
.post-sources h3 { font-size:0.82rem; font-weight:700; text-transform:uppercase; letter-spacing:0.08em; color:var(--text-3); margin-bottom:12px; }
.post-sources ul { list-style:none; padding:0; display:flex; flex-direction:column; gap:6px; }
.post-sources li { font-size:0.82rem; color:var(--text-2); }

.nav-logo { text-decoration:none; }
.nav-link  { text-decoration:none; display:inline-flex; align-items:center; }
.mm-link   { text-decoration:none; display:block; }
.mm-cta    { text-decoration:none; display:block; }
.footer-lnk { text-decoration:none; }
.footer-tos-link { text-decoration:underline; }

/* ── Budget Dual-Range Slider ───────────────────────────── */
.budget-range-wrap { padding: 4px 0 24px; }

.budget-input-row {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  margin-bottom: 32px;
}
.budget-input-box { display: flex; flex-direction: column; gap: 5px; }
.budget-input-label {
  font-size: 0.7rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: var(--text-3);
}
.budget-input-field {
  background: var(--bg3);
  border: 1px solid var(--border);
  border-radius: 8px;
  color: var(--gold);
  font-family: 'Playfair Display', serif;
  font-size: 1.6rem;
  font-weight: 800;
  width: 140px;
  padding: 10px 14px;
  text-align: center;
  transition: border-color 0.15s;
  outline: none;
}
.budget-input-field:focus {
  border-color: var(--gold);
  color: var(--text);
}
.budget-input-dash {
  font-family: 'Playfair Display', serif;
  font-size: 1.8rem;
  font-weight: 800;
  color: var(--text-3);
  padding-top: 20px;
}

.budget-dual-wrap {
  position: relative;
  height: 36px;
  margin: 0 8px 4px;
}
.budget-dual-track {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: 0; right: 0;
  height: 6px;
  background: rgba(255,255,255,0.07);
  border-radius: 3px;
  pointer-events: none;
}
.budget-dual-fill {
  position: absolute;
  height: 100%;
  background: var(--gold);
  border-radius: 3px;
  transition: left 0.05s, width 0.05s;
}
.budget-thumb {
  position: absolute;
  top: 0; left: 0;
  width: 100%;
  height: 100%;
  -webkit-appearance: none;
  appearance: none;
  background: transparent;
  pointer-events: none;
  outline: none;
}
.budget-thumb::-webkit-slider-thumb {
  -webkit-appearance: none;
  width: 24px; height: 24px;
  border-radius: 50%;
  background: var(--gold);
  border: 3px solid var(--bg);
  box-shadow: 0 0 0 2px rgba(212,175,55,0.25);
  cursor: pointer;
  pointer-events: all;
  transition: box-shadow 0.15s, transform 0.15s;
}
.budget-thumb::-webkit-slider-thumb:hover {
  box-shadow: 0 0 0 6px rgba(212,175,55,0.18);
  transform: scale(1.12);
}
.budget-thumb::-webkit-slider-thumb:active {
  transform: scale(1.18);
}
.budget-thumb::-moz-range-thumb {
  width: 24px; height: 24px;
  border-radius: 50%;
  background: var(--gold);
  border: 3px solid var(--bg);
  cursor: pointer;
  pointer-events: all;
}
.budget-thumb::-webkit-slider-runnable-track { background: transparent; }
.budget-thumb::-moz-range-track { background: transparent; }
.budget-thumb:focus { outline: none; }
.budget-thumb-max { z-index: 2; }
.budget-thumb-min { z-index: 3; }

.budget-ticks {
  display: flex;
  justify-content: space-between;
  padding: 0 4px;
  margin-bottom: 12px;
}
.budget-ticks span {
  font-size: 0.65rem;
  color: var(--text-3);
}
.budget-hint {
  text-align: center;
  font-size: 0.82rem;
  color: var(--text-2);
  margin-top: 4px;
}

@media (max-width: 480px) {
  .budget-input-field { width: 120px; font-size: 1.3rem; }
}

/* ── Budget Tier Row ───────────────────────────────────── */
.budget-row-wrap {
  max-width: 960px;
  margin: 40px auto 40px;
  padding: 0 16px;
}
.budget-tier-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}
@media (max-width: 640px) {
  .budget-tier-row { grid-template-columns: 1fr; }
}
.budget-tier-card {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 18px 20px;
  cursor: pointer;
  transition: border-color 0.15s, transform 0.15s;
  position: relative;
  overflow: hidden;
}
.budget-tier-card:hover {
  border-color: var(--gold);
  transform: translateY(-2px);
}
.btc-tier-label {
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  margin-bottom: 2px;
}
.btc-tier-range {
  font-size: 0.75rem;
  color: var(--text-3);
  margin-bottom: 14px;
}
.btc-name {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 4px;
  line-height: 1.3;
}
.btc-price {
  font-size: 1.1rem;
  font-weight: 800;
  color: var(--gold);
  margin-bottom: 8px;
}
.btc-score {
  font-size: 0.78rem;
  color: var(--text-2);
  margin-bottom: 8px;
}
.btc-bar {
  height: 4px;
  background: rgba(255,255,255,0.06);
  border-radius: 2px;
  overflow: hidden;
  margin-bottom: 12px;
}
.btc-fill {
  height: 100%;
  border-radius: 2px;
  transition: width 0.6s cubic-bezier(.4,0,.2,1);
  width: 0%;
}
.btc-tags {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}
.btc-tag {
  font-size: 0.68rem;
  font-weight: 600;
  background: var(--bg3);
  border: 1px solid var(--border);
  color: var(--text-2);
  padding: 2px 8px;
  border-radius: 4px;
}

.btc-stretch {
  border-color: rgba(171,71,188,0.35);
  background: rgba(171,71,188,0.04);
}
.btc-stretch:hover { border-color: #AB47BC; }
.btc-stretch-badge {
  display: inline-block;
  font-size: 0.65rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  background: rgba(171,71,188,0.15);
  color: #AB47BC;
  border: 1px solid rgba(171,71,188,0.3);
  border-radius: 4px;
  padding: 2px 8px;
  margin-bottom: 10px;
}

/* ── LIGHT MODE ─────────────────────────────────────────────────── */
body.light {
  --bg:  #f5f4f0;
  --bg2: #eeece8;
  --bg3: #e5e3de;
  --border: rgba(0,0,0,0.09);
  --border-gold: rgba(180,140,20,0.35);
  --text:   #1a1814;
  --text-2: #4a4740;
  --text-3: #9a9590;
  --gold: #b08c1a;
  --gold-dim: rgba(180,140,20,0.10);
  --gold-glow: rgba(180,140,20,0.25);
}
body.light .hero-section {
  background: radial-gradient(ellipse 70% 45% at 50% -5%, rgba(180,140,20,0.08) 0%, transparent 55%), var(--bg);
}
body.light .nav { background: rgba(245,244,240,0.92); }
body.light .mobile-menu { background: var(--bg); }
body.light .nav-cta { background: var(--gold); color: #fff; }
body.light .btn-primary { background: var(--gold); color: #fff; }
body.light mark { background: rgba(180,140,20,0.2); color: var(--text); }

/* ── SETTINGS BUTTON ─────────────────────────────────────────────── */
.settings-btn {
  position: fixed;
  bottom: 24px;
  right: 24px;
  z-index: 8000;
  width: 42px; height: 42px;
  border-radius: 50%;
  background: var(--bg2);
  border: 1px solid var(--border);
  color: var(--text-2);
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  font-size: 1rem;
  box-shadow: 0 4px 16px rgba(0,0,0,0.3);
  transition: background 0.15s, color 0.15s, transform 0.2s;
}
.settings-btn:hover { background: var(--bg3); color: var(--text); transform: rotate(30deg); }

/* ── SETTINGS PANEL ──────────────────────────────────────────────── */
.settings-panel {
  position: fixed;
  bottom: 76px;
  right: 24px;
  z-index: 8000;
  background: var(--bg2);
  border: 1px solid var(--border-gold);
  border-radius: 14px;
  padding: 20px;
  width: 220px;
  box-shadow: 0 8px 32px rgba(0,0,0,0.4);
  transform: scale(0.92) translateY(8px);
  opacity: 0;
  pointer-events: none;
  transform-origin: bottom right;
  transition: transform 0.18s ease, opacity 0.18s ease;
}
.settings-panel.open {
  transform: scale(1) translateY(0);
  opacity: 1;
  pointer-events: all;
}
.settings-panel-title {
  font-size: 0.68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--text-3);
  margin-bottom: 14px;
}
.settings-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.settings-row-label {
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--text-2);
}
/* Toggle switch */
.toggle {
  position: relative;
  width: 40px; height: 22px;
  flex-shrink: 0;
}
.toggle input { opacity: 0; width: 0; height: 0; }
.toggle-track {
  position: absolute;
  inset: 0;
  background: var(--bg3);
  border: 1px solid var(--border);
  border-radius: 22px;
  cursor: pointer;
  transition: background 0.2s;
}
.toggle input:checked + .toggle-track { background: var(--gold); border-color: var(--gold); }
.toggle-track::after {
  content: '';
  position: absolute;
  left: 3px; top: 50%;
  transform: translateY(-50%);
  width: 14px; height: 14px;
  border-radius: 50%;
  background: #fff;
  transition: left 0.2s;
  box-shadow: 0 1px 3px rgba(0,0,0,0.2);
}
.toggle input:checked + .toggle-track::after { left: 21px; }
