:root{--bg: #0a0f1e;--bg-surface: #111827;--bg-card: #1a2744;--primary: #3b82f6;--primary-dark: #2563eb;--accent: #f59e0b;--success: #10b981;--error: #ef4444;--text: #f1f5f9;--text-muted: #94a3b8;--border: rgba(255, 255, 255, .08);--radius: 16px;--radius-sm: 10px;--navbar-h: 60px;--bottom-nav-h: 68px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%}body{background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Inter,sans-serif;line-height:1.6;min-height:100vh;overflow-x:hidden}a{color:var(--primary);text-decoration:none}a:active{opacity:.75}img{display:block;max-width:100%}h1,h2,h3,h4{color:var(--text);line-height:1.3}@keyframes pulse-glow{0%,to{box-shadow:0 0 8px #3b82f666}50%{box-shadow:0 0 20px #3b82f6cc}}@keyframes slide-up{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.slide-up{animation:slide-up .4s ease both}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes bounce-in{0%{transform:scale(.5);opacity:0}60%{transform:scale(1.1);opacity:1}80%{transform:scale(.95)}to{transform:scale(1)}}@keyframes spin{to{transform:rotate(360deg)}}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;background:var(--bg);gap:1rem}.spinner{width:44px;height:44px;border:3px solid rgba(59,130,246,.2);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}.navbar{position:fixed;top:0;left:0;right:0;height:var(--navbar-h);background:#0d1b2e;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid rgba(59,130,246,.15);box-shadow:0 1px 24px #00000080;display:flex;align-items:center;padding:0 1rem;z-index:100;gap:1rem}.navbar-brand{display:flex;align-items:center;gap:.5rem;text-decoration:none;flex-shrink:0}.navbar-logo{font-size:1.5rem}.navbar-title{font-weight:700;font-size:1.1rem;color:var(--text);letter-spacing:-.02em}.navbar-mobile-right{display:flex;align-items:center;gap:.625rem;margin-left:auto}.navbar-score{font-size:.9rem;font-weight:600;color:var(--accent);background:#f59e0b1f;border:1px solid rgba(245,158,11,.25);padding:.25rem .625rem;border-radius:20px}.navbar-avatar-link{display:flex;align-items:center;border-radius:50%;overflow:hidden;border:2px solid rgba(59,130,246,.4);transition:border-color .2s}.navbar-avatar-link:active{border-color:var(--primary)}.navbar-links{display:none}.nav-link{color:var(--text-muted);font-weight:500;font-size:.9rem;padding:.4rem .75rem;border-radius:var(--radius-sm);transition:color .2s,background .2s;white-space:nowrap}.nav-link:active,.nav-link.active{color:var(--primary);background:#3b82f61a}.navbar-user{display:none;align-items:center;gap:.625rem;margin-left:auto}.btn-icon{background:none;border:none;cursor:pointer;font-size:1.2rem;color:var(--text-muted);padding:.4rem;border-radius:8px;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center;transition:color .2s,background .2s;font-family:inherit}.btn-icon:active{color:var(--primary);background:#3b82f61a}.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:var(--bottom-nav-h);background:#0d1b2e;border-top:1px solid rgba(59,130,246,.12);display:flex;align-items:stretch;z-index:100;padding-bottom:env(safe-area-inset-bottom,0px)}.bottom-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;background:none;border:none;cursor:pointer;color:var(--text-muted);font-size:.68rem;font-weight:500;text-decoration:none;padding:.4rem .25rem;min-height:48px;transition:color .2s;-webkit-tap-highlight-color:transparent;font-family:inherit}.bottom-nav-item .nav-icon{font-size:1.35rem;line-height:1}.bottom-nav-item.active,.bottom-nav-item:active{color:var(--primary)}.bottom-nav-item.active .nav-icon{filter:drop-shadow(0 0 6px rgba(59,130,246,.7))}@media (min-width: 768px){.bottom-nav{display:none}.navbar-links{display:flex;align-items:center;gap:.25rem;flex:1;justify-content:center}.navbar-mobile-right{display:none}.navbar-user{display:flex}}.page-container{max-width:680px;margin:0 auto;padding:1.25rem 1rem;padding-top:calc(var(--navbar-h) + 1.25rem);padding-bottom:calc(var(--bottom-nav-h) + 1.5rem)}@media (min-width: 768px){.page-container{padding-bottom:2rem}}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;box-shadow:0 4px 24px #0006}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;border:none;border-radius:12px;font-weight:600;font-size:.95rem;cursor:pointer;padding:.75rem 1.25rem;min-height:48px;transition:transform .15s,opacity .2s,box-shadow .2s;text-decoration:none;white-space:nowrap;-webkit-tap-highlight-color:transparent;font-family:inherit}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.btn:active:not(:disabled){transform:scale(.97)}.btn-primary{background:linear-gradient(135deg,var(--primary-dark) 0%,var(--primary) 100%);color:#fff;box-shadow:0 4px 16px #3b82f659}.btn-primary:active:not(:disabled){box-shadow:0 2px 8px #3b82f640}.btn-outline{background:transparent;border:1px solid var(--primary);color:var(--primary)}.btn-outline:active:not(:disabled){background:#3b82f61a}.btn-danger{background:linear-gradient(135deg,#b91c1c 0%,var(--error) 100%);color:#fff;box-shadow:0 4px 16px #ef44444d}.btn-full{width:100%}.btn-sm{font-size:.8rem;padding:.4rem .8rem;min-height:36px;border-radius:8px}.btn-group{display:flex;gap:.5rem;flex-wrap:wrap}.form-group{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1rem}label{font-size:.875rem;font-weight:500;color:var(--text-muted)}input[type=text],input[type=password],input[type=email],input[type=number],textarea,.select,select{background:#ffffff0f;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:.95rem;font-family:inherit;padding:.75rem 1rem;width:100%;min-height:48px;transition:border-color .2s,box-shadow .2s;outline:none;-moz-appearance:none;appearance:none;-webkit-appearance:none}input::placeholder,textarea::placeholder{color:var(--text-muted)}input:focus,textarea:focus,select:focus,.select:focus{border-color:var(--primary);box-shadow:0 0 0 3px #3b82f633}select option{background:var(--bg-surface);color:var(--text)}.hint{font-size:.78rem;color:var(--text-muted);font-weight:400}.alert{padding:.75rem 1rem;border-radius:var(--radius-sm);font-size:.875rem;margin:.5rem 0}.alert-error{background:#ef44441f;border:1px solid rgba(239,68,68,.3);color:#fca5a5}.alert-success{background:#10b9811f;border:1px solid rgba(16,185,129,.3);color:#6ee7b7}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1rem;background:radial-gradient(ellipse at 50% 0%,rgba(37,99,235,.25) 0%,transparent 70%),linear-gradient(180deg,#0d1b2e 0%,var(--bg) 100%)}.auth-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:2rem 1.75rem;width:100%;max-width:420px;box-shadow:0 8px 48px #00000080;animation:slide-up .4s ease both}.auth-card-wide{max-width:560px}.auth-header{text-align:center;margin-bottom:1.75rem}.auth-logo{font-size:3rem;display:block;margin-bottom:.5rem}.auth-header h1{font-size:1.5rem;font-weight:700;margin-bottom:.3rem;background:linear-gradient(135deg,var(--text) 0%,var(--primary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.auth-header p{color:var(--text-muted);font-size:.9rem}.auth-form{display:flex;flex-direction:column;gap:0}.auth-footer{text-align:center;margin-top:1.25rem;font-size:.875rem;color:var(--text-muted)}.page-header{margin-bottom:1.25rem}.page-header h2{font-size:1.4rem;font-weight:700}.page-header p{color:var(--text-muted);font-size:.9rem;margin-top:.2rem}.text-muted{color:var(--text-muted)}.difficulty-badge{display:inline-block;padding:4px 10px;border-radius:20px;font-size:.75rem;font-weight:600;color:#fff;letter-spacing:.02em}.avatar-img{border-radius:50%;object-fit:cover;background:#3b82f61a;flex-shrink:0}.avatar-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:.5rem}.avatar-option{background:#ffffff0a;border:2px solid var(--border);border-radius:12px;display:flex;flex-direction:column;align-items:center;gap:4px;padding:.5rem .25rem;cursor:pointer;transition:border-color .2s,background .2s,transform .15s;min-height:48px;-webkit-tap-highlight-color:transparent;font-family:inherit}.avatar-option.selected{border-color:var(--primary);background:#3b82f61f;animation:pulse-glow 2s ease-in-out infinite}.avatar-option:active{transform:scale(.95)}.avatar-label{font-size:.65rem;color:var(--text-muted);text-align:center}.quiz-progress-bar{height:8px;background:#ffffff12;border-radius:20px;overflow:hidden;margin-bottom:.75rem}.quiz-progress-fill{height:100%;background:linear-gradient(90deg,var(--primary-dark),var(--primary),#60a5fa);border-radius:20px;transition:width .4s ease;box-shadow:0 0 10px #3b82f680}.quiz-meta{display:flex;align-items:center;gap:.5rem;margin-bottom:.875rem;flex-wrap:wrap}.quiz-counter{font-weight:700;font-size:1rem}.quiz-category-badge{background:#ffffff12;border:1px solid var(--border);border-radius:20px;padding:2px 10px;font-size:.75rem;color:var(--text-muted);flex:1;text-align:center}.quiz-score{font-size:.875rem;font-weight:600;color:var(--accent)}.quiz-card{margin-bottom:0}.quiz-card-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:.875rem}.quiz-question{font-size:1.05rem;font-weight:600;line-height:1.5;margin-bottom:1.25rem;color:var(--text)}.quiz-options{display:flex;flex-direction:column;gap:.625rem;margin-bottom:1rem}.quiz-option{background:#ffffff08;border:1px solid var(--border);border-radius:var(--radius-sm);padding:.875rem 1rem;min-height:52px;cursor:pointer;display:flex;align-items:center;gap:.75rem;text-align:left;width:100%;font-family:inherit;font-size:.92rem;color:var(--text);transition:border-color .2s,background .2s,transform .15s;-webkit-tap-highlight-color:transparent}.quiz-option:active:not(:disabled){transform:scale(.99)}.quiz-option:disabled{cursor:default}.option-letter{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:8px;background:#ffffff12;font-weight:700;font-size:.8rem;flex-shrink:0;border:1px solid var(--border)}.option-text{flex:1}.option-check,.option-x{font-size:1rem;font-weight:700;flex-shrink:0}.option-check{color:var(--success)}.option-x{color:var(--error)}.quiz-option.selected-pending{border-color:var(--primary);background:#3b82f61a;box-shadow:0 0 0 2px #3b82f640;animation:pulse-glow 1.5s ease-in-out infinite}.quiz-option.selected-pending .option-letter{background:var(--primary);border-color:var(--primary);color:#fff}.quiz-option.correct{border-color:var(--success);background:#10b9811a;box-shadow:0 0 12px #10b98133}.quiz-option.correct .option-letter{background:var(--success);border-color:var(--success);color:#fff}.quiz-option.wrong{border-color:var(--error);background:#ef444414}.quiz-option.wrong .option-letter{background:var(--error);border-color:var(--error);color:#fff}.validate-btn{width:100%;min-height:52px;background:linear-gradient(135deg,#d97706 0%,var(--accent) 100%);color:#fff;border:none;border-radius:12px;font-weight:700;font-size:1rem;cursor:pointer;margin-top:.5rem;box-shadow:0 4px 20px #f59e0b66;transition:transform .15s,box-shadow .2s;animation:bounce-in .3s ease both;font-family:inherit;-webkit-tap-highlight-color:transparent}.validate-btn:active{transform:scale(.97);box-shadow:0 2px 10px #f59e0b4d}.quiz-feedback{margin-top:.75rem;display:flex;flex-direction:column;gap:.625rem;animation:slide-up .3s ease both}.feedback-badge{padding:.625rem 1rem;border-radius:var(--radius-sm);font-weight:600;font-size:.9rem;text-align:center}.feedback-correct{background:#10b98126;border:1px solid rgba(16,185,129,.35);color:#6ee7b7}.feedback-wrong{background:#ef44441f;border:1px solid rgba(239,68,68,.3);color:#fca5a5}.quiz-explanation{background:#ffffff0a;border-left:3px solid var(--primary);border-radius:0 var(--radius-sm) var(--radius-sm) 0;padding:.75rem 1rem;font-size:.875rem;color:var(--text-muted)}.quiz-explanation strong{display:block;color:var(--text);margin-bottom:.3rem}.quiz-explanation p{margin:0}.quiz-hint{text-align:center;color:var(--text-muted);font-size:.8rem;margin-top:.5rem;opacity:.7}.quiz-result{animation:slide-up .4s ease both}.result-score{display:flex;justify-content:center;margin-bottom:1rem}.result-circle{width:120px;height:120px;border-radius:50%;background:linear-gradient(135deg,var(--primary-dark) 0%,var(--primary) 100%);box-shadow:0 0 32px #3b82f680;display:flex;flex-direction:column;align-items:center;justify-content:center;animation:bounce-in .5s .2s ease both}.result-pts{font-size:1.5rem;font-weight:800;color:#fff;line-height:1.1}.result-pts small{font-size:.65rem;font-weight:500;opacity:.8}.result-pct{font-size:.85rem;color:#ffffffbf;font-weight:600}.result-mention{text-align:center;font-size:1.25rem;font-weight:700;margin-bottom:.25rem}.result-by-diff{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.25rem;padding:1rem;background:#ffffff08;border-radius:var(--radius-sm);border:1px solid var(--border)}.diff-row{display:flex;align-items:center;gap:.625rem}.diff-score{margin-left:auto;font-weight:600;font-size:.9rem}.diff-pts{color:var(--accent);font-size:.85rem;font-weight:600;min-width:70px;text-align:right}.quiz-answers-summary{display:flex;flex-direction:column;gap:.375rem;margin-bottom:1.25rem;max-height:220px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--border) transparent}.answer-row{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;border-radius:8px;font-size:.82rem;background:#ffffff08}.answer-row.correct{border-left:3px solid var(--success)}.answer-row.wrong{border-left:3px solid var(--error)}.answer-icon{font-size:.85rem;font-weight:700;flex-shrink:0}.answer-row.correct .answer-icon{color:var(--success)}.answer-row.wrong .answer-icon{color:var(--error)}.answer-question{flex:1;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.answer-pts{font-size:.75rem;font-weight:600;flex-shrink:0}.result-actions{display:flex;flex-direction:column;gap:.625rem}.leaderboard{display:flex;flex-direction:column;gap:.5rem}.leaderboard-row{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;transition:border-color .2s}.leaderboard-self{border-color:#3b82f680;background:#3b82f60f;box-shadow:0 0 0 1px #3b82f633}.leaderboard-top{box-shadow:0 4px 16px #0000004d}.rank{min-width:36px;text-align:center;font-weight:700}.medal{font-size:1.5rem}.rank-num{color:var(--text-muted);font-size:.9rem}.leaderboard-info{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.leaderboard-pseudo{font-weight:600;font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.you-badge{font-size:.75rem;color:var(--primary);font-weight:500}.leaderboard-details{font-size:.78rem}.leaderboard-score{flex-shrink:0}.score-value{font-size:1rem;font-weight:700;color:var(--accent)}.profile-card{animation:slide-up .3s ease both}.profile-header{display:flex;flex-direction:column;align-items:center;gap:.625rem;margin-bottom:1.5rem;text-align:center}.profile-avatar-wrap{position:relative;display:inline-block}.avatar-edit-btn{position:absolute;bottom:0;right:-4px;background:var(--bg-surface);border:2px solid var(--border);border-radius:50%;width:32px;height:32px;min-width:32px;min-height:32px;font-size:.85rem;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text);transition:background .2s;font-family:inherit}.avatar-edit-btn:active{background:#3b82f626}.profile-pseudo{font-size:1.4rem;font-weight:700}.badge-admin{background:linear-gradient(135deg,var(--primary-dark),var(--primary));color:#fff;font-size:.75rem;font-weight:600;padding:3px 10px;border-radius:20px}.profile-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;margin-bottom:1.25rem}.stat{background:#ffffff0a;border:1px solid var(--border);border-radius:var(--radius-sm);padding:.875rem .5rem;display:flex;flex-direction:column;align-items:center;gap:4px;text-align:center}.stat-value{font-size:1.1rem;font-weight:700;color:var(--accent)}.stat-label{font-size:.72rem;color:var(--text-muted)}.avatar-editor{margin-top:1.25rem;padding-top:1.25rem;border-top:1px solid var(--border)}.avatar-editor h3{font-size:1rem;margin-bottom:1rem}.avatar-editor-actions{display:flex;gap:.625rem;margin-top:1rem}.revision-start-bar{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;gap:1rem;flex-wrap:wrap}.revision-list{display:flex;flex-direction:column;gap:.875rem}.revision-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;box-shadow:0 2px 12px #0000004d}.revision-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem;gap:.5rem;flex-wrap:wrap}.q-category-badge{background:#3b82f61f;border:1px solid rgba(59,130,246,.25);color:var(--primary);font-size:.75rem;font-weight:600;padding:3px 10px;border-radius:20px}.revision-error-count{font-size:.75rem;color:#fca5a5;font-weight:600}.revision-question{font-weight:600;font-size:.95rem;margin-bottom:.875rem;color:var(--text);line-height:1.5}.revision-options{display:flex;flex-direction:column;gap:.375rem}.revision-option{display:flex;align-items:center;gap:.625rem;padding:.5rem .75rem;border-radius:8px;font-size:.875rem;background:#ffffff08;color:var(--text-muted)}.revision-option-correct{background:#10b9811a;color:var(--text);font-weight:600}.correct-tag{margin-left:auto;font-size:.75rem;color:var(--success);font-weight:600;flex-shrink:0}.empty-state{text-align:center;padding:2rem 1rem;color:var(--text-muted);display:flex;flex-direction:column;align-items:center;gap:.5rem}.loading-spinner{width:36px;height:36px;border:3px solid rgba(59,130,246,.2);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite;margin:2rem auto}
