.summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;margin-bottom:30px}.summary-card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 4px 6px #0000001a;border-top:4px solid;transition:transform .2s,box-shadow .2s;display:flex;align-items:flex-start;gap:16px}.summary-card:hover{transform:translateY(-4px);box-shadow:0 8px 12px #00000026}.card-icon{font-size:32px;line-height:1}.card-content{flex:1}.card-title{font-size:14px;color:#666;margin-bottom:8px;font-weight:500}.card-value{font-size:24px;font-weight:700;color:#333;margin-bottom:4px}.card-subtitle{font-size:12px;color:#999}@media (max-width: 768px){.summary-cards{grid-template-columns:1fr}}.chart-container{background:#fff;border-radius:12px;padding:30px;box-shadow:0 4px 6px #0000001a;margin-bottom:30px}.chart-title{font-size:24px;color:#333;margin-bottom:20px;font-weight:700}.chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.view-toggle{display:flex;gap:8px}.view-toggle button{padding:8px 16px;border:2px solid #667eea;background:#fff;color:#667eea;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s}.view-toggle button:hover{background:#f0f0f0}.view-toggle button.active{background:#667eea;color:#fff}.custom-tooltip{background:#000000d9;color:#fff;padding:12px;border-radius:6px;box-shadow:0 4px 6px #0003}.tooltip-label{font-weight:600;margin-bottom:4px;font-size:14px}.tooltip-value{font-size:13px;margin:2px 0;color:#e0e0e0}@media (max-width: 768px){.chart-container{padding:20px}.chart-header{flex-direction:column;align-items:flex-start;gap:15px}}.detailed-breakdowns{background:#fff;border-radius:12px;padding:30px;box-shadow:0 4px 6px #0000001a;margin-bottom:30px}.breakdown-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;flex-wrap:wrap;gap:20px}.breakdown-title{font-size:24px;color:#333;font-weight:700;margin:0}.breakdown-tabs{display:flex;gap:10px;flex-wrap:wrap}.breakdown-tabs button{padding:10px 20px;border:2px solid #667eea;background:#fff;color:#667eea;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s}.breakdown-tabs button:hover{background:#f0f0f0}.breakdown-tabs button.active{background:#667eea;color:#fff}.breakdown-content{max-height:800px;overflow-y:auto}.breakdown-section{border:1px solid #e0e0e0;border-radius:8px;margin-bottom:15px;overflow:hidden;transition:box-shadow .2s}.breakdown-section:hover{box-shadow:0 2px 8px #0000001a}.breakdown-section-header{background:#f8f9fa;padding:20px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;transition:background .2s}.breakdown-section-header:hover{background:#e9ecef}.section-header-content{flex:1}.section-header-content h3{font-size:18px;color:#333;margin:0 0 10px;font-weight:600}.section-stats{display:flex;gap:20px;flex-wrap:wrap}.stat-item{font-size:14px;color:#666}.stat-item strong{color:#333;font-weight:600}.expand-icon{font-size:12px;color:#667eea;font-weight:700;margin-left:15px}.breakdown-table-container{padding:20px;background:#fff}.breakdown-table{width:100%;border-collapse:collapse;font-size:14px}.breakdown-table thead{background:#f8f9fa}.breakdown-table th{padding:12px;text-align:left;font-weight:600;color:#333;border-bottom:2px solid #e0e0e0}.breakdown-table td{padding:12px;border-bottom:1px solid #f0f0f0;color:#666}.breakdown-table tbody tr:hover{background:#f8f9fa}.class-cell{font-weight:600;color:#667eea}.course-cell{max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.plan-cell{max-width:250px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.number-cell{text-align:right;font-weight:500}.amount-cell{text-align:right;font-weight:600;color:#333}.percentage-cell{text-align:right;color:#667eea;font-weight:600}.class-breakdown{margin-bottom:20px;border:1px solid #e0e0e0;border-radius:6px;overflow:hidden}.class-header{background:#f0f4ff;padding:15px 20px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;transition:background .2s}.class-header:hover{background:#e0e8ff}.class-header h4{margin:0;font-size:16px;color:#667eea;font-weight:600}.class-header-stats{display:flex;gap:20px;flex-wrap:wrap;flex:1;margin-left:20px}.no-data{text-align:center;padding:40px;color:#999;font-size:16px}.breakdown-content::-webkit-scrollbar{width:8px}.breakdown-content::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.breakdown-content::-webkit-scrollbar-thumb{background:#667eea;border-radius:4px}.breakdown-content::-webkit-scrollbar-thumb:hover{background:#5568d3}@media (max-width: 768px){.breakdown-header{flex-direction:column;align-items:flex-start}.breakdown-tabs{width:100%}.breakdown-tabs button{flex:1;font-size:12px;padding:8px 12px}.section-stats{flex-direction:column;gap:8px}.breakdown-table{font-size:12px}.breakdown-table th,.breakdown-table td{padding:8px}.course-cell,.plan-cell{max-width:150px}}.app{width:100%}.app-header{text-align:center;color:#fff;margin-bottom:40px;padding:30px 20px}.app-header h1{font-size:42px;font-weight:700;margin-bottom:10px;text-shadow:2px 2px 4px rgba(0,0,0,.2)}.subtitle{font-size:18px;opacity:.9;font-weight:300}.charts-grid{display:grid;grid-template-columns:1fr;gap:30px}.app-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;color:#fff}.loading-spinner{width:50px;height:50px;border:4px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:20px}@keyframes spin{to{transform:rotate(360deg)}}.app-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;color:#fff;text-align:center;padding:20px}.app-error h2{font-size:32px;margin-bottom:20px}.app-error p{font-size:18px;margin-bottom:30px;opacity:.9}.app-error button{padding:12px 24px;background:#fff;color:#667eea;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s}.app-error button:hover{transform:scale(1.05)}.app-footer{text-align:center;color:#fff;padding:30px 20px;margin-top:40px;opacity:.8}.app-footer p{margin:5px 0;font-size:14px}@media (max-width: 768px){.app-header h1{font-size:32px}.subtitle{font-size:16px}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;padding:20px}#root{width:100%;max-width:1600px;margin:0 auto}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}
