*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-dark:#0d0f14;--bg-panel:#131720;--bg-card:#1a2030;--bg-hover:#1f2840;--border:#252d3d;--cyan:#00d2ff;--yellow:#f5c518;--green:#22c55e;--red:#ef4444;--orange:#f97316;--purple:#a855f7;--text-primary:#e8eaf0;--text-secondary:#8892a4;--text-muted:#4a5568;--radius:10px;--radius-sm:6px}html,body,#root{background:var(--bg-dark);height:100%;color:var(--text-primary);font-family:Segoe UI,system-ui,sans-serif;font-size:14px}button{cursor:pointer;border:none;outline:none;font-family:inherit}.app-shell{height:100vh;display:flex;overflow:hidden}.left-panel{background:var(--bg-panel);border-right:1px solid var(--border);flex-direction:column;width:300px;min-width:280px;max-width:300px;display:flex;overflow:hidden}.config-panel{scrollbar-width:thin;scrollbar-color:var(--border) transparent;flex-direction:column;height:100%;display:flex;overflow-y:auto}.config-panel::-webkit-scrollbar{width:4px}.config-panel::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.config-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.logo-area{align-items:center;gap:10px;display:flex}.logo-icon{border:1px solid var(--cyan);width:36px;height:36px;color:var(--cyan);background:linear-gradient(135deg,#00d2ff22,#7c3aed22);border-radius:8px;justify-content:center;align-items:center;display:flex}.logo-title{color:var(--text-primary);font-size:13px;font-weight:700}.logo-sub{color:var(--text-secondary);font-size:10px}.header-scores{align-items:center;gap:6px;display:flex}.score-chip{background:var(--bg-card);border:1px solid var(--border);color:var(--yellow);border-radius:20px;padding:3px 8px;font-size:11px;font-weight:600}.score-chip.diamond{color:var(--cyan)}.icon-btn{color:var(--text-secondary);background:0 0;border-radius:4px;padding:4px;font-size:16px}.icon-btn:hover{color:var(--text-primary)}.api-key-box{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);flex-direction:column;gap:8px;margin:10px 16px;padding:12px;display:flex}.api-key-box label{color:var(--cyan);text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:600}.api-key-box input{background:var(--bg-dark);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);width:100%;padding:7px 10px;font-family:monospace;font-size:12px}.btn-save{background:var(--cyan);color:#000;border-radius:var(--radius-sm);width:100%;padding:7px 14px;font-size:12px;font-weight:700}.api-link{color:var(--cyan);text-align:center;font-size:11px;text-decoration:none}.api-link:hover{text-decoration:underline}.config-section{border-bottom:1px solid var(--border);padding:14px 16px}.config-label{letter-spacing:1px;color:var(--cyan);text-transform:uppercase;align-items:center;gap:6px;margin-bottom:10px;font-size:10px;font-weight:700;display:flex}.config-label.mt{margin-top:12px}.row-2{grid-template-columns:1fr 1fr;gap:8px;margin-bottom:10px;display:grid}.select-field{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);appearance:none;width:100%;padding:8px 10px;font-family:inherit;font-size:13px}.select-field:focus{border-color:var(--cyan)}.board-row{grid-template-columns:1fr 1fr;gap:8px;display:grid}.board-btn{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);padding:8px;font-size:13px;font-weight:600;transition:all .2s}.board-btn.active{background:var(--cyan);border-color:var(--cyan);color:#000}.board-btn:hover:not(.active){border-color:var(--cyan);color:var(--text-primary)}.difficulty-row{grid-template-columns:repeat(3,1fr);gap:6px;display:grid}.diff-btn{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);padding:7px 4px;font-size:12px;font-weight:600;transition:all .2s}.diff-btn.active-easy{border-color:var(--green);color:var(--green);background:#22c55e22}.diff-btn.active-medium{border-color:var(--yellow);color:var(--yellow);background:#f5c51822}.diff-btn.active-hard{border-color:var(--red);color:var(--red);background:#ef444422}.q-count-row{grid-template-columns:repeat(4,1fr);gap:6px;display:grid}.q-btn{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);padding:7px 4px;font-size:12px;font-weight:600;transition:all .2s}.q-btn.active{border-color:var(--cyan);color:var(--cyan);background:#00d2ff22}.topic-list{scrollbar-width:thin;flex-direction:column;gap:4px;max-height:280px;display:flex;overflow-y:auto}.chapter-item{flex-direction:column;display:flex}.chapter-btn{background:var(--bg-card);border-radius:var(--radius-sm);width:100%;color:var(--text-secondary);text-align:left;border:1px solid #0000;align-items:center;gap:8px;padding:9px 10px;font-size:12.5px;transition:all .2s;display:flex}.chapter-btn.expanded{border-color:var(--cyan);color:var(--cyan);background:#00d2ff11}.chapter-btn:hover:not(.expanded){background:var(--bg-hover);color:var(--text-primary)}.chapter-dot{border:2px solid var(--text-muted);border-radius:50%;flex-shrink:0;width:8px;height:8px}.chapter-dot.selected{background:var(--cyan);border-color:var(--cyan)}.chapter-name{flex:1;font-size:12px}.chapter-arrow{color:var(--text-muted);font-size:9px}.subtopics{flex-direction:column;gap:2px;padding:4px 0 4px 18px;display:flex}.subtopic-btn{border-radius:var(--radius-sm);width:100%;color:var(--text-secondary);text-align:left;background:0 0;border:none;align-items:center;gap:8px;padding:7px 8px;font-size:12px;transition:all .2s;display:flex}.subtopic-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.subtopic-btn.selected{color:var(--cyan)}.sub-dot{border:1.5px solid var(--text-muted);border-radius:50%;flex-shrink:0;width:6px;height:6px}.sub-dot.selected{background:var(--cyan);border-color:var(--cyan)}.selected-info{border-top:1px solid var(--border);padding:12px 16px}.selected-label{color:var(--text-secondary);margin-bottom:8px;font-size:11px}.selected-label strong{color:var(--cyan)}.start-btn{background:linear-gradient(135deg,var(--cyan),#7c3aed);color:#fff;border-radius:var(--radius-sm);letter-spacing:.5px;width:100%;padding:11px;font-size:14px;font-weight:700;transition:opacity .2s,transform .1s}.start-btn:hover{opacity:.92;transform:translateY(-1px)}.start-btn:active{transform:translateY(0)}.right-panel{background:var(--bg-dark);flex-direction:column;flex:1;display:flex;overflow-y:auto}.ready-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:16px;height:100%;padding:40px;display:flex}.error-banner{border:1px solid var(--red);border-radius:var(--radius-sm);width:100%;max-width:480px;color:var(--red);background:#ef444422;padding:10px 16px;font-size:13px}.ready-icon{font-size:64px;line-height:1}.ready-title{letter-spacing:3px;background:linear-gradient(135deg,var(--cyan),#7c3aed);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:36px;font-weight:900}.ready-sub{color:var(--text-secondary);font-size:14px}.ready-features{flex-wrap:wrap;justify-content:center;gap:8px;max-width:400px;display:flex}.feature-chip{background:var(--bg-card);border:1px solid var(--border);color:var(--text-secondary);border-radius:20px;padding:6px 14px;font-size:12px}.loading-state{flex-direction:column;justify-content:center;align-items:center;gap:20px;height:100%;display:flex}.loader-ring{border:3px solid var(--border);border-top-color:var(--cyan);border-radius:50%;width:56px;height:56px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.loading-msg{color:var(--text-primary);font-size:16px;font-weight:600}.loading-sub{color:var(--text-secondary);font-size:12px}.streak-banner{color:var(--orange);text-align:center;background:linear-gradient(90deg,#f9731622,#ef444422);border-bottom:1px solid #f97316;flex-shrink:0;padding:8px;font-size:13px;font-weight:700}.quiz-wrapper{flex-direction:column;height:100%;display:flex}.quiz-area{flex-direction:column;flex:1;gap:16px;padding:24px;display:flex;overflow-y:auto}.quiz-area-header{flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.quiz-breadcrumb{color:var(--text-secondary);align-items:center;gap:6px;font-size:12px;display:flex}.breadcrumb-sep{color:var(--text-muted)}.breadcrumb-active{color:var(--cyan);font-weight:600}.quiz-live-score{gap:10px;font-size:13px;font-weight:700;display:flex}.live-correct{color:var(--green)}.live-wrong{color:var(--red)}.question-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;flex:1;gap:20px;padding:24px;display:flex}.q-progress-bar{background:var(--border);border-radius:2px;height:4px;overflow:hidden}.q-progress-fill{background:linear-gradient(90deg,var(--cyan),#7c3aed);border-radius:2px;height:100%;transition:width .4s}.q-meta{justify-content:space-between;align-items:center;display:flex}.q-counter{color:var(--text-secondary);font-size:12px}.q-type-badge{border-radius:20px;padding:3px 10px;font-size:11px;font-weight:600}.q-type-badge.type-mcq{color:var(--cyan);background:#00d2ff15;border:1px solid #00d2ff44}.q-type-badge.type-truefalse{color:var(--purple);background:#a855f715;border:1px solid #a855f744}.q-type-badge.type-fillblank{color:var(--yellow);background:#f5c51815;border:1px solid #f5c51844}.q-text{color:var(--text-primary);font-size:17px;font-weight:600;line-height:1.55}.options-grid{grid-template-columns:1fr 1fr;gap:10px;display:grid}.option-btn{background:var(--bg-dark);border:1.5px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);text-align:left;cursor:pointer;align-items:flex-start;gap:10px;width:100%;padding:12px 14px;font-size:13.5px;line-height:1.45;transition:all .18s;display:flex}.option-btn:hover:not(:disabled):not(.correct):not(.wrong):not(.dimmed){border-color:var(--cyan);background:var(--bg-hover)}.option-btn.correct{border-color:var(--green);color:var(--green);background:#22c55e18}.option-btn.wrong{border-color:var(--red);color:var(--red);background:#ef444418}.option-btn.dimmed{opacity:.45}.option-btn:disabled{cursor:default}.option-label{background:var(--border);border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;font-size:11px;font-weight:700;display:flex}.option-btn.correct .option-label{background:var(--green);color:#000}.option-btn.wrong .option-label{background:var(--red);color:#fff}.option-text{flex:1}.option-icon{flex-shrink:0;font-size:16px;font-weight:700}.correct-icon{color:var(--green)}.wrong-icon{color:var(--red)}.fill-area{flex-direction:column;gap:10px;display:flex}.fill-input{background:var(--bg-dark);border:1.5px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);width:100%;padding:12px 16px;font-family:inherit;font-size:15px}.fill-input:focus{border-color:var(--cyan);outline:none}.fill-input:disabled{opacity:.6}.fill-submit-btn{background:var(--cyan);color:#000;border-radius:var(--radius-sm);align-self:flex-start;padding:10px 20px;font-size:13px;font-weight:700}.fill-result{border-radius:var(--radius-sm);padding:10px 14px;font-size:13px;font-weight:600}.fill-result.correct{color:var(--green);background:#22c55e18;border:1px solid #22c55e44}.fill-result.wrong{color:var(--red);background:#ef444418;border:1px solid #ef444444}.explanation-box{border-radius:var(--radius-sm);background:#00d2ff0a;border:1px solid #00d2ff33;padding:14px;animation:.3s fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.explanation-label{color:var(--cyan);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;font-size:11px;font-weight:700}.explanation-text{color:var(--text-secondary);font-size:13px;line-height:1.5}.results-screen{flex-direction:column;gap:20px;padding:24px;display:flex;overflow-y:auto}.results-header{text-align:center;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px}.results-emoji{margin-bottom:8px;font-size:48px}.results-grade{color:var(--cyan);font-size:48px;font-weight:900}.results-message{color:var(--text-secondary);margin-top:4px;font-size:18px}.results-stats{grid-template-columns:repeat(3,1fr);gap:12px;display:grid}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);text-align:center;padding:18px}.stat-value{font-size:28px;font-weight:800}.text-cyan{color:var(--cyan)}.text-yellow{color:var(--yellow)}.text-green{color:var(--green)}.stat-label{color:var(--text-secondary);margin-top:4px;font-size:12px}.results-meta{flex-wrap:wrap;gap:8px;display:flex}.meta-chip{background:var(--bg-card);border:1px solid var(--border);color:var(--text-secondary);border-radius:20px;padding:5px 12px;font-size:12px}.results-topic{color:var(--text-secondary);background:var(--bg-card);border-radius:var(--radius-sm);border:1px solid var(--border);padding:10px 14px;font-size:13px}.results-topic strong{color:var(--text-primary)}.results-review{flex-direction:column;gap:8px;display:flex}.review-item{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);gap:12px;padding:12px;display:flex}.review-item.review-correct{border-left:3px solid var(--green)}.review-item.review-wrong{border-left:3px solid var(--red)}.review-q-num{color:var(--text-muted);flex-direction:column;flex-shrink:0;align-items:center;gap:4px;font-size:11px;display:flex}.review-dot{border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;font-size:11px;font-weight:700;display:flex}.review-dot.correct{color:var(--green);background:#22c55e22}.review-dot.wrong{color:var(--red);background:#ef444422}.review-content{flex-direction:column;flex:1;gap:6px;display:flex}.review-question{color:var(--text-primary);font-size:13px;line-height:1.4}.review-answer{flex-wrap:wrap;gap:12px;font-size:11px;display:flex}.wrong-ans{color:var(--red)}.correct-ans{color:var(--green);font-weight:600}.review-explanation{color:var(--text-muted);font-size:12px;line-height:1.4}.results-actions{grid-template-columns:1fr 1fr;gap:12px;display:grid}.btn-retry{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);padding:12px;font-size:14px;font-weight:600;transition:all .2s}.btn-retry:hover{border-color:var(--cyan);color:var(--text-primary)}.btn-new{background:linear-gradient(135deg,var(--cyan),#7c3aed);border-radius:var(--radius-sm);color:#fff;padding:12px;font-size:14px;font-weight:700}.btn-new:hover{opacity:.9}@media (width<=680px){.app-shell{flex-direction:column}.left-panel{border-right:none;border-bottom:1px solid var(--border);width:100%;max-width:100%;height:auto}.options-grid{grid-template-columns:1fr}}.dashboard{flex-direction:column;gap:16px;padding:24px;display:flex;overflow-y:auto}.dash-header{flex-wrap:wrap;flex-shrink:0;align-items:center;gap:16px;display:flex}.dash-back-btn{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);padding:7px 14px;font-size:13px;font-weight:600;transition:all .2s}.dash-back-btn:hover{border-color:var(--cyan);color:var(--text-primary)}.dash-title{color:var(--text-primary);flex:1;font-size:20px;font-weight:800}.dash-user-chip{color:var(--text-secondary);align-items:center;gap:8px;font-size:13px;font-weight:600;display:flex}.user-avatar.sm{width:26px;height:26px;font-size:11px}.dash-loading{color:var(--text-secondary);justify-content:center;align-items:center;gap:12px;padding:40px;display:flex}.dash-empty{text-align:center;color:var(--text-primary);flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:60px 24px;display:flex}.dash-grid-4{grid-template-columns:repeat(4,1fr);gap:12px;display:grid}.dash-stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);text-align:center;padding:18px}.dash-stat-val{font-size:28px;font-weight:800}.dash-stat-lbl{color:var(--text-secondary);margin-top:4px;font-size:11px}.dash-row-2{grid-template-columns:1fr 1fr;gap:16px;display:grid}.dash-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:12px;padding:18px;display:flex}.dash-card-title{letter-spacing:1px;text-transform:uppercase;color:var(--cyan);margin-bottom:2px;font-size:11px;font-weight:700}.dash-card-title.text-green{color:var(--green)}.dash-card-title.text-red{color:var(--red)}.dash-row-item{align-items:center;gap:12px;display:flex}.dash-row-label{width:90px;color:var(--text-secondary);flex-shrink:0;font-size:12.5px}.dash-row-right{flex:1;align-items:center;gap:8px;display:flex}.acc-bar-track{background:var(--border);border-radius:3px;flex:1;height:6px;overflow:hidden}.acc-bar-fill{border-radius:3px;height:100%;transition:width .4s}.dash-row-pct{text-align:right;width:36px;color:var(--text-primary);font-size:12px;font-weight:700}.dash-chapter-row{justify-content:space-between;align-items:center;font-size:12.5px;display:flex}.dash-chapter-name{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;max-width:140px;overflow:hidden}.dash-chapter-acc{flex-shrink:0;font-weight:700}.dash-session-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:10px 0;display:flex}.dash-session-row:last-child{border-bottom:none;padding-bottom:0}.dash-session-row:first-of-type{padding-top:0}.dash-session-info{flex-direction:column;gap:3px;min-width:0;display:flex}.dash-session-topic{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;max-width:340px;font-size:13px;overflow:hidden}.dash-session-meta{color:var(--text-muted);font-size:11px}.dash-session-pct{flex-shrink:0;font-size:18px;font-weight:800}.text-red{color:var(--red)}.user-info-btn{cursor:pointer;text-align:left;border-radius:var(--radius-sm);background:0 0;border:none;align-items:center;gap:10px;min-width:0;padding:0;transition:opacity .2s;display:flex}.user-info-btn:hover{opacity:.8}@media (width<=680px){.dash-grid-4{grid-template-columns:repeat(2,1fr)}.dash-row-2{grid-template-columns:1fr}}.admin-panel{flex-direction:column;height:100%;display:flex;overflow:hidden}.admin-tabs{border-bottom:1px solid var(--border);flex-shrink:0;padding:0 24px;display:flex}.admin-tab-btn{color:var(--text-secondary);background:0 0;border-bottom:2px solid #0000;padding:12px 16px;font-size:13px;font-weight:600;transition:all .2s}.admin-tab-btn.active{color:var(--cyan);border-bottom-color:var(--cyan)}.admin-tab-btn:hover:not(.active){color:var(--text-primary)}.admin-tab-content{flex-direction:column;flex:1;gap:16px;padding:20px 24px;display:flex;overflow-y:auto}.admin-loading{color:var(--text-secondary);justify-content:center;align-items:center;gap:12px;padding:40px;display:flex}.admin-empty{text-align:center;color:var(--text-muted);padding:40px;font-size:13px}.admin-count-badge{background:var(--bg-dark);border:1px solid var(--border);color:var(--text-primary);border-radius:20px;padding:2px 10px;font-size:12px;font-weight:700}.admin-count-badge.text-green{color:var(--green)}.admin-filters{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.admin-filter-sel{flex:1;min-width:110px;max-width:160px}.admin-total-badge{color:var(--text-muted);white-space:nowrap;font-size:11px}.admin-q-list{flex-direction:column;gap:8px;display:flex}.admin-q-row{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);align-items:flex-start;gap:12px;padding:12px 14px;transition:background .15s;display:flex}.admin-q-row--selected{background:#3b82f610;border-color:#3b82f640}.admin-q-header{background:0 0;border-color:#0000;align-items:center;padding:8px 14px}.admin-q-checkbox{cursor:pointer;width:16px;height:16px;accent-color:var(--accent);flex-shrink:0}.admin-q-select-label{color:var(--text-muted);font-size:12px}.admin-q-info{flex-direction:column;flex:1;gap:6px;min-width:0;display:flex}.admin-q-text{color:var(--text-primary);font-size:13px;line-height:1.4}.admin-q-meta{flex-wrap:wrap;gap:4px;display:flex}.admin-delete-btn{border-radius:var(--radius-sm);color:var(--red);background:#ef444415;border:1px solid #ef444430;flex-shrink:0;padding:4px 10px;font-size:13px;font-weight:700;transition:all .2s}.admin-delete-btn:hover:not(:disabled){border-color:var(--red);background:#ef444425}.admin-delete-btn:disabled{opacity:.4;cursor:not-allowed}.admin-bulk-delete-btn{border-radius:var(--radius-sm);color:var(--red);cursor:pointer;white-space:nowrap;background:#ef444420;border:1px solid #ef444450;padding:6px 14px;font-size:12px;font-weight:600;transition:all .2s}.admin-bulk-delete-btn:hover:not(:disabled){border-color:var(--red);background:#ef444435}.admin-bulk-delete-btn:disabled{opacity:.4;cursor:not-allowed}.admin-upload-box{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.admin-file-input{display:none}.admin-file-label{background:var(--bg-dark);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;padding:8px 14px;font-size:12.5px;font-weight:600;transition:all .2s}.admin-file-label:hover{border-color:var(--cyan);color:var(--text-primary)}.admin-upload-btn{background:var(--cyan);color:#000;border-radius:var(--radius-sm);padding:8px 18px;font-size:13px;font-weight:700;transition:opacity .2s}.admin-upload-btn:hover:not(:disabled){opacity:.88}.admin-upload-btn:disabled{opacity:.4;cursor:not-allowed}.admin-template-btn{border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);background:0 0;padding:8px 14px;font-size:12.5px;transition:all .2s}.admin-template-btn:hover{border-color:var(--cyan);color:var(--text-primary)}.admin-upload-result{border-radius:var(--radius-sm);margin-top:4px;padding:10px 14px;font-size:13px;font-weight:600}.admin-upload-result.ok{color:var(--green);background:#22c55e18;border:1px solid #22c55e44}.admin-upload-result.err{color:var(--red);background:#ef444418;border:1px solid #ef444444}.admin-upload-errors{opacity:.8;flex-direction:column;gap:2px;margin-top:6px;font-size:11px;display:flex}.admin-upload-row{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:8px 0;display:flex}.admin-upload-row:last-child{border-bottom:none}.admin-upload-name{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;flex:1;max-width:300px;font-size:12.5px;overflow:hidden}.admin-upload-date{color:var(--text-muted);flex-shrink:0;font-size:11px}.admin-user-list{flex-direction:column;gap:8px;display:flex}.admin-user-row{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);align-items:center;gap:12px;padding:12px 14px;display:flex}.admin-user-info{flex-direction:column;flex:1;gap:3px;min-width:0;display:flex}.admin-user-name{color:var(--text-primary);font-size:13px;font-weight:600}.admin-user-email{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.admin-role-select{background:var(--bg-dark);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);flex-shrink:0;padding:5px 8px;font-family:inherit;font-size:12px}.admin-icon-btn{font-size:15px;color:var(--cyan)!important}.option-btn.selected-offline{border-color:var(--cyan);color:var(--cyan);background:#00d2ff18}.explanation-box.offline-noted{background:#00d2ff08;border-color:#00d2ff22}.explanation-box.offline-noted .explanation-text{color:var(--text-muted);font-style:italic}.user-bar{border-bottom:1px solid var(--border);background:var(--bg-panel);flex-shrink:0;justify-content:space-between;align-items:center;padding:10px 16px;display:flex}.user-info{align-items:center;gap:10px;min-width:0;display:flex}.user-avatar{background:linear-gradient(135deg,var(--cyan),#7c3aed);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:13px;font-weight:700;display:flex}.user-details{min-width:0}.user-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;max-width:160px;font-size:12.5px;font-weight:600;overflow:hidden}.user-role{color:var(--text-secondary);text-transform:capitalize;font-size:10px}.logout-btn{color:var(--text-muted);background:0 0;border-radius:4px;flex-shrink:0;padding:4px 6px;font-size:18px;transition:color .2s}.logout-btn:hover{color:var(--red)}.login-btn{background:linear-gradient(135deg,var(--cyan),#7c3aed);color:#fff;border-radius:var(--radius-sm);letter-spacing:.3px;width:100%;padding:8px 14px;font-size:12.5px;font-weight:700;transition:opacity .2s}.login-btn:hover{opacity:.88}.auth-overlay{z-index:1000;background:#000b;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.auth-modal{background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;width:100%;max-width:400px;animation:.2s fadeIn;display:flex;overflow:hidden}.auth-modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.auth-logo{color:var(--cyan);align-items:center;gap:8px;font-size:14px;font-weight:700;display:flex}.auth-close-btn{color:var(--text-muted);background:0 0;border-radius:4px;padding:4px 8px;font-size:16px;transition:color .2s}.auth-close-btn:hover{color:var(--text-primary)}.auth-tabs{border-bottom:1px solid var(--border);grid-template-columns:1fr 1fr;display:grid}.auth-tab{color:var(--text-secondary);background:0 0;border-bottom:2px solid #0000;padding:12px;font-size:13px;font-weight:600;transition:all .2s}.auth-tab.active{color:var(--cyan);border-bottom-color:var(--cyan)}.auth-tab:hover:not(.active){color:var(--text-primary)}.auth-error{border:1px solid var(--red);border-radius:var(--radius-sm);color:var(--red);background:#ef444420;margin:12px 20px 0;padding:10px 14px;font-size:12.5px}.auth-success{border-radius:var(--radius-sm);color:#22c55e;background:#22c55e20;border:1px solid #22c55e;padding:10px 14px;font-size:12.5px}.auth-form{flex-direction:column;gap:14px;padding:20px;display:flex}.auth-field{flex-direction:column;gap:6px;display:flex}.auth-field label{color:var(--cyan);text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:600}.auth-field input,.auth-field select{background:var(--bg-dark);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);width:100%;padding:9px 12px;font-family:inherit;font-size:13px;transition:border-color .2s}.auth-field input:focus,.auth-field select:focus{border-color:var(--cyan);outline:none}.auth-row-2{grid-template-columns:1fr 1fr;gap:12px;display:grid}.auth-submit-btn{background:linear-gradient(135deg,var(--cyan),#7c3aed);color:#fff;border-radius:var(--radius-sm);margin-top:4px;padding:11px;font-size:14px;font-weight:700;transition:opacity .2s}.auth-submit-btn:hover:not(:disabled){opacity:.88}.auth-submit-btn:disabled{opacity:.5;cursor:not-allowed}.auth-hint{color:var(--text-muted);text-align:center;font-size:11px;line-height:1.5}.auth-hint code{color:var(--text-secondary);font-family:monospace}
