/* ============================================
   ICE FISHING CASINO - Arctic Manga Design System
   Dark-first, mobile-first, icy-blue + frost-navy + ember-red
   ============================================ */

/* ---- Reset / Safety ---- */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body {
    margin: 0;
    font-family: var(--font-body);
    font-size: 16px;
    line-height: 1.6;
    color: var(--foreground);
    background: var(--background);
    background-image:
        radial-gradient(1000px 600px at 10% -10%, rgba(0,207,255,.10), transparent 60%),
        radial-gradient(800px 600px at 120% 10%, rgba(255,69,0,.08), transparent 60%),
        linear-gradient(180deg, #0a1628 0%, #0b1a30 100%);
    min-height: 100vh;
    overflow-x: hidden;
}

img, video, iframe, svg { max-width: 100%; height: auto; display: block; }
[class*="grid"] > *, [class*="flex"] > * { min-width: 0; }
pre, code { max-width: 100%; overflow-x: auto; }
table { border-collapse: collapse; width: 100%; }
p, li, td, th { overflow-wrap: break-word; }
input, textarea, select { max-width: 100%; box-sizing: border-box; }
section { overflow: clip; position: relative; }

a { color: var(--primary); text-decoration: none; }
a:hover { color: #7fe6ff; }
a:focus-visible, button:focus-visible, summary:focus-visible {
    outline: 2px solid var(--primary);
    outline-offset: 3px;
    border-radius: 4px;
}

.skip-link {
    position: absolute; left: -9999px; top: 0;
    background: var(--accent); color: #fff; padding: 10px 16px; z-index: 2000;
    font-weight: 700;
}
.skip-link:focus { left: 12px; top: 12px; }

/* ============================================
   TYPOGRAPHY - Bangers display + Noto Sans body
   ============================================ */
h1, h2, h3, h4 {
    font-family: var(--font-display);
    font-weight: 400;
    letter-spacing: 0.02em;
    text-transform: uppercase;
    color: var(--primary);
    line-height: 1.1;
    margin: 0 0 .5em;
    text-shadow: 2px 2px 0 rgba(255,69,0,.35);
}
h1 { font-size: clamp(2.5rem, 6vw + 1rem, 4.5rem); }
h2 { font-size: clamp(1.9rem, 3.5vw + .8rem, 3.25rem); }
h3 { font-size: clamp(1.35rem, 1.2vw + .8rem, 2rem); }
h4 { font-size: clamp(1.1rem, .6vw + .8rem, 1.4rem); color: var(--snow); }
p { margin: 0 0 1.25rem; }
strong { color: var(--snow); font-weight: 700; }
em { color: var(--primary); font-style: normal; font-weight: 600; }

.container { width: 100%; max-width: var(--container); margin: 0 auto; padding: 0 16px; }
@media (min-width: 768px) { .container { padding: 0 24px; } }
@media (min-width: 1024px) { .container { padding: 0 32px; } }

.section { padding: 72px 0; position: relative; }
@media (min-width: 1024px) { .section { padding: 120px 0; } }

.section--tight { padding: 48px 0; }
.section--band {
    background: linear-gradient(180deg, #0a1628 0%, #0f1f3a 100%);
    border-top: 1px solid rgba(0,207,255,.18);
    border-bottom: 1px solid rgba(0,207,255,.18);
}

/* Ice-shard diagonal divider */
.divider-shard {
    height: 24px;
    background: linear-gradient(180deg, transparent 0, rgba(0,207,255,.25) 100%);
    clip-path: polygon(0 0, 8% 100%, 16% 0, 24% 100%, 32% 0, 40% 100%, 48% 0, 56% 100%, 64% 0, 72% 100%, 80% 0, 88% 100%, 96% 0, 100% 100%, 100% 100%, 0 100%);
}

/* Section heading pattern */
.sec-head { text-align: center; margin: 0 auto 40px; max-width: 820px; padding: 0 4px; }
.sec-head__eyebrow {
    display: inline-block; font-family: var(--font-display); color: var(--accent);
    letter-spacing: .12em; font-size: .95rem; margin-bottom: 8px;
    text-shadow: 1px 1px 0 #0a1628;
}
.sec-head__title { margin: 0 0 10px; }
.sec-head__sub { color: var(--muted-foreground); font-size: 1.05rem; margin: 0; }

/* ============================================
   BUTTONS
   ============================================ */
.btn {
    display: inline-flex; align-items: center; justify-content: center; gap: 8px;
    font-family: var(--font-display); font-weight: 400; letter-spacing: .06em;
    text-transform: uppercase; font-size: 1rem;
    padding: 14px 22px; min-height: 48px; border-radius: 10px;
    border: 2px solid transparent; cursor: pointer; transition: transform .25s ease, box-shadow .25s ease, background .25s ease;
    text-decoration: none; text-align: center;
}
.btn--primary {
    background: linear-gradient(180deg, #ff5a1f 0%, #ff4500 100%);
    color: #fff; border-color: #ffb199;
    box-shadow: 0 6px 0 #8a1d00, 0 10px 24px rgba(255,69,0,.35);
}
.btn--primary:hover { transform: translateY(-2px); color: #fff; box-shadow: 0 8px 0 #8a1d00, 0 14px 28px rgba(255,69,0,.5); }
.btn--primary:active { transform: translateY(2px); box-shadow: 0 2px 0 #8a1d00, 0 6px 12px rgba(255,69,0,.3); }
.btn--ghost {
    background: transparent; color: var(--primary); border-color: rgba(0,207,255,.6);
}
.btn--ghost:hover { background: rgba(0,207,255,.1); color: #fff; }
.btn--block { display: flex; width: 100%; }
.btn--xl { font-size: 1.2rem; padding: 18px 32px; min-height: 56px; }

/* Pulse ember glow */
@keyframes ember-pulse {
    0%,100% { box-shadow: 0 6px 0 #8a1d00, 0 10px 24px rgba(255,69,0,.35); }
    50% { box-shadow: 0 6px 0 #8a1d00, 0 12px 36px rgba(255,69,0,.75); }
}
.btn--pulse { animation: ember-pulse 2.4s ease-in-out infinite; }
@media (prefers-reduced-motion: reduce) {
    .btn--pulse { animation: none; }
}

/* ============================================
   HEADER & NAV
   ============================================ */
.site-header {
    position: fixed; top: 0; left: 0; right: 0; z-index: 1000;
    background: rgba(10,22,40,.92);
    border-bottom: 1px solid rgba(0,207,255,.2);
}
@media (min-width: 1024px) {
    .site-header { backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px); background: rgba(10,22,40,.78); }
}
.site-header__inner {
    max-width: var(--container); margin: 0 auto;
    display: flex; align-items: center; justify-content: space-between;
    padding: 10px 16px; min-height: var(--header-h); gap: 12px;
}
@media (min-width: 768px) { .site-header__inner { padding: 12px 24px; } }
@media (min-width: 1024px) { .site-header__inner { padding: 14px 32px; } }

body { padding-top: var(--header-h); }

.brand { display: inline-flex; align-items: center; gap: 10px; text-decoration: none; color: var(--snow); }
.brand__mark { display: inline-flex; filter: drop-shadow(0 0 8px rgba(0,207,255,.4)); }
.brand__text { display: inline-flex; flex-direction: column; line-height: 1; }
.brand__name { font-family: var(--font-display); font-size: 1.15rem; letter-spacing: .04em; color: var(--primary); }
.brand__suffix { font-family: var(--font-display); font-size: .85rem; color: var(--accent); letter-spacing: .18em; }
@media (min-width: 1024px) {
    .brand__name { font-size: 1.4rem; }
    .brand__suffix { font-size: .95rem; }
}

/* Desktop nav */
.site-nav { display: none; }
.site-nav__list { display: flex; gap: 8px; list-style: none; margin: 0; padding: 0; }
.site-nav__list a {
    display: inline-flex; align-items: center; padding: 10px 14px; border-radius: 8px;
    font-family: var(--font-display); letter-spacing: .06em; font-size: 1rem;
    color: var(--snow); text-transform: uppercase;
}
.site-nav__list a:hover { color: var(--primary); background: rgba(0,207,255,.08); }
.site-nav__cta { display: flex; gap: 10px; align-items: center; }
.site-nav__cta .btn { padding: 10px 16px; min-height: 42px; font-size: .95rem; }

@media (min-width: 1024px) {
    .site-nav {
        display: flex; align-items: center; gap: 24px; flex: 1; justify-content: flex-end;
    }
}

/* Hamburger toggle */
.menu-toggle {
    display: inline-flex; flex-direction: column; justify-content: center; gap: 5px;
    width: 48px; height: 48px; border: 1px solid rgba(0,207,255,.4);
    background: rgba(15,31,58,.8); border-radius: 10px; cursor: pointer;
    z-index: 1001; padding: 10px;
}
.menu-toggle span {
    display: block; height: 2px; width: 100%; background: var(--primary);
    transition: transform .3s ease, opacity .3s ease;
}
.menu-toggle[aria-expanded="true"] span:nth-child(1) { transform: translateY(7px) rotate(45deg); background: var(--accent); }
.menu-toggle[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.menu-toggle[aria-expanded="true"] span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); background: var(--accent); }
@media (min-width: 1024px) { .menu-toggle { display: none; } }

/* Mobile drawer */
@media (max-width: 1023px) {
    .site-nav {
        position: fixed; top: var(--header-h); left: 0; right: 0; bottom: 0;
        background: var(--background);
        background-image:
            radial-gradient(600px 400px at 100% 0%, rgba(0,207,255,.18), transparent 60%),
            radial-gradient(600px 400px at 0% 100%, rgba(255,69,0,.12), transparent 60%);
        flex-direction: column; align-items: stretch; gap: 0;
        padding: 24px 20px 40px; overflow-y: auto; z-index: 999;
        transform: translateX(100%); transition: transform .35s cubic-bezier(.2,.8,.2,1);
    }
    .site-nav.is-open { display: flex; transform: translateX(0); }
    .site-nav:not(.is-open) { display: none; }
    .site-nav__list { flex-direction: column; gap: 4px; }
    .site-nav__list a {
        display: flex; min-height: 52px; font-size: 1.3rem;
        border-bottom: 1px solid rgba(0,207,255,.12); border-radius: 0;
    }
    .site-nav__cta { flex-direction: column; margin-top: 20px; gap: 12px; }
    .site-nav__cta .btn { width: 100%; min-height: 52px; font-size: 1.05rem; }
}

/* ============================================
   FOOTER
   ============================================ */
.site-footer {
    background: #06101e; border-top: 2px solid rgba(0,207,255,.25);
    padding: 56px 0 0; margin-top: 72px;
    position: relative;
}
.site-footer::before {
    content: ""; position: absolute; top: -1px; left: 0; right: 0; height: 24px;
    background: linear-gradient(180deg, rgba(0,207,255,.35), transparent);
    clip-path: polygon(0 0, 6% 100%, 12% 0, 18% 100%, 24% 0, 30% 100%, 36% 0, 42% 100%, 48% 0, 54% 100%, 60% 0, 66% 100%, 72% 0, 78% 100%, 84% 0, 90% 100%, 96% 0, 100% 100%, 100% 100%, 0 100%);
    pointer-events: none;
}
.site-footer__inner {
    max-width: var(--container); margin: 0 auto; padding: 0 16px;
    display: grid; grid-template-columns: 1fr; gap: 32px;
}
@media (min-width: 768px) { .site-footer__inner { grid-template-columns: 1.4fr 1fr 1fr 1fr; padding: 0 24px; gap: 40px; } }
@media (min-width: 1024px) { .site-footer__inner { padding: 0 32px; } }

.site-footer__heading {
    font-family: var(--font-display); font-size: 1.15rem; letter-spacing: .08em;
    color: var(--primary); margin: 0 0 14px; text-transform: uppercase;
}
.site-footer__links { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 8px; }
.site-footer__links a { color: var(--snow); font-size: .98rem; }
.site-footer__links a:hover { color: var(--primary); }
.site-footer__tagline { color: var(--muted-foreground); font-size: .95rem; margin-top: 8px; }
.site-footer__note { color: var(--muted-foreground); font-size: .85rem; margin-top: 10px; }

.pay-list { list-style: none; margin: 0; padding: 0; display: flex; flex-wrap: wrap; gap: 8px; }
.pay-chip {
    display: inline-flex; align-items: center; padding: 6px 12px; min-height: 32px;
    background: rgba(15,31,58,.9); color: var(--snow);
    border: 1px solid rgba(0,207,255,.3); border-radius: 6px;
    font-size: .85rem; font-weight: 600;
}
.seal {
    display: inline-flex; align-items: center; justify-content: center;
    padding: 6px 10px; min-height: 32px; background: rgba(255,69,0,.12);
    border: 1px solid rgba(255,69,0,.5); color: var(--snow);
    font-family: var(--font-display); letter-spacing: .08em; font-size: .85rem;
    border-radius: 6px;
}
.seal--mga { background: rgba(0,207,255,.12); border-color: rgba(0,207,255,.5); color: var(--primary); }
.seal--age { background: var(--accent); color: #fff; border-color: #fff; }

.site-footer__bottom {
    margin-top: 40px; padding: 20px 16px;
    border-top: 1px solid rgba(0,207,255,.15);
    color: var(--muted-foreground); font-size: .85rem;
    text-align: center;
}
.site-footer__bottom p { margin: 4px 0; }

/* ============================================
   GAME CARD
   ============================================ */
.game-card {
    position: relative;
    background: linear-gradient(180deg, #0f1f3a 0%, #0a1628 100%);
    border: 1px solid rgba(0,207,255,.3);
    border-radius: var(--radius);
    overflow: hidden;
    transition: transform .3s ease, box-shadow .3s ease, border-color .3s ease;
    display: flex; flex-direction: column;
    box-shadow: 0 6px 24px rgba(0,0,0,.35);
}
.game-card:hover {
    transform: rotate(-2deg) translateY(-4px);
    border-color: var(--primary);
    box-shadow: 0 14px 36px rgba(0,207,255,.28);
}
.game-card--featured { border-color: var(--accent); box-shadow: 0 10px 34px rgba(255,69,0,.28); }
.game-card__media {
    position: relative; aspect-ratio: 16/10; overflow: hidden;
    background: radial-gradient(circle at 30% 40%, #173258 0%, #081225 80%);
}
.game-card__media img { width: 100%; height: 100%; object-fit: cover; }
.game-card__placeholder {
    width: 100%; height: 100%;
    background:
        radial-gradient(circle at 50% 55%, rgba(255,69,0,.4) 0, transparent 45%),
        radial-gradient(circle at 50% 55%, rgba(0,207,255,.25) 0, transparent 60%),
        linear-gradient(180deg, #0f1f3a, #0a1628);
    position: relative;
}
.mascot-silhouette {
    position: absolute; inset: 15% 20%;
    background: radial-gradient(ellipse, #ff4500 0, #8a1d00 60%, transparent 72%);
    clip-path: polygon(0 50%, 22% 22%, 60% 20%, 78% 30%, 100% 18%, 92% 50%, 100% 82%, 78% 70%, 60% 80%, 22% 78%);
    filter: drop-shadow(0 0 18px rgba(255,69,0,.5));
}
.speed-lines {
    position: absolute; inset: 0; pointer-events: none;
    background:
        repeating-linear-gradient(115deg, transparent 0 14px, rgba(255,255,255,.06) 14px 15px),
        repeating-linear-gradient(115deg, transparent 0 34px, rgba(0,207,255,.14) 34px 36px);
    mix-blend-mode: screen;
}
.ribbon {
    position: absolute; top: 12px; left: -6px; padding: 6px 14px;
    background: var(--accent); color: #fff; font-family: var(--font-display);
    letter-spacing: .1em; font-size: .85rem; border-radius: 4px;
    box-shadow: 0 4px 10px rgba(255,69,0,.4);
}
.game-card__body { padding: 20px; display: flex; flex-direction: column; gap: 12px; flex: 1; }
@media (min-width: 1024px) { .game-card__body { padding: 28px; } }
.game-card__title { margin: 0; color: var(--primary); font-size: 1.5rem; }
.game-card__provider {
    margin: -6px 0 0; color: var(--muted-foreground);
    font-size: .85rem; text-transform: uppercase; letter-spacing: .08em;
}
.stat-chips { list-style: none; margin: 0; padding: 0; display: flex; flex-wrap: wrap; gap: 8px; }
.stat-chips li {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 6px 10px; border-radius: 6px;
    background: rgba(10,22,40,.7); border: 1px solid rgba(255,69,0,.5);
    font-size: .82rem;
}
.stat-chips__k { color: var(--muted-foreground); text-transform: uppercase; letter-spacing: .08em; font-size: .72rem; }
.stat-chips__v { color: var(--snow); font-weight: 700; }

/* Game grid */
.game-grid {
    display: grid; grid-template-columns: minmax(0,1fr); gap: 16px;
}
@media (min-width: 768px) { .game-grid { grid-template-columns: repeat(2, minmax(0,1fr)); } }
@media (min-width: 1024px) { .game-grid { grid-template-columns: repeat(3, minmax(0,1fr)); gap: 24px; } }

/* ============================================
   BONUS CARD
   ============================================ */
.bonus-card {
    position: relative; background: linear-gradient(180deg, #0f1f3a 0%, #091327 100%);
    border: 1px solid rgba(0,207,255,.3); border-radius: var(--radius);
    padding: 24px; display: flex; flex-direction: column; gap: 12px;
    overflow: hidden;
    box-shadow: 0 8px 28px rgba(0,0,0,.4);
    transition: transform .3s ease, box-shadow .3s ease;
}
.bonus-card:hover { transform: translateY(-4px); box-shadow: 0 14px 34px rgba(0,207,255,.28); }
.bonus-card--orange { border-color: rgba(255,140,0,.5); }
.bonus-card--red { border-color: rgba(255,69,0,.6); }
.bonus-card__shard {
    position: absolute; top: 0; left: 0; right: 0; height: 16px;
    background: linear-gradient(180deg, rgba(0,207,255,.45), transparent);
    clip-path: polygon(0 0, 10% 100%, 20% 0, 30% 100%, 40% 0, 50% 100%, 60% 0, 70% 100%, 80% 0, 90% 100%, 100% 0, 100% 100%, 0 100%);
    pointer-events: none;
}
.bonus-card--orange .bonus-card__shard { background: linear-gradient(180deg, rgba(255,140,0,.5), transparent); }
.bonus-card--red .bonus-card__shard { background: linear-gradient(180deg, rgba(255,69,0,.55), transparent); }
.bonus-card__media { margin: 4px -8px 0; aspect-ratio: 3/2; border-radius: 10px; overflow: hidden; }
.bonus-card__media img { width: 100%; height: 100%; object-fit: cover; }
.bonus-card__amount {
    display: flex; align-items: baseline; gap: 6px; margin-top: 8px;
}
.bonus-card__amount-num {
    font-family: var(--font-display); color: var(--primary);
    font-size: clamp(3rem, 8vw + 1rem, 5.5rem); line-height: .9;
    -webkit-text-stroke: 2px var(--accent);
    text-shadow: 3px 3px 0 rgba(255,69,0,.35);
}
.bonus-card__amount-unit { font-family: var(--font-display); color: var(--snow); font-size: 1.4rem; }
.bonus-card__headline { margin: 0; font-size: 1.35rem; color: var(--snow); }
.bonus-card__subtitle { margin: 0; color: var(--muted-foreground); font-size: .95rem; }
.bonus-card__bullets { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 6px; }
.bonus-card__bullets li {
    position: relative; padding-left: 22px; color: var(--snow); font-size: .95rem;
}
.bonus-card__bullets li::before {
    content: "❄"; position: absolute; left: 0; top: 0; color: var(--primary); font-size: 1rem;
}
.bonus-card__code {
    display: inline-flex; align-items: center; gap: 8px;
    padding: 8px 12px; border: 1px dashed var(--primary); border-radius: 8px;
    background: rgba(0,207,255,.08); width: fit-content;
}
.bonus-card__code-label { color: var(--muted-foreground); font-size: .8rem; text-transform: uppercase; letter-spacing: .1em; }
.bonus-card__code-val { font-family: var(--font-display); color: var(--accent); font-size: 1.1rem; letter-spacing: .08em; }
.bonus-card__disclaimer { margin: 6px 0 0; color: var(--muted-foreground); font-size: .78rem; line-height: 1.4; }

.snow-dot {
    position: absolute; width: 6px; height: 6px; border-radius: 50%;
    background: var(--snow); opacity: .7;
    box-shadow: 0 0 8px var(--primary); pointer-events: none;
    animation: snow-drift 6s linear infinite;
}
.snow-dot--a { top: 20%; left: 8%; animation-delay: -1s; }
.snow-dot--b { top: 50%; right: 10%; animation-delay: -3s; }
.snow-dot--c { bottom: 12%; left: 30%; animation-delay: -5s; }
@keyframes snow-drift {
    0% { transform: translateY(-6px); opacity: 0; }
    20% { opacity: .8; }
    100% { transform: translateY(30px); opacity: 0; }
}

/* Bonus grid */
.bonus-grid { display: grid; grid-template-columns: minmax(0,1fr); gap: 20px; }
@media (min-width: 768px) { .bonus-grid { grid-template-columns: repeat(2, minmax(0,1fr)); } }
@media (min-width: 1024px) { .bonus-grid--3 { grid-template-columns: repeat(3, minmax(0,1fr)); } }

/* ============================================
   CTA BANNER
   ============================================ */
.cta-banner {
    position: relative;
    background:
        radial-gradient(600px 400px at 20% 50%, rgba(0,207,255,.18), transparent 70%),
        radial-gradient(500px 380px at 85% 40%, rgba(255,69,0,.22), transparent 65%),
        linear-gradient(135deg, #0a1628 0%, #0f1f3a 100%);
    border-top: 1px solid rgba(0,207,255,.25);
    border-bottom: 1px solid rgba(0,207,255,.25);
    padding: 56px 0;
    overflow: hidden;
}
@media (min-width: 1024px) { .cta-banner { padding: 96px 0; } }
.cta-banner__lines {
    position: absolute; inset: 0; pointer-events: none;
    background:
        repeating-linear-gradient(110deg, transparent 0 40px, rgba(255,255,255,.04) 40px 42px),
        repeating-linear-gradient(110deg, transparent 0 100px, rgba(0,207,255,.1) 100px 102px);
}
.cta-banner__inner {
    max-width: var(--container); margin: 0 auto; padding: 0 16px;
    display: grid; grid-template-columns: 1fr; gap: 32px; align-items: center;
    position: relative;
}
@media (min-width: 768px) { .cta-banner__inner { padding: 0 24px; } }
@media (min-width: 1024px) { .cta-banner__inner { grid-template-columns: 1fr 1fr; padding: 0 32px; gap: 48px; } }
.cta-banner__art { position: relative; order: -1; min-height: 240px; }
@media (min-width: 1024px) { .cta-banner__art { order: 0; min-height: 420px; } }
.cta-banner__art img { width: 100%; height: 100%; object-fit: contain; max-height: 480px; }
.cta-banner__mascot {
    position: absolute; inset: 0;
    background:
        radial-gradient(closest-side at 55% 60%, rgba(255,69,0,.85) 0%, rgba(255,69,0,.4) 40%, transparent 70%),
        radial-gradient(closest-side at 55% 60%, rgba(0,207,255,.4) 50%, transparent 80%);
    filter: drop-shadow(0 10px 40px rgba(255,69,0,.5));
}
.cta-banner__mascot::after {
    content: ""; position: absolute; inset: 20% 15% 15% 15%;
    background: radial-gradient(ellipse, #ff4500 10%, #8a1d00 60%, transparent 74%);
    clip-path: polygon(5% 50%, 22% 22%, 55% 18%, 75% 30%, 100% 12%, 90% 50%, 100% 88%, 75% 70%, 55% 82%, 22% 78%);
}
.ice-shards {
    position: absolute; inset: 0; pointer-events: none;
    background:
        linear-gradient(60deg, transparent 48%, rgba(232,244,255,.35) 49%, transparent 51%) 10% 30% / 80px 80px no-repeat,
        linear-gradient(-40deg, transparent 48%, rgba(232,244,255,.3) 49%, transparent 51%) 70% 70% / 120px 120px no-repeat,
        linear-gradient(20deg, transparent 48%, rgba(0,207,255,.4) 49%, transparent 51%) 40% 10% / 100px 100px no-repeat;
}
.cta-banner__headline { margin: 0 0 12px; font-size: clamp(2rem, 4vw + 1rem, 3.4rem); }
.cta-banner__subtitle { color: var(--snow); margin: 0 0 20px; font-size: 1.1rem; max-width: 52ch; }
.cta-banner__microcopy { color: var(--muted-foreground); font-size: .82rem; margin: 12px 0 0; }

/* ============================================
   FAQ ACCORDION
   ============================================ */
.faq { display: flex; flex-direction: column; gap: 10px; max-width: 860px; margin: 0 auto; }
.faq__item {
    background: linear-gradient(180deg, #0f1f3a, #0b1a30);
    border: 1px solid rgba(0,207,255,.2);
    border-left: 4px solid var(--primary);
    border-radius: 10px;
    overflow: hidden;
}
.faq__summary {
    list-style: none; cursor: pointer;
    display: flex; align-items: center; justify-content: space-between; gap: 16px;
    padding: 18px 20px; min-height: 56px;
}
.faq__summary::-webkit-details-marker { display: none; }
.faq__q {
    font-family: var(--font-display); color: var(--primary);
    font-size: 1.1rem; letter-spacing: .04em; text-transform: uppercase; line-height: 1.2;
}
.faq__icon {
    flex-shrink: 0; position: relative; width: 28px; height: 28px;
    background: rgba(255,69,0,.15); border: 1px solid var(--accent); border-radius: 50%;
    transition: transform .3s ease;
}
.faq__icon::before, .faq__icon::after {
    content: ""; position: absolute; background: var(--accent);
    left: 50%; top: 50%; transform: translate(-50%, -50%);
}
.faq__icon::before { width: 12px; height: 2px; }
.faq__icon::after { width: 2px; height: 12px; transition: transform .3s ease; }
.faq__item[open] .faq__icon { transform: rotate(180deg); }
.faq__item[open] .faq__icon::after { transform: translate(-50%, -50%) scaleY(0); }
.faq__answer {
    padding: 0 20px 20px; color: var(--snow); background: rgba(15,31,58,.6);
    border-top: 1px solid rgba(0,207,255,.14);
}
.faq__answer p { margin: 16px 0 0; line-height: 1.65; font-size: 1rem; }
.faq__answer ul, .faq__answer ol { margin: 12px 0 0; padding-left: 22px; color: var(--snow); }
.faq__answer li { margin-bottom: 6px; }

/* ============================================
   COMPARISON TABLE
   ============================================ */
.table-wrapper {
    max-width: 100%; overflow-x: auto; min-width: 0;
    border-radius: var(--radius); border: 1px solid rgba(0,207,255,.25);
    background: #0b1a30;
    position: relative;
}
.cmp-table {
    width: 100%; border-collapse: collapse; min-width: 600px;
    color: var(--snow);
}
.cmp-table__caption {
    caption-side: top; text-align: left; padding: 16px 20px;
    font-family: var(--font-display); color: var(--primary); font-size: 1.2rem;
    letter-spacing: .06em; text-transform: uppercase;
}
.cmp-table thead th {
    background: linear-gradient(180deg, #123258, #0a1e3a);
    font-family: var(--font-display); text-transform: uppercase; letter-spacing: .08em;
    color: var(--primary); font-weight: 400; font-size: 1rem;
    padding: 14px 14px; text-align: left;
    border-bottom: 2px solid rgba(0,207,255,.35);
}
.cmp-table tbody td, .cmp-table tbody th {
    padding: 14px; border-bottom: 1px solid rgba(0,207,255,.12);
    font-size: .95rem; vertical-align: top; text-align: left; font-weight: 500;
}
.cmp-table tbody tr:nth-child(even) { background: rgba(15,31,58,.5); }
.cmp-table__row--rec {
    background: linear-gradient(90deg, rgba(255,69,0,.14), rgba(255,69,0,.04)) !important;
    box-shadow: inset 4px 0 0 var(--accent);
}
.cmp-table__row--rec th, .cmp-table__row--rec td { color: var(--snow); font-weight: 600; }

@media (max-width: 767px) {
    .cmp-table { min-width: 0; }
    .cmp-table thead { display: none; }
    .cmp-table, .cmp-table tbody, .cmp-table tr, .cmp-table td, .cmp-table th { display: block; width: 100%; }
    .cmp-table tr {
        margin-bottom: 16px; padding: 12px; border-radius: 10px;
        background: #0f1f3a !important; border: 1px solid rgba(0,207,255,.2);
    }
    .cmp-table__row--rec { border-color: var(--accent) !important; box-shadow: 0 0 0 1px var(--accent); }
    .cmp-table td, .cmp-table th {
        display: flex; justify-content: space-between; gap: 12px; text-align: right;
        padding: 8px 4px; border-bottom: 1px dashed rgba(0,207,255,.14);
    }
    .cmp-table td::before, .cmp-table th::before {
        content: attr(data-label); font-family: var(--font-display);
        color: var(--primary); letter-spacing: .06em; text-transform: uppercase;
        text-align: left; flex: 0 0 40%;
    }
    .cmp-table tr td:last-child { border-bottom: none; }
}

/* ============================================
   STAT BLOCK
   ============================================ */
.stat-row {
    display: grid; grid-template-columns: minmax(0,1fr); gap: 16px;
}
@media (min-width: 768px) { .stat-row { grid-template-columns: repeat(2, minmax(0,1fr)); } }
@media (min-width: 1024px) { .stat-row { grid-template-columns: repeat(4, minmax(0,1fr)); } }
.stat-tile {
    position: relative; padding: 24px 20px; text-align: center;
    background: linear-gradient(180deg, #0f1f3a, #091327);
    border: 1px solid rgba(0,207,255,.25); border-radius: var(--radius);
    overflow: hidden;
}
.stat-tile__shard {
    position: absolute; top: -12px; right: -12px; width: 60px; height: 60px;
    background: linear-gradient(135deg, rgba(0,207,255,.3), transparent);
    clip-path: polygon(100% 0, 100% 100%, 0 0);
}
.stat-tile__num {
    display: block; font-family: var(--font-display); color: var(--primary);
    font-size: clamp(3.5rem, 6vw + 1rem, 7rem); line-height: 1;
    -webkit-text-stroke: 2px var(--accent);
    text-shadow: 3px 3px 0 rgba(255,69,0,.3);
    margin-bottom: 8px;
}
.stat-tile__label { display: block; color: var(--snow); font-weight: 600; font-size: 1.05rem; }
.stat-tile__src { display: block; color: var(--muted-foreground); font-size: .8rem; margin-top: 4px; }

/* ============================================
   PAYMENT TRUST STRIP
   ============================================ */
.trust-strip {
    display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: 16px;
    padding: 18px 16px;
    background: #08111f;
    border-top: 1px solid rgba(0,207,255,.25);
    border-bottom: 1px solid rgba(0,207,255,.25);
    position: relative;
}
.trust-strip__pays, .trust-strip__seals {
    list-style: none; margin: 0; padding: 0;
    display: flex; flex-wrap: wrap; gap: 10px; justify-content: center;
}
.trust-strip__chip {
    display: inline-flex; align-items: center; padding: 8px 14px; min-height: 44px;
    background: rgba(15,31,58,.95); color: var(--snow);
    border: 1px solid rgba(0,207,255,.35); border-radius: 8px;
    font-size: .88rem; font-weight: 600; letter-spacing: .02em;
}
.trust-strip__seal {
    display: inline-flex; align-items: center; padding: 8px 12px; min-height: 44px;
    background: rgba(255,69,0,.12); border: 1px solid rgba(255,69,0,.5);
    color: var(--snow); font-family: var(--font-display); letter-spacing: .08em;
    border-radius: 8px; font-size: .88rem;
}
.trust-strip__divider {
    display: block; width: 1px; height: 28px; background: rgba(0,207,255,.5);
}
@media (max-width: 767px) {
    .trust-strip__divider { display: none; }
    .trust-strip { gap: 12px; }
}

/* ============================================
   PAGE TILE (internal link navigator)
   ============================================ */
.page-tile {
    display: flex; flex-direction: column; gap: 12px;
    background: linear-gradient(180deg, #0f1f3a, #091327);
    border: 1px solid rgba(0,207,255,.3);
    border-radius: var(--radius); overflow: hidden;
    color: var(--snow); text-decoration: none;
    transition: transform .3s ease, border-color .3s ease, box-shadow .3s ease;
}
.page-tile:hover { transform: translateY(-4px) rotate(-1deg); border-color: var(--primary); box-shadow: 0 14px 36px rgba(0,207,255,.25); color: var(--snow); }
.page-tile--orange:hover { border-color: #ff8c00; box-shadow: 0 14px 36px rgba(255,140,0,.3); }
.page-tile--red:hover { border-color: var(--accent); box-shadow: 0 14px 36px rgba(255,69,0,.3); }
.page-tile__media {
    aspect-ratio: 3/2; position: relative;
    background:
        radial-gradient(circle at 50% 55%, rgba(255,69,0,.35) 0, transparent 55%),
        linear-gradient(180deg, #123258, #0a1628);
    overflow: hidden;
}
.page-tile__media img { width: 100%; height: 100%; object-fit: cover; }
.page-tile__glyph {
    position: absolute; inset: 25% 30%;
    background: radial-gradient(ellipse, #ff4500 10%, transparent 74%);
    filter: drop-shadow(0 0 16px rgba(255,69,0,.5));
    clip-path: polygon(0 50%, 25% 25%, 60% 22%, 80% 32%, 100% 18%, 90% 50%, 100% 82%, 80% 68%, 60% 78%, 25% 75%);
}
.page-tile__body { padding: 18px 20px 22px; display: flex; flex-direction: column; gap: 8px; }
.page-tile__title {
    margin: 0; font-family: var(--font-display); color: var(--primary);
    font-size: 1.3rem; letter-spacing: .04em;
}
.page-tile__desc { margin: 0; color: var(--muted-foreground); font-size: .95rem; line-height: 1.5; }
.page-tile__cta {
    margin-top: auto; font-family: var(--font-display); color: var(--accent);
    letter-spacing: .06em; text-transform: uppercase; font-size: .95rem;
}

.tile-grid { display: grid; grid-template-columns: minmax(0,1fr); gap: 16px; }
@media (min-width: 768px) { .tile-grid { grid-template-columns: repeat(2, minmax(0,1fr)); } }
@media (min-width: 1024px) { .tile-grid--4 { grid-template-columns: repeat(4, minmax(0,1fr)); } .tile-grid--3 { grid-template-columns: repeat(3, minmax(0,1fr)); } }

/* ============================================
   GENERIC ENGAGEMENT PATTERNS
   ============================================ */

/* TL;DR summary */
.tldr {
    border-left: 4px solid var(--primary);
    background: linear-gradient(90deg, rgba(0,207,255,.08), transparent);
    padding: 20px 22px; border-radius: 0 12px 12px 0;
    margin: 28px 0;
}
.tldr__label {
    display: inline-block; font-family: var(--font-display); color: var(--accent);
    letter-spacing: .1em; font-size: .9rem; margin-bottom: 6px;
}
.tldr p { margin: 0; color: var(--snow); font-size: 1.02rem; }

/* Callout */
.callout {
    padding: 18px 20px; border-radius: 12px; border: 1px solid rgba(255,69,0,.5);
    background: linear-gradient(180deg, rgba(255,69,0,.08), transparent);
    margin: 24px 0;
}
.callout--tip { border-color: rgba(0,207,255,.5); background: linear-gradient(180deg, rgba(0,207,255,.08), transparent); }
.callout__title {
    font-family: var(--font-display); color: var(--accent); letter-spacing: .06em;
    font-size: 1.1rem; margin: 0 0 6px; text-transform: uppercase;
}
.callout--tip .callout__title { color: var(--primary); }
.callout p:last-child { margin-bottom: 0; }

/* Pull quote */
.pull-quote {
    margin: 32px 0; padding: 24px 24px 20px; border-radius: 12px;
    background: linear-gradient(135deg, rgba(0,207,255,.1), rgba(255,69,0,.08));
    border: 1px solid rgba(0,207,255,.25);
    transform: rotate(-.6deg);
}
.pull-quote blockquote {
    margin: 0; font-family: var(--font-display); color: var(--primary);
    font-size: clamp(1.4rem, 2vw + 1rem, 2rem); line-height: 1.25;
    letter-spacing: .02em;
}
.pull-quote cite {
    display: block; margin-top: 10px; color: var(--muted-foreground);
    font-style: normal; font-size: .9rem; letter-spacing: .02em;
}

/* Content prose wrapper (SEO body) */
.prose { max-width: 780px; margin: 0 auto; color: var(--snow); font-size: 1.05rem; }
.prose h2 { margin-top: 2.4em; text-align: left; }
.prose h3 { margin-top: 1.8em; color: var(--snow); }
.prose p { line-height: 1.7; }
.prose ul, .prose ol { padding-left: 22px; margin: 0 0 1.4em; }
.prose ul li, .prose ol li { margin-bottom: 8px; line-height: 1.6; }
.prose ul li::marker { color: var(--primary); }
.prose a { color: var(--primary); text-decoration: underline; text-decoration-color: rgba(0,207,255,.4); text-underline-offset: 3px; }
.prose a:hover { color: #fff; text-decoration-color: var(--accent); }
.prose blockquote {
    border-left: 4px solid var(--accent); padding: 8px 0 8px 20px;
    margin: 24px 0; color: var(--snow); font-style: italic;
    background: rgba(255,69,0,.06);
}
.prose table { margin: 20px 0; }
.prose figure { margin: 24px 0; }

/* Two column split */
.split {
    display: grid; grid-template-columns: minmax(0,1fr); gap: 32px; align-items: center;
}
@media (min-width: 1024px) { .split { grid-template-columns: 1fr 1fr; gap: 48px; } }
.split__media { position: relative; border-radius: var(--radius); overflow: hidden; min-height: 280px;
    background: linear-gradient(135deg, #0f1f3a, #0a1628); border: 1px solid rgba(0,207,255,.25); }
.split__media img { width: 100%; height: 100%; object-fit: cover; }
.split__copy h2 { margin-top: 0; }

/* How-to steps */
.steps { display: grid; grid-template-columns: minmax(0,1fr); gap: 16px; counter-reset: step; }
@media (min-width: 768px) { .steps { grid-template-columns: repeat(2, minmax(0,1fr)); } }
@media (min-width: 1024px) { .steps { grid-template-columns: repeat(4, minmax(0,1fr)); } }
.step {
    position: relative; padding: 28px 20px 20px; border-radius: 12px;
    background: linear-gradient(180deg, #0f1f3a, #081226);
    border: 1px solid rgba(0,207,255,.25);
    counter-increment: step;
}
.step::before {
    content: counter(step); position: absolute; top: -20px; left: 16px;
    width: 44px; height: 44px; border-radius: 50%;
    background: var(--accent); color: #fff; display: flex; align-items: center; justify-content: center;
    font-family: var(--font-display); font-size: 1.4rem; border: 3px solid var(--background);
    box-shadow: 0 4px 12px rgba(255,69,0,.4);
}
.step h3 { margin: 6px 0 8px; color: var(--primary); font-size: 1.15rem; }
.step p { margin: 0; color: var(--snow); font-size: .95rem; }

/* Feature grid with icons */
.feature-grid { display: grid; grid-template-columns: minmax(0,1fr); gap: 16px; }
@media (min-width: 768px) { .feature-grid { grid-template-columns: repeat(2, minmax(0,1fr)); } }
@media (min-width: 1024px) { .feature-grid { grid-template-columns: repeat(3, minmax(0,1fr)); } }
.feature {
    padding: 24px; border-radius: 12px;
    background: linear-gradient(180deg, #0f1f3a, #091327);
    border: 1px solid rgba(0,207,255,.25);
    display: flex; flex-direction: column; gap: 10px;
}
.feature__icon {
    width: 52px; height: 52px; border-radius: 12px;
    background: linear-gradient(135deg, rgba(0,207,255,.2), rgba(255,69,0,.15));
    border: 1px solid rgba(0,207,255,.4);
    display: inline-flex; align-items: center; justify-content: center;
    font-size: 1.6rem; color: var(--primary);
}
.feature h3 { margin: 0; color: var(--primary); font-size: 1.15rem; }
.feature p { margin: 0; color: var(--snow); font-size: .95rem; line-height: 1.55; }

/* ============================================
   HERO (shared across pages)
   ============================================ */
.hero {
    position: relative; padding: 48px 0 40px; overflow: hidden;
}
@media (min-width: 1024px) { .hero { padding: 80px 0 72px; } }
.hero::before {
    content: ""; position: absolute; inset: 0; pointer-events: none;
    background:
        radial-gradient(600px 500px at 12% 10%, rgba(0,207,255,.25), transparent 65%),
        radial-gradient(700px 500px at 90% 30%, rgba(255,69,0,.18), transparent 65%),
        repeating-linear-gradient(125deg, transparent 0 60px, rgba(255,255,255,.04) 60px 62px);
}
.hero__grid {
    display: grid; grid-template-columns: minmax(0,1fr); gap: 28px; align-items: center;
    position: relative;
}
@media (min-width: 1024px) { .hero__grid { grid-template-columns: 1.1fr 1fr; gap: 48px; } }
.hero__copy h1 { margin: 0 0 16px; }
.hero__eyebrow {
    display: inline-block; padding: 6px 14px; border-radius: 999px;
    background: rgba(255,69,0,.15); border: 1px solid rgba(255,69,0,.5);
    color: var(--accent); font-family: var(--font-display); letter-spacing: .1em;
    font-size: .85rem; margin-bottom: 14px;
}
.hero__lead { color: var(--snow); font-size: 1.1rem; margin: 0 0 22px; max-width: 54ch; }
.hero__ctas { display: flex; gap: 12px; flex-wrap: wrap; }
.hero__microcopy { color: var(--muted-foreground); font-size: .85rem; margin: 14px 0 0; }
.hero__art {
    position: relative; min-height: 280px; border-radius: 20px;
    background: linear-gradient(160deg, #0f1f3a, #06101e);
    border: 1px solid rgba(0,207,255,.3); overflow: hidden;
}
.hero__art img { width: 100%; height: 100%; object-fit: cover; max-height: 520px; }
.hero__art-placeholder {
    position: absolute; inset: 0;
    background:
        radial-gradient(circle at 55% 58%, rgba(255,69,0,.7) 0, transparent 45%),
        radial-gradient(circle at 55% 58%, rgba(0,207,255,.35) 30%, transparent 70%);
}
.hero__art-placeholder::after {
    content: ""; position: absolute; inset: 18% 12%;
    background: radial-gradient(ellipse, #ff4500 10%, #6b1500 60%, transparent 74%);
    clip-path: polygon(5% 50%, 22% 22%, 55% 18%, 75% 30%, 100% 12%, 90% 50%, 100% 88%, 75% 70%, 55% 82%, 22% 78%);
    filter: drop-shadow(0 12px 30px rgba(255,69,0,.5));
}

/* ============================================
   SNOW PARTICLES - site-wide background
   ============================================ */
.snow-layer {
    position: fixed; inset: 0; pointer-events: none; z-index: 1; overflow: hidden;
}
.snow-layer span {
    position: absolute; top: -10px; color: rgba(232,244,255,.55);
    font-size: 10px; animation: snowfall linear infinite;
    text-shadow: 0 0 6px rgba(0,207,255,.6);
}
@keyframes snowfall {
    0% { transform: translate3d(0,-20px,0); opacity: 0; }
    10% { opacity: .8; }
    100% { transform: translate3d(var(--dx,20px), 110vh, 0); opacity: 0; }
}
@media (prefers-reduced-motion: reduce) {
    .snow-layer { display: none; }
}

/* ============================================
   SCROLL ANIMATIONS - freeze/thaw reveal
   ============================================ */
.animate-on-scroll {
    opacity: 0; transform: translateY(24px) scale(.98);
    filter: blur(4px);
    transition: opacity .7s ease, transform .7s cubic-bezier(.2,.8,.2,1), filter .7s ease;
}
.animate-on-scroll.is-visible {
    opacity: 1; transform: translateY(0) scale(1); filter: blur(0);
}
@media (prefers-reduced-motion: reduce) {
    .animate-on-scroll { opacity: 1; transform: none; filter: none; transition: none; }
}

/* ============================================
   REDIRECT STUB (arctic.html)
   ============================================ */
.redirect-stub {
    min-height: 100vh; display: flex; flex-direction: column;
    align-items: center; justify-content: center; gap: 24px;
    padding: 24px; text-align: center; position: relative; overflow: hidden;
}
.redirect-stub__bg {
    position: absolute; inset: 0; pointer-events: none;
    background:
        radial-gradient(600px 500px at 50% 50%, rgba(0,207,255,.2), transparent 65%),
        radial-gradient(400px 300px at 50% 55%, rgba(255,69,0,.2), transparent 70%);
}
.redirect-stub__silhouette {
    position: absolute; inset: 30% 25%; opacity: .18;
    background: radial-gradient(ellipse, #ff4500, transparent 70%);
    clip-path: polygon(5% 50%, 22% 22%, 55% 18%, 75% 30%, 100% 12%, 90% 50%, 100% 88%, 75% 70%, 55% 82%, 22% 78%);
    filter: blur(4px);
}
.redirect-stub__logo { position: relative; z-index: 1; }
.redirect-stub__title { position: relative; z-index: 1; margin: 0; color: var(--primary); }
.redirect-stub__msg { position: relative; z-index: 1; max-width: 40ch; color: var(--snow); margin: 0; }
.redirect-stub__dots { position: relative; z-index: 1; display: inline-flex; gap: 8px; }
.redirect-stub__dots span {
    width: 12px; height: 12px; border-radius: 50%; background: var(--primary);
    animation: dot-pulse 1.4s ease-in-out infinite;
}
.redirect-stub__dots span:nth-child(2) { animation-delay: .2s; background: #5fe0ff; }
.redirect-stub__dots span:nth-child(3) { animation-delay: .4s; background: var(--accent); }
@keyframes dot-pulse {
    0%,100% { transform: scale(.7); opacity: .4; }
    50% { transform: scale(1.2); opacity: 1; }
}