/* ═══════════════════════════════════════════════════════════════════════════
   OSU!GRIND Mockup Styles
   High-fidelity recreations of app components for the website
   ═══════════════════════════════════════════════════════════════════════════ */

.mockup-container {
    width: 100%;
    height: 100%;
    background: #000;
    position: relative;
    font-family: 'Inter', sans-serif;
    color: #fff;
    overflow: hidden;
}

/* ═══════════════════════════════════════════════════════════════════════════
   LIVE TAB MOCKUP
   ═══════════════════════════════════════════════════════════════════════════ */
.mock-live-content {
    display: flex;
    flex-direction: column;
    height: 100%;
    padding: 30px;
    background: radial-gradient(circle at center, rgba(255, 102, 171, 0.05) 0%, #000 100%);
}

.mock-live-header {
    text-align: center;
    margin-bottom: 40px;
}

.mock-map-title { font-size: 24px; font-weight: 800; margin-bottom: 4px; }
.mock-map-artist { font-size: 14px; color: #aaa; }

.mock-live-main {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 40px;
    flex: 1;
}

.mock-stat-box { text-align: center; width: 140px; }
.mock-stat-label { font-size: 10px; font-weight: 800; letter-spacing: 2px; color: #666; margin-bottom: 8px; text-transform: uppercase; }
.mock-stat-value { font-size: 42px; font-weight: 900; line-height: 1; }

.mock-acc-val { color: var(--accent-cyan); }
.mock-pp-val { color: var(--accent-pink); }
.mock-grade { font-size: 80px; font-weight: 950; color: #FFD700; text-shadow: 0 0 20px rgba(255, 215, 0, 0.4); }

.mock-live-dash {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-top: 20px;
    border-top: 1px solid rgba(255, 255, 255, 0.05);
}

.mock-dash-item { display: flex; flex-direction: column; gap: 4px; align-items: center; }
.mock-dash-label { font-size: 9px; font-weight: 800; color: #666; text-transform: uppercase; }
.mock-dash-value { font-size: 14px; font-weight: 800; color: #fff; }

/* ═══════════════════════════════════════════════════════════════════════════
   ANALYTICS MOCKUP
   ═══════════════════════════════════════════════════════════════════════════ */
.mock-analytics-content {
    padding: 30px;
    display: flex;
    flex-direction: column;
    gap: 20px;
    background: #0a0a0a;
}

.mock-perf-card {
    background: #0f0f0f;
    border: 1px solid #1a1a1a;
    border-radius: 12px;
    padding: 24px;
    display: flex;
    justify-content: space-between;
}

.mock-perf-value { font-size: 48px; font-weight: 900; color: #fff; }
.mock-form-value { font-size: 20px; font-weight: 800; color: var(--accent-yellow); text-transform: uppercase; }

.mock-mentality-box {
    background: #0f0f0f;
    border: 1px solid #1a1a1a;
    border-radius: 12px;
    padding: 20px;
}

.mock-mentality-header { display: flex; justify-content: space-between; margin-bottom: 12px; }
.mock-mentality-track { height: 8px; background: rgba(255, 255, 255, 0.05); border-radius: 4px; overflow: hidden; }
.mock-mentality-fill { height: 100%; width: 85%; background: linear-gradient(90deg, #00b4d8, #48cae4); }

.mock-chart-placeholder {
    height: 140px;
    background: repeating-linear-gradient(90deg, transparent, transparent 40px, rgba(255, 255, 255, 0.02) 40px, rgba(255, 255, 255, 0.02) 41px);
    border-radius: 8px;
    position: relative;
}

.mock-line {
    position: absolute;
    bottom: 40px; left: 0; right: 0;
    height: 2px; background: var(--accent-purple);
    box-shadow: 0 0 15px var(--accent-purple);
}

/* ═══════════════════════════════════════════════════════════════════════════
   GOALS MOCKUP
   ═══════════════════════════════════════════════════════════════════════════ */
.mock-goals-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 15px;
    padding: 30px;
}

.mock-goal-card {
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 12px;
    padding: 15px;
}

.mock-goal-card.completed { border-color: rgba(255, 102, 171, 0.3); }
.mock-goal-current { font-size: 28px; font-weight: 900; margin: 5px 0; }
.mock-goal-progress { height: 6px; background: rgba(0,0,0,0.3); border-radius: 3px; overflow: hidden; }
.mock-goal-fill { height: 100%; background: var(--accent-pink); width: 100%; }
.mock-goal-fill.cyan { background: var(--accent-cyan); width: 70%; }

/* ═══════════════════════════════════════════════════════════════════════════
   REWIND MOCKUP (DARK PLAYER)
   ═══════════════════════════════════════════════════════════════════════════ */
.mock-rewind-content {
    height: 100%;
    background: #000;
    display: flex;
    flex-direction: column;
}

.mock-rewind-hud {
    position: absolute;
    inset: 0;
    padding: 25px;
    pointer-events: none;
}

.mock-rewind-ur { position: absolute; bottom: 30px; left: 25px; font-size: 24px; font-weight: 900; color: var(--accent-cyan); }
.mock-rewind-pp { position: absolute; bottom: 30px; right: 25px; font-size: 24px; font-weight: 900; color: var(--accent-pink); text-align: right; }

.mock-hit-marker {
    position: absolute;
    width: 40px; height: 40px;
    border: 2px solid rgba(255,255,255,0.4);
    border-radius: 50%;
    transform: translate(-50%, -50%);
}

.mock-hit-ripple {
    position: absolute;
    width: 60px; height: 60px;
    border: 1px solid var(--accent-cyan);
    border-radius: 50%;
    transform: translate(-50%, -50%);
    opacity: 0.5;
}
