*,*: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{height:120px;width:120px;object-fit:cover;border-radius:50%;border:3px solid rgba(60,200,219,.4);margin-bottom:2rem;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-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}.page{min-height:100vh}.top-bar{display:flex;align-items:center;justify-content:space-between;height:64px;padding:0 1.5rem;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}.beta-tag{font-size:.625rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:.125rem .4375rem;border-radius:100px;background:#fff3e0;color:#e65100;border:1px solid #ffcc80;text-shadow:none}.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}.main-content{max-width:1440px;margin:0 auto;padding:1.5rem}.game-filters-bar{margin-bottom:2rem;padding:1rem 1.5rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px}.filters-desktop{display:flex;align-items:center;justify-content:center;gap:1.5rem}.filters-mobile{display:none}.filter-group{display:flex;align-items:center;gap:.625rem}.filter-chips{display:flex;gap:.375rem;flex-wrap:wrap;justify-content:center}@media(max-width:1200px){.filter-group{flex-direction:column;gap:.375rem}}.filter-label{font-size:.8125rem;font-weight:700;color:var(--color-text);text-transform:uppercase;letter-spacing:.04em}.filter-divider{width:1px;height:28px;background:var(--color-border)}.filter-chip{padding:.4375rem 1rem;border:1.5px solid var(--color-border);border-radius:100px;background:var(--color-surface);color:var(--color-text-secondary);font-size:.8125rem;font-weight:600;cursor:pointer;transition:all .15s}.filter-chip:hover{border-color:var(--color-primary);color:var(--color-primary)}.filter-chip.active{background:var(--color-primary);border-color:var(--color-primary);color:var(--color-surface)}.filter-chip.category-chip-grammar:hover{border-color:#3cc8db;color:#3cc8db}.filter-chip.category-chip-grammar.active{background:#3cc8db;border-color:#3cc8db;color:var(--color-surface)}.filter-chip.category-chip-vocabulary:hover{border-color:#8b6cc1;color:#8b6cc1}.filter-chip.category-chip-vocabulary.active{background:#8b6cc1;border-color:#8b6cc1;color:var(--color-surface)}.game-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1.25rem}.game-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;overflow:hidden;cursor:pointer;transition:box-shadow .2s,transform .2s}.game-card:hover{box-shadow:0 6px 20px #00000014;transform:translateY(-2px)}.game-thumbnail{aspect-ratio:2 / 1;overflow:hidden;border-bottom:1px solid var(--color-border)}.game-thumbnail svg{width:100%;height:100%;display:block}.game-card-body{padding:.875rem 1rem}.game-card-tags{display:flex;gap:.375rem;margin-bottom:.5rem}.game-tag{display:inline-block;padding:.125rem .5rem;border-radius:100px;font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em}.game-tag.category-grammar{background:#e4f7f9;color:#1a6e7a}.game-tag.category-vocabulary{background:#ede8f5;color:#5c3d8f}.game-tag.type-tag{background:var(--color-bg);color:var(--color-text-secondary);text-transform:none;font-size:.69rem}.game-card-title{font-size:.9375rem;font-weight:600;color:var(--color-text);margin-bottom:.25rem}.game-card-sub{font-size:.8125rem;color:var(--color-text-secondary)}@media(max-width:640px){.game-grid{grid-template-columns:1fr}.filters-desktop{display:none}.filters-mobile{display:flex;gap:.75rem;padding:1rem}.filter-select-group{flex:1;display:flex;flex-direction:column;gap:.375rem}.filter-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;padding:.5rem 2rem .5rem .75rem;border:1.5px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M3 4.5L6 7.5L9 4.5' fill='none' stroke='%23667085' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") no-repeat right .75rem center;font-size:.875rem;font-weight:500;color:var(--color-text);cursor:pointer;transition:border-color .15s}.filter-select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #3cc8db33}}@media(max-width:390px){.filters-mobile{flex-direction:column}}.game-card-disabled{opacity:.5;cursor:default}.game-card-disabled:hover{box-shadow:none;transform:none}.ftg-back{display:inline-flex;align-items:center;gap:.375rem;background:none;border:none;color:var(--color-text-secondary);font-size:.875rem;font-weight:500;cursor:pointer;padding:0;margin-bottom:1rem;transition:color .15s}.ftg-back:hover{color:var(--color-primary)}.ftg-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 1.25rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;margin-bottom:1rem;flex-wrap:wrap}.ftg-header-title h1{font-size:1rem;font-weight:700;color:var(--color-text);margin:0}.ftg-header-title p{font-size:.8125rem;color:var(--color-text-secondary);margin:.25rem 0 0}.ftg-pills{display:flex;gap:.5rem;flex-wrap:wrap}.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-grid-wrapper{position:relative}.ftg-loading-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#fafafa99;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:grid;grid-template-columns:1.05fr .95fr;gap:1rem}@media(max-width:900px){.ftg-grid{grid-template-columns:1fr}}.ftg-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;padding:1rem 1.25rem}.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-bottom:.75rem}.ftg-btn{padding:.5rem .75rem;border-radius:var(--radius);border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text);font-size:.8125rem;font-weight:600;cursor:pointer;transition:all .15s}.ftg-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.ftg-btn:disabled{opacity:.4;cursor:not-allowed}.ftg-btn:disabled:hover{border-color:var(--color-border);color:var(--color-text)}.ftg-btn-primary{background:#3cc8db1a;border-color:#3cc8db4d;color:#1a8a9a}.ftg-btn-primary:hover{background:#3cc8db2e;border-color:var(--color-primary);color:#1a8a9a}.ftg-btn-danger{background:#f044380f;border-color:#f0443840;color:#c0362e}.ftg-btn-danger:hover{background:#f044381f;border-color:var(--color-error);color:#c0362e}.ftg-btn-ghost{background:transparent;border-color:transparent;color:var(--color-text-secondary)}.ftg-btn-ghost:hover{background:var(--color-bg);border-color:var(--color-border);color:var(--color-text)}.ftg-question-area{border:1px solid var(--color-border);border-radius:var(--radius);padding:.875rem;background:var(--color-bg)}.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-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}.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:.625rem .75rem;border-radius:var(--radius);border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text);font-size:.9375rem;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;outline:none;transition:border-color .15s,box-shadow .15s}.ftg-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #3cc8db26}.ftg-input:disabled{opacity:.5}.ftg-input-row{display:flex;gap:.5rem;align-items:center}.ftg-feedback{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-good{border-color:#12b76a66;background:#12b76a0f}.ftg-feedback-bad{border-color:#f0443866;background:#f044380f}.ftg-feedback-warn{border-color:#f7900959;background:#f790090d}.ftg-footer-pills{display:flex;gap:.5rem;flex-wrap:wrap}.ftg-progress{height:8px;border-radius:100px;background:var(--color-border);overflow:hidden}.ftg-progress-bar{height:100%;background:var(--color-primary);border-radius:100px;transition:width .3s ease}.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-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-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:1.5px 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:#3cc8db0a}.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}.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}.st-textarea{width:100%;min-height:80px;padding:.625rem .75rem;border-radius:var(--radius);border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text);font-size:.9375rem;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;outline:none;resize:vertical;transition:border-color .15s,box-shadow .15s}.st-textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #3cc8db26}.st-textarea:disabled{opacity:.5}.st-textarea[rows="1"]{min-height:auto;resize:none}.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{flex-direction:column;align-items:flex-start}.ftg-pills{width:100%}.ftg-pill{font-size:.75rem}}
