*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0f1117;--surface: #1a1d27;--surface-2: #22263a;--border: #2e3250;--accent: #6c63ff;--accent-hover: #5a52e0;--accent-light: rgba(108, 99, 255, .15);--text: #e8eaf6;--text-muted: #8b90b0;--success: #4caf7d;--danger: #e05c6e;--radius: 12px;--shadow: 0 4px 24px rgba(0,0,0,.4);font-family:Inter,system-ui,-apple-system,sans-serif;font-size:16px;line-height:1.6}html,body{min-height:100vh;background:var(--bg);color:var(--text)}#root{min-height:100vh}.app{min-height:100vh;display:flex;flex-direction:column;align-items:center;padding:2rem 1rem}.error-banner{width:100%;max-width:680px;background:#e05c6e26;border:1px solid var(--danger);color:#f2a0aa;border-radius:var(--radius);padding:.75rem 1rem;display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;font-size:.9rem}.error-banner button{background:none;border:none;color:inherit;cursor:pointer;font-size:1rem;padding:0 .25rem}.success-banner{width:100%;max-width:680px;background:#4caf7d1f;border:1px solid rgba(76,175,125,.4);color:#7ddba8;border-radius:var(--radius);padding:.75rem 1rem;display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;font-size:.9rem}.success-banner button{background:none;border:none;color:inherit;cursor:pointer;font-size:1rem;padding:0 .25rem}.quiz-form-container{width:100%;max-width:680px}.hero{text-align:center;margin-bottom:2.5rem}.logo{font-size:2.4rem;font-weight:800;letter-spacing:-1px;background:linear-gradient(135deg,#6c63ff,#a78bfa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.tagline{color:var(--text-muted);margin-top:.4rem;font-size:1.05rem}.quiz-form{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:2rem;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:1.5rem}.field{display:flex;flex-direction:column;gap:.5rem}.field label{font-size:.875rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}textarea{background:var(--bg);border:1px solid var(--border);border-radius:8px;color:var(--text);font-family:inherit;font-size:.95rem;line-height:1.6;padding:.875rem 1rem;resize:vertical;transition:border-color .2s;width:100%}textarea:focus{outline:none;border-color:var(--accent)}textarea::placeholder{color:var(--text-muted)}textarea:disabled{opacity:.5}.char-hint{font-size:.8rem;color:var(--text-muted);text-align:right}.char-hint.error{color:var(--danger)}.count-selector{display:flex;gap:.75rem}.count-btn{flex:1;background:var(--bg);border:1px solid var(--border);border-radius:8px;color:var(--text-muted);cursor:pointer;font-size:1rem;font-weight:600;padding:.6rem;transition:all .15s}.count-btn:hover:not(:disabled){border-color:var(--accent);color:var(--text)}.count-btn.active{background:var(--accent-light);border-color:var(--accent);color:var(--accent)}.count-btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:var(--accent);border:none;border-radius:8px;color:#fff;cursor:pointer;font-family:inherit;font-size:1rem;font-weight:600;padding:.8rem 1.5rem;transition:background .15s,transform .1s;width:100%}.btn-primary:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-1px)}.btn-primary:disabled{opacity:.45;cursor:not-allowed;transform:none}.btn-secondary{background:var(--surface-2);border:1px solid var(--border);border-radius:8px;color:var(--text);cursor:pointer;font-family:inherit;font-size:.95rem;font-weight:500;padding:.7rem 1.25rem;transition:border-color .15s}.btn-secondary:hover:not(:disabled){border-color:var(--accent)}.btn-secondary:disabled{opacity:.4;cursor:not-allowed}.btn-ghost{background:none;border:1px solid var(--border);border-radius:6px;color:var(--text-muted);cursor:pointer;font-family:inherit;font-size:.85rem;padding:.3rem .7rem;transition:all .15s}.btn-ghost:hover{border-color:var(--accent);color:var(--accent)}.spinner-row{display:flex;align-items:center;justify-content:center;gap:.5rem}.spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.quiz-container{width:100%;max-width:680px;display:flex;flex-direction:column;gap:1.25rem}.quiz-header{display:flex;flex-direction:column;gap:.5rem}.progress-bar{height:4px;background:var(--surface-2);border-radius:2px;overflow:hidden}.progress-fill{height:100%;background:var(--accent);border-radius:2px;transition:width .3s ease}.quiz-meta{display:flex;justify-content:space-between;align-items:center;font-size:.85rem;color:var(--text-muted)}.question-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.75rem;box-shadow:var(--shadow)}.question-text{font-size:1.1rem;font-weight:500;line-height:1.55;margin-bottom:1.5rem}.options{display:flex;flex-direction:column;gap:.65rem}.option-btn{align-items:center;background:var(--bg);border:1px solid var(--border);border-radius:8px;color:var(--text);cursor:pointer;display:flex;font-family:inherit;font-size:.95rem;gap:.875rem;padding:.8rem 1rem;text-align:left;transition:all .15s;width:100%}.option-btn:hover{border-color:var(--accent);background:var(--accent-light)}.option-btn.selected{border-color:var(--accent);background:var(--accent-light);color:var(--text)}.option-letter{background:var(--surface-2);border-radius:4px;color:var(--text-muted);flex-shrink:0;font-size:.8rem;font-weight:700;padding:.1rem .45rem}.option-btn.selected .option-letter{background:var(--accent);color:#fff}.quiz-nav{display:flex;gap:.75rem;justify-content:space-between}.quiz-nav .btn-primary{width:auto;flex:1}.quiz-nav .btn-secondary{flex:0 0 auto}.results-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:2rem;box-shadow:var(--shadow);display:flex;flex-direction:column;align-items:center;gap:.75rem;width:100%}.score-circle{width:100px;height:100px;border-radius:50%;border:4px solid var(--accent);display:flex;align-items:center;justify-content:center;margin-bottom:.5rem}.score-num{font-size:1.6rem;font-weight:800;color:var(--accent)}.results-card h2{font-size:1.4rem}.score-detail{color:var(--text-muted)}.results-breakdown{width:100%;display:flex;flex-direction:column;gap:.6rem;margin-top:1rem;max-height:360px;overflow-y:auto;padding-right:.25rem}.result-item{border-radius:8px;display:flex;gap:.75rem;padding:.75rem 1rem}.result-item.correct{background:#4caf7d1a;border:1px solid rgba(76,175,125,.3)}.result-item.wrong{background:#e05c6e1a;border:1px solid rgba(224,92,110,.3)}.result-indicator{font-size:1rem;font-weight:700;flex-shrink:0;padding-top:1px}.result-item.correct .result-indicator{color:var(--success)}.result-item.wrong .result-indicator{color:var(--danger)}.result-q{font-size:.9rem;font-weight:500;margin-bottom:.25rem}.result-wrong,.result-correct{font-size:.82rem;color:var(--text-muted)}.result-wrong span{color:var(--danger)}.result-correct span{color:var(--success)}.results-actions{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center;margin-top:1.25rem;width:100%}.results-actions .btn-primary{width:auto}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.page-spinner{display:flex;align-items:center;justify-content:center;min-height:100vh;width:100%}.spinner-lg{width:36px;height:36px;border-width:3px}.auth-container{width:100%;max-width:420px}.auth-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.auth-tabs{display:flex;border-bottom:1px solid var(--border)}.auth-tab{flex:1;background:none;border:none;border-bottom:2px solid transparent;color:var(--text-muted);cursor:pointer;font-family:inherit;font-size:.9rem;font-weight:600;padding:.9rem;transition:all .15s;margin-bottom:-1px}.auth-tab:hover{color:var(--text)}.auth-tab.active{border-bottom-color:var(--accent);color:var(--text)}.auth-form{display:flex;flex-direction:column;gap:1.1rem;padding:1.5rem}.auth-error{background:#e05c6e1f;border-top:1px solid rgba(224,92,110,.3);color:#f2a0aa;font-size:.875rem;padding:.7rem 1.5rem}.auth-hint{color:var(--text-muted);font-size:.8rem;padding:0 1.5rem 1.25rem;text-align:center}input[type=email],input[type=password],input[type=text]{background:var(--bg);border:1px solid var(--border);border-radius:8px;color:var(--text);font-family:inherit;font-size:.95rem;padding:.75rem 1rem;transition:border-color .2s;width:100%}input:focus{outline:none;border-color:var(--accent)}input::placeholder{color:var(--text-muted)}input:disabled{opacity:.5}.usage-widget{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:.75rem;padding:.875rem 1.1rem}.usage-row{align-items:center;display:flex;justify-content:space-between;margin-bottom:.5rem}.usage-label{align-items:center;display:flex;font-size:.85rem;gap:.5rem;color:var(--text-muted)}.plan-badge{border-radius:4px;font-size:.7rem;font-weight:700;letter-spacing:.05em;padding:.15rem .45rem;text-transform:uppercase}.plan-badge.free{background:var(--surface-2);color:var(--text-muted)}.plan-badge.pro{background:#6c63ff33;color:var(--accent)}.usage-track{background:var(--surface-2);border-radius:3px;height:4px;overflow:hidden}.usage-fill{background:var(--accent);border-radius:3px;height:100%;transition:width .4s ease}.usage-fill.full{background:var(--danger)}.upgrade-hint{color:var(--danger);font-size:.8rem;margin-top:.5rem}.usage-actions{display:flex;gap:.5rem;align-items:center}.upgrade-cta{background:linear-gradient(135deg,#6c63ff1f,#a78bfa14);border:1px solid rgba(108,99,255,.35);border-radius:var(--radius);display:flex;flex-direction:column;align-items:center;gap:.5rem;margin-bottom:.75rem;padding:1.25rem 1.5rem;text-align:center}.btn-upgrade-compact{background:linear-gradient(135deg,#6c63ff,#a78bfa);border:none;border-radius:6px;color:#fff;cursor:pointer;font-family:inherit;font-size:.8rem;font-weight:700;padding:.25rem .7rem;transition:opacity .15s;white-space:nowrap}.btn-upgrade-compact:hover:not(:disabled){opacity:.85}.btn-upgrade-compact:disabled{opacity:.5;cursor:not-allowed}.btn-upgrade{background:linear-gradient(135deg,#6c63ff,#a78bfa);border:none;border-radius:8px;color:#fff;cursor:pointer;font-family:inherit;font-size:1rem;font-weight:700;letter-spacing:.01em;padding:.8rem 2rem;transition:opacity .15s,transform .1s;width:100%;max-width:320px}.btn-upgrade:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.btn-upgrade:disabled{opacity:.5;cursor:not-allowed;transform:none}.upgrade-sub{color:var(--text-muted);font-size:.8rem}.upgrade-error{color:var(--danger);font-size:.8rem}.admin-nav{display:flex;gap:.25rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:.35rem;margin-bottom:1.25rem;width:100%;max-width:860px}.admin-nav-tab{flex:1;background:none;border:none;border-radius:8px;color:var(--text-muted);cursor:pointer;font-family:inherit;font-size:.9rem;font-weight:600;padding:.55rem 1rem;transition:all .15s}.admin-nav-tab:hover{color:var(--text)}.admin-nav-tab.active{background:var(--accent-light);color:var(--accent)}.admin-panel{width:100%;max-width:860px;display:flex;flex-direction:column;gap:1.25rem}.admin-title{font-size:1.3rem;font-weight:700;color:var(--text)}.admin-stats{display:flex;gap:.75rem;flex-wrap:wrap}.admin-stat-card{flex:1;min-width:120px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1rem 1.25rem;display:flex;flex-direction:column;gap:.2rem}.admin-stat-value{font-size:1.6rem;font-weight:800;color:var(--accent);line-height:1}.admin-stat-label{font-size:.78rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.admin-table-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow-x:auto}.admin-table{width:100%;border-collapse:collapse;font-size:.9rem}.admin-table th{background:var(--surface-2);color:var(--text-muted);font-size:.75rem;font-weight:700;letter-spacing:.05em;padding:.7rem 1rem;text-align:left;text-transform:uppercase;border-bottom:1px solid var(--border)}.admin-table td{padding:.7rem 1rem;border-bottom:1px solid var(--border);vertical-align:middle}.admin-table tr:last-child td{border-bottom:none}.admin-table tr:hover td{background:#ffffff05}.admin-cell-email{max-width:220px;word-break:break-all}.admin-cell-date{white-space:nowrap;color:var(--text-muted);font-size:.83rem}.admin-actions{display:flex;gap:.4rem;flex-wrap:wrap}.role-badge{border-radius:4px;font-size:.7rem;font-weight:700;letter-spacing:.05em;padding:.15rem .45rem;text-transform:uppercase}.role-badge.user{background:var(--surface-2);color:var(--text-muted)}.role-badge.admin{background:#6c63ff33;color:var(--accent)}.btn-ghost.btn-danger{border-color:#e05c6e66;color:var(--danger)}.btn-ghost.btn-danger:hover:not(:disabled){border-color:var(--danger);background:#e05c6e1a;color:var(--danger)}.top-nav{width:100%;max-width:680px;display:flex;justify-content:flex-end;margin-bottom:.75rem}.top-nav .btn-ghost.active{border-color:var(--accent);color:var(--accent)}.save-panel{display:flex;align-items:center;gap:.65rem;width:100%;margin-top:.25rem}.save-title-input{flex:1;background:var(--bg);border:1px solid var(--border);border-radius:8px;color:var(--text);font-family:inherit;font-size:.9rem;padding:.6rem .9rem;transition:border-color .2s}.save-title-input:focus{outline:none;border-color:var(--accent)}.save-title-input::placeholder{color:var(--text-muted)}.save-confirm{font-size:.88rem;color:var(--success)}.history-screen{width:100%;max-width:680px;display:flex;flex-direction:column;gap:.85rem}.history-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.5rem}.history-title{font-size:1.4rem;font-weight:700}.history-sub{color:var(--text-muted);font-size:.875rem;margin-top:.2rem}.history-loading{display:flex;justify-content:center;padding:2rem}.history-error{color:var(--danger);font-size:.9rem}.history-empty{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:2rem;text-align:center;color:var(--text-muted)}.history-empty-sub{font-size:.85rem;margin-top:.4rem}.quiz-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.quiz-card-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .15s}.quiz-card-header:hover{background:#ffffff05}.quiz-card-info{display:flex;flex-direction:column;gap:.2rem;min-width:0}.quiz-card-title{font-weight:600;font-size:.97rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.quiz-card-meta{font-size:.8rem;color:var(--text-muted)}.quiz-card-right{display:flex;align-items:center;gap:.75rem;flex-shrink:0}.quiz-card-chevron{font-size:.7rem;color:var(--text-muted)}.quiz-card-body{border-top:1px solid var(--border);padding:1rem 1.25rem;display:flex;flex-direction:column;gap:.85rem}.quiz-card-actions{display:flex;gap:.6rem;flex-wrap:wrap}.score-badge{border-radius:4px;font-size:.75rem;font-weight:700;padding:.15rem .5rem}.score-badge.good{background:#4caf7d33;color:var(--success)}.score-badge.mid{background:#ffc10726;color:#f0c040}.score-badge.bad{background:#e05c6e26;color:var(--danger)}.attempt-list{display:flex;flex-direction:column;gap:.4rem}.attempt-row{display:flex;align-items:center;gap:.75rem;font-size:.875rem}.attempt-num{color:var(--text-muted);font-size:.78rem;min-width:24px}.attempt-date{color:var(--text-muted);font-size:.8rem}.no-attempts{color:var(--text-muted);font-size:.875rem}@media(max-width:480px){.quiz-form,.question-card,.results-card,.auth-form{padding:1.25rem}.count-selector{gap:.4rem}.results-actions{flex-direction:column}.results-actions button{width:100%}.save-panel{flex-wrap:wrap}.save-title-input{width:100%}}
