/* ===== CSS TOKENS ===== */
:root {
  --bg: #09090B;
  --bg-alt: #121217;
  --bg-card: #1a1a24;
  --bg-footer: #0d0d12;
  --text: #F1E8D4;
  --text-body: #E8D8B0;
  --muted: #B8B0A0;
  --soft: #8B8B7A;
  --soft2: #808070;
  --soft3: #7C7C6E;
  --gold: #D6A84F;
  --gold-bright: #F3D88A;
  --gold-dim: #B68A3A;
  --ember: #E85D2A;
  --ember-dark: #8B1E1E;
  --teal: #256D85;
  --teal-bright: #2AA6A1;
  --blue: #1F3A5F;
  --blue-bright: #6BB7FF;
  --forest: #3D5A40;
  --forest-bright: #4B6B2A;
  --violet: #6D5A8D;
  --violet-light: #B8A0D0;
  --amber: #B8860B;
  --bronze: #8B6914;
  --dusty-rose: #8B5A6B;
  --wheat: #C2A75B;
  --steel: #8B8B8B;
  --coal: #5F6266;
  --capitol-accent: #D4A0A0;
  --line: rgba(214,168,79,0.15);
  --font-heading: 'Cinzel', Georgia, 'Times New Roman', serif;
  --font-body: 'Spectral', Georgia, 'Times New Roman', serif;
  --font-ui: Arial, sans-serif;
}

/* ===== RESET & BASE ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:80px}
body{font-family:var(--font-body);background:var(--bg);color:var(--text-body);line-height:1.7;overflow-x:hidden;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);color:var(--gold);letter-spacing:0.02em}
a{color:var(--gold);text-decoration:none;transition:color 0.3s}
a:hover{color:var(--ember)}
:focus-visible{outline:2px solid var(--gold);outline-offset:2px;border-radius:2px}

/* ===== UTILITY ===== */
.container{max-width:1200px;margin:0 auto;padding:0 20px}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip-path:inset(50%);white-space:nowrap;border:0}
.skip-link{position:absolute;top:-100%;left:16px;z-index:10000;background:var(--gold);color:var(--bg);padding:10px 20px;border-radius:4px;font-family:var(--font-ui);font-size:0.9rem;font-weight:bold;text-decoration:none;transition:top 0.3s}
.skip-link:focus{top:16px}

/* ===== NAVIGATION ===== */
.nav{position:fixed;top:0;left:0;right:0;z-index:1000;background:rgba(9,9,11,0.95);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);padding:14px 0;transition:all 0.3s}
.nav-inner{display:flex;align-items:center;justify-content:space-between;max-width:1200px;margin:0 auto;padding:0 20px}
.nav-logo{display:flex;align-items:center;gap:10px;font-size:1.3rem;font-weight:bold;color:var(--gold);text-transform:uppercase;letter-spacing:0.08em;font-family:var(--font-heading)}
.nav-logo img{width:32px;height:32px;border-radius:6px}
.nav-links{display:flex;gap:24px;list-style:none;flex-wrap:wrap}
.nav-links a{color:var(--text-body);font-size:0.9rem;font-family:var(--font-ui);text-transform:uppercase;letter-spacing:0.05em;transition:color 0.3s}
.nav-links a:hover{color:var(--gold)}
.nav-cta{background:linear-gradient(135deg,var(--ember),var(--gold));color:var(--bg);padding:8px 18px;border-radius:4px;font-weight:bold;font-size:0.85rem;font-family:var(--font-ui);text-transform:uppercase;letter-spacing:0.05em;border:none;cursor:pointer;text-decoration:none;transition:all 0.3s}
.nav-cta:hover{transform:translateY(-1px);box-shadow:0 4px 20px rgba(232,93,42,0.4);color:var(--bg)}

/* ===== SECTIONS ===== */
.section{padding:80px 0;position:relative}
.section-dark{background:var(--bg)}
.section-card{background:var(--bg-alt)}
.section-accent{background:linear-gradient(180deg,var(--bg-alt),var(--bg-card))}
.section-header{text-align:center;margin-bottom:50px}
.section-header h2{font-size:2.2rem;margin-bottom:12px;color:var(--gold-bright)}
.section-header p{color:var(--soft);font-size:1.1rem;max-width:700px;margin:0 auto}
.border-top{border-top:1px solid rgba(214,168,79,0.1)}
.border-bottom{border-bottom:1px solid rgba(214,168,79,0.1)}

/* ===== HERO ===== */
.hero{min-height:100vh;display:flex;align-items:center;padding:120px 0 60px;position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(ellipse at 30% 40%,rgba(214,168,79,0.06) 0%,transparent 60%),radial-gradient(ellipse at 70% 40%,rgba(232,93,42,0.04) 0%,transparent 60%);pointer-events:none}
.hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;position:relative;z-index:1}
.hero-badge{display:inline-block;background:rgba(214,168,79,0.1);border:1px solid rgba(214,168,79,0.25);color:var(--gold);padding:6px 16px;border-radius:20px;font-size:0.85rem;margin-bottom:20px;font-family:var(--font-ui);text-transform:uppercase;letter-spacing:0.08em}
.hero h1{font-size:3.2rem;line-height:1.15;margin-bottom:16px;background:linear-gradient(135deg,var(--gold-bright),var(--ember));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-subtitle{color:var(--soft);font-size:1.15rem;margin-bottom:30px;max-width:500px}
.hero-trust{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:28px}
.hero-trust span{background:rgba(214,168,79,0.08);border:1px solid rgba(214,168,79,0.12);color:var(--muted);padding:5px 12px;border-radius:4px;font-size:0.8rem;font-family:var(--font-ui)}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap}
.btn-primary{background:linear-gradient(135deg,var(--ember),var(--gold));color:var(--bg);padding:14px 32px;border-radius:4px;font-size:1rem;font-weight:bold;border:none;cursor:pointer;font-family:var(--font-ui);text-transform:uppercase;letter-spacing:0.05em;transition:all 0.3s;text-decoration:none;display:inline-block}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 30px rgba(232,93,42,0.5)}
.btn-secondary{background:transparent;color:var(--gold);padding:14px 32px;border-radius:4px;font-size:1rem;border:1px solid rgba(214,168,79,0.3);cursor:pointer;font-family:var(--font-ui);text-transform:uppercase;letter-spacing:0.05em;transition:all 0.3s;text-decoration:none;display:inline-block}
.btn-secondary:hover{border-color:var(--gold);background:rgba(214,168,79,0.06)}
.hero-right{display:flex;flex-direction:column;gap:14px}
.result-preview-card{background:var(--bg-card);border:1px solid var(--line);border-radius:8px;padding:20px 24px;display:flex;align-items:center;gap:18px;transition:all 0.3s}
.result-preview-card:hover{border-color:rgba(214,168,79,0.35);transform:translateX(4px)}
.preview-badge{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:bold;font-family:var(--font-ui);flex-shrink:0}
.preview-info h3{font-size:1.05rem;margin-bottom:2px}
.preview-info p{color:var(--soft);font-size:0.85rem;margin:0}
.preview-label{display:inline-block;font-size:0.7rem;text-transform:uppercase;letter-spacing:0.08em;padding:2px 8px;border-radius:3px;font-family:var(--font-ui);margin-top:4px}
.badge-d12{background:rgba(95,98,102,0.25);border:2px solid var(--coal);color:var(--gold-dim)}
.badge-d4{background:rgba(37,109,133,0.25);border:2px solid var(--teal);color:var(--teal-bright)}
.badge-d3{background:rgba(31,58,95,0.25);border:2px solid var(--blue);color:var(--blue-bright)}
.badge-d1{background:rgba(214,168,79,0.15);border:2px solid var(--gold);color:var(--gold)}
.badge-capitol{background:rgba(139,30,30,0.2);border:2px solid var(--ember-dark);color:var(--capitol-accent)}
.badge-d13{background:rgba(109,90,141,0.2);border:2px solid var(--violet);color:var(--violet-light)}
.label-d12{background:rgba(95,98,102,0.2);color:var(--gold-dim)}
.label-d4{background:rgba(37,109,133,0.2);color:var(--teal-bright)}
.label-d3{background:rgba(31,58,95,0.2);color:var(--blue-bright)}
.label-d1{background:rgba(214,168,79,0.1);color:var(--gold)}
.label-capitol{background:rgba(139,30,30,0.15);color:var(--capitol-accent)}
.label-d13{background:rgba(109,90,141,0.15);color:var(--violet-light)}

/* ===== QUIZ ===== */
.quiz-window{max-width:700px;margin:0 auto;background:var(--bg-alt);border:1px solid rgba(214,168,79,0.12);border-radius:12px;overflow:hidden}
.quiz-progress{height:3px;background:rgba(214,168,79,0.08)}
.quiz-progress-bar{height:100%;background:linear-gradient(90deg,var(--gold),var(--ember));transition:width 0.5s ease}
.quiz-body{padding:40px}
.quiz-qnum{font-family:var(--font-ui);font-size:0.8rem;color:var(--soft);text-transform:uppercase;letter-spacing:0.08em;margin-bottom:12px}
.quiz-question{font-size:1.5rem;color:var(--text);margin-bottom:28px;line-height:1.4}
.quiz-options{display:flex;flex-direction:column;gap:10px}
.quiz-option{background:rgba(214,168,79,0.04);border:1px solid rgba(214,168,79,0.12);border-radius:8px;padding:16px 20px;cursor:pointer;transition:all 0.25s;text-align:left;font-size:1rem;color:var(--text-body);font-family:var(--font-body)}
.quiz-option:hover{background:rgba(214,168,79,0.1);border-color:rgba(214,168,79,0.3);transform:translateX(3px)}
.quiz-option.selected{background:rgba(214,168,79,0.12);border-color:var(--gold);color:var(--gold)}
.quiz-nav{display:flex;justify-content:space-between;padding:20px 40px;border-top:1px solid rgba(214,168,79,0.08)}
.quiz-nav button{background:transparent;border:1px solid rgba(214,168,79,0.2);color:var(--gold);padding:8px 20px;border-radius:4px;cursor:pointer;font-family:var(--font-ui);font-size:0.85rem;transition:all 0.3s}
.quiz-nav button:hover:not(:disabled){border-color:var(--gold);background:rgba(214,168,79,0.06)}
.quiz-nav button:disabled{opacity:0.3;cursor:not-allowed}
.quiz-hidden{display:none}
.quiz-result-area{display:none}

/* ===== RESULT SCREEN ===== */
.result-screen{max-width:700px;margin:0 auto;background:var(--bg-alt);border:1px solid var(--line);border-radius:12px;overflow:hidden;display:none}
.result-header{padding:40px;text-align:center;position:relative}
.result-district-num{font-size:6rem;font-weight:bold;font-family:var(--font-ui);line-height:1;opacity:0.08;position:absolute;top:10px;right:20px}
.result-title{font-size:2rem;margin-bottom:6px}
.result-subtitle{color:var(--soft);font-size:1.1rem;margin-bottom:0}
.result-body{padding:30px 40px 40px}
.result-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:24px}
.result-stat{background:rgba(214,168,79,0.04);border:1px solid rgba(214,168,79,0.08);border-radius:8px;padding:16px}
.result-stat-label{font-family:var(--font-ui);font-size:0.7rem;color:var(--soft);text-transform:uppercase;letter-spacing:0.08em;margin-bottom:4px}
.result-stat-value{font-size:1.1rem;color:var(--text)}
.result-description{font-size:1.05rem;color:var(--text-body);line-height:1.8;margin-bottom:24px;padding:20px;background:rgba(214,168,79,0.03);border-left:2px solid rgba(214,168,79,0.3);border-radius:0 8px 8px 0}
.result-colors{display:flex;gap:8px;margin-bottom:24px;flex-wrap:wrap}
.color-swatch{width:36px;height:36px;border-radius:6px;border:2px solid rgba(255,255,255,0.1)}
.result-actions{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:20px}
.btn-small{padding:10px 20px;border-radius:4px;font-size:0.85rem;font-family:var(--font-ui);cursor:pointer;border:none;text-transform:uppercase;letter-spacing:0.04em;transition:all 0.3s}
.btn-gold{background:rgba(214,168,79,0.15);color:var(--gold);border:1px solid rgba(214,168,79,0.3)}
.btn-gold:hover{background:rgba(214,168,79,0.25)}
.btn-fire{background:rgba(232,93,42,0.15);color:var(--ember);border:1px solid rgba(232,93,42,0.3)}
.btn-fire:hover{background:rgba(232,93,42,0.25)}
.btn-dark{background:rgba(255,255,255,0.05);color:var(--text-body);border:1px solid rgba(255,255,255,0.1)}
.btn-dark:hover{background:rgba(255,255,255,0.1)}
.result-share-card{background:var(--bg-footer);border:1px solid rgba(214,168,79,0.2);border-radius:8px;padding:24px;text-align:center;margin-bottom:16px}
.share-card-title{font-size:1.3rem;color:var(--gold);margin-bottom:4px}
.share-card-sub{font-size:0.9rem;color:var(--soft);margin-bottom:12px}
.result-top3{display:flex;gap:8px;justify-content:center;margin-top:12px;flex-wrap:wrap}
.top3-badge{padding:4px 10px;border-radius:4px;font-size:0.75rem;font-family:var(--font-ui);background:rgba(214,168,79,0.06);border:1px solid rgba(214,168,79,0.1);color:var(--muted)}
.top3-badge.active{background:rgba(214,168,79,0.15);border-color:var(--gold);color:var(--gold)}

/* ===== DISTRICT GRID ===== */
.district-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}
.district-card{background:var(--bg-card);border:1px solid rgba(214,168,79,0.08);border-radius:8px;padding:24px;transition:all 0.3s;cursor:default}
.district-card:hover{border-color:rgba(214,168,79,0.25);transform:translateY(-3px);box-shadow:0 8px 30px rgba(0,0,0,0.3)}
.district-card-num{font-size:2.5rem;font-weight:bold;font-family:var(--font-ui);line-height:1;opacity:0.15;margin-bottom:8px}
.district-card h3{font-size:1.15rem;margin-bottom:6px}
.district-card .industry{color:var(--soft);font-size:0.85rem;margin-bottom:8px}
.district-card .trait{font-size:0.8rem;color:var(--muted);font-family:var(--font-ui);text-transform:uppercase;letter-spacing:0.05em}
.dc-d1{border-left:3px solid var(--gold)}
.dc-d2{border-left:3px solid var(--steel)}
.dc-d3{border-left:3px solid var(--blue-bright)}
.dc-d4{border-left:3px solid var(--teal)}
.dc-d5{border-left:3px solid var(--amber)}
.dc-d6{border-left:3px solid var(--bronze)}
.dc-d7{border-left:3px solid var(--forest)}
.dc-d8{border-left:3px solid var(--dusty-rose)}
.dc-d9{border-left:3px solid var(--wheat)}
.dc-d10{border-left:3px solid var(--bronze)}
.dc-d11{border-left:3px solid var(--forest-bright)}
.dc-d12{border-left:3px solid var(--coal)}
.dc-d13{border-left:3px solid var(--violet)}
.dc-capitol{border-left:3px solid var(--ember-dark)}

/* ===== DEEP DIVE ===== */
.deep-dive{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:start}
.deep-info h3{font-size:1.6rem;margin-bottom:12px}
.deep-info p{margin-bottom:12px;color:var(--muted)}
.deep-traits{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}
.deep-trait{background:rgba(214,168,79,0.06);border:1px solid rgba(214,168,79,0.1);padding:6px 14px;border-radius:20px;font-size:0.8rem;font-family:var(--font-ui);color:var(--muted)}
.deep-characters{display:flex;flex-wrap:wrap;gap:8px}
.deep-char-badge{padding:4px 10px;border-radius:4px;font-size:0.8rem;background:rgba(214,168,79,0.08)}
.deep-side{background:var(--bg-card);border:1px solid rgba(214,168,79,0.1);border-radius:8px;padding:24px}
.deep-side h4{font-size:1rem;margin-bottom:10px;color:var(--gold)}
.deep-side ul{list-style:none}
.deep-side li{padding:6px 0;border-bottom:1px solid rgba(214,168,79,0.06);font-size:0.9rem;color:var(--muted)}
.deep-side li:last-child{border-bottom:none}

/* ===== FIGMA BANNER ===== */
.figma-banner{background:linear-gradient(135deg,rgba(214,168,79,0.05),rgba(232,93,42,0.05));border:1px solid var(--line);border-radius:12px;padding:30px;text-align:center;max-width:700px;margin:0 auto}
.figma-banner h2{font-size:1.5rem;margin-bottom:8px}
.figma-banner p{color:var(--soft);margin-bottom:16px}

/* ===== MAP ===== */
.map-container{max-width:800px;margin:0 auto;background:var(--bg-alt);border:1px solid rgba(214,168,79,0.12);border-radius:12px;padding:30px;text-align:center}
.map-svg{width:100%;max-width:600px}

/* ===== SURVIVAL STYLE ===== */
.style-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px}
.style-card{background:rgba(214,168,79,0.04);border:1px solid rgba(214,168,79,0.08);border-radius:8px;padding:20px;cursor:pointer;transition:all 0.3s;text-align:center}
.style-card:hover{border-color:rgba(214,168,79,0.3);background:rgba(214,168,79,0.08)}
.style-card.selected{border-color:var(--gold);background:rgba(214,168,79,0.1)}
.style-icon{font-size:2.5rem;margin-bottom:10px}
.style-name{font-size:1rem;color:var(--gold);margin-bottom:4px;font-family:var(--font-ui);text-transform:uppercase;letter-spacing:0.05em}
.style-desc{font-size:0.8rem;color:var(--soft)}

/* ===== FAQ ===== */
.faq-list{max-width:750px;margin:0 auto}
.faq-item{border:1px solid rgba(214,168,79,0.08);border-radius:8px;margin-bottom:10px;overflow:hidden;background:var(--bg-card)}
.faq-question{padding:18px 24px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;font-size:1.05rem;color:var(--text-body);transition:all 0.3s}
.faq-question:hover{color:var(--gold)}
.faq-question::after{content:'+';font-size:1.3rem;color:var(--gold);transition:transform 0.3s}
.faq-question.active::after{content:'\\2212'}
.faq-answer{padding:0 24px;max-height:0;overflow:hidden;transition:all 0.35s ease}
.faq-answer-content{padding-bottom:18px;color:var(--muted);font-size:0.95rem;line-height:1.7}
.faq-answer.open{max-height:500px}

/* ===== RELATED QUIZZES ===== */
.related-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}
.related-card{background:var(--bg-card);border:1px solid rgba(214,168,79,0.08);border-radius:8px;padding:24px;transition:all 0.3s}
.related-card:hover{border-color:rgba(214,168,79,0.25);transform:translateY(-2px)}
.related-card h3{font-size:1.05rem;margin-bottom:6px}
.related-card p{font-size:0.85rem;color:var(--soft);margin-bottom:12px}
.related-link{font-family:var(--font-ui);font-size:0.8rem;color:var(--gold);text-transform:uppercase;letter-spacing:0.05em}

/* ===== POLL ===== */
.poll-options{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-bottom:16px}
.poll-btn{background:rgba(214,168,79,0.06);border:1px solid rgba(214,168,79,0.1);color:var(--text-body);padding:8px 18px;border-radius:20px;cursor:pointer;font-family:var(--font-ui);font-size:0.85rem;transition:all 0.3s}
.poll-btn:hover{background:rgba(214,168,79,0.12);border-color:rgba(214,168,79,0.3)}
.poll-btn.voted{background:rgba(214,168,79,0.18);border-color:var(--gold);color:var(--gold)}
.poll-results{display:none}

/* ===== DIMENSIONS ===== */
.dimension-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}
.dimension-card{background:rgba(214,168,79,0.03);border:1px solid rgba(214,168,79,0.08);border-radius:8px;padding:20px}
.dimension-card h4{font-size:1rem;margin-bottom:4px;color:var(--gold)}
.dimension-card p{font-size:0.85rem;color:var(--soft)}

/* ===== GENERATOR ===== */
.generator-box{max-width:500px;margin:0 auto;text-align:center;background:var(--bg-card);border:1px solid rgba(214,168,79,0.12);border-radius:12px;padding:40px}
.generator-result{font-size:1.5rem;color:var(--gold);margin:16px 0;min-height:40px}
.generator-btn{background:linear-gradient(135deg,var(--ember),var(--gold));color:var(--bg);padding:12px 28px;border:none;border-radius:4px;cursor:pointer;font-family:var(--font-ui);font-weight:bold;text-transform:uppercase;letter-spacing:0.05em;font-size:0.9rem;transition:all 0.3s}
.generator-btn:hover{transform:translateY(-1px);box-shadow:0 4px 20px rgba(232,93,42,0.4)}

/* ===== FOOTER ===== */
.footer{background:var(--bg-footer);border-top:1px solid rgba(214,168,79,0.1);padding:60px 0 30px;font-size:0.85rem;color:var(--soft2);text-align:center}
.footer-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:30px;text-align:left;margin-bottom:30px}
.footer-col h4{font-size:0.9rem;color:var(--gold);margin-bottom:12px;text-transform:uppercase;letter-spacing:0.06em}
.footer-col ul{list-style:none}
.footer-col li{margin-bottom:6px}
.footer-col a{color:var(--soft);font-size:0.85rem}
.footer-col a:hover{color:var(--gold)}
.footer-disclaimer{background:rgba(214,168,79,0.03);border:1px solid rgba(214,168,79,0.08);border-radius:8px;padding:16px;margin-bottom:20px;text-align:center;font-size:0.8rem;color:var(--soft2);line-height:1.6}
.footer-bottom{font-size:0.75rem;color:var(--soft3)}

/* ===== PROCESS STEPS ===== */
.process-steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;counter-reset:step}
.process-step{text-align:center;position:relative}
.process-step::before{counter-increment:step;content:counter(step);display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--gold),var(--ember));color:var(--bg);font-weight:bold;font-size:1.2rem;font-family:var(--font-ui);margin:0 auto 14px}
.process-step h4{font-size:1rem;margin-bottom:6px}
.process-step p{font-size:0.85rem;color:var(--soft)}

/* ===== SHARE SECTION ===== */
.share-preview-box{max-width:500px;margin:0 auto;text-align:center;background:var(--bg-alt);border:2px solid rgba(214,168,79,0.2);border-radius:12px;padding:30px}
.share-preview-box .preview-name{font-size:1.8rem;font-weight:bold;color:var(--gold);margin-bottom:4px}
.share-preview-box .preview-identity{color:var(--soft);margin-bottom:16px}
.share-buttons{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-top:16px}

/* ===== BACK TO TOP ===== */
.back-top{position:fixed;bottom:30px;right:30px;width:44px;height:44px;background:rgba(214,168,79,0.15);border:1px solid rgba(214,168,79,0.3);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--gold);font-size:1.2rem;z-index:999;transition:all 0.3s;opacity:0;pointer-events:none}
.back-top.visible{opacity:1;pointer-events:all}
.back-top:hover{background:rgba(214,168,79,0.25)}
.back-top:focus-visible{outline:2px solid var(--gold);outline-offset:4px}

/* ===== TOAST ===== */
.toast{position:fixed;bottom:30px;left:50%;transform:translateX(-50%);background:rgba(214,168,79,0.2);border:1px solid var(--gold);color:var(--gold);padding:10px 24px;border-radius:8px;font-family:var(--font-ui);font-size:0.85rem;z-index:2000;opacity:0;transition:all 0.3s;pointer-events:none}
.toast.show{opacity:1}

/* ===== MOBILE NAV ===== */
.mobile-toggle{display:none;background:none;border:none;color:var(--gold);font-size:1.5rem;cursor:pointer}

/* ===== RESPONSIVE ===== */
@media(max-width:900px){
  .hero-grid{grid-template-columns:1fr;gap:30px}
  .hero h1{font-size:2.2rem}
  .hero-right{flex-direction:row;flex-wrap:wrap}
  .result-preview-card{flex:1;min-width:220px}
  .deep-dive{grid-template-columns:1fr}
  .district-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}
  .result-grid{grid-template-columns:1fr}
  .nav-links{display:none}
  .nav-links.open{display:flex;flex-direction:column;position:absolute;top:100%;left:0;right:0;background:rgba(9,9,11,0.98);padding:20px;gap:16px;border-bottom:1px solid var(--line)}
  .mobile-toggle{display:block}
  .section{padding:50px 0}
  .quiz-body{padding:24px}
  .quiz-nav{padding:16px 24px}
  .quiz-question{font-size:1.2rem}
}
@media(max-width:600px){
  .hero h1{font-size:1.8rem}
  .hero-right{flex-direction:column}
  .hero-ctas{flex-direction:column}
  .hero-ctas .btn-primary,.hero-ctas .btn-secondary{text-align:center}
  .result-header{padding:24px}
  .result-body{padding:20px 24px 30px}
  .section-header h2{font-size:1.6rem}
}

/* ===== PRINT ===== */
@media print{
  nav, .back-top, .mobile-toggle, button, .skip-link,
  .hero-ctas, .nav-cta, .quiz-nav, .result-actions,
  .share-buttons, .poll-options, .generator-btn,
  .figma-banner .btn-primary, .cta-block .btn-primary,
  .btn-primary, .btn-secondary, .btn-gold, .btn-fire, .btn-dark,
  .btn-small, .worksheet-cta, .nav-links{display:none !important}
  body{font-size:11pt;line-height:1.5;color:#000;background:#fff}
  @page{size:A4;margin:1.5cm}
  h1,h2,h3,h4{color:#000;page-break-after:avoid}
  .section{padding:16px 0}
  .district-card, .result-stat, .dimension-card, .faq-item,
  .process-step, .result-preview-card, .share-preview-box,
  .worksheet-card{page-break-inside:avoid;background:#fff !important;border:1px solid #ccc !important}
  .hero{min-height:auto;padding:20px 0}
  .quiz-window, .result-screen{max-width:100%}
  .result-header, .result-body{padding:16px 0}
  .container{max-width:100% !important;padding:0}
  .footer, .footer-disclaimer{font-size:8pt;color:#666}
  a{color:#000;text-decoration:underline}
  img{max-width:100% !important}
  .color-swatch{print-color-adjust:exact;-webkit-print-color-adjust:exact}
}

/* ===== PRINTABLE WORKSHEETS SECTION ===== */
.worksheets-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}
.worksheet-card{background:var(--bg-card);border:1px solid rgba(214,168,79,0.08);border-radius:8px;padding:24px;transition:all 0.3s}
.worksheet-card:hover{border-color:rgba(214,168,79,0.25);transform:translateY(-2px)}
.worksheet-card h3{font-size:1.1rem;margin-bottom:8px}
.worksheet-card p{font-size:0.85rem;color:var(--soft);margin-bottom:14px}
.worksheet-card .wk-icon{font-size:2rem;margin-bottom:10px}
.worksheet-cta{display:inline-block;background:rgba(214,168,79,0.12);color:var(--gold);border:1px solid rgba(214,168,79,0.25);padding:8px 18px;border-radius:4px;cursor:pointer;font-family:var(--font-ui);font-size:0.8rem;text-transform:uppercase;letter-spacing:0.04em;transition:all 0.25s;text-decoration:none}
.worksheet-cta:hover{background:rgba(214,168,79,0.2);border-color:var(--gold)}