/* ==========================================================================
   ram.md - Markdown Editor Aesthetic
   ========================================================================== */

/* CSS Custom Properties - Centralized theming */
:root {
    /* Colors - Dark theme mimicking text editors */
    --color-background: #1e1e1e;
    --color-surface: #252526;
    --color-border: #3c3c3c;
    --color-text: #d4d4d4;
    --color-text-muted: #808080;
    --color-text-dim: #6a6a6a;
    --color-accent: #569cd6;
    --color-accent-hover: #4fc3f7;
    --color-success: #6a9955;
    --color-warning: #dcdcaa;
    --color-error: #f44747;
    --color-cost: #ce9178;
    --color-header: #4ec9b0;
    --color-blockquote: #608b4e;

    /* Typography */
    --font-mono: 'Consolas', 'Fira Code', 'JetBrains Mono', 'Monaco', 'Courier New', monospace;
    --font-size-base: 14px;
    --font-size-small: 12px;
    --font-size-large: 16px;
    --font-size-h1: 24px;
    --font-size-h2: 20px;
    --font-size-h3: 16px;

    /* Spacing */
    --spacing-xs: 4px;
    --spacing-sm: 8px;
    --spacing-md: 16px;
    --spacing-lg: 24px;
    --spacing-xl: 32px;

    /* Layout */
    --max-width: 800px;
    --line-height: 1.6;
}

/* Reset and base styles */
*, *::before, *::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

html {
    font-size: var(--font-size-base);
}

body {
    font-family: var(--font-mono);
    background-color: var(--color-background);
    color: var(--color-text);
    line-height: var(--line-height);
    min-height: 100vh;
    padding: var(--spacing-md);
}

/* Game container */
#game-container {
    max-width: var(--max-width);
    margin: 0 auto;
    background-color: var(--color-surface);
    border: 1px solid var(--color-border);
    padding: var(--spacing-lg);
}

/* ==========================================================================
   Header
   ========================================================================== */

#game-header {
    margin-bottom: var(--spacing-lg);
    border-bottom: 1px solid var(--color-border);
    padding-bottom: var(--spacing-md);
}

#game-header h1 {
    font-size: var(--font-size-h1);
    font-weight: normal;
    color: var(--color-header);
    margin-bottom: var(--spacing-sm);
}

#simulation-depth {
    color: var(--color-accent);
    font-size: var(--font-size-base);
}

/* ==========================================================================
   Stage Banner
   ========================================================================== */

#stage-banner {
    margin-bottom: var(--spacing-lg);
}

#stage-title {
    font-size: var(--font-size-h2);
    font-weight: normal;
    color: var(--color-header);
    margin-bottom: var(--spacing-sm);
}

#stage-flavor {
    color: var(--color-blockquote);
    font-style: italic;
    padding-left: var(--spacing-md);
    border-left: 3px solid var(--color-border);
}

/* ==========================================================================
   Resources Panel
   ========================================================================== */

#resources-panel {
    margin-bottom: var(--spacing-lg);
}

#resources-panel h3 {
    font-size: var(--font-size-h3);
    font-weight: normal;
    color: var(--color-header);
    margin-bottom: var(--spacing-sm);
}

.resource-item {
    margin-bottom: var(--spacing-xs);
    display: flex;
    align-items: baseline;
    gap: var(--spacing-sm);
}

.resource-name {
    color: var(--color-text-muted);
}

.resource-value {
    color: var(--color-warning);
    font-weight: bold;
    min-width: 100px;
}

.resource-rate {
    color: var(--color-text-dim);
    font-size: var(--font-size-small);
}

/* ==========================================================================
   Progress Section
   ========================================================================== */

#progress-section {
    margin-bottom: var(--spacing-lg);
}

#progress-bar-container {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
}

#progress-bar {
    color: var(--color-success);
    font-family: var(--font-mono);
    letter-spacing: 0;
}

#progress-text {
    color: var(--color-text-muted);
    font-size: var(--font-size-small);
}

/* ==========================================================================
   Action Area
   ========================================================================== */

#action-area {
    margin-bottom: var(--spacing-lg);
    text-align: center;
}

.action-button {
    font-family: var(--font-mono);
    font-size: var(--font-size-large);
    background-color: var(--color-background);
    color: var(--color-accent);
    border: 1px solid var(--color-accent);
    padding: var(--spacing-md) var(--spacing-xl);
    cursor: pointer;
    transition: all 0.15s ease;
}

.action-button:hover {
    background-color: var(--color-accent);
    color: var(--color-background);
}

.action-button:active {
    transform: scale(0.98);
}

.action-button:focus {
    outline: 2px solid var(--color-accent-hover);
    outline-offset: 2px;
}

#click-power {
    margin-top: var(--spacing-sm);
    color: var(--color-text-dim);
    font-size: var(--font-size-small);
}

/* ==========================================================================
   Section Divider
   ========================================================================== */

.section-divider {
    border: none;
    border-top: 1px solid var(--color-border);
    margin: var(--spacing-lg) 0;
}

/* ==========================================================================
   Upgrades Panel
   ========================================================================== */

#upgrades-panel {
    margin-bottom: var(--spacing-lg);
}

#upgrades-panel h3 {
    font-size: var(--font-size-h3);
    font-weight: normal;
    color: var(--color-header);
    margin-bottom: var(--spacing-md);
}

#upgrades-list {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
}

.upgrade-item {
    padding: var(--spacing-sm);
    border: 1px solid transparent;
    cursor: pointer;
    transition: all 0.15s ease;
}

.upgrade-item:hover:not(.upgrade-maxed):not(.upgrade-locked) {
    border-color: var(--color-border);
    background-color: var(--color-background);
}

.upgrade-item.upgrade-affordable {
    border-color: var(--color-success);
}

.upgrade-item.upgrade-affordable:hover {
    background-color: rgba(106, 153, 85, 0.1);
}

.upgrade-item.upgrade-locked {
    opacity: 0.5;
    cursor: not-allowed;
}

.upgrade-item.upgrade-maxed {
    opacity: 0.7;
    cursor: default;
}

.upgrade-header {
    display: flex;
    align-items: baseline;
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-xs);
}

.upgrade-checkbox {
    color: var(--color-text-muted);
}

.upgrade-maxed .upgrade-checkbox {
    color: var(--color-success);
}

.upgrade-name {
    color: var(--color-text);
}

.upgrade-cost {
    color: var(--color-cost);
    margin-left: auto;
}

.upgrade-affordable .upgrade-cost {
    color: var(--color-success);
}

.upgrade-count {
    color: var(--color-text-dim);
    font-size: var(--font-size-small);
}

.upgrade-flavor {
    color: var(--color-blockquote);
    font-style: italic;
    font-size: var(--font-size-small);
    padding-left: var(--spacing-lg);
    margin-bottom: var(--spacing-xs);
}

.upgrade-effect {
    color: var(--color-accent);
    font-size: var(--font-size-small);
    padding-left: var(--spacing-lg);
}

/* ==========================================================================
   Statistics Panel
   ========================================================================== */

#stats-panel h3 {
    font-size: var(--font-size-h3);
    font-weight: normal;
    color: var(--color-header);
    margin-bottom: var(--spacing-sm);
}

#stats-list {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-xs);
}

.stat-item {
    color: var(--color-text-muted);
    font-size: var(--font-size-small);
}

.stat-item span {
    color: var(--color-text);
}

/* ==========================================================================
   News Ticker
   ========================================================================== */

#news-ticker {
    margin-top: var(--spacing-lg);
    padding-top: var(--spacing-md);
    border-top: 1px solid var(--color-border);
    overflow: hidden;
    white-space: nowrap;
}

.ticker-label {
    color: var(--color-warning);
    font-weight: bold;
    margin-right: var(--spacing-sm);
}

#ticker-content {
    color: var(--color-text-muted);
    animation: ticker-fade 8s ease-in-out infinite;
}

@keyframes ticker-fade {
    0%, 100% { opacity: 1; }
    45%, 55% { opacity: 1; }
    50% { opacity: 0.3; }
}

/* ==========================================================================
   Modal Styles
   ========================================================================== */

.modal {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.8);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 1000;
}

.modal.hidden {
    display: none;
}

.modal-content {
    background-color: var(--color-surface);
    border: 1px solid var(--color-border);
    padding: var(--spacing-xl);
    max-width: 600px;
    width: 90%;
    max-height: 80vh;
    overflow-y: auto;
}

.modal-content h2 {
    font-size: var(--font-size-h2);
    font-weight: normal;
    color: var(--color-header);
    margin-bottom: var(--spacing-lg);
}

#welcome-back-message,
#prestige-message {
    color: var(--color-text);
    margin-bottom: var(--spacing-lg);
    line-height: 1.8;
}

#welcome-back-message p,
#prestige-message p {
    margin-bottom: var(--spacing-sm);
}

.prestige-buttons {
    display: flex;
    gap: var(--spacing-md);
    justify-content: center;
}

/* ==========================================================================
   Utility Classes
   ========================================================================== */

.hidden {
    display: none !important;
}

.text-success {
    color: var(--color-success);
}

.text-warning {
    color: var(--color-warning);
}

.text-error {
    color: var(--color-error);
}

/* ==========================================================================
   Responsive Adjustments
   ========================================================================== */

@media (max-width: 600px) {
    body {
        padding: var(--spacing-sm);
    }

    #game-container {
        padding: var(--spacing-md);
    }

    .upgrade-header {
        flex-wrap: wrap;
    }

    .upgrade-cost {
        margin-left: 0;
        width: 100%;
        padding-left: var(--spacing-lg);
    }

    .prestige-buttons {
        flex-direction: column;
    }
}
