*{box-sizing:border-box}body{margin:0;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:#e6edf7;background:radial-gradient(circle at 20% 10%,#1e293b,#0b1220 55%,#060b16)}#root{min-height:100vh}.login-screen{min-height:100vh;display:grid;place-items:center;padding:20px}.login-card{width:min(520px,100%);border:1px solid rgba(255,255,255,.16);background:#ffffff14;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-radius:28px;padding:28px;box-shadow:0 20px 40px #00000059}.brand{width:70px;height:70px;border-radius:22px;display:grid;place-items:center;font-size:2rem;background:linear-gradient(135deg,#3b82f6,#4f46e5)}.login-card h1{margin:16px 0 6px;font-size:1.8rem}.login-card p{margin:0;color:#c3d0e5}.login-users{margin-top:20px;display:grid;gap:10px}.login-user-btn{width:100%;display:flex;align-items:center;gap:12px;border:1px solid rgba(255,255,255,.18);border-radius:16px;padding:10px;background:#ffffff14;color:#fff;cursor:pointer}.login-user-btn img{width:48px;height:48px;border-radius:50%}.login-user-btn strong,.login-user-btn span{display:block;text-align:left}.login-user-btn span{color:#b9c8e0;font-size:.84rem}.shelf-page{min-height:100vh;padding:20px}.shelf-shell{min-height:100vh;display:grid;grid-template-columns:82px 220px 1fr}.icon-rail{border-right:1px solid rgba(255,255,255,.12);background:#060b16bf;display:flex;flex-direction:column;align-items:center;padding:12px 8px;gap:14px}.rail-logo{width:48px;height:48px;border-radius:14px;border:0;background:linear-gradient(135deg,#3b82f6,#4f46e5);color:#fff;cursor:pointer;font-size:1.2rem}.rail-buttons{display:flex;flex-direction:column;gap:8px}.rail-buttons button{width:46px;height:46px;border-radius:14px;border:1px solid rgba(255,255,255,.14);background:#ffffff0d;color:#d6e3f8;cursor:pointer}.rail-buttons button.active{background:#3b82f6b3;border-color:#3b82f6e6;color:#fff}.rail-bottom{margin-top:auto;display:flex;flex-direction:column;gap:8px;align-items:center}.rail-bottom img{width:36px;height:36px;border-radius:50%}.rail-bottom button{width:36px;height:36px;border-radius:10px;border:1px solid rgba(255,255,255,.14);background:#ffffff0d;color:#fff;cursor:pointer}.menu-drawer{border-right:1px solid rgba(255,255,255,.12);background:#080e1bbf;padding:16px;transition:transform .25s ease}.menu-drawer h3{margin:0;font-size:1.15rem}.menu-drawer p{margin:4px 0 12px;color:#b8cae9;font-size:.88rem}.drawer-items{display:grid;gap:8px}.drawer-items button{text-align:left;border:1px solid rgba(255,255,255,.14);background:#ffffff0d;color:#d6e4f8;border-radius:11px;padding:10px;cursor:pointer}.drawer-items button.active{background:#3b82f6b3;border-color:#3b82f6e6;color:#fff}.shelf-page.with-drawer{border-left:1px solid rgba(255,255,255,.08)}.shelf-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.shelf-header h2{margin:0}.shelf-header p{margin:6px 0 0;color:#bdd0ee}.shelf-actions{display:flex;gap:10px;align-items:center}.shelf-actions img{width:38px;height:38px;border-radius:50%}.shelf-actions button{border:1px solid rgba(255,255,255,.2);background:#ffffff14;color:#fff;border-radius:12px;padding:8px 14px;cursor:pointer}.shelf-toolbar{border:1px solid rgba(255,255,255,.14);background:#ffffff12;border-radius:18px;padding:14px}.shelf-toolbar input{width:100%;border-radius:12px;border:1px solid rgba(255,255,255,.15);background:#0c1220b3;color:#fff;padding:10px 12px}.subject-chips{margin-top:10px;display:flex;gap:8px;flex-wrap:wrap}.subject-chips button{border-radius:999px;border:1px solid rgba(255,255,255,.16);color:#cbd9f0;background:#ffffff0f;padding:6px 12px;cursor:pointer}.subject-chips button.active{color:#fff;background:#2563eb;border-color:#2563eb}.books-grid{margin-top:16px;display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px}.content-section{margin-top:16px;display:grid;gap:14px}.panel-grid{display:grid;gap:12px}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.two-col{grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}.panel-card{border:1px solid rgba(255,255,255,.14);background:#ffffff12;border-radius:16px;padding:12px}.panel-card h3{margin:0 0 8px}.stat-card p{margin:0;color:#b8cae9;font-size:.86rem}.stat-card strong{display:block;margin-top:5px;font-size:1.5rem}.stat-card span{display:block;margin-top:4px;color:#9fb4d8;font-size:.82rem}.simple-list{margin:0;padding-left:18px;display:grid;gap:6px}.notice-list{display:grid;gap:8px}.notice-item{border-radius:12px;padding:9px;border:1px solid rgba(255,255,255,.16)}.notice-item strong,.notice-item span{display:block}.notice-item span{margin-top:4px;color:#bdd0ef;font-size:.84rem}.notice-item.success{border-color:#10b9818c;background:#10b9811f}.notice-item.warn{border-color:#f59e0b8c;background:#f59e0b1f}.recent-grid{display:grid;gap:10px}.recent-card{border:1px solid rgba(255,255,255,.16);border-radius:12px;background:#ffffff0d;color:#fff;padding:8px;display:flex;align-items:center;gap:10px;cursor:pointer;text-align:left}.recent-card img{width:42px;height:62px;object-fit:cover;border-radius:7px}.recent-card strong,.recent-card span{display:block}.recent-card span{margin-top:3px;color:#bdd0ef;font-size:.82rem}.assignment-card p{margin:0;color:#bdd0ef}.assignment-meta{margin-top:10px;display:flex;justify-content:space-between;font-size:.86rem;color:#d7e4f9}.progress-track{margin-top:8px;width:100%;height:8px;border-radius:999px;background:#ffffff24;overflow:hidden}.progress-fill{height:100%;border-radius:999px;background:linear-gradient(135deg,#3b82f6,#4f46e5)}.wide-card{grid-column:1 / -1}.analytics-section{gap:18px}.analytics-kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:14px}.kpi-card{padding:16px;min-height:128px;display:flex;flex-direction:column;justify-content:space-between}.kpi-label{margin:0;color:#bdd0ef;font-size:.86rem;letter-spacing:.01em}.kpi-value{display:block;margin:8px 0 6px;font-size:2rem;font-weight:800;color:#fff;line-height:1.05}.kpi-detail{display:block;color:#9fb4d8;font-size:.83rem}.analytics-notes{padding:16px}.analytics-notes .simple-list{gap:10px}.zebra-card{padding:14px}.zebra-list{margin-top:10px;border:1px solid rgba(255,255,255,.14);border-radius:12px;overflow:hidden}.zebra-row{display:grid;grid-template-columns:1fr auto;gap:6px 10px;padding:10px 12px}.zebra-row:nth-child(odd){background:#ffffff12}.zebra-row:nth-child(2n){background:#ffffff08}.zebra-row strong{font-size:.92rem}.zebra-row span{justify-self:end;font-weight:700;color:#d8e4f9}.zebra-row small{grid-column:1 / -1;color:#a8bddf;font-size:.8rem}.zebra-row.warn span{color:#fca5a5}.book-card{border-radius:18px;overflow:hidden;border:1px solid rgba(255,255,255,.16);background:#ffffff14;cursor:pointer;transition:transform .2s ease}.book-card:hover{transform:translateY(-3px)}.book-cover-wrap{aspect-ratio:2 / 3;background:#0f172a}.book-cover{width:100%;height:100%;object-fit:cover}.book-content{padding:10px}.book-content h3{margin:0;font-size:.96rem}.book-content p{margin:4px 0 10px;color:#bac9e3;font-size:.86rem}.book-content button{width:100%;border:0;border-radius:10px;padding:8px;background:linear-gradient(135deg,#3b82f6,#4f46e5);color:#fff;font-weight:700;cursor:pointer}.reader-overlay{height:100vh;display:flex;flex-direction:column;overflow:hidden}.reader-header{display:flex;gap:14px;align-items:center;padding:14px 16px;border-bottom:1px solid rgba(255,255,255,.12);background:#0c1220eb}.back-btn{border:1px solid rgba(255,255,255,.16);border-radius:10px;background:#ffffff14;color:#fff;padding:8px 12px;cursor:pointer}.reader-header h2{margin:0}.reader-header p{margin:3px 0 0;color:#bdd0ee;font-size:.9rem}.reader-body{flex:1;min-height:0;display:grid;grid-template-columns:1fr 420px;height:calc(100vh - 74px);overflow:hidden}.reader-pdf{height:100%;background:#fff;position:relative;overflow:hidden}.reader-side{border-left:1px solid rgba(255,255,255,.12);background:#080e1bf2;display:flex;flex-direction:column;min-height:0}.chat-header{padding:12px 12px 0}.chat-header h3{margin:0;font-size:.98rem}.chat-header p{margin:3px 0 0;color:#a9bfdf;font-size:.8rem}.side-tabs{display:grid;grid-template-columns:1fr 1fr;padding:8px;gap:8px}.side-tabs button{border:1px solid rgba(255,255,255,.16);border-radius:10px;background:#ffffff0f;color:#d1def3;padding:8px;cursor:pointer}.side-tabs button.active{background:#2563eb;border-color:#2563eb;color:#fff}.qa-panel,.test-panel{padding:10px;display:flex;flex-direction:column;min-height:0;overflow:auto}.quick-prompts{display:flex;gap:8px;overflow:auto;padding-bottom:6px}.quick-prompts button{border-radius:999px;border:1px solid rgba(255,255,255,.16);background:#ffffff14;color:#d3e0f5;padding:6px 10px;white-space:nowrap;cursor:pointer}.messages{margin-top:10px;display:flex;flex-direction:column;gap:8px;max-height:420px;overflow:auto;padding-right:4px}.msg{border-radius:12px;padding:10px;max-width:92%}.msg.user{align-self:flex-end;background:#2563eb}.msg.ai{align-self:flex-start;background:#ffffff1a;border:1px solid rgba(255,255,255,.12)}.msg p{margin:0;font-size:.92rem;line-height:1.45}.msg small{color:#b8c9e8;display:block;margin-top:6px}.qa-input{margin-top:10px}.qa-input textarea{width:100%;border-radius:10px;border:1px solid rgba(255,255,255,.16);background:#ffffff14;color:#fff;padding:8px;resize:none}.qa-input button,.evaluate-btn{width:100%;margin-top:8px;border:0;border-radius:10px;padding:9px;color:#fff;background:linear-gradient(135deg,#3b82f6,#4f46e5);cursor:pointer;font-weight:700}.test-card{border:1px solid rgba(255,255,255,.14);border-radius:10px;padding:10px;margin-bottom:8px;background:#ffffff0d}.test-card p{margin:0 0 8px}.test-options{display:grid;gap:6px}.test-options label{display:flex;gap:8px;font-size:.9rem}.test-result{margin-top:10px;border-radius:12px;border:1px solid rgba(59,130,246,.5);background:#1e40af33;padding:10px}.test-empty-state{border:1px dashed rgba(255,255,255,.22);border-radius:12px;padding:14px;text-align:center;background:#ffffff0a}.test-empty-state h3{margin:0}.test-empty-state p{margin:8px 0 12px;color:#b9cbe9}.test-topbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.test-topbar-actions{display:flex;gap:8px}.ghost-btn{border:1px solid rgba(255,255,255,.2);background:#ffffff14;color:#e7f0ff;border-radius:10px;padding:8px 10px;cursor:pointer}.ghost-btn.full{width:100%;margin-top:8px}.result-chart,.topic-bars{margin-top:10px;display:grid;gap:8px}.bar-row,.topic-bar-row{display:grid;grid-template-columns:64px 1fr 44px;align-items:center;gap:8px}.bar-row span,.topic-bar-row span{color:#d4e2f9;font-size:.82rem}.bar-track{height:10px;border-radius:999px;background:#ffffff24;overflow:hidden}.bar-fill{height:100%;border-radius:999px;background:linear-gradient(135deg,#3b82f6,#4f46e5)}.bar-fill.success{background:linear-gradient(135deg,#22c55e,#16a34a)}.bar-fill.danger{background:linear-gradient(135deg,#ef4444,#dc2626)}.bar-fill.neutral{background:linear-gradient(135deg,#64748b,#475569)}.bar-row b,.topic-bar-row b{justify-self:end;font-size:.82rem;color:#f0f6ff}.test-modal-backdrop{position:fixed;inset:0;background:#020617a8;display:grid;place-items:center;z-index:60;padding:16px}.test-modal{width:min(430px,100%);border-radius:16px;border:1px solid rgba(255,255,255,.18);background:#090f1cf7;padding:16px}.test-modal h3{margin:0}.test-modal p{margin:8px 0 12px;color:#bfd2ef;font-size:.88rem}.test-size-options{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.test-size-options button{border:1px solid rgba(255,255,255,.18);background:#ffffff0f;color:#dbe8fb;border-radius:10px;padding:10px 8px;cursor:pointer}.test-size-options button.active{background:#3b82f6b8;border-color:#3b82f6f2;color:#fff}.test-modal-actions{margin-top:12px;display:flex;justify-content:flex-end;gap:8px}.question-modal{max-width:560px}.question-modal-head{display:flex;justify-content:space-between;align-items:center;gap:10px}.question-progress{margin-top:10px;height:8px;border-radius:999px;background:#ffffff24;overflow:hidden}.question-progress-fill{height:100%;border-radius:999px;background:linear-gradient(135deg,#3b82f6,#4f46e5)}.question-text{margin:12px 0 10px;font-size:1rem;line-height:1.45;color:#eef5ff}.question-options{display:grid;gap:8px}.question-options button{text-align:left;border:1px solid rgba(255,255,255,.18);background:#ffffff0f;color:#dbe8fb;border-radius:10px;padding:10px 12px;cursor:pointer}.question-options button.active,.question-options button:hover{background:#3b82f6b8;border-color:#3b82f6f2;color:#fff}.topic-guide{margin-top:10px;padding-top:10px;border-top:1px dashed rgba(255,255,255,.25)}.topic-guide p{margin:0 0 6px}.topic-guide ul{margin:0;padding-left:18px}@media(max-width:1140px){.shelf-shell{grid-template-columns:68px 1fr}.menu-drawer{position:fixed;left:68px;top:0;bottom:0;width:220px;z-index:35;transform:translate(-110%)}.menu-drawer.open{transform:translate(0)}.shelf-page{padding:16px}.reader-body{grid-template-columns:1fr}.reader-side{max-height:52vh}.reader-pdf{min-height:60vh}}
