:root{--blue:#0077b6;--blue-light:#00b4d8;--blue-dark:#005f8a;--blue-bg:#0077b614;--blue-bg2:#0077b626;--red:#c8102e;--red-light:#e63946;--red-bg:#c8102e14;--bg:#f0f4f8;--surface:#fff;--text:#1a2a3a;--text-secondary:#5a6a7a;--border:#00285014}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;font-size:16px}body{background:var(--bg);color:var(--text);-webkit-tap-highlight-color:transparent;min-height:100dvh;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;position:relative;overflow-x:hidden}body:before{content:"";pointer-events:none;z-index:0;background:radial-gradient(80% 60% at 50% -10%,#0077b612 0%,#0000 60%),radial-gradient(60% 50% at 80% 90%,#c8102e0a 0%,#0000 50%);position:fixed;inset:0}button{cursor:pointer;color:inherit;background:0 0;border:none;font-family:inherit}img{max-width:100%}a{color:inherit;text-decoration:none}.hidden{display:none!important}.text-gradient{background:linear-gradient(135deg, var(--blue), var(--blue-light));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.screen{min-height:100dvh;padding-bottom:80px;display:none;position:relative}.screen.active{animation:.35s fadeUp;display:block}@keyframes fadeUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.bottom-nav{z-index:100;-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--border);padding:6px 0 env(safe-area-inset-bottom,8px);background:#fffffff2;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -2px 20px #0028500f}.bnav-item{letter-spacing:.02em;color:var(--text-secondary);flex-direction:column;flex:1;align-items:center;gap:2px;padding:8px 0;font-size:.65rem;font-weight:500;transition:color .2s;display:flex}.bnav-item svg{width:22px;height:22px;transition:transform .2s}.bnav-item.active{color:var(--blue)}.bnav-item.active svg{transform:scale(1.12)}.bottom-nav.hidden-nav{transform:translateY(100%)}.login-scroll{flex-direction:column;min-height:100vh;padding:0 20px;display:flex}.scroll-hint-wrap{text-align:center;color:var(--blue);opacity:.6;flex-direction:column;align-items:center;gap:6px;padding:10px 0 30px;animation:2s infinite bounceDown;display:flex}.scroll-hint-wrap span{text-transform:uppercase;letter-spacing:.1em;font-size:.7rem;font-weight:700}.scroll-hint-wrap svg{width:20px;height:20px}@keyframes bounceDown{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(6px)}60%{transform:translateY(3px)}}.login-header{text-align:center;margin-bottom:32px}.login-header .main-logo{mix-blend-mode:multiply;width:130px;margin:0 auto 5px}.login-subtitle{color:var(--text-secondary);margin-top:8px;font-size:.85rem;line-height:1.4}.login-form{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:24px 20px;box-shadow:0 4px 20px #00285014}.input-group{flex-direction:column;gap:6px;margin-bottom:16px;display:flex}.input-group label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;font-size:.8rem;font-weight:600}.custom-input{background:var(--bg);border:1px solid var(--border);width:100%;color:var(--text);border-radius:12px;outline:none;padding:14px 16px;font-size:.95rem;transition:all .2s}.custom-input:focus{border-color:var(--blue);box-shadow:0 0 0 3px #0077b626}.custom-input::placeholder{color:#a0aec0}.login-options{flex-direction:column;gap:8px;margin-top:-4px;margin-bottom:20px;display:flex}.checkbox-label{color:var(--text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:10px;padding:4px 0;font-size:.85rem;display:inline-flex}.checkbox-label input[type=checkbox]{width:18px;height:18px;accent-color:var(--blue);cursor:pointer;border:2px solid var(--border);border-radius:6px}.forgot-password-link{width:fit-content;color:var(--blue);cursor:pointer;background:0 0;border:none;padding:0;font-family:inherit;font-size:.82rem;font-weight:600;text-decoration:none;transition:color .2s,opacity .2s;display:inline}.forgot-password-link:hover{color:var(--blue-dark);text-underline-offset:3px;text-decoration:underline}.forgot-password-link:active{opacity:.7}.login-actions{flex-direction:column;gap:10px;margin-top:10px;display:flex}.login-error{color:var(--red);text-align:center;background:var(--red-bg);border-radius:8px;margin-top:16px;padding:10px;font-size:.8rem}.login-success{color:#059669;text-align:center;background:#10b98114;border:1px solid #10b98133;border-radius:8px;margin-top:16px;padding:10px;font-size:.8rem}.login-seo-text{text-align:left;background:var(--surface);border:1px solid var(--border);border-radius:20px;margin-bottom:32px;padding:24px;animation:.8s .2s backwards fadeUp;box-shadow:0 4px 24px #0028500a}.login-seo-text h2{color:var(--blue-dark);margin-bottom:12px;font-size:1.15rem;font-weight:800;line-height:1.3}.login-seo-text h3{color:var(--text);margin-top:20px;margin-bottom:10px;font-size:.95rem;font-weight:700}.login-seo-text p{color:var(--text-secondary);margin-bottom:14px;font-size:.88rem;line-height:1.6}.login-seo-text strong{color:var(--blue);font-weight:700}.seo-features-grid{background:var(--bg);border:1px solid #0077b60d;border-radius:14px;margin:18px 0;padding:16px}.seo-features-grid .features-title{color:var(--blue);text-transform:uppercase;letter-spacing:.05em;margin-bottom:10px;font-size:.82rem;font-weight:800;display:block}.seo-features-list{color:var(--text);grid-template-columns:repeat(2,1fr);gap:8px;font-size:.8rem;font-weight:500;list-style:none;display:grid}.seo-features-list li{align-items:center;gap:6px;display:flex}.seo-tags{flex-wrap:wrap;gap:8px;margin-top:12px;display:flex}.seo-tag{color:var(--blue-dark);background:#0077b614;border:1px solid #0077b61a;border-radius:10px;padding:5px 12px;font-size:.75rem;font-weight:600}.home-scroll{padding:0 20px}.home-spacer{height:24px}.home-header{padding-top:max(env(safe-area-inset-top,50px), 50px);text-align:center;margin-bottom:24px;position:relative}.header-actions{top:max(env(safe-area-inset-top,16px), 16px);gap:8px;display:flex;position:absolute;right:20px}.main-logo{mix-blend-mode:multiply;width:150px;max-width:100%;height:auto;margin:0 auto 5px;animation:.5s fadeUp;display:block}.main-title{color:var(--text);letter-spacing:-.02em;font-size:2rem;font-weight:800;animation:.6s fadeUp}.contact-email{color:var(--blue);text-underline-offset:3px;margin-top:4px;font-size:.8rem;font-weight:600;text-decoration:underline;transition:color .2s;animation:.6s fadeUp;display:inline-block}.contact-email:hover{color:var(--blue-dark)}.quick-stats{grid-template-columns:repeat(3,1fr);gap:10px;margin:24px 0;display:grid}.qs-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;flex-direction:column;align-items:center;gap:8px;padding:16px 8px;transition:transform .2s,background .2s;display:flex;box-shadow:0 2px 12px #0028500f}.qs-card:active{transform:scale(.97)}.qs-icon{border-radius:12px;justify-content:center;align-items:center;width:38px;height:38px;display:flex}.qs-icon svg{width:20px;height:20px}.qs-purple{background:var(--blue-bg2);color:var(--blue)}.qs-green{color:#059669;background:#10b9811f}.qs-orange{color:#d97706;background:#f59e0b1f}.qs-data{flex-direction:column;align-items:center;display:flex}.qs-value{color:var(--text);font-size:1.25rem;font-weight:700}.qs-label{color:var(--text-secondary);font-size:.7rem}.section{margin-bottom:28px}.section-header{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.section-title{color:var(--text);font-size:1.1rem;font-weight:700}.section-count{color:var(--text-secondary);font-size:.75rem}.action-card{text-align:left;border:1px solid var(--border);background:var(--surface);border-radius:16px;align-items:center;gap:14px;width:100%;margin-bottom:10px;padding:16px;transition:transform .2s,box-shadow .2s;display:flex;box-shadow:0 2px 12px #0028500d}.action-card:active{transform:scale(.98)}.action-icon-wrap{border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.action-icon-wrap svg{width:22px;height:22px}.action-info{flex:1}.action-title{color:var(--text);margin-bottom:2px;font-size:.95rem;font-weight:600;display:block}.action-desc{color:var(--text-secondary);font-size:.75rem;line-height:1.3;display:block}.action-arrow{color:#00285033;flex-shrink:0;width:18px;height:18px}.action-primary{background:var(--surface)}.action-primary .action-icon-wrap{background:var(--blue-bg2);color:var(--blue)}.action-study{background:var(--surface)}.action-study .action-icon-wrap{color:#059669;background:#10b9811f}.action-exam{background:var(--surface)}.action-exam .action-icon-wrap{color:var(--red);background:#c8102e1a}.action-failed{background:var(--surface)}.action-failed .action-icon-wrap{color:#d97706;background:#f59e0b1f}.action-osakidetza{background:linear-gradient(135deg,#00945e0f,#00945e1f);border-color:#00945e40}.action-osakidetza .action-icon-wrap{color:#00945e;background:#00945e26}.osakidetza-title{letter-spacing:.12em;font-weight:700;color:#00945e!important;font-family:Oswald,sans-serif!important;font-size:1.1rem!important}.action-osakidetza .action-desc{color:#065f46}.action-osakidetza .action-arrow{color:#00945e59}.topics-list{flex-direction:column;gap:8px;display:flex}.topic-card{text-align:left;background:var(--surface);border:1px solid var(--border);border-radius:14px;align-items:center;gap:14px;width:100%;padding:14px 16px;transition:transform .15s,background .15s;display:flex}.topic-card:active{background:#e8f0f8;transform:scale(.98)}.topic-emoji{text-align:center;flex-shrink:0;width:40px;font-size:1.5rem}.topic-info{flex:1;min-width:0}.topic-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:.85rem;font-weight:600;display:block;overflow:hidden}.topic-count{color:var(--text-secondary);margin-top:2px;font-size:.7rem;display:block}.topic-progress-bar{background:#0077b61a;border-radius:4px;width:100%;height:4px;margin-top:6px;overflow:hidden}.topic-progress-fill{background:linear-gradient(90deg, var(--blue), var(--blue-light));border-radius:4px;height:100%;transition:width .4s}.topic-arrow{color:#00285033;flex-shrink:0;width:16px;height:16px}.topic-arrow svg{width:16px;height:16px}.config-scroll{padding:0 20px}.screen-topbar{padding:max(env(safe-area-inset-top,12px), 12px) 0 12px;z-index:10;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#f0f4f8e6;align-items:center;gap:12px;display:flex;position:sticky;top:0}.topbar-back{background:var(--surface);border:1px solid var(--border);cursor:pointer;border-radius:12px;justify-content:center;align-items:center;width:40px;height:40px;transition:background .15s;display:flex}.topbar-back:active{background:#e0e8f0}.topbar-back svg{width:20px;height:20px;color:var(--text);pointer-events:none}.topbar-title{color:var(--text);font-size:1rem;font-weight:600}.topbar-spacer{flex:1}.config-hero{text-align:center;padding:20px 0 28px}.config-emoji{margin-bottom:12px;font-size:3rem;display:block}.config-heading{color:var(--text);font-size:1.35rem;font-weight:800}.config-sub{color:var(--text-secondary);margin-top:4px;font-size:.85rem}.config-body{margin-bottom:32px}.config-group{margin-bottom:24px}.config-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;margin-bottom:10px;font-size:.8rem;font-weight:600;display:block}.custom-select{background:var(--surface);border:1px solid var(--border);width:100%;color:var(--text);appearance:none;background-image:url(data:image/svg+xml;charset=US-ASCII,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%22292.4%22%20height%3D%22292.4%22%3E%3Cpath%20fill%3D%22%231a2a3a%22%20d%3D%22M287%2069.4a17.6%2017.6%200%200%200-13-5.4H18.4c-5%200-9.3%201.8-12.9%205.4A17.6%2017.6%200%200%200%200%2082.2c0%205%201.8%209.3%205.4%2012.9l128%20127.9c3.6%203.6%207.8%205.4%2012.8%205.4s9.2-1.8%2012.8-5.4L287%2095c3.5-3.5%205.4-7.8%205.4-12.8%200-5-1.9-9.2-5.5-12.8z%22%2F%3E%3C%2Fsvg%3E);background-position:right 14px top 50%;background-repeat:no-repeat;background-size:10px;border-radius:12px;outline:none;padding:14px 16px;font-family:inherit;font-size:.9rem;font-weight:500;transition:all .2s}.custom-select:focus{border-color:var(--blue);box-shadow:0 0 0 3px #0077b626}.custom-select option{color:var(--text);background-color:#fff;font-weight:500}.chip-group{flex-wrap:wrap;gap:8px;display:flex}.chip{background:var(--surface);border:1px solid var(--border);color:var(--text-secondary);border-radius:12px;padding:10px 18px;font-size:.82rem;font-weight:600;transition:all .2s}.chip:active{transform:scale(.96)}.chip.selected{background:var(--blue-bg2);border-color:var(--blue);color:var(--blue-dark);box-shadow:0 0 20px #0077b61a}.config-footer{padding-bottom:100px}.btn-admin,.btn-logout,.btn-install-app{border-radius:8px;align-items:center;gap:4px;padding:6px 10px;font-size:.75rem;font-weight:600;transition:all .2s;display:inline-flex}.btn-admin{color:#8a2be2;background:#8a2be226}.btn-admin:hover{background:#8a2be240}.btn-install-app{color:var(--blue-dark);background:#0077b626}.btn-install-app:hover{background:#0077b640}.btn-install-app svg{width:14px;height:14px}.btn-logout{background:var(--red-bg);color:var(--red)}.btn-logout:hover{background:#c8102e26}.btn-logout svg{width:14px;height:14px}.btn-primary{background:linear-gradient(135deg, var(--blue), var(--blue-dark));color:#fff;border-radius:14px;justify-content:center;align-items:center;gap:8px;width:100%;padding:14px 28px;font-size:.92rem;font-weight:700;transition:transform .15s,box-shadow .15s;display:inline-flex;box-shadow:0 4px 24px #0077b640}.btn-primary svg{width:20px;height:20px}.btn-primary:active{transform:scale(.97)}.btn-lg{border-radius:16px;padding:16px 32px;font-size:1rem}.btn-glass{background:var(--surface);border:1px solid var(--border);color:var(--text);border-radius:14px;justify-content:center;align-items:center;gap:8px;width:100%;padding:13px 24px;font-size:.88rem;font-weight:600;transition:transform .15s,background .15s;display:inline-flex}.btn-glass svg{width:18px;height:18px}.btn-glass:active{background:#e8f0f8;transform:scale(.97)}.btn-danger-sm{color:var(--red);background:#c8102e0f;border:1px solid #c8102e26;border-radius:10px;justify-content:center;align-items:center;gap:6px;width:100%;padding:10px 20px;font-size:.8rem;font-weight:600;transition:background .15s;display:inline-flex}.btn-danger-sm svg{width:16px;height:16px}.btn-danger-sm:active{background:#c8102e1f}.test-scroll{padding:0 20px}.test-topbar{padding:max(env(safe-area-inset-top,12px), 12px) 0 8px;z-index:150;-webkit-backdrop-filter:blur(12px);background:#f0f4f8eb;justify-content:space-between;align-items:center;display:flex;position:sticky;top:0;transform:translateZ(0)}.test-topbar-info{align-items:center;display:flex}.test-counter{color:var(--text);font-size:.85rem;font-weight:700}.test-timer{background:var(--blue-bg2);color:var(--blue);border-radius:10px;align-items:center;gap:5px;padding:6px 12px;font-size:.82rem;font-weight:600;display:flex}.test-timer svg{width:15px;height:15px}.test-timer.warning{color:#d97706;background:#f59e0b1f}.test-timer.danger{color:var(--red);background:#c8102e1a;animation:1s infinite timerPulse}@keyframes timerPulse{50%{opacity:.6}}.test-progress{background:#0077b61a;border-radius:4px;height:4px;margin:4px 0 20px;overflow:hidden}.test-progress-fill{background:linear-gradient(90deg, var(--blue), var(--blue-light));border-radius:4px;height:100%;transition:width .3s}.question-container{min-height:50vh}.question-card{background:var(--surface);border:1px solid var(--border);border-radius:18px;margin-bottom:16px;padding:24px 20px;box-shadow:0 2px 12px #0028500f}.question-number{text-transform:uppercase;letter-spacing:.08em;color:var(--blue);margin-bottom:10px;font-size:.7rem;font-weight:700;display:inline-block}.question-text{color:var(--text);font-size:.95rem;font-weight:500;line-height:1.55}.options-list{flex-direction:column;gap:8px;margin-bottom:16px;display:flex}.option-btn{text-align:left;background:var(--surface);border:1.5px solid var(--border);border-radius:14px;align-items:flex-start;gap:12px;width:100%;padding:14px 16px;transition:all .2s;display:flex}.option-btn:active{transform:scale(.98)}.option-letter{width:28px;height:28px;color:var(--text-secondary);background:#edf2f7;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;font-size:.75rem;font-weight:700;transition:all .2s;display:flex}.option-text{color:var(--text);padding-top:3px;font-size:.85rem;line-height:1.45;transition:color .2s}.option-btn.selected{background:var(--blue-bg);border-color:var(--blue)}.option-btn.selected .option-letter{background:var(--blue);color:#fff}.option-btn.selected .option-text{color:var(--blue-dark)}.option-btn.correct{background:#10b98114;border-color:#10b98166}.option-btn.correct .option-letter{color:#fff;background:#10b981}.option-btn.correct .option-text{color:#065f46}.option-btn.wrong{background:#c8102e0f;border-color:#c8102e4d}.option-btn.wrong .option-letter{background:var(--red);color:#fff}.option-btn.wrong .option-text{color:#991b1b}.option-btn.disabled{pointer-events:none;opacity:.5}.option-btn.correct.disabled,.option-btn.wrong.disabled{opacity:1}.feedback-card{background:#34d39914;border:1px solid #34d39933;border-radius:14px;margin-bottom:16px;padding:16px;animation:.3s fadeUp}.feedback-card.wrong-fb{background:#ef444414;border-color:#ef444433}.feedback-icon{margin-bottom:6px;font-size:1.5rem}.feedback-meta{color:var(--blue);letter-spacing:.02em;background:#0077b614;border-radius:6px;margin-bottom:6px;padding:4px 10px;font-size:.72rem;font-weight:600;display:inline-block}.feedback-card.wrong-fb .feedback-meta{color:#991b1b;background:#c8102e14}.feedback-text{color:var(--text-secondary);font-size:.82rem;line-height:1.5}.btn-report-error{color:#b45309;cursor:pointer;background:#f59e0b14;border:1px solid #f59e0b33;border-radius:10px;align-items:center;gap:6px;margin-bottom:12px;padding:7px 14px;font-family:inherit;font-size:.75rem;font-weight:600;transition:all .2s;display:inline-flex}.btn-report-error svg{width:14px;height:14px}.btn-report-error:active{background:#f59e0b26;transform:scale(.96)}.report-panel{background:var(--surface);border:1px solid #f59e0b40;border-radius:16px;margin-bottom:16px;padding:16px;animation:.3s fadeUp;box-shadow:0 4px 16px #f59e0b14}.report-panel-header{color:var(--text);justify-content:space-between;align-items:center;margin-bottom:10px;font-size:.85rem;font-weight:700;display:flex}.report-close{cursor:pointer;width:28px;height:28px;color:var(--text-secondary);background:#0000000a;border:none;border-radius:8px;justify-content:center;align-items:center;font-size:.9rem;transition:background .15s;display:flex}.report-close:active{background:#0000001a}.report-context{color:var(--text-secondary);background:var(--bg);border-radius:8px;margin-bottom:10px;padding:6px 10px;font-size:.72rem;font-weight:600;line-height:1.4}.report-textarea{border:1px solid var(--border);background:var(--bg);width:100%;color:var(--text);resize:vertical;border-radius:12px;outline:none;min-height:70px;max-height:150px;margin-bottom:12px;padding:12px 14px;font-family:inherit;font-size:.85rem;transition:border-color .2s,box-shadow .2s}.report-textarea:focus{border-color:#f59e0b;box-shadow:0 0 0 3px #f59e0b1f}.report-textarea::placeholder{color:#a0aec0}.report-actions{display:flex}.btn-report-send{color:#fff;cursor:pointer;background:linear-gradient(135deg,#f59e0b,#d97706);border:none;border-radius:12px;justify-content:center;align-items:center;gap:8px;width:100%;padding:12px 20px;font-family:inherit;font-size:.85rem;font-weight:700;transition:transform .15s,box-shadow .15s;display:inline-flex;box-shadow:0 4px 14px #f59e0b40}.btn-report-send svg{width:16px;height:16px}.btn-report-send:active{transform:scale(.97)}.btn-report-send:disabled{opacity:.6;cursor:not-allowed}.report-status{text-align:center;border-radius:8px;margin-top:10px;padding:8px 12px;font-size:.8rem;line-height:1.4}.report-status.success{color:#059669;background:#10b98114;border:1px solid #10b98133}.report-status.error{color:var(--red);background:var(--red-bg)}.test-nav{z-index:5;justify-content:space-between;align-items:center;gap:12px;padding:12px 0;display:flex;position:sticky;bottom:80px}.btn-nav{background:var(--surface);border:1px solid var(--border);width:48px;height:48px;color:var(--text);border-radius:14px;justify-content:center;align-items:center;transition:all .15s;display:flex}.btn-nav:disabled{opacity:.25}.btn-nav svg{width:22px;height:22px}.btn-nav:active:not(:disabled){background:#e8f0f8;transform:scale(.93)}.btn-nav-next{background:var(--blue-bg2);border-color:var(--blue);color:var(--blue)}.question-dots{flex-wrap:wrap;flex:1;justify-content:center;gap:4px;max-height:48px;display:flex;overflow:hidden}.q-dot{cursor:pointer;background:#0077b61f;border-radius:50%;width:8px;height:8px;transition:all .2s}.q-dot.current{background:var(--blue);transform:scale(1.3)}.q-dot.answered{background:#0077b659}.q-dot.correct-dot{background:#10b981}.q-dot.wrong-dot{background:var(--red)}.test-finish-wrap{padding:8px 0 20px}.btn-finish{color:#fff;background:linear-gradient(135deg,#10b981,#34d399);border-radius:14px;width:100%;padding:14px;font-size:.92rem;font-weight:700;transition:transform .15s;box-shadow:0 4px 20px #10b98140}.btn-finish:active{transform:scale(.97)}.results-scroll{padding:0 20px}.results-top{text-align:center;padding:max(env(safe-area-inset-top,40px), 40px) 0 20px}.results-emoji{margin-bottom:12px;font-size:3.5rem;animation:.5s bounceIn}@keyframes bounceIn{0%{transform:scale(0)}60%{transform:scale(1.15)}to{transform:scale(1)}}.results-title{color:var(--text);font-size:1.4rem;font-weight:800}.score-ring-wrap{width:160px;height:160px;margin:24px auto;position:relative}.score-ring{width:100%;height:100%;transform:rotate(-90deg)}.ring-bg{fill:none;stroke:#0077b61a;stroke-width:8px}.ring-fill{fill:none;stroke:url(#ringGrad);stroke-width:8px;stroke-linecap:round;stroke-dasharray:364.42;stroke-dashoffset:364.42px;transition:stroke-dashoffset 1.2s}.ring-center{flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.ring-value{color:var(--text);font-size:2.2rem;font-weight:900}.ring-label{color:var(--text-secondary);font-size:.75rem}.result-cards{grid-template-columns:repeat(4,1fr);gap:8px;margin:20px 0;display:grid}.rc{background:var(--surface);border:1px solid var(--border);border-radius:14px;flex-direction:column;align-items:center;gap:4px;padding:14px 6px;display:flex;box-shadow:0 2px 8px #0028500d}.rc-val{color:var(--text);font-size:1.15rem;font-weight:700}.rc-lbl{color:var(--text-secondary);text-align:center;font-size:.6rem}.rc-correct .rc-val{color:#059669}.rc-wrong .rc-val{color:var(--red)}.rc-skip .rc-val{color:#d97706}.rc-time .rc-val{color:var(--blue)}.result-note{text-align:center;color:var(--text-secondary);background:var(--blue-bg);border-radius:12px;margin-bottom:20px;padding:12px 16px;font-size:.82rem;line-height:1.4}.result-actions{flex-direction:column;gap:10px;margin-bottom:24px;display:flex}.review-heading{color:var(--text);border-top:1px solid var(--border);margin-bottom:16px;padding-top:12px;font-size:1rem;font-weight:700}.review-list{flex-direction:column;gap:16px;padding-bottom:100px;display:flex}.review-item{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:16px;box-shadow:0 2px 8px #0028500d}.review-q-num{color:var(--blue);text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px;font-size:.7rem;font-weight:700}.review-q-text{color:var(--text);margin-bottom:12px;font-size:.85rem;line-height:1.4}.review-option{border-radius:9px;align-items:flex-start;gap:8px;margin-bottom:4px;padding:8px 12px;font-size:.8rem;display:flex}.review-option .opt-letter{width:22px;height:22px;color:var(--text-secondary);background:#edf2f7;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;font-size:.65rem;font-weight:700;display:flex}.review-option.r-correct{background:#10b98114}.review-option.r-correct .opt-letter{color:#fff;background:#10b981}.review-option.r-wrong{background:#c8102e0f}.review-option.r-wrong .opt-letter{background:var(--red);color:#fff}.review-option.r-user{border:1px solid #0077b64d}.stats-scroll{padding:0 20px}.stats-hero{justify-content:center;padding:20px 0;display:flex}.stats-ring-wrap{width:120px;height:120px;position:relative}.stats-ring{width:100%;height:100%;transform:rotate(-90deg)}.sring-bg{fill:none;stroke:#0077b61a;stroke-width:7px}.sring-fill{fill:none;stroke:var(--blue);stroke-width:7px;stroke-linecap:round;stroke-dasharray:263.89;stroke-dashoffset:263.89px;transition:stroke-dashoffset 1s}.sring-center{flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.sring-val{color:var(--text);font-size:1.5rem;font-weight:800}.sring-lbl{color:var(--text-secondary);font-size:.65rem}.s-cards{grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:28px;display:grid}.s-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;flex-direction:column;align-items:center;gap:3px;padding:14px 6px;display:flex;box-shadow:0 2px 8px #0028500d}.s-val{color:var(--text);font-size:1.1rem;font-weight:700}.s-lbl{color:var(--text-secondary);font-size:.6rem}.stats-section-title{color:var(--text);margin-bottom:12px;font-size:.9rem;font-weight:700}.stats-topics{margin-bottom:28px}.st-row{border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:12px 0;display:flex}.st-emoji{text-align:center;width:32px;font-size:1.2rem}.st-info{flex:1}.st-name{color:var(--text);font-size:.8rem;font-weight:600;display:block}.st-bar{background:#0077b61a;border-radius:4px;height:4px;margin-top:5px}.st-bar-fill{background:linear-gradient(90deg, var(--blue), var(--blue-light));border-radius:4px;height:100%;transition:width .5s}.st-pct{color:var(--blue);text-align:right;min-width:36px;font-size:.8rem;font-weight:700}.stats-history{margin-bottom:28px}.sh-row{background:var(--surface);border:1px solid var(--border);border-radius:12px;justify-content:space-between;align-items:center;margin-bottom:6px;padding:12px 14px;display:flex;box-shadow:0 2px 8px #0028500a}.sh-left{flex-direction:column;display:flex}.sh-topic{color:var(--text);font-size:.8rem;font-weight:600}.sh-date{color:var(--text-secondary);margin-top:2px;font-size:.65rem}.sh-score{border-radius:8px;padding:4px 10px;font-size:.85rem;font-weight:700}.sh-score.good{color:#34d399;background:#34d3991f}.sh-score.avg{color:#fbbf24;background:#fbbf241f}.sh-score.bad{color:#f87171;background:#ef44441f}.stats-empty{text-align:center;color:var(--text-secondary);padding:32px 16px;font-size:.85rem}.dialog-container{z-index:200;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#0009;justify-content:center;align-items:center;padding:20px;animation:.2s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.dialog-box{background:var(--surface);border:1px solid var(--border);text-align:center;border-radius:20px;width:100%;max-width:340px;padding:28px 24px 20px;animation:.25s scaleIn;box-shadow:0 8px 40px #00285026}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.dialog-box h3{color:var(--text);margin-bottom:8px;font-size:1.1rem;font-weight:700}.dialog-box p{color:var(--text-secondary);margin-bottom:20px;font-size:.85rem;line-height:1.4}.dialog-btns{gap:10px;display:flex}.dialog-btns button{flex:1}.topics-scroll{padding:0 20px}.topics-subtitle{color:var(--text-secondary);text-align:center;margin-bottom:20px;font-size:.85rem}.accordion-list{flex-direction:column;gap:8px;display:flex}.accordion-item{background:var(--surface);border:1px solid var(--border);border-radius:16px;transition:border-color .3s,background .3s;overflow:hidden;box-shadow:0 2px 8px #0028500a}.accordion-item.open{background:var(--surface);border-color:#0077b64d;box-shadow:0 4px 16px #0077b61a}.accordion-header{text-align:left;justify-content:space-between;align-items:center;width:100%;padding:14px 16px;transition:background .15s;display:flex}.accordion-header:active{background:#0077b60a}.accordion-header-left{flex:1;align-items:center;gap:12px;min-width:0;display:flex}.accordion-emoji{text-align:center;flex-shrink:0;width:36px;font-size:1.4rem}.accordion-header-info{flex:1;min-width:0}.accordion-title{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:.85rem;font-weight:600;display:block;overflow:hidden}.accordion-meta{color:var(--text-secondary);margin-top:2px;font-size:.7rem;display:block}.accordion-chevron{color:#00285040;flex-shrink:0;width:18px;height:18px;transition:transform .3s}.accordion-item.open .accordion-chevron{color:var(--blue);transform:rotate(180deg)}.accordion-body{max-height:0;padding:0 16px;transition:max-height .35s,padding .35s;overflow:hidden}.accordion-item.open .accordion-body{max-height:320px;padding:0 16px 16px}.accordion-desc{color:var(--text-secondary);border-top:1px solid var(--border);margin-bottom:14px;padding-top:4px;font-size:.8rem;line-height:1.4}.accordion-stats-row{grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:12px;display:grid}.accordion-stat{background:var(--blue-bg);border-radius:10px;flex-direction:column;align-items:center;gap:2px;padding:10px 6px;display:flex}.accordion-stat-val{color:var(--text);font-size:.95rem;font-weight:700}.accordion-stat-lbl{color:var(--text-secondary);font-size:.6rem}.accordion-progress{background:#0077b61a;border-radius:4px;height:4px;margin-bottom:14px;overflow:hidden}.accordion-progress-fill{background:linear-gradient(90deg, var(--blue), var(--blue-light));border-radius:4px;height:100%;transition:width .4s}.accordion-start-btn{padding:13px 20px!important;font-size:.88rem!important}.topic-checkbox{background:#0077b60a;border:2px solid #0077b640;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;transition:all .25s cubic-bezier(.34,1.56,.64,1);display:flex}.topic-checkbox .check-icon{opacity:0;color:#fff;width:14px;height:14px;transition:all .25s cubic-bezier(.34,1.56,.64,1);transform:scale(.3)}.topic-checkbox.checked{background:var(--blue);border-color:var(--blue);box-shadow:0 2px 8px #0077b64d}.topic-checkbox.checked .check-icon{opacity:1;transform:scale(1)}.accordion-item:has(.topic-checkbox.checked){background:linear-gradient(135deg,#0077b608,#00b4d805);border-color:#0077b659;box-shadow:0 2px 12px #0077b614}.btn-select-all{background:var(--blue-bg);color:var(--blue);cursor:pointer;white-space:nowrap;border:1.5px solid #0077b633;border-radius:10px;flex-shrink:0;padding:6px 14px;font-family:inherit;font-size:.72rem;font-weight:700;transition:all .2s}.btn-select-all:active{background:#0077b61f;transform:scale(.95)}.btn-start-study{z-index:100;background:linear-gradient(135deg, var(--blue), #00b4d8);color:#fff;cursor:pointer;white-space:nowrap;opacity:0;pointer-events:none;border:none;border-radius:50px;justify-content:center;align-items:center;gap:10px;max-width:calc(100% - 40px);padding:16px 32px;font-family:inherit;font-size:.92rem;font-weight:700;transition:all .35s cubic-bezier(.34,1.56,.64,1);display:flex;position:fixed;bottom:80px;left:50%;transform:translate(-50%)translateY(100px);box-shadow:0 8px 32px #0077b659,0 2px 8px #0000001a}.btn-start-study svg{flex-shrink:0;width:18px;height:18px}.btn-start-study.visible{opacity:1;pointer-events:auto;transform:translate(-50%)translateY(0)}.btn-start-study:active{transform:translate(-50%)scale(.96)}.btn-start-study:hover{box-shadow:0 10px 40px #0077b673,0 4px 12px #0000001a}.swipe-hint{opacity:0;justify-content:center;margin-bottom:-10px;transition:all .5s;display:flex;transform:translateY(-10px)}.swipe-hint-inner{background:var(--blue-bg2);color:var(--blue);border-radius:20px;align-items:center;gap:8px;padding:6px 14px;font-size:.7rem;font-weight:600;display:flex}.swipe-hint-inner svg{width:14px;height:14px;animation:1.5s infinite swipeAnim}@keyframes swipeAnim{0%{transform:translate(-3px)}50%{transform:translate(3px)}to{transform:translate(-3px)}}.anim-slide-out-left{animation:.3s forwards slideOutLeft}.anim-slide-in-right{animation:.3s forwards slideInRight}.anim-slide-out-right{animation:.3s forwards slideOutRight}.anim-slide-in-left{animation:.3s forwards slideInLeft}@keyframes slideOutLeft{to{opacity:0;transform:translate(-20%)}}@keyframes slideInRight{0%{opacity:0;transform:translate(20%)}to{opacity:1;transform:translate(0)}}@keyframes slideOutRight{to{opacity:0;transform:translate(20%)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-20%)}to{opacity:1;transform:translate(0)}}@media (width>=640px){.home-scroll,.topics-scroll,.config-scroll,.test-scroll,.results-scroll,.stats-scroll{max-width:600px;margin:0 auto}.hero-title{font-size:2.2rem}.result-cards{gap:12px}.quick-stats{gap:14px}}@media (width>=1024px){.home-scroll,.topics-scroll,.config-scroll,.test-scroll,.results-scroll,.stats-scroll{max-width:680px}.bottom-nav{border-top:none;border-right:1px solid var(--border);flex-direction:column;width:72px;height:100dvh;padding:16px 0;inset:0 auto auto 0}.bnav-item{padding:16px 0}.screen{padding-bottom:20px;padding-left:72px}.test-nav{bottom:20px}}.login-legal-note{color:var(--text-secondary);text-align:center;margin-top:14px;font-size:.75rem;line-height:1.5}.login-legal-note a{color:var(--blue);text-underline-offset:2px;text-decoration:underline}.login-legal-note a:hover{color:var(--blue-dark)}.grace-banner{color:var(--text-secondary);text-align:center;background:linear-gradient(135deg,#0077b614,#00b4d814);border:1px solid #0077b626;border-radius:14px;flex-wrap:wrap;justify-content:center;align-items:center;gap:6px;margin-bottom:12px;padding:10px 16px;font-size:.82rem;font-weight:500;animation:.4s fadeUp;display:flex}.grace-banner.hidden{display:none!important}.grace-banner strong{color:var(--blue)}.grace-banner.grace-urgent{background:linear-gradient(135deg,#f59e0b14,#c8102e0f);border-color:#f59e0b40}.grace-banner.grace-urgent strong{color:#d97706}.grace-login-link{color:var(--blue);cursor:pointer;text-underline-offset:3px;background:0 0;border:none;padding:0;font-family:inherit;font-size:.82rem;font-weight:700;text-decoration:underline;transition:color .2s;display:inline}.grace-login-link:hover{color:var(--blue-dark)}.grace-urgent .grace-login-link{color:var(--red)}.grace-urgent .grace-login-link:hover{color:var(--red-light)}.guest-access-wrap{margin-top:20px;animation:.5s fadeUp}.guest-divider{align-items:center;gap:14px;margin-bottom:16px;display:flex}.guest-divider:before,.guest-divider:after{content:"";background:var(--border);flex:1;height:1px}.guest-divider span{color:var(--text-secondary);text-transform:lowercase;font-size:.8rem;font-weight:600}.btn-guest{color:#059669;cursor:pointer;background:linear-gradient(135deg,#10b9811a,#34d39914);border:1.5px solid #10b9814d;border-radius:14px;justify-content:center;align-items:center;gap:8px;width:100%;padding:14px 24px;font-family:inherit;font-size:.92rem;font-weight:600;transition:all .2s;display:flex}.btn-guest svg{width:18px;height:18px}.btn-guest:active{background:#10b98126;transform:scale(.97)}.btn-guest:hover{box-shadow:0 4px 16px #10b98126}.guest-hint{text-align:center;color:var(--text-secondary);margin-top:8px;font-size:.75rem;font-weight:500}.btn-admin{color:#d97706;cursor:pointer;background:linear-gradient(135deg,#d9770626,#f59e0b14);border:1.5px solid #d9770666;border-radius:12px;align-items:center;gap:6px;padding:8px 14px;font-size:.8rem;font-weight:700;transition:all .2s;display:inline-flex}.btn-admin svg{width:14px;height:14px}.btn-admin:hover{background:linear-gradient(135deg,#d9770640,#f59e0b26);box-shadow:0 4px 12px #d9770626}.btn-admin:active{transform:scale(.95)}.admin-badge-home{color:#b45309;background:linear-gradient(90deg,#d977061a,#7c3aed1a);border:1px dashed #d977064d;border-radius:20px;justify-content:center;align-items:center;margin:8px auto 0;padding:6px 16px;font-size:.78rem;font-weight:600;animation:2s ease-in-out infinite pulse;display:inline-flex;box-shadow:0 2px 8px #d977060a}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.02)}to{transform:scale(1)}}.admin-q-card{background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:12px;font-size:.8rem;line-height:1.4;transition:all .2s}.admin-q-card:hover{border-color:var(--blue-light);box-shadow:0 2px 8px #0000000d}.admin-q-header{color:var(--text-secondary);justify-content:space-between;margin-bottom:6px;font-size:.7rem;font-weight:700;display:flex}.admin-q-text{color:var(--text);margin-bottom:8px;font-weight:600}.admin-q-options{grid-template-columns:1fr;gap:4px;margin:0 0 8px;padding:0;list-style:none;display:grid}.admin-q-option{background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:4px 8px;font-size:.75rem}.admin-q-option.correct{color:#059669;background:#10b98114;border-color:#10b9814d;font-weight:600}.admin-q-explanation{color:var(--text-secondary);border-left:2px solid var(--border);padding-left:6px;font-size:.72rem;font-style:italic}.install-prompt-card{background:linear-gradient(135deg,#0077b614,#00b4d808);border:1px solid #0077b633;border-radius:16px;align-items:center;gap:12px;margin:16px 0;padding:14px 16px;animation:.5s fadeUp;display:flex;box-shadow:0 4px 18px #00285008}.install-prompt-icon{filter:drop-shadow(0 2px 4px #00000014);font-size:1.8rem}.install-prompt-info{flex-direction:column;flex:1;gap:2px;display:flex}.install-title{color:var(--blue-dark);font-size:.85rem;font-weight:700}.install-desc{color:var(--text-secondary);font-size:.72rem;line-height:1.3}.btn-install-prompt{background:var(--blue);color:#fff;cursor:pointer;border:none;border-radius:10px;padding:8px 14px;font-size:.76rem;font-weight:700;transition:all .2s;box-shadow:0 2px 8px #0077b633}.btn-install-prompt:hover{background:var(--blue-dark);box-shadow:0 4px 12px #0077b64d}.btn-install-prompt:active{transform:scale(.95)}.gami-card{background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:12px;margin-top:12px;padding:10px 14px;box-shadow:0 2px 8px #0000000a}.gami-top-row{align-items:center;gap:10px;display:flex}.gami-avatar{background:var(--red-bg);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-size:1.6rem;display:flex}.gami-info{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.gami-rank{background:linear-gradient(135deg, var(--red), #e85d04, var(--red-light));-webkit-text-fill-color:transparent;white-space:nowrap;text-overflow:ellipsis;-webkit-background-clip:text;background-clip:text;font-size:.85rem;font-weight:800;overflow:hidden}.gami-level{color:var(--blue);text-transform:uppercase;letter-spacing:.06em;font-size:.65rem;font-weight:700}.gami-streak-badge{border:1px solid var(--border);background:#00000008;border-radius:10px;flex-direction:column;flex-shrink:0;align-items:center;gap:0;min-width:42px;padding:4px 8px;transition:all .4s;display:flex}.gami-streak-badge.active{background:#ff8c0014;border-color:#ff8c0040}@keyframes fireFlicker{0%,to{opacity:1;transform:scale(1)rotate(0)}25%{opacity:.9;transform:scale(1.1)rotate(-3deg)}50%{opacity:.8;transform:scale(.95)rotate(3deg)}75%{opacity:1;filter:drop-shadow(0 0 2px #ff6400cc);transform:scale(1.15)rotate(-1deg)}}.gami-streak-fire{font-size:.9rem;line-height:1;animation:1.5s ease-in-out infinite alternate fireFlicker}.gami-streak-count{color:var(--text);font-size:.9rem;font-weight:800;line-height:1.2}.gami-streak-mult{color:#e67e00;min-height:8px;font-size:.55rem;font-weight:700;line-height:1}.gami-xp-section{margin-top:8px}.gami-xp-bar-track{background:#0000000f;border-radius:6px;width:100%;height:6px;overflow:hidden}.gami-xp-bar-fill{background:linear-gradient(90deg,#e63946,#c8102e,#e63946) 0 0/200% 100%;border-radius:6px;height:100%;transition:width 1s cubic-bezier(.22,1,.36,1);animation:2.5s ease-in-out infinite xpShimmer}@keyframes xpShimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.gami-xp-labels{justify-content:space-between;margin-top:4px;display:flex}.gami-xp-current{color:var(--text-secondary);font-size:.65rem;font-weight:600}.gami-xp-next{color:var(--text-secondary);opacity:.7;font-size:.65rem}.levelup-toast{z-index:9999;-webkit-backdrop-filter:blur(8px);opacity:0;pointer-events:none;background:#000000b3;justify-content:center;align-items:center;transition:opacity .4s;display:flex;position:fixed;inset:0}.levelup-toast.show{opacity:1;pointer-events:auto}.levelup-content{text-align:center;color:#fff;animation:.5s cubic-bezier(.34,1.56,.64,1) levelBounce}.levelup-emoji{margin-bottom:8px;font-size:4rem;display:block}.levelup-title{text-transform:uppercase;letter-spacing:.1em;color:orange;margin-bottom:4px;font-size:1.4rem;font-weight:800}.levelup-rank{opacity:.9;font-size:1.1rem;font-weight:600}@keyframes levelBounce{0%{opacity:0;transform:scale(.3)}50%{transform:scale(1.1)}to{opacity:1;transform:scale(1)}}.xp-toast{color:#fff;z-index:9998;opacity:0;pointer-events:none;white-space:nowrap;background:linear-gradient(135deg,#0a1628,#132744);border-radius:50px;padding:8px 20px;font-size:.85rem;font-weight:700;transition:all .4s cubic-bezier(.34,1.56,.64,1);position:fixed;bottom:100px;left:50%;transform:translate(-50%)translateY(30px);box-shadow:0 4px 20px #0006}.xp-toast.show{opacity:1;transform:translate(-50%)translateY(0)}.xp-toast .xp-bonus{color:orange;margin-left:6px}
