/* --- MASTER DESIGN TOKENS --- */
:root {
    --bg: #020617;
    --glass: rgba(255, 255, 255, 0.03);
    --border: rgba(255, 255, 255, 0.1);
    --indigo: #6366f1;
    --cyan: #22d3ee;
    --gold: #fbbf24;
    --mono: 'JetBrains Mono', monospace;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
body { background: var(--bg); color: #f8fafc; font-family: 'Plus Jakarta Sans', sans-serif; overflow-x: hidden; }

/* LOGO FIX */
img.nav-logo { height: 60px; width: auto; object-fit: contain; }

/* NEURAL HANDSHAKE */
.neural-overlay { position: fixed; inset: 0; background: var(--bg); z-index: 2000; display: flex; justify-content: center; align-items: center; transition: 1s ease-in-out; }
.scan-line-container { width: 300px; height: 2px; background: rgba(255,255,255,0.05); margin-top: 15px; overflow: hidden; }
.scan-bar { height: 100%; width: 50%; background: var(--cyan); box-shadow: 0 0 15px var(--cyan); animation: scan 1.5s infinite linear; }
@keyframes scan { from { transform: translateX(-100%); } to { transform: translateX(250%); } }
.glitch-text { font-family: var(--mono); color: var(--cyan); letter-spacing: 5px; font-weight: 800; }

/* MASTER LAYOUT */
.glass-container { padding: 30px; max-width: 1750px; margin: 0 auto; }
.dashboard-grid { display: grid; grid-template-columns: 380px 1fr; gap: 25px; align-items: start; }
.sidebar-stats, .main-viewport { display: flex; flex-direction: column; gap: 25px; min-width: 0; }

.glass-card { background: var(--glass); backdrop-filter: blur(25px); border: 1px solid var(--border); border-radius: 28px; padding: 25px; box-shadow: 0 15px 40px rgba(0,0,0,0.5); position: relative; z-index: 1; }

/* SYNERGY TOOLTIP (FIXED STACKING) */
.synergy-trigger { position: relative; cursor: help; z-index: 10; }
.synergy-trigger:hover { z-index: 100; }
.synergy-tooltip {
    position: absolute; top: 105%; left: 50%; transform: translateX(-50%) translateY(10px);
    width: 250px; background: #0f172a; border: 1px solid var(--indigo);
    border-radius: 12px; padding: 15px; z-index: 9999 !important; 
    opacity: 0; visibility: hidden; transition: 0.3s;
    box-shadow: 0 20px 60px rgba(0,0,0,0.9); pointer-events: none;
}
.synergy-trigger:hover .synergy-tooltip { opacity: 1; visibility: visible; transform: translateX(-50%) translateY(0); }
.tooltip-row { display: flex; justify-content: space-between; font-size: 0.8rem; margin-bottom: 8px; color: #94a3b8; }
.tooltip-row b { color: var(--cyan); }
.tooltip-footer { border-top: 1px solid var(--border); padding-top: 10px; font-size: 0.65rem; color: var(--gold); text-align: center; }

/* CHARTS (FIXED DIMENSIONS) */
.analysis-row { display: grid; grid-template-columns: 1.2fr 1fr; gap: 25px; min-height: 420px; }
.canvas-wrap { position: relative; height: 320px; width: 100%; margin: 0 auto; display: flex; justify-content: center; align-items: center; }
#portalRadarChart { width: 100% !important; height: 100% !important; }

.gauge-container { position: relative; height: 130px; width: 220px; margin: 20px auto 0; }
.gauge-overlay { position: absolute; bottom: 0; left: 50%; transform: translateX(-50%); }
#match-percent { font-size: 3rem; font-weight: 800; color: var(--indigo); }
.clinical-label-small { font-size: 0.65rem; text-transform: uppercase; color: var(--cyan); font-weight: 800; letter-spacing: 1px; display: flex; align-items: center; gap: 8px; }

/* CARDS & EXPANSION */
.selection-bar { display: flex; gap: 12px; margin-top: 20px; overflow-x: auto; padding-bottom: 15px; scrollbar-width: thin; scrollbar-color: var(--indigo) transparent; }
.opt-tab { min-width: 220px; cursor: pointer; border-left: 4px solid transparent; transition: 0.3s; }
.opt-tab.active { border-left-color: var(--indigo); background: rgba(99, 102, 241, 0.1); }
.expansion-deck { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 20px; width: 100%; }
.expansion-card { min-height: 480px; border: 1px solid var(--border); }
.expansion-card.gold-border { border-color: var(--gold); box-shadow: 0 0 30px rgba(251, 191, 36, 0.1); }

/* TERMINAL */
.terminal-content { font-family: var(--mono); font-size: 0.85rem; color: var(--cyan); background: rgba(0,0,0,0.3); padding: 20px; border-radius: 12px; min-height: 160px; line-height: 1.6; }
.system-logs-footer { margin-top: 30px; background: rgba(0,0,0,0.4); height: 45px; border-radius: 8px; overflow: hidden; }
.log-track { font-family: var(--mono); font-size: 0.7rem; color: #4ade80; display: flex; gap: 50px; padding: 14px; animation: scroll 35s linear infinite; }
@keyframes scroll { from { transform: translateX(100%); } to { transform: translateX(-100%); } }

/* DOSSIER MODAL */
.modal-backdrop { position: fixed; inset: 0; background: rgba(0,0,0,0.9); backdrop-filter: blur(15px); display: none; justify-content: center; align-items: center; z-index: 1000; }
.modal-window { width: 92%; max-width: 950px; }
.neural-border { border: 1px solid var(--cyan) !important; box-shadow: 0 0 50px rgba(34, 211, 238, 0.15); }
.modal-header-detailed { display: flex; align-items: center; gap: 20px; border-bottom: 1px solid var(--border); padding-bottom: 20px; }
.modal-grid-detailed { display: grid; grid-template-columns: 1.3fr 1fr; gap: 25px; margin-top: 25px; }
.modal-pane-glass { background: rgba(255,255,255,0.02); border: 1px solid var(--border); border-radius: 20px; padding: 20px; }
.motto-text { font-family: var(--mono); color: var(--gold); font-style: italic; font-size: 0.9rem; margin-top: 5px; }
.skill-tags-dossier span { background: rgba(99,102,241,0.1); padding: 5px 12px; border-radius: 6px; font-size: 0.75rem; color: var(--cyan); margin: 4px; display: inline-block; }
.warning-text { color: #f87171 !important; }
.modal-close { position: absolute; top: 20px; right: 20px; background: none; border: none; color: #fff; font-size: 2rem; cursor: pointer; }

@media (max-width: 1400px) { .dashboard-grid, .expansion-deck, .analysis-row { grid-template-columns: 1fr; } }
/* --- FLOATING FEEDBACK BUTTON --- */
.feedback-fab {
    position: fixed;
    bottom: 30px;
    right: 30px;
    background: var(--glass);
    backdrop-filter: blur(10px);
    border: 1px solid var(--border);
    padding: 12px 20px;
    border-radius: 50px;
    color: var(--neon-cyan);
    text-decoration: none;
    font-size: 0.75rem;
    font-weight: 800;
    letter-spacing: 1.5px;
    display: flex;
    align-items: center;
    gap: 10px;
    transition: 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
    z-index: 5000; /* Stays above everything */
    box-shadow: 0 10px 30px rgba(0,0,0,0.5);
}

.feedback-fab:hover {
    transform: scale(1.05) translateY(-5px);
    border-color: var(--indigo);
    background: rgba(99, 102, 241, 0.1);
    box-shadow: 0 15px 40px rgba(99, 102, 241, 0.2);
    color: white;
}

.feedback-fab .icon {
    font-size: 1.1rem;
}

/* Hide on the boot-loader screen */
#boot-loader[style*="display: none"] ~ .feedback-fab {
    display: flex;
}