/*
 * 1Go Casino Design System
 * Garage-Noir Racing Glamour: dark graphite, neon red, trophy gold.
 */

/* ============================================
   TOKENS - Colors, spacing, fonts, motion
   Dark theme is the default; .dark mirrors tokens for compatibility.
   ============================================ */

:root,
.dark {
    --background: #0b0d10;
    --foreground: #f4f6f8;
    --card: #151a22;
    --card-foreground: #f4f6f8;
    --popover: #10151d;
    --popover-foreground: #f4f6f8;
    --primary: #e0002a;
    --primary-foreground: #ffffff;
    --secondary: #172033;
    --secondary-foreground: #f4f6f8;
    --muted: #253042;
    --muted-foreground: #c1c9d6;
    --accent: #d4a017;
    --accent-foreground: #161006;
    --destructive: #dc2626;
    --destructive-foreground: #ffffff;
    --border: #334155;
    --input: #111827;
    --ring: #ff2d55;

    --charcoal: #07090d;
    --graphite: #101722;
    --steel: #1c2a3d;
    --smoke: #a8b3c4;
    --pearl: #f4f6f8;
    --gold: #d4a017;
    --gold-soft: #ffcf5a;
    --red: #e0002a;
    --red-hot: #ff2d55;

    --font-display: "Orbitron", sans-serif;
    --font-body: "Manrope", sans-serif;

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

    --radius-sm: 0.75rem;
    --radius-md: 1.25rem;
    --radius-lg: 1.75rem;
    --radius-pill: 999px;

    --shadow-smoke: 0 20px 60px rgba(0, 0, 0, 0.38);
    --shadow-red: 0 0 34px rgba(224, 0, 42, 0.34);
    --shadow-gold: 0 0 28px rgba(212, 160, 23, 0.2);

    --container: 73.75rem;
    --header-height: 4.75rem;
    --transition-fast: 180ms ease-out;
}

/* ============================================
   RESET & OVERFLOW SAFETY - Predictable layout
   ============================================ */

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

html {
    min-width: 320px;
    scroll-behavior: smooth;
    color-scheme: dark;
}

body {
    margin: 0;
    min-width: 320px;
    background:
        radial-gradient(circle at 15% 0%, rgba(224, 0, 42, 0.20), transparent 32rem),
        radial-gradient(circle at 85% 18%, rgba(36, 59, 83, 0.55), transparent 34rem),
        linear-gradient(180deg, #0b0d10 0%, #10141c 48%, #07090d 100%);
    color: var(--foreground);
    font-family: var(--font-body);
    font-size: 1rem;
    line-height: 1.58;
    overflow-x: hidden;
    text-rendering: optimizeLegibility;
}

body.menu-open {
    overflow: hidden;
}

img,
video,
iframe,
embed,
object,
svg {
    max-width: 100%;
    height: auto;
}

[class*="grid"] > *,
[class*="flex"] > *,
.card,
.info-card,
.feature-card,
.stat-card {
    min-width: 0;
}

pre,
code,
.code-block,
[class*="code"] {
    max-width: 100%;
    overflow-x: auto;
}

pre code,
.code-block code {
    display: block;
    min-width: 0;
    white-space: pre;
}

.table-wrapper,
[class*="table-"] {
    max-width: 100%;
    min-width: 0;
    overflow-x: auto;
    outline-offset: 4px;
}

.table-wrapper:focus-visible {
    outline: 3px solid var(--ring);
    border-radius: var(--radius-md);
}

p,
li,
td,
th {
    overflow-wrap: break-word;
}

a {
    color: var(--gold-soft);
    text-underline-offset: 0.22em;
}

a[href^="http"],
.inline-url {
    word-break: break-all;
}

button,
input,
textarea,
select {
    font: inherit;
    max-width: 100%;
}

section,
.hero,
.cta-banner {
    overflow: clip;
}

/* ============================================
   ACCESSIBILITY - Focus, skip link, hidden text
   ============================================ */

.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: fixed;
    top: var(--space-md);
    left: var(--space-md);
    z-index: 2000;
    transform: translateY(-160%);
    padding: var(--space-sm) var(--space-md);
    border-radius: var(--radius-pill);
    background: var(--primary);
    color: var(--primary-foreground);
    font-weight: 800;
    text-decoration: none;
    transition: transform var(--transition-fast);
}

.skip-link:focus {
    transform: translateY(0);
}

:focus-visible {
    outline: 3px solid var(--ring);
    outline-offset: 3px;
}

/* ============================================
   TYPOGRAPHY - Orbitron display, Manrope body
   ============================================ */

h1,
h2,
h3,
h4,
.display-heading {
    margin: 0 0 var(--space-md);
    color: var(--pearl);
    font-family: var(--font-display);
    font-weight: 800;
    line-height: 1.08;
    letter-spacing: -0.035em;
    text-transform: uppercase;
}

h1 {
    font-size: clamp(2.5rem, calc(7vw + 0.5rem), 4.5rem);
}

h2 {
    font-size: clamp(1.875rem, calc(4vw + 0.5rem), 3rem);
}

h3 {
    font-size: clamp(1.375rem, calc(2vw + 0.75rem), 1.875rem);
}

h4 {
    font-size: 1.125rem;
}

p {
    margin: 0 0 var(--space-md);
}

.lead,
.section-lead {
    max-width: 72ch;
    color: var(--muted-foreground);
    font-size: clamp(1.05rem, calc(0.5vw + 1rem), 1.18rem);
}

.section-kicker {
    display: inline-flex;
    align-items: center;
    gap: var(--space-xs);
    margin-bottom: var(--space-sm);
    color: var(--gold-soft);
    font-family: var(--font-display);
    font-size: 0.82rem;
    font-weight: 800;
    letter-spacing: 0.16em;
    text-transform: uppercase;
}

.section-kicker::before {
    content: "";
    width: 2.25rem;
    height: 0.125rem;
    border-radius: var(--radius-pill);
    background: linear-gradient(90deg, var(--red), var(--gold));
    box-shadow: var(--shadow-red);
}

/* ============================================
   LAYOUT - Containers, sections, grids
   ============================================ */

.container {
    width: min(100% - 2rem, var(--container));
    margin-inline: auto;
}

.container.narrow {
    width: min(100% - 2rem, 52rem);
}

.section {
    padding-block: var(--space-3xl);
}

.section-tight {
    padding-block: var(--space-2xl);
}

.grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: var(--space-lg);
}

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

.content-flow > * + * {
    margin-top: var(--space-lg);
}

.prose {
    max-width: 72ch;
}

.prose p,
.prose li {
    color: var(--muted-foreground);
}

/* ============================================
   HEADER & NAVIGATION - Sticky racing cockpit
   ============================================ */

.site-header {
    position: sticky;
    top: 0;
    z-index: 1000;
    min-height: var(--header-height);
    background: rgba(11, 13, 16, 0.98);
    border-bottom: 1px solid rgba(255, 255, 255, 0.10);
    box-shadow: 0 16px 40px rgba(0, 0, 0, 0.34);
}

.header-inner {
    width: min(100% - 1rem, var(--container));
    min-height: var(--header-height);
    margin-inline: auto;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-md);
}

.site-brand {
    display: inline-flex;
    align-items: center;
    gap: var(--space-sm);
    min-height: 3rem;
    color: var(--foreground);
    text-decoration: none;
    flex-shrink: 0;
}

.logo {
    width: 3rem;
    height: 3rem;
    border-radius: 1rem;
    box-shadow: var(--shadow-red);
}

.brand-text {
    font-family: var(--font-display);
    font-size: 1.05rem;
    font-weight: 900;
    letter-spacing: -0.02em;
    text-transform: uppercase;
}

.mobile-menu-toggle {
    position: relative;
    z-index: 1001;
    display: inline-flex;
    width: 3rem;
    height: 3rem;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.32rem;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    background: var(--graphite);
    color: var(--foreground);
    cursor: pointer;
}

.burger-line {
    width: 1.35rem;
    height: 0.125rem;
    border-radius: var(--radius-pill);
    background: var(--foreground);
    transition: transform var(--transition-fast), opacity var(--transition-fast);
}

.mobile-menu-toggle[aria-expanded="true"] .burger-line:nth-child(2) {
    transform: translateY(0.45rem) rotate(45deg);
}

.mobile-menu-toggle[aria-expanded="true"] .burger-line:nth-child(3) {
    opacity: 0;
}

.mobile-menu-toggle[aria-expanded="true"] .burger-line:nth-child(4) {
    transform: translateY(-0.45rem) rotate(-45deg);
}

.primary-nav {
    display: none;
}

.primary-nav.is-open {
    position: fixed;
    z-index: 999;
    top: var(--header-height);
    right: 0;
    bottom: 0;
    left: 0;
    display: flex;
    flex-direction: column;
    gap: var(--space-lg);
    padding: var(--space-lg);
    background: var(--background);
    overflow-y: auto;
}

.nav-list {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: var(--space-xs);
    margin: 0;
    padding: 0;
    list-style: none;
}

.nav-list a {
    position: relative;
    display: flex;
    min-height: 3rem;
    align-items: center;
    padding: var(--space-sm) var(--space-md);
    border-radius: var(--radius-sm);
    color: var(--foreground);
    font-weight: 800;
    text-decoration: none;
    transition: background var(--transition-fast), color var(--transition-fast);
}

.nav-list a:hover {
    background: rgba(224, 0, 42, 0.14);
    color: var(--gold-soft);
}

.header-actions {
    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
}

/* ============================================
   BUTTONS - Primary red CTA, ghost action
   ============================================ */

.btn {
    display: inline-flex;
    min-height: 3rem;
    align-items: center;
    justify-content: center;
    gap: var(--space-xs);
    padding: 0.82rem 1.15rem;
    border: 1px solid transparent;
    border-radius: var(--radius-pill);
    font-weight: 900;
    line-height: 1.1;
    text-align: center;
    text-decoration: none;
    cursor: pointer;
    transition: transform var(--transition-fast), box-shadow var(--transition-fast), background var(--transition-fast), border-color var(--transition-fast);
}

.btn:hover {
    transform: translateY(-2px);
}

.btn-primary {
    border-color: rgba(255, 207, 90, 0.45);
    background: linear-gradient(135deg, #ff1747 0%, var(--primary) 52%, #9a001c 100%);
    color: var(--primary-foreground);
    box-shadow: var(--shadow-red);
}

.btn-primary:hover {
    box-shadow: 0 0 0 2px rgba(212, 160, 23, 0.34), var(--shadow-red);
}

.btn-ghost {
    border-color: var(--border);
    background: rgba(255, 255, 255, 0.04);
    color: var(--foreground);
}

.btn-ghost:hover {
    border-color: var(--red-hot);
    background: rgba(224, 0, 42, 0.14);
}

.btn-large {
    min-height: 3.5rem;
    padding-inline: var(--space-xl);
    font-size: 1.05rem;
}

/* ============================================
   HERO - Cinematic garage-noir banner
   ============================================ */

.hero {
    position: relative;
    padding-block: clamp(4rem, calc(8vw + 2rem), 8rem);
    background:
        linear-gradient(110deg, rgba(7, 9, 13, 0.95) 0%, rgba(11, 13, 16, 0.88) 48%, rgba(224, 0, 42, 0.17) 100%),
        radial-gradient(circle at 78% 25%, rgba(255, 45, 85, 0.28), transparent 28rem);
}

.hero::before,
.cta-banner::before,
.card-featured::before {
    content: "";
    position: absolute;
    inset: auto -8rem 10% auto;
    width: 22rem;
    height: 0.45rem;
    background: linear-gradient(90deg, transparent, var(--red-hot), var(--gold), transparent);
    transform: rotate(-24deg);
    box-shadow: var(--shadow-red);
    pointer-events: none;
}

.hero-grid {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: var(--space-2xl);
    align-items: center;
}

.hero-media {
    position: relative;
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: var(--radius-lg);
    background: linear-gradient(145deg, rgba(21, 26, 34, 0.9), rgba(224, 0, 42, 0.12));
    box-shadow: var(--shadow-smoke);
    overflow: hidden;
}

.hero-media img {
    display: block;
    width: 100%;
}

.bonus-pill {
    display: inline-flex;
    align-items: center;
    gap: var(--space-xs);
    margin-bottom: var(--space-md);
    padding: 0.55rem 0.9rem;
    border: 1px solid rgba(212, 160, 23, 0.45);
    border-radius: var(--radius-pill);
    background: rgba(212, 160, 23, 0.10);
    color: var(--gold-soft);
    font-family: var(--font-display);
    font-size: 0.85rem;
    font-weight: 800;
    text-transform: uppercase;
}

.hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-sm);
    margin-top: var(--space-xl);
}

.microcopy {
    margin: var(--space-sm) 0 0;
    color: var(--muted-foreground);
    font-size: 0.9rem;
}

/* ============================================
   CARDS - Content containers and feature blocks
   ============================================ */

.card,
.info-card,
.feature-card,
.review-card {
    position: relative;
    padding: var(--space-lg);
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: var(--radius-md);
    background:
        linear-gradient(145deg, rgba(21, 26, 34, 0.94), rgba(16, 23, 34, 0.94)),
        radial-gradient(circle at top right, rgba(224, 0, 42, 0.12), transparent 14rem);
    color: var(--card-foreground);
    box-shadow: 0 12px 36px rgba(0, 0, 0, 0.18);
    transition: transform var(--transition-fast), border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.card:hover,
.info-card:hover,
.feature-card:hover,
.review-card:hover {
    transform: translateY(-3px);
    border-color: rgba(255, 45, 85, 0.42);
    box-shadow: var(--shadow-smoke);
}

.card-featured {
    position: relative;
    border-color: rgba(255, 45, 85, 0.55);
    box-shadow: var(--shadow-red);
}

.card h3,
.info-card h3,
.feature-card h3,
.review-card h3 {
    margin-bottom: var(--space-sm);
}

.card p:last-child,
.info-card p:last-child,
.feature-card p:last-child,
.review-card p:last-child {
    margin-bottom: 0;
}

.icon-badge {
    display: inline-grid;
    width: 3rem;
    height: 3rem;
    place-items: center;
    margin-bottom: var(--space-md);
    border-radius: var(--radius-sm);
    background: rgba(224, 0, 42, 0.16);
    color: var(--gold-soft);
    font-size: 1.3rem;
}

/* ============================================
   ENGAGEMENT PATTERNS - TL;DR, callouts, quotes
   ============================================ */

.summary-box,
.tldr-box {
    padding: var(--space-lg);
    border: 1px solid rgba(212, 160, 23, 0.42);
    border-radius: var(--radius-md);
    background:
        linear-gradient(135deg, rgba(212, 160, 23, 0.13), rgba(224, 0, 42, 0.08)),
        var(--card);
    box-shadow: var(--shadow-gold);
}

.summary-box strong,
.tldr-box strong {
    color: var(--gold-soft);
}

.callout {
    padding: var(--space-lg);
    border-left: 4px solid var(--red-hot);
    border-radius: var(--radius-md);
    background: rgba(224, 0, 42, 0.10);
}

.callout.warning {
    border-left-color: var(--gold);
    background: rgba(212, 160, 23, 0.10);
}

.pull-quote,
blockquote {
    margin: var(--space-xl) 0;
    padding: var(--space-lg);
    border-left: 4px solid var(--gold);
    border-radius: 0 var(--radius-md) var(--radius-md) 0;
    background: rgba(255, 255, 255, 0.045);
    color: var(--pearl);
    font-size: clamp(1.15rem, calc(1vw + 1rem), 1.45rem);
    font-weight: 700;
    line-height: 1.45;
}

blockquote cite,
.pull-quote cite {
    display: block;
    margin-top: var(--space-sm);
    color: var(--muted-foreground);
    font-size: 0.95rem;
    font-style: normal;
    font-weight: 600;
}

/* ============================================
   STATS - Citation-friendly number cards
   ============================================ */

.stat-highlight-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: var(--space-md);
    margin-block: var(--space-xl);
}

.stat-card {
    position: relative;
    padding: var(--space-lg);
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: var(--radius-md);
    background:
        radial-gradient(circle at 18% 20%, rgba(224, 0, 42, 0.22), transparent 8rem),
        var(--secondary);
    overflow: hidden;
    transition: transform var(--transition-fast), border-color var(--transition-fast);
}

.stat-card::after {
    content: "";
    position: absolute;
    top: 1rem;
    right: -1.75rem;
    width: 7rem;
    height: 0.2rem;
    background: linear-gradient(90deg, var(--red), var(--gold));
    transform: rotate(-28deg);
    transition: right var(--transition-fast);
}

.stat-card:hover {
    transform: translateY(-3px);
    border-color: rgba(255, 45, 85, 0.45);
}

.stat-card:hover::after {
    right: -1rem;
}

.stat-card strong {
    display: block;
    color: var(--gold-soft);
    font-family: var(--font-display);
    font-size: clamp(2rem, calc(3vw + 1rem), 3rem);
    font-variant-numeric: tabular-nums;
    line-height: 1;
    text-shadow: 0 0 18px rgba(224, 0, 42, 0.42);
}

.stat-card span {
    display: block;
    margin-top: var(--space-sm);
    color: var(--foreground);
    font-weight: 800;
}

.stat-card small {
    display: block;
    margin-top: var(--space-xs);
    color: var(--muted-foreground);
    font-size: 0.88rem;
}

/* ============================================
   TABLES - Comparison and payment data
   ============================================ */

table {
    width: 100%;
    min-width: 42rem;
    border-collapse: collapse;
    overflow: hidden;
    border-radius: var(--radius-md);
    background: var(--card);
}

caption {
    margin-bottom: var(--space-sm);
    color: var(--muted-foreground);
    text-align: left;
    font-weight: 700;
}

th,
td {
    padding: 0.95rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.10);
    text-align: left;
    vertical-align: top;
}

th {
    background: rgba(224, 0, 42, 0.14);
    color: var(--pearl);
    font-family: var(--font-display);
    font-size: 0.82rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

td {
    color: var(--muted-foreground);
}

tr.recommended td,
td.recommended,
th.recommended {
    background: rgba(212, 160, 23, 0.12);
    color: var(--foreground);
}

/* ============================================
   FAQ & DETAILS - Native accessible accordions
   ============================================ */

.faq-accordion {
    display: grid;
    gap: var(--space-md);
    margin-top: var(--space-xl);
}

details,
.faq-item {
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: var(--radius-md);
    background: var(--card);
    overflow: hidden;
}

summary {
    position: relative;
    display: flex;
    min-height: 3.5rem;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-md);
    padding: var(--space-md) var(--space-lg);
    color: var(--foreground);
    font-family: var(--font-display);
    font-weight: 800;
    letter-spacing: 0.02em;
    cursor: pointer;
    list-style: none;
}

summary::-webkit-details-marker {
    display: none;
}

.faq-icon,
summary::after {
    content: "+";
    display: inline-grid;
    width: 1.75rem;
    height: 1.75rem;
    flex: 0 0 auto;
    place-items: center;
    border-radius: 50%;
    background: rgba(212, 160, 23, 0.16);
    color: var(--gold-soft);
    font-family: var(--font-display);
    font-weight: 900;
}

.faq-icon {
    display: none;
}

details[open] {
    border-color: rgba(255, 45, 85, 0.48);
    box-shadow: var(--shadow-red);
}

details[open] summary::after {
    content: "-";
}

.faq-answer,
details > :not(summary) {
    padding: 0 var(--space-lg) var(--space-lg);
    color: var(--muted-foreground);
}

/* ============================================
   CTA BANNER - Full-width conversion strip
   ============================================ */

.cta-banner {
    position: relative;
    margin-block: var(--space-3xl);
    padding-block: var(--space-3xl);
    background:
        linear-gradient(110deg, rgba(7, 9, 13, 0.96), rgba(24, 32, 48, 0.92)),
        radial-gradient(circle at 80% 20%, rgba(224, 0, 42, 0.30), transparent 24rem);
    border-block: 1px solid rgba(255, 255, 255, 0.10);
}

.cta-banner-inner {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: var(--space-xl);
    align-items: center;
    text-align: center;
}

.cta-copy p {
    max-width: 64ch;
    margin-inline: auto;
    color: var(--muted-foreground);
}

.cta-actions {
    display: grid;
    justify-items: center;
    gap: var(--space-xs);
}

/* ============================================
   BADGES & SOCIAL PROOF - Trust rows and reviews
   ============================================ */

.trust-badges,
.provider-badges,
.payment-badges {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-sm);
    align-items: center;
    justify-content: center;
    margin-block: var(--space-lg);
}

.badge,
.payment-badge,
.provider-badge {
    display: inline-flex;
    min-height: 2.75rem;
    align-items: center;
    justify-content: center;
    padding: 0.55rem 0.9rem;
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: var(--radius-pill);
    background: rgba(255, 255, 255, 0.045);
    color: var(--muted-foreground);
    font-weight: 800;
    filter: grayscale(0.25);
    transition: filter var(--transition-fast), border-color var(--transition-fast), color var(--transition-fast);
}

.badge:hover,
.payment-badge:hover,
.provider-badge:hover {
    border-color: rgba(255, 45, 85, 0.45);
    color: var(--foreground);
    filter: grayscale(0);
}

.social-proof-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: var(--space-lg);
}

.rating-stars {
    display: inline-flex;
    gap: 0.15rem;
    color: var(--gold-soft);
    font-size: 1.05rem;
}

/* ============================================
   FOOTER - Internal links, payments, license cues
   ============================================ */

.site-footer {
    padding-top: var(--space-3xl);
    background: #07090d;
    border-top: 1px solid rgba(255, 255, 255, 0.10);
}

.footer-inner {
    width: min(100% - 2rem, var(--container));
    margin-inline: auto;
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: var(--space-xl);
}

.footer-brand {
    display: flex;
    gap: var(--space-md);
}

.footer-logo-mark {
    display: inline-grid;
    width: 3.25rem;
    height: 3.25rem;
    flex: 0 0 auto;
    place-items: center;
    border-radius: var(--radius-sm);
    background: linear-gradient(135deg, var(--red), #7c0018);
    color: var(--primary-foreground);
    font-family: var(--font-display);
    font-weight: 900;
    box-shadow: var(--shadow-red);
}

.footer-title {
    margin-bottom: var(--space-xs);
    color: var(--foreground);
    font-family: var(--font-display);
    font-weight: 900;
    text-transform: uppercase;
}

.site-footer h2 {
    margin-bottom: var(--space-sm);
    font-size: 1rem;
}

.site-footer p,
.site-footer li {
    color: var(--muted-foreground);
    font-size: 0.95rem;
}

.footer-nav ul,
.payment-mini-list {
    margin: 0;
    padding: 0;
    list-style: none;
}

.footer-nav a {
    display: inline-flex;
    min-height: 2.25rem;
    align-items: center;
    color: var(--muted-foreground);
    text-decoration: none;
}

.footer-nav a:hover {
    color: var(--gold-soft);
}

.payment-mini-list {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-xs);
}

.payment-mini-list li {
    padding: 0.35rem 0.6rem;
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: var(--radius-pill);
    background: rgba(255, 255, 255, 0.04);
    color: var(--foreground);
    font-weight: 800;
}

.age-badge {
    display: inline-grid;
    width: 3rem;
    height: 3rem;
    place-items: center;
    border: 2px solid var(--red-hot);
    border-radius: 50%;
    color: var(--foreground) !important;
    font-family: var(--font-display);
    font-weight: 900;
}

.footer-bottom {
    margin-top: var(--space-2xl);
    padding: var(--space-md);
    border-top: 1px solid rgba(255, 255, 255, 0.08);
    text-align: center;
}

/* ============================================
   ANIMATIONS - Fast fade-up, reduced-motion safe
   ============================================ */

.animate-on-scroll {
    opacity: 0;
    transform: translateY(1rem);
    transition: opacity 520ms ease-out, transform 520ms ease-out;
}

.animate-on-scroll.is-visible {
    opacity: 1;
    transform: translateY(0);
}

/* ============================================
   RESPONSIVE - Mobile first enhancements
   ============================================ */

@media (min-width: 768px) {
    body {
        font-size: 1.0625rem;
    }

    .section {
        padding-block: var(--space-4xl);
    }

    .grid-2 {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .grid-3 {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .grid-4 {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .stat-highlight-row {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .social-proof-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .cta-banner-inner {
        grid-template-columns: minmax(0, 1.35fr) minmax(16rem, 0.65fr);
        text-align: left;
    }

    .cta-copy p {
        margin-inline: 0;
    }

    .footer-inner {
        grid-template-columns: 1.4fr 1fr 1fr 1fr;
    }
}

@media (min-width: 900px) {
    .site-header {
        background: rgba(11, 13, 16, 0.86);
        backdrop-filter: blur(16px);
        -webkit-backdrop-filter: blur(16px);
    }

    .mobile-menu-toggle {
        display: none;
    }

    .primary-nav {
        display: flex;
        flex: 1;
        align-items: center;
        justify-content: space-between;
        gap: var(--space-lg);
        min-width: 0;
    }

    .nav-list {
        flex-direction: row;
        align-items: center;
        overflow-x: auto;
    }

    .nav-list li {
        flex-shrink: 0;
    }

    .nav-list a::after {
        content: "";
        position: absolute;
        right: var(--space-md);
        bottom: 0.35rem;
        left: var(--space-md);
        height: 0.125rem;
        border-radius: var(--radius-pill);
        background: var(--red-hot);
        transform: scaleX(0);
        transform-origin: left;
        transition: transform var(--transition-fast);
    }

    .nav-list a:hover::after {
        transform: scaleX(1);
    }

    .header-actions {
        flex-direction: row;
        flex-shrink: 0;
    }
}

@media (min-width: 1024px) {
    .hero-grid {
        grid-template-columns: minmax(0, 1.02fr) minmax(22rem, 0.98fr);
    }

    .grid-4 {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }

    .card,
    .info-card,
    .feature-card,
    .review-card,
    .summary-box,
    .tldr-box,
    .callout {
        padding: var(--space-xl);
    }
}

@media (min-width: 1280px) {
    .container,
    .header-inner,
    .footer-inner {
        width: min(100% - 3rem, var(--container));
    }
}

@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        scroll-behavior: auto !important;
        transition-duration: 1ms !important;
        animation-duration: 1ms !important;
        animation-iteration-count: 1 !important;
    }

    .animate-on-scroll {
        opacity: 1;
        transform: none;
    }
}