*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--color-bg: #fafafa;--color-surface: #ffffff;--color-border: #e4e7ec;--color-text: #101828;--color-text-secondary: #667085;--color-primary: #3cc8db;--color-primary-hover: #2ab3c5;--color-error: #f04438;--color-success: #12b76a;--radius: 8px}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--color-bg);color:var(--color-text);line-height:1.5}.loading{display:grid;place-items:center;height:100vh;color:var(--color-text-secondary)}.login-split{display:grid;grid-template-columns:1fr 1fr;min-height:100vh}.login-hero{background:radial-gradient(ellipse at 20% 80%,rgba(60,200,219,.15) 0%,transparent 50%),radial-gradient(ellipse at 80% 20%,rgba(167,231,240,.25) 0%,transparent 50%),radial-gradient(ellipse at 50% 50%,rgba(200,240,245,.2) 0%,transparent 70%),linear-gradient(160deg,#f0fbfc,#e4f7f9,#daf2f6 60%,#eef9fb);display:flex;align-items:center;justify-content:center;padding:3rem;position:relative;overflow:hidden}.login-hero:before{content:"";position:absolute;top:-30%;right:-20%;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(60,200,219,.08) 0%,transparent 70%);pointer-events:none}.login-hero:after{content:"";position:absolute;bottom:-20%;left:-10%;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(60,200,219,.06) 0%,transparent 70%);pointer-events:none}.login-hero-content{max-width:420px;position:relative;z-index:1}.login-hero-logo-link{display:block;width:fit-content;margin:0 auto 2rem;line-height:0;transition:transform .2s ease}.login-hero-logo-link:hover{transform:scale(1.05)}.login-hero-logo{height:120px;width:120px;object-fit:cover;border-radius:50%;border:3px solid rgba(60,200,219,.4);box-shadow:0 8px 32px #3cc8db1f;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.login-hero h2{font-size:1.875rem;font-weight:700;color:var(--color-text);margin-bottom:1rem;letter-spacing:-.02em}.login-hero-description{font-size:1.0625rem;line-height:1.75;color:var(--color-text-secondary)}.login-hero-tagline{display:none}.login-form-side{display:flex;align-items:center;justify-content:center;padding:2rem;background:var(--color-surface);border-left:1px solid var(--color-border)}.login-form{width:100%;max-width:380px;display:flex;flex-direction:column;gap:1rem}.login-form h1{font-size:1.5rem;font-weight:600;margin-bottom:.5rem}@media(max-width:768px){.login-split{grid-template-columns:1fr;grid-template-rows:auto 1fr;background:radial-gradient(ellipse at 20% 80%,rgba(60,200,219,.15) 0%,transparent 50%),radial-gradient(ellipse at 80% 20%,rgba(167,231,240,.25) 0%,transparent 50%),linear-gradient(160deg,#f0fbfc,#e4f7f9,#daf2f6 60%,#eef9fb)}.login-hero{background:none;padding:2rem 1.5rem .75rem}.login-hero:before,.login-hero:after{display:none}.login-hero-content{text-align:center}.login-hero-logo{height:80px;width:80px;margin-bottom:.75rem}.login-hero h2{font-size:1.25rem;margin-bottom:.25rem}.login-hero-description{display:none}.login-hero-tagline{display:block;font-size:.9375rem;color:var(--color-text-secondary)}.login-form-side{background:none;border-left:none;padding:1.5rem;align-items:flex-start}}.login-form label{display:flex;flex-direction:column;gap:.375rem;font-size:.875rem;font-weight:500;color:var(--color-text-secondary)}.login-form input{padding:.625rem .875rem;border:1px solid var(--color-border);border-radius:var(--radius);font-size:1rem;outline:none;transition:border-color .15s}.login-form input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #3cc8db33}.login-legal{display:flex;flex-direction:column;gap:.5rem;margin-top:-.25rem}.login-form .login-checkbox{flex-direction:row;align-items:flex-start;gap:.625rem;font-size:.8125rem;font-weight:500;color:var(--color-text);line-height:1.45;cursor:pointer}.login-form .login-checkbox input[type=checkbox]{margin-top:.2rem;width:16px;height:16px;flex-shrink:0;accent-color:var(--color-primary);border-radius:3px}.login-form .login-checkbox a{color:var(--color-primary);text-decoration:underline}.login-form .login-checkbox a:hover{color:var(--color-primary-hover)}.login-form button[type=submit]{padding:.625rem;background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius);font-size:1rem;font-weight:500;cursor:pointer;transition:background .15s}.login-form button[type=submit]:hover{background:var(--color-primary-hover)}.login-form button[type=submit]:disabled{opacity:.6;cursor:not-allowed}.error{color:var(--color-error);font-size:.875rem}.success{color:var(--color-success);font-size:.875rem}.login-divider{display:flex;align-items:center;gap:.75rem;color:var(--color-text-secondary);font-size:.8125rem}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:var(--color-border)}.google-btn{display:flex;align-items:center;justify-content:center;gap:.625rem;width:100%;padding:.625rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);font-size:.9375rem;font-weight:500;color:var(--color-text);cursor:pointer;transition:background .15s,border-color .15s}.google-btn:hover{background:var(--color-bg);border-color:#d0d5dd}.google-btn:disabled{opacity:.6;cursor:not-allowed}.toggle-auth{text-align:center;font-size:.875rem;color:var(--color-text-secondary)}.toggle-auth button{background:none;border:none;color:var(--color-primary);cursor:pointer;font-size:inherit;font-weight:500}.forgot-link{align-self:flex-end;background:none;border:none;padding:0;margin-top:-.5rem;color:var(--color-primary);font-size:.8125rem;font-weight:500;cursor:pointer}.forgot-link:hover{text-decoration:underline}.page{min-height:100vh;background:radial-gradient(ellipse at 30% 20%,rgba(60,200,219,.1) 0%,transparent 50%),radial-gradient(ellipse at 70% 80%,rgba(42,179,197,.07) 0%,transparent 50%),#e3eced}.top-bar{position:relative;display:flex;align-items:center;justify-content:space-between;min-height:64px;padding:env(safe-area-inset-top) 1.5rem 0;background:var(--color-surface);border-bottom:1px solid var(--color-border)}.top-bar-brand{display:flex;align-items:center;gap:.75rem}.top-bar-logo{height:63px;width:auto}.top-bar-divider{color:var(--color-border);font-size:1.5rem;font-weight:300}.top-bar-title{font-size:1.375rem;font-weight:700;letter-spacing:-.01em;color:#1a1d1e;text-shadow:2px 2px 0 rgba(60,200,219,.4);display:inline-flex;align-items:center;gap:.5rem}.top-bar-chevron{color:var(--color-border);font-weight:400;text-shadow:none}.top-bar-breadcrumb{font-size:1.125rem;font-weight:600;color:#1a1d1e;text-shadow:2px 2px 0 rgba(60,200,219,.4)}.avatar-menu{position:relative}.avatar-button{width:40px;height:40px;border-radius:50%;border:none;background:var(--color-primary);color:#fff;font-weight:600;font-size:.875rem;cursor:pointer;overflow:hidden;display:grid;place-items:center;transition:box-shadow .15s}.avatar-button:hover{box-shadow:0 0 0 3px #3cc8db40}.avatar-img{width:100%;height:100%;object-fit:cover}.avatar-dropdown{position:absolute;top:calc(100% + 8px);right:0;min-width:200px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:0 4px 12px #0000001a;overflow:hidden;z-index:50}.dropdown-email{padding:.75rem 1rem;font-size:.8125rem;color:var(--color-text-secondary);border-bottom:1px solid var(--color-border);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dropdown-item{display:block;width:100%;padding:.625rem 1rem;background:none;border:none;text-align:left;font-size:.875rem;color:var(--color-text);cursor:pointer;transition:background .1s}.dropdown-item:hover{background:var(--color-bg)}.dropdown-item:disabled{opacity:.6;cursor:not-allowed}.dropdown-item-upgrade{display:flex;align-items:center;justify-content:space-between;gap:.5rem;font-weight:600;color:#b07211;background:linear-gradient(180deg,#e8a02014,#e8a0200a)}.dropdown-item-upgrade:hover{background:#e8a02024}.dropdown-badge{display:inline-flex;align-items:center;padding:2px 7px;font-size:.6875rem;font-weight:700;letter-spacing:.02em;text-transform:uppercase;color:#fff;background:#e8a020;border-radius:999px;box-shadow:0 0 #e8a0208c;animation:dropdown-badge-pulse 2.2s ease-out infinite}@keyframes dropdown-badge-pulse{0%{box-shadow:0 0 #e8a0208c}60%{box-shadow:0 0 0 6px #e8a02000}to{box-shadow:0 0 #e8a02000}}.install-banner{position:fixed;left:12px;right:12px;bottom:calc(12px + env(safe-area-inset-bottom,0px));z-index:90;display:flex;align-items:center;gap:.75rem;padding:.75rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:14px;box-shadow:0 10px 30px #0000002e;animation:install-banner-in .25s ease-out}@keyframes install-banner-in{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.install-banner-icon{width:40px;height:40px;border-radius:9px;flex:0 0 auto}.install-banner-text{display:flex;flex-direction:column;gap:2px;flex:1 1 auto;min-width:0}.install-banner-text strong{font-size:.9375rem;font-weight:600;color:var(--color-text)}.install-banner-text span{font-size:.8125rem;color:var(--color-text-secondary);line-height:1.3}.install-banner-action{flex:0 0 auto;padding:.5rem .875rem;font-size:.875rem;font-weight:600;color:#fff;background:var(--color-primary);border:1px solid var(--color-primary);border-radius:8px;cursor:pointer;transition:background .15s,border-color .15s}.install-banner-action:hover{background:var(--color-primary-hover);border-color:var(--color-primary-hover)}.install-banner-close{flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;background:transparent;border:none;color:var(--color-text-secondary);border-radius:6px;cursor:pointer;transition:background .15s,color .15s}.install-banner-close:hover{background:var(--color-bg);color:var(--color-text)}.install-banner-tutorial{display:flex;flex-direction:column;gap:.5rem;width:100%}.install-banner-tutorial-head{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.install-banner-tutorial-head strong{font-size:.9375rem;font-weight:600;color:var(--color-text)}.install-banner-steps{margin:0;padding-left:1.25rem;font-size:.8125rem;line-height:1.5;color:var(--color-text)}.install-banner-steps li{margin-bottom:.25rem}.install-banner-glyph{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;margin:0 2px;vertical-align:-6px;color:var(--color-primary);background:#3cc8db1f;border-radius:5px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#10182873;display:grid;place-items:center;z-index:100;padding:1rem;animation:modal-fade-in .15s ease-out}@keyframes modal-fade-in{0%{opacity:0}to{opacity:1}}.modal-card{position:relative;width:100%;max-width:400px;background:var(--color-surface);border-radius:12px;box-shadow:0 20px 50px #0003;padding:1.75rem}.modal-card h1{font-size:1.5rem;font-weight:600;margin-bottom:.5rem}.modal-lede{color:var(--color-text-secondary);font-size:.9375rem;margin-bottom:1rem}.modal-features{list-style:none;padding:0;margin:0 0 1rem;display:flex;flex-direction:column;gap:.5rem}.modal-features li{font-size:.875rem;color:var(--color-text);padding-left:1.25rem;position:relative}.modal-features li:before{content:"✓";position:absolute;left:0;color:var(--color-success);font-weight:700}.modal-legal-links{font-size:.75rem;color:var(--color-text-secondary);text-align:center;margin:.5rem 0 0;line-height:1.5}.modal-legal-links a{color:inherit;text-decoration:underline}.modal-card-soft-wall .modal-legal-links{color:#ffffff8c}.modal-card-soft-wall .modal-legal-links a{color:#ffffffbf}.subscription-ribbon{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:.75rem;padding:.625rem 1rem;background:#fff3e0;color:#b35400;border-bottom:1px solid #ffcc80;font-size:.9375rem}.subscription-ribbon-text{text-align:center}.subscription-ribbon-btn{background:#e65100;color:#fff;border:none;border-radius:999px;padding:.375rem .875rem;font-size:.8125rem;font-weight:600;cursor:pointer;transition:background .15s}.subscription-ribbon-btn:hover{background:#cc4800}.modal-spinner-wrap{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:2rem 0}.modal-spinner{width:32px;height:32px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:modal-spinner-spin .8s linear infinite}@keyframes modal-spinner-spin{to{transform:rotate(360deg)}}.modal-spinner-label{font-size:.9375rem;color:var(--color-text-secondary)}.modal-card-wide{max-width:560px}.modal-backdrop-dark{background:#080c10c7}.modal-card-soft-wall{position:relative;background:radial-gradient(ellipse at 30% 0%,rgba(60,200,219,.12) 0%,transparent 55%),radial-gradient(ellipse at 80% 100%,rgba(42,179,197,.08) 0%,transparent 50%),#141a1f;color:#ffffffeb;border:1px solid rgba(255,255,255,.08);box-shadow:0 24px 60px #0000008c;padding:1.5rem 1.75rem 1.75rem}.modal-card-soft-wall h1{color:#fff;font-size:1.625rem}.modal-card-soft-wall .modal-lede{color:#ffffffb3}.modal-card-soft-wall .modal-features li{color:#ffffffd9}.modal-card-soft-wall .modal-features li:before{color:var(--color-primary)}.modal-card-soft-wall .plan-card{background:#ffffff0a;border-color:#ffffff1f;color:#fff}.modal-card-soft-wall .plan-card-highlight{border-color:var(--color-primary);box-shadow:0 0 0 1px var(--color-primary)}.modal-card-soft-wall .plan-card-label{color:#fff9}.modal-card-soft-wall .plan-card-price{color:#fff}.modal-card-soft-wall .plan-card-cadence{color:#ffffff8c}.modal-card-soft-wall .plan-card-skeleton{background:linear-gradient(90deg,#ffffff0a,#ffffff24,#ffffff0a);background-size:200% 100%}.modal-close-x{position:absolute;top:.625rem;right:.625rem;display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;background:transparent;border:none;color:var(--color-text-secondary);cursor:pointer;transition:background .15s,color .15s}.modal-close-x:hover{background:var(--color-bg);color:var(--color-text)}.modal-card-soft-wall .modal-close-x{color:#ffffff80}.modal-card-soft-wall .modal-close-x:hover{background:#ffffff1a;color:#fff}@media(max-width:600px){.modal-backdrop-dark{padding:0;place-items:stretch}.modal-card-soft-wall{max-width:none;width:100%;height:100%;min-height:100%;border-radius:0;border:none;box-shadow:none;overflow-y:auto;padding:calc(2.5rem + env(safe-area-inset-top)) 1.25rem calc(1.5rem + env(safe-area-inset-bottom))}.modal-card-soft-wall .modal-close-x{top:calc(.625rem + env(safe-area-inset-top));right:.875rem}}.soft-wall-fade{position:fixed;top:0;right:0;bottom:0;left:0;background:#141a1f;z-index:200;pointer-events:none}.soft-wall-fade-in{animation:soft-wall-fade-in .26s ease forwards}.soft-wall-fade-out{animation:soft-wall-fade-out .32s ease forwards}@keyframes soft-wall-fade-in{0%{opacity:0}to{opacity:1}}@keyframes soft-wall-fade-out{0%{opacity:1}to{opacity:0}}.settings-modal{padding:0;overflow:hidden}.settings-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem .875rem}.settings-header h1{font-size:1.25rem;font-weight:600;margin:0}.settings-close{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;border:none;background:transparent;color:var(--color-text-secondary);border-radius:6px;cursor:pointer;transition:background .15s,color .15s}.settings-close:hover{background:var(--color-bg);color:var(--color-text)}.settings-tabs{display:flex;gap:.25rem;padding:0 1.5rem;border-bottom:1px solid var(--color-border)}.settings-tab{position:relative;padding:.625rem .75rem .75rem;margin-bottom:-1px;font-size:.875rem;font-weight:500;color:var(--color-text-secondary);background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;transition:color .15s,border-color .15s}.settings-tab:hover{color:var(--color-text)}.settings-tab-active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.settings-panel{padding:1.25rem 1.5rem 1.5rem;display:flex;flex-direction:column;gap:1rem}.settings-panel-loading{display:flex;justify-content:center;padding:2rem 0}.settings-lede{margin:0;font-size:.9375rem;line-height:1.5;color:var(--color-text)}.settings-features{margin:0;padding-left:1.125rem;font-size:.875rem;line-height:1.55;color:var(--color-text)}.settings-features li{margin-bottom:.25rem}.settings-form{display:flex;flex-direction:column;gap:.875rem;margin:0}.settings-field{display:flex;flex-direction:column;gap:.375rem}.settings-field label{font-size:.8125rem;font-weight:600;color:var(--color-text-secondary)}.settings-field input{width:100%;box-sizing:border-box;padding:.5625rem .75rem;font-size:.9375rem;line-height:1.4;color:var(--color-text);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);outline:none;transition:border-color .15s,box-shadow .15s}.settings-field input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #3cc8db33}.settings-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:.25rem}.settings-radio{display:grid;grid-template-columns:20px 1fr;align-items:start;gap:.75rem;padding:.75rem .875rem;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);cursor:pointer;transition:border-color .15s,background .15s;font-weight:500;font-size:.875rem;color:var(--color-text)}.settings-radio+.settings-radio{margin-top:.5rem}.settings-radio:hover{border-color:#3cc8db80}.settings-radio:has(input:checked){border-color:var(--color-primary);background:#3cc8db0f}.settings-radio input[type=radio]{margin-top:.2rem;accent-color:var(--color-primary)}.settings-radio strong{display:block;color:var(--color-text);font-weight:600;font-size:.9375rem}.settings-radio small{display:block;margin-top:.25rem;font-size:.8125rem;font-weight:500;color:var(--color-text-secondary);line-height:1.4}.settings-actions .btn-secondary,.settings-actions .settings-primary,.settings-actions .settings-danger-action{flex:0 0 auto}.settings-primary{padding:.5625rem 1rem;font-size:.9375rem;font-weight:600;color:#fff;background:var(--color-primary);border:1px solid var(--color-primary);border-radius:var(--radius);cursor:pointer;transition:background .15s,border-color .15s}.settings-primary:hover:not(:disabled){background:var(--color-primary-hover);border-color:var(--color-primary-hover)}.settings-primary:disabled{opacity:.6;cursor:not-allowed}.settings-danger{display:flex;flex-direction:column;gap:.875rem;padding:1rem;margin-top:.5rem;background:#f044380a;border:1px solid rgba(240,68,56,.25);border-radius:var(--radius)}.settings-danger-head{display:flex;flex-direction:column;gap:.25rem}.settings-danger-head strong{font-size:.9375rem;font-weight:600;color:#b42318}.settings-danger-head span{font-size:.8125rem;line-height:1.45;color:var(--color-text-secondary)}.settings-danger-action{padding:.5625rem 1rem;font-size:.9375rem;font-weight:600;color:#fff;background:#f04438;border:1px solid #f04438;border-radius:var(--radius);cursor:pointer;transition:background .15s,border-color .15s}.settings-danger-action:hover:not(:disabled){background:#d92d20;border-color:#d92d20}.settings-danger-action:disabled{opacity:.55;cursor:not-allowed}.settings-danger-outline{padding:.5625rem 1rem;font-size:.9375rem;font-weight:600;color:#b42318;background:transparent;border:1px solid #f04438;border-radius:var(--radius);cursor:pointer;transition:background .15s,color .15s,border-color .15s}.settings-danger-outline:hover:not(:disabled){background:#f04438;color:#fff;border-color:#f04438}.settings-danger-outline:disabled{opacity:.55;cursor:not-allowed}.settings-danger-blocker{display:flex;flex-direction:column;gap:.625rem;padding:.75rem .875rem;background:#f7900914;border:1px solid rgba(247,144,9,.3);border-radius:var(--radius)}.settings-danger-blocker p{margin:0;font-size:.875rem;line-height:1.45;color:var(--color-text)}.settings-note{margin:0;font-size:.8125rem;line-height:1.45;color:var(--color-text-secondary);font-style:italic}.settings-inline-status{display:flex;align-items:center;gap:.625rem;padding:.625rem .75rem;font-size:.875rem;color:var(--color-text);background:#3cc8db14;border:1px solid rgba(60,200,219,.25);border-radius:var(--radius)}.settings-inline-status .modal-spinner{flex:0 0 auto;width:16px;height:16px}.settings-btn-with-spinner{display:inline-flex;align-items:center;gap:.5rem}.btn-spinner{display:inline-block;width:13px;height:13px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;opacity:.7;animation:modal-spinner-spin .8s linear infinite}.plan-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin:1rem 0}@media(max-width:480px){.plan-grid{grid-template-columns:1fr}}.plan-card{position:relative;padding:1rem;border:1px solid var(--color-border);border-radius:10px;display:flex;flex-direction:column;gap:.25rem;background:var(--color-surface)}.plan-card-highlight{border-color:var(--color-primary);box-shadow:0 0 0 1px var(--color-primary)}.plan-card-badge{position:absolute;top:-10px;right:12px;background:var(--color-primary);color:#fff;font-size:.6875rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;padding:2px 8px;border-radius:999px}.plan-card-label{font-size:.8125rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary)}.plan-card-price{font-size:1.5rem;font-weight:700;color:var(--color-text);min-height:1.75rem}.plan-card-cadence{font-size:.8125rem;color:var(--color-text-secondary);margin-bottom:.75rem}.plan-card-skeleton{display:inline-block;width:80px;height:1.25rem;border-radius:6px;background:linear-gradient(90deg,var(--color-bg) 0%,var(--color-border) 50%,var(--color-bg) 100%);background-size:200% 100%;animation:skeleton-pulse 1.2s ease-in-out infinite}@keyframes skeleton-pulse{0%{background-position:200% 0}to{background-position:-200% 0}}.plan-card button{padding:.5rem;background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius);font-size:.9375rem;font-weight:500;cursor:pointer;transition:background .15s}.plan-card button:hover:not(:disabled){background:var(--color-primary-hover)}.plan-card button:disabled{opacity:.6;cursor:not-allowed}.modal-actions{display:flex;gap:.5rem;margin-top:.5rem}.modal-actions button{flex:1}.report-modal-card{max-width:460px}.report-modal-header{display:flex;align-items:flex-start;gap:.75rem;margin-bottom:1rem}.report-modal-icon{flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;background:#e8a0201f;color:#e8a020;margin-top:2px}.report-modal-header h1{font-size:1.125rem;font-weight:600;margin:0 0 .25rem;line-height:1.3}.report-modal-lede{margin:0;font-size:.875rem;color:var(--color-text-secondary);line-height:1.45}.report-modal-label{display:block;font-size:.8125rem;font-weight:600;color:var(--color-text);margin-bottom:1rem}.report-modal-optional{font-weight:400;color:var(--color-text-secondary)}.report-modal-textarea{display:block;width:100%;margin-top:.4rem;padding:.625rem .75rem;font:inherit;font-size:.9375rem;line-height:1.45;color:var(--color-text);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);resize:vertical;min-height:96px;transition:border-color .15s,box-shadow .15s;box-sizing:border-box}.report-modal-textarea:focus{outline:none;border-color:#e8a020;box-shadow:0 0 0 3px #e8a0202e}.report-modal-textarea:disabled{opacity:.7;cursor:not-allowed}.report-modal-success{margin:0 0 .75rem;padding:.5rem .625rem;font-size:.875rem;color:#128250;background:#12b76a1a;border:1px solid rgba(18,183,106,.3);border-radius:var(--radius)}.report-modal-submit{display:inline-flex;align-items:center;justify-content:center;padding:.625rem 1rem;font-size:.9375rem;font-weight:600;color:#fff;background:#e8a020;border:1px solid #e8a020;border-radius:var(--radius);box-shadow:0 1px 2px #e8a02040,inset 0 1px #ffffff2e;cursor:pointer;transition:background .15s,box-shadow .15s,transform .1s,border-color .15s}.report-modal-submit:hover:not(:disabled){background:#d18d12;border-color:#d18d12;box-shadow:0 2px 6px #e8a02066,inset 0 1px #ffffff38}.report-modal-submit:active:not(:disabled){transform:translateY(1px);box-shadow:0 1px 2px #e8a02040}.report-modal-submit:focus-visible{outline:none;box-shadow:0 0 0 3px #e8a02059,inset 0 1px #ffffff2e}.report-modal-submit:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{padding:.625rem;background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border);border-radius:var(--radius);font-size:1rem;font-weight:500;cursor:pointer;transition:background .15s}.btn-secondary:hover{background:var(--color-bg)}.btn-secondary:disabled{opacity:.6;cursor:not-allowed}.main-content{max-width:1440px;margin:0 auto;padding:1.5rem}.top-bar-nav{position:absolute;left:50%;transform:translate(calc(-50% - 4rem));display:flex;gap:2rem}@media(max-width:1250px){.top-bar-nav{position:static;transform:none}}.top-bar-nav-link{position:relative;height:64px;padding:0;border:none;background:none;color:#b0b8c4;font-size:1.125rem;font-weight:600;cursor:pointer;transition:color .15s,text-shadow .15s}.top-bar-nav-link:hover{color:var(--color-text-secondary)}.top-bar-nav-link.active{color:#1a1d1e;text-shadow:2px 2px 0 rgba(60,200,219,.4)}.top-bar-nav-link.active:after{content:"";position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--color-primary);border-radius:3px 3px 0 0}.game-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.game-card{position:relative;background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;overflow:hidden;cursor:pointer;box-shadow:0 2px 8px #0000000f;transition:box-shadow .2s,transform .2s,filter .45s ease,opacity .4s ease}.game-card-loading{filter:saturate(.2) brightness(.97);pointer-events:none;animation:card-loading-flash .9s ease-in-out infinite}@keyframes card-loading-flash{0%{opacity:.6}50%{opacity:1}to{opacity:.6}}::view-transition-group(*){animation-duration:.7s;animation-timing-function:cubic-bezier(.45,0,.15,1)}::view-transition-old(*),::view-transition-new(*){animation-duration:.7s;animation-timing-function:cubic-bezier(.45,0,.15,1)}.game-card-wip{position:absolute;top:8px;right:8px;z-index:1;padding:2px 8px;font-size:.625rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:#e8a020;background:#ffffff1a;border:1px solid rgba(232,160,32,.3);border-radius:4px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.game-card:hover{box-shadow:0 8px 28px #00000024;transform:translateY(-3px)}.game-card-mastered{border-color:var(--color-success);box-shadow:0 0 0 1px var(--color-success),0 2px 8px #12b76a2e}.game-card-mastered:hover{box-shadow:0 0 0 1px var(--color-success),0 8px 28px #12b76a47}.game-thumbnail{overflow:hidden;line-height:0;border-bottom:1px solid var(--color-border);transition:filter .3s ease,opacity .3s ease}.game-card .game-thumbnail{border-bottom:none;padding-top:1rem;padding-bottom:5rem}.game-thumbnail svg{width:calc(100% + 1px);height:auto;display:block}.game-card-body{position:absolute;left:0;right:0;bottom:0;padding:.75rem 1rem;background:var(--color-surface);border-top:1px solid var(--color-border);transition:opacity .3s ease}.game-card-title{font-size:.9375rem;font-weight:600;color:var(--color-text);line-height:1.3;min-height:2.6em;margin:0}.ftg-finished-notions{display:grid;gap:10px;margin:1rem auto 0;max-width:560px;width:100%}.ftg-finished-notion{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 10px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:8px;text-align:center;min-width:0}.ftg-finished-notion-label{font-size:10px;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary);line-height:1.25;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.ftg-finished-notion-value{font-size:15px;font-weight:700;font-variant-numeric:tabular-nums;color:var(--color-text)}.ftg-finished-note{margin:.5rem auto 0;max-width:480px;text-align:center;font-size:.8125rem;color:var(--color-text-secondary);font-style:italic}.ftg-finished-notion-row{display:flex;align-items:baseline;justify-content:center;gap:6px}.ftg-finished-notion-change{font-size:15px;font-weight:700;font-variant-numeric:tabular-nums;white-space:nowrap}.mastery-tooltip{width:220px;max-width:calc(100vw - 32px);background:#1f2937;color:#f9fafb;border-radius:8px;padding:8px 10px;box-shadow:0 8px 24px #00000047;z-index:50;font-size:11px;line-height:1.4}.mastery-tooltip-row{margin-bottom:8px}.mastery-tooltip-row:last-child{margin-bottom:0}.mastery-tooltip-head{display:flex;justify-content:space-between;align-items:baseline;gap:8px;margin-bottom:4px}.mastery-tooltip-label{font-size:11px;color:#f9fafb;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mastery-tooltip-pct{font-size:10px;color:#f9fafba6;font-variant-numeric:tabular-nums;flex-shrink:0}.mastery-tooltip-bar{height:5px;background:#ffffff24;border-radius:2.5px;overflow:hidden}.mastery-tooltip-fill{height:100%;border-radius:2.5px;transition:width .2s ease,background .2s ease}@media(max-width:640px){.game-grid{grid-template-columns:1fr;gap:.5rem}}.game-card-disabled{opacity:.5;cursor:default}.game-card-disabled:hover{box-shadow:none;transform:none}.game-card-locked,.wizard-card-locked{cursor:pointer;opacity:.6;filter:grayscale(.8)}.game-card.game-card-locked:hover,.wizard-card.wizard-card-locked:hover{box-shadow:0 2px 8px #0000000f;transform:none;opacity:.6;filter:grayscale(.8)}.game-card-locked .game-thumbnail{filter:grayscale(1);opacity:.55}.game-card-locked .game-card-body{opacity:.65}.game-card-locked .wizard-card-badge,.wizard-card-locked .wizard-card-badge{animation:game-card-badge-fade-in .3s ease}@keyframes game-card-badge-fade-in{0%{opacity:0}to{opacity:1}}.vocab-wizard{display:flex;flex-direction:column;gap:3rem;padding-bottom:50vh}.wizard-section{scroll-margin-top:80px}.main-content>.wizard-section+.wizard-section{margin-top:3rem}.wizard-section-enter{animation:wizard-fade-in .35s ease-out}@keyframes wizard-fade-in{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.wizard-section-title{font-size:1.5rem;font-weight:700;color:var(--color-text);margin:0 0 .25rem}.wizard-section-subtitle{font-size:.9375rem;color:var(--color-text-secondary);margin:0 0 1.25rem}.wizard-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.wizard-card{position:relative;background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;overflow:hidden;cursor:pointer;box-shadow:0 2px 8px #0000000f;transition:box-shadow .2s,transform .2s,filter .45s ease,opacity .4s ease}.wizard-card-loading{filter:saturate(.2) brightness(.97);pointer-events:none;animation:card-loading-flash .9s ease-in-out infinite}.wizard-card-check{position:absolute;top:8px;left:8px;width:22px;height:22px;border-radius:6px;background:#ffffff8c;border:1.5px solid rgba(0,0,0,.18);display:flex;align-items:center;justify-content:center;color:transparent;cursor:pointer;z-index:2;opacity:.45;transition:background .15s,border-color .15s,color .15s,opacity .15s,transform .15s}.wizard-card:hover .wizard-card-check,.wizard-card-check:hover,.wizard-card-check:focus-visible{background:#fffffff2;border-color:#00000080;opacity:1}.wizard-card-check:hover{transform:scale(1.08)}.wizard-card-check:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.wizard-card-check-on,.wizard-card:hover .wizard-card-check-on,.wizard-card-check-on:hover{background:var(--color-primary);border-color:var(--color-primary);color:#fff;opacity:1}.wizard-card:hover{box-shadow:0 8px 28px #00000024;transform:translateY(-3px)}.wizard-card-selected{box-shadow:0 6px 20px #0000001f;transform:scale(1.03)}.wizard-card-selected:hover{box-shadow:0 8px 28px #00000024;transform:scale(1.03)}.wizard-card-dimmed{opacity:.4;filter:grayscale(.5)}.wizard-card-dimmed:hover{opacity:.7;filter:grayscale(0)}.wizard-card-disabled{opacity:.35;filter:grayscale(.6);cursor:default}.wizard-card-disabled:hover{box-shadow:0 2px 8px #0000000f;transform:none;opacity:.35;filter:grayscale(.6)}.wizard-card-disabled .wizard-card-badge{animation:game-card-badge-fade-in .3s ease}.wizard-card-body{padding:.75rem 1rem;display:flex;flex-wrap:wrap;align-items:center;gap:.25rem .5rem}.wizard-card-label{font-size:.9375rem;font-weight:600;color:var(--color-text)}.wizard-card-badge{position:absolute;top:8px;right:8px;z-index:1;font-size:.6875rem;font-weight:600;padding:.125rem .5rem;border-radius:100px;background:#fff3e0;color:#e65100;border:1px solid #ffcc80;white-space:nowrap}.wizard-card-mastery{position:absolute;top:8px;right:8px;z-index:1;display:inline-flex;align-items:center;gap:5px;font-variant-numeric:tabular-nums;padding:3px 10px;border-radius:999px;background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border);box-shadow:0 1px 3px #00000014;opacity:0;pointer-events:none;transition:opacity .3s ease}.wizard-card-mastery-ready{opacity:1;pointer-events:auto}.wizard-card-mastery svg{color:var(--color-text-secondary)}.wizard-card-mastery b{font-weight:700}.wizard-card-mastery-part{font-size:.75rem;font-weight:600;color:var(--color-text-secondary);padding-right:6px;margin-right:1px;border-right:1px solid var(--color-border)}.wizard-card-mastery-num{font-size:.9375rem;font-weight:700;color:var(--color-text)}.wizard-card-mastery-zero{color:var(--color-text-secondary)}.wizard-card-mastery-zero .wizard-card-mastery-num{color:var(--color-text-secondary);font-weight:600}.mastery-pill{position:absolute;top:8px;right:8px;z-index:1;display:inline-flex;align-items:center;gap:5px;font-variant-numeric:tabular-nums;padding:5px 12px;border-radius:999px;background:var(--color-surface);color:var(--color-text);box-shadow:0 1px 3px #00000014;opacity:0;pointer-events:none;transition:opacity .3s ease}.mastery-pill-ready{opacity:1;pointer-events:auto}.mastery-pill>svg:not(.mastery-pill-ring){color:var(--color-text-secondary)}.mastery-pill b{font-weight:700}.mastery-pill-ring{position:absolute;top:0;left:0;pointer-events:none;z-index:0}.mastery-pill>*:not(.mastery-pill-ring){position:relative;z-index:1}.mastery-pill-num{font-size:.9375rem;font-weight:700;color:var(--color-text)}.mastery-pill-zero{color:var(--color-text-secondary)}.mastery-pill-zero .mastery-pill-num{color:var(--color-text-secondary);font-weight:600}@media(max-width:640px){.wizard-grid{grid-template-columns:1fr;gap:.5rem}}@media(max-width:600px){.top-bar{flex-wrap:wrap;height:auto;padding:0 1rem;row-gap:0}.top-bar-brand{order:1;flex:1 1 auto;min-width:0;min-height:56px;gap:.5rem}.top-bar-logo{height:44px}.top-bar-divider,.top-bar-product-name,.top-bar-chevron{display:none}.top-bar-title{font-size:1rem;text-shadow:none;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.top-bar-breadcrumb{font-size:1rem;text-shadow:none}.avatar-menu{order:2;align-self:center}.top-bar-nav{order:3;flex:0 0 calc(100% + 2rem);margin:0 -1rem;border-top:1px solid var(--color-border);gap:0;justify-content:stretch}.top-bar-nav-link{flex:1;height:48px;font-size:1rem}.top-bar-nav-link.active:after{height:2px}}@media(max-width:600px){.main-content{padding:1rem}.subscription-ribbon{padding:.5rem .875rem;font-size:.875rem;gap:.5rem}.wizard-section-title{font-size:1.25rem}.wizard-section-subtitle{font-size:.875rem;margin-bottom:1rem}.vocab-wizard{gap:2rem;padding-bottom:25vh}}@media(max-width:640px){.game-card,.wizard-card{display:flex;align-items:stretch;min-height:76px}.game-card>.game-thumbnail,.wizard-card>.game-thumbnail{flex:0 0 96px;padding:0;border-bottom:none;border-right:1px solid var(--color-border);display:flex;align-items:center;justify-content:center;overflow:hidden}.game-card>.game-thumbnail svg,.wizard-card>.game-thumbnail svg{width:100%;height:auto;max-height:100%;display:block}.wizard-card>.game-thumbnail svg{width:140%;flex-shrink:0}.game-card-body{position:static;flex:1 1 auto;min-width:0;padding:.5rem .875rem 1.5rem;background:var(--color-surface);border-top:none;display:flex;align-items:flex-start}.game-card-title{font-size:.9375rem;line-height:1.3;min-height:0}.wizard-card-body{flex:1 1 auto;min-width:0;padding:.625rem .875rem;align-items:center}.wizard-card-label{font-size:.9375rem;line-height:1.3}.mastery-pill{top:auto;left:auto;bottom:6px;right:10px;transform:none;padding:0;background:transparent;border:none;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none;color:var(--color-text-secondary);gap:4px}.mastery-pill>.mastery-pill-ring{display:none}.mastery-pill>svg:not(.mastery-pill-ring){width:13px;height:13px}.mastery-pill .mastery-pill-num{font-size:12px;font-weight:700;color:var(--color-text)}.mastery-pill-zero .mastery-pill-num{color:var(--color-text-secondary);font-weight:600}.game-card:after{content:"";position:absolute;left:0;right:0;bottom:0;height:0;background:transparent;pointer-events:none;z-index:2;transition:height .2s ease}.game-card[style*=--mastery]:after{height:3px;background:linear-gradient(to right,var(--mastery-color) var(--mastery-pct),var(--color-border) var(--mastery-pct))}.wizard-card-body{align-items:flex-start;padding:.5rem .875rem 1.5rem}.wizard-card-mastery{top:auto;left:auto;bottom:6px;right:10px;transform:none;padding:0;background:transparent;border:none;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none;color:var(--color-text-secondary);gap:4px}.wizard-card-mastery svg{width:13px;height:13px}.wizard-card-mastery .wizard-card-mastery-num{font-size:12px;font-weight:700;color:var(--color-text)}.wizard-card-mastery-zero .wizard-card-mastery-num{color:var(--color-text-secondary);font-weight:600}.wizard-card-mastery-part{font-size:11px;padding-right:5px;margin-right:2px;border-right-color:var(--color-border)}.wizard-card-badge,.game-card-wip{top:50%;right:10px;transform:translateY(-50%)}.wizard-card-check{top:0;left:0;width:96px;height:100%;background:transparent;border:none;border-radius:0;box-shadow:none;opacity:1;padding:0}.wizard-card-check:before{content:"";position:absolute;top:6px;left:6px;width:22px;height:22px;border-radius:6px;background:#ffffff8c;border:1.5px solid rgba(0,0,0,.18);transition:background .15s,border-color .15s;pointer-events:none}.wizard-card:hover .wizard-card-check,.wizard-card-check:hover,.wizard-card-check:focus-visible,.wizard-card-check-on,.wizard-card:hover .wizard-card-check-on,.wizard-card-check-on:hover{background:transparent;border-color:transparent;box-shadow:none}.wizard-card:hover .wizard-card-check:before,.wizard-card-check:hover:before{background:#fffffff2;border-color:#00000080}.wizard-card-check-on:before,.wizard-card:hover .wizard-card-check-on:before,.wizard-card-check-on:hover:before{background:var(--color-primary);border-color:var(--color-primary)}.wizard-card-check>svg{position:absolute;top:11px;left:11px}.wizard-card-check:focus-visible{outline:none}.wizard-card-check:focus-visible:before{outline:2px solid var(--color-primary);outline-offset:2px}.wizard-card-selected,.wizard-card-selected:hover{transform:none}}@media(hover:none){.game-card:hover,.wizard-card:hover{transform:none;box-shadow:0 2px 8px #0000000f}.game-card-mastered:hover{box-shadow:0 0 0 1px var(--color-success),0 2px 8px #12b76a2e}.wizard-card-selected:hover{transform:scale(1.03);box-shadow:0 6px 20px #0000001f}.game-card:active,.wizard-card:active{transform:scale(.98)}.wizard-card-selected:active{transform:scale(1.01)}}@keyframes game-fade-in{0%{opacity:0}to{opacity:1}}@keyframes game-card-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.page-game{background:radial-gradient(ellipse at 30% 20%,rgba(60,200,219,.12) 0%,transparent 50%),radial-gradient(ellipse at 70% 80%,rgba(42,179,197,.08) 0%,transparent 50%),#141a1f;display:flex;flex-direction:column;animation:game-fade-in .8s ease}.page-game .ftg-question-area{animation:game-card-in 1s ease .2s both}.page-game .main-content{flex:1;display:flex;flex-direction:column;max-width:none;width:100%;padding:0}.ftg-header-counter{display:none}.ftg-header{display:flex;align-items:center;gap:.75rem;max-width:1400px;margin:0 auto;width:100%;padding:calc(.5rem + env(safe-area-inset-top)) 2.5rem .5rem;flex-wrap:nowrap}.ftg-back{display:inline-flex;align-items:center;gap:.25rem;background:none;border:none;color:#fff6;font-size:.75rem;font-weight:500;cursor:pointer;padding:.25rem 0;transition:color .15s;white-space:nowrap;flex-shrink:0}.ftg-back:hover{color:#ffffffb3}.ftg-header-title{flex:1 1 0;min-width:0}.ftg-header-title h1{font-size:.9375rem;font-weight:500;color:#ffffff80;margin:0;letter-spacing:.01em;text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ftg-header-no-back .ftg-header-title h1{text-align:left}.ftg-header-actions{display:flex;align-items:center;gap:.5rem;flex:1 1 0;min-width:0;justify-content:flex-end;flex-wrap:nowrap}.ftg-header-actions .ftg-pills{margin-right:auto}.ftg-pills{display:flex;gap:.5rem;flex-wrap:nowrap}.ftg-pill{padding:.375rem .625rem;border-radius:100px;border:1px solid var(--color-border);background:var(--color-bg);font-size:.8125rem;color:var(--color-text-secondary);white-space:nowrap}.ftg-pill b{color:var(--color-text);font-weight:700}.ftg-header .ftg-pill{background:#ffffff0f;border-color:#ffffff1a;color:#ffffff80;font-size:.75rem;padding:.25rem .5rem}.ftg-header .ftg-pill b{color:#ffffffd9}button.ftg-pill-clickable{cursor:pointer;font-family:inherit;font-size:inherit;line-height:inherit;color:inherit;transition:background .15s ease,border-color .15s ease,color .15s ease}button.ftg-pill-clickable:hover{background:#ffffff1f;border-color:#fff3;color:#ffffffbf}.ftg-grid-wrapper{position:relative;width:100%;flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:.5rem 1.5rem 2rem}.ftg-fullscreen-loading{flex:1;display:flex;align-items:center;justify-content:center;min-height:100vh}.ftg-fullscreen-loading .ftg-loading-dots{font-size:2rem;color:#ffffff80;text-shadow:none}.ftg-loading-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#1a1d21b3;border-radius:12px;z-index:10;display:grid;place-items:center}.ftg-loading-dots{font-size:1.5rem;font-weight:700;color:var(--color-text);text-shadow:2px 2px 0 rgba(60,200,219,.4);letter-spacing:.15em}.ftg-loading-dots:after{content:".";animation:ftg-dots 1.2s steps(1) infinite}@keyframes ftg-dots{0%{content:"."}33%{content:".."}66%{content:"..."}}.ftg-grid{display:block;width:100%;max-width:720px;margin:0 auto}.ftg-ref-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:100;opacity:0;pointer-events:none;transition:opacity .3s ease}.ftg-ref-overlay.open{opacity:1;pointer-events:auto}.ftg-ref-panel{position:fixed;top:0;right:0;bottom:0;width:min(520px,90vw);background:var(--color-surface);border-left:1px solid var(--color-border);box-shadow:-4px 0 24px #0000001a;z-index:101;transform:translate(100%);transition:transform .3s ease;overflow-y:auto;padding:1.25rem}.ftg-ref-panel.open{transform:translate(0)}.ftg-ref-panel .ftg-card{border:none;padding:0;box-shadow:none;border-radius:0}.ftg-ref-close{display:flex;align-items:center;gap:.375rem;background:none;border:none;cursor:pointer;font-size:.8125rem;font-weight:600;color:var(--color-text-secondary);padding:.25rem 0;margin-bottom:.75rem}.ftg-ref-close:hover{color:var(--color-text)}.ftg-header-btn,.ftg-ref-toggle{display:inline-flex;align-items:center;gap:.375rem;padding:.3rem .625rem;border-radius:100px;border:1px solid rgba(255,255,255,.15);background:#ffffff14;box-shadow:0 1px 3px #0003,inset 0 1px #ffffff0f;cursor:pointer;font-size:.8125rem;font-weight:500;color:#ffffff8c;white-space:nowrap;transition:background .15s,border-color .15s,color .15s,box-shadow .15s}.ftg-header-btn:hover,.ftg-ref-toggle:hover{background:#ffffff24;border-color:#ffffff40;color:#ffffffd9;box-shadow:0 2px 5px #00000040,inset 0 1px #ffffff14}.ftg-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:14px;padding:1.5rem 1.75rem;box-shadow:0 8px 32px #00000040,0 2px 8px #00000026}.ftg-card-header{display:flex;align-items:center;justify-content:space-between;gap:.625rem;font-size:.875rem;font-weight:600;color:var(--color-text-secondary);margin-bottom:.75rem}.ftg-controls{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:.75rem}.ftg-btn{display:inline-flex;align-items:center;gap:.375rem;padding:.5rem .875rem;border-radius:var(--radius);border:1px solid #d0d5dd;background:#fff;color:#344054;font-size:.8125rem;font-weight:600;cursor:pointer;box-shadow:0 1px 2px #1018280d;transition:background .15s,border-color .15s,box-shadow .15s,color .15s}.ftg-btn:hover:not(:disabled){background:#f9fafb;border-color:#98a2b3;color:#1d2939}.ftg-btn:focus-visible{outline:none;box-shadow:0 1px 2px #1018280d,0 0 0 4px #3cc8db33}.ftg-btn:disabled{opacity:.4;cursor:not-allowed}.ftg-btn-primary{background:var(--color-primary);border-color:var(--color-primary);color:#fff;font-weight:600;box-shadow:0 1px 2px #1018280d}.ftg-btn-primary:hover:not(:disabled){background:var(--color-primary-hover);border-color:var(--color-primary-hover);color:#fff}.ftg-btn-primary:focus-visible{box-shadow:0 1px 2px #1018280d,0 0 0 4px #3cc8db3d}.ftg-btn-danger{background:#fff;border-color:#fda29b;color:#b42318}.ftg-btn-danger:hover{background:#fef3f2;border-color:#f97066;color:#912018}.ftg-btn-danger:focus-visible{box-shadow:0 1px 2px #1018280d,0 0 0 4px #f0443824}.ftg-btn-warn{background:#fff;border-color:#fec84b;color:#b54708}.ftg-btn-warn:hover{background:#fffbeb;border-color:#f59e0b;color:#93370d}.ftg-btn-warn:focus-visible{box-shadow:0 1px 2px #1018280d,0 0 0 4px #f59e0b24}.ftg-btn-ghost{background:transparent;border-color:transparent;color:#475467;box-shadow:none}.ftg-btn-ghost:hover{background:#f9fafb;border-color:transparent;color:#344054}.ftg-question-area{background:var(--color-surface);border:1px solid var(--color-border);border-radius:14px;padding:1.5rem 1.75rem;box-shadow:0 8px 32px #00000040,0 2px 8px #00000026}.ftg-question-top{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-bottom:.75rem}.ftg-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.375rem .625rem;border-radius:100px;border:1px solid var(--color-border);background:var(--color-surface);font-size:.8125rem;color:var(--color-text-secondary)}.ftg-badge b{color:var(--color-text);font-weight:600}.ftg-badge-clickable{cursor:pointer;-webkit-user-select:none;user-select:none;border-color:#3cc8db66;background:linear-gradient(180deg,#3cc8db26,#3cc8db14);box-shadow:0 1px 3px #0003,inset 0 1px #3cc8db26;transition:border-color .15s,background .15s,box-shadow .15s,transform .1s}.ftg-badge-clickable:hover{border-color:#3cc8db99;background:linear-gradient(180deg,#3cc8db38,#3cc8db1f);box-shadow:0 2px 6px #00000040,inset 0 1px #3cc8db33}.ftg-badge-clickable:active{transform:scale(.97);background:#3cc8db33;box-shadow:0 1px 2px #0003}.ftg-badge-feather{color:#3cc8db;flex-shrink:0}.ftg-dot{width:8px;height:8px;border-radius:50%;background:var(--color-primary);box-shadow:0 0 0 3px #3cc8db26}.ftg-tag{font-size:.75rem;padding:.25rem .5rem;border-radius:100px;border:1px solid var(--color-border);color:var(--color-text-secondary);white-space:nowrap}.ftg-prompt{padding:.875rem;border-radius:var(--radius);border:1px solid var(--color-border);background:var(--color-surface);margin-bottom:.75rem}.ftg-prompt-label{font-size:.75rem;color:var(--color-text-secondary);margin-bottom:.5rem}.mcq-prompt-actions{position:absolute;top:.375rem;right:.375rem;display:flex;align-items:center;gap:.5rem}.mcq-prompt-actions .ftg-btn{padding:.25rem .625rem;font-size:.8125rem}.ftg-sentence{font-size:1.0625rem;line-height:1.5;color:var(--color-text)}.ftg-sentence .gap{display:inline-flex;align-items:center;justify-content:center;padding:.125rem .5rem;border-radius:6px;border:1.5px dashed var(--color-primary);background:#3cc8db14;color:var(--color-primary);font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-weight:700;min-width:80px;font-size:.9375rem}.ftg-input-area{display:grid;gap:.625rem}.ftg-input{width:100%;padding:.75rem .875rem;border-radius:var(--radius);border:2px solid var(--color-primary);background:var(--color-surface);color:var(--color-text);font-weight:600;font-size:.9375rem;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;outline:none;transition:border-color .15s,box-shadow .15s}.ftg-multi-gap-row{display:flex;gap:.5rem}.ftg-multi-gap-row .ftg-input{flex:1;min-width:0}.ftg-input:focus{border-color:var(--color-primary-hover);box-shadow:0 0 0 4px #3cc8db40}.ftg-input:disabled{opacity:.5}.ftg-input-correct,.ftg-input-correct:focus{border-color:#86efac;box-shadow:0 0 0 4px #86efac4d}.ftg-input-error,.ftg-input-error:focus{border-color:#fca5a5;box-shadow:0 0 0 4px #fca5a54d}.ftg-input-done,.ftg-input-done:focus{border-color:#67e8f9;box-shadow:0 0 0 6px #67e8f959}.ftg-input-revealed{background:#fef3c7;border-color:#f59e0b;color:#92400e;font-weight:700;cursor:default}.ftg-input-row{display:flex;gap:.5rem;align-items:center;justify-content:flex-end}.ftg-feedback{position:relative;padding:.75rem;border-radius:var(--radius);border:1px solid var(--color-border);background:var(--color-surface);min-height:48px;display:flex;align-items:center;line-height:1.4;font-size:.875rem;color:var(--color-text)}.ftg-feedback>span{flex:1;min-width:0}.ftg-feedback-bad>span{padding-right:1.75rem}.ftg-feedback-report{position:absolute;top:6px;right:6px;display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;padding:0;border:1px solid rgba(240,68,56,.5);border-radius:6px;background:#fff9;color:#f04438;cursor:pointer;transition:background .15s,color .15s,border-color .15s,transform .15s}.ftg-feedback-report svg{transform:translate(2px)}.ftg-feedback-report:hover{background:#f04438;color:#fff;border-color:#f04438}.ftg-feedback-report:active{transform:scale(.94)}.text-tooltip{background:#1f2937;color:#f9fafb;font-size:.75rem;font-weight:500;line-height:1.3;padding:5px 8px;border-radius:6px;box-shadow:0 4px 12px #0003;z-index:60;max-width:240px;pointer-events:none}.ftg-feedback-notes{display:inline-flex;align-items:center;gap:.25rem;padding:0;padding-right:.5rem;border:none;background:none;font-size:.875rem;font-weight:600;color:#3cc8db;cursor:pointer;transition:opacity .15s}.ftg-feedback-notes:hover{opacity:.75}.ftg-feedback-good{border-color:#12b76a66;background:#12b76a0f}.ftg-feedback-bad{border-color:#f0443866;background:#f044380f}.ftg-feedback-bad u{text-decoration:none;color:#f04438;font-weight:700}.ftg-feedback-warn{border-color:#f7900959;background:#f790090d}.ftg-footer-pills{display:flex;gap:.5rem;flex-wrap:wrap}.ftg-progress{display:flex;height:8px;border-radius:100px;background:var(--color-border);overflow:hidden}.ftg-progress-correct,.ftg-progress-revealed,.ftg-progress-wrong{height:100%;transition:width .3s ease}.ftg-progress-correct{background:#86efac}.ftg-progress-wrong{background:#f89696}.ftg-progress-revealed{background:#d1d5db}.ftg-rules{display:grid;gap:.625rem}.ftg-rule{padding:.75rem;border-radius:var(--radius);border:1px solid var(--color-border);background:var(--color-bg)}.ftg-vocab-item{position:relative;padding-right:0;border-radius:6px;scroll-margin-top:1rem;scroll-margin-bottom:1rem;transition:background .2s ease,box-shadow .2s ease,opacity .15s ease}.ftg-vocab-item-skipped{opacity:.45}.ftg-vocab-item-skipped .ftg-vocab-phrase-line b{text-decoration:line-through}.ftg-vocab-phrase-line{display:inline}.ftg-vocab-edit-toggle{font-size:.75rem;font-weight:600;padding:.25rem .625rem;border-radius:999px;border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text-secondary);cursor:pointer;transition:background .15s,color .15s,border-color .15s}.ftg-vocab-edit-toggle:hover{background:var(--color-bg);color:var(--color-text);border-color:var(--color-text-secondary)}.ftg-vocab-edit-toggle[aria-pressed=true]{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.ftg-vocab-clear-skipped{font-size:.75rem;font-weight:600;padding:.25rem .625rem;border-radius:999px;border:1px solid transparent;background:transparent;color:var(--color-error);cursor:pointer;transition:background .15s,border-color .15s,opacity .15s}.ftg-vocab-clear-skipped:hover:not(:disabled){background:#f0443814;border-color:#f0443866}.ftg-vocab-clear-skipped:disabled{opacity:.5;cursor:not-allowed}.ftg-vocab-skip-pill{position:absolute;top:0;right:0;display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:999px;border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text-secondary);font-size:.6875rem;font-weight:600;letter-spacing:.02em;cursor:pointer;transition:background .15s,color .15s,border-color .15s}.ftg-vocab-skip-pill:hover{background:var(--color-bg);color:var(--color-text);border-color:var(--color-text-secondary)}.ftg-vocab-skip-pill-on{background:var(--color-error);border-color:var(--color-error);color:#fff;opacity:1}.ftg-vocab-skip-pill-on:hover{background:#d93b30;border-color:#d93b30;color:#fff}.ftg-vocab-item:has(.ftg-vocab-skip-pill) .ftg-vocab-phrase-line{padding-right:72px}.ftg-skip-ignored-banner{display:flex;align-items:center;gap:.625rem;margin-bottom:.75rem;padding:.625rem 1rem;background:#e8a02024;border:1px solid rgba(232,160,32,.45);border-radius:8px;color:#f5c061;font-size:.8125rem;line-height:1.35}.ftg-skip-ignored-banner svg{flex-shrink:0;color:#f5c061}@media(max-width:640px){.ftg-skip-ignored-banner{font-size:.75rem;padding:.5rem .75rem}}.ftg-vocab-mastered,.ftg-vocab-partial{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;margin-right:6px;border-radius:999px;color:#fff;vertical-align:-2px}.ftg-vocab-mastered{background:var(--color-success)}.ftg-vocab-partial{background:#d99a1a}.ftg-tag-mastered{color:var(--color-success);font-weight:600}.ftg-tag-partial,.ftg-finished-stat-sublabel{color:#d99a1a;font-weight:600}.ftg-vocab-item-active{background:#3cc8db2e;box-shadow:0 0 0 10px #3cc8db2e;animation:ftg-vocab-pulse 1.4s ease-out}@keyframes ftg-vocab-pulse{0%{background:#3cc8db73;box-shadow:0 0 0 10px #3cc8db73}to{background:#3cc8db2e;box-shadow:0 0 0 10px #3cc8db2e}}.ftg-rule-top{display:flex;align-items:flex-start;justify-content:space-between;gap:.5rem;margin-bottom:.375rem}.ftg-rule-top b{font-size:.875rem;color:var(--color-text)}.ftg-small{font-size:.8125rem;color:var(--color-text-secondary)}.ftg-kbd{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.75rem;padding:.125rem .375rem;border-radius:4px;border:1px solid var(--color-border);background:var(--color-bg);color:var(--color-text)}.ftg-header .ftg-kbd{border-color:#ffffff26;background:#ffffff14;color:#ffffff80}.ftg-original-label{display:block;font-size:.75rem;font-weight:600;color:var(--color-text-secondary);margin-bottom:.25rem;margin-top:.5rem}.ftg-original-label:first-child{margin-top:0}.ftg-keywords{display:inline-block;margin-top:.5rem;padding:.25rem .625rem;border-radius:100px;border:1px solid rgba(60,200,219,.3);background:#3cc8db14;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.8125rem;font-weight:700;color:var(--color-primary)}.mcq-choices{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}@media(max-width:640px){.mcq-choices{grid-template-columns:1fr}}.mcq-choice{text-align:left;padding:.75rem .875rem;border-radius:var(--radius);border:2px solid var(--color-border);background:var(--color-surface);color:var(--color-text);font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .15s;display:flex;align-items:center;gap:.625rem}.mcq-choice:hover:not(:disabled){border-color:var(--color-primary);background:#3cc8db0f;box-shadow:0 0 0 3px #3cc8db1a}.mcq-choice:disabled{cursor:default}.mcq-choice-num{display:inline-flex;width:24px;height:24px;align-items:center;justify-content:center;border-radius:50%;font-size:.75rem;font-weight:700;border:1px solid var(--color-border);color:var(--color-text-secondary);background:var(--color-bg);flex-shrink:0}.mcq-choice-correct{border-color:#12b76a80;background:#12b76a14}.mcq-choice-correct .mcq-choice-num{border-color:var(--color-success);background:#12b76a26;color:var(--color-success)}.mcq-choice-wrong{border-color:#f0443880;background:#f0443814}.mcq-choice-wrong .mcq-choice-num{border-color:var(--color-error);background:#f0443826;color:var(--color-error)}.mcq-choice-disabled{opacity:.5}.ftg-finished-summary{display:flex;flex-direction:column;align-items:center;gap:1.5rem;padding:2rem 1rem}.ftg-finished-title{font-size:1.75rem;font-weight:700;color:#1a1d1e;text-shadow:2px 2px 0 rgba(60,200,219,.4);margin:0;letter-spacing:-.01em}.ftg-finished-stats{display:flex;gap:1.5rem;flex-wrap:wrap;justify-content:center}.ftg-finished-stat{display:flex;flex-direction:column;align-items:center;gap:.25rem;min-width:4rem}.ftg-finished-stat-value{font-size:2rem;font-weight:700;color:#1a1d1e;text-shadow:2px 2px 0 rgba(60,200,219,.4)}.ftg-finished-stat-value-muted{color:var(--color-text-secondary);text-shadow:2px 2px 0 rgba(0,0,0,.06)}.ftg-finished-stat-label{font-size:.6875rem;font-weight:500;color:#667085;text-transform:uppercase;letter-spacing:.04em}.ftg-finished-stat-row{position:relative;display:inline-block}.ftg-finished-stat-change{position:absolute;left:100%;top:0;margin-left:.5rem;font-size:1.25rem;font-weight:700;font-variant-numeric:tabular-nums;white-space:nowrap}.ftg-finished-stat-change-up{color:#12b76a}.ftg-finished-actions{display:flex;gap:.75rem;margin-top:.5rem}.ftg-finished-actions .ftg-btn{font-size:.9375rem;padding:.5rem 1rem}.st-starter{margin-top:.5rem;padding:.375rem .625rem;border-radius:6px;background:#3cc8db0f;border:1px solid rgba(60,200,219,.2);font-size:.8125rem;color:var(--color-text-secondary)}.st-starter b{color:var(--color-primary);font-weight:700}.mcq-clarifier{margin-top:.5rem;padding:.375rem .625rem;border-radius:6px;background:#3cc8db0f;border:1px solid rgba(60,200,219,.2);font-size:.8125rem;color:var(--color-text-secondary)}.mcq-clarifier b{color:var(--color-primary);font-weight:700}.st-textarea{width:100%;padding:.75rem .875rem;border-radius:var(--radius);border:2px solid var(--color-primary);background:var(--color-surface);color:var(--color-text);font-size:.9375rem;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;outline:none;resize:none;overflow:hidden;transition:border-color .15s,box-shadow .15s}.st-textarea:focus{border-color:var(--color-primary-hover);box-shadow:0 0 0 4px #3cc8db40}.st-textarea:disabled{opacity:.5}.st-textarea[rows="1"]{resize:none}.st-corrected{line-height:1.8;box-sizing:border-box}.st-corrected del{text-decoration:line-through;color:#f04438;font-weight:600}.st-corrected ins{text-decoration:none;color:#15803d;font-weight:700}.ftg-not-found{text-align:center;padding:4rem 1rem}.ftg-not-found h2{font-size:1.25rem;color:var(--color-text);margin-bottom:1rem}@media(max-width:640px){.ftg-header{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;max-width:none;padding:calc(.375rem + env(safe-area-inset-top)) .75rem .375rem;gap:.5rem}.ftg-header-no-back{grid-template-columns:auto 1fr}.ftg-back{justify-self:start}.ftg-header-title{flex:unset;min-width:0}.ftg-header-title h1{font-size:.8125rem;text-align:center;white-space:nowrap}.ftg-header-counter{display:inline;color:#fff6;font-weight:500}.ftg-header-type,.ftg-pills{display:none}.ftg-header-actions{justify-self:end;flex:0 0 auto;width:auto;flex-wrap:nowrap;gap:.25rem;justify-content:flex-end}.ftg-header-btn{padding:.375rem;font-size:0;gap:0;width:32px;height:32px;justify-content:center}.ftg-header-btn>svg{width:16px;height:16px}.ftg-header .ftg-header-actions>.ftg-header-btn:first-of-type{display:none}.page-game{height:var(--app-vh, 100dvh);min-height:0;overflow:hidden}.ftg-grid-wrapper{justify-content:center;overflow:auto;padding:.5rem .75rem calc(1rem + env(safe-area-inset-bottom))}}.onboarding-page{display:flex;flex-direction:column;height:var(--app-vh, 100dvh);min-height:0;overflow:hidden}.onboarding-shell{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.5rem;padding:calc(2rem + env(safe-area-inset-top)) 1.5rem calc(2rem + env(safe-area-inset-bottom));max-width:480px;width:100%;margin:0 auto;overflow-y:auto}.onboarding-progress{display:flex;gap:.5rem}.onboarding-progress-dot{width:8px;height:8px;border-radius:50%;background:#ffffff26;transition:background .2s}.onboarding-progress-dot-on{background:var(--color-primary)}.onboarding-card{width:100%;display:flex;flex-direction:column;gap:1.25rem;animation:onboarding-card-in .4s ease}@keyframes onboarding-card-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.onboarding-title{color:#fff;font-size:2rem;font-weight:700;margin:0;text-align:center;line-height:1.2}.onboarding-subtitle{color:#ffffffb3;font-size:1rem;margin:0;text-align:center}.onboarding-input{width:100%;padding:.875rem 1rem;border-radius:12px;border:1px solid rgba(255,255,255,.18);background:#ffffff0f;color:#fff;font-size:1rem;font-family:inherit;outline:none;transition:border-color .15s,background .15s}.onboarding-input:focus{border-color:var(--color-primary);background:#ffffff1a}.onboarding-input[type=date]{color-scheme:dark}.onboarding-goal-list{display:flex;flex-direction:column;gap:.625rem}.onboarding-goal{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;border-radius:12px;border:1px solid rgba(255,255,255,.18);background:#ffffff0f;color:#ffffffd9;font-size:.95rem;font-family:inherit;text-align:left;cursor:pointer;transition:border-color .15s,background .15s,color .15s}.onboarding-goal:hover{border-color:#3cc8db66}.onboarding-goal-selected{border-color:var(--color-primary);background:#3cc8db1f;color:#fff}.onboarding-goal-check{width:22px;height:22px;border-radius:50%;border:1.5px solid rgba(255,255,255,.3);display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--color-primary)}.onboarding-goal-selected .onboarding-goal-check{border-color:var(--color-primary);background:#3cc8db2e}.onboarding-continue{margin-top:.5rem;padding:.875rem 1.25rem;border:none;border-radius:12px;background:var(--color-primary);color:#0b1014;font-size:1rem;font-weight:600;font-family:inherit;cursor:pointer;transition:background .15s,opacity .15s}.onboarding-continue:hover:not(:disabled){background:var(--color-primary-hover)}.onboarding-continue:disabled{opacity:.45;cursor:not-allowed}.onboarding-error{color:#ff8a8a;font-size:.875rem;margin:0;text-align:center}.onboarding-intro-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.625rem;color:#ffffffc7;font-size:.95rem}.onboarding-intro-list li{position:relative;padding-left:1.25rem}.onboarding-intro-list li:before{content:"";position:absolute;left:0;top:.55em;width:6px;height:6px;border-radius:50%;background:var(--color-primary)}.month-picker{display:flex;flex-direction:column;gap:.875rem;padding:1rem;border-radius:14px;border:1px solid rgba(255,255,255,.14);background:#ffffff0a}.month-picker-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.month-picker-nav{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;background:#ffffff0f;border:1px solid rgba(255,255,255,.12);color:#fffc;cursor:pointer;transition:background .15s,border-color .15s,color .15s,opacity .15s}.month-picker-nav:hover:not(:disabled){background:#ffffff1f;border-color:#ffffff38;color:#fff}.month-picker-nav:disabled{opacity:.3;cursor:not-allowed}.month-picker-year{color:#fff;font-size:1.125rem;font-weight:600;letter-spacing:.02em}.month-picker-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem}.month-picker-month{padding:.625rem .5rem;border-radius:10px;border:1px solid rgba(255,255,255,.14);background:#ffffff0a;color:#ffffffd1;font-family:inherit;font-size:.9rem;font-weight:500;cursor:pointer;transition:background .15s,border-color .15s,color .15s,opacity .15s}.month-picker-month:hover:not(:disabled):not(.month-picker-month-selected){border-color:#3cc8db66;background:#3cc8db14;color:#fff}.month-picker-month-selected{background:var(--color-primary);border-color:var(--color-primary);color:#0b1014}.month-picker-month:disabled{opacity:.28;cursor:not-allowed}
