*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,sans-serif;font-size:16px;background:#f0f4e8;color:#2d3a1f;--bg: #f0f4e8;--bg-card: #ffffff;--bg-secondary: #e8f0d8;--text: #2d3a1f;--text-muted: #6b7a5a;--accent: #c44b11;--accent-light: #e8652b;--success: #2d7a1f;--success-bg: #e0f5d8;--warning: #b8860b;--warning-bg: #fff8e0;--danger: #c42020;--danger-bg: #ffe0e0;--gold: #c4a411;--gold-bg: #fffbe0;--field: #3a5a1f;--field-light: #4a7a2f;--yard-white: #ffffff;--border: #d4e0c4;--shadow: 0 2px 12px rgba(0,0,0,.08);--radius: 12px;--radius-sm: 8px}html.dark{--bg: #1a2214;--bg-card: #24301c;--bg-secondary: #2d3a22;--text: #e0e8d0;--text-muted: #a0b090;--accent: #e8652b;--accent-light: #f0804a;--success: #4ad040;--success-bg: #1a3a14;--warning: #e0b010;--warning-bg: #3a3010;--danger: #f04040;--danger-bg: #3a1414;--gold: #e0c020;--gold-bg: #3a3010;--field: #2a4a14;--field-light: #3a5a22;--border: #3a4a2a;color-scheme:dark}body{background:var(--bg);color:var(--text);min-height:100dvh;max-width:600px;margin:0 auto;padding:0 0 80px;-webkit-tap-highlight-color:transparent}#app-header{display:flex;justify-content:space-between;align-items:flex-start;padding:16px 20px 8px;position:sticky;top:0;background:var(--bg);z-index:10;border-bottom:2px solid var(--field)}#app-header h1{font-size:1.3rem;color:var(--accent);line-height:1.2}#app-subtitle{font-size:.75rem;color:var(--text-muted);margin-top:2px}.header-right{display:flex;gap:6px}.icon-btn{width:36px;height:36px;border-radius:50%;background:var(--bg-secondary);border:1px solid var(--border);font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.icon-btn:hover{background:var(--border)}.tab-view{display:none;padding:12px 16px}.tab-view.active{display:block}.mode-header{margin-bottom:16px}.mode-header h2{font-size:1.15rem;color:var(--accent)}.mode-header p{font-size:.8rem;color:var(--text-muted);margin-top:2px}.yardage-bar{margin-bottom:20px}.field{width:100%;height:20px;background:var(--bg-secondary);border-radius:10px;overflow:hidden;position:relative;border:1px solid var(--border)}.field .progress{height:100%;background:linear-gradient(90deg,var(--field),var(--field-light));border-radius:10px;transition:width .4s ease}#yardage-text{font-size:.75rem;color:var(--text-muted);margin-top:4px;display:block;text-align:center}.word-card{background:var(--bg-card);border-radius:var(--radius);padding:16px;margin-bottom:12px;box-shadow:var(--shadow);border-left:4px solid var(--field);transition:opacity .3s}.word-card.done{opacity:.6;border-left-color:var(--success)}.word-card .word-text{font-size:1.2rem;font-weight:700;color:var(--accent)}.word-card .word-phonetic{font-size:.8rem;color:var(--text-muted);margin-left:8px}.word-card .word-pos{display:inline-block;padding:2px 8px;border-radius:4px;font-size:.7rem;font-weight:600;margin-left:8px}.word-pos.noun,.word-pos.n{background:#d4e4ff;color:#2040a0}.word-pos.verb,.word-pos.v{background:#ffe4d4;color:#a04020}.word-pos.adjective,.word-pos.adj{background:#e4ffd4;color:#208020}.word-pos.adverb,.word-pos.adv{background:#ffe4ff;color:#802080}.word-pos.phrase,.word-pos.phr{background:#fff8d4;color:#807020}.word-pos.idiom{background:#e4ffff;color:#206060}html.dark .word-pos.noun,html.dark .word-pos.n{background:#1a2a50;color:#80b0ff}html.dark .word-pos.verb,html.dark .word-pos.v{background:#502010;color:#ff9060}html.dark .word-pos.adjective,html.dark .word-pos.adj{background:#103020;color:#60d060}html.dark .word-pos.phrase,html.dark .word-pos.phr{background:#504010;color:#e0c040}html.dark .word-pos.idiom{background:#103030;color:#60d0d0}.word-zh{font-size:.95rem;color:var(--text);margin:6px 0}.word-def{font-size:.8rem;color:var(--text-muted)}.word-example{font-size:.8rem;font-style:italic;color:var(--text-muted);margin-top:4px}.word-example-zh{font-size:.75rem;color:var(--text-muted)}.football-context{margin-top:8px;padding:8px 12px;background:var(--success-bg);border-radius:var(--radius-sm);font-size:.75rem;color:var(--success);border-left:3px solid var(--success)}.done-tag{display:inline-block;padding:4px 12px;background:var(--success-bg);color:var(--success);border-radius:4px;font-size:.8rem;margin-top:8px}.word-actions{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap}.btn{padding:10px 18px;border:none;border-radius:var(--radius-sm);font-size:.85rem;font-weight:600;cursor:pointer;transition:background .2s,transform .15s;border:2px solid transparent}.btn:active{transform:scale(.96)}.btn-sm{padding:6px 12px;font-size:.75rem}.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-secondary{background:var(--bg-secondary);color:var(--text);border-color:var(--border)}.btn-success{background:var(--success-bg);color:var(--success);border-color:var(--success)}.btn-warning{background:var(--warning-bg);color:var(--warning);border-color:var(--warning)}.btn-danger{background:var(--danger-bg);color:var(--danger);border-color:var(--danger)}.btn.active{background:var(--accent);color:#fff}.full{width:100%}.huddle-controls{display:flex;gap:8px;margin-bottom:16px}.flashcard{width:100%;min-height:260px;perspective:1000px;margin-bottom:16px}.card-inner{position:relative;width:100%;min-height:260px;transition:transform .5s;transform-style:preserve-3d;cursor:pointer}.card-inner.flipped{transform:rotateY(180deg)}.card-front,.card-back{position:absolute;inset:0;backface-visibility:hidden;background:var(--bg-card);border-radius:var(--radius);padding:32px 24px;box-shadow:var(--shadow);display:flex;flex-direction:column;align-items:center;justify-content:center;border:3px solid var(--field)}.card-back{transform:rotateY(180deg);overflow-y:auto;align-items:flex-start}.card-word{font-size:2rem;font-weight:800;color:var(--accent)}.card-hint{font-size:.8rem;color:var(--text-muted);margin-top:12px}.card-actions{display:flex;gap:12px;margin-bottom:8px}.card-actions .btn{flex:1}#huddle-counter{text-align:center;font-size:.8rem;color:var(--text-muted)}.card-details strong{font-size:1.2rem;color:var(--accent)}.card-pos{font-size:.8rem;color:var(--text-muted);margin:4px 0}.card-zh{font-size:1rem;margin:8px 0}.card-en{font-size:.85rem;color:var(--text-muted)}.card-ex{font-size:.8rem;font-style:italic;color:var(--text-muted);margin-top:8px}.card-ex-zh{font-size:.75rem;color:var(--text-muted)}.card-ctx{font-size:.75rem;color:var(--success);margin-top:8px;padding:6px 10px;background:var(--success-bg);border-radius:var(--radius-sm)}.stats-bar{display:flex;gap:16px;margin-bottom:16px;font-size:.8rem;color:var(--text-muted)}.quiz-word{font-size:1.8rem;font-weight:800;color:var(--accent);text-align:center;margin-bottom:20px}.quiz-options{display:flex;flex-direction:column;gap:10px}.quiz-option-btn,.gap-option-btn{padding:14px 20px;background:var(--bg-card);border:2px solid var(--border);border-radius:var(--radius-sm);font-size:1rem;cursor:pointer;text-align:center;transition:all .2s}.quiz-option-btn:hover,.gap-option-btn:hover{border-color:var(--accent)}.quiz-option-btn.correct,.gap-option-btn.correct{border-color:var(--success);background:var(--success-bg)}.quiz-option-btn:disabled,.gap-option-btn:disabled{cursor:default;opacity:.8}.spell-card{background:var(--bg-card);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow)}.spell-zh{font-size:1.2rem;font-weight:600;margin-bottom:8px;color:var(--accent)}.spell-example{font-size:.9rem;color:var(--text-muted);margin-bottom:12px;font-style:italic}.hint-area{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px;min-height:24px}.hint{font-size:.8rem;background:var(--warning-bg);color:var(--warning);padding:4px 10px;border-radius:4px}.spell-input{width:100%;padding:14px 18px;border-radius:var(--radius-sm);border:2px solid var(--border);font-size:1.1rem;background:var(--bg);color:var(--text);margin-bottom:12px}.spell-input:focus{border-color:var(--accent);outline:none}.spell-actions{display:flex;gap:8px}.red-zone{text-align:center;margin-bottom:16px}.red-zone-progress{display:inline-flex;align-items:center;gap:8px;background:var(--danger-bg);color:var(--danger);padding:8px 20px;border-radius:20px;font-size:.9rem}#gap-streak-count{font-weight:800;font-size:1.3rem}.gap-sentence{font-size:1.1rem;font-weight:600;text-align:center;padding:16px;background:var(--bg-card);border-radius:var(--radius);margin-bottom:16px;box-shadow:var(--shadow);border:2px dashed var(--accent)}.gap-options{display:flex;flex-direction:column;gap:10px}.feedback{margin-top:16px;padding:16px;background:var(--bg-card);border-radius:var(--radius);box-shadow:var(--shadow)}.fb-correct{font-size:1.2rem;font-weight:800;color:var(--success);text-align:center}.fb-wrong{font-size:1.1rem;font-weight:700;color:var(--danger);text-align:center}.fb-answer,.fb-full-correct{font-size:.9rem;margin-top:8px;color:var(--text)}.fb-example,.fb-full{font-size:.85rem;font-style:italic;color:var(--text-muted);margin-top:4px}.fb-example-zh{font-size:.75rem;color:var(--text-muted);margin-top:2px}.td-celebration{text-align:center;padding:24px;background:linear-gradient(135deg,var(--gold-bg),var(--success-bg));border-radius:var(--radius);margin:12px 0;border:2px solid var(--gold);animation:bounce .6s ease}.td-celebration h2{font-size:1.4rem;color:var(--accent)}.td-celebration p{font-size:.9rem;color:var(--success);margin-top:4px}@keyframes bounce{0%,to{transform:scale(1)}50%{transform:scale(1.04)}}.empty-state{text-align:center;padding:40px 20px;color:var(--text-muted);font-size:.9rem}.empty-state h3{color:var(--accent);margin-bottom:8px}.empty-state p{margin-top:4px}.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:20px}.stat-card{background:var(--bg-card);border-radius:var(--radius);padding:16px;text-align:center;box-shadow:var(--shadow)}.stat-card span{font-size:2rem;font-weight:800;color:var(--accent);display:block}.stat-card label{font-size:.75rem;color:var(--text-muted);margin-top:4px;display:block}.achievements-grid h3{color:var(--accent);margin-bottom:12px}.ach-card{display:flex;align-items:center;gap:12px;padding:12px 16px;margin-bottom:8px;border-radius:var(--radius-sm);background:var(--bg-card);box-shadow:0 1px 4px #0000000f;border-left:4px solid var(--border)}.ach-card.earned{border-left-color:var(--gold);background:var(--gold-bg)}.ach-card.locked{opacity:.5}.ach-icon{font-size:1.3rem}.trophy-actions{display:flex;gap:8px;margin-top:16px}.overlay{position:fixed;inset:0;background:var(--bg);z-index:100;overflow-y:auto;padding:16px}.overlay.hidden{display:none}.overlay-content{max-width:500px;margin:0 auto}.overlay-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.close-btn{font-size:1.5rem;background:none;border:none;color:var(--text);cursor:pointer;padding:4px}#search-input{width:100%;padding:12px 16px;border-radius:var(--radius-sm);border:2px solid var(--border);font-size:1rem;background:var(--bg-card);color:var(--text);margin-bottom:12px}#filter-category{width:100%;padding:10px 14px;border-radius:var(--radius-sm);border:2px solid var(--border);font-size:.9rem;background:var(--bg-card);color:var(--text);margin-bottom:16px}.results-list{display:flex;flex-direction:column;gap:8px}.search-result{background:var(--bg-card);padding:12px 16px;border-radius:var(--radius-sm);box-shadow:0 1px 4px #0000000f}.search-result.learned{border-left:4px solid var(--success)}.sr-header{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:.85rem}.sr-def{font-size:.75rem;color:var(--text-muted);margin-top:4px}.sr-ex{font-size:.75rem;font-style:italic;color:var(--text-muted)}.toast{position:fixed;bottom:96px;left:50%;transform:translate(-50%);background:var(--accent);color:#fff;padding:10px 24px;border-radius:20px;font-size:.85rem;font-weight:600;z-index:200;box-shadow:0 4px 16px #00000040;transition:opacity .3s;white-space:nowrap}.toast.hidden{opacity:0;pointer-events:none}#bottom-nav{position:fixed;bottom:0;left:0;right:0;max-width:600px;margin:0 auto;background:var(--bg-card);border-top:2px solid var(--field);display:flex;justify-content:space-around;padding:6px 0 env(safe-area-inset-bottom,6px);z-index:50;box-shadow:0 -2px 12px #0000000f}.nav-btn{background:none;border:none;color:var(--text-muted);font-size:.65rem;display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 4px;cursor:pointer;min-width:56px;transition:color .2s}.nav-btn span{font-size:.62rem}.nav-btn.active{color:var(--accent);font-weight:700}.streak-badge{font-size:.8rem;color:var(--warning);margin-left:6px}@media(min-width:420px){.nav-btn{font-size:.75rem}.nav-btn span{font-size:.68rem}#app-header h1{font-size:1.5rem}}.hidden{display:none!important}hr{border:none;border-top:1px solid var(--border);margin:16px 0}.msg{font-size:.8rem;text-align:center;margin-top:8px}.msg.success{color:var(--success)}.msg.error{color:var(--danger)}
