:root{--color-cream: #fef9f3;--color-cream-deep: #faf2e8;--color-orange: #ff6b35;--color-orange-soft: #ff8a5b;--color-orange-fade: #fff0e8;--color-yellow: #e2c044;--color-green: #6cba6c;--color-green-soft: #e9f5e9;--color-red: #d9534f;--color-red-soft: #fdecea;--color-blue: #4a90e2;--color-blue-soft: #eaf2fb;--color-warm-gray: #8a7a6b;--color-warm-gray-light: #c2b5a6;--color-charcoal: #4b4439;--color-black: #2b2520;--color-white: #ffffff;--color-divider: #ece4d6;--color-bg-card: #ffffff;--color-bg-hover: #f7efe2;--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, "Helvetica Neue", sans-serif;--text-micro: 11px;--text-caption: 13px;--text-body: 15px;--text-h3: 18px;--text-h2: 22px;--text-h1: 28px;--text-hero-sm: 36px;--text-hero: 48px;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--space-16: 64px;--radius-button: 6px;--radius-content: 8px;--radius-card: 12px;--radius-pill: 999px;--shadow-sm: 0 1px 2px rgba(43, 37, 32, .04);--shadow-md: 0 2px 8px rgba(43, 37, 32, .06);--shadow-lg: 0 8px 24px rgba(43, 37, 32, .1);--max-width: 1280px;--sidebar-width: 240px;--header-height: 56px}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:var(--font-sans);font-size:var(--text-body);line-height:1.5;color:var(--color-charcoal);background:var(--color-cream);-webkit-font-smoothing:antialiased}a{color:var(--color-orange);text-decoration:none}a:hover{text-decoration:underline}h1,h2,h3,h4{margin:0 0 var(--space-3);color:var(--color-black);font-weight:600}h1{font-size:var(--text-h1)}h2{font-size:var(--text-h2)}h3{font-size:var(--text-h3)}button{font-family:inherit;font-size:inherit;cursor:pointer;border:none;background:none;color:inherit}input,textarea,select{font-family:inherit;font-size:var(--text-body)}table{border-collapse:collapse;width:100%}.btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border-radius:var(--radius-button);font-weight:500;transition:all .12s;white-space:nowrap}.btn-primary{background:var(--color-orange);color:var(--color-white)}.btn-primary:hover{background:var(--color-orange-soft)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-ghost{background:transparent;color:var(--color-charcoal);border:1px solid var(--color-divider)}.btn-ghost:hover{background:var(--color-bg-hover)}.btn-danger{background:var(--color-red);color:var(--color-white)}.btn-danger:hover{background:#c0392b}.btn-sm{padding:var(--space-1) var(--space-3);font-size:var(--text-caption)}.card{background:var(--color-bg-card);border-radius:var(--radius-card);border:1px solid var(--color-divider);padding:var(--space-6);box-shadow:var(--shadow-sm)}.card-tight{padding:var(--space-4)}.badge{display:inline-flex;align-items:center;padding:2px var(--space-2);border-radius:var(--radius-pill);font-size:var(--text-micro);font-weight:600;text-transform:uppercase;letter-spacing:.04em}.badge-success{background:var(--color-green-soft);color:var(--color-green)}.badge-warning{background:#fff8e1;color:#b8860b}.badge-danger{background:var(--color-red-soft);color:var(--color-red)}.badge-info{background:var(--color-blue-soft);color:var(--color-blue)}.badge-neutral{background:var(--color-cream-deep);color:var(--color-warm-gray)}.input,.select,.textarea{width:100%;padding:var(--space-2) var(--space-3);border:1px solid var(--color-divider);border-radius:var(--radius-button);background:var(--color-white);outline:none;transition:border .12s}.input:focus,.select:focus,.textarea:focus{border-color:var(--color-orange);box-shadow:0 0 0 3px #ff6b351f}.label{display:block;font-weight:500;margin-bottom:var(--space-2);font-size:var(--text-caption)}.form-group{margin-bottom:var(--space-4)}table.data-table{background:var(--color-white);border:1px solid var(--color-divider);border-radius:var(--radius-content);overflow:hidden}table.data-table th,table.data-table td{padding:var(--space-3) var(--space-4);text-align:left;border-bottom:1px solid var(--color-divider)}table.data-table th{background:var(--color-cream-deep);color:var(--color-warm-gray);font-size:var(--text-caption);text-transform:uppercase;letter-spacing:.04em;font-weight:600}table.data-table tbody tr:last-child td{border-bottom:none}table.data-table tbody tr:hover{background:var(--color-bg-hover)}.app-shell{display:grid;grid-template-columns:var(--sidebar-width) 1fr;min-height:100vh}.sidebar{background:var(--color-white);border-right:1px solid var(--color-divider);padding:var(--space-6) var(--space-4);position:sticky;top:0;height:100vh;overflow-y:auto}.sidebar-brand{font-size:var(--text-h3);font-weight:700;color:var(--color-orange);margin-bottom:var(--space-8)}.sidebar nav{display:flex;flex-direction:column;gap:var(--space-1)}.sidebar nav a{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-radius:var(--radius-button);color:var(--color-charcoal);font-size:var(--text-caption);font-weight:500}.sidebar nav a:hover{background:var(--color-bg-hover);text-decoration:none}.sidebar nav a.active{background:var(--color-orange-fade);color:var(--color-orange)}.sidebar-section{margin-top:var(--space-6);padding:0 var(--space-3);font-size:var(--text-micro);text-transform:uppercase;letter-spacing:.06em;color:var(--color-warm-gray);font-weight:600}.main-content{padding:var(--space-6) var(--space-8);max-width:var(--max-width);margin:0 auto;width:100%}.page-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-4);margin-bottom:var(--space-6)}.page-title h1{margin-bottom:var(--space-1)}.page-title p{color:var(--color-warm-gray);margin:0;font-size:var(--text-caption)}.spinner{display:inline-block;width:20px;height:20px;border:2px solid var(--color-divider);border-top-color:var(--color-orange);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.center-spinner{display:flex;justify-content:center;padding:var(--space-12)}.error-banner{background:var(--color-red-soft);border:1px solid var(--color-red);border-radius:var(--radius-content);padding:var(--space-4);display:flex;justify-content:space-between;align-items:center;gap:var(--space-3);color:var(--color-red);margin-bottom:var(--space-4)}.empty-state{text-align:center;padding:var(--space-12) var(--space-6);color:var(--color-warm-gray)}.empty-state h3{color:var(--color-charcoal)}.flex{display:flex}.flex-col{display:flex;flex-direction:column}.gap-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-6{gap:var(--space-6)}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.flex-1{flex:1}.text-center{text-align:center}.text-right{text-align:right}.muted{color:var(--color-warm-gray)}.mono{font-family:SF Mono,Menlo,Monaco,Consolas,monospace;font-size:13px}.mt-2{margin-top:var(--space-2)}.mt-4{margin-top:var(--space-4)}.mt-6{margin-top:var(--space-6)}.mb-2{margin-bottom:var(--space-2)}.mb-4{margin-bottom:var(--space-4)}.mb-6{margin-bottom:var(--space-6)}.w-full{width:100%}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4)}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-4)}@media (max-width: 768px){.app-shell{grid-template-columns:1fr}.sidebar{position:fixed;left:-100%;z-index:100;transition:left .2s;width:80%;max-width:320px}.sidebar.open{left:0}.main-content{padding:var(--space-4)}.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}.toast-container{position:fixed;bottom:var(--space-6);right:var(--space-6);z-index:1000;display:flex;flex-direction:column;gap:var(--space-2)}.toast{padding:var(--space-3) var(--space-4);background:var(--color-white);border-radius:var(--radius-content);box-shadow:var(--shadow-lg);border-left:4px solid var(--color-orange);min-width:280px;max-width:420px;animation:slide-in .2s}.toast.success{border-color:var(--color-green)}.toast.error{border-color:var(--color-red)}.toast.warn{border-color:var(--color-yellow)}@keyframes slide-in{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.graph-page{display:flex;flex-direction:column;height:calc(100vh - var(--space-12))}.graph-toolbar{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) 0;flex-wrap:wrap}.graph-container{position:relative;flex:1;display:flex;border:1px solid var(--color-divider);border-radius:var(--radius-card);overflow:hidden;background:var(--color-white);min-height:480px}.graph-canvas{flex:1}.graph-sidebar{width:360px;border-left:1px solid var(--color-divider);background:var(--color-white);overflow-y:auto;padding:var(--space-5);animation:slide-in-right .2s}@keyframes slide-in-right{0%{transform:translate(20px);opacity:0}to{transform:translate(0);opacity:1}}.graph-sidebar-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-4)}.graph-sidebar-header h3{margin:0;font-size:var(--text-h3)}.graph-sidebar-section{margin-bottom:var(--space-4)}.graph-sidebar-section h4{font-size:var(--text-caption);text-transform:uppercase;letter-spacing:.04em;color:var(--color-warm-gray);margin-bottom:var(--space-2);font-weight:600}.graph-sidebar-meta{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-bottom:var(--space-4)}.graph-legend{position:absolute;top:var(--space-3);right:var(--space-3);background:#fffffff2;border:1px solid var(--color-divider);border-radius:var(--radius-content);padding:var(--space-3);font-size:var(--text-caption);z-index:10;box-shadow:var(--shadow-sm)}.graph-legend-title{font-weight:600;margin-bottom:var(--space-2);display:flex;justify-content:space-between;align-items:center;cursor:pointer}.graph-legend-item{display:flex;align-items:center;gap:var(--space-2);padding:2px 0}.graph-legend-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.graph-zoom-controls{position:absolute;bottom:var(--space-3);right:var(--space-3);display:flex;flex-direction:column;gap:var(--space-1);z-index:10}.graph-zoom-controls button{width:36px;height:36px;background:var(--color-white);border:1px solid var(--color-divider);border-radius:var(--radius-button);display:flex;align-items:center;justify-content:center;font-size:18px;box-shadow:var(--shadow-sm)}.graph-zoom-controls button:hover{background:var(--color-bg-hover)}.graph-tooltip{position:absolute;pointer-events:none;z-index:20;background:var(--color-charcoal);color:var(--color-white);padding:var(--space-2) var(--space-3);border-radius:var(--radius-button);font-size:var(--text-caption);white-space:nowrap;box-shadow:var(--shadow-md);transform:translate(-50%,-100%);margin-top:-8px}.graph-fullscreen{position:fixed;top:0;right:0;bottom:0;left:0;z-index:400;background:var(--color-cream);padding:var(--space-4)}.graph-fullscreen .graph-page{height:100%}.course-link{display:block;padding:var(--space-1) var(--space-2);border-radius:var(--radius-button);cursor:pointer;font-size:var(--text-caption);color:var(--color-charcoal)}.course-link:hover{background:var(--color-bg-hover);text-decoration:none}.graph-semester-header{position:absolute;top:0;left:0;right:0;pointer-events:none;z-index:5;display:flex}.graph-semester-col{text-align:center;font-size:var(--text-micro);font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--color-warm-gray);padding:var(--space-2) 0;border-right:1px dashed var(--color-divider)}.graph-semester-col:last-child{border-right:none}@media (max-width: 768px){.graph-sidebar{position:fixed;right:0;top:0;bottom:0;z-index:300;box-shadow:var(--shadow-lg);width:85%;max-width:360px}.graph-toolbar{gap:var(--space-2)}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#2b252066;display:flex;align-items:center;justify-content:center;z-index:500;padding:var(--space-4)}.modal{background:var(--color-white);border-radius:var(--radius-card);max-width:720px;width:100%;max-height:85vh;overflow-y:auto;box-shadow:var(--shadow-lg)}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--color-divider)}.modal-body{padding:var(--space-6)}.modal-footer{padding:var(--space-4) var(--space-6);border-top:1px solid var(--color-divider);display:flex;gap:var(--space-3);justify-content:flex-end}
