@font-face {
  font-family: 'Fredoka';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: local('Fredoka SemiBold'), local('Fredoka-SemiBold');
}
@font-face {
  font-family: 'Quicksand';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: local('Quicksand Medium'), local('Quicksand-Medium');
}

body[data-theme] {
    --font-display: 'Fredoka', sans-serif;
    --font-body: 'Quicksand', sans-serif;
    --font-accent: 'Nunito', sans-serif;
    --text-inverse: #f4fbff;

    --radius-sm: 10px;
    --radius-md: 14px;
    --radius-lg: 20px;
    --radius-xl: 24px;
    --radius-full: 9999px;

    --space-xs: 0.5rem;
    --space-sm: 0.75rem;
    --space-md: 1rem;
    --space-lg: 1.5rem;
    --space-xl: 2rem;
    --space-2xl: 3rem;
    --space-3xl: 4rem;

    --transition-fast: 0.15s ease;
    --transition-normal: 0.25s ease;
    --transition-slow: 0.4s ease;

    --chrome-surface: color-mix(in srgb, var(--card-bg) 90%, transparent);
    --chrome-surface-strong: color-mix(in srgb, var(--card-bg) 96%, transparent);
    --chrome-shadow: 0 10px 32px var(--shadow);
    color-scheme: dark;
}

body[data-theme="core"] {
    --primary: #ff8f80;
    --primary-light: #ffc1b7;
    --primary-dark: #ff6f6f;
    --secondary: #b7f695;
    --secondary-light: #d8ffc3;
    --secondary-dark: #155d72;
    --accent: #9fefff;
    --accent-light: #d6fbff;
    --accent-dark: #68dce9;
    --gold: #ffd45a;
    --gold-dark: #ffd45a;
    --success: #8be7a8;
    --success-dark: #58d68d;
    --bg-main: #07141d;
    --bg-gradient: linear-gradient(180deg, #07141d 0%, #0b3446 100%);
    --card-bg: #102a38;
    --border: rgba(214, 251, 255, 0.16);
    --shadow: rgba(0, 0, 0, 0.38);
    --text-dark: #ecfdff;
    --text-medium: rgba(236, 253, 255, 0.84);
    --text-light: rgba(236, 253, 255, 0.68);
    --card-alpha-70: color-mix(in srgb, var(--card-bg) 70%, transparent);
    --card-alpha-90: color-mix(in srgb, var(--card-bg) 90%, transparent);
    --card-alpha-92: color-mix(in srgb, var(--card-bg) 92%, transparent);
    --card-alpha-95: color-mix(in srgb, var(--card-bg) 95%, transparent);
    --primary-alpha-06: color-mix(in srgb, var(--primary) 6%, transparent);
    --primary-alpha-08: color-mix(in srgb, var(--primary) 8%, transparent);
    --primary-alpha-10: color-mix(in srgb, var(--primary) 10%, transparent);
    --primary-alpha-12: color-mix(in srgb, var(--primary) 12%, transparent);
    --primary-alpha-15: color-mix(in srgb, var(--primary) 15%, transparent);
    --primary-alpha-16: color-mix(in srgb, var(--primary) 16%, transparent);
    --primary-alpha-18: color-mix(in srgb, var(--primary) 18%, transparent);
    --primary-alpha-20: color-mix(in srgb, var(--primary) 20%, transparent);
    --primary-alpha-22: color-mix(in srgb, var(--primary) 22%, transparent);
    --primary-alpha-85: color-mix(in srgb, var(--primary) 85%, transparent);
    --secondary-alpha-08: color-mix(in srgb, var(--secondary) 8%, transparent);
    --secondary-alpha-06: color-mix(in srgb, var(--secondary) 6%, transparent);
    --secondary-alpha-10: color-mix(in srgb, var(--secondary) 10%, transparent);
    --secondary-alpha-12: color-mix(in srgb, var(--secondary) 12%, transparent);
    --secondary-alpha-16: color-mix(in srgb, var(--secondary) 16%, transparent);
    --secondary-alpha-18: color-mix(in srgb, var(--secondary) 18%, transparent);
    --secondary-alpha-25: color-mix(in srgb, var(--secondary) 25%, transparent);
    --accent-alpha-08: color-mix(in srgb, var(--accent) 8%, transparent);
    --accent-alpha-06: color-mix(in srgb, var(--accent) 6%, transparent);
    --accent-alpha-10: color-mix(in srgb, var(--accent) 10%, transparent);
    --accent-alpha-12: color-mix(in srgb, var(--accent) 12%, transparent);
    --accent-alpha-15: color-mix(in srgb, var(--accent) 15%, transparent);
    --accent-alpha-16: color-mix(in srgb, var(--accent) 16%, transparent);
    --gold-alpha-08: color-mix(in srgb, var(--gold) 8%, transparent);
    --gold-alpha-12: color-mix(in srgb, var(--gold) 12%, transparent);
    --gold-alpha-18: color-mix(in srgb, var(--gold) 18%, transparent);
    --success-alpha-08: color-mix(in srgb, var(--success) 8%, transparent);
    --success-alpha-15: color-mix(in srgb, var(--success) 15%, transparent);
    --overlay-dark-70: rgba(7, 20, 29, 0.78);
}

body[data-shell="article"] { --shell-width: 900px; }
body[data-shell="hub"] { --shell-width: 1100px; }

*, *::before, *::after { box-sizing: border-box; }

html { scroll-behavior: smooth; scroll-padding-top: 92px; }

.skip-to-content {
    position: absolute;
    top: -100%;
    left: var(--space-md);
    z-index: 200;
    padding: 0.6rem 1.2rem;
    background: var(--secondary-dark);
    color: var(--text-inverse);
    font-weight: 700;
    border-radius: var(--radius-sm);
    transition: top var(--transition-fast);
}
.skip-to-content:focus { top: var(--space-xs); }

body {
    margin: 0;
    font-family: var(--font-body);
    color: var(--text-dark);
    background: var(--bg-main);
    line-height: 1.7;
    letter-spacing: 0.01em;
}

:focus-visible {
    outline: 3px solid var(--primary);
    outline-offset: 2px;
    border-radius: 2px;
}

body::before {
    content: "";
    position: fixed;
    inset: 0;
    background:
        var(--bg-gradient),
        radial-gradient(circle at 18% 16%, var(--accent-alpha-10) 0%, transparent 42%),
        radial-gradient(circle at 82% 14%, var(--secondary-alpha-12) 0%, transparent 38%),
        radial-gradient(circle at 50% 78%, var(--primary-alpha-10) 0%, transparent 46%);
    pointer-events: none;
    z-index: -1;
}

a { color: var(--accent-light); text-decoration: none; transition: color var(--transition-fast); }
a:hover { color: var(--secondary); }

h1, h2, h3, h4 { font-family: var(--font-display); font-weight: 700; line-height: 1.3; margin: 0 0 var(--space-md); }
h1 { font-size: clamp(1.8rem, 4vw, 2.6rem); }
h2 { font-size: clamp(1.4rem, 3vw, 2rem); }
h3 { font-size: clamp(1.1rem, 2vw, 1.5rem); }

img { max-width: 100%; height: auto; }

.header {
    position: sticky;
    top: 0;
    z-index: 100;
    background: color-mix(in srgb, var(--bg-main) 82%, transparent);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    border-bottom: 1px solid var(--border);
    padding: 0 var(--space-lg);
}

.header-inner {
    max-width: calc(var(--shell-width) + var(--space-xl) * 2);
    margin: 0 auto;
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: 76px;
}

.logo {
    display: flex;
    align-items: center;
    text-decoration: none;
}

.logo:hover { opacity: 0.92; }
.logo-icon { width: 40px; height: 40px; flex-shrink: 0; vertical-align: middle; }
.logo-wordmark {
    width: clamp(150px, 18vw, 188px);
    height: auto;
    display: block;
    filter: drop-shadow(0 8px 20px rgba(0, 0, 0, 0.35));
}

.nav { display: flex; gap: var(--space-xs); }

.nav a {
    padding: 0.4rem 1rem;
    border-radius: var(--radius-full);
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--text-medium);
    text-decoration: none;
    transition: all var(--transition-fast);
}

.nav a:hover,
.nav a.active {
    background: var(--secondary-alpha-12);
    color: var(--secondary);
    box-shadow: inset 0 -2px 0 0 var(--secondary);
}

.container {
    width: min(calc(100% - 2rem), var(--shell-width));
    margin: 0 auto;
    padding: var(--space-lg) 0 var(--space-xl);
}

.hero {
    text-align: center;
    padding: var(--space-md) 0 0;
    min-height: auto;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
}

.hero h1 {
    font-size: clamp(1.6rem, 3.5vw, 2.8rem);
    margin-bottom: var(--space-xs);
    color: var(--secondary);
}

.hero .subtitle {
    font-size: 1rem;
    color: var(--text-light);
    max-width: 600px;
    margin: 0 auto var(--space-md);
}

.hero-game-area {
    flex: none;
    display: flex;
    flex-direction: column;
    justify-content: center;
    max-width: 1100px;
    width: 100%;
    margin: 0 auto;
    padding: var(--space-sm) 0;
    min-height: 0;
}

.hero-game {
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: 0 8px 32px var(--shadow);
    background: var(--card-bg);
    border: 1px solid var(--border);
    flex: none;
    display: flex;
    flex-direction: column;
}

.game-frame {
    position: relative;
    width: 100%;
    height: clamp(190px, 28vh, 340px);
    min-height: 0;
}

.game-frame.is-loaded {
    height: clamp(420px, 70vh, 620px);
}

.game-frame iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border: none;
}

.game-frame-placeholder {
    position: absolute;
    inset: 0;
    z-index: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: var(--space-md);
    padding: var(--space-xl);
    color: var(--text-inverse);
    background:
        linear-gradient(135deg, rgba(7, 20, 29, 0.78), rgba(21, 93, 114, 0.82)),
        url('/images/banner.webp') center/cover no-repeat;
    text-align: center;
}

.game-frame-placeholder h2 {
    max-width: 620px;
    margin: 0;
    color: var(--text-inverse);
    font-size: clamp(1.2rem, 3vw, 2rem);
}

.game-frame-placeholder p {
    max-width: 560px;
    margin: 0;
    color: var(--text-inverse);
    font-weight: 600;
}

.game-frame-placeholder .btn {
    background: var(--secondary);
    color: var(--bg-main);
}

.game-frame.is-loaded .game-frame-placeholder {
    display: none;
}

.game-caption {
    text-align: center;
    padding: var(--space-sm) var(--space-md);
    margin: 0;
    font-size: 0.9rem;
    font-weight: 700;
    color: var(--text-inverse);
    background: linear-gradient(90deg, var(--bg-main), var(--secondary-dark));
    flex-shrink: 0;
}

.hero-banner-row {
    display: grid;
    grid-template-columns: minmax(0, 1.5fr) minmax(260px, 0.9fr);
    align-items: center;
    justify-content: center;
    gap: var(--space-lg);
    max-width: 1100px;
    margin: 0 auto var(--space-sm);
    width: 100%;
    padding: var(--space-md);
    border: 1px solid var(--border);
    border-radius: var(--radius-xl);
    background: color-mix(in srgb, var(--card-bg) 94%, transparent);
    box-shadow: 0 10px 28px var(--shadow);
}

.hero-banner-img {
    max-width: 220px;
    height: auto;
    width: 100%;
    display: block;
    filter: drop-shadow(0 10px 24px rgba(0, 0, 0, 0.28));
}

.hero-scene {
    width: 100%;
    min-height: 180px;
    border-radius: var(--radius-lg);
    border: 1px solid var(--border);
    object-fit: cover;
    background: #0b3446;
    box-shadow: 0 8px 24px var(--shadow);
}

.hero-brand-copy {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: var(--space-md);
}

.hero-proof-copy {
    max-width: 420px;
    margin: 0;
    color: var(--text-medium);
    font-size: 0.92rem;
    text-align: left;
}

.hero-cta {
    padding-bottom: var(--space-sm);
    width: 100%;
}

.next-steps-panel {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-md);
    margin-bottom: var(--space-xl);
}

.next-step-card {
    display: flex;
    flex-direction: column;
    gap: var(--space-xs);
    min-height: 100%;
    padding: var(--space-lg);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    background: var(--chrome-surface-strong);
    box-shadow: 0 4px 16px var(--shadow);
    color: inherit;
    text-decoration: none;
    transition: transform var(--transition-normal), box-shadow var(--transition-normal);
}

.next-step-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 24px var(--shadow);
    color: inherit;
}

.next-step-card strong {
    font-family: var(--font-display);
    color: var(--secondary);
}

.next-step-card span {
    color: var(--text-light);
    font-size: 0.9rem;
}

.next-step-card em {
    color: var(--primary-dark);
    font-style: normal;
    font-weight: 700;
    margin-top: auto;
}

.btn-group {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: var(--space-sm);
}

.btn {
    display: inline-flex;
    align-items: center;
    gap: var(--space-xs);
    padding: 0.7rem 1.6rem;
    border-radius: var(--radius-full);
    font-family: var(--font-body);
    font-weight: 700;
    font-size: 0.95rem;
    text-decoration: none;
    border: none;
    cursor: pointer;
    transition: all var(--transition-normal);
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.18);
}

.btn-primary {
    background: var(--primary-dark);
    color: var(--bg-main);
}
.btn-primary:hover { transform: translateY(-2px); box-shadow: 0 8px 22px var(--primary-alpha-20); color: var(--bg-main); }

.btn-secondary {
    background: var(--secondary-dark);
    color: var(--text-inverse);
}
.btn-secondary:hover { transform: translateY(-2px); box-shadow: 0 8px 22px var(--secondary-alpha-25); color: var(--text-inverse); }

.btn-outline {
    border: 1px solid var(--accent-dark);
    color: var(--accent-light);
    background: color-mix(in srgb, var(--card-bg) 80%, transparent);
}
.btn-outline:hover { background: var(--accent-alpha-10); transform: translateY(-2px); color: var(--accent-light); }

.card {
    background: var(--card-alpha-92);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: var(--space-xl);
    box-shadow: 0 8px 28px var(--shadow);
    transition: transform var(--transition-normal), box-shadow var(--transition-normal);
}

.card:hover { transform: translateY(-2px); box-shadow: 0 12px 36px var(--accent-alpha-12); }

.stat-pills {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-sm);
    margin-bottom: var(--space-xl);
}

.stat-pill {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.35rem 1rem;
    border-radius: var(--radius-full);
    font-size: 0.85rem;
    font-weight: 600;
    background: var(--secondary-alpha-12);
    color: var(--secondary);
}

.stat-pill.pink { background: var(--primary-alpha-12); color: var(--primary-dark); }
.stat-pill.purple { background: var(--accent-alpha-12); color: var(--accent-light); }
.stat-pill.gold { background: var(--gold-alpha-18); color: var(--gold-dark); }

.breadcrumb {
    font-size: 0.9rem;
    color: var(--text-light);
    margin-bottom: var(--space-md);
}

.breadcrumb a { color: var(--accent-light); }
.breadcrumb span { color: var(--text-light); }

.reading-time {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    font-size: 0.82rem;
    color: var(--text-light);
    padding: 0.2rem 0.8rem;
    background: var(--secondary-alpha-08);
    border-radius: var(--radius-full);
    margin-bottom: var(--space-md);
}

.toc-widget {
    background: var(--card-alpha-92);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: var(--space-lg);
    margin-bottom: var(--space-xl);
    box-shadow: 0 4px 16px var(--shadow);
}
.toc-widget h3 { font-size: 1rem; margin-bottom: var(--space-sm); }
.toc-widget ol {
    margin: 0;
    padding-left: 1.2rem;
    font-size: 0.9rem;
    color: var(--text-medium);
}
.toc-widget ol li { margin-bottom: var(--space-xs); }
.toc-widget ol a { font-weight: 600; }

.related-content {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-md);
    margin-top: var(--space-xl);
    padding-top: var(--space-xl);
    border-top: 2px solid var(--border);
}

.related-card {
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: var(--space-lg);
    background: var(--card-alpha-90);
    text-decoration: none;
    color: inherit;
    transition: all var(--transition-normal);
    box-shadow: 0 4px 16px var(--shadow);
}
.related-card:hover { transform: translateY(-2px); box-shadow: 0 8px 24px var(--shadow); color: inherit; }
.related-card h4 { font-family: var(--font-display); font-size: 0.95rem; margin: 0 0 var(--space-xs); color: var(--text-dark); }
.related-card p { font-size: 0.82rem; color: var(--text-light); margin: 0; }

.related-paths {
    margin: var(--space-xl) 0;
    padding: var(--space-lg);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    background: var(--chrome-surface-strong);
    box-shadow: 0 6px 22px var(--shadow);
}

.related-paths h2 {
    font-size: clamp(1.2rem, 2vw, 1.55rem);
    margin-bottom: var(--space-sm);
}

.related-paths > p {
    max-width: 720px;
    margin: 0 0 var(--space-md);
    color: var(--text-light);
}

.related-paths-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-md);
}

.related-path-card {
    display: flex;
    flex-direction: column;
    gap: var(--space-xs);
    min-height: 100%;
    padding: var(--space-md);
    border: 1px solid var(--border);
    border-radius: var(--radius-md);
    background: color-mix(in srgb, var(--card-bg) 94%, #0b3446);
    color: inherit;
    text-decoration: none;
    transition: transform var(--transition-normal), box-shadow var(--transition-normal);
}

.related-path-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 22px var(--shadow);
    color: inherit;
}

.related-path-card strong {
    font-family: var(--font-display);
    color: var(--text-dark);
}

.related-reason {
    color: var(--text-light);
    font-size: 0.86rem;
}

.related-path-card em {
    margin-top: auto;
    color: var(--secondary);
    font-style: normal;
    font-weight: 700;
    font-size: 0.86rem;
}

.reading-progress {
    position: fixed;
    top: 76px;
    left: 0;
    right: 0;
    z-index: 95;
    height: 4px;
    background: transparent;
    pointer-events: none;
}

.reading-progress-bar {
    width: 100%;
    height: 100%;
    transform: scaleX(0);
    transform-origin: left center;
    background: linear-gradient(90deg, var(--primary-dark), var(--secondary-dark));
}

.article-anchor-nav {
    position: sticky;
    top: 88px;
    z-index: 50;
    display: flex;
    gap: var(--space-xs);
    overflow-x: auto;
    padding: var(--space-xs) 0;
    margin-bottom: var(--space-md);
    background: var(--bg-main);
    scrollbar-width: thin;
}

.article-anchor-nav a {
    flex: 0 0 auto;
    max-width: 220px;
    padding: 0.28rem 0.72rem;
    border: 1px solid var(--border);
    border-radius: var(--radius-full);
    background: var(--chrome-surface-strong);
    color: var(--text-medium);
    font-size: 0.78rem;
    font-weight: 700;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.article-anchor-nav a:hover,
.article-anchor-nav a.is-active {
    background: var(--secondary-alpha-12);
    color: var(--secondary);
}

.helpful-feedback {
    margin: var(--space-xl) 0;
    padding: var(--space-lg);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    background: var(--chrome-surface-strong);
    box-shadow: 0 4px 16px var(--shadow);
}

.helpful-feedback p {
    margin: 0 0 var(--space-sm);
    color: var(--text-medium);
    font-weight: 700;
}

.helpful-actions {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-sm);
}

.helpful-feedback .btn[aria-pressed="true"] {
    background: var(--secondary-dark);
    color: var(--text-inverse);
    border-color: var(--secondary-dark);
}

.helpful-note {
    margin-top: var(--space-sm);
    color: var(--text-light);
    font-size: 0.86rem;
}

.explore-more {
    text-align: center;
    padding: var(--space-2xl) var(--space-lg);
    margin-top: var(--space-2xl);
    background: var(--bg-gradient);
    border-radius: var(--radius-xl);
    border: 1px solid var(--border);
}
.explore-more h2 { margin-bottom: var(--space-sm); }
.explore-more p { color: var(--text-light); max-width: 500px; margin: 0 auto var(--space-lg); }
.explore-more .btn-group { justify-content: center; }

.continue-reading {
    display: flex;
    align-items: center;
    gap: var(--space-md);
    padding: var(--space-lg);
    background: linear-gradient(135deg, var(--secondary-alpha-12), var(--accent-alpha-10));
    border-radius: var(--radius-lg);
    border: 1px solid var(--border);
    margin-top: var(--space-xl);
    font-weight: 600;
    color: var(--accent-light);
    text-decoration: none;
    transition: all var(--transition-normal);
}
.continue-reading:hover { background: linear-gradient(135deg, var(--secondary-alpha-18), var(--accent-alpha-15)); color: var(--accent-light); }
.continue-reading .cta-arrow { margin-left: auto; font-size: 1.2rem; }

.checklist-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-md);
    margin-top: var(--space-md);
}

.checklist-item {
    display: flex;
    flex-direction: column;
    gap: var(--space-xs);
    min-height: 100%;
    padding: var(--space-lg);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    background: var(--chrome-surface-strong);
    box-shadow: 0 4px 16px var(--shadow);
}

.checklist-item strong {
    font-family: var(--font-display);
    color: var(--text-dark);
}

.checklist-item span {
    color: var(--text-light);
    font-size: 0.9rem;
}

.sticky-mobile-cta {
    display: none;
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 90;
    background: var(--chrome-surface-strong);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    border-top: 1px solid var(--border);
    padding: var(--space-sm) var(--space-md);
    box-shadow: 0 -4px 16px var(--shadow);
}
.sticky-mobile-cta .btn { width: 100%; }

@keyframes fadeInUp {
    from { opacity: 0; transform: translateY(20px); }
    to { opacity: 1; transform: translateY(0); }
}
.fade-in-section {
    opacity: 0;
    transform: translateY(20px);
    transition: opacity 0.6s ease, transform 0.6s ease;
}
.fade-in-section.is-visible { opacity: 1; transform: translateY(0); }

.grid-2 { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--space-lg); }
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-lg); }

.feature-card {
    text-align: center;
    padding: var(--space-xl);
}

.feature-card .icon {
    width: 56px;
    height: 56px;
    margin: 0 auto var(--space-md);
    border-radius: var(--radius-full);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.5rem;
}

.feature-card .icon.pink { background: var(--primary-alpha-16); }
.feature-card .icon.blue { background: var(--secondary-alpha-16); }
.feature-card .icon.purple { background: var(--accent-alpha-16); }
.feature-card .icon.gold { background: var(--gold-alpha-18); }

.feature-card h3 { font-size: 1.15rem; margin-bottom: var(--space-xs); }
.feature-card p { color: var(--text-light); font-size: 0.93rem; margin: 0; }

.table-wrap {
    overflow-x: auto;
    border-radius: var(--radius-lg);
    border: 1px solid var(--border);
    box-shadow: 0 4px 16px var(--shadow);
}

table {
    width: 100%;
    border-collapse: collapse;
    background: color-mix(in srgb, var(--card-bg) 92%, #0b3446);
}

thead th {
    background: linear-gradient(135deg, var(--primary-alpha-15), var(--secondary-alpha-10));
    padding: 0.9rem var(--space-md);
    text-align: left;
    font-family: var(--font-display);
    font-weight: 600;
    color: var(--secondary);
    font-size: 0.9rem;
}

tbody td {
    color: var(--text-medium);
}

tbody td {
    padding: 0.8rem var(--space-md);
    border-top: 1px solid var(--border);
    color: var(--text-medium);
    font-size: 0.9rem;
}

.step-list { list-style: none; padding: 0; counter-reset: step; }

.step-list li {
    counter-increment: step;
    display: flex;
    gap: var(--space-md);
    align-items: flex-start;
    padding: var(--space-lg) 0;
    border-bottom: 1px solid var(--border);
}

.step-list li:last-child { border-bottom: none; }

.step-list li::before {
    content: counter(step);
    flex-shrink: 0;
    width: 36px;
    height: 36px;
    border-radius: var(--radius-full);
    background: var(--primary-light);
    color: var(--primary-dark);
    font-family: var(--font-display);
    font-weight: 700;
    font-size: 1rem;
    display: flex;
    align-items: center;
    justify-content: center;
}

.tip-card {
    border-left: 4px solid;
    padding: var(--space-md) var(--space-lg);
    border-radius: 0 var(--radius-md) var(--radius-md) 0;
    margin-bottom: var(--space-md);
}

.tip-card.pink { border-color: var(--primary); background: var(--primary-alpha-06); }
.tip-card.blue { border-color: var(--secondary); background: var(--secondary-alpha-06); }
.tip-card.purple { border-color: var(--accent); background: var(--accent-alpha-06); }
.tip-card.gold { border-color: var(--gold); background: var(--gold-alpha-08); }

.faq-item {
    border-bottom: 1px solid var(--border);
    padding: var(--space-lg) 0;
}

.faq-item:last-child { border-bottom: none; }

.faq-item h3 {
    font-size: 1.05rem;
    margin-bottom: var(--space-xs);
    cursor: pointer;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.faq-item p {
    color: var(--text-medium);
    margin: var(--space-sm) 0 0;
    font-size: 0.93rem;
}

footer {
    text-align: center;
    padding: var(--space-2xl) var(--space-lg);
    color: var(--text-light);
    font-size: 0.85rem;
    border-top: 1px solid var(--border);
    margin-top: var(--space-2xl);
}

footer a { color: var(--text-light); }
footer a:hover { color: var(--primary-dark); }

/* ── Stats Dashboard ── */
.stats-dashboard {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--space-md);
    margin-bottom: var(--space-xl);
}

.stat-card {
    background: var(--card-alpha-95);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: var(--space-lg);
    text-align: center;
    box-shadow: 0 4px 16px var(--shadow);
    transition: transform var(--transition-normal), box-shadow var(--transition-normal);
    position: relative;
    overflow: hidden;
}
.stat-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
    border-radius: var(--radius-lg) var(--radius-lg) 0 0;
}
.stat-card:hover { transform: translateY(-3px); box-shadow: 0 8px 24px var(--shadow); }

.stat-card .stat-number {
    font-family: var(--font-display);
    font-size: 2rem;
    font-weight: 800;
    margin: 0 0 var(--space-xs);
}
.stat-card .stat-number.pink { color: var(--primary-dark); }
.stat-card .stat-number.blue { color: var(--secondary-dark); }
.stat-card .stat-number.purple { color: var(--accent-dark); }
.stat-card .stat-number.gold { color: var(--gold-dark); }
.stat-card .stat-number.green { color: var(--success-dark); }

.stat-card .stat-label {
    font-size: 0.85rem;
    color: var(--text-light);
    font-weight: 500;
}

.stat-card .stat-sub {
    font-size: 0.75rem;
    color: var(--text-light);
    margin-top: var(--space-xs);
    opacity: 0.7;
}

/* ── Map Showcase ── */
.map-showcase {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: var(--space-md);
    margin-top: var(--space-md);
}

.map-card {
    background: var(--card-alpha-95);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    overflow: hidden;
    text-decoration: none;
    color: inherit;
    transition: all var(--transition-normal);
    box-shadow: 0 4px 16px var(--shadow);
}
.map-card:hover { transform: translateY(-4px); box-shadow: 0 12px 32px var(--primary-alpha-22); }

.map-card .map-thumb {
    height: 100px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2.5rem;
}
.map-card .map-thumb.mansion { background: linear-gradient(135deg, var(--gold-dark), var(--primary-dark)); }
.map-card .map-thumb.farm { background: linear-gradient(135deg, var(--secondary-light), var(--success-dark)); }
.map-card .map-thumb.sewer { background: linear-gradient(135deg, var(--secondary-dark), var(--text-dark)); }
.map-card .map-thumb.backrooms { background: linear-gradient(135deg, var(--gold), var(--border)); }
.map-card .map-thumb.hotel { background: linear-gradient(135deg, var(--primary-light), var(--accent-dark)); }

.map-card .map-info {
    padding: var(--space-md);
    text-align: center;
}
.map-card .map-info h3 { font-size: 0.9rem; margin-bottom: var(--space-xs); }
.map-card .map-info p { font-size: 0.78rem; color: var(--text-light); margin: 0; }

/* ── Timeline ── */
.timeline {
    position: relative;
    padding: var(--space-md) 0;
}

.timeline::before {
    content: '';
    position: absolute;
    left: 20px;
    top: 0;
    bottom: 0;
    width: 4px;
    background: linear-gradient(to bottom, var(--primary-light), var(--secondary-light));
    border-radius: 2px;
}

.timeline-item {
    position: relative;
    padding-left: 54px;
    margin-bottom: var(--space-lg);
}

.timeline-item:last-child { margin-bottom: 0; }

.timeline-item::before {
    content: '';
    position: absolute;
    left: 12px;
    top: 4px;
    width: 20px;
    height: 20px;
    border-radius: 50%;
    background: var(--primary);
    border: 3px solid var(--bg-main);
    box-shadow: 0 0 0 2px var(--primary-light);
}

.timeline-item .timeline-date {
    font-family: var(--font-display);
    font-weight: 700;
    font-size: 0.9rem;
    color: var(--primary-dark);
    margin-bottom: var(--space-xs);
}

.timeline-item .timeline-content h3 {
    font-size: 1.05rem;
    margin-bottom: var(--space-xs);
}

.timeline-item .timeline-content p {
    color: var(--text-light);
    font-size: 0.9rem;
    margin: 0;
}

/* ── Comparison Cards ── */
.compare-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-md);
    margin-top: var(--space-md);
}

.compare-card {
    background: var(--card-alpha-95);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: var(--space-lg);
    text-align: center;
    box-shadow: 0 4px 16px var(--shadow);
    transition: all var(--transition-normal);
}
.compare-card:hover { transform: translateY(-3px); box-shadow: 0 8px 24px var(--primary-alpha-20); }

.compare-card .compare-icon {
    font-size: 2.5rem;
    margin-bottom: var(--space-sm);
}

.compare-card h3 { font-size: 1.05rem; margin-bottom: var(--space-xs); }
.compare-card .compare-price {
    font-family: var(--font-display);
    font-weight: 700;
    color: var(--primary-dark);
    font-size: 1.1rem;
    margin-bottom: var(--space-sm);
}
.compare-card p { font-size: 0.85rem; color: var(--text-light); margin: 0 0 var(--space-md); }
.compare-card .compare-tags {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: var(--space-xs);
}
.compare-card .compare-tag {
    font-size: 0.72rem;
    padding: 0.2rem 0.6rem;
    border-radius: var(--radius-full);
    background: var(--secondary-alpha-12);
    color: var(--secondary-dark);
    font-weight: 600;
}
.compare-card .compare-tag.pink { background: var(--primary-alpha-12); color: var(--primary-dark); }
.compare-card .compare-tag.purple { background: var(--accent-alpha-12); color: var(--accent-light); }
.compare-card .compare-tag.gold { background: var(--gold-alpha-18); color: var(--gold-dark); }

/* ── Spot Challenge ── */
.spot-section {
    background: var(--bg-gradient);
    border-radius: var(--radius-xl);
    padding: var(--space-2xl) var(--space-xl);
    margin-bottom: var(--space-xl);
    text-align: center;
    border: 1px solid var(--border);
}

.spot-section h2 { margin-bottom: var(--space-xs); }
.spot-section .spot-subtitle { color: var(--text-light); margin-bottom: var(--space-lg); }

.spot-game-area {
    position: relative;
    width: 100%;
    max-width: 700px;
    margin: 0 auto var(--space-lg);
    border-radius: var(--radius-lg);
    overflow: hidden;
    border: 3px solid var(--border);
    box-shadow: 0 8px 32px var(--shadow);
    cursor: crosshair;
}

.spot-game-area img {
    display: block;
    width: 100%;
    height: auto;
}

.spot-game-area canvas {
    display: block;
    width: 100%;
    height: auto;
}

.spot-mini-link {
    font-size: 0.82rem;
    color: var(--text-light);
    margin-top: var(--space-md);
}

.spot-mini-link a {
    font-weight: 700;
}

.spot-hint-zone {
    position: absolute;
    border-radius: 50%;
    border: 3px dashed var(--card-alpha-70);
    pointer-events: none;
    display: none;
}

.spot-score {
    font-family: var(--font-display);
    font-size: 1.3rem;
    font-weight: 700;
    color: var(--primary-dark);
    margin-bottom: var(--space-md);
}

.spot-feedback {
    padding: var(--space-md);
    border-radius: var(--radius-md);
    margin-bottom: var(--space-md);
    display: none;
    font-weight: 600;
}

.spot-feedback.correct {
    display: block;
    background: var(--success-alpha-15);
    color: var(--success-dark);
}

.spot-feedback.wrong {
    display: block;
    background: var(--primary-alpha-15);
    color: var(--primary-dark);
}

.spot-difficulty {
    display: flex;
    justify-content: center;
    gap: var(--space-sm);
    margin-bottom: var(--space-lg);
}

.spot-difficulty .diff-btn {
    padding: 0.5rem 1.2rem;
    border-radius: var(--radius-full);
    font-family: var(--font-body);
    font-weight: 600;
    font-size: 0.85rem;
    border: 2px solid transparent;
    cursor: pointer;
    transition: all var(--transition-fast);
}

.diff-btn.easy { border-color: var(--success); color: var(--success-dark); background: var(--success-alpha-08); }
.diff-btn.medium { border-color: var(--gold); color: var(--gold-dark); background: var(--gold-alpha-12); }
.diff-btn.hard { border-color: var(--primary); color: var(--primary-dark); background: var(--primary-alpha-08); }
.diff-btn.active { background: var(--primary-dark); color: var(--text-inverse); border-color: var(--primary-dark); }
.diff-btn:hover { opacity: 0.8; }

/* ── Three-Step Guide ── */
.steps-row {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-lg);
    margin-top: var(--space-md);
}

.step-box {
    text-align: center;
    padding: var(--space-xl) var(--space-lg);
    border-radius: var(--radius-lg);
    background: var(--card-alpha-95);
    border: 2px dashed var(--border);
    transition: all var(--transition-normal);
}
.step-box:hover { border-color: var(--primary-light); transform: translateY(-2px); }

.step-box .step-number {
    width: 48px;
    height: 48px;
    margin: 0 auto var(--space-md);
    border-radius: var(--radius-full);
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--font-display);
    font-weight: 800;
    font-size: 1.3rem;
    color: var(--text-inverse);
}

.step-box .step-number.pink { background: var(--primary-dark); }
.step-box .step-number.blue { background: var(--secondary-dark); }
.step-box .step-number.purple { background: var(--accent-dark); }

.step-box h3 { font-size: 1.1rem; margin-bottom: var(--space-sm); }
.step-box p { font-size: 0.88rem; color: var(--text-light); margin: 0 0 var(--space-md); }

/* ── Community Clips ── */
.clips-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-md);
    margin-top: var(--space-md);
}

.clip-card {
    background: var(--card-alpha-95);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: var(--space-lg);
    box-shadow: 0 4px 16px var(--shadow);
    transition: all var(--transition-normal);
}
.clip-card:hover { transform: translateY(-3px); box-shadow: 0 8px 24px var(--primary-alpha-18); }

.clip-card .clip-header {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    margin-bottom: var(--space-sm);
}

.clip-card .clip-header .clip-emoji { font-size: 1.5rem; }
.clip-card .clip-header .clip-source {
    font-size: 0.78rem;
    color: var(--text-light);
    font-weight: 600;
}

.clip-card h4 { font-size: 0.95rem; margin-bottom: var(--space-xs); }
.clip-card p { font-size: 0.85rem; color: var(--text-light); margin: 0 0 var(--space-sm); }
.clip-card .clip-link {
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--secondary-dark);
}

/* ── Media Quotes ── */
.quotes-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-md);
    margin-top: var(--space-md);
}

.quote-card {
    background: var(--card-alpha-95);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: var(--space-lg);
    box-shadow: 0 4px 16px var(--shadow);
    position: relative;
}

.quote-card::before {
    content: '\\201C';
    position: absolute;
    top: -10px;
    left: var(--space-md);
    font-family: Georgia, serif;
    font-size: 3rem;
    color: var(--primary-light);
    line-height: 1;
}

.quote-card .quote-text {
    font-size: 0.95rem;
    color: var(--text-medium);
    font-style: italic;
    margin: var(--space-sm) 0;
    line-height: 1.6;
}

.quote-card .quote-source {
    font-size: 0.82rem;
    color: var(--text-light);
    font-weight: 600;
    margin-top: var(--space-sm);
    padding-top: var(--space-sm);
    border-top: 1px solid var(--border);
}

/* ── Section Header ── */
.section-header {
    text-align: center;
    margin-bottom: var(--space-lg);
    padding-bottom: var(--space-sm);
    border-bottom: 2px solid var(--border);
}

.section-header h2 { margin-bottom: var(--space-xs); }
.section-header .section-desc {
    font-size: 1rem;
    color: var(--text-light);
    max-width: 500px;
    margin: 0 auto;
}

.section-badge {
    display: inline-block;
    padding: 0.25rem 1rem;
    border-radius: var(--radius-full);
    font-size: 0.75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: var(--space-sm);
}
.section-badge.pink { background: var(--primary-alpha-12); color: var(--primary-dark); }
.section-badge.blue { background: var(--secondary-alpha-12); color: var(--secondary); }
.section-badge.purple { background: var(--accent-alpha-12); color: var(--accent-light); }
.section-badge.gold { background: var(--gold-alpha-18); color: var(--gold-dark); }
.section-badge.green { background: var(--success-alpha-15); color: var(--success); }

/* ── CTA Banner ── */
.cta-banner {
    background: linear-gradient(135deg, rgba(11, 52, 70, 0.92), rgba(21, 93, 114, 0.88));
    border-radius: var(--radius-xl);
    padding: var(--space-2xl);
    text-align: center;
    margin-bottom: var(--space-xl);
    box-shadow: 0 8px 32px var(--shadow);
    border: 1px solid var(--border);
}

.cta-banner h2 { color: var(--text-dark); }
.cta-banner p { color: var(--text-medium); max-width: 500px; margin: 0 auto var(--space-lg); }

.cta-banner .btn-group { margin-top: var(--space-md); }

.price-hero-box {
    margin-top: var(--space-md);
    padding: var(--space-lg);
    border-radius: var(--radius-md);
    background: linear-gradient(135deg, rgba(11, 52, 70, 0.82), rgba(21, 93, 114, 0.7));
    text-align: center;
}

.price-hero-box .price-value {
    margin: 0;
    color: var(--gold);
    font-size: 3rem;
    font-weight: 800;
}

.price-hero-box .price-note {
    margin: var(--space-xs) 0 0;
    color: var(--text-light);
}

/* ── Updates Card ── */
.update-highlight {
    display: flex;
    align-items: flex-start;
    gap: var(--space-lg);
    padding: var(--space-lg);
    background: var(--card-alpha-95);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    box-shadow: 0 4px 16px var(--shadow);
}

.update-highlight .update-badge {
    flex-shrink: 0;
    width: 56px;
    height: 56px;
    border-radius: var(--radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.5rem;
    background: var(--primary-light);
}

.update-highlight .update-info h3 { font-size: 1.05rem; margin-bottom: var(--space-xs); }
.update-highlight .update-info p { font-size: 0.88rem; color: var(--text-light); margin: 0 0 var(--space-sm); }

/* ── Spot Challenge Gallery ── */
.spot-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-md);
    margin-top: var(--space-md);
}

.spot-item {
    position: relative;
    border-radius: var(--radius-lg);
    overflow: hidden;
    border: 2px solid var(--border);
    box-shadow: 0 4px 16px var(--shadow);
    transition: all var(--transition-normal);
}
.spot-item:hover { border-color: var(--primary); box-shadow: 0 8px 28px var(--primary-alpha-20); }

.spot-item-img {
    width: 100%;
    height: 220px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 4rem;
    position: relative;
}

.spot-item-overlay {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--overlay-dark-70);
    color: var(--text-inverse);
    font-size: 0.9rem;
    font-weight: 700;
    opacity: 0;
    transition: opacity var(--transition-normal);
    cursor: pointer;
    font-family: var(--font-body);
}
.spot-item-overlay:hover { opacity: 1; }
.spot-item-overlay.revealed { opacity: 1; background: var(--primary-alpha-85); }

.spot-item-caption {
    padding: var(--space-sm) var(--space-md);
    font-size: 0.82rem;
    color: var(--text-light);
    text-align: center;
    background: color-mix(in srgb, var(--card-bg) 94%, #0b3446);
}

.spot-thumb-mansion { background: linear-gradient(135deg, var(--gold-dark), var(--primary-dark)); }
.spot-thumb-sewer { background: linear-gradient(135deg, var(--secondary-dark), var(--text-dark)); }
.spot-thumb-backrooms { background: linear-gradient(135deg, var(--gold), var(--border)); }
.spot-thumb-farm { background: linear-gradient(135deg, var(--secondary-light), var(--success-dark)); }
.spot-thumb-hotel { background: linear-gradient(135deg, var(--primary-light), var(--accent-dark)); }
.spot-thumb-blue { background: linear-gradient(135deg, var(--secondary-light), var(--secondary-dark)); }

.media-object-icon {
    flex-shrink: 0;
    width: 120px;
    height: 120px;
    border-radius: var(--radius-lg);
    background: linear-gradient(135deg, var(--primary-light), var(--secondary-light));
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 3rem;
}

/* ── Mistakes Grid ── */
.mistakes-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--space-md);
    margin-top: var(--space-md);
}

.mistake-card {
    background: var(--card-alpha-95);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: var(--space-lg) var(--space-md);
    text-align: center;
    box-shadow: 0 4px 16px var(--shadow);
    transition: all var(--transition-normal);
}
.mistake-card:hover { transform: translateY(-3px); box-shadow: 0 8px 24px var(--primary-alpha-18); }

.mistake-card .mistake-icon {
    font-size: 2rem;
    margin-bottom: var(--space-sm);
}

.mistake-card .mistake-bad {
    font-size: 0.82rem;
    color: var(--primary-dark);
    font-weight: 700;
    margin-bottom: var(--space-xs);
    text-decoration: line-through;
}

.mistake-card .mistake-good {
    font-size: 0.85rem;
    color: var(--success-dark);
    font-weight: 600;
}

/* ── Reviews Row ── */
.reviews-row {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-md);
    margin-top: var(--space-md);
}

.review-card {
    background: var(--card-alpha-95);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: var(--space-lg);
    box-shadow: 0 4px 16px var(--shadow);
}

.review-card .review-stars {
    color: var(--gold-dark);
    font-size: 1rem;
    margin-bottom: var(--space-sm);
}

.review-card .review-text {
    font-size: 0.9rem;
    color: var(--text-medium);
    font-style: italic;
    line-height: 1.6;
    margin-bottom: var(--space-sm);
}

.review-card .review-author {
    font-size: 0.78rem;
    color: var(--text-light);
    font-weight: 600;
}

/* ── Roadmap ── */
.roadmap {
    display: flex;
    flex-direction: column;
    gap: var(--space-md);
    margin-top: var(--space-md);
}

.roadmap-item {
    display: flex;
    align-items: center;
    gap: var(--space-md);
    padding: var(--space-md) var(--space-lg);
    background: var(--card-alpha-95);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    box-shadow: 0 4px 16px var(--shadow);
}

.roadmap-item .roadmap-icon {
    flex-shrink: 0;
    width: 48px;
    height: 48px;
    border-radius: var(--radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.3rem;
}

.roadmap-item.done .roadmap-icon { background: var(--success-alpha-15); }
.roadmap-item.in-progress .roadmap-icon { background: var(--gold-alpha-18); }
.roadmap-item.planned .roadmap-icon { background: var(--secondary-alpha-12); }

.roadmap-item .roadmap-info h4 {
    font-size: 0.95rem;
    margin: 0 0 var(--space-xs);
}

.roadmap-item .roadmap-info p {
    font-size: 0.82rem;
    color: var(--text-light);
    margin: 0;
}

.roadmap-item .roadmap-tag {
    flex-shrink: 0;
    margin-left: auto;
    font-size: 0.72rem;
    padding: 0.2rem 0.8rem;
    border-radius: var(--radius-full);
    font-weight: 700;
}

.roadmap-item.done .roadmap-tag { background: var(--success-alpha-15); color: var(--success); }
.roadmap-item.in-progress .roadmap-tag { background: var(--gold-alpha-18); color: var(--gold-dark); }
.roadmap-item.planned .roadmap-tag { background: var(--secondary-alpha-12); color: var(--secondary); }

/* ── Mobile Navigation Toggle ── */
.nav-toggle {
    display: none;
    background: none;
    border: none;
    font-size: 1.6rem;
    cursor: pointer;
    color: var(--text-medium);
    padding: var(--space-xs);
    line-height: 1;
}

.nav-toggle:hover { color: var(--secondary); }

.stat-card.border-primary { border-top: 4px solid var(--primary-dark); }
.stat-card.border-secondary { border-top: 4px solid var(--secondary-dark); }
.stat-card.border-gold { border-top: 4px solid var(--gold); }
.stat-card.border-success { border-top: 4px solid var(--success-dark); }
.stat-card.border-accent { border-top: 4px solid var(--accent-dark); }

.map-card-link {
    text-decoration: none;
    color: inherit;
}

.map-link-accent {
    margin-top: var(--space-sm);
    font-weight: 700;
}

.map-link-accent.primary { color: var(--primary-light); }
.map-link-accent.secondary { color: var(--secondary); }
.map-link-accent.accent { color: var(--accent-light); }
.map-link-accent.gold { color: var(--gold-dark); }

.challenge-header {
    text-align: center;
    margin-bottom: var(--space-xl);
}

.challenge-header h1 { font-size: 2.2rem; }

.challenge-copy,
.challenge-muted {
    color: var(--text-light);
}

.challenge-difficulty {
    justify-content: center;
    margin-bottom: var(--space-xl);
}

.challenge-tool-section {
    padding: var(--space-lg);
}

.challenge-canvas-wrap {
    max-width: 800px;
}

.challenge-actions {
    justify-content: center;
}

.challenge-stats {
    display: flex;
    justify-content: center;
    gap: var(--space-xl);
    margin-bottom: var(--space-lg);
    flex-wrap: wrap;
}

.challenge-stat { text-align: center; }
.challenge-stat .stat-big {
    font-family: var(--font-display);
    font-size: 1.8rem;
    font-weight: 800;
    color: var(--primary-dark);
}
.challenge-stat .stat-small {
    font-size: 0.8rem;
    color: var(--text-light);
}

.challenge-progress {
    height: 6px;
    background: var(--border);
    border-radius: var(--radius-sm);
    margin-bottom: var(--space-lg);
    overflow: hidden;
}

.challenge-progress-bar {
    height: 100%;
    background: linear-gradient(90deg, var(--primary), var(--secondary));
    border-radius: var(--radius-sm);
    transition: width var(--transition-normal);
}

.round-indicator {
    text-align: center;
    font-size: 0.85rem;
    color: var(--text-light);
    margin-bottom: var(--space-md);
}

.leaderboard {
    margin-top: var(--space-xl);
}

.leaderboard.challenge-board {
    margin-top: var(--space-2xl);
}

.leaderboard-copy {
    color: var(--text-light);
    margin-bottom: var(--space-md);
}

.leaderboard table { width: 100%; }
.leaderboard .rank { font-weight: 700; }
.leaderboard .rank-1 { color: var(--gold-dark); }
.leaderboard .rank-2 { color: var(--secondary-dark); }
.leaderboard .rank-3 { color: var(--primary-dark); }

.end-screen {
    text-align: center;
    padding: var(--space-2xl);
    display: none;
}

.end-screen .final-score {
    font-size: 3rem;
    font-family: var(--font-display);
    font-weight: 800;
    color: var(--primary-dark);
}

.end-screen .grade {
    font-size: 1.5rem;
    margin: var(--space-md) 0;
}

.end-screen #final-stats {
    margin-bottom: var(--space-lg);
}

.is-hidden { display: none !important; }

@media (max-width: 768px) {
    .nav-toggle { display: block; }
    .nav {
        display: none;
        position: absolute;
        top: 76px;
        left: 0;
        right: 0;
        background: var(--chrome-surface-strong);
        backdrop-filter: blur(16px);
        -webkit-backdrop-filter: blur(16px);
        border-bottom: 1px solid var(--border);
        flex-direction: column;
        padding: var(--space-md);
        box-shadow: 0 8px 24px var(--shadow);
    }
    .nav.open { display: flex; }
    .nav a {
        padding: 0.6rem 1rem;
        font-size: 0.95rem;
        border-radius: var(--radius-sm);
    }
}

/* ── Comprehensive Responsive overrides ── */
@media (max-width: 900px) {
    .stats-dashboard { grid-template-columns: repeat(4, 1fr); }
    .map-showcase { grid-template-columns: repeat(3, 1fr); }
    .compare-grid { grid-template-columns: repeat(2, 1fr); }
    .steps-row { grid-template-columns: 1fr; }
    .clips-grid { grid-template-columns: 1fr; }
    .quotes-grid { grid-template-columns: 1fr; }
    .hero-banner-row { grid-template-columns: 1fr; }
    .hero-banner-img { max-width: 200px; }
    .hero-brand-copy { align-items: center; }
    .hero-scene { min-height: 220px; }
    .mistakes-grid { grid-template-columns: repeat(2, 1fr); }
    .reviews-row { grid-template-columns: 1fr; }
    .spot-grid { grid-template-columns: 1fr; }
    .next-steps-panel { grid-template-columns: 1fr; }
    .related-paths-grid { grid-template-columns: 1fr; }
    .checklist-grid { grid-template-columns: 1fr; }
    .hero-proof-copy { text-align: center; }
}

@media (max-width: 768px) {
    .grid-2, .grid-3 { grid-template-columns: 1fr; }
    .related-content { grid-template-columns: 1fr; }
    .related-paths { padding: var(--space-md); }
    .sticky-mobile-cta { display: block; }
    .explore-more { padding: var(--space-lg); }
    .toc-widget { padding: var(--space-md); }
    .hero { min-height: auto; padding: var(--space-lg) 0; }
    .hero h1 { font-size: 1.5rem; }
    .hero .subtitle { font-size: 0.9rem; padding: 0 var(--space-sm); }
    .hero-game-area { padding: var(--space-sm) 0; }
    .game-frame,
    .game-frame.is-loaded { aspect-ratio: 16 / 9; height: auto; min-height: 220px; }
    .game-frame-placeholder { padding: var(--space-lg); }
    .game-frame-placeholder p { font-size: 0.9rem; }
    .game-caption { font-size: 0.8rem; padding: var(--space-xs) var(--space-sm); }
    .hero-cta { padding-bottom: var(--space-md); }
    .hero-cta .btn-group {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        width: 100%;
    }
    .hero-cta .btn {
        min-height: 44px;
        padding: 0.55rem 0.7rem;
        font-size: 0.82rem;
        white-space: normal;
    }
    .btn-group { flex-direction: column; align-items: center; }
    .btn { width: 100%; justify-content: center; padding: 0.6rem 1.2rem; font-size: 0.9rem; }
    .header { padding: 0 var(--space-sm); }
    .header-inner { height: 52px; }
    .logo { font-size: 1.1rem; }
    .stats-dashboard { grid-template-columns: repeat(2, 1fr); }
    .map-showcase { grid-template-columns: repeat(2, 1fr); }
    .mistakes-grid { grid-template-columns: 1fr 1fr; }
    .card { padding: var(--space-md); }
    .container { padding: var(--space-md) 0 var(--space-lg); }
    table { font-size: 0.82rem; }
    thead th, tbody td { padding: 0.6rem var(--space-sm); }
    .cta-banner { padding: var(--space-lg); }
    .update-highlight { flex-direction: column; align-items: center; text-align: center; }
    .roadmap-item { flex-wrap: wrap; }
    .roadmap-item .roadmap-tag { margin-left: 0; }
    .spot-item-img { height: 160px; font-size: 3rem; }
    footer { padding: var(--space-lg) var(--space-sm); }
    footer p { line-height: 2; }
}

@media (max-width: 480px) {
    .container { width: 100%; padding: var(--space-sm); }
    .card { padding: var(--space-sm); border-radius: var(--radius-md); }
    .stats-dashboard { grid-template-columns: repeat(2, 1fr); gap: var(--space-sm); }
    .stat-card { padding: var(--space-sm); }
    .stat-card .stat-number { font-size: 1.5rem; }
    .stat-card .stat-label { font-size: 0.75rem; }
    .map-showcase { grid-template-columns: repeat(2, 1fr); gap: var(--space-sm); }
    .map-card .map-thumb { height: 70px; font-size: 1.8rem; }
    .map-card .map-info { padding: var(--space-sm); }
    .compare-grid { grid-template-columns: 1fr; }
    .mistakes-grid { grid-template-columns: 1fr; }
    .spot-item-img { height: 130px; font-size: 2.5rem; }
    .hero { padding: var(--space-md) 0; }
    .hero h1 { font-size: 1.3rem; }
    .game-frame { min-height: 190px; }
    .section-header { margin-bottom: var(--space-md); padding-bottom: var(--space-xs); }
    .section-header h2 { font-size: 1.2rem; }
    .timeline { padding: var(--space-sm) 0; }
    .timeline::before { left: 12px; width: 3px; }
    .timeline-item { padding-left: 36px; }
    .timeline-item::before { left: 6px; width: 16px; height: 16px; }
    h1 { font-size: 1.4rem; }
    h2 { font-size: 1.2rem; }
    h3 { font-size: 1rem; }
}
