/* ============================================
   WHEN HELL CAME - GOTHIC EMBER HYBRID THEME
   Shared CSS for all game screens

   Version: 1.0
   Last Updated: 2025-12-06

   Usage: Link this file in <head>:
   <link rel="stylesheet" href="styles/gothic-ember-theme.css">
   or for /tools/ subdirectory:
   <link rel="stylesheet" href="../styles/gothic-ember-theme.css">
   ============================================ */

/* Google Fonts Import */
@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@400;600;700&family=IM+Fell+English:ital@0;1&family=Spectral:ital,wght@0,400;0,600;1,400&family=Crimson+Text:ital,wght@0,400;0,600;1,400&display=swap');

/* ============================================
   CSS CUSTOM PROPERTIES (VARIABLES)
   ============================================ */

:root {
    /* Primary Accent - Gold */
    --accent-primary: #c9a227;
    --accent-secondary: #6b5a2e;
    --accent-bright: #e8c84a;
    --accent-dim: #3d3425;

    /* Danger - Blood Red */
    --danger: #8b3535;
    --danger-bright: #d45555;
    --danger-dim: #5a2525;

    /* Success - Muted Green */
    --success: #558b2f;
    --success-bright: #9ccc65;
    --success-dim: #3d5a2d;

    /* Info - Muted Blue */
    --info: #1976d2;
    --info-bright: #64b5f6;
    --info-dim: #0d47a1;

    /* Text Colors */
    --text-primary: #c4b89a;
    --text-secondary: #888;
    --text-bright: #e8e0d0;
    --text-dim: #666;

    /* Background Colors */
    --bg-darkest: #0d0b09;
    --bg-dark: #1a1612;
    --bg-panel: rgba(13, 11, 9, 0.95);
    --bg-panel-hover: rgba(26, 22, 18, 0.95);
    --bg-overlay: rgba(0, 0, 0, 0.85);

    /* Border Colors */
    --border-primary: #3d3425;
    --border-accent: #6b5a2e;
    --border-bright: #c9a227;

    /* Glow Effects */
    --glow-gold: rgba(201, 162, 39, 0.4);
    --glow-gold-strong: rgba(201, 162, 39, 0.6);
    --glow-danger: rgba(139, 53, 53, 0.5);
    --glow-success: rgba(85, 139, 47, 0.5);

    /* Class Colors - Subtle/Muted versions */
    --class-ranger: #6b8f5e;
    --class-rogue: #7a6b8a;
    --class-warrior: #8b5a5a;
    --class-paladin: #c9a227;
    --class-priest: #a8a8a8;
    --class-mage: #5a7a9a;

    /* Spacing */
    --spacing-xs: 4px;
    --spacing-sm: 8px;
    --spacing-md: 15px;
    --spacing-lg: 25px;
    --spacing-xl: 40px;

    /* Border Radius */
    --radius-sm: 4px;
    --radius-md: 6px;
    --radius-lg: 8px;

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

    /* Font Families */
    --font-heading: 'Cinzel', serif;
    --font-body: 'IM Fell English', serif;
    --font-body-alt: 'Spectral', serif;
    --font-ui: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
}

/* ============================================
   BASE RESET & BODY
   ============================================ */

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

body {
    font-family: var(--font-ui);
    background: linear-gradient(180deg, var(--bg-dark) 0%, var(--bg-darkest) 100%);
    color: #e0e0e0;
    min-height: 100vh;
    line-height: 1.6;
}

/* Subtle background glow effect */
body::before {
    content: '';
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: radial-gradient(ellipse at center top, rgba(201, 162, 39, 0.03) 0%, transparent 50%);
    pointer-events: none;
    z-index: 0;
}

/* ============================================
   TYPOGRAPHY
   ============================================ */

h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-heading);
    color: var(--accent-primary);
    font-weight: 400;
}

h1 {
    font-size: 2.8rem;
    letter-spacing: 3px;
    text-shadow: 0 0 30px var(--glow-gold);
    margin-bottom: var(--spacing-lg);
    text-align: center;
}

h2 {
    font-size: 1.8rem;
    color: var(--accent-secondary);
    letter-spacing: 2px;
    margin-bottom: var(--spacing-md);
}

h3 {
    font-size: 1.4rem;
    letter-spacing: 1px;
    margin-bottom: var(--spacing-sm);
}

h4 {
    font-size: 1.1rem;
    color: var(--accent-secondary);
    text-transform: uppercase;
    letter-spacing: 1px;
    margin-bottom: var(--spacing-sm);
}

/* ============================================
   CONTAINER
   ============================================ */

.container {
    max-width: 1400px;
    margin: 0 auto;
    padding: 0 20px;
    position: relative;
    z-index: 1;
}

/* ============================================
   BUTTONS
   ============================================ */

button, .btn {
    font-family: var(--font-heading);
    background: linear-gradient(180deg, #4a3f2a 0%, #2d2518 100%);
    border: 1px solid var(--border-accent);
    border-radius: var(--radius-md);
    color: var(--accent-primary);
    padding: 12px 24px;
    font-size: 0.95rem;
    cursor: pointer;
    letter-spacing: 0.5px;
    transition: all var(--transition-normal);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
}

button:hover:not(:disabled), .btn:hover:not(:disabled) {
    background: linear-gradient(180deg, #5a4f3a 0%, #3d3528 100%);
    border-color: var(--accent-primary);
    box-shadow: 0 0 20px var(--glow-gold), 0 4px 12px rgba(0, 0, 0, 0.4);
    transform: translateY(-2px);
}

button:active:not(:disabled), .btn:active:not(:disabled) {
    transform: translateY(0);
    box-shadow: 0 0 15px var(--glow-gold);
}

/* Primary Button */
button.primary, .btn.primary,
button.enter, .btn.enter {
    background: linear-gradient(180deg, #6b5a2e 0%, #4a3f2a 100%);
    border-color: var(--accent-primary);
    color: var(--accent-bright);
    box-shadow: 0 0 10px rgba(201, 162, 39, 0.2), 0 2px 8px rgba(0, 0, 0, 0.3);
}

button.primary:hover:not(:disabled), .btn.primary:hover:not(:disabled),
button.enter:hover:not(:disabled), .btn.enter:hover:not(:disabled) {
    background: linear-gradient(180deg, #8b7535 0%, #5a4a25 100%);
    box-shadow: 0 0 25px var(--glow-gold), 0 4px 12px rgba(0, 0, 0, 0.4);
}

/* Secondary/Import Button */
button.import, .btn.import,
button.secondary, .btn.secondary {
    background: linear-gradient(180deg, #4a3f2a 0%, #2d2518 100%);
    border-color: var(--border-accent);
    color: var(--accent-primary);
}

/* Danger Button */
button.danger, .btn.danger,
button.condemn, .btn.condemn {
    background: linear-gradient(180deg, #5a2525 0%, #3a1818 100%);
    border-color: var(--danger);
    color: var(--danger-bright);
}

button.danger:hover:not(:disabled), .btn.danger:hover:not(:disabled),
button.condemn:hover:not(:disabled), .btn.condemn:hover:not(:disabled) {
    background: linear-gradient(180deg, #6a3030 0%, #4a2020 100%);
    border-color: var(--danger-bright);
    box-shadow: 0 0 20px var(--glow-danger), 0 4px 12px rgba(0, 0, 0, 0.4);
}

/* Success Button */
button.success, .btn.success {
    background: linear-gradient(180deg, var(--success-dim) 0%, #2d4a1d 100%);
    border-color: var(--success);
    color: var(--success-bright);
}

button.success:hover:not(:disabled), .btn.success:hover:not(:disabled) {
    box-shadow: 0 0 20px var(--glow-success), 0 4px 12px rgba(0, 0, 0, 0.4);
}

/* Disabled Button */
button:disabled, .btn:disabled {
    background: linear-gradient(180deg, #2a2520 0%, #1a1815 100%);
    border-color: #333;
    color: #555;
    cursor: not-allowed;
    box-shadow: none;
    transform: none;
}

button:disabled:hover, .btn:disabled:hover {
    transform: none;
    box-shadow: none;
}

/* ============================================
   PANELS & CARDS
   ============================================ */

.panel, .card, .slot-card {
    background: linear-gradient(180deg, var(--bg-panel-hover) 0%, var(--bg-panel) 100%);
    border: 1px solid var(--border-primary);
    border-radius: var(--radius-lg);
    padding: var(--spacing-lg);
    transition: all var(--transition-normal);
    position: relative;
    overflow: hidden;
}

/* Top glow accent for panels */
.panel::before, .card::before, .slot-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 80px;
    background: linear-gradient(180deg, rgba(201, 162, 39, 0.06) 0%, transparent 100%);
    pointer-events: none;
}

.panel:hover, .card:hover, .slot-card:hover {
    border-color: var(--border-accent);
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.5), 0 0 25px var(--glow-gold);
    transform: translateY(-3px);
}

/* Panel Header */
.panel-header, .card-header {
    font-family: var(--font-heading);
    font-size: 1.1rem;
    color: var(--accent-primary);
    padding-bottom: var(--spacing-sm);
    margin-bottom: var(--spacing-md);
    border-bottom: 1px solid var(--border-primary);
    text-shadow: 0 0 15px var(--glow-gold);
}

/* Panel Title (for slot cards, etc.) */
.slot-name, .panel-title, .card-title {
    font-family: var(--font-heading);
    font-size: 1.6rem;
    color: var(--accent-primary);
    text-align: center;
    text-shadow: 0 0 20px var(--glow-gold);
    letter-spacing: 2px;
    margin-bottom: var(--spacing-md);
}

/* ============================================
   STAT BOXES
   ============================================ */

.stat, .stat-box {
    background: rgba(0, 0, 0, 0.4);
    border: 1px solid var(--border-primary);
    border-radius: var(--radius-md);
    padding: var(--spacing-md);
    text-align: center;
    transition: all var(--transition-fast);
}

.stat:hover, .stat-box:hover {
    border-color: var(--accent-dim);
    box-shadow: 0 0 15px rgba(201, 162, 39, 0.1);
}

.stat-label {
    font-family: var(--font-heading);
    font-size: 0.75rem;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 1px;
    margin-bottom: var(--spacing-xs);
}

.stat-value {
    font-family: var(--font-heading);
    font-size: 1.5rem;
    font-weight: 600;
    color: var(--text-primary);
    text-shadow: 0 0 10px currentColor;
}

/* Stat Value Colors */
.stat-value.xp { color: var(--info-bright); }
.stat-value.despair { color: var(--danger-bright); }
.stat-value.attempts { color: var(--text-primary); }
.stat-value.tokens { color: var(--accent-bright); }
.stat-value.heroes, .stat-value.supplies { color: var(--success-bright); }
.stat-value.faith { color: var(--info-bright); }
.stat-value.doom { color: var(--danger-bright); }
.stat-value.actions { color: var(--accent-primary); }
.stat-value.draw { color: var(--success-bright); }

/* ============================================
   STATUS INDICATORS
   ============================================ */

.status {
    text-align: center;
    padding: 12px 20px;
    border-radius: var(--radius-md);
    font-family: var(--font-body);
    font-size: 1rem;
    transition: all var(--transition-fast);
}

.status.empty {
    background: rgba(139, 53, 53, 0.15);
    border: 1px solid rgba(139, 53, 53, 0.3);
    color: var(--danger-bright);
}

.status.ready {
    background: rgba(85, 139, 47, 0.15);
    border: 1px solid rgba(85, 139, 47, 0.3);
    color: var(--success-bright);
}

.status.active {
    background: rgba(201, 162, 39, 0.15);
    border: 1px solid rgba(201, 162, 39, 0.3);
    color: var(--accent-primary);
}

/* ============================================
   GRIDS
   ============================================ */

.slot-grid, .world-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--spacing-lg);
    margin-bottom: var(--spacing-xl);
}

.slot-stats {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 12px;
    margin-bottom: var(--spacing-md);
}

@media (max-width: 800px) {
    .slot-grid, .world-grid {
        grid-template-columns: 1fr;
    }
}

/* ============================================
   SLOT ACTIONS
   ============================================ */

.slot-actions {
    display: flex;
    gap: 10px;
    justify-content: center;
    flex-wrap: wrap;
    margin-top: var(--spacing-md);
}

/* ============================================
   LINKS
   ============================================ */

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

a:hover {
    color: var(--accent-primary);
    text-shadow: 0 0 15px var(--glow-gold);
}

.tools-link {
    text-align: center;
    margin-top: var(--spacing-xl);
    padding: var(--spacing-lg);
    background: var(--bg-panel);
    border: 1px solid var(--border-primary);
    border-radius: var(--radius-lg);
}

.tools-link a {
    font-family: var(--font-heading);
    font-size: 1rem;
    letter-spacing: 1px;
}

/* ============================================
   DIVIDERS
   ============================================ */

.divider, .party-separator {
    height: 2px;
    background: linear-gradient(90deg, transparent, var(--accent-secondary), var(--accent-primary), var(--accent-secondary), transparent);
    margin: var(--spacing-xl) 0;
    box-shadow: 0 0 15px var(--glow-gold);
}

/* ============================================
   MODALS & OVERLAYS
   ============================================ */

.modal-backdrop {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: var(--bg-overlay);
    z-index: 9998;
}

.modal {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    background: linear-gradient(180deg, var(--bg-dark) 0%, var(--bg-darkest) 100%);
    border: 2px solid var(--border-accent);
    border-radius: var(--radius-lg);
    padding: var(--spacing-lg);
    z-index: 9999;
    max-width: 90%;
    max-height: 90vh;
    overflow-y: auto;
    box-shadow: 0 0 60px rgba(0, 0, 0, 0.8), 0 0 30px var(--glow-gold);
}

.modal-header {
    font-family: var(--font-heading);
    font-size: 1.5rem;
    color: var(--accent-primary);
    text-shadow: 0 0 20px var(--glow-gold);
    margin-bottom: var(--spacing-md);
    padding-bottom: var(--spacing-sm);
    border-bottom: 1px solid var(--border-primary);
}

/* ============================================
   TABS
   ============================================ */

.tabs {
    display: flex;
    gap: 5px;
    margin-bottom: var(--spacing-lg);
    border-bottom: 2px solid var(--border-primary);
}

.tab-button {
    font-family: var(--font-heading);
    background: transparent;
    border: none;
    border-bottom: 3px solid transparent;
    border-radius: 0;
    padding: var(--spacing-md) var(--spacing-lg);
    color: var(--text-secondary);
    font-size: 1rem;
    letter-spacing: 1px;
    box-shadow: none;
}

.tab-button:hover {
    color: var(--accent-primary);
    background: transparent;
    transform: none;
    box-shadow: none;
}

.tab-button.active {
    color: var(--accent-primary);
    border-bottom-color: var(--accent-primary);
    text-shadow: 0 0 10px var(--glow-gold);
}

.tab-content {
    display: none;
}

.tab-content.active {
    display: block;
}

/* ============================================
   FORM ELEMENTS
   ============================================ */

input, select, textarea {
    font-family: var(--font-ui);
    background: rgba(0, 0, 0, 0.4);
    border: 1px solid var(--border-primary);
    border-radius: var(--radius-sm);
    color: var(--text-primary);
    padding: var(--spacing-sm) var(--spacing-md);
    transition: all var(--transition-fast);
}

input:focus, select:focus, textarea:focus {
    outline: none;
    border-color: var(--accent-secondary);
    box-shadow: 0 0 10px var(--glow-gold);
}

input:disabled, select:disabled {
    background: rgba(0, 0, 0, 0.2);
    color: var(--text-dim);
    cursor: not-allowed;
}

/* ============================================
   SCROLLBARS
   ============================================ */

::-webkit-scrollbar {
    width: 8px;
    height: 8px;
}

::-webkit-scrollbar-track {
    background: var(--bg-darkest);
}

::-webkit-scrollbar-thumb {
    background: var(--border-accent);
    border-radius: var(--radius-sm);
}

::-webkit-scrollbar-thumb:hover {
    background: var(--accent-secondary);
}

/* ============================================
   UTILITY CLASSES
   ============================================ */

.text-center { text-align: center; }
.text-left { text-align: left; }
.text-right { text-align: right; }

.text-gold { color: var(--accent-primary); }
.text-danger { color: var(--danger-bright); }
.text-success { color: var(--success-bright); }
.text-muted { color: var(--text-secondary); }

.glow-gold { text-shadow: 0 0 15px var(--glow-gold); }
.glow-danger { text-shadow: 0 0 15px var(--glow-danger); }

.mb-0 { margin-bottom: 0; }
.mb-sm { margin-bottom: var(--spacing-sm); }
.mb-md { margin-bottom: var(--spacing-md); }
.mb-lg { margin-bottom: var(--spacing-lg); }

/* ============================================
   STYLE NOTES FOR FUTURE IMPLEMENTATION

   DESPERATE MODE (Combat):
   - When desperate condition triggers, add class 'theme-desperate' to body
   - Override --accent-primary with #ff6b35 (ember orange)
   - Override --accent-secondary with #ff9f5a
   - Override --glow-gold with rgba(255, 107, 53, 0.4)
   - Add pulsing animation to center divider

   SHADOW THEME (Story Events):
   - Add class 'theme-shadow' to story container
   - Override --accent-primary with #8899aa
   - Override --accent-secondary with #556677
   - Use Crimson Text font for body

   EMBER THEME (Story Events):
   - Add class 'theme-ember' to story container
   - Override --accent-primary with #ff6b35
   - Override --accent-secondary with #ff9f5a
   - Use Spectral font for body
   ============================================ */
