/* ===== COMPONENTS — Page, Progress, Stats, Tracks, Badges, Digest, Category, Phases, Leaderboard ===== */

/* ===== PAGE STYLES ===== */
.page-title{font-size:22px;font-weight:800;margin-bottom:6px;display:flex;align-items:center;gap:10px}
.page-desc{font-size:13px;color:var(--muted-foreground);margin-bottom:24px;line-height:1.5;max-width:800px}
.welcome-banner{background:linear-gradient(135deg,var(--blue) 0%,var(--purple) 100%);border-radius:12px;padding:28px 32px;color:var(--white);margin-bottom:24px}
.welcome-banner h2{font-size:20px;font-weight:800;margin-bottom:4px}
.welcome-banner p{font-size:13px;opacity:.85;line-height:1.6}

/* ===== PROGRESS BAR ===== */
.progress-section{margin-bottom:24px}
.progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.progress-label{font-size:13px;font-weight:600;color:var(--gray-700)}
.progress-pct{font-size:12px;font-weight:700;color:var(--primary)}
.progress-bar{height:8px;background:var(--border);border-radius:var(--radius-full);overflow:hidden}
.progress-fill{height:100%;border-radius:var(--radius-full);background:linear-gradient(90deg,var(--primary),var(--purple));transition:width .4s ease}

/* ===== STAT CARDS ===== */
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:24px}
.stat-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px;text-align:center;box-shadow:var(--shadow)}
.stat-number{font-size:28px;font-weight:800;color:var(--primary)}
.stat-label{font-size:11px;color:var(--muted-foreground);margin-top:2px}

/* ===== TRACK CARDS ===== */
.section-title{font-size:16px;font-weight:700;color:var(--gray-800);margin-bottom:12px;display:flex;align-items:center;gap:8px}
.track-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px;margin-bottom:24px}
.track-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px;cursor:pointer;transition:all .15s;box-shadow:var(--shadow)}
.track-card:hover{border-color:var(--primary);box-shadow:var(--shadow-md);transform:translateY(-1px)}
.track-card-header{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.track-card-icon{font-size:24px}
.track-card-title{font-size:14px;font-weight:700;color:var(--card-foreground)}
.track-card-desc{font-size:12px;color:var(--muted-foreground);line-height:1.5;margin-bottom:10px}
.track-card-progress{display:flex;align-items:center;gap:8px}
.track-card-bar{flex:1;height:4px;background:var(--gray-200);border-radius:9999px;overflow:hidden}
.track-card-fill{height:100%;border-radius:9999px;transition:width .3s}
.track-card-pct{font-size:10px;font-weight:700;color:var(--gray-400)}

/* ===== BADGES ===== */
.badges-row{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:24px}
.badge-item{display:flex;align-items:center;gap:6px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:8px 14px;box-shadow:var(--shadow)}
.badge-item.locked{opacity:.4;filter:grayscale(1)}
.badge-icon{font-size:22px}
.badge-info{display:flex;flex-direction:column}
.badge-name{font-size:11px;font-weight:700;color:var(--gray-800)}
.badge-desc{font-size:9px;color:var(--gray-400)}

/* ===== DIGEST CARDS ===== */
.digest-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:14px;margin-bottom:24px}
.digest-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px;box-shadow:var(--shadow);transition:border-color .15s}
.digest-card:hover{border-color:var(--blue-light)}
.digest-tag{display:inline-block;font-size:9px;font-weight:700;padding:2px 8px;border-radius:9999px;margin-bottom:8px}
.digest-title{font-size:14px;font-weight:700;color:var(--card-foreground);margin-bottom:6px;line-height:1.4;transition:color .15s}
.digest-title:hover{color:var(--blue)}
.digest-summary{font-size:12px;color:var(--muted-foreground);line-height:1.5;margin-bottom:8px}
.digest-meta{font-size:10px;color:var(--muted-foreground);opacity:.7}

/* ===== CATEGORY VIEW ===== */
.cat-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.cat-emoji{font-size:32px}
.cat-info h2{font-size:20px;font-weight:800}
.cat-info p{font-size:13px;color:var(--gray-500)}
.stage-grid{display:grid;gap:8px;max-width:900px}
.stage-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:14px 18px;display:flex;align-items:center;gap:14px;transition:all .15s;cursor:pointer;box-shadow:var(--shadow)}
.stage-card:hover{border-color:var(--primary);box-shadow:var(--shadow-md)}
.stage-num{font-size:10px;font-weight:800;color:var(--primary-foreground);background:var(--gray-400);width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.stage-num.done{background:var(--success)}
.stage-num.progress{background:var(--primary)}
.stage-info{flex:1;min-width:0}
.stage-code{font-size:9px;font-weight:700;color:var(--gray-400);letter-spacing:1px}
.stage-title{font-size:13px;font-weight:600;color:var(--gray-800)}
.stage-summary{font-size:11px;color:var(--gray-500);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.stage-status{font-size:10px;font-weight:700;padding:3px 10px;border-radius:9999px;white-space:nowrap}
.stage-status.not-started{background:var(--gray-100);color:var(--gray-400)}
.stage-status.in-progress{background:var(--blue-light);color:var(--blue-dark)}
.stage-status.completed{background:var(--green-light);color:var(--green)}
.stage-status.na{background:var(--gray-50);color:var(--gray-300);font-style:italic}

/* ===== PHASE SEPARATOR ===== */
.phase-sep{display:flex;align-items:center;gap:12px;margin:20px 0 12px;max-width:900px}
.phase-sep .line{flex:1;height:2px}
.phase-sep .label{font-size:11px;font-weight:800;letter-spacing:1px;padding:4px 16px;border-radius:8px;white-space:nowrap;color:var(--white)}
.phase-prod .line{background:linear-gradient(90deg,var(--blue),var(--purple))}
.phase-prod .label{background:linear-gradient(135deg,var(--blue),var(--purple))}
.phase-post .line{background:linear-gradient(90deg,var(--green),var(--teal))}
.phase-post .label{background:linear-gradient(135deg,var(--green),var(--teal))}

/* ===== LEADERBOARD ===== */
.leaderboard{max-width:500px;margin-bottom:24px}
.lb-row{display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:4px}
.lb-rank{font-size:14px;font-weight:800;color:var(--gray-400);width:24px;text-align:center}
.lb-rank.gold{color:var(--yellow)}
.lb-rank.silver{color:var(--gray-400)}
.lb-rank.bronze{color:var(--orange)}
.lb-name{flex:1;font-size:13px;font-weight:600}
.lb-xp{font-size:12px;font-weight:700;color:var(--purple)}
.lb-badges{font-size:14px}

/* ===== DIGEST TABS ===== */
.digest-tabs{display:flex;gap:4px;margin-bottom:16px;background:var(--gray-100);border-radius:8px;padding:3px}
.digest-tab{border:none;background:none;padding:8px 16px;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;color:var(--gray-500);transition:all .15s}
.digest-tab:hover{color:var(--gray-700)}
.digest-tab.active{background:var(--white);color:var(--blue-dark);box-shadow:var(--shadow)}

/* ===== FUNDAMENTOS ===== */
.fundamentals-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px;margin-bottom:24px}
.fund-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px;box-shadow:var(--shadow);cursor:pointer;transition:all .15s}
.fund-card:hover{border-color:var(--purple);box-shadow:var(--shadow-md)}
.fund-card.completed-fund{border-left:3px solid var(--success)}
.fund-icon{font-size:28px;margin-bottom:8px}
.fund-title{font-size:14px;font-weight:700;color:var(--card-foreground);margin-bottom:4px}
.fund-desc{font-size:12px;color:var(--muted-foreground);line-height:1.5;margin-bottom:8px}
.fund-time{font-size:10px;color:var(--muted-foreground);opacity:.7;font-weight:600}
