@import url('https://fonts.googleapis.com/css2?family=Orbitron:wght@400;700;900&family=Share+Tech+Mono&display=swap');

:root {
    --neon-pink: #ff2975;
    --neon-cyan: #00fff9;
    --neon-purple: #b429f9;
    --neon-yellow: #f9f002;
    --neon-green: #29ff75;
    --neon-orange: #ff9500;
    --dark-bg: #0a0a1a;
    --darker-bg: #050510;
    --panel-bg: rgba(10, 10, 26, 0.92);
    --panel-border: rgba(0, 255, 249, 0.2);
}

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

body {
    font-family: 'Share Tech Mono', monospace;
    background: var(--dark-bg);
    color: #e0e0ff;
    overflow-x: hidden;
    min-height: 100vh;
}

#synthwave-bg {
    position: fixed;
    top: 0; left: 0;
    width: 100%; height: 100%;
    z-index: 0;
}

#particle-canvas {
    position: fixed;
    top: 0; left: 0;
    width: 100%; height: 100%;
    z-index: 1;
    pointer-events: none;
}

#toast-container {
    position: fixed;
    top: 20px;
    right: 20px;
    z-index: 1000;
    display: flex;
    flex-direction: column;
    gap: 8px;
    max-width: 350px;
}

.toast {
    background: var(--panel-bg);
    border: 1px solid var(--neon-cyan);
    border-radius: 6px;
    padding: 12px 18px;
    font-size: 0.9rem;
    box-shadow: 0 0 15px rgba(0, 255, 249, 0.3);
    animation: toastIn 0.3s ease-out, toastOut 0.5s ease-in 2.5s forwards;
    backdrop-filter: blur(10px);
}

.toast.success { border-color: var(--neon-green); box-shadow: 0 0 15px rgba(41, 255, 117, 0.3); }
.toast.warning { border-color: var(--neon-yellow); box-shadow: 0 0 15px rgba(249, 240, 2, 0.3); }
.toast.danger { border-color: var(--neon-pink); box-shadow: 0 0 15px rgba(255, 41, 117, 0.3); }
.toast.achievement { border-color: var(--neon-orange); box-shadow: 0 0 20px rgba(255, 149, 0, 0.4); }

@keyframes toastIn {
    from { opacity: 0; transform: translateX(100px); }
    to { opacity: 1; transform: translateX(0); }
}

@keyframes toastOut {
    from { opacity: 1; transform: translateX(0); }
    to { opacity: 0; transform: translateX(100px); }
}

#game-container {
    position: relative;
    z-index: 2;
    max-width: 1400px;
    margin: 0 auto;
    padding: 10px 15px;
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}

header {
    text-align: center;
    padding: 15px 0 10px;
}

h1.glitch {
    font-family: 'Orbitron', sans-serif;
    font-size: clamp(1.5rem, 5vw, 2.8rem);
    font-weight: 900;
    color: var(--neon-cyan);
    text-shadow: 0 0 10px var(--neon-cyan), 0 0 20px var(--neon-cyan), 0 0 40px var(--neon-cyan), 0 0 80px var(--neon-purple);
    position: relative;
    animation: glitch-skew 4s infinite linear alternate-reverse;
}

h1.glitch::before, h1.glitch::after {
    content: attr(data-text);
    position: absolute;
    top: 0; left: 0;
    width: 100%; height: 100%;
}

h1.glitch::before {
    color: var(--neon-pink);
    animation: glitch-effect 3s infinite linear alternate-reverse;
    clip-path: polygon(0 0, 100% 0, 100% 35%, 0 35%);
    transform: translate(-3px, -2px);
}

h1.glitch::after {
    color: var(--neon-purple);
    animation: glitch-effect2 2s infinite linear alternate-reverse;
    clip-path: polygon(0 65%, 100% 65%, 100% 100%, 0 100%);
    transform: translate(3px, 2px);
}

@keyframes glitch-effect {
    0% { transform: translate(0); }
    20% { transform: translate(-3px, 3px); }
    40% { transform: translate(-3px, -3px); }
    60% { transform: translate(3px, 3px); }
    80% { transform: translate(3px, -3px); }
    100% { transform: translate(0); }
}

@keyframes glitch-effect2 {
    0% { transform: translate(0); }
    20% { transform: translate(3px, -3px); }
    40% { transform: translate(3px, 3px); }
    60% { transform: translate(-3px, -3px); }
    80% { transform: translate(-3px, 3px); }
    100% { transform: translate(0); }
}

@keyframes glitch-skew {
    0% { transform: skew(0deg); }
    2% { transform: skew(2deg); }
    4% { transform: skew(0deg); }
    100% { transform: skew(0deg); }
}

.subtitle {
    font-size: 0.85rem;
    color: var(--neon-purple);
    text-shadow: 0 0 10px var(--neon-purple);
    margin-top: 5px;
    letter-spacing: 3px;
}

main {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 5px 0;
}

.screen {
    display: none;
    width: 100%;
    max-width: 1300px;
    animation: fadeIn 0.5s ease-out;
}

.screen.active { display: flex; flex-direction: column; align-items: center; }

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

.terminal {
    background: var(--panel-bg);
    border: 1px solid var(--panel-border);
    border-radius: 8px;
    padding: 20px;
    width: 100%;
    margin: 10px 0;
    box-shadow: 0 0 15px rgba(0, 255, 249, 0.15), inset 0 0 30px rgba(0, 0, 0, 0.5);
    position: relative;
    overflow: hidden;
}

.terminal::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 2px;
    background: linear-gradient(90deg, transparent, var(--neon-cyan), transparent);
    animation: scanline 3s infinite linear;
}

@keyframes scanline {
    0% { top: 0; }
    100% { top: 100%; }
}

.terminal p { margin: 8px 0; line-height: 1.5; font-size: 1rem; }

.neon-pink { color: var(--neon-pink) !important; text-shadow: 0 0 10px var(--neon-pink); }
.neon-cyan { color: var(--neon-cyan) !important; text-shadow: 0 0 10px var(--neon-cyan); }
.neon-purple { color: var(--neon-purple) !important; text-shadow: 0 0 10px var(--neon-purple); }
.neon-yellow { color: var(--neon-yellow) !important; text-shadow: 0 0 10px var(--neon-yellow); }

.blink { animation: blink 1s infinite; }
@keyframes blink { 0%, 50% { opacity: 1; } 51%, 100% { opacity: 0; } }

.neon-btn {
    font-family: 'Orbitron', sans-serif;
    font-size: 1.1rem;
    font-weight: 700;
    padding: 14px 35px;
    margin: 10px;
    background: transparent;
    color: var(--neon-cyan);
    border: 2px solid var(--neon-cyan);
    border-radius: 5px;
    cursor: pointer;
    text-transform: uppercase;
    letter-spacing: 3px;
    transition: all 0.3s ease;
    box-shadow: 0 0 10px var(--neon-cyan), inset 0 0 10px var(--neon-cyan);
}

.neon-btn:hover {
    background: var(--neon-cyan);
    color: var(--dark-bg);
    box-shadow: 0 0 20px var(--neon-cyan), 0 0 40px var(--neon-cyan);
}

.neon-btn:active { transform: scale(0.98); }

h2, h3 { font-family: 'Orbitron', sans-serif; margin-bottom: 10px; font-size: 1rem; }

/* Top Bar */
#top-bar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 100%;
    background: var(--panel-bg);
    border: 1px solid var(--panel-border);
    border-radius: 8px;
    padding: 10px 20px;
    margin-bottom: 10px;
    flex-wrap: wrap;
    gap: 10px;
}

#time-display {
    display: flex;
    gap: 15px;
    font-size: 1rem;
}

#display-year { color: var(--neon-cyan); font-weight: bold; font-size: 1.2rem; text-shadow: 0 0 8px var(--neon-cyan); }
#display-age { color: var(--neon-purple); }
#display-date { color: rgba(224, 224, 255, 0.6); }

#speed-controls { display: flex; gap: 5px; }

.speed-btn {
    background: rgba(180, 41, 249, 0.1);
    color: var(--neon-purple);
    border: 1px solid var(--neon-purple);
    border-radius: 4px;
    padding: 5px 12px;
    cursor: pointer;
    font-family: 'Share Tech Mono', monospace;
    font-size: 0.85rem;
    transition: all 0.2s;
}

.speed-btn:hover, .speed-btn.active {
    background: var(--neon-purple);
    color: var(--dark-bg);
    box-shadow: 0 0 10px var(--neon-purple);
}

#money-display { font-size: 1.2rem; font-weight: bold; }
#display-money { color: var(--neon-green); text-shadow: 0 0 8px var(--neon-green); }

/* Main Content Layout */
#main-content {
    display: grid;
    grid-template-columns: 280px 1fr 260px;
    gap: 10px;
    width: 100%;
    margin-bottom: 10px;
}

#left-panel, #right-panel {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

#center-panel {
    display: flex;
    flex-direction: column;
    gap: 10px;
    min-width: 0;
}

/* Stat Bars */
#stats-panel {
    background: var(--panel-bg);
    border: 1px solid var(--panel-border);
    border-radius: 8px;
    padding: 15px;
}

.stat-bar { margin-bottom: 10px; }

.stat-header {
    display: flex;
    justify-content: space-between;
    margin-bottom: 3px;
    font-size: 0.85rem;
}

.stat-header .label { color: rgba(224, 224, 255, 0.8); }
.stat-header .value { color: var(--neon-cyan); font-weight: bold; }

.bar-bg {
    width: 100%;
    height: 10px;
    background: rgba(255, 255, 255, 0.05);
    border-radius: 5px;
    overflow: hidden;
}

.bar-fill {
    height: 100%;
    border-radius: 5px;
    transition: width 0.5s ease;
    box-shadow: 0 0 8px currentColor;
}

/* Current Activity */
#current-activity {
    background: var(--panel-bg);
    border: 1px solid var(--panel-border);
    border-radius: 8px;
    padding: 15px;
}

#activity-display { text-align: center; }
#activity-name { color: var(--neon-cyan); font-size: 1.1rem; margin: 8px 0; }

/* Levels */
#level-display {
    background: var(--panel-bg);
    border: 1px solid var(--panel-border);
    border-radius: 8px;
    padding: 15px;
}

#levels-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
}

.level-item {
    text-align: center;
    padding: 6px;
    background: rgba(255, 255, 255, 0.03);
    border-radius: 4px;
}

.level-item .level-label { font-size: 0.7rem; color: rgba(224, 224, 255, 0.5); }
.level-item .level-value { font-size: 1rem; font-weight: bold; color: var(--neon-cyan); }
.level-item .level-title { font-size: 0.65rem; color: var(--neon-purple); }

/* Timeline */
#timeline {
    background: var(--panel-bg);
    border: 1px solid var(--panel-border);
    border-radius: 8px;
    padding: 15px;
    max-height: 250px;
    overflow-y: auto;
}

#timeline-events { position: relative; padding-left: 20px; }

#timeline-events::before {
    content: '';
    position: absolute;
    left: 6px;
    top: 0;
    bottom: 0;
    width: 2px;
    background: linear-gradient(to bottom, var(--neon-cyan), var(--neon-purple), var(--neon-pink));
}

.timeline-event {
    position: relative;
    padding: 6px 0 6px 15px;
    font-size: 0.85rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.03);
}

.timeline-event::before {
    content: '';
    position: absolute;
    left: -17px;
    top: 12px;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--neon-cyan);
    box-shadow: 0 0 6px var(--neon-cyan);
}

.timeline-event .event-year { color: var(--neon-purple); font-weight: bold; }
.timeline-event .event-text { color: rgba(224, 224, 255, 0.8); }

/* News Feed */
#news-feed {
    background: var(--panel-bg);
    border: 1px solid var(--panel-border);
    border-radius: 8px;
    padding: 15px;
    max-height: 200px;
    overflow-y: auto;
}

.news-item {
    padding: 6px 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.03);
    font-size: 0.85rem;
    color: var(--neon-yellow);
}

.news-item .news-year { color: var(--neon-purple); font-weight: bold; }

/* Relationships */
#relationships-panel {
    background: var(--panel-bg);
    border: 1px solid var(--panel-border);
    border-radius: 8px;
    padding: 12px;
}

#relationships-list { max-height: 180px; overflow-y: auto; margin-bottom: 8px; }

#family-display { margin-bottom: 10px; padding-bottom: 8px; border-bottom: 1px solid rgba(180,41,249,0.2); }

.family-member {
    padding: 4px 0;
    font-size: 0.8rem;
    border-bottom: 1px solid rgba(255,255,255,0.03);
}

.family-member .fam-role { color: var(--neon-orange); font-weight: bold; }
.family-member .fam-name { color: var(--neon-cyan); }

.relationship-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 5px 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.03);
    font-size: 0.8rem;
}

.relationship-item .rel-name { color: var(--neon-cyan); }
.relationship-item .rel-type { color: var(--neon-purple); font-size: 0.7rem; }
.relationship-item .rel-bar { width: 50px; }
.relationship-item .rel-bar .bar-bg { height: 6px; }

/* Inventory */
#inventory-panel {
    background: var(--panel-bg);
    border: 1px solid var(--panel-border);
    border-radius: 8px;
    padding: 12px;
}

#inventory-list { max-height: 120px; overflow-y: auto; }

.inventory-item {
    padding: 4px 0;
    font-size: 0.8rem;
    color: var(--neon-yellow);
    border-bottom: 1px solid rgba(255, 255, 255, 0.03);
}

/* Achievements */
#achievements-panel {
    background: var(--panel-bg);
    border: 1px solid var(--panel-border);
    border-radius: 8px;
    padding: 12px;
}

#achievements-list { max-height: 120px; overflow-y: auto; }

.achievement-item {
    padding: 4px 0;
    font-size: 0.8rem;
    color: var(--neon-orange);
    border-bottom: 1px solid rgba(255, 255, 255, 0.03);
}

/* Investments */
#investments-panel {
    background: var(--panel-bg);
    border: 1px solid var(--panel-border);
    border-radius: 8px;
    padding: 12px;
}

#investments-list { max-height: 150px; overflow-y: auto; margin-bottom: 8px; }

.investment-item {
    padding: 6px 0;
    font-size: 0.75rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.03);
}

.investment-item .inv-name { color: var(--neon-yellow); font-weight: bold; }
.investment-item .inv-details {
    display: flex;
    gap: 8px;
    color: rgba(224, 224, 255, 0.6);
    margin-top: 2px;
    flex-wrap: wrap;
}

.sell-btn {
    margin-top: 4px;
    padding: 3px 8px;
    font-size: 0.7rem;
}

/* Scrollbar */
::-webkit-scrollbar { width: 6px; }
::-webkit-scrollbar-track { background: var(--darker-bg); }
::-webkit-scrollbar-thumb { background: var(--neon-purple); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--neon-cyan); }

/* Character Details */
#character-details .char-stat {
    display: flex;
    justify-content: space-between;
    padding: 8px 0;
    border-bottom: 1px solid rgba(0, 255, 249, 0.1);
}

#character-details .char-stat .char-label { color: var(--neon-cyan); font-weight: bold; }

/* Responsive */
@media (max-width: 1100px) {
    #main-content {
        grid-template-columns: 1fr;
    }
    #left-panel, #right-panel {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 10px;
    }
}

@media (max-width: 700px) {
    #left-panel, #right-panel {
        grid-template-columns: 1fr;
    }
    #top-bar {
        flex-direction: column;
        align-items: stretch;
        text-align: center;
    }
    #time-display, #speed-controls { justify-content: center; }
    #actions-panel { grid-template-columns: repeat(3, 1fr); }
    h1.glitch { font-size: 1.5rem; }
}
