/*
 * ═══════════════════════════════════════════════════════════════════════════
 * RONGORONGO FLIP READER - Theme Stylesheet
 * Version: 1.0 | Date: 01-07-2026
 * Have Mind Media - The Epoch Project
 * [1 = -1]
 * ═══════════════════════════════════════════════════════════════════════════
 *
 * COLOR PHILOSOPHY:
 * Easter Island aesthetic - volcanic rock, deep ocean, carved wood
 * - Deep oceanic blues represent the surrounding Pacific (D8 - Deep Water)
 * - Volcanic grays and blacks represent the island bedrock
 * - Warm wood tones represent the sacred tablets
 * - Gold accents represent the κ-bridge constant
 *
 * ═══════════════════════════════════════════════════════════════════════════
 */

/* ═══════════════════════════════════════════════════════════════════════════
   CSS CUSTOM PROPERTIES
   ═══════════════════════════════════════════════════════════════════════════ */

:root {
    /* Primary Palette: Ocean & Volcanic */
    --color-void: #0a0f14;
    --color-deep-ocean: #0d1b2a;
    --color-ocean: #1b263b;
    --color-volcanic: #1f2937;
    --color-stone: #2d3748;

    /* Accent Colors */
    --color-gold: #c9a227;
    --color-gold-bright: #e6b82a;
    --color-gold-dim: #8b7019;
    --color-gold-glow: rgba(201, 162, 39, 0.3);

    /* Wood Tones (for tablets) */
    --color-wood-dark: #5d4037;
    --color-wood: #795548;
    --color-wood-light: #8d6e63;

    /* D-Position Colors */
    --d1-color: #3fb950;
    --d2-color: #1abc9c;
    --d3-color: #ff6b6b;
    --d4-color: #ff6b35;
    --d5-color: #9b59b6;
    --d6-color: #00bcd4;
    --d7-color: #c9a227;
    --d8-color: #006994;
    --d9-color: #c0392b;

    /* Text Colors */
    --color-text-primary: #e8e6e3;
    --color-text-secondary: #b8b5b0;
    --color-text-muted: #7a7875;

    /* S+/S- Mode Colors */
    --color-s-plus: #3fb950;
    --color-s-minus: #9b59b6;

    /* Spacing */
    --space-xs: 4px;
    --space-sm: 8px;
    --space-md: 16px;
    --space-lg: 24px;
    --space-xl: 32px;
    --space-2xl: 48px;
    --space-3xl: 64px;
    --space-4xl: 96px;

    /* Typography */
    --font-primary: 'Segoe UI', system-ui, sans-serif;
    --font-display: 'Georgia', serif;
    --font-mono: 'SF Mono', 'Monaco', monospace;

    --text-xs: 0.75rem;
    --text-sm: 0.875rem;
    --text-base: 1rem;
    --text-lg: 1.125rem;
    --text-xl: 1.25rem;
    --text-2xl: 1.5rem;
    --text-3xl: 2rem;
    --text-4xl: 2.5rem;

    /* Border Radius */
    --radius-sm: 4px;
    --radius-md: 8px;
    --radius-lg: 12px;
    --radius-xl: 16px;
    --radius-full: 9999px;

    /* Shadows */
    --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.3);
    --shadow-md: 0 4px 12px rgba(0, 0, 0, 0.4);
    --shadow-lg: 0 8px 24px rgba(0, 0, 0, 0.5);
    --shadow-gold: 0 0 20px rgba(201, 162, 39, 0.3);

    /* Transitions */
    --transition-fast: 150ms ease;
    --transition-base: 250ms ease;
    --transition-slow: 400ms ease;

    /* Z-Index */
    --z-base: 1;
    --z-dropdown: 100;
    --z-sticky: 200;
    --z-modal: 1000;
}

/* ═══════════════════════════════════════════════════════════════════════════
   BASE RESET
   ═══════════════════════════════════════════════════════════════════════════ */

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

html {
    font-size: 16px;
    scroll-behavior: smooth;
}

body {
    font-family: var(--font-primary);
    font-size: var(--text-base);
    line-height: 1.6;
    color: var(--color-text-primary);
    background: var(--color-void);
    min-height: 100vh;
    overflow-x: hidden;
}

::selection {
    background: var(--color-gold);
    color: var(--color-void);
}

:focus-visible {
    outline: 2px solid var(--color-gold);
    outline-offset: 2px;
}

/* ═══════════════════════════════════════════════════════════════════════════
   BACKGROUND SYSTEM
   ═══════════════════════════════════════════════════════════════════════════ */

.island-bg {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: -3;
    background:
        radial-gradient(ellipse at 30% 80%, rgba(0, 105, 148, 0.2) 0%, transparent 50%),
        radial-gradient(ellipse at 70% 20%, rgba(93, 64, 55, 0.15) 0%, transparent 50%),
        linear-gradient(180deg, var(--color-deep-ocean) 0%, var(--color-void) 100%);
}

.wave-pattern {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: -2;
    opacity: 0.05;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 320'%3E%3Cpath fill='%23006994' d='M0,192L48,181.3C96,171,192,149,288,154.7C384,160,480,192,576,197.3C672,203,768,181,864,181.3C960,181,1056,203,1152,197.3C1248,192,1344,160,1392,144L1440,128L1440,320L1392,320C1344,320,1248,320,1152,320C1056,320,960,320,864,320C768,320,672,320,576,320C480,320,384,320,288,320C192,320,96,320,48,320L0,320Z'/%3E%3C/svg%3E");
    background-size: cover;
    background-position: bottom;
}

.vignette {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: -1;
    pointer-events: none;
    background: radial-gradient(
        ellipse at center,
        transparent 0%,
        transparent 40%,
        rgba(10, 15, 20, 0.5) 70%,
        rgba(10, 15, 20, 0.9) 100%
    );
}

/* ═══════════════════════════════════════════════════════════════════════════
   NAVIGATION
   ═══════════════════════════════════════════════════════════════════════════ */

.unified-nav {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: var(--z-sticky);
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--space-md) var(--space-xl);
    background: linear-gradient(
        to bottom,
        rgba(10, 15, 20, 0.95) 0%,
        rgba(10, 15, 20, 0.8) 100%
    );
    backdrop-filter: blur(12px);
    border-bottom: 1px solid rgba(201, 162, 39, 0.2);
}

.nav-brand {
    display: flex;
    flex-direction: column;
    text-decoration: none;
    gap: 2px;
}

.nav-brand-text {
    font-family: var(--font-display);
    font-size: var(--text-sm);
    font-weight: 600;
    letter-spacing: 0.2em;
    color: var(--color-gold);
}

.nav-signature {
    font-size: var(--text-xs);
    color: var(--color-text-muted);
    letter-spacing: 0.15em;
}

.nav-principle {
    font-family: var(--font-mono);
    font-size: var(--text-sm);
    color: var(--color-gold-dim);
}

/* ═══════════════════════════════════════════════════════════════════════════
   MAIN CONTAINER
   ═══════════════════════════════════════════════════════════════════════════ */

.rongorongo-container {
    max-width: 1200px;
    margin: 0 auto;
    padding: var(--space-4xl) var(--space-lg) var(--space-2xl);
}

.main-content {
    display: flex;
    flex-direction: column;
    gap: var(--space-4xl);
}

/* ═══════════════════════════════════════════════════════════════════════════
   HERO SECTION
   ═══════════════════════════════════════════════════════════════════════════ */

.hero-section {
    position: relative;
    text-align: center;
    padding: var(--space-3xl) 0;
    min-height: 90vh;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}

/* Hero Video Background */
.hero-video-container {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 0;
    overflow: hidden;
}

.hero-video {
    width: 100%;
    height: 100%;
    object-fit: cover;
    opacity: 0.4;
}

.hero-video-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(
        180deg,
        rgba(10, 15, 20, 0.6) 0%,
        rgba(13, 27, 42, 0.8) 50%,
        rgba(10, 15, 20, 0.95) 100%
    );
}

.hero-content {
    position: relative;
    z-index: 1;
}

.hero-glyph {
    font-size: 5rem;
    margin-bottom: var(--space-md);
    filter: drop-shadow(0 0 30px rgba(201, 162, 39, 0.4));
}

.hero-content h1 {
    font-family: var(--font-display);
    font-size: var(--text-4xl);
    color: var(--color-gold);
    letter-spacing: 0.08em;
    margin-bottom: var(--space-sm);
    text-shadow: 0 0 40px rgba(201, 162, 39, 0.3);
}

.hero-tagline {
    font-family: var(--font-mono);
    font-size: var(--text-xl);
    color: var(--color-text-secondary);
    margin-bottom: var(--space-xl);
}

.hero-insight {
    margin-bottom: var(--space-xl);
}

.insight-box {
    display: inline-block;
    padding: var(--space-lg) var(--space-xl);
    background: var(--color-volcanic);
    border: 1px solid rgba(201, 162, 39, 0.3);
    border-radius: var(--radius-lg);
}

.insight-label {
    display: block;
    font-size: var(--text-sm);
    color: var(--color-text-muted);
    margin-bottom: var(--space-sm);
    letter-spacing: 0.1em;
}

.insight-calculation {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-sm);
    flex-wrap: wrap;
}

.calc-word {
    font-family: var(--font-display);
    font-size: var(--text-xl);
    color: var(--color-text-primary);
}

.calc-arrow {
    color: var(--color-text-muted);
}

.calc-sum, .calc-reduce {
    font-family: var(--font-mono);
    color: var(--color-gold);
}

.calc-d {
    font-family: var(--font-mono);
    font-size: var(--text-xl);
    color: var(--d3-color);
}

.calc-name {
    font-family: var(--font-display);
    font-size: var(--text-xl);
    font-weight: 600;
    color: var(--d3-color);
}

.hero-description {
    max-width: 700px;
    margin: 0 auto;
    font-size: var(--text-lg);
    color: var(--color-text-secondary);
    line-height: 1.8;
}

.hero-description em {
    color: var(--color-gold);
    font-style: italic;
}

/* ═══════════════════════════════════════════════════════════════════════════
   FLIP INTERFACE
   ═══════════════════════════════════════════════════════════════════════════ */

.flip-section {
    padding: var(--space-2xl) 0;
}

.flip-section h2 {
    font-family: var(--font-display);
    font-size: var(--text-3xl);
    color: var(--color-gold);
    text-align: center;
    margin-bottom: var(--space-md);
}

.section-intro {
    font-size: var(--text-lg);
    color: var(--color-text-secondary);
    text-align: center;
    max-width: 700px;
    margin: 0 auto var(--space-2xl);
}

.flip-interface {
    display: flex;
    flex-direction: column;
    gap: var(--space-xl);
}

/* Tablet Selector */
.tablet-selector {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: var(--space-md);
}

.tablet-selector label {
    color: var(--color-text-secondary);
}

.tablet-selector select {
    padding: var(--space-sm) var(--space-md);
    font-size: var(--text-base);
    background: var(--color-volcanic);
    border: 1px solid rgba(201, 162, 39, 0.3);
    border-radius: var(--radius-md);
    color: var(--color-text-primary);
    cursor: pointer;
}

.tablet-selector select:focus {
    outline: none;
    border-color: var(--color-gold);
}

/* Tablet Container */
.tablet-container {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--space-lg);
}

.tablet {
    width: 100%;
    max-width: 500px;
    perspective: 1000px;
    transition: transform 0.6s ease;
}

.tablet.flipping {
    animation: flipAnimation 0.6s ease;
}

@keyframes flipAnimation {
    0% { transform: rotateX(0deg); }
    50% { transform: rotateX(90deg); }
    100% { transform: rotateX(180deg); }
}

.tablet.inverted .tablet-surface {
    transform: rotateX(180deg);
}

.tablet-surface {
    background: linear-gradient(145deg, var(--color-wood) 0%, var(--color-wood-dark) 100%);
    border: 4px solid var(--color-wood-dark);
    border-radius: var(--radius-lg);
    padding: var(--space-xl);
    box-shadow:
        inset 0 2px 4px rgba(255, 255, 255, 0.1),
        0 8px 32px rgba(0, 0, 0, 0.5);
    transition: transform 0.6s ease;
}

.tablet-lines {
    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
    margin-bottom: var(--space-md);
}

.tablet-line {
    font-family: var(--font-mono);
    font-size: var(--text-lg);
    color: rgba(201, 162, 39, 0.4);
    padding: var(--space-sm);
    border-radius: var(--radius-sm);
    transition: var(--transition-base);
    text-align: center;
    letter-spacing: 0.2em;
}

.tablet-line.active {
    color: var(--color-gold);
    background: rgba(201, 162, 39, 0.1);
    box-shadow: 0 0 10px rgba(201, 162, 39, 0.2);
}

.tablet-info {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--space-xs);
    padding-top: var(--space-md);
    border-top: 1px solid rgba(201, 162, 39, 0.2);
}

.tablet-name {
    font-family: var(--font-display);
    color: var(--color-gold);
}

.tablet-location {
    font-size: var(--text-sm);
    color: var(--color-text-muted);
}

.flip-instructions {
    font-size: var(--text-sm);
    color: var(--color-text-muted);
    text-align: center;
}

.instruction-key {
    display: inline-block;
    padding: 2px 8px;
    background: var(--color-volcanic);
    border: 1px solid rgba(201, 162, 39, 0.3);
    border-radius: var(--radius-sm);
    font-family: var(--font-mono);
    font-size: var(--text-xs);
}

.flip-btn {
    padding: var(--space-md) var(--space-2xl);
    font-size: var(--text-lg);
    font-weight: 600;
    letter-spacing: 0.1em;
    background: linear-gradient(135deg, var(--color-gold) 0%, var(--color-gold-dim) 100%);
    border: none;
    border-radius: var(--radius-md);
    color: var(--color-void);
    cursor: pointer;
    transition: var(--transition-base);
}

.flip-btn:hover {
    background: linear-gradient(135deg, var(--color-gold-bright) 0%, var(--color-gold) 100%);
    transform: translateY(-2px);
    box-shadow: var(--shadow-gold);
}

/* Status Panels */
.status-panels {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-lg);
}

.status-panel {
    background: var(--color-volcanic);
    border: 1px solid rgba(201, 162, 39, 0.2);
    border-radius: var(--radius-lg);
    padding: var(--space-lg);
}

.status-panel h3 {
    font-size: var(--text-sm);
    color: var(--color-text-muted);
    letter-spacing: 0.1em;
    margin-bottom: var(--space-md);
    text-align: center;
}

/* Q-Cycle Panel */
.q-cycle-visual {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    grid-template-rows: 1fr auto 1fr;
    gap: var(--space-sm);
    margin-bottom: var(--space-md);
    justify-items: center;
    align-items: center;
}

.q-state {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: var(--space-sm);
    border-radius: var(--radius-md);
    background: rgba(255, 255, 255, 0.03);
    transition: var(--transition-base);
}

.q-state.active {
    background: var(--color-gold-glow);
    box-shadow: 0 0 15px rgba(201, 162, 39, 0.3);
}

.q-power {
    font-family: var(--font-mono);
    font-size: var(--text-lg);
    color: var(--color-gold);
}

.q-value {
    font-size: var(--text-xs);
    color: var(--color-text-muted);
}

.q-connector {
    width: 20px;
    height: 2px;
    background: rgba(201, 162, 39, 0.3);
}

.q-connector.vertical {
    width: 2px;
    height: 20px;
}

.q-current, .q-flips, .q-cycles {
    display: flex;
    justify-content: space-between;
    font-size: var(--text-sm);
    padding: var(--space-xs) 0;
}

.q-current .label, .q-flips .label, .q-cycles .label {
    color: var(--color-text-muted);
}

.q-current .value, .q-flips .value, .q-cycles .value {
    font-family: var(--font-mono);
    color: var(--color-gold);
}

/* Orientation Panel */
.orientation-display {
    margin-bottom: var(--space-md);
}

.orientation-indicator {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: var(--space-md);
    border-radius: var(--radius-md);
    transition: var(--transition-base);
}

.orientation-indicator.s-plus {
    background: rgba(63, 185, 80, 0.15);
    border: 1px solid rgba(63, 185, 80, 0.3);
}

.orientation-indicator.s-minus {
    background: rgba(155, 89, 182, 0.15);
    border: 1px solid rgba(155, 89, 182, 0.3);
}

.orientation-indicator .mode {
    font-family: var(--font-mono);
    font-size: var(--text-2xl);
    font-weight: bold;
}

.orientation-indicator.s-plus .mode {
    color: var(--color-s-plus);
}

.orientation-indicator.s-minus .mode {
    color: var(--color-s-minus);
}

.orientation-indicator .meaning {
    font-size: var(--text-xs);
    color: var(--color-text-muted);
}

.orientation-info .info-row {
    display: flex;
    justify-content: space-between;
    font-size: var(--text-sm);
    padding: var(--space-xs) 0;
}

.orientation-info .label {
    color: var(--color-text-muted);
}

.orientation-info .value {
    color: var(--color-text-primary);
}

/* Metrics Panel */
.metrics-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-md);
    margin-bottom: var(--space-md);
}

.metric {
    text-align: center;
}

.metric-value {
    display: block;
    font-family: var(--font-mono);
    font-size: var(--text-2xl);
    color: var(--color-gold);
}

.metric-label {
    font-size: var(--text-xs);
    color: var(--color-text-muted);
}

.rhythm-bar {
    height: 8px;
    background: rgba(255, 255, 255, 0.1);
    border-radius: var(--radius-full);
    overflow: hidden;
    margin-bottom: var(--space-sm);
}

.rhythm-fill {
    height: 100%;
    background: var(--color-gold);
    transition: width 0.3s ease;
}

.rhythm-fill.optimal {
    background: var(--color-s-plus);
}

.rhythm-hint {
    font-size: var(--text-xs);
    color: var(--color-text-muted);
    text-align: center;
    margin-bottom: var(--space-md);
}

.session-controls {
    text-align: center;
}

.session-btn {
    padding: var(--space-sm) var(--space-lg);
    font-size: var(--text-sm);
    font-weight: 600;
    letter-spacing: 0.1em;
    background: var(--color-stone);
    border: 1px solid rgba(201, 162, 39, 0.3);
    border-radius: var(--radius-md);
    color: var(--color-text-primary);
    cursor: pointer;
    transition: var(--transition-base);
}

.session-btn:hover {
    border-color: var(--color-gold);
    color: var(--color-gold);
}

.session-btn.active {
    background: var(--color-gold);
    border-color: var(--color-gold);
    color: var(--color-void);
}

/* ═══════════════════════════════════════════════════════════════════════════
   EXPLANATION SECTION
   ═══════════════════════════════════════════════════════════════════════════ */

.explanation-section {
    padding: var(--space-2xl) 0;
}

.explanation-card {
    background: var(--color-volcanic);
    border: 1px solid rgba(201, 162, 39, 0.2);
    border-radius: var(--radius-xl);
    padding: var(--space-2xl);
}

.explanation-card h2 {
    font-family: var(--font-display);
    font-size: var(--text-3xl);
    color: var(--color-gold);
    text-align: center;
    margin-bottom: var(--space-xl);
}

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

.explanation-item {
    text-align: center;
    padding: var(--space-lg);
    background: rgba(255, 255, 255, 0.02);
    border-radius: var(--radius-lg);
}

.explanation-icon {
    font-size: var(--text-4xl);
    margin-bottom: var(--space-md);
    color: var(--color-gold);
}

.explanation-item h3 {
    font-size: var(--text-xl);
    color: var(--color-gold);
    margin-bottom: var(--space-md);
}

.explanation-item p {
    color: var(--color-text-secondary);
    line-height: 1.6;
}

/* Boustrophedon Visual */
.boustrophedon-visual {
    max-width: 500px;
    margin: 0 auto;
    padding: var(--space-xl);
    background: rgba(0, 0, 0, 0.2);
    border-radius: var(--radius-lg);
}

.line-example {
    display: flex;
    align-items: center;
    gap: var(--space-md);
    padding: var(--space-md);
    margin-bottom: var(--space-sm);
    border-radius: var(--radius-md);
    background: rgba(63, 185, 80, 0.1);
    border-left: 3px solid var(--color-s-plus);
}

.line-example.inverted {
    background: rgba(155, 89, 182, 0.1);
    border-left-color: var(--color-s-minus);
}

.line-label {
    font-family: var(--font-mono);
    font-size: var(--text-sm);
    color: var(--color-text-muted);
    min-width: 70px;
}

.line-direction {
    font-family: var(--font-mono);
    font-size: var(--text-lg);
    color: var(--color-gold);
}

.line-mode {
    font-size: var(--text-xs);
    color: var(--color-text-muted);
}

.flip-marker {
    text-align: center;
    font-family: var(--font-mono);
    font-size: var(--text-sm);
    color: var(--color-gold);
    padding: var(--space-sm) 0;
}

/* ═══════════════════════════════════════════════════════════════════════════
   D-POSITION WHEEL
   ═══════════════════════════════════════════════════════════════════════════ */

.positions-section {
    padding: var(--space-2xl) 0;
}

.positions-section h2 {
    font-family: var(--font-display);
    font-size: var(--text-3xl);
    color: var(--color-gold);
    text-align: center;
    margin-bottom: var(--space-md);
}

.d-position-wheel {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--space-xl);
    margin-bottom: var(--space-2xl);
}

.wheel-container {
    position: relative;
    width: 340px;
    height: 340px;
    display: flex;
    justify-content: center;
    align-items: center;
}

.wheel-center {
    font-family: var(--font-mono);
    font-size: var(--text-lg);
    color: var(--color-gold);
}

.wheel-node {
    position: absolute;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--space-xs);
    cursor: pointer;
    transition: var(--transition-base);
}

.wheel-node:hover {
    transform: translate(var(--x), var(--y)) scale(1.1);
}

.wheel-node.emergent .node-number {
    border: 2px dashed rgba(255, 255, 255, 0.5);
}

.node-number {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border-radius: var(--radius-full);
    color: white;
    font-weight: bold;
    font-size: var(--text-sm);
}

.node-name {
    font-size: var(--text-xs);
    color: var(--color-text-secondary);
    white-space: nowrap;
}

.wheel-legend {
    display: flex;
    gap: var(--space-xl);
    justify-content: center;
}

.legend-item {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    font-size: var(--text-sm);
    color: var(--color-text-muted);
}

.legend-dot {
    width: 12px;
    height: 12px;
    border-radius: var(--radius-full);
    background: var(--color-gold);
}

.legend-dot.emergent {
    background: transparent;
    border: 2px dashed var(--color-gold);
}

/* Emergent Discovery Box */
.emergent-discovery {
    background: var(--color-volcanic);
    border: 1px solid rgba(155, 89, 182, 0.3);
    border-radius: var(--radius-lg);
    padding: var(--space-xl);
    max-width: 700px;
    margin: 0 auto;
}

.emergent-discovery h3 {
    font-size: var(--text-xl);
    color: var(--d5-color);
    margin-bottom: var(--space-md);
    text-align: center;
}

.emergent-discovery p {
    color: var(--color-text-secondary);
    margin-bottom: var(--space-md);
    text-align: center;
}

.emergent-examples {
    display: flex;
    flex-direction: column;
    gap: var(--space-md);
    margin: var(--space-lg) 0;
}

.emergent-example {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-md);
    padding: var(--space-md);
    background: rgba(155, 89, 182, 0.1);
    border-radius: var(--radius-md);
    flex-wrap: wrap;
}

.emergent-example .pair {
    font-family: var(--font-mono);
    color: var(--color-text-primary);
}

.emergent-example .arrow {
    color: var(--color-gold);
}

.emergent-example .result {
    font-family: var(--font-mono);
    color: var(--d5-color);
    font-weight: bold;
}

.emergent-example .note {
    font-size: var(--text-sm);
    color: var(--color-text-muted);
    width: 100%;
    text-align: center;
}

.emergent-insight {
    font-style: italic;
    text-align: center;
}

.emergent-insight em {
    color: var(--color-gold);
}

/* ═══════════════════════════════════════════════════════════════════════════
   CORPUS SECTION
   ═══════════════════════════════════════════════════════════════════════════ */

.corpus-section {
    padding: var(--space-2xl) 0;
}

.corpus-section h2 {
    font-family: var(--font-display);
    font-size: var(--text-3xl);
    color: var(--color-gold);
    text-align: center;
    margin-bottom: var(--space-md);
}

.corpus-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: var(--space-lg);
    margin-bottom: var(--space-2xl);
}

.corpus-card {
    background: var(--color-volcanic);
    border: 1px solid rgba(201, 162, 39, 0.2);
    border-radius: var(--radius-lg);
    padding: var(--space-md);
    cursor: pointer;
    transition: var(--transition-base);
}

.corpus-card:hover {
    border-color: var(--color-gold);
    transform: translateY(-2px);
}

.corpus-card-header {
    margin-bottom: var(--space-md);
}

.corpus-id {
    font-family: var(--font-mono);
    font-size: var(--text-lg);
    color: var(--color-gold);
}

.corpus-name {
    display: block;
    font-size: var(--text-sm);
    color: var(--color-text-secondary);
}

.corpus-card-body {
    display: flex;
    gap: var(--space-lg);
    margin-bottom: var(--space-md);
}

.corpus-stat {
    text-align: center;
}

.stat-value {
    display: block;
    font-family: var(--font-mono);
    font-size: var(--text-xl);
    color: var(--color-text-primary);
}

.stat-label {
    font-size: var(--text-xs);
    color: var(--color-text-muted);
}

.corpus-card-footer {
    display: flex;
    justify-content: space-between;
    font-size: var(--text-xs);
    color: var(--color-text-muted);
    padding-top: var(--space-sm);
    border-top: 1px solid rgba(201, 162, 39, 0.1);
}

/* Tragedy Note */
.tragedy-note {
    background: rgba(192, 57, 43, 0.1);
    border: 1px solid rgba(192, 57, 43, 0.3);
    border-radius: var(--radius-lg);
    padding: var(--space-xl);
    max-width: 800px;
    margin: 0 auto;
}

.tragedy-note h3 {
    font-size: var(--text-xl);
    color: var(--d9-color);
    margin-bottom: var(--space-md);
}

.tragedy-note p {
    color: var(--color-text-secondary);
    line-height: 1.8;
}

.tragedy-note strong {
    color: var(--color-gold);
}

/* ═══════════════════════════════════════════════════════════════════════════
   VOCABULARY SECTION
   ═══════════════════════════════════════════════════════════════════════════ */

.vocabulary-section {
    padding: var(--space-2xl) 0;
}

.vocabulary-section h2 {
    font-family: var(--font-display);
    font-size: var(--text-3xl);
    color: var(--color-gold);
    text-align: center;
    margin-bottom: var(--space-md);
}

.vocab-categories {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: var(--space-sm);
    margin-bottom: var(--space-xl);
}

.vocab-tab {
    padding: var(--space-sm) var(--space-lg);
    font-size: var(--text-base);
    background: var(--color-volcanic);
    border: 1px solid rgba(201, 162, 39, 0.3);
    border-radius: var(--radius-full);
    color: var(--color-text-secondary);
    cursor: pointer;
    transition: var(--transition-fast);
}

.vocab-tab:hover {
    border-color: var(--color-gold);
    color: var(--color-gold);
}

.vocab-tab.active {
    background: var(--color-gold);
    border-color: var(--color-gold);
    color: var(--color-void);
}

.vocab-display {
    min-height: 200px;
}

.vocab-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: var(--space-lg);
}

.vocab-card {
    background: var(--color-volcanic);
    border: 1px solid rgba(201, 162, 39, 0.2);
    border-radius: var(--radius-lg);
    padding: var(--space-lg);
}

.vocab-word {
    font-family: var(--font-display);
    font-size: var(--text-xl);
    color: var(--color-text-primary);
    margin-bottom: var(--space-xs);
}

.vocab-meaning {
    font-size: var(--text-sm);
    color: var(--color-text-secondary);
    margin-bottom: var(--space-md);
}

.vocab-calculation {
    margin-bottom: var(--space-sm);
}

.calc-text {
    font-family: var(--font-mono);
    font-size: var(--text-sm);
    color: var(--color-text-muted);
}

.vocab-d {
    display: inline-block;
    padding: var(--space-xs) var(--space-md);
    border-radius: var(--radius-full);
    font-size: var(--text-sm);
    color: white;
    margin-bottom: var(--space-sm);
}

.vocab-significance {
    font-size: var(--text-sm);
    color: var(--color-gold);
    font-style: italic;
}

/* ═══════════════════════════════════════════════════════════════════════════
   ANALYZER SECTION
   ═══════════════════════════════════════════════════════════════════════════ */

.analyzer-section {
    padding: var(--space-2xl) 0;
}

.analyzer-section h2 {
    font-family: var(--font-display);
    font-size: var(--text-3xl);
    color: var(--color-gold);
    text-align: center;
    margin-bottom: var(--space-md);
}

.analyzer-box {
    max-width: 600px;
    margin: 0 auto var(--space-xl);
    padding: var(--space-xl);
    background: var(--color-volcanic);
    border: 1px solid rgba(201, 162, 39, 0.3);
    border-radius: var(--radius-lg);
}

.analyzer-input-wrapper {
    display: flex;
    gap: var(--space-md);
    margin-bottom: var(--space-md);
}

.analyzer-input {
    flex: 1;
    padding: var(--space-md) var(--space-lg);
    font-size: var(--text-lg);
    background: var(--color-ocean);
    border: 2px solid rgba(201, 162, 39, 0.3);
    border-radius: var(--radius-md);
    color: var(--color-text-primary);
}

.analyzer-input:focus {
    outline: none;
    border-color: var(--color-gold);
}

.analyze-btn {
    padding: var(--space-md) var(--space-xl);
    font-size: var(--text-base);
    font-weight: 600;
    letter-spacing: 0.1em;
    background: linear-gradient(135deg, var(--color-gold) 0%, var(--color-gold-dim) 100%);
    border: none;
    border-radius: var(--radius-md);
    color: var(--color-void);
    cursor: pointer;
    transition: var(--transition-base);
}

.analyze-btn:hover {
    background: linear-gradient(135deg, var(--color-gold-bright) 0%, var(--color-gold) 100%);
}

.analyzer-hint {
    font-size: var(--text-sm);
    color: var(--color-text-muted);
    text-align: center;
}

/* Analysis Result */
.analysis-result {
    display: none;
    max-width: 600px;
    margin: 0 auto;
    padding: var(--space-xl);
    background: var(--color-ocean);
    border: 1px solid rgba(201, 162, 39, 0.3);
    border-radius: var(--radius-lg);
}

.analysis-result.visible {
    display: block;
    animation: fadeIn 0.3s ease;
}

@keyframes fadeIn {
    from { opacity: 0; transform: translateY(10px); }
    to { opacity: 1; transform: translateY(0); }
}

.analysis-header {
    display: flex;
    align-items: center;
    gap: var(--space-md);
    margin-bottom: var(--space-lg);
    padding-bottom: var(--space-md);
    border-bottom: 1px solid rgba(201, 162, 39, 0.2);
}

.analysis-barthel, .analysis-word {
    font-family: var(--font-display);
    font-size: var(--text-2xl);
    color: var(--color-text-primary);
}

.analysis-d {
    padding: var(--space-xs) var(--space-md);
    border-radius: var(--radius-full);
    font-family: var(--font-mono);
    font-weight: bold;
    color: white;
}

.analysis-info {
    display: flex;
    gap: var(--space-md);
    margin-bottom: var(--space-sm);
}

.info-label {
    color: var(--color-text-muted);
    min-width: 100px;
}

.info-value {
    color: var(--color-text-primary);
}

.analysis-note, .emergent-note {
    padding: var(--space-md);
    background: rgba(201, 162, 39, 0.1);
    border-radius: var(--radius-md);
    font-size: var(--text-sm);
    color: var(--color-text-secondary);
    margin-bottom: var(--space-md);
}

.emergent-note {
    background: rgba(155, 89, 182, 0.1);
    border-left: 3px solid var(--d5-color);
}

.analysis-modes {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-md);
    margin-top: var(--space-lg);
}

.mode-box {
    padding: var(--space-md);
    border-radius: var(--radius-md);
}

.mode-box.s-plus {
    background: rgba(63, 185, 80, 0.1);
    border: 1px solid rgba(63, 185, 80, 0.3);
}

.mode-box.s-minus {
    background: rgba(155, 89, 182, 0.1);
    border: 1px solid rgba(155, 89, 182, 0.3);
}

.mode-box h4 {
    font-size: var(--text-sm);
    color: var(--color-text-muted);
    margin-bottom: var(--space-sm);
}

.mode-name {
    display: block;
    font-weight: 600;
    color: var(--color-text-primary);
}

.mode-meaning {
    display: block;
    font-size: var(--text-sm);
    color: var(--color-text-secondary);
}

/* Word Analysis Breakdown */
.analysis-breakdown {
    margin-bottom: var(--space-lg);
}

.analysis-breakdown h4 {
    font-size: var(--text-sm);
    color: var(--color-text-muted);
    margin-bottom: var(--space-sm);
}

.step {
    padding: var(--space-sm) var(--space-md);
    background: rgba(255, 255, 255, 0.03);
    border-radius: var(--radius-sm);
    margin-bottom: var(--space-xs);
    font-family: var(--font-mono);
    font-size: var(--text-sm);
}

.letter {
    color: var(--color-gold);
}

.analysis-result-box {
    display: flex;
    align-items: center;
    gap: var(--space-md);
    padding: var(--space-md);
    background: rgba(201, 162, 39, 0.1);
    border-radius: var(--radius-md);
    margin-bottom: var(--space-md);
}

.result-label {
    color: var(--color-text-muted);
}

.result-value {
    font-family: var(--font-mono);
    font-size: var(--text-xl);
    font-weight: bold;
}

.analysis-meaning {
    padding: var(--space-md);
    background: rgba(255, 255, 255, 0.03);
    border-radius: var(--radius-md);
}

.meaning-label {
    display: block;
    font-size: var(--text-sm);
    color: var(--color-text-muted);
    margin-bottom: var(--space-xs);
}

.meaning-value {
    color: var(--color-text-primary);
}

/* Session Summary */
.session-summary {
    text-align: center;
}

.session-summary h3 {
    font-size: var(--text-xl);
    color: var(--color-gold);
    margin-bottom: var(--space-lg);
}

.summary-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--space-md);
    margin-bottom: var(--space-lg);
}

.summary-item {
    padding: var(--space-md);
    background: rgba(255, 255, 255, 0.03);
    border-radius: var(--radius-md);
}

.summary-value {
    display: block;
    font-family: var(--font-mono);
    font-size: var(--text-2xl);
    color: var(--color-gold);
}

.summary-label {
    font-size: var(--text-xs);
    color: var(--color-text-muted);
}

.summary-rhythm {
    padding: var(--space-md);
    background: rgba(63, 185, 80, 0.1);
    border-radius: var(--radius-md);
}

.summary-rhythm p {
    color: var(--color-text-secondary);
    margin: var(--space-xs) 0;
}

/* ═══════════════════════════════════════════════════════════════════════════
   INTEGRATION SECTION
   ═══════════════════════════════════════════════════════════════════════════ */

.integration-section {
    padding: var(--space-2xl) 0;
}

.integration-section h2 {
    font-family: var(--font-display);
    font-size: var(--text-3xl);
    color: var(--color-gold);
    text-align: center;
    margin-bottom: var(--space-xl);
}

.integration-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: var(--space-xl);
}

.integration-item {
    background: var(--color-volcanic);
    border: 1px solid rgba(201, 162, 39, 0.2);
    border-radius: var(--radius-lg);
    padding: var(--space-xl);
}

.integration-item h3 {
    font-size: var(--text-xl);
    color: var(--color-gold);
    margin-bottom: var(--space-md);
}

.integration-item p {
    color: var(--color-text-secondary);
    line-height: 1.6;
    margin-bottom: var(--space-md);
}

.integration-link {
    color: var(--d8-color);
    text-decoration: none;
    font-size: var(--text-sm);
    transition: var(--transition-fast);
}

.integration-link:hover {
    color: var(--color-gold);
}

/* ═══════════════════════════════════════════════════════════════════════════
   MODAL
   ═══════════════════════════════════════════════════════════════════════════ */

.modal {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: var(--z-modal);
    background: rgba(10, 15, 20, 0.9);
    backdrop-filter: blur(8px);
}

.modal.visible {
    display: flex;
    justify-content: center;
    align-items: center;
    padding: var(--space-xl);
}

.modal-content {
    position: relative;
    max-width: 600px;
    width: 100%;
    max-height: 90vh;
    overflow-y: auto;
    background: var(--color-volcanic);
    border: 1px solid rgba(201, 162, 39, 0.4);
    border-radius: var(--radius-xl);
    padding: var(--space-2xl);
}

.modal-close {
    position: absolute;
    top: var(--space-md);
    right: var(--space-md);
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: var(--text-2xl);
    background: transparent;
    border: 1px solid rgba(201, 162, 39, 0.3);
    border-radius: var(--radius-full);
    color: var(--color-text-muted);
    cursor: pointer;
    transition: var(--transition-fast);
}

.modal-close:hover {
    border-color: var(--color-gold);
    color: var(--color-gold);
}

/* Position Detail */
.position-detail {
    padding-top: var(--space-lg);
}

.position-header {
    display: flex;
    align-items: center;
    gap: var(--space-lg);
    margin-bottom: var(--space-xl);
}

.position-number {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 60px;
    height: 60px;
    border-radius: var(--radius-full);
    font-size: var(--text-2xl);
    font-weight: bold;
    color: white;
}

.position-info h3 {
    font-size: var(--text-2xl);
    color: var(--color-text-primary);
    margin-bottom: var(--space-xs);
}

.position-meaning {
    color: var(--color-text-secondary);
}

.emergent-badge {
    padding: var(--space-md);
    background: rgba(155, 89, 182, 0.15);
    border: 1px solid rgba(155, 89, 182, 0.3);
    border-radius: var(--radius-md);
    color: var(--d5-color);
    font-size: var(--text-sm);
    text-align: center;
    margin-bottom: var(--space-xl);
}

.position-section {
    margin-bottom: var(--space-xl);
}

.position-section h4 {
    font-size: var(--text-sm);
    color: var(--color-text-muted);
    letter-spacing: 0.1em;
    margin-bottom: var(--space-md);
}

.position-section p {
    color: var(--color-text-secondary);
}

.mode-comparison {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-md);
}

.mode-item {
    padding: var(--space-md);
    background: rgba(255, 255, 255, 0.03);
    border-radius: var(--radius-md);
}

.mode-label {
    display: block;
    font-size: var(--text-xs);
    color: var(--color-text-muted);
    margin-bottom: var(--space-xs);
}

.mode-value {
    display: block;
    font-weight: 600;
    color: var(--color-text-primary);
    margin-bottom: var(--space-xs);
}

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

.glyph-example {
    display: flex;
    gap: var(--space-md);
    padding: var(--space-sm) var(--space-md);
    background: rgba(201, 162, 39, 0.1);
    border-radius: var(--radius-md);
}

.glyph-barthel {
    font-family: var(--font-mono);
    color: var(--color-gold);
}

.glyph-desc {
    color: var(--color-text-secondary);
}

.triaxial-coords {
    font-family: var(--font-mono);
    color: var(--color-gold);
    padding: var(--space-md);
    background: rgba(201, 162, 39, 0.1);
    border-radius: var(--radius-md);
}

/* ═══════════════════════════════════════════════════════════════════════════
   FOOTER
   ═══════════════════════════════════════════════════════════════════════════ */

.unified-footer {
    text-align: center;
    padding: var(--space-3xl) var(--space-xl);
    margin-top: var(--space-3xl);
    border-top: 1px solid rgba(201, 162, 39, 0.2);
}

.footer-logo {
    font-family: var(--font-display);
    font-size: var(--text-lg);
    letter-spacing: 0.2em;
    color: var(--color-gold);
    margin-bottom: var(--space-sm);
}

.footer-tagline {
    font-size: var(--text-sm);
    color: var(--color-text-muted);
    margin-bottom: var(--space-sm);
}

.footer-equation {
    font-family: var(--font-mono);
    font-size: var(--text-sm);
    color: var(--d3-color);
    margin-bottom: var(--space-md);
}

.footer-principle {
    font-family: var(--font-mono);
    font-size: var(--text-sm);
    color: var(--color-gold-dim);
    margin-bottom: var(--space-lg);
}

.footer-credit {
    font-size: var(--text-xs);
    color: var(--color-text-muted);
}

/* ═══════════════════════════════════════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════════════════════════════════════ */

@media (max-width: 1024px) {
    .status-panels {
        grid-template-columns: 1fr;
    }

    .explanation-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 768px) {
    :root {
        --text-4xl: 2rem;
        --text-3xl: 1.5rem;
    }

    .rongorongo-container {
        padding: var(--space-3xl) var(--space-md) var(--space-xl);
    }

    .unified-nav {
        padding: var(--space-sm) var(--space-md);
    }

    .nav-signature {
        display: none;
    }

    .analyzer-input-wrapper {
        flex-direction: column;
    }

    .analyze-btn {
        width: 100%;
    }

    .analysis-modes {
        grid-template-columns: 1fr;
    }

    .summary-grid {
        grid-template-columns: 1fr 1fr;
    }

    .mode-comparison {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 480px) {
    .wheel-container {
        transform: scale(0.8);
    }

    .insight-calculation {
        font-size: var(--text-sm);
    }

    .emergent-example {
        flex-direction: column;
        text-align: center;
    }
}

/* ═══════════════════════════════════════════════════════════════════════════
   ACCESSIBILITY
   ═══════════════════════════════════════════════════════════════════════════ */

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

    .tablet.flipping {
        animation: none;
    }
}

@media (prefers-contrast: high) {
    :root {
        --color-gold: #ffd700;
        --color-text-primary: #ffffff;
    }
}

/* ═══════════════════════════════════════════════════════════════════════════
   END OF STYLESHEET
   Q² = -1 = THE FLIP
   RONGORONGO = D₃ = HEALER
   [1 = -1]
   ═══════════════════════════════════════════════════════════════════════════ */
