/* ringworld.quest v2
   Coastal-blend palette + glassmorphism + leather + retro-pattern + bebas-bold
   Split-screen explorer's field log
*/

:root {
    /* Coastal blend palette */
    --ocean-deep: #1B4965;
    --ocean-deep-dark: #143247;
    --reef-teal: #5FA8D3;
    --reef-teal-soft: rgba(95, 168, 211, 0.45);
    --sky-aqua: #BEE9E8;
    --sand-warm: #CAD2C5;
    --coral-signal: #E76F51;
    --leather-brown: #6B4226;
    --leather-brown-mid: #8B6240;
    --leather-brown-dark: #4A2E1B;

    /* Glass surfaces */
    --glass-bg: rgba(255, 255, 255, 0.10);
    --glass-bg-hover: rgba(255, 255, 255, 0.14);
    --glass-border: rgba(255, 255, 255, 0.22);
    --glass-shadow: 0 8px 32px rgba(20, 50, 71, 0.25);

    /* Type */
    --font-display: "Bebas Neue", "Impact", sans-serif;
    --font-body: "Work Sans", "Helvetica Neue", sans-serif;
    --font-mono: "Space Mono", "Courier New", monospace;

    /* Layout */
    --section-min-h: 70vh;
    --easing: cubic-bezier(0.4, 0.0, 0.2, 1);
}

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

html {
    scroll-behavior: smooth;
}

body {
    margin: 0;
    padding: 0;
    font-family: var(--font-body);
    color: var(--sand-warm);
    background: linear-gradient(180deg, var(--ocean-deep) 0%, var(--ocean-deep-dark) 100%);
    background-attachment: fixed;
    overflow-x: hidden;
    line-height: 1.75;
    -webkit-font-smoothing: antialiased;
}

/* SVG filter container */
.svg-filters {
    position: absolute;
    width: 0;
    height: 0;
    pointer-events: none;
}

/* ============================================================
   Shared: leather texture
   ============================================================ */
.leather-texture {
    position: relative;
    background:
        radial-gradient(circle at 22% 28%, rgba(139, 98, 64, 0.55) 0%, transparent 38%),
        radial-gradient(circle at 78% 64%, rgba(74, 46, 27, 0.6) 0%, transparent 42%),
        radial-gradient(circle at 56% 88%, rgba(139, 98, 64, 0.4) 0%, transparent 36%),
        linear-gradient(135deg, var(--leather-brown-dark) 0%, var(--leather-brown) 50%, var(--leather-brown-mid) 100%);
    overflow: hidden;
}

.leather-texture::before {
    content: '';
    position: absolute;
    inset: 0;
    background:
        repeating-linear-gradient(38deg,
            transparent 0,
            transparent 4px,
            rgba(0, 0, 0, 0.08) 4px,
            rgba(0, 0, 0, 0.08) 5px),
        repeating-linear-gradient(-52deg,
            transparent 0,
            transparent 6px,
            rgba(255, 255, 255, 0.04) 6px,
            rgba(255, 255, 255, 0.04) 7px);
    pointer-events: none;
    mix-blend-mode: overlay;
}

.leather-noise {
    position: absolute;
    inset: 0;
    opacity: 0.45;
    filter: url(#leatherNoise);
    pointer-events: none;
    mix-blend-mode: overlay;
}

/* ============================================================
   Shared: glass panel
   ============================================================ */
.glass-panel {
    position: relative;
    background: var(--glass-bg);
    backdrop-filter: blur(16px) saturate(140%);
    -webkit-backdrop-filter: blur(16px) saturate(140%);
    border: 1px solid var(--glass-border);
    border-radius: 16px;
    box-shadow: var(--glass-shadow);
    transition: background 0.4s var(--easing), transform 0.4s var(--easing), border-color 0.4s var(--easing);
}

.glass-panel:hover {
    background: var(--glass-bg-hover);
    border-color: rgba(255, 255, 255, 0.32);
}

.glass-panel__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1.4rem 1.6rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
}

.glass-panel__title {
    margin: 0;
    font-family: var(--font-display);
    font-size: clamp(20px, 2vw, 28px);
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--sky-aqua);
}

.glass-panel__badge {
    font-family: var(--font-mono);
    font-size: 11px;
    color: var(--coral-signal);
    padding: 4px 10px;
    border: 1px solid var(--coral-signal);
    border-radius: 4px;
    letter-spacing: 0.12em;
}

.glass-panel__footer {
    padding: 0.8rem 1.6rem;
    border-top: 1px solid rgba(255, 255, 255, 0.10);
}

.glass-panel__meta {
    font-family: var(--font-mono);
    font-size: 11px;
    color: rgba(190, 233, 232, 0.7);
}

/* ============================================================
   Shared: section heading & underline
   ============================================================ */
.section-heading {
    position: relative;
    display: inline-block;
    margin: 0 0 1.4rem 0;
    font-family: var(--font-display);
    font-size: clamp(36px, 5.2vw, 64px);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--sky-aqua);
    line-height: 1.05;
}

.section-heading--center {
    display: block;
    text-align: center;
}

.section-heading[data-underline]::after {
    content: '';
    position: absolute;
    left: 0;
    bottom: -6px;
    width: 0;
    height: 3px;
    background: var(--reef-teal);
    transition: width 0.6s var(--easing);
}

.section-heading--center[data-underline]::after {
    left: 50%;
    transform: translateX(-50%);
}

.section-heading.is-underlined::after {
    width: 100%;
}

.section-heading--center.is-underlined::after {
    width: 60%;
}

.body-text {
    margin: 0 0 1.1rem 0;
    font-size: clamp(15px, 1.1vw, 17px);
    color: rgba(202, 210, 197, 0.92);
}

/* ============================================================
   Section 1: The Rim View
   ============================================================ */
.rim-view {
    position: relative;
    display: grid;
    grid-template-columns: 1fr 1fr;
    min-height: 100vh;
    overflow: hidden;
    background: linear-gradient(180deg, var(--ocean-deep) 0%, var(--reef-teal) 60%, var(--sky-aqua) 100%);
}

.rim-view__panel {
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    padding: clamp(2rem, 4vw, 4rem);
    min-height: 100vh;
}

.rim-view__panel--leather {
    color: var(--sand-warm);
}

.rim-view__panel--glass {
    align-items: stretch;
    justify-content: center;
}

.rim-view__wordmark-block {
    position: relative;
    z-index: 2;
    max-width: 640px;
}

.rim-view__eyebrow {
    display: inline-block;
    font-family: var(--font-mono);
    font-size: 12px;
    letter-spacing: 0.18em;
    color: var(--coral-signal);
    margin-bottom: 1.4rem;
    padding: 4px 10px;
    border: 1px solid rgba(231, 111, 81, 0.5);
    border-radius: 3px;
    text-transform: uppercase;
}

.rim-view__wordmark {
    margin: 0;
    font-family: var(--font-display);
    font-size: clamp(56px, 8vw, 116px);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    line-height: 0.95;
    color: var(--sky-aqua);
    text-shadow: 0 4px 18px rgba(0, 0, 0, 0.4);
}

.wordmark-dot {
    color: var(--coral-signal);
}

.wordmark-tld {
    color: var(--sand-warm);
}

.rim-view__underline {
    position: relative;
    margin-top: 0.4rem;
    width: 0;
    height: 4px;
    background: linear-gradient(90deg, var(--coral-signal) 0%, var(--reef-teal) 100%);
    transition: width 0.7s var(--easing) 0.1s;
    border-radius: 2px;
}

.rim-view__underline.is-drawn {
    width: 88%;
}

.rim-view__tagline {
    margin-top: 1.6rem;
    font-family: var(--font-body);
    font-size: clamp(16px, 1.4vw, 20px);
    color: rgba(202, 210, 197, 0.88);
    max-width: 520px;
    font-weight: 500;
}

.rim-view__compass {
    position: relative;
    align-self: flex-end;
    width: clamp(80px, 12vw, 132px);
    z-index: 2;
}

.compass-svg {
    width: 100%;
    height: auto;
    filter: drop-shadow(0 2px 8px rgba(0, 0, 0, 0.45));
    animation: spin-slow 80s linear infinite;
}

.rim-view__stats-card {
    width: 100%;
    max-width: 520px;
    margin: auto;
}

.rim-view__stats {
    list-style: none;
    margin: 0;
    padding: 1.2rem 1.6rem;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.1rem 1.4rem;
}

.stat-item {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
    padding: 0.6rem 0;
    border-bottom: 1px dashed rgba(190, 233, 232, 0.16);
    opacity: 0;
    transform: translateY(12px);
    transition: opacity 0.5s var(--easing), transform 0.5s var(--easing);
}

.stat-item.is-visible {
    opacity: 1;
    transform: translateY(0);
}

.stat-label {
    font-family: var(--font-mono);
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.14em;
    color: rgba(190, 233, 232, 0.7);
    margin: 0;
}

.stat-value {
    margin: 0;
    font-family: var(--font-display);
    font-size: clamp(20px, 2.2vw, 30px);
    color: var(--sky-aqua);
    letter-spacing: 0.03em;
}

.stat-value small {
    font-family: var(--font-mono);
    font-size: 10px;
    color: var(--coral-signal);
    margin-left: 0.3em;
    letter-spacing: 0.1em;
}

.rim-view__starfield {
    position: absolute;
    inset: 0;
    z-index: 0;
    background-image:
        radial-gradient(1px 1px at 20% 30%, rgba(255, 255, 255, 0.7), transparent),
        radial-gradient(1px 1px at 60% 22%, rgba(190, 233, 232, 0.5), transparent),
        radial-gradient(1.5px 1.5px at 80% 70%, rgba(255, 255, 255, 0.6), transparent),
        radial-gradient(1px 1px at 35% 80%, rgba(255, 255, 255, 0.4), transparent),
        radial-gradient(1px 1px at 90% 35%, rgba(190, 233, 232, 0.7), transparent),
        radial-gradient(1px 1px at 12% 65%, rgba(255, 255, 255, 0.45), transparent);
    background-size: 600px 600px;
    opacity: 0.45;
    pointer-events: none;
    animation: starfield-drift 120s linear infinite;
}

@keyframes starfield-drift {
    from { background-position: 0 0; }
    to { background-position: 600px 600px; }
}

@keyframes spin-slow {
    from { transform: rotate(0deg); }
    to { transform: rotate(360deg); }
}

.rim-view__zigzag {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 24px;
    z-index: 3;
    pointer-events: none;
}

.zigzag-svg {
    width: 100%;
    height: 100%;
    display: block;
}

.zigzag-path {
    stroke-dasharray: 2400;
    stroke-dashoffset: 2400;
    animation: zigzag-draw 2.4s var(--easing) forwards 0.3s;
}

.zigzag-path--bottom {
    animation-delay: 0.6s;
}

@keyframes zigzag-draw {
    to { stroke-dashoffset: 0; }
}

/* ============================================================
   Section 2/3/4: Exploration Splits
   ============================================================ */
.exploration-split {
    position: relative;
    display: grid;
    grid-template-columns: 1fr 1fr;
    min-height: var(--section-min-h);
    overflow: hidden;
}

.exploration-split--even {
    background: linear-gradient(135deg, var(--ocean-deep) 0%, var(--ocean-deep-dark) 100%);
}

.exploration-split--odd {
    background: linear-gradient(225deg, var(--ocean-deep-dark) 0%, var(--ocean-deep) 100%);
}

.exploration-split__glass {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: clamp(2rem, 5vw, 5rem) clamp(1.4rem, 3.5vw, 3.5rem);
    position: relative;
}

.exploration-glass {
    width: 100%;
    max-width: 580px;
    padding: clamp(1.6rem, 3vw, 2.6rem);
}

.exploration-glass__index {
    display: inline-block;
    font-family: var(--font-mono);
    font-size: 11px;
    letter-spacing: 0.2em;
    color: var(--coral-signal);
    margin-bottom: 0.6rem;
    text-transform: uppercase;
}

.exploration-split__texture {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}

.exploration-split__motif {
    position: relative;
    z-index: 2;
    text-align: center;
    color: var(--sand-warm);
}

.ring-illustration,
.wall-illustration,
.shadow-illustration {
    width: clamp(220px, 26vw, 320px);
    height: auto;
    filter: drop-shadow(0 6px 16px rgba(0, 0, 0, 0.4));
}

.motif-caption {
    display: block;
    margin-top: 1rem;
    font-family: var(--font-mono);
    font-size: 12px;
    letter-spacing: 0.14em;
    color: rgba(202, 210, 197, 0.78);
}

#shadowSquaresOrbit {
    transform-origin: 120px 120px;
    animation: orbit-spin 18s linear infinite;
}

@keyframes orbit-spin {
    from { transform: rotate(0deg); }
    to { transform: rotate(360deg); }
}

/* Data list inside exploration glass */
.data-list {
    list-style: none;
    margin: 1.4rem 0 0 0;
    padding: 0;
    display: grid;
    gap: 0.5rem;
}

.data-list li {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    padding: 0.4rem 0;
    border-bottom: 1px dashed rgba(190, 233, 232, 0.18);
    opacity: 0;
    transform: translateX(-12px);
    transition: opacity 0.5s var(--easing), transform 0.5s var(--easing);
}

.data-list li.is-visible {
    opacity: 1;
    transform: translateX(0);
}

.data-list__key {
    font-family: var(--font-mono);
    font-size: 12px;
    letter-spacing: 0.1em;
    color: rgba(190, 233, 232, 0.75);
    text-transform: lowercase;
}

.data-list__val {
    font-family: var(--font-display);
    font-size: clamp(18px, 1.8vw, 24px);
    color: var(--sky-aqua);
    letter-spacing: 0.04em;
}

.data-list__val sup {
    font-size: 0.6em;
    color: var(--coral-signal);
}

/* ============================================================
   Retro divider
   ============================================================ */
.retro-divider {
    position: relative;
    height: 28px;
    background: linear-gradient(180deg, transparent 0%, rgba(231, 111, 81, 0.06) 50%, transparent 100%);
    overflow: hidden;
}

.retro-divider .zigzag-svg {
    height: 100%;
    width: 100%;
}

.retro-divider svg path {
    transition: stroke-dashoffset 0.6s var(--easing);
}

/* ============================================================
   Section 5: Structure Gallery (Horizontal scroll)
   ============================================================ */
.structure-gallery {
    position: relative;
    padding: clamp(3rem, 6vw, 6rem) 0 clamp(2rem, 4vw, 4rem) 0;
    background: linear-gradient(180deg, var(--ocean-deep-dark) 0%, var(--ocean-deep) 100%);
}

.structure-gallery__header {
    text-align: center;
    padding: 0 clamp(1.4rem, 4vw, 4rem);
    margin-bottom: 2.4rem;
}

.structure-gallery__index {
    display: inline-block;
    font-family: var(--font-mono);
    font-size: 11px;
    letter-spacing: 0.2em;
    color: var(--coral-signal);
    margin-bottom: 0.6rem;
    text-transform: uppercase;
}

.structure-gallery__intro {
    margin: 0.8rem auto 0 auto;
    max-width: 640px;
    font-size: clamp(15px, 1.1vw, 17px);
    color: rgba(202, 210, 197, 0.88);
}

.structure-gallery__rail {
    display: flex;
    gap: 1.6rem;
    padding: 1.4rem clamp(1.4rem, 4vw, 4rem);
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    scroll-behavior: smooth;
    scrollbar-width: none;
}

.structure-gallery__rail::-webkit-scrollbar { display: none; }
.structure-gallery__rail:focus { outline: none; }

/* Region card */
.region-card {
    flex: 0 0 clamp(260px, 30vw, 340px);
    border-radius: 16px;
    overflow: hidden;
    scroll-snap-align: center;
    display: flex;
    flex-direction: column;
    min-height: 380px;
    position: relative;
    transform: translateY(0);
    transition: transform 0.5s var(--easing), box-shadow 0.5s var(--easing);
}

.region-card:hover,
.region-card.is-active {
    transform: translateY(-6px);
    box-shadow: 0 16px 40px rgba(0, 0, 0, 0.35);
}

.region-card__leather {
    position: relative;
    padding: 1.4rem 1.6rem;
    color: var(--sand-warm);
    overflow: hidden;
}

.region-card__id {
    display: inline-block;
    font-family: var(--font-mono);
    font-size: 11px;
    letter-spacing: 0.2em;
    color: var(--coral-signal);
    background: rgba(231, 111, 81, 0.12);
    padding: 3px 8px;
    border-radius: 3px;
    text-transform: uppercase;
    position: relative;
    z-index: 2;
}

.region-card__name {
    margin: 0.6rem 0 0 0;
    font-family: var(--font-display);
    font-size: clamp(22px, 2.4vw, 32px);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--sky-aqua);
    position: relative;
    z-index: 2;
}

.region-card__body {
    padding: 1.4rem 1.6rem 1.6rem 1.6rem;
    flex-grow: 1;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    gap: 1rem;
}

.region-card__lore {
    margin: 0;
    font-size: 14.5px;
    line-height: 1.65;
    color: rgba(202, 210, 197, 0.92);
}

.region-card__stats {
    margin: 0;
    padding: 0.8rem 0 0 0;
    border-top: 1px solid rgba(255, 255, 255, 0.12);
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.6rem;
}

.region-card__stats div {
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
}

.region-card__stats dt {
    font-family: var(--font-mono);
    font-size: 10px;
    letter-spacing: 0.16em;
    color: var(--coral-signal);
    text-transform: uppercase;
    margin: 0;
}

.region-card__stats dd {
    margin: 0;
    font-family: var(--font-display);
    font-size: 18px;
    color: var(--sky-aqua);
    letter-spacing: 0.04em;
}

/* Retro corner decoration on cards */
.region-card__corner {
    position: absolute;
    top: 12px;
    right: 12px;
    width: 24px;
    height: 24px;
    border-top: 2px solid var(--coral-signal);
    border-right: 2px solid var(--coral-signal);
    pointer-events: none;
    opacity: 0.7;
}

.region-card::after {
    content: '';
    position: absolute;
    bottom: 12px;
    left: 12px;
    width: 24px;
    height: 24px;
    border-bottom: 2px solid var(--coral-signal);
    border-left: 2px solid var(--coral-signal);
    pointer-events: none;
    opacity: 0.7;
}

/* Gallery progress */
.structure-gallery__progress {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1.2rem;
    padding: 1.4rem clamp(1.4rem, 4vw, 4rem) 0;
}

.structure-gallery__track {
    width: clamp(200px, 30vw, 360px);
    height: 4px;
    background: rgba(255, 255, 255, 0.10);
    border-radius: 2px;
    overflow: hidden;
}

.structure-gallery__thumb {
    width: 16.66%;
    height: 100%;
    background: linear-gradient(90deg, var(--coral-signal) 0%, var(--reef-teal) 100%);
    border-radius: 2px;
    transition: transform 0.4s var(--easing), width 0.3s var(--easing);
    transform: translateX(0);
}

.structure-gallery__count {
    font-family: var(--font-mono);
    font-size: 12px;
    letter-spacing: 0.18em;
    color: var(--sky-aqua);
}

/* ============================================================
   Section 6: Quest Log timeline
   ============================================================ */
.quest-log {
    position: relative;
    display: grid;
    grid-template-columns: minmax(280px, 1fr) 2.4fr;
    background: linear-gradient(180deg, var(--ocean-deep) 0%, var(--ocean-deep-dark) 100%);
    min-height: var(--section-min-h);
}

.quest-log__intro {
    position: relative;
    padding: clamp(2rem, 4vw, 4rem);
    color: var(--sand-warm);
    overflow: hidden;
}

.quest-log__intro .body-text {
    color: rgba(202, 210, 197, 0.88);
    position: relative;
    z-index: 2;
}

.quest-log__index {
    display: inline-block;
    font-family: var(--font-mono);
    font-size: 11px;
    letter-spacing: 0.2em;
    color: var(--coral-signal);
    margin-bottom: 0.6rem;
    text-transform: uppercase;
    position: relative;
    z-index: 2;
}

.quest-log__intro .section-heading {
    color: var(--sky-aqua);
    position: relative;
    z-index: 2;
}

.quest-log__entries {
    list-style: none;
    margin: 0;
    padding: clamp(2rem, 4vw, 4rem) clamp(1.4rem, 3vw, 3rem);
    display: grid;
    gap: 1.4rem;
    position: relative;
}

.quest-log__entries::before {
    content: '';
    position: absolute;
    top: clamp(2rem, 4vw, 4rem);
    bottom: clamp(2rem, 4vw, 4rem);
    left: clamp(2rem, 4vw, 4rem);
    width: 2px;
    background: linear-gradient(180deg, transparent 0%, var(--coral-signal) 12%, var(--reef-teal) 88%, transparent 100%);
    opacity: 0.55;
}

.quest-entry {
    position: relative;
    padding-left: clamp(1.4rem, 3vw, 3rem);
    opacity: 0;
    transform: translateX(20px);
    transition: opacity 0.6s var(--easing), transform 0.6s var(--easing);
}

.quest-entry.is-visible {
    opacity: 1;
    transform: translateX(0);
}

.quest-entry::before {
    content: '';
    position: absolute;
    left: -7px;
    top: 24px;
    width: 14px;
    height: 14px;
    border-radius: 50%;
    background: var(--coral-signal);
    border: 2px solid var(--sky-aqua);
    box-shadow: 0 0 0 4px rgba(231, 111, 81, 0.18);
}

.quest-entry__card {
    padding: 1.2rem 1.4rem;
}

.quest-entry__time {
    font-family: var(--font-mono);
    font-size: 11px;
    letter-spacing: 0.18em;
    color: var(--coral-signal);
    text-transform: uppercase;
}

.quest-entry__title {
    margin: 0.4rem 0 0.6rem 0;
    font-family: var(--font-display);
    font-size: clamp(20px, 2vw, 28px);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--sky-aqua);
}

.quest-entry__body {
    margin: 0;
    font-size: 15px;
    color: rgba(202, 210, 197, 0.92);
}

/* ============================================================
   Section 7: Shadow square footer
   ============================================================ */
.shadow-footer {
    position: relative;
    background: linear-gradient(180deg, var(--ocean-deep-dark) 0%, #0d1f2e 100%);
    padding: clamp(2rem, 4vw, 4rem) clamp(1.4rem, 4vw, 4rem) 1.6rem;
    color: var(--sand-warm);
    overflow: hidden;
}

.shadow-footer__pattern {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 32px;
    opacity: 0.55;
}

.footer-pattern-svg {
    width: 100%;
    height: 100%;
    display: block;
}

.shadow-footer__panels {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 1.4rem;
    margin: 2.4rem 0 1.8rem;
}

.shadow-footer__card {
    padding: 1.4rem 1.6rem;
}

.shadow-footer__title {
    margin: 0 0 0.6rem 0;
    font-family: var(--font-display);
    font-size: clamp(22px, 2.2vw, 30px);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--sky-aqua);
}

.shadow-footer__subtitle {
    margin: 0 0 0.8rem 0;
    font-family: var(--font-display);
    font-size: 18px;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--coral-signal);
}

.shadow-footer__body {
    margin: 0;
    font-size: 14.5px;
    line-height: 1.7;
    color: rgba(202, 210, 197, 0.85);
}

.shadow-footer__list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    gap: 0.4rem;
}

.shadow-footer__list li {
    font-family: var(--font-body);
    font-size: 14px;
    color: rgba(202, 210, 197, 0.82);
    padding-left: 0.9rem;
    position: relative;
}

.shadow-footer__list li::before {
    content: '\25C6';
    position: absolute;
    left: 0;
    color: var(--coral-signal);
    font-size: 9px;
    top: 4px;
}

.shadow-footer__meta {
    margin: 0 0 0.3rem 0;
    font-family: var(--font-mono);
    font-size: 12.5px;
    letter-spacing: 0.06em;
    color: rgba(190, 233, 232, 0.78);
}

.shadow-footer__base {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.8rem;
    padding: 1rem 0 0;
    border-top: 1px solid rgba(255, 255, 255, 0.08);
    font-family: var(--font-mono);
    font-size: 11px;
    letter-spacing: 0.16em;
    color: rgba(202, 210, 197, 0.55);
    text-transform: uppercase;
}

/* ============================================================
   Spin indicator (fixed)
   ============================================================ */
.spin-indicator {
    position: fixed;
    bottom: 22px;
    right: 22px;
    width: 60px;
    height: 60px;
    z-index: 10;
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.5s var(--easing);
}

.spin-indicator.is-visible {
    opacity: 1;
}

.spin-indicator__svg {
    width: 100%;
    height: 100%;
    filter: drop-shadow(0 4px 12px rgba(0, 0, 0, 0.4));
}

#spinProgress {
    transition: stroke-dashoffset 0.18s linear;
}

/* ============================================================
   Animation triggers (data-animate generic reveal)
   ============================================================ */
[data-animate] {
    opacity: 0;
    transform: translateY(28px);
    transition: opacity 0.7s var(--easing), transform 0.7s var(--easing);
}

[data-animate].is-visible {
    opacity: 1;
    transform: translateY(0);
}

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width: 960px) {
    .rim-view,
    .exploration-split {
        grid-template-columns: 1fr;
    }

    .rim-view__panel,
    .exploration-split__glass,
    .exploration-split__texture {
        min-height: auto;
    }

    .rim-view__panel--leather {
        min-height: 70vh;
    }

    .rim-view__panel--glass {
        padding: 2rem clamp(1rem, 4vw, 2.4rem);
    }

    .exploration-split__texture {
        min-height: 320px;
        padding: 2rem 1rem;
    }

    .quest-log {
        grid-template-columns: 1fr;
    }

    .quest-log__entries::before {
        left: 1.6rem;
    }

    .quest-entry {
        padding-left: 2.4rem;
    }

    .quest-entry::before {
        left: calc(1.6rem - 7px);
    }
}

@media (max-width: 540px) {
    .rim-view__stats {
        grid-template-columns: 1fr;
        gap: 0.6rem 0;
    }

    .glass-panel__header {
        padding: 1rem 1.2rem;
    }

    .region-card {
        flex: 0 0 80vw;
    }

    .shadow-footer__base {
        flex-direction: column;
        align-items: flex-start;
    }
}

@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        animation-duration: 0.01ms !important;
        transition-duration: 0.01ms !important;
    }
}
