:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f3f4f6;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#c9d1d9;--text-h:#f0f0f0;--bg:#2b2b2b;--border:#444;--code-bg:#333;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}#root{text-align:center;box-sizing:border-box;flex-direction:column;width:1126px;max-width:100%;min-height:100svh;margin:0 auto;display:flex}body{margin:0}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}@keyframes shimmer{0%{background-position:-600px 0}to{background-position:600px 0}}.skeleton{background:linear-gradient(90deg, var(--border) 25%, var(--code-bg) 50%, var(--border) 75%);background-size:1200px 100%;border-radius:8px;animation:1.5s linear infinite shimmer}.skeleton--avatar{border-radius:9999px;flex-shrink:0;width:72px;height:72px}.skeleton--name{width:140px;height:26px}.skeleton--btn{border-radius:10px;flex-shrink:0;width:110px;height:44px}.skeleton--chip{border-radius:9999px;flex:1;width:80px;max-width:100px;height:32px}.skeleton--chart{border-radius:6px;height:78px}@keyframes spin{to{transform:rotate(360deg)}}.spinner--lg{border-width:3px;width:40px;height:40px}.page-greeting{margin-bottom:40px}.page-logo{width:auto;height:48px;margin-bottom:16px;display:block}.page-greeting-title{letter-spacing:-1px;color:var(--text-h);margin:0 0 8px;font-size:36px;font-weight:700;line-height:1.1}@media (width<=640px){.page-greeting-title{letter-spacing:-.5px;font-size:26px}}.page-greeting-sub{color:var(--text);margin:0;font-size:17px}.section-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.section-title{color:var(--text-h);margin:0;font-size:20px;font-weight:600}.card-list{flex-direction:column;gap:16px;display:flex}.card{background:var(--code-bg);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:18px;flex-direction:column;gap:20px;padding:32px 36px;transition:transform .18s,box-shadow .18s,border-color .18s;display:flex;position:relative;overflow:hidden}@media (width<=640px){.card{gap:16px;padding:22px 20px}}.card:before{content:"";border-radius:inherit;opacity:0;background:radial-gradient(circle at 10% 0%, var(--accent-bg), transparent 55%);pointer-events:none;transition:opacity .2s;position:absolute;inset:0}.card:hover{transform:translateY(-2px);box-shadow:0 10px 32px -6px #00000017,0 4px 10px -3px #0000000d}.card:hover:before{opacity:1}.card--clickable{cursor:pointer;text-align:left}.card--clickable:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.card--done{border-left:3px solid #22c55e}.card--available{border-left:3px solid var(--accent)}.card--expired{opacity:.55}.card--skeleton{pointer-events:none}.card-top{justify-content:space-between;align-items:center;gap:16px;display:flex}.chip-row{flex-wrap:wrap;gap:10px;display:flex}.chip{background:var(--bg);border:1px solid var(--border);white-space:nowrap;border-radius:9999px;align-items:center;gap:5px;padding:7px 12px;font-size:13px;display:flex}.chip--streak{background:#f59e0b1a;border-color:#f59e0b59;box-shadow:0 0 10px #f59e0b26}.chip--countdown{background:var(--accent-bg);border-color:var(--accent-border)}.chip-icon{font-size:14px;line-height:1}.chip-val{color:var(--text-h);font-weight:700}.chip--streak .chip-val{color:#d97706}.chip--countdown .chip-val{color:var(--accent)}@media (prefers-color-scheme:dark){.chip--streak .chip-val{color:#fbbf24}}.chip-lbl{color:var(--text);opacity:.6;font-size:12px}.score-display{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:1px;display:flex}.score-num{letter-spacing:-1px;font-size:36px;font-weight:800;line-height:1}.score-label{letter-spacing:.3px;opacity:.8;font-size:12px;font-weight:600}.btn-primary{background:var(--accent);color:#fff;cursor:pointer;box-shadow:0 0 20px var(--accent-border);font-size:16px;font-weight:600;font-family:var(--sans);border:none;border-radius:10px;padding:14px 28px;transition:opacity .15s,transform .15s,box-shadow .15s}.btn-primary:hover{opacity:.9;box-shadow:0 0 28px var(--accent-border);transform:translateY(-2px)}.error-box{color:#dc2626;background:#dc262614;border:1px solid #dc262640;border-radius:10px;margin-bottom:24px;padding:16px 20px;font-size:15px}.empty-state{text-align:center;flex-direction:column;align-items:center;gap:16px;padding:64px 24px;display:flex}.empty-state-emoji{filter:drop-shadow(0 4px 12px #0000001a);font-size:72px;line-height:1}.empty-state-title{color:var(--text-h);letter-spacing:-.4px;margin:0;font-size:28px;font-weight:700}.empty-state-body{color:var(--text);max-width:380px;margin:0;font-size:16px;line-height:1.6}.login-page{box-sizing:border-box;justify-content:center;align-items:center;min-height:100svh;padding:24px;display:flex}.login-card{text-align:center;flex-direction:column;align-items:center;gap:0;width:100%;max-width:420px;display:flex}.login-logo{width:auto;height:80px;margin-bottom:24px}@media (prefers-color-scheme:dark){.login-logo{filter:invert()hue-rotate(180deg)}}.login-subtitle{color:var(--text);margin:0 0 48px;font-size:18px;line-height:1.4}.login-buttons{flex-direction:column;gap:14px;width:100%;margin-bottom:32px;display:flex}.login-btn{cursor:pointer;border:1px solid var(--border);background:var(--bg);width:100%;color:var(--text-h);font-size:16px;font-weight:500;font-family:var(--sans);border-radius:10px;justify-content:center;align-items:center;gap:12px;padding:14px 24px;transition:transform .15s,box-shadow .15s,opacity .15s;display:flex}.login-btn:hover:not(:disabled){transform:translateY(-1px)}.login-btn:active:not(:disabled){transform:translateY(0)}.login-btn:disabled{opacity:.6;cursor:not-allowed}.login-btn--google{box-shadow:0 0 0 1px #4285f433,0 2px 8px #4285f41f}.login-btn--google:hover:not(:disabled){box-shadow:0 0 0 1px #4285f459,0 4px 16px #4285f433}.login-btn--facebook{box-shadow:0 0 0 1px #1877f233,0 2px 8px #1877f21f}.login-btn--facebook:hover:not(:disabled){box-shadow:0 0 0 1px #1877f259,0 4px 16px #1877f233}.btn-icon{flex-shrink:0;width:20px;height:20px}.spinner{border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;flex-shrink:0;width:20px;height:20px;animation:.7s linear infinite spin;display:inline-block}.login-footer{color:var(--text);opacity:.7;margin:0;font-size:14px}.avatar{object-fit:cover;-webkit-user-select:none;user-select:none;border-radius:9999px;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.avatar--sm{width:32px;height:32px;font-size:12px;font-weight:600}.avatar--md{width:44px;height:44px;font-size:16px;font-weight:600}.avatar--lg{width:72px;height:72px;font-size:26px;font-weight:700}.avatar--initials{color:#fff;letter-spacing:.5px}.shell{flex-direction:column;min-height:100svh;display:flex}.shell-nav{z-index:100;background:var(--bg);border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);justify-content:space-between;align-items:center;height:60px;padding:0 32px;display:flex;position:sticky;top:0}@media (width<=640px){.shell-nav{padding:0 16px}}.shell-brand{cursor:pointer;background:0 0;border:none;align-items:center;gap:8px;padding:0;text-decoration:none;display:flex}.shell-brand-logo{object-fit:contain;width:auto;height:36px}@media (prefers-color-scheme:dark){.shell-brand-logo{filter:invert()hue-rotate(180deg)}}.shell-nav-right{align-items:center;gap:16px;display:flex;position:relative}.shell-user{border:1px solid var(--border);cursor:pointer;font-family:var(--sans);background:0 0;border-radius:9999px;align-items:center;gap:8px;padding:4px 10px 4px 4px;transition:background .15s,border-color .15s;display:flex}.shell-user:hover{background:var(--code-bg);border-color:var(--accent-border)}.shell-user-name{color:var(--text);font-size:14px;font-weight:500}@media (width<=480px){.shell-user-name{display:none}}.shell-chevron{color:var(--text);opacity:.5;margin-left:2px;font-size:9px}.shell-dropdown{background:var(--bg);border:1px solid var(--border);min-width:180px;box-shadow:var(--shadow);z-index:200;border-radius:12px;animation:.15s dropdownEnter;position:absolute;top:calc(100% + 8px);right:0;overflow:hidden}@keyframes dropdownEnter{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.shell-dropdown-item{width:100%;font-size:14px;font-weight:500;font-family:var(--sans);color:var(--text-h);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:8px;padding:12px 16px;transition:background .12s;display:flex}.shell-dropdown-item:hover{background:var(--code-bg)}.shell-dropdown-item--logout{color:var(--text)}.shell-dropdown-divider{background:var(--border);height:1px;margin:0}.shell-main{box-sizing:border-box;text-align:left;flex:1;width:100%;max-width:1100px;margin:0 auto;padding:40px 32px 64px}@media (width<=640px){.shell-main{padding:24px 16px 48px}}.pc-identity{align-items:center;gap:16px;min-width:0;display:flex}.pc-name-row{align-items:center;gap:6px;min-width:0;display:flex}.pc-edit-btn{cursor:pointer;opacity:.35;background:0 0;border:none;flex-shrink:0;padding:2px;font-size:15px;line-height:1;transition:opacity .15s}.pc-edit-btn:hover{opacity:1}.pc-name{color:var(--text-h);letter-spacing:-.4px;white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:26px;font-weight:700;overflow:hidden}@media (width<=480px){.pc-name{font-size:20px}}.pc-no-test{color:var(--text);opacity:.55;white-space:nowrap;flex-shrink:0;font-size:13px}.pc-test-available{color:var(--accent);background:var(--accent-bg);border:1px solid var(--accent-border);white-space:nowrap;border-radius:9999px;flex-shrink:0;align-items:center;gap:7px;padding:6px 14px;font-size:13px;font-weight:600;display:flex}.pc-test-dot{background:var(--accent);border-radius:9999px;flex-shrink:0;width:7px;height:7px;animation:1.8s ease-in-out infinite pulse-dot}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.7)}}.pc-chart-wrap{flex-direction:column;gap:8px;display:flex}.pc-chart-label{color:var(--text);opacity:.45;text-transform:uppercase;letter-spacing:.6px;font-size:11px;font-weight:600}.pc-chart{align-items:flex-end;gap:6px;height:78px;display:flex}.pc-bar-col{cursor:default;flex-direction:column;flex:1;justify-content:flex-end;align-items:center;gap:4px;height:100%;display:flex}.pc-bar{border-radius:3px 3px 0 0;width:100%;min-height:3px;transition:height .6s cubic-bezier(.34,1.2,.64,1)}.pc-bar--empty{border:1.5px dashed var(--border);opacity:.45;border-radius:3px 3px 0 0;background:0 0!important}.pc-bar-col:hover .pc-bar:not(.pc-bar--empty){filter:brightness(1.15)}.pc-bar-day{color:var(--text);opacity:.45;-webkit-user-select:none;user-select:none;font-size:10px;line-height:1}.pc-add{border:2px dashed var(--border);cursor:pointer;font-family:var(--sans);background:0 0;border-radius:18px;justify-content:center;align-items:center;gap:10px;padding:22px;transition:border-color .15s,background .15s,box-shadow .15s,transform .15s;display:flex}.pc-add:hover{border-color:var(--accent-border);background:var(--accent-bg);box-shadow:0 0 16px var(--accent-border);transform:translateY(-1px)}.pc-add-icon{color:var(--text);opacity:.4;font-size:24px;line-height:1;transition:opacity .15s,color .15s}.pc-add:hover .pc-add-icon{opacity:1;color:var(--accent)}.pc-add-label{color:var(--text);opacity:.45;font-size:15px;font-weight:600;transition:opacity .15s,color .15s}.pc-add:hover .pc-add-label{opacity:1;color:var(--accent)}.btn-add-child{border:1px solid var(--accent-border);background:var(--accent-bg);color:var(--accent);cursor:pointer;font-size:14px;font-weight:600;font-family:var(--sans);border-radius:8px;align-items:center;gap:6px;padding:8px 16px;transition:box-shadow .15s;display:inline-flex}.btn-add-child:hover{box-shadow:0 0 12px var(--accent-border)}.ap-grid{grid-template-columns:repeat(4,1fr);gap:12px;width:100%;display:grid}@media (width<=360px){.ap-grid{grid-template-columns:repeat(3,1fr)}}.ap-item{cursor:pointer;aspect-ratio:1;background:0 0;border:3px solid #0000;border-radius:9999px;padding:0;transition:transform .15s,border-color .15s,box-shadow .15s;overflow:hidden}.ap-item:hover{transform:scale(1.08)}.ap-item--selected{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-bg)}.ap-img{object-fit:cover;border-radius:9999px;width:100%;height:100%;display:block}.ap-skeleton{aspect-ratio:1;background:var(--border);border-radius:9999px;animation:1.4s ease-in-out infinite apPulse}@keyframes apPulse{0%,to{opacity:1}50%{opacity:.4}}.cp-page{box-sizing:border-box;flex-direction:column;align-items:center;min-height:100svh;padding:32px 24px 64px;display:flex}.cp-back{color:var(--text);font-size:15px;font-family:var(--sans);cursor:pointer;opacity:.7;background:0 0;border:none;align-self:flex-start;padding:8px 0;transition:opacity .15s}.cp-back:hover{opacity:1}.cp-steps{gap:8px;margin:32px 0 48px;display:flex}.cp-step-dot{background:var(--border);border-radius:9999px;width:10px;height:10px;transition:background .2s}.cp-step-dot--done{background:var(--accent)}.cp-card{text-align:center;flex-direction:column;align-items:center;gap:0;width:100%;max-width:440px;animation:.3s both cpEnter;display:flex}@keyframes cpEnter{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.cp-emoji{filter:drop-shadow(0 4px 16px #0000001a);margin-bottom:24px;font-size:64px;line-height:1}.cp-question{letter-spacing:-.8px;color:var(--text-h);margin:0 0 32px;font-size:36px;font-weight:700;line-height:1.15}@media (width<=480px){.cp-question{font-size:28px}}.cp-hint{color:var(--text);opacity:.6;margin:-24px 0 12px;font-size:14px}.cp-hint--avatar{margin:-8px 0 20px}.cp-input{border:1.5px solid var(--border);background:var(--code-bg);width:100%;color:var(--text-h);font-size:20px;font-family:var(--sans);text-align:center;box-sizing:border-box;border-radius:12px;outline:none;margin-bottom:20px;padding:16px 20px;transition:border-color .15s,box-shadow .15s}.cp-input:focus{border-color:var(--accent-border);box-shadow:0 0 0 3px var(--accent-bg)}.cp-input::placeholder{color:var(--text);opacity:.35}.cp-input::-webkit-outer-spin-button{-webkit-appearance:none}.cp-input::-webkit-inner-spin-button{-webkit-appearance:none}.cp-next{background:var(--accent);color:#fff;width:100%;font-size:17px;font-weight:600;font-family:var(--sans);cursor:pointer;box-shadow:0 0 20px var(--accent-border);border:none;border-radius:12px;justify-content:center;align-items:center;gap:8px;padding:16px;transition:opacity .15s,transform .15s,box-shadow .15s;display:flex}.cp-next:hover:not(:disabled){opacity:.9;box-shadow:0 0 28px var(--accent-border);transform:translateY(-2px)}.cp-next:disabled{opacity:.35;cursor:not-allowed;box-shadow:none}.cp-next--submit{background:var(--accent);box-shadow:0 0 20px var(--accent-border)}.cp-next--submit:hover:not(:disabled){box-shadow:0 0 28px var(--accent-border)}.emodal-backdrop{z-index:200;background:#00000073;justify-content:center;align-items:center;padding:24px;animation:.15s emodal-fade;display:flex;position:fixed;inset:0}@keyframes emodal-fade{0%{opacity:0}to{opacity:1}}.emodal{background:var(--bg);border:1px solid var(--border);width:100%;max-width:400px;box-shadow:var(--shadow);text-align:center;border-radius:16px;flex-direction:column;align-items:center;gap:16px;padding:32px 28px;animation:.18s emodal-rise;display:flex}@keyframes emodal-rise{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.emodal-icon{font-size:40px;line-height:1}.emodal-message{color:var(--text);margin:0;font-size:16px;line-height:1.5}.emodal-actions{gap:12px;width:100%;margin-top:4px;display:flex}.emodal-actions .emodal-close{flex:1;margin-top:0}.emodal-confirm{color:#fff;font-size:15px;font-weight:600;font-family:var(--sans);cursor:pointer;background:#ef4444;border:none;border-radius:10px;flex:1;padding:11px 28px;transition:opacity .15s}.emodal-confirm:hover{opacity:.88}.emodal-close{border:1px solid var(--border);color:var(--text-h);font-size:15px;font-weight:600;font-family:var(--sans);cursor:pointer;background:0 0;border-radius:10px;margin-top:4px;padding:11px 28px;transition:background .15s,border-color .15s}.emodal-close:hover{background:var(--code-bg);border-color:var(--accent-border)}.pp-greeting-identity{align-items:center;gap:20px;display:flex}.pp-dashboard-btn{background:var(--accent);color:#fff;width:100%;font-size:16px;font-weight:600;font-family:var(--sans);cursor:pointer;box-shadow:0 0 20px var(--accent-border);border:none;border-radius:12px;margin-top:24px;padding:15px 32px;transition:opacity .15s,transform .15s,box-shadow .15s;display:block}.pp-dashboard-btn:hover{opacity:.9;box-shadow:0 0 28px var(--accent-border);transform:translateY(-2px)}.tc-title-wrap{flex-direction:column;gap:4px;min-width:0;display:flex}.tc-title{color:var(--text-h);letter-spacing:-.3px;margin:0;font-size:20px;font-weight:700}.tc-date{color:var(--text);opacity:.55;font-size:13px}.tc-remaining{color:var(--text);opacity:.6;margin-top:2px;font-size:13px}.tc-action{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:10px;display:flex}.tc-start-wrap{border-top:1px solid var(--border);flex-direction:column;align-items:center;gap:10px;margin-top:16px;padding-top:16px;display:flex}.tc-meta{color:var(--text);opacity:.7;gap:16px;font-size:14px;display:flex}.tc-start-btn{background:var(--accent);color:#fff;width:100%;font-size:18px;font-weight:700;font-family:var(--sans);cursor:pointer;box-shadow:0 0 20px var(--accent-border);border:none;border-radius:14px;justify-content:center;align-items:center;gap:8px;padding:18px;transition:opacity .15s,transform .15s,box-shadow .15s;display:flex}.tc-start-btn:hover:not(:disabled){opacity:.9;box-shadow:0 0 28px var(--accent-border);transform:translateY(-2px)}.tc-start-btn:disabled{opacity:.6;cursor:not-allowed}.tc-badge{white-space:nowrap;border-radius:9999px;flex-shrink:0;padding:6px 14px;font-size:13px;font-weight:600}.tc-badge--pending{color:#d97706;background:#f59e0b1f;border:1px solid #f59e0b4d}.tc-badge--expired{background:var(--bg);color:var(--text);border:1px solid var(--border);opacity:.6}.quiz-page{background:var(--bg);flex-direction:column;min-height:100svh;display:flex}.quiz-topbar{flex-shrink:0;justify-content:space-between;align-items:center;height:60px;padding:0 20px;display:flex}.quiz-exit-btn{border:1.5px solid var(--border);width:36px;height:36px;color:var(--text);cursor:pointer;background:0 0;border-radius:50%;justify-content:center;align-items:center;font-size:14px;transition:background .15s,color .15s;display:flex}.quiz-exit-btn:hover{background:var(--border);color:var(--text-h)}.quiz-counter{color:var(--text);font-size:15px;font-weight:600}.quiz-counter-current{color:var(--text-h);font-size:18px}.quiz-counter-sep{opacity:.4}.quiz-counter-total{opacity:.5}.quiz-timer{width:52px;height:52px;position:relative}.timer-track{fill:none;stroke:var(--border);stroke-width:3px}.timer-ring{fill:none;stroke:var(--accent);stroke-width:3px;stroke-linecap:round;transition:stroke-dasharray .9s linear,stroke .3s}.quiz-timer--warn .timer-ring{stroke:#f59e0b}.quiz-timer--urgent .timer-ring{stroke:#ef4444}.timer-num{color:var(--text-h);justify-content:center;align-items:center;font-size:13px;font-weight:700;display:flex;position:absolute;inset:0}.quiz-timer--urgent .timer-num{color:#ef4444;animation:.5s ease-in-out infinite alternate timerPulse}@keyframes timerPulse{0%{transform:scale(1)}to{transform:scale(1.15)}}.quiz-progress-bar{background:var(--border);flex-shrink:0;height:5px}.quiz-progress-fill{background:var(--accent);border-radius:0 9999px 9999px 0;height:100%;transition:width .4s}.quiz-body{box-sizing:border-box;flex-direction:column;flex:1;width:100%;max-width:720px;margin:0 auto;padding:32px 20px 40px;animation:.3s both bodyEnter;display:flex}@keyframes bodyEnter{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}.quiz-question-text{color:var(--text-h);letter-spacing:-.3px;margin:0 0 32px;font-size:clamp(20px,3.5vw,30px);font-weight:700;line-height:1.35}.quiz-options--grid{grid-template-columns:1fr 1fr;gap:12px;display:grid}@media (width<=480px){.quiz-options--grid{grid-template-columns:1fr}}.quiz-options--tf{grid-template-columns:1fr 1fr;gap:16px;display:grid}.quiz-opt{border:2px solid var(--opt-border,var(--border));background:var(--opt-bg,var(--code-bg));color:var(--opt-color,var(--text-h));font-size:16px;font-weight:500;font-family:var(--sans);cursor:pointer;text-align:left;border-radius:14px;align-items:center;gap:12px;min-height:64px;padding:18px 20px;transition:transform .14s,box-shadow .14s,background .14s;display:flex}.quiz-opt:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 16px #0000001a}.quiz-opt:disabled{cursor:not-allowed;opacity:.65}.quiz-opt--tf{justify-content:center;min-height:80px;font-size:20px;font-weight:700}.quiz-opt--selected{transform:scale(.97);background:var(--accent)!important;color:#fff!important;border-color:var(--accent)!important}.opt-letter{background:#00000014;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:13px;font-weight:700;display:flex}.quiz-opt--selected .opt-letter{background:#ffffff40}.opt-text{flex:1;line-height:1.3}.tf-icon{margin-right:4px;font-size:24px}.quiz-text-wrap{flex-direction:column;gap:14px;display:flex}.quiz-text-input{border:2px solid var(--border);background:var(--code-bg);width:100%;color:var(--text-h);font-size:20px;font-family:var(--sans);box-sizing:border-box;border-radius:12px;outline:none;padding:16px 20px;transition:border-color .15s,box-shadow .15s}.quiz-text-input:focus{border-color:var(--accent-border);box-shadow:0 0 0 3px var(--accent-bg)}.quiz-submit-btn{background:var(--accent);color:#fff;font-size:16px;font-weight:600;font-family:var(--sans);cursor:pointer;box-shadow:0 0 16px var(--accent-border);border:none;border-radius:12px;align-self:stretch;margin-top:4px;padding:16px 28px;transition:opacity .15s,transform .15s}.quiz-submit-btn:hover:not(:disabled){opacity:.9;transform:translateY(-2px)}.quiz-submit-btn:disabled{opacity:.35;cursor:not-allowed;box-shadow:none}.quiz-ordering{flex-direction:column;gap:10px;display:flex}.ordering-row{background:var(--code-bg);border:1.5px solid var(--border);border-radius:12px;align-items:center;gap:12px;padding:14px 16px;display:flex}.ordering-rank{background:var(--accent-bg);width:28px;height:28px;color:var(--accent);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:13px;font-weight:700;display:flex}.ordering-text{color:var(--text-h);flex:1;font-size:16px}.ordering-arrows{flex-direction:column;gap:2px;display:flex}.ordering-arrows button{border:1px solid var(--border);width:28px;height:24px;color:var(--text);cursor:pointer;background:0 0;border-radius:6px;justify-content:center;align-items:center;font-size:12px;display:flex}.ordering-arrows button:disabled{opacity:.3;cursor:not-allowed}.ordering-arrows button:hover:not(:disabled){background:var(--border)}.quiz-matching{flex-direction:column;gap:16px;display:flex}.matching-cols{grid-template-columns:1fr 1fr;gap:12px;display:grid}.matching-col{flex-direction:column;gap:8px;display:flex}.matching-item{border:2px solid var(--border);background:var(--code-bg);color:var(--text-h);font-size:14px;font-family:var(--sans);cursor:pointer;text-align:left;border-radius:10px;justify-content:space-between;align-items:center;min-height:48px;padding:12px 14px;transition:border-color .15s,background .15s;display:flex}.matching-item--active{border-color:var(--accent-border);background:var(--accent-bg);color:var(--accent)}.matching-item--paired{background:#22c55e14;border-color:#22c55e}.matching-item--disabled{cursor:not-allowed;opacity:.5}.matching-check{color:#22c55e;font-weight:700}.tr-page{box-sizing:border-box;background:var(--bg);flex-direction:column;justify-content:center;align-items:center;min-height:100svh;padding:32px 20px 64px;display:flex;position:relative;overflow:hidden}.tr-page--loading{color:var(--text);gap:16px;font-size:16px}.tr-card{text-align:center;flex-direction:column;align-items:center;gap:0;width:100%;max-width:580px;animation:.5s both trEnter;display:flex}@keyframes trEnter{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.tr-emoji{filter:drop-shadow(0 4px 20px #00000026);margin-bottom:16px;font-size:80px;line-height:1}.tr-heading{letter-spacing:-1.2px;color:var(--text-h);margin:0 0 28px;font-size:44px;font-weight:800}@media (width<=480px){.tr-heading{font-size:32px}}.tr-score{align-items:baseline;gap:6px;margin-bottom:6px;display:flex}.tr-score-num{color:var(--text-h);letter-spacing:-3px;font-size:88px;font-weight:900;line-height:1}@media (width<=480px){.tr-score-num{font-size:64px}}.tr-score-sep{color:var(--text);opacity:.4;font-size:40px;font-weight:300}.tr-score-total{color:var(--text);opacity:.55;font-size:40px;font-weight:700}.tr-pct{color:var(--text);margin:0 0 20px;font-size:18px}.tr-bar-bg{background:var(--border);border-radius:9999px;width:100%;height:10px;margin-bottom:40px;overflow:hidden}.tr-bar-fill{border-radius:9999px;height:100%;transition:width 1s}.tr-breakdown{text-align:left;width:100%;margin-bottom:32px}.tr-breakdown-title{color:var(--text-h);margin:0 0 12px;font-size:16px;font-weight:600}.tr-breakdown-list{flex-direction:column;gap:6px;display:flex}.tr-item{background:var(--code-bg);border-left:3px solid var(--border);border-radius:10px;align-items:flex-start;gap:12px;padding:12px 16px;display:flex}.tr-item--correct{border-left-color:#22c55e}.tr-item--wrong{border-left-color:#ef4444}.tr-item--unknown{border-left-color:var(--border)}.tr-item-icon{flex-shrink:0;width:20px;margin-top:1px;font-size:15px;font-weight:700}.tr-item--correct .tr-item-icon{color:#22c55e}.tr-item--wrong .tr-item-icon{color:#ef4444}.tr-item-body{flex-direction:column;gap:2px;display:flex}.tr-item-num{color:var(--text);opacity:.55;text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:700}.tr-item-text{color:var(--text);font-size:14px;line-height:1.4}.tr-done-btn{background:var(--accent);color:#fff;font-size:16px;font-weight:600;font-family:var(--sans);cursor:pointer;box-shadow:0 0 20px var(--accent-border);border:none;border-radius:12px;padding:15px 32px;transition:opacity .15s,transform .15s,box-shadow .15s}.tr-done-btn:hover{opacity:.9;box-shadow:0 0 28px var(--accent-border);transform:translateY(-2px)}.tr-error{color:var(--text);margin-bottom:20px;font-size:16px}.confetti{pointer-events:none;z-index:50;position:fixed;inset:0;overflow:hidden}.confetti-piece{border-radius:2px;animation:ease-in forwards confettiFall;position:absolute;top:-20px}@keyframes confettiFall{0%{opacity:1;transform:translateY(0)rotate(0)}80%{opacity:1}to{opacity:0;transform:translateY(100vh)rotate(720deg)}}.ep-page{box-sizing:border-box;flex-direction:column;align-items:center;min-height:100svh;padding:32px 24px 64px;display:flex}.ep-back{color:var(--text);font-size:15px;font-family:var(--sans);cursor:pointer;opacity:.7;background:0 0;border:none;align-self:flex-start;padding:8px 0;transition:opacity .15s}.ep-back:hover{opacity:1}.ep-card{text-align:center;flex-direction:column;align-items:center;width:100%;max-width:440px;margin-top:48px;animation:.3s both epEnter;display:flex}@keyframes epEnter{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.ep-emoji{margin-bottom:16px;font-size:56px;line-height:1}.ep-title{letter-spacing:-.8px;color:var(--text-h);margin:0 0 32px;font-size:32px;font-weight:700}.ep-label{color:var(--text);opacity:.6;text-transform:uppercase;letter-spacing:.5px;align-self:flex-start;margin-bottom:8px;font-size:13px;font-weight:600}.ep-label--avatar{margin-top:24px;margin-bottom:12px}.ep-input{border:1.5px solid var(--border);background:var(--code-bg);width:100%;color:var(--text-h);font-size:18px;font-family:var(--sans);box-sizing:border-box;border-radius:12px;outline:none;margin-bottom:16px;padding:16px 20px;transition:border-color .15s,box-shadow .15s}.ep-input:focus{border-color:var(--accent-border);box-shadow:0 0 0 3px var(--accent-bg)}.ep-input--danger:focus{border-color:#ef444480;box-shadow:0 0 0 3px #ef44441a}.ep-input::placeholder{color:var(--text);opacity:.35}.ep-save{background:var(--accent);color:#fff;width:100%;font-size:16px;font-weight:600;font-family:var(--sans);cursor:pointer;box-shadow:0 0 20px var(--accent-border);border:none;border-radius:12px;justify-content:center;align-items:center;margin-top:24px;padding:16px;transition:opacity .15s,transform .15s,box-shadow .15s;display:flex}.ep-save:hover:not(:disabled){opacity:.9;box-shadow:0 0 28px var(--accent-border);transform:translateY(-2px)}.ep-save:disabled{opacity:.35;cursor:not-allowed;box-shadow:none}.ep-danger-zone{border-top:1.5px solid var(--border);flex-direction:column;align-items:center;width:100%;margin-top:48px;padding-top:32px;display:flex}.ep-danger-title{color:#ef4444;text-transform:uppercase;letter-spacing:.5px;margin:0 0 12px;font-size:15px;font-weight:700}.ep-danger-hint{color:var(--text);margin-bottom:16px;font-size:14px;line-height:1.5}.ep-danger-hint strong{color:var(--text-h)}.ep-delete{color:#ef4444;width:100%;font-size:16px;font-weight:600;font-family:var(--sans);cursor:pointer;background:0 0;border:1.5px solid #ef4444;border-radius:12px;justify-content:center;align-items:center;padding:16px;transition:background .15s,color .15s,opacity .15s;display:flex}.ep-delete:hover:not(:disabled){color:#fff;background:#ef4444}.ep-delete:disabled{opacity:.3;cursor:not-allowed}.ac-page{max-width:480px;margin:0 auto}.ac-back{color:var(--text);font-size:15px;font-family:var(--sans);cursor:pointer;opacity:.7;background:0 0;border:none;padding:0 0 32px;transition:opacity .15s;display:block}.ac-back:hover{opacity:1}.ac-card{flex-direction:column;animation:.3s both acEnter;display:flex}@keyframes acEnter{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.ac-emoji{margin-bottom:12px;font-size:48px;line-height:1}.ac-title{letter-spacing:-.6px;color:var(--text-h);margin:0 0 28px;font-size:28px;font-weight:700}.ac-info{border:1px solid var(--border);border-radius:12px;flex-direction:column;gap:0;margin-bottom:0;display:flex;overflow:hidden}.ac-info-row{background:var(--code-bg);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:14px 18px;display:flex}.ac-info-row:last-child{border-bottom:none}.ac-info-label{color:var(--text);opacity:.6;text-transform:uppercase;letter-spacing:.5px;font-size:13px;font-weight:600}.ac-info-val{color:var(--text-h);font-size:15px;font-weight:500}.ac-danger-zone{border-top:1.5px solid var(--border);flex-direction:column;gap:14px;margin-top:40px;padding-top:40px;display:flex}.ac-danger-title{color:#ef4444;text-transform:uppercase;letter-spacing:.5px;margin:0;font-size:15px;font-weight:700}.ac-danger-hint{color:var(--text);margin:0;font-size:14px;line-height:1.5}.ac-danger-hint strong{color:var(--text-h)}.ac-input{border:1.5px solid var(--border);background:var(--code-bg);width:100%;color:var(--text-h);font-size:16px;font-family:var(--sans);box-sizing:border-box;border-radius:10px;outline:none;padding:14px 16px;transition:border-color .15s,box-shadow .15s}.ac-input:focus{border-color:#ef444480;box-shadow:0 0 0 3px #ef44441a}.ac-input::placeholder{color:var(--text);opacity:.35}.ac-delete{color:#ef4444;width:100%;font-size:15px;font-weight:600;font-family:var(--sans);cursor:pointer;background:0 0;border:1.5px solid #ef4444;border-radius:10px;justify-content:center;align-items:center;padding:14px;transition:background .15s,color .15s,opacity .15s;display:flex}.ac-delete:hover:not(:disabled){color:#fff;background:#ef4444}.ac-delete:disabled{opacity:.3;cursor:not-allowed}
