@font-face{font-family:Outfit;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/b2ea385cb5ae8625-s.866357a4.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Outfit;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/1b99372b3eaef0c8-s.p.758e15a8.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Outfit Fallback;src:local(Arial);ascent-override:100.18%;descent-override:26.05%;line-gap-override:0.0%;size-adjust:99.82%}.outfit_43d50961-module__KOAtAG__className{font-family:Outfit,Outfit Fallback;font-style:normal}
:root{--primary-color:#4f46e5;--primary-hover:#4338ca;--secondary-color:#64748b;--bg-color:#f8fafc;--sidebar-bg:#fff;--card-bg:#fff;--text-main:#0f172a;--text-muted:#64748b;--border-color:#e2e8f0;--success-color:#22c55e;--danger-color:#ef4444;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a}body{background-color:var(--bg-color);color:var(--text-main);height:100vh;margin:0;display:flex;overflow:hidden}.app-container{width:100%;display:flex}.sidebar{background:var(--sidebar-bg);border-right:1px solid var(--border-color);flex-direction:column;flex-shrink:0;gap:20px;width:280px;padding:24px;display:flex}.logo-area h2{color:var(--primary-color);letter-spacing:-.5px;margin:0;font-size:1.5rem;font-weight:600}.sidebar-mode-toggle{background:var(--bg-color);border-radius:8px;gap:4px;padding:4px;display:flex}.toggle-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:6px;flex:1;padding:8px;font-family:inherit;font-weight:500;transition:all .2s}.toggle-btn.active{color:var(--text-main);box-shadow:var(--shadow-sm);background:#fff}.search-box{position:relative}.search-box i,.search-box svg{color:var(--text-muted);position:absolute;top:50%;left:12px;transform:translateY(-50%)}.search-box input{border:1px solid var(--border-color);box-sizing:border-box;border-radius:8px;outline:none;width:100%;padding:10px 10px 10px 36px;font-family:inherit;font-size:.9rem;transition:border-color .2s}.search-box input:focus{border-color:var(--primary-color)}.course-list{flex-direction:column;flex:1;gap:4px;display:flex;overflow-y:auto}.course-item{cursor:pointer;color:var(--text-muted);border-radius:8px;padding:12px;font-size:.95rem;transition:all .2s}.course-item:hover{background:var(--bg-color);color:var(--text-main)}.course-item.active{color:var(--primary-color);background:#e0e7ff;font-weight:500}.main-content{flex:1;max-width:1600px;padding:32px 40px;overflow-y:auto}header{justify-content:space-between;align-items:center;margin-bottom:32px;display:flex}header h1{margin:0;font-size:1.8rem;font-weight:600}.date-filter{border:1px solid var(--border-color);box-shadow:var(--shadow-sm);background:#fff;border-radius:10px;align-items:center;gap:12px;padding:8px 12px;display:flex}.date-filter input{border:1px solid var(--border-color);color:var(--text-muted);border-radius:6px;padding:6px;font-family:inherit}header button{cursor:pointer;border:none;border-radius:6px;padding:8px 16px;font-family:inherit;font-weight:500;transition:opacity .2s}header button#applyFilter,.btn-primary{background:var(--primary-color);color:#fff}header button.secondary,.btn-secondary{color:var(--text-muted);background:0 0}.kpi-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;margin-bottom:32px;display:grid}.stat-card{border:1px solid var(--border-color);box-shadow:var(--shadow-sm);background:#fff;border-radius:12px;flex-direction:column;justify-content:space-between;padding:24px;transition:transform .2s,box-shadow .2s;display:flex}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-card .label{color:var(--text-muted);margin-bottom:8px;font-size:.9rem;font-weight:500}.stat-card .value{color:var(--text-main);font-size:2rem;font-weight:600}.stat-card .sub-value{color:var(--text-muted);margin-top:8px;font-size:.85rem}.stat-card .icon-wrapper{background:var(--bg-color);width:40px;height:40px;color:var(--primary-color);border-radius:50%;justify-content:center;align-items:center;margin-bottom:16px;font-size:1.2rem;display:flex}.chart-section{border:1px solid var(--border-color);box-shadow:var(--shadow-sm);background:#fff;border-radius:12px;margin-bottom:32px;padding:24px}.section-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.section-header h3{margin:0;font-size:1.1rem;font-weight:500}.chart-controls button{background:var(--bg-color);border:1px solid var(--border-color);cursor:pointer;border-radius:6px;padding:4px 12px;font-size:.85rem}.chart-controls button.active{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.map-container{background:#e2e8f0;border-radius:8px;height:400px;overflow:hidden}.table-responsive{overflow-x:auto}table{border-collapse:collapse;width:100%}th,td{text-align:left;border-bottom:1px solid var(--border-color);padding:16px}th{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:.85rem;font-weight:500}.loading{color:var(--text-muted);justify-content:center;padding:40px;display:flex}.pdf-breakdown{flex-direction:column;gap:6px;margin-top:12px;display:flex}.pdf-item{color:var(--text-muted);justify-content:space-between;font-size:.85rem;display:flex}.pdf-item span:last-child{color:var(--text-main);font-weight:500}@media print{.sidebar,.date-filter,.chart-controls button,.toggle-btn{display:none!important}.main-content{max-width:100%;padding:0}body,.app-container{height:auto;display:block;overflow:visible}.kpi-grid{page-break-inside:avoid;grid-template-columns:repeat(3,1fr);gap:16px}.stat-card{box-shadow:none;break-inside:avoid;border:1px solid #ccc}.chart-section{box-shadow:none;page-break-inside:avoid;border:1px solid #ccc}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton{background:linear-gradient(90deg,#f1f5f9 25%,#e2e8f0 50%,#f1f5f9 75%) 0 0/200% 100%;animation:2s linear infinite shimmer;display:inline-block}.skeleton-card{background:#fff;border-radius:16px;flex-direction:column;gap:12px;height:100%;padding:24px;display:flex;box-shadow:0 4px 6px -1px #0000000d}.skeleton-chart-container{background:#fff;border-radius:16px;height:350px;padding:24px;box-shadow:0 4px 6px -1px #0000000d}
