/**
 * Evo Academy — Page-specific CSS
 * Login, Dashboard, Course, Lesson, Ranking, Profile, Certificates
 */

/* ===================================================================
   LOGIN PAGE
   =================================================================== */
.login-page {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px;
    position: relative;
    overflow: hidden;
}

/* Glow orbs (dark theme only) */
.login-glow-orb {
    position: absolute;
    border-radius: 50%;
    filter: blur(100px);
    pointer-events: none;
}
body.light .login-glow-orb {
    display: none;
}
.login-glow-1 {
    width: 500px;
    height: 500px;
    background: rgba(34, 197, 94, 0.04);
    top: -150px;
    right: -100px;
}
.login-glow-2 {
    width: 400px;
    height: 400px;
    background: rgba(14, 165, 233, 0.05);
    bottom: -100px;
    left: -100px;
}

.login-card {
    width: 100%;
    max-width: 420px;
    position: relative;
    z-index: 1;
}
.login-logo-section {
    text-align: center;
    margin-bottom: 8px;
    padding: 32px 32px 24px;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: 20px 20px 0 0;
}
.login-logo-icon {
    width: 56px;
    height: 56px;
    border-radius: 16px;
    background: var(--gradient);
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 16px;
    color: #fff;
    font-weight: 800;
    font-size: 22px;
}
.login-title {
    font-size: 24px;
    font-weight: 800;
    color: var(--text);
    margin-bottom: 4px;
}
.login-subtitle {
    font-size: 13px;
    color: var(--accent-light);
    font-weight: 500;
}
.login-welcome {
    font-size: 12px;
    color: var(--text-dim);
    margin-top: 12px;
}

.login-form-section {
    padding: 32px 36px 36px;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-top: none;
    border-radius: 0 0 20px 20px;
}
.login-form-title {
    font-size: 17px;
    font-weight: 700;
    color: var(--text);
    margin-bottom: 4px;
}
.login-form-subtitle {
    font-size: 13px;
    color: var(--text-muted);
    margin-bottom: 24px;
}
.login-forgot {
    display: block;
    text-align: right;
    font-size: 12px;
    color: var(--accent-light);
    margin-top: -8px;
    margin-bottom: 20px;
}
.login-footer {
    text-align: center;
    font-size: 11px;
    color: var(--text-dim);
    margin-top: 24px;
}
.login-theme-toggle {
    position: fixed;
    top: 20px;
    right: 20px;
    z-index: 10;
}

/* ===================================================================
   DASHBOARD PAGE
   =================================================================== */
.dashboard-greeting {
    margin-bottom: 24px;
}
.dashboard-greeting h1 {
    font-size: 24px;
    font-weight: 700;
}
.dashboard-greeting p {
    font-size: 14px;
    color: var(--text-muted);
    margin-top: 4px;
}

/* Course cards */
.course-card {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: 16px;
    overflow: hidden;
    transition: all 0.2s;
    cursor: pointer;
    position: relative;
}
.course-card:hover {
    border-color: var(--accent);
    transform: translateY(-3px);
    box-shadow: 0 8px 32px var(--shadow);
}
.course-card-cover {
    height: 160px;
    position: relative;
    overflow: hidden;
    background: var(--bg-surface);
}
.course-card-cover img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.course-card-cover-placeholder {
    width: 100%;
    height: 100%;
    background: var(--gradient);
    opacity: 0.3;
}
.course-card-tag {
    position: absolute;
    top: 12px;
    right: 12px;
}
.course-card-play {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: rgba(0, 0, 0, 0.6);
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    backdrop-filter: blur(4px);
}
.course-card-body {
    padding: 16px;
}
.course-card-title {
    font-size: 15px;
    font-weight: 700;
    color: var(--text);
    margin-bottom: 6px;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.course-card-desc {
    font-size: 12px;
    color: var(--text-dim);
    margin-bottom: 12px;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.course-card-meta {
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: 12px;
    color: var(--text-dim);
    margin-bottom: 12px;
}
.course-card-progress {
    display: flex;
    align-items: center;
    gap: 10px;
}
.course-card-progress-text {
    font-size: 13px;
    font-weight: 700;
    color: var(--accent-light);
    white-space: nowrap;
}

/* Locked course overlay */
.course-card-locked {
    position: absolute;
    inset: 0;
    background: rgba(5, 8, 15, 0.85);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 8px;
    border-radius: 16px;
    z-index: 2;
    backdrop-filter: blur(4px);
}
.course-card-locked-icon {
    color: var(--text-dim);
    margin-bottom: 4px;
}
.course-card-locked-text {
    font-size: 14px;
    font-weight: 600;
    color: var(--text-muted);
}
.course-card-locked-sub {
    font-size: 12px;
    color: var(--text-dim);
}

/* Exclusive content cards */
.exclusive-card {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: 14px;
    overflow: hidden;
    transition: all 0.2s;
    cursor: pointer;
}
.exclusive-card:hover {
    border-color: var(--border-light);
    transform: translateY(-2px);
}
.exclusive-card-thumb {
    height: 80px;
    background: var(--bg-surface);
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
}
.exclusive-card-thumb-play {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: rgba(0, 0, 0, 0.5);
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
}
.exclusive-card-tag {
    position: absolute;
    top: 8px;
    right: 8px;
}
.exclusive-card-duration {
    position: absolute;
    bottom: 6px;
    right: 8px;
    font-size: 10px;
    font-weight: 600;
    color: #fff;
    background: rgba(0, 0, 0, 0.6);
    padding: 2px 6px;
    border-radius: 4px;
}
.exclusive-card-body {
    padding: 12px;
}
.exclusive-card-title {
    font-size: 14px;
    font-weight: 600;
    color: var(--text);
    margin-bottom: 4px;
}
.exclusive-card-info {
    font-size: 12px;
    color: var(--text-dim);
}

/* ===================================================================
   COURSE PAGE
   =================================================================== */
.course-banner {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: 16px;
    padding: 24px;
    margin-bottom: 24px;
    position: relative;
    overflow: hidden;
}
.course-banner-title {
    font-size: 22px;
    font-weight: 700;
    margin-bottom: 8px;
}
.course-banner-desc {
    font-size: 14px;
    color: var(--text-muted);
    margin-bottom: 16px;
}
.course-banner-stats {
    display: flex;
    gap: 20px;
    font-size: 13px;
    color: var(--text-dim);
}

/* Module header */
.module-header {
    font-size: 11px;
    font-weight: 700;
    color: var(--accent);
    text-transform: uppercase;
    letter-spacing: 1px;
    padding: 12px 0 8px;
    border-bottom: 1px solid var(--border);
    margin-top: 20px;
    margin-bottom: 4px;
}
.module-header:first-child {
    margin-top: 0;
}

/* Lesson row */
.lesson-row {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 14px 16px;
    border-bottom: 1px solid var(--border);
    transition: all 0.15s;
    cursor: pointer;
    text-decoration: none;
    color: inherit;
}
.lesson-row:hover {
    background: var(--bg-card-hover);
}
.lesson-row.locked {
    opacity: 0.45;
    cursor: not-allowed;
}
.lesson-row.locked:hover {
    background: transparent;
}

.lesson-status-icon {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    font-size: 12px;
}
.lesson-status-completed {
    background: var(--green-glow);
    color: var(--green);
}
.lesson-status-current {
    background: var(--accent-glow);
    color: var(--accent);
    border: 2px solid var(--accent);
}
.lesson-status-locked {
    background: var(--bg-surface);
    color: var(--text-dim);
}

.lesson-info {
    flex: 1;
    min-width: 0;
}
.lesson-title {
    font-size: 14px;
    font-weight: 600;
    color: var(--text);
}
.lesson-row.locked .lesson-title {
    color: var(--text-dim);
}

.lesson-badges {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-shrink: 0;
}
.lesson-duration {
    font-size: 12px;
    color: var(--text-dim);
    white-space: nowrap;
}

/* ===================================================================
   LESSON PAGE (Player)
   =================================================================== */
.player-container {
    border-radius: 16px;
    overflow: hidden;
    background: #060d15;
    border: 1px solid var(--border);
    margin-bottom: 20px;
}
.player-container.fullscreen {
    border-radius: 0;
    border: none;
}
.player-video {
    position: relative;
    width: 100%;
    padding-top: 56.25%; /* 16:9 */
    background: linear-gradient(135deg, #060d15, #0c1a28);
}
.player-video iframe,
.player-video video {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

/* Player controls — always dark */
.player-controls {
    background: #0c1219;
    padding: 0 16px 12px;
}

/* Seek bar */
.player-seek {
    position: relative;
    height: 24px;
    display: flex;
    align-items: center;
    cursor: pointer;
    touch-action: none;
    -webkit-touch-callout: none;
    user-select: none;
}
.player-seek-track {
    position: absolute;
    left: 0;
    right: 0;
    height: 6px;
    background: #1a2332;
    border-radius: 3px;
    overflow: hidden;
}
.player-seek-max {
    position: absolute;
    height: 100%;
    background: rgba(34, 197, 94, 0.3);
    border-radius: 3px;
}
.player-seek-progress {
    position: absolute;
    height: 100%;
    background: linear-gradient(90deg, #22c55e, #0ea5e9);
    border-radius: 3px;
    transition: width 0.1s linear;
}
.player-seek-thumb {
    position: absolute;
    width: 20px;
    height: 20px;
    border-radius: 50%;
    background: #22c55e;
    border: 3px solid #fff;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.4);
    transform: translateX(-50%);
    z-index: 2;
    pointer-events: none;
}

/* Control buttons */
.player-buttons {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: 8px;
}
.player-buttons-left {
    display: flex;
    align-items: center;
    gap: 12px;
}
.player-buttons-right {
    display: flex;
    align-items: center;
    gap: 6px;
}

.player-play-btn {
    width: 44px;
    height: 44px;
    border-radius: 12px;
    background: linear-gradient(135deg, #22c55e, #0ea5e9);
    border: none;
    color: #fff;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: transform 0.15s;
}
.player-play-btn:hover {
    transform: scale(1.05);
}

.player-time {
    font-size: 13px;
    color: #94a3b8;
    font-variant-numeric: tabular-nums;
}

.player-speed-btn {
    padding: 4px 10px;
    border-radius: 6px;
    border: 1px solid #253344;
    background: none;
    color: #64748b;
    font-size: 12px;
    font-weight: 600;
    cursor: pointer;
    font-family: inherit;
    transition: all 0.15s;
}
.player-speed-btn:hover {
    border-color: #34d399;
    color: #94a3b8;
}
.player-speed-btn.active {
    background: rgba(34, 197, 94, 0.14);
    border-color: #22c55e;
    color: #22c55e;
}

.player-fullscreen-btn {
    width: 40px;
    height: 36px;
    border-radius: 8px;
    border: 1px solid #253344;
    background: none;
    color: #64748b;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.15s;
}
.player-fullscreen-btn:hover {
    border-color: #34d399;
    color: #94a3b8;
}

/* Status indicator */
.player-indicator {
    padding: 10px 16px;
    border-radius: 10px;
    font-size: 13px;
    font-weight: 600;
    display: flex;
    align-items: center;
    gap: 8px;
    margin-top: 12px;
}
.player-indicator-blocked {
    background: var(--yellow-glow);
    color: var(--yellow);
    border: 1px solid rgba(234, 179, 8, 0.25);
}
.player-indicator-free {
    background: var(--green-glow);
    color: var(--green);
    border: 1px solid rgba(34, 197, 94, 0.25);
}

/* ===================================================================
   RANKING PAGE
   =================================================================== */
.ranking-header {
    text-align: center;
    margin-bottom: 32px;
}
.ranking-header-icon {
    color: var(--yellow);
    margin-bottom: 8px;
}
.ranking-company-badge {
    display: inline-flex;
    align-items: center;
    padding: 4px 12px;
    border-radius: 8px;
    background: var(--accent-glow);
    color: var(--accent);
    font-size: 12px;
    font-weight: 600;
    margin-top: 8px;
}

/* Podium */
.podium-container {
    display: flex;
    align-items: flex-end;
    justify-content: center;
    gap: 16px;
    margin-bottom: 32px;
}
.podium-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
}
.podium-avatar {
    margin-bottom: 8px;
}
.podium-name {
    font-size: 14px;
    font-weight: 700;
    color: var(--text);
    margin-bottom: 2px;
}
.podium-points {
    font-size: 13px;
    font-weight: 700;
    margin-bottom: 8px;
}
.podium-pillar {
    width: 100%;
    min-width: 80px;
    border-radius: 12px 12px 0 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 16px 8px;
}
.podium-medal {
    font-size: 24px;
    margin-bottom: 4px;
}
.podium-position {
    font-size: 28px;
    font-weight: 800;
    color: #fff;
}

.podium-gold .podium-points { color: #f59e0b; }
.podium-gold .podium-pillar { background: linear-gradient(180deg, #f59e0b, #b45309); height: 150px; }

.podium-silver .podium-points { color: #94a3b8; }
.podium-silver .podium-pillar { background: linear-gradient(180deg, #94a3b8, #64748b); height: 120px; }

.podium-bronze .podium-points { color: #cd7f32; }
.podium-bronze .podium-pillar { background: linear-gradient(180deg, #cd7f32, #8b5a2b); height: 100px; }

/* Ranking list */
.ranking-list {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: 16px;
    overflow: hidden;
    margin-bottom: 32px;
}
.ranking-row {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 14px 20px;
    border-bottom: 1px solid var(--border);
    transition: background 0.15s;
}
.ranking-row:last-child {
    border-bottom: none;
}
.ranking-row:hover {
    background: var(--bg-card-hover);
}
.ranking-row.is-you {
    background: var(--accent-glow2);
    border-left: 3px solid var(--accent);
}
.ranking-position {
    width: 32px;
    text-align: center;
    font-size: 16px;
    font-weight: 700;
    color: var(--text-dim);
}
.ranking-name {
    flex: 1;
    font-size: 14px;
    font-weight: 600;
    color: var(--text);
    display: flex;
    align-items: center;
    gap: 8px;
}
.ranking-you-badge {
    font-size: 10px;
    font-weight: 700;
    background: var(--accent);
    color: #fff;
    padding: 2px 8px;
    border-radius: 6px;
}
.ranking-points {
    font-size: 16px;
    font-weight: 700;
    color: var(--text-muted);
}
.ranking-row.is-you .ranking-points {
    color: var(--green);
}

/* Scoring table */
.scoring-table {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: 16px;
    padding: 24px;
}
.scoring-table-title {
    font-size: 16px;
    font-weight: 700;
    margin-bottom: 16px;
}
.scoring-row {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 0;
    border-bottom: 1px solid var(--border);
}
.scoring-row:last-child {
    border-bottom: none;
}
.scoring-icon {
    font-size: 20px;
    width: 32px;
    text-align: center;
}
.scoring-action {
    flex: 1;
    font-size: 13px;
    color: var(--text);
}
.scoring-points {
    font-size: 14px;
    font-weight: 700;
    color: var(--accent);
    white-space: nowrap;
}

/* ===================================================================
   PROFILE PAGE
   =================================================================== */
.profile-avatar-section {
    text-align: center;
    margin-bottom: 32px;
}
.profile-avatar-wrapper {
    position: relative;
    display: inline-block;
}
.profile-avatar-upload {
    position: absolute;
    inset: 0;
    border-radius: 50%;
    background: rgba(0, 0, 0, 0.5);
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    opacity: 0;
    cursor: pointer;
    transition: opacity 0.2s;
}
.profile-avatar-wrapper:hover .profile-avatar-upload {
    opacity: 1;
}
.profile-name {
    font-size: 22px;
    font-weight: 700;
    margin-top: 16px;
}
.profile-role {
    font-size: 13px;
    color: var(--text-dim);
    margin-top: 4px;
}

.profile-info-card {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: 16px;
    overflow: hidden;
}
.profile-info-row {
    display: flex;
    align-items: center;
    padding: 16px 20px;
    border-bottom: 1px solid var(--border);
}
.profile-info-row:last-child {
    border-bottom: none;
}
.profile-info-label {
    width: 160px;
    font-size: 12px;
    font-weight: 600;
    color: var(--text-dim);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    flex-shrink: 0;
}
.profile-info-value {
    font-size: 14px;
    color: var(--text);
    flex: 1;
}

/* ===================================================================
   CERTIFICATES PAGE
   =================================================================== */
.certificate-card {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: 16px;
    padding: 24px;
    display: flex;
    align-items: center;
    gap: 20px;
}
.certificate-icon {
    color: var(--accent);
    flex-shrink: 0;
}
.certificate-info {
    flex: 1;
}
.certificate-course {
    font-size: 16px;
    font-weight: 700;
    color: var(--text);
    margin-bottom: 4px;
}
.certificate-meta {
    font-size: 12px;
    color: var(--text-dim);
}
.certificate-code {
    font-size: 11px;
    color: var(--accent);
    font-weight: 600;
    margin-top: 4px;
}

/* Certificate preview (modal) */
.certificate-preview {
    background: var(--accent-glow2);
    border: 1px solid var(--accent-glow);
    border-radius: 16px;
    padding: 32px;
    text-align: center;
    margin: 20px 0;
}
.certificate-preview-title {
    font-size: 11px;
    font-weight: 700;
    color: var(--accent);
    text-transform: uppercase;
    letter-spacing: 2px;
    margin-bottom: 12px;
}
.certificate-preview-course {
    font-size: 18px;
    font-weight: 700;
    color: var(--text);
    margin-bottom: 8px;
}
.certificate-preview-student {
    font-size: 14px;
    color: var(--text-muted);
}
.certificate-preview-details {
    font-size: 12px;
    color: var(--text-dim);
    margin-top: 16px;
}
.certificate-preview-code {
    font-size: 13px;
    color: var(--accent);
    font-weight: 700;
    margin-top: 8px;
}

/* ===================================================================
   QUIZ SECTION (within lesson page)
   =================================================================== */
.quiz-section {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: 16px;
    padding: 28px;
    margin-top: 20px;
    border-color: var(--accent-glow);
    box-shadow: 0 0 30px var(--accent-glow2);
}
.quiz-title {
    font-size: 18px;
    font-weight: 700;
    margin-bottom: 16px;
}
.quiz-question {
    font-size: 15px;
    color: var(--text-muted);
    margin-bottom: 20px;
}
.quiz-options {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin-bottom: 24px;
}

/* Quiz result */
.quiz-result {
    border-radius: 16px;
    padding: 32px;
    text-align: center;
    margin-top: 20px;
}
.quiz-result-correct {
    background: var(--green-glow);
    border: 1px solid rgba(34, 197, 94, 0.25);
}
.quiz-result-wrong {
    background: rgba(239, 68, 68, 0.08);
    border: 1px solid rgba(239, 68, 68, 0.25);
}
.quiz-result-emoji {
    font-size: 48px;
    margin-bottom: 12px;
}
.quiz-result-title {
    font-size: 20px;
    font-weight: 700;
    margin-bottom: 8px;
}
.quiz-result-correct .quiz-result-title { color: var(--green); }
.quiz-result-wrong .quiz-result-title { color: var(--red); }
.quiz-result-text {
    font-size: 14px;
    color: var(--text-muted);
}
