:root{font-family:Manrope,Inter,Segoe UI,sans-serif;--text: #1a2a3d;--title: #10213d;--text-soft: #51617a;--primary: #002045;--primary-deep: #1a365d;--primary-soft: rgba(0, 32, 69, .08);--accent: #2c694e;--card: rgba(255, 255, 255, .78);--card-strong: rgba(255, 255, 255, .93);--line: rgba(20, 48, 82, .13);--blue: #1a365d;--green: #2c694e;--amber: #c6842d;--rose: #bc465b;--purple: #5b6da6;--sky: #2f6a8f;--radius-xl: 24px;--radius-lg: 18px;--radius-md: 14px;--shadow-lg: 0 20px 54px rgba(17, 35, 58, .12);--shadow-md: 0 12px 34px rgba(17, 35, 58, .09);--shadow-sm: 0 8px 18px rgba(17, 35, 58, .08)}*{box-sizing:border-box}html,body,#root{margin:0;min-height:100vh}body{color:var(--text);background:radial-gradient(circle at 8% 2%,rgba(173,199,247,.4),transparent 34%),radial-gradient(circle at 90% 8%,rgba(174,238,203,.26),transparent 30%),linear-gradient(180deg,#f7f9fc,#f1f5fa 54%,#ecf1f8)}button,input,textarea,select{font:inherit}button{cursor:pointer}.glass-card,.panel-card,.kpi-card,.login-card,.showcase-card,.module-card,.hardware-card,.chat-bubble,.sidebar{background:var(--card);border:1px solid rgba(255,255,255,.88);box-shadow:var(--shadow-md);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.app-shell{display:grid;grid-template-columns:292px 1fr;gap:20px;padding:20px;min-height:100vh}.main-shell{display:flex;flex-direction:column;gap:16px;min-width:0}.sidebar{border-radius:var(--radius-xl);padding:16px 12px;position:sticky;top:20px;max-height:calc(100vh - 40px);overflow:auto;z-index:30}.sidebar-close{border:1px solid var(--line);width:36px;height:36px;border-radius:12px;display:none;align-items:center;justify-content:center;background:#fff;color:var(--primary);margin-left:auto}.sidebar-backdrop{display:none}.brand-block{display:flex;align-items:center;gap:12px;margin-bottom:18px}.brand-block.large{margin-bottom:24px}.brand-mark{width:44px;height:44px;border-radius:14px;display:grid;place-items:center;background:linear-gradient(135deg,#002045,#1a365d);color:#fff;font-weight:800;letter-spacing:.02em}.brand-title{font-weight:800;font-size:1rem;color:var(--title)}.brand-subtitle,.eyebrow,.kpi-title,.chat-role,.field-label,.sidebar-group-title,.table-footer,.section-heading p,.module-card p,.mini-list-item p,.kpi-delta,.login-note{color:var(--text-soft)}.eyebrow{text-transform:uppercase;letter-spacing:.13em;font-size:.7rem;font-weight:700}.sidebar-group{margin-top:14px}.sidebar-group-title{font-size:.68rem;font-weight:800;margin:10px 10px 8px;text-transform:uppercase;letter-spacing:.1em}.sidebar-items{display:grid;gap:5px}.sidebar-item{position:relative;display:flex;align-items:center;gap:10px;border:none;background:transparent;color:#213658;padding:11px 12px;border-radius:12px;overflow:hidden;z-index:1;text-align:left}.sidebar-item span,.sidebar-item svg{position:relative;z-index:2}.sidebar-item.active{color:var(--primary);font-weight:700}.sidebar-item:hover{transform:translateY(-1px)}.sidebar-pill{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:12px;background:linear-gradient(135deg,#adc7f76b,#aeeecb3d);border:1px solid rgba(69,95,136,.2);z-index:1}.topbar{border-radius:var(--radius-xl);padding:14px 16px;display:flex;justify-content:space-between;align-items:center;gap:14px}.topbar h1{margin:5px 0 0;font-size:1.32rem;letter-spacing:-.01em;color:#122840}.topbar-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}.nav-toggle{display:none;margin-bottom:8px}.provider-pill{border-radius:999px;padding:8px 12px;background:var(--card-strong);border:1px solid var(--line);display:inline-flex;align-items:center;gap:8px;font-size:.82rem}.provider-pill.online{color:var(--green)}.provider-pill.offline{color:var(--amber)}.provider-pill strong{color:#1a2f4d;font-weight:700}.search-input{display:flex;align-items:center;gap:10px;background:#fffffff2;border:1px solid var(--line);border-radius:12px;padding:9px 12px;min-width:280px}.search-input input{border:none;outline:none;background:transparent;width:100%}.ai-quick,.icon-button,.primary-button,.secondary-button,.suggestion-chip,.role-switcher button,.mini-action{border:none;transition:transform .16s ease,box-shadow .16s ease,opacity .16s ease}.ai-quick:hover,.icon-button:hover,.primary-button:hover,.secondary-button:hover,.suggestion-chip:hover,.role-switcher button:hover,.mini-action:hover{transform:translateY(-1px)}.ai-quick,.primary-button{background:linear-gradient(135deg,var(--primary),var(--primary-deep));color:#fff;border-radius:12px;padding:10px 13px;display:inline-flex;align-items:center;gap:8px;box-shadow:0 10px 24px #1a365d33}.primary-button.slim{padding:8px 11px;font-size:.88rem}.secondary-button{background:#fffffff2;color:#1d3358;border-radius:12px;padding:9px 13px;border:1px solid var(--line)}.icon-button{width:40px;height:40px;display:grid;place-items:center;border-radius:12px;background:#fffffff2;border:1px solid var(--line);color:#17304e}.mini-action{background:#fffffff2;border:1px solid rgba(84,112,176,.2);border-radius:10px;padding:6px 10px;color:#1a355d;font-size:.79rem;font-weight:700;white-space:nowrap}main{display:flex;flex-direction:column;gap:16px;min-width:0}.page-content{display:flex;flex-direction:column;gap:16px}.page-header{display:flex;justify-content:space-between;align-items:center;gap:10px}.page-header h2{margin:5px 0 0;font-size:1.58rem;letter-spacing:-.02em;color:#122840}.page-header.compact h2{font-size:1.42rem}.page-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.text-field{border:1px solid var(--line);background:#fffffff5;border-radius:12px;padding:10px 12px;outline:none;color:#16324f}.text-field:focus,.chat-input-row textarea:focus,select.text-field:focus,input.text-field:focus,textarea.text-field:focus{border-color:#455f8873;box-shadow:0 0 0 3px #adc7f742}.text-field.small{min-width:128px;padding:8px 10px}.kpi-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:10px}.kpi-grid.four{grid-template-columns:repeat(4,minmax(0,1fr))}.kpi-card{padding:14px;border-radius:18px;border:1px solid rgba(255,255,255,.88);animation:cardFloat .4s ease both}@keyframes cardFloat{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.kpi-value{font-size:1.38rem;font-weight:800;margin:7px 0 4px;color:#132740}.kpi-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.tone-blue{background:linear-gradient(175deg,#e2ecfcf2,#ffffffd6)}.tone-green{background:linear-gradient(175deg,#e5f5edf2,#ffffffd6)}.tone-amber{background:linear-gradient(175deg,#fbefdbf2,#ffffffd6)}.tone-purple{background:linear-gradient(175deg,#eceef8f2,#ffffffd6)}.tone-sky{background:linear-gradient(175deg,#e4f1f9f2,#ffffffd6)}.tone-rose{background:linear-gradient(175deg,#fae6ecf2,#ffffffd6)}.grid-two{display:grid;grid-template-columns:1fr 1fr;gap:16px}.grid-two.uneven{grid-template-columns:1.08fr .92fr}.panel-card{border-radius:var(--radius-xl);padding:18px;border:1px solid rgba(255,255,255,.9)}.section-heading{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:10px}.section-heading.compact{margin-bottom:8px}.section-heading h3{margin:0;font-size:1rem;color:#142b47}.section-heading p{margin:4px 0 0}.ai-command-bar{padding-top:12px;padding-bottom:12px}.chart-card{min-height:280px}.chart-wrap{width:100%;height:220px}.alert-list,.mini-list,.hardware-list,.module-grid,.student-meta-grid{display:grid;gap:10px}.alert-item,.mini-list-item,.hardware-card{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;padding:11px 12px;border-radius:12px;background:#fffffff0;border:1px solid var(--line)}.alert-item{align-items:center}.alert-dot{width:8px;height:8px;border-radius:50%;background:linear-gradient(135deg,#bc465b,#c6842d);flex:none}.mini-list-right{text-align:right}.status-pill,.provider-badge{display:inline-flex;align-items:center;gap:7px;padding:7px 10px;border-radius:999px;background:#dce9fce6;color:var(--primary);font-weight:700;font-size:.79rem;border:1px solid rgba(69,95,136,.2)}.status-pill.warn{color:var(--amber);background:#fbefdbe6}.status-pill.ok{color:var(--green);background:#e4f5ece6}.module-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.module-grid.three{grid-template-columns:repeat(3,minmax(0,1fr))}.module-card{padding:14px;border-radius:14px;background:#fffffff2;border:1px solid var(--line)}.module-card h4{margin:0 0 6px;color:#132a45}.module-card span{font-weight:700;color:#1e3c64;font-size:.88rem}.table-shell{overflow:auto}table{width:100%;border-collapse:collapse;min-width:520px}th,td{text-align:left;padding:11px 9px;border-bottom:1px solid var(--line);color:#1c3454}th{color:var(--text-soft);font-weight:700;font-size:.8rem;text-transform:uppercase;letter-spacing:.03em}.table-footer{padding-top:10px;font-size:.84rem}.row-clickable{cursor:pointer}.row-clickable:hover{background:#e2ecfc6b}.inline-actions{display:flex;gap:7px;flex-wrap:wrap}.student-drawer .student-meta-grid{grid-template-columns:repeat(2,minmax(0,1fr));margin-bottom:10px}.student-meta-grid div{padding:9px;border-radius:10px;background:#fffffff2;border:1px solid var(--line);display:flex;flex-direction:column;gap:4px}.student-meta-grid span{color:var(--text-soft);font-size:.74rem}.ai-panel{display:flex;flex-direction:column;min-height:530px}.ai-panel.compact{min-height:410px}.suggestion-row{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:10px}.suggestion-chip{background:#fffffff2;border-radius:999px;padding:7px 12px;border:1px solid var(--line);color:#274366;font-size:.81rem}.chat-window{flex:1;display:flex;flex-direction:column;gap:10px;overflow:auto;padding-right:4px}.chat-bubble{border-radius:14px;padding:11px 13px;max-width:92%}.chat-bubble.user{margin-left:auto;background:linear-gradient(135deg,var(--primary),var(--primary-deep));color:#fff}.chat-bubble.assistant{background:#fffffff5;border:1px solid var(--line)}.chat-bubble.loading{display:inline-flex;align-items:center;gap:8px}.chat-content{margin-top:5px;line-height:1.5;white-space:pre-wrap}.chat-meta,.chat-intent{margin-top:6px;color:var(--text-soft);font-size:.8rem}.chat-actions{display:flex;gap:8px;margin-top:8px;flex-wrap:wrap}.chat-table-wrap{overflow:auto;margin-top:8px}.chat-table{width:100%;min-width:480px;border-collapse:collapse;font-size:.83rem}.chat-table th,.chat-table td{padding:7px;border-bottom:1px solid var(--line)}.chat-input-row{display:flex;gap:9px;margin-top:10px;align-items:flex-end}.chat-input-row textarea{flex:1;resize:none;border:1px solid var(--line);border-radius:12px;background:#fffffff5;padding:11px;outline:none}.login-screen{min-height:100vh;display:grid;grid-template-columns:1.08fr .92fr;gap:20px;padding:20px}.login-showcase,.login-card{border-radius:28px;padding:30px}.login-showcase{position:relative;background:radial-gradient(circle at 8% 10%,rgba(173,199,247,.48),transparent 38%),radial-gradient(circle at 86% 2%,rgba(174,238,203,.28),transparent 34%),linear-gradient(180deg,#ffffffeb,#f5f9ffeb);border:1px solid rgba(255,255,255,.9);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;justify-content:center;animation:gradientPulse 6.2s ease-in-out infinite}@keyframes gradientPulse{0%{filter:saturate(100%)}50%{filter:saturate(108%)}to{filter:saturate(100%)}}.login-showcase h1{font-size:2.55rem;line-height:1.05;margin:10px 0 18px;max-width:680px;color:#11263f}.showcase-points{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.showcase-card{border-radius:14px;padding:14px;font-weight:650;font-size:.86rem;background:#ffffffdb;border:1px solid var(--line)}.login-card{max-width:470px;justify-self:end;width:100%;align-self:center;border:1px solid rgba(255,255,255,.9)}.role-switcher{display:flex;flex-wrap:wrap;gap:6px;background:#ecf2fbe6;padding:5px;border-radius:12px;margin-bottom:16px}.role-switcher button{flex:1 1 calc(50% - 6px);padding:9px 8px;border-radius:9px;background:transparent;color:#1d3457}.role-switcher button.active{background:#fffffff5;box-shadow:var(--shadow-sm);font-weight:700}.login-provider{width:100%;margin:8px 0 14px;justify-content:space-between}.wide{width:100%;justify-content:center}.ai-provider-controls{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}.model-select{border:1px solid var(--line);background:#fffffff5;border-radius:10px;padding:7px 9px;color:#1b3358;min-width:185px}.model-select:disabled{opacity:.62}.settings-panel{display:flex;flex-direction:column;gap:10px}.settings-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.settings-field{display:flex;flex-direction:column;gap:6px}.settings-field>span{font-size:.8rem;color:var(--text-soft);font-weight:700;text-transform:uppercase;letter-spacing:.06em}.settings-field>small{color:var(--text-soft);font-size:.76rem}.settings-field.full{grid-column:1 / -1}.settings-textarea{min-height:120px;resize:vertical}.settings-actions{display:flex;gap:10px;flex-wrap:wrap}.settings-notice{padding:10px 11px;border-radius:10px;background:#fffffff2;border:1px solid var(--line);color:#1b3358;font-size:.88rem}.announcement-studio{display:flex;flex-direction:column;gap:10px}.announcement-grid{display:grid;gap:8px}.mic-orb{width:42px;height:42px;border-radius:999px;border:1px solid rgba(69,95,136,.26);background:#fff;color:#113053;display:inline-flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm)}.mic-orb.active{background:linear-gradient(135deg,#bc465b,#d16a45);color:#fff;box-shadow:0 0 0 6px #bc465b33,0 12px 26px #bc465b59}.wave-grid{display:flex;align-items:flex-end;gap:5px;min-height:80px;padding:10px 8px;border-radius:12px;border:1px solid var(--line);background:linear-gradient(180deg,#bc465b14,#1a365d0d)}.wave-grid span{width:7px;border-radius:999px;background:linear-gradient(180deg,#bc465b,#1a365d);animation:waveUp .9s ease-in-out infinite}.wave-grid span:nth-child(2n){animation-duration:1.1s}.wave-grid span:nth-child(3n){animation-duration:1.3s}@keyframes waveUp{0%,to{transform:scaleY(.62);opacity:.75}50%{transform:scaleY(1);opacity:1}}.pulse{animation:pulseGlow 1.3s ease-in-out infinite}@keyframes pulseGlow{0%,to{box-shadow:0 0 #2c694e1f}50%{box-shadow:0 0 0 6px #2c694e2b}}.map-card{display:flex;flex-direction:column;gap:10px}.map-controls{display:flex;flex-wrap:wrap;gap:8px}.map-controls .suggestion-chip{display:inline-flex;align-items:center;gap:6px}.suggestion-chip.active{background:#dce9fcf2;border-color:#455f884d;color:#103151;font-weight:700}.map-stage{border-radius:14px;overflow:hidden;border:1px solid var(--line);background:radial-gradient(circle at 10% 0%,rgba(173,199,247,.34),transparent 40%),linear-gradient(180deg,#fffffff5,#eff5fcf5);min-height:250px}.map-svg{width:100%;height:260px}.bus-ping{animation:busPing 1.2s ease-in-out infinite}@keyframes busPing{0%,to{r:2.6;opacity:.8}50%{r:3.4;opacity:1}}@media (max-width: 1320px){.kpi-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.kpi-grid.four{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-two,.grid-two.uneven,.module-grid.three,.login-screen{grid-template-columns:1fr}.login-card{justify-self:stretch;max-width:none}}@media (max-width: 980px){.app-shell{grid-template-columns:1fr;padding:12px;gap:12px}.sidebar{position:fixed;top:0;left:0;width:min(84vw,320px);max-height:100vh;height:100vh;border-radius:0 20px 20px 0;transform:translate(-105%);transition:transform .24s ease;z-index:80;padding-top:12px}.sidebar.open{transform:translate(0)}.sidebar-close{display:inline-flex}.sidebar-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#09142361;border:none;opacity:0;pointer-events:none;transition:opacity .18s ease;z-index:70;display:block}.sidebar-backdrop.show{opacity:1;pointer-events:auto}.topbar{flex-direction:column;align-items:stretch}.nav-toggle{display:inline-grid}.topbar-actions{justify-content:stretch}.search-input{min-width:0;width:100%}.kpi-grid,.kpi-grid.four,.module-grid,.showcase-points,.student-drawer .student-meta-grid,.settings-grid{grid-template-columns:1fr}.login-screen{padding:12px;gap:12px}.login-showcase,.login-card{padding:22px}.login-showcase h1{font-size:2rem}table,.chat-table{min-width:560px}.chat-input-row{flex-direction:column;align-items:stretch}.chat-input-row button{width:100%;justify-content:center}}@media (max-width: 640px){.page-header{flex-direction:column;align-items:flex-start}.page-actions{width:100%}.page-actions>*{flex:1;min-width:0}.topbar h1{font-size:1.15rem}.panel-card,.kpi-card,.module-card,.alert-item,.mini-list-item,.hardware-card{padding:12px}.provider-pill,.status-pill,.provider-badge{font-size:.75rem}}
