@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&display=swap";
:root{--bg-primary:#0f1219;--bg-secondary:#161a23;--bg-card:#1d222e;--brand-primary:#f34;--brand-secondary:#ff6b6b;--brand-surface:#ff33441a;--brand-gradient:linear-gradient(135deg, #f34 0%, #ff6b6b 100%);--text-primary:#f8fafc;--text-secondary:#94a3b8;--text-tertiary:#64748b;--success:#10b981;--success-surface:#10b98126;--warning:#f59e0b;--warning-surface:#f59e0b26;--info:#3b82f6;--info-surface:#3b82f626;--purple:#8b5cf6;--border-subtle:#ffffff0f;--shadow-lg:0 10px 25px -5px #00000080, 0 8px 10px -6px #0000004d;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px}*{box-sizing:border-box;margin:0;padding:0}html,body{background-color:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;width:100%;min-height:100vh;font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;line-height:1.5}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--bg-card);border-radius:var(--radius-sm)}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}.glass-panel{-webkit-backdrop-filter:blur(12px);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);background:#1d222eb3}.dashboard-container{background:var(--bg-primary);background-image:radial-gradient(circle at 10% 20%,#ff33440d 0%,#0000 40%),radial-gradient(circle at 90% 80%,#8b5cf60d 0%,#0000 40%);background-attachment:fixed;width:100%;min-height:100vh;display:flex}.sidebar{background:var(--bg-secondary);border-right:1px solid var(--border-subtle);z-index:10;flex-direction:column;width:250px;padding:1.5rem;display:flex}.brand{border-bottom:1px solid var(--border-subtle);align-items:center;gap:.75rem;margin-bottom:2rem;padding-bottom:1.5rem;display:flex}.brand-icon{background:var(--brand-gradient);border-radius:var(--radius-sm);color:#fff;justify-content:center;align-items:center;width:36px;height:36px;display:flex;box-shadow:0 4px 12px #ff33444d}.brand h1{color:var(--text-primary);letter-spacing:-.02em;font-size:1.25rem;font-weight:700}.brand h1 span{color:var(--text-tertiary);margin-top:.1rem;font-size:.75rem;font-weight:400;display:block}.nav-menu{flex-direction:column;gap:.5rem;display:flex}.nav-item{color:var(--text-secondary);border-radius:var(--radius-md);cursor:pointer;align-items:center;gap:.75rem;padding:.8rem 1rem;font-size:.95rem;font-weight:500;transition:all .2s;display:flex}.nav-item:hover{color:var(--text-primary);background:#ffffff08}.nav-item.active{background:var(--brand-surface);color:var(--brand-primary)}.nav-item svg{color:var(--text-tertiary);transition:color .2s}.nav-item:hover svg{color:var(--text-primary)}.nav-item.active svg{color:var(--brand-primary)}.main-content{flex:1;padding:2rem 3rem;position:relative;overflow-y:auto}.header{justify-content:space-between;align-items:center;margin-bottom:2.5rem;display:flex}.header-title h2{letter-spacing:-.02em;font-size:1.8rem;font-weight:700}.header-title p{color:var(--text-secondary);margin-top:.2rem;font-size:.95rem}.header-actions{gap:1rem;display:flex}.btn-secondary,.btn-primary{border-radius:var(--radius-sm);cursor:pointer;border:none;align-items:center;gap:.5rem;padding:.6rem 1.2rem;font-size:.9rem;font-weight:600;transition:all .2s;display:flex}.btn-secondary{background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border-subtle)}.btn-secondary:hover{background:#ffffff14}.btn-primary{background:var(--brand-gradient);color:#fff;box-shadow:0 4px 12px #f343}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 16px #ff33444d}.period-toggle{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);display:flex;overflow:hidden}.period-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;padding:.5rem 1.1rem;font-size:.88rem;font-weight:600;transition:all .2s}.period-btn.active{background:var(--brand-gradient);color:#fff;box-shadow:0 2px 10px #ff334440}.period-btn:not(.active):hover{color:var(--text-primary);background:#ffffff0f}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:2000;background:#000000a6;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-card{background:#1a1f2e;border:1px solid #ffffff14;border-radius:16px;width:420px;max-width:90vw;padding:2rem;box-shadow:0 24px 64px #0009}.modal-header{justify-content:space-between;align-items:center;margin-bottom:.6rem;display:flex}.modal-header h3{color:var(--text-primary);align-items:center;font-size:1.1rem;font-weight:700;display:flex}.modal-close{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:6px;align-items:center;padding:.25rem;transition:color .2s;display:flex}.modal-close:hover{color:var(--text-primary)}.modal-sub{color:var(--text-secondary);margin-bottom:1.5rem;font-size:.85rem}.modal-fields{grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.5rem;display:grid}.modal-fields label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;flex-direction:column;gap:.4rem;font-size:.82rem;font-weight:600;display:flex}.modal-fields input[type=date]{background:var(--bg-body);border:1px solid var(--border-subtle);color:var(--text-primary);border-radius:8px;outline:none;padding:.5rem .75rem;font-family:inherit;font-size:.9rem;transition:border-color .2s}.modal-fields input[type=date]:focus{border-color:var(--brand-primary)}.modal-actions{justify-content:flex-end;gap:.75rem;display:flex}.kpi-grid{grid-template-columns:repeat(4,1fr);gap:1.5rem;margin-bottom:2.5rem;display:grid}.kpi-grid-3{grid-template-columns:repeat(3,1fr)}.chart-tooltip{z-index:1000;pointer-events:none;background:#1d222e;border:1px solid #ffffff14;border-radius:8px;min-width:160px;padding:.6rem .9rem;position:fixed;box-shadow:0 8px 24px #00000080}.tooltip-title{color:var(--text-primary);border-bottom:1px solid #ffffff0f;margin-bottom:.3rem;padding-bottom:.3rem;font-size:.82rem;font-weight:700}.tooltip-line{color:var(--text-secondary);font-size:.78rem;line-height:1.6}.kpi-card{padding:1.5rem;transition:transform .3s,box-shadow .3s;position:relative;overflow:hidden}.kpi-card:hover{transform:translateY(-4px);box-shadow:0 12px 30px -8px #0009}.kpi-card .glass-blur{background:radial-gradient(circle, var(--info-surface) 0%, transparent 60%);opacity:.5;filter:blur(20px);width:100px;height:100px;position:absolute;top:-20px;right:-20px}.kpi-card:nth-child(2) .glass-blur{background:radial-gradient(circle, var(--success-surface) 0%, transparent 60%)}.kpi-card:nth-child(3) .glass-blur{background:radial-gradient(circle, var(--purple) 0%, transparent 60%);opacity:.15}.kpi-card:nth-child(4) .glass-blur{background:radial-gradient(circle, var(--warning-surface) 0%, transparent 60%)}.kpi-header{color:var(--text-secondary);z-index:2;justify-content:space-between;align-items:center;margin-bottom:1rem;font-size:.9rem;font-weight:500;display:flex;position:relative}.kpi-icon{border-radius:var(--radius-sm);justify-content:center;align-items:center;width:32px;height:32px;display:flex}.kpi-value{color:var(--text-primary);z-index:2;margin-bottom:.2rem;font-size:2.2rem;font-weight:700;position:relative}.kpi-trend{z-index:2;align-items:center;gap:.3rem;font-size:.85rem;font-weight:500;display:flex;position:relative}.kpi-trend.positive{color:var(--success)}.kpi-trend.neutral{color:var(--text-tertiary)}.charts-row{grid-template-columns:1fr 1fr;gap:1.5rem;margin-bottom:2.5rem;display:grid}.chart-card{flex-direction:column;padding:1.5rem;display:flex}.chart-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.chart-title h3{font-size:1.1rem;font-weight:600}.chart-title p{color:var(--text-secondary);margin-top:.1rem;font-size:.85rem}.chart-body{flex:1;justify-content:center;align-items:center;min-height:280px;display:flex;position:relative}.funnel-list{flex-direction:column;gap:1.2rem;width:100%;display:flex}.funnel-item{width:100%}.funnel-info{justify-content:space-between;margin-bottom:.4rem;font-size:.9rem;font-weight:500;display:flex}.funnel-track{background:#ffffff0d;border-radius:4px;width:100%;height:8px;overflow:hidden}.funnel-fill{background:var(--brand-gradient);border-radius:4px;height:100%;transition:width 1s ease-in-out}.pyramid-container{flex-direction:column;gap:.85rem;width:100%;padding:.5rem 0;display:flex}.pyramid-row{align-items:center;gap:1rem;display:flex}.pyramid-label{min-width:200px;max-width:200px;color:var(--text-secondary);text-align:right;white-space:nowrap;text-overflow:ellipsis;flex-shrink:0;font-size:.85rem;overflow:hidden}.pyramid-bar-wrap{flex:1;align-items:center;display:flex}.pyramid-bar{border-radius:0 6px 6px 0;align-items:center;min-width:70px;height:28px;padding:0 .75rem;transition:width 1s ease-in-out;display:flex;position:relative}.pyramid-count{color:#ffffffeb;white-space:nowrap;font-size:.78rem;font-weight:700}.pyramid-completion-label{color:var(--text-secondary);white-space:nowrap;flex-shrink:0;margin-left:.6rem;font-size:.78rem;font-weight:600}.dual-legend{color:var(--text-secondary);white-space:nowrap;align-items:center;gap:.5rem;font-size:.8rem;display:flex}.legend-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px;display:inline-block}.dual-bar-list{flex-direction:column;gap:1rem;width:100%;display:flex}.dual-bar-item{width:100%}.dual-bar-label{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;margin-bottom:.35rem;font-size:.85rem;font-weight:500;overflow:hidden}.dual-bar-rows{flex-direction:column;gap:.3rem;display:flex}.dual-bar-row{align-items:center;gap:.6rem;display:flex}.dual-bar-pct{text-align:right;flex-shrink:0;width:36px;font-size:.78rem;font-weight:700}.dual-bar-track{background:#ffffff0d;border-radius:4px;flex:1;height:7px;overflow:hidden}.dual-bar-fill{border-radius:4px;height:100%;transition:width 1s ease-in-out}.table-section{padding:1.5rem;overflow-x:auto}.student-table{border-collapse:collapse;width:100%}.student-table th{text-align:left;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border-subtle);padding:1rem;font-size:.8rem;font-weight:600}.student-table td{vertical-align:middle;border-bottom:1px solid #ffffff08;padding:1.2rem 1rem}.student-table tr:hover td{background:#ffffff04}.student-table tr:last-child td{border-bottom:none}.user-cell{align-items:center;gap:1rem;display:flex}.avatar{background:var(--bg-primary);width:36px;height:36px;color:var(--brand-secondary);border:1px solid #ff6b6b33;border-radius:50%;justify-content:center;align-items:center;font-size:.9rem;font-weight:600;display:flex}.user-details strong{font-size:.95rem;font-weight:500;display:block}.user-details span{color:var(--text-secondary);font-size:.8rem}.progress-cell{width:150px}.mini-progress{align-items:center;gap:.75rem;font-size:.85rem;font-weight:500;display:flex}.mini-track{background:#ffffff14;border-radius:3px;flex:1;height:6px;overflow:hidden}.mini-fill{background:var(--success);border-radius:3px;height:100%}.badge{background:var(--bg-primary);border-radius:20px;align-items:center;gap:.3rem;padding:.3rem .6rem;font-size:.75rem;font-weight:600;display:inline-flex}.badge-success{color:var(--success);border:1px solid var(--success-surface);background:var(--success-surface)}.badge-warning{color:var(--warning);border:1px solid var(--warning-surface)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.animate-in{opacity:0;animation:.6s cubic-bezier(.16,1,.3,1) forwards fadeIn}.delay-100{animation-delay:.1s}.delay-200{animation-delay:.2s}.delay-300{animation-delay:.3s}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spin-icon{flex-shrink:0;animation:.9s linear infinite spin}
