/* --- LOAD LOCAL FONTS --- */
@font-face {
    font-family: 'Arvo';
    src: url('../fonts/Arvo.ttf') format('truetype');
    font-weight: normal;
}
@font-face {
    font-family: 'Open Sans';
    src: url('../fonts/OpenSans.ttf') format('truetype');
    font-weight: 400; 
}
@font-face {
    font-family: 'Open Sans';
    src: url('../fonts/OpenSans.ttf') format('truetype');
    font-weight: 700; 
}

/* --- THEME PALETTES --- */
:root, body.theme-classic {
    --bg-color: #2b2724;      
    --panel-bg: #3f3833;      
    --text-main: #f0eadd;     
    --border-color: #1a1614;  
    --accent-gold: #d4af37;   
    --accent-green: #4f8f4f;  
    --accent-red: #a83232;    
    --accent-blue: #4a7c8c;   
    --accent-spikes: #ffc107; /* NEW: Richer Gold for Spikes */
    --text-muted: #888888;
    --font-head: 'Arvo', serif;
    --font-body: 'Open Sans', sans-serif;
}
body.theme-architect {
    --bg-color: #0f172a; --panel-bg: #1e293b; --text-main: #cbd5e1; --border-color: #020617;  
    --accent-gold: #ffffff; --accent-green: #34d399; --accent-red: #fb7185; --accent-blue: #fb923c;   
    --accent-spikes: #fbbf24;  --text-muted: #64748b;
}
body.theme-artdeco {
    --bg-color: #131c17; --panel-bg: #1e2b24; --text-main: #e2e8f0; --border-color: #080c0a;  
    --accent-gold: #e1d1a1; --accent-green: #6ee7b7; --accent-red: #ef4444; --accent-blue: #7dd3fc;   
    --accent-spikes: #d4af37; --text-muted: #9ca3af; 
}
body.theme-cyber {
    --bg-color: #111111; --panel-bg: #1c1c1c; --text-main: #d4d4d4; --border-color: #000000;  
    --accent-gold: #22d3ee; --accent-green: #4ade80; --accent-red: #f87171; --accent-blue: #a78bfa;   
    --accent-spikes: #fde047;  --text-muted: #737373;
}
body.theme-victorian {
    --bg-color: #1c192b; --panel-bg: #2a253a; --text-main: #e2e8f0; --border-color: #0e0d16;  
    --accent-gold: #fca5a5; --accent-green: #34d399; --accent-red: #f87171; --accent-blue: #818cf8;   
    --accent-spikes: #fbbf24; --text-muted: #94a3b8;
}
body.theme-obsidian {
    --bg-color: #050505; --panel-bg: #121212; --text-main: #a3a3a3; --border-color: #000000;  
    --accent-gold: #3b82f6; --accent-green: #10b981; --accent-red: #ef4444; --accent-blue: #8b5cf6;   
    --accent-spikes: #f59e0b; --text-muted: #525252;
}
body.theme-paperwork {
    --bg-color: #d6d1c4; --panel-bg: #e8e4da; --text-main: #2d2a26; --border-color: #b0aba1;  
    --accent-gold: #1d4ed8; --accent-green: #047857; --accent-red: #b91c1c; --accent-blue: #c2410c;   
    --accent-spikes: #d97706; --text-muted: #78716c;
}
body.theme-sunset {
    --bg-color: #2e102e; --panel-bg: #421b3b; --text-main: #fed7aa; --border-color: #1f0b1f;  
    --accent-gold: #f97316; --accent-green: #fde047; --accent-red: #f43f5e; --accent-blue: #c084fc;   
    --accent-spikes: #facc15; --text-muted: #a1a1aa;
}
body.theme-highnoon {
            --bg-color: #d1bfae;      /* Pale dune sand */
            --panel-bg: #e6d5c3;      /* Bleached parchment */
            --text-main: #3d261d;     /* Deep brown text for contrast */
            --border-color: #a89582;  /* Slightly darker sand shadow */
            --accent-gold: #c2410c;   /* Burnt orange/rust for headings */
            --accent-green: #047857;  /* Deep cactus green */
            --accent-red: #be123c;    /* Brick red */
            --accent-blue: #0284c7;   /* Deep oasis blue */
            --accent-spikes: #b45309; /* Dark amber for spikes */
             --text-muted: #785a46;
        }
        body.theme-lunar {
            --bg-color: #1a1b1e;      /* Deep space grey */
            --panel-bg: #2a2d34;      /* Lunar dust grey */
            --text-main: #f8f9fa;     /* Stark white */
            --border-color: #0d0e11;  /* Void black */
            --accent-gold: #c0c0c0;   /* Metallic silver/grey instead of gold */
            --accent-green: #00f0ff;  /* Neon cyan (oxygen/life support) */
            --accent-red: #ff0055;    /* Neon magenta (warning) */
            --accent-blue: #6366f1;   /* Violet */
            --accent-spikes: #e2e8f0; /* Platinum/Silver spikes */
             --text-muted: #71717a;
        }

body { 
    background-color: var(--bg-color); color: var(--text-main); 
    font-family: var(--font-body); margin: 0; display: flex; flex-direction: column;
    height: 100vh; overflow: hidden; font-size: 13px;
}

::-webkit-scrollbar { width: 8px; }
::-webkit-scrollbar-track { background: var(--bg-color); }
::-webkit-scrollbar-thumb { background: var(--panel-bg); border-radius: 4px; border: 1px solid var(--border-color); }
::-webkit-scrollbar-thumb:hover { background: var(--accent-gold); }

h1, h2, h3 { font-family: var(--font-head); margin: 0; letter-spacing: 0.5px; }

#top-bar {
    display: flex; 
    flex-direction: row;
    flex-wrap: nowrap; 
    justify-content: space-between; 
    align-items: center;
    background: var(--panel-bg); 
    border-bottom: 3px solid var(--border-color);
    padding: 10px 20px; 
    min-height: 55px; 
    box-sizing: border-box;
    box-shadow: 0 2px 10px rgba(0,0,0,0.5); 
    z-index: 10;
    width: 100%;
    overflow-x: auto;
}

#top-bar h1 { 
    color: var(--accent-gold); 
    font-size: 24px; 
    text-transform: uppercase; 
    margin: 0;
    margin-right: 20px;
    flex-shrink: 0; 
}

.top-stats { 
    display: flex; 
    flex-direction: row;
    gap: 15px; 
    font-size: 14px; 
    align-items: center; 
    font-weight: 600; 
    flex-grow: 1; 
    white-space: nowrap; 
}

.stat-highlight { color: var(--accent-gold); font-weight: bold; font-size: 15px; }

.nav-icon-group { 
    display: flex; 
    flex-direction: row;
    gap: 8px; 
    align-items: center; 
    flex-shrink: 0; 
}

.nav-btn {
    background: transparent; border: 1px solid transparent; padding: 4px;
    display: flex; justify-content: center; align-items: center;
    border-radius: 4px; transition: all 0.2s; cursor: pointer;
}
.nav-btn canvas { opacity: 0.6; transition: 0.2s; pointer-events: none; }
.nav-btn:hover { background: rgba(0,0,0,0.3); border-color: var(--border-color); }
.nav-btn:hover canvas { opacity: 1; }
.nav-btn:active { transform: scale(0.95); }

#main-layout { display: flex; flex-grow: 1; overflow: hidden; padding: 12px; gap: 12px; }

.side-panel { 
    width: 330px; display: flex; flex-direction: column; gap: 10px; 
    background: var(--panel-bg); border: 2px solid var(--border-color); padding: 12px;
    border-radius: 4px; box-shadow: inset 0 0 10px rgba(0,0,0,0.3); max-height: 100%; box-sizing: border-box; 
    flex-shrink: 0;
}

#canvas-wrapper { position: relative; flex-grow: 1; display: flex; justify-content: center; align-items: center; background: #111; border: 3px solid var(--border-color); border-radius: 4px; overflow: hidden; }
canvas { image-rendering: pixelated; cursor: crosshair; }

#zoom-controls { position: absolute; bottom: 15px; right: 15px; display: flex; flex-direction: column; gap: 5px; }
#zoom-controls button { font-size: 18px; padding: 5px 12px; opacity: 0.8; font-family: monospace; }

h2 { color: var(--text-main); font-size: 18px; border-bottom: 2px solid var(--border-color); padding-bottom: 4px; margin-bottom: 10px; }
h3 { font-size: 15px; color: var(--accent-gold); margin-bottom: 5px;}

button {
    font-family: var(--font-body); font-weight: bold; text-transform: uppercase;
    background: var(--bg-color); color: var(--text-main); font-size: 12px;
    border: 2px solid var(--border-color); cursor: pointer; padding: 6px 10px;
    border-radius: 3px; transition: 0.1s;
}
button:hover:not(:disabled) { background: var(--accent-gold); color: #111; border-color: #111;}
button:active:not(:disabled) { transform: translateY(1px); }
button:disabled { color: #777; border-color: #444; background: #222; cursor: not-allowed; }

.btn-small { padding: 3px 6px; font-size: 11px; }

.tab-headers { display: flex; gap: 5px; margin-bottom: 10px; }
.tab-btn { flex-grow: 1; border: none; background: transparent; border-bottom: 3px solid transparent; padding: 6px 0; border-radius: 0; display: flex; justify-content: center; align-items: center; color: #aaa;}
.tab-btn canvas { opacity: 0.3; transition: 0.2s; pointer-events: none; }
.tab-btn.active { border-bottom: 3px solid var(--accent-gold); color: var(--accent-gold); font-weight: bold; }
.tab-btn.active canvas { opacity: 1; }
.tab-btn:hover:not(.active) { background: rgba(0,0,0,0.1); color: var(--text-main); }
.tab-btn:hover canvas { opacity: 0.8; }

.tab-content { display: none; flex-direction: column; flex-grow: 1; overflow-y: auto; overflow-x: hidden; }
.tab-content.active { display: flex; }

.list-item { border: 1px solid var(--border-color); padding: 10px; margin-bottom: 8px; background: rgba(0,0,0,0.2); font-size: 12px; line-height: 1.4; border-radius: 3px; }
.list-item b { color: var(--accent-gold); font-size: 14px; font-family: var(--font-head); }
.row-buttons { display: flex; gap: 8px; margin-top: 8px; }
.row-buttons button { flex-grow: 1; }

.route-stop { display: flex; justify-content: space-between; align-items: center; background: rgba(0,0,0,0.4); padding: 4px 8px; margin-bottom: 4px; border-radius: 2px; }

#inspector-container { display: flex; flex-direction: column; flex: 1 1 50%; min-height: 0; }
#inspector-content { flex-grow: 1; overflow-y: auto; font-size: 13px; line-height: 1.6; padding-right: 5px; }

#log-wrapper { display: flex; flex-direction: column; flex: 1 1 50%; min-height: 0; }
#log { flex-grow: 1; overflow-y: auto; background: rgba(0,0,0,0.3); border: 1px solid var(--border-color); padding: 10px; font-size: 12px; border-radius: 3px; }
.log-sys { color: #aaa; } .log-event { color: var(--accent-green); font-weight: bold; } 
.log-score { color: var(--accent-gold); font-weight: bold; } .log-important { color: var(--accent-red); font-weight: bold; }
.log-photo { color: #5dade2; font-weight: bold; }
.log-cond { color: #d35400; font-weight: bold; } 

#camera-options { flex-shrink: 0; margin-top: 10px; border-top: 1px solid var(--border-color); padding-top: 10px; }

.modal-overlay { position: fixed; top: 0; left: 0; width: 100vw; height: 100vh; background: rgba(0,0,0,0.8); display: none; justify-content: center; align-items: center; z-index: 100; }
.modal-box { background: var(--panel-bg); border: 2px solid var(--accent-gold); padding: 25px; min-width: 300px; border-radius: 4px; display: flex; flex-direction: column; gap: 15px; box-shadow: 0 10px 30px rgba(0,0,0,0.8); max-height: 80vh;}

#achievements-modal .modal-box, #spikes-modal .modal-box, #photos-modal .modal-box { width: 800px; max-width: 90%; }
#achievements-grid, #spikes-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(350px, 1fr)); gap: 10px; overflow-y: auto; padding-right: 5px; max-height: 60vh; }
#photos-grid { display: flex; flex-wrap: wrap; justify-content: center; gap: 10px; overflow-y: auto; padding-right: 5px; max-height: 60vh; }
#photos-grid .ach-card { width: 320px; }
#photos-grid h3 { width: 100%; text-align: center; }

.ach-card { display: flex; align-items: center; background: rgba(0,0,0,0.2); border: 1px solid var(--border-color); border-radius: 4px; padding: 10px; gap: 15px; transition: 0.2s;}
.ach-card.locked { opacity: 0.5; }
.ach-card.locked:hover { opacity: 0.8; }
.ach-card.unlocked { border-color: var(--accent-gold); background: rgba(212, 175, 55, 0.05); }
.ach-icon-wrapper { width: 40px; height: 40px; background: #111; border: 1px solid var(--border-color); border-radius: 4px; display: flex; justify-content: center; align-items: center; flex-shrink:0; }
.ach-info { display: flex; flex-direction: column; gap: 3px; flex-grow: 1; }
.ach-title { font-family: var(--font-head); font-weight: bold; font-size: 14px; color: var(--accent-gold); }
.locked .ach-title { color: var(--text-muted); }
.ach-desc { font-size: 11px; color: var(--text-muted); font-style: italic; }
.ach-reward { font-size: 11px; color: var(--accent-green); font-weight: bold; }

#toast-container { position: fixed; bottom: 50px; right: 20px; display: flex; flex-direction: column; gap: 10px; z-index: 200; pointer-events: none; }
.toast { background: var(--panel-bg); border: 2px solid var(--accent-gold); padding: 10px 15px; border-radius: 4px; box-shadow: 0 4px 10px rgba(0,0,0,0.8); display: flex; align-items: center; gap: 15px; animation: slideIn 0.3s ease-out; color: var(--text-main); }
.toast-out { animation: slideOut 0.5s ease-in forwards; }
@keyframes slideIn { from { transform: translateX(100%); opacity: 0; } to { transform: translateX(0); opacity: 1; } }
@keyframes slideOut { from { transform: translateX(0); opacity: 1; } to { transform: translateX(100%); opacity: 0; } }

#context-menu { position: absolute; display: none; background: var(--panel-bg); border: 2px solid var(--accent-gold); padding: 10px; z-index: 50; box-shadow: 5px 5px 0px rgba(0,0,0,0.8); flex-direction: column; gap: 5px; border-radius: 4px; min-width: 150px; }
#context-menu h3 { margin: 0 0 8px 0; font-size: 14px; border-bottom: 1px solid var(--border-color); padding-bottom: 4px; }
#context-menu button { text-align: left; width: 100%; font-size: 11px; padding: 4px; }

.large-modal-content { flex-grow: 1; overflow-y: auto; color: #ddd; font-size: 14px; line-height: 1.6; }
.large-modal-content p { margin-top: 0; margin-bottom: 15px; }