*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#edebe5;--surface:#e5e2dc;--surface-2:#dedad3;--text:#0a0a0a;--text-2:#6b6b6b;--text-3:#9e9a93;--accent:#0047ab;--accent-2:#00368a;--accent-bg:#e4eafa;--border:#d0cbc2;--border-2:#0000001a;--again:#c0392b;--again-bg:#f9edec;--hard:#9b6a2f;--hard-bg:#f7f0e6;--good:#2d6a4f;--good-bg:#e6f1ec;--easy:#0047ab;--easy-bg:#e4eafa;--r:8px;--r-lg:12px;--serif:"Playfair Display", Georgia, serif;--sans:"Helvetica Neue", Helvetica, Arial, sans-serif;--ease:cubic-bezier(.25,.46,.45,.94);--gap:24px;--pad-x:clamp(16px, 5vw, 32px)}html,body{background:var(--bg);height:100%;color:var(--text);font-family:var(--sans);-webkit-font-smoothing:antialiased;font-size:16px;line-height:1.5;overflow:hidden}.main-nav{background:var(--bg);border-bottom:1px solid var(--border);height:48px;padding:0 var(--pad-x);z-index:10;justify-content:space-between;align-items:center;display:flex;position:fixed;top:0;left:0;right:0}.nav-logo{font-family:var(--serif);letter-spacing:-.03em;font-size:1.1rem;font-weight:600}.nav-logo em{color:var(--accent);font-style:normal}.btn-icon{cursor:pointer;width:32px;height:32px;color:var(--text-2);border-radius:var(--r);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;transition:background .12s;display:flex}.btn-icon:hover{background:var(--surface-2)}.view-root{position:fixed;inset:48px 0 0}.view-root.no-nav{top:0}.view{padding:40px var(--pad-x) 40px;-webkit-overflow-scrolling:touch;flex-direction:column;align-items:center;display:flex;position:absolute;inset:0;overflow-y:auto}.view-center{justify-content:center}.inner{width:100%;min-width:0;max-width:1100px}.btn{border:1px solid var(--border);border-radius:var(--r);cursor:pointer;width:100%;min-height:44px;font-family:var(--sans);letter-spacing:-.01em;touch-action:manipulation;color:var(--text);background:0 0;outline:none;justify-content:center;align-items:center;padding:0 20px;font-size:.875rem;font-weight:500;transition:background .1s,border-color .1s,color .1s,opacity .1s;display:flex}.btn:active{opacity:.7}.btn+.btn{margin-top:8px}.btn-primary{background:var(--text);color:var(--bg);border-color:var(--text)}.btn-primary:hover{background:#222;border-color:#222}.btn-secondary{color:var(--text-2);border-color:var(--border);background:0 0}.btn-secondary:hover{background:var(--surface-2);color:var(--text)}.btn-start{background:var(--text);color:var(--bg);border-color:var(--text);border-radius:var(--r);letter-spacing:.04em;text-transform:uppercase;min-height:52px;font-size:.875rem;font-weight:600;transition:opacity .15s,transform .12s}.btn-start:hover{opacity:.85}.btn-start:active{opacity:.7;transform:scale(.98)}@keyframes staggerUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.stagger-1{animation:.5s cubic-bezier(.16,1,.3,1) 50ms backwards staggerUp}.stagger-2{animation:.5s cubic-bezier(.16,1,.3,1) .12s backwards staggerUp}.stagger-3{animation:.5s cubic-bezier(.16,1,.3,1) .2s backwards staggerUp}.stagger-4{animation:.5s cubic-bezier(.16,1,.3,1) .28s backwards staggerUp}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes fadeUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes cardReveal{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}.skeleton{background:linear-gradient(90deg, var(--surface) 25%, var(--surface-2) 50%, var(--surface) 75%);border-radius:var(--r);background-size:200% 100%;animation:1.5s linear infinite shimmer}.skeleton-btn{border-radius:var(--r);border:none;width:100%;height:52px}.setup-logo{font-family:var(--serif);letter-spacing:-.02em;margin-bottom:32px;font-size:1.4rem;font-weight:600}.setup-logo em{color:var(--accent);font-style:normal}.setup-view h2{font-family:var(--sans);letter-spacing:-.03em;margin-bottom:8px;font-size:1.3rem;font-weight:700}.setup-view .sub{color:var(--text-2);margin-bottom:24px;font-size:.85rem;line-height:1.7}.field{margin-bottom:14px}.field label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-3);margin-bottom:5px;font-size:.62rem;font-weight:600;display:block}input[type=password],input[type=text].token-input{border:1px solid var(--border);border-radius:var(--r);width:100%;color:var(--text);appearance:none;background:0 0;outline:none;padding:10px 13px;font-family:SF Mono,Menlo,monospace;font-size:13px;transition:border-color .15s}input[type=password]:focus,input[type=text].token-input:focus{border-color:var(--accent)}.hero-section{margin-bottom:32px;padding:0 2px}.hero-title{font-family:var(--sans);letter-spacing:-.04em;margin-bottom:6px;font-size:clamp(2.6rem,7vw,3.8rem);font-weight:700;line-height:1}.hero-sub{color:var(--text-3);font-size:.875rem;font-weight:400}.home-grid{grid-template-columns:1fr;align-items:start;gap:32px;width:100%;display:grid}.home-side{flex-direction:column;gap:24px;display:flex}@media (min-width:640px){.home-grid{grid-template-columns:minmax(0,1.2fr) minmax(0,1fr);gap:48px}}.stats-card{border:none;border-top:1px solid var(--border);background:0 0;border-radius:0;padding:clamp(20px,4vw,28px) 0 0}.stats-card-label{text-transform:uppercase;letter-spacing:.14em;color:var(--text-3);margin-bottom:24px;font-size:.6rem;font-weight:600}.streak-row{align-items:center;gap:5px;margin-bottom:16px;display:inline-flex}.streak-icon{font-size:.85rem}.streak-count{font-family:var(--sans);letter-spacing:-.02em;color:var(--accent);font-size:.9rem;font-weight:700}.streak-lbl{color:var(--text-3);font-size:.72rem}.today-row{align-items:baseline;gap:14px;margin-bottom:20px;display:flex}.today-num{font-family:var(--sans);letter-spacing:-.05em;font-size:clamp(4.5rem,18vw,7rem);font-weight:700;line-height:.9}.today-lbl{color:var(--text-3);font-size:.85rem;font-weight:400}.seg-bar{background:var(--border);border-radius:100px;height:2px;margin-bottom:14px;display:flex;overflow:hidden}.seg-fill{height:100%;transition:width .8s cubic-bezier(.16,1,.3,1)}.seg-fill.due{background:var(--accent)}.seg-fill.new{background:var(--text-3)}.seg-fill.done{background:var(--good)}.seg-legend{flex-wrap:wrap;gap:16px;display:flex}.seg-legend-item{color:var(--text-3);align-items:center;gap:5px;font-size:.65rem;display:flex}.seg-dot{border-radius:50%;flex-shrink:0;width:4px;height:4px}.seg-dot.due{background:var(--accent)}.seg-dot.new{background:var(--text-3)}.seg-dot.done{background:var(--good)}.seg-n{color:var(--text-2);font-weight:700}.stats-sep{background:var(--border);height:1px;margin:24px 0 20px}.level-row{align-items:center;gap:10px;margin-bottom:8px;display:flex}.level-row:last-child{margin-bottom:0}.level-tag{color:var(--text-3);letter-spacing:.05em;flex-shrink:0;width:18px;font-size:.58rem;font-weight:700}.bar-track{background:var(--border);border-radius:100px;flex:1;height:2px;overflow:hidden}.bar-fill{background:var(--border-2);border-radius:100px;height:100%;transition:width .7s cubic-bezier(.16,1,.3,1)}.bar-fill.has-due{background:var(--accent)}.level-count{color:var(--text-3);text-align:right;flex-shrink:0;width:22px;font-size:.6rem}.empty-note{text-align:center;color:var(--text-3);padding:12px 0 16px;font-size:.8rem;line-height:1.7}.explain-card{background:0 0;border:none}.explain-title{text-transform:uppercase;letter-spacing:.12em;color:var(--text-3);margin-bottom:12px;font-size:.6rem;font-weight:600}.explain-body{color:var(--text-2);margin-bottom:0;font-size:.82rem;line-height:1.75}.explain-grid{flex-direction:column;display:flex}.explain-bento{border:none;border-top:1px solid var(--border);background:0 0;border-radius:0;gap:16px;padding:14px 0;display:flex}.bento-num{width:18px;color:var(--text-3);flex-shrink:0;justify-content:flex-start;align-items:flex-start;padding-top:2px;font-size:.68rem;font-weight:400;display:flex}.bento-text{color:var(--text-2);font-size:.82rem;line-height:1.55}.empty-state{text-align:center;border-top:1px solid var(--border);padding:32px 20px}.empty-icon{margin-bottom:10px;font-size:1.8rem;display:inline-block}.empty-title{font-family:var(--sans);letter-spacing:-.02em;margin-bottom:6px;font-size:1.2rem;font-weight:700}.empty-p{color:var(--text-2);max-width:220px;margin:0 auto;font-size:.82rem;line-height:1.6}.study-view{justify-content:flex-start;padding:20px 20px 28px}.study-header{grid-template-columns:1fr auto;align-items:center;gap:12px;width:100%;max-width:480px;margin-bottom:20px;display:grid}.back-btn{color:var(--text-3);cursor:pointer;font-size:.8rem;font-family:var(--sans);background:0 0;border:none;align-items:center;gap:4px;padding:0;transition:color .12s;display:flex}.back-btn:hover{color:var(--text)}.study-progress{justify-content:flex-end;align-items:center;gap:10px;display:flex}.progress-bar-track{background:var(--border);border-radius:2px;width:80px;height:2px}.progress-bar-fill{background:var(--accent);height:100%;transition:width .35s var(--ease);border-radius:2px}.prog-text{color:var(--text-3);letter-spacing:.04em;white-space:nowrap;font-size:.68rem}.card-tag{letter-spacing:.12em;text-transform:uppercase;color:var(--text-3);text-align:center;font-size:.6rem;font-weight:600}.card-stage{perspective:1200px;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:16px;width:100%;max-width:480px;min-height:260px;display:flex}.flash-card{width:100%;transform-style:preserve-3d;cursor:pointer;min-height:220px;transition:transform .6s cubic-bezier(.34,1.56,.64,1);position:relative}.flash-card.revealed{cursor:default;transform:rotateY(180deg)}.card-anim{animation:.3s cubic-bezier(.2,.8,.2,1) cardReveal}.card-face{border-radius:var(--r-lg);text-align:center;backface-visibility:hidden;width:100%;min-height:220px;transition:box-shadow .2s var(--ease);background:#fff;border:1px solid #d8d4cc;flex-direction:column;justify-content:center;align-items:center;gap:10px;padding:40px 32px;display:flex;box-shadow:0 2px 20px #00000014}.flash-card:not(.revealed):hover .card-face{box-shadow:0 6px 36px #00000021}.card-front{z-index:2;position:absolute;inset:0}.card-back{position:relative;transform:rotateY(180deg)}.f-word{font-family:var(--serif);letter-spacing:-.02em;font-size:2.5rem;font-weight:400;line-height:1.1}.f-ipa{color:var(--text-3);letter-spacing:.03em;min-height:14px;font-family:SF Mono,Menlo,monospace;font-size:.75rem}.f-badges{justify-content:center;gap:5px;display:flex}.badge{letter-spacing:.04em;color:var(--text-3);background:#fff;border:1px solid #d8d4cc;border-radius:20px;padding:2px 9px;font-size:.6rem;font-weight:600}.reveal-hint{color:var(--text-3);margin-top:6px;font-size:.65rem}.reveal-hint kbd{font-family:var(--sans);color:var(--text-2);background:#f5f2ee;border:1px solid #d8d4cc;border-radius:4px;padding:1px 5px;font-size:.6rem;display:inline-block}@media (pointer:coarse){.reveal-hint{display:none}}.card-divider{background:#d8d4cc;width:24px;height:1px;margin:2px 0}.b-trad{font-family:var(--serif);color:var(--text-2);letter-spacing:-.01em;font-size:1.4rem;font-style:italic}.b-def{color:var(--text-2);font-size:.8rem;line-height:1.7}.b-ex{color:var(--text-2);text-align:left;background:#f5f2ee;border-left:2px solid #d8d4cc;width:100%;padding:9px 13px;font-size:.78rem;line-height:1.7}.b-extra{color:var(--text-3);font-size:.68rem;line-height:1.6}.ratings{grid-template-columns:repeat(4,1fr);gap:6px;width:100%;max-width:480px;display:grid}.ratings-anim{animation:.3s cubic-bezier(.2,.8,.2,1) fadeUp}@media (max-width:360px){.ratings{grid-template-columns:repeat(2,1fr)}}.btn-rate{border-radius:var(--r);cursor:pointer;min-height:54px;font-family:var(--sans);text-align:center;touch-action:manipulation;border:1px solid var(--border);color:var(--text-2);background:#fff;outline:none;flex-direction:column;justify-content:center;align-items:center;gap:2px;padding:8px 6px;font-weight:500;transition:border-color .1s,background .1s,color .1s,transform .1s;display:flex}.btn-rate:active{transform:scale(.96)}.btn-rate .rate-label{text-transform:uppercase;letter-spacing:.06em;font-size:.68rem}.btn-rate .rate-interval{color:var(--text-3);font-size:.58rem}.r-again:hover{border-color:var(--again);color:var(--again);background:var(--again-bg)}.r-hard:hover{border-color:var(--hard);color:var(--hard);background:var(--hard-bg)}.r-good:hover{border-color:var(--good);color:var(--good);background:var(--good-bg)}.r-easy:hover{border-color:var(--easy);color:var(--easy);background:var(--easy-bg)}.done-mark{border:1px solid var(--border);width:52px;height:52px;color:var(--text-2);border-radius:50%;justify-content:center;align-items:center;margin:0 auto 20px;font-size:1.2rem;display:flex}.done-view h2{font-family:var(--sans);letter-spacing:-.03em;text-align:center;margin-bottom:8px;font-size:1.5rem;font-weight:700}.done-sub{color:var(--text-2);text-align:center;margin-bottom:28px;font-size:.85rem;line-height:1.7}.streak-done{color:var(--text-2);margin:10px 0 4px;font-size:.9rem}.builder-view{justify-content:flex-start;padding-top:20px}.builder-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.builder-nav{align-items:center;gap:5px;display:flex}.btn-nav{border-radius:var(--r);border:1px solid var(--border);cursor:pointer;width:30px;height:30px;color:var(--text-2);background:0 0;justify-content:center;align-items:center;font-size:13px;transition:background .1s;display:flex}.btn-nav:hover{background:var(--surface-2)}.btn-nav:disabled{opacity:.25;cursor:default}.builder-counter{color:var(--text-3);text-align:center;letter-spacing:.03em;min-width:48px;font-size:.68rem}.builder-word{font-family:var(--sans);letter-spacing:-.04em;margin-bottom:8px;font-size:2rem;font-weight:700;line-height:1.1}.builder-missing{flex-wrap:wrap;gap:4px;margin-bottom:16px;display:flex}.missing-tag{text-transform:uppercase;letter-spacing:.04em;background:var(--again-bg);color:var(--again);border:1px solid #c0392b33;border-radius:4px;padding:2px 7px;font-size:.6rem;font-weight:600}.form-grid{grid-template-columns:1fr 1fr;gap:10px;margin-bottom:12px;display:grid}.form-grid .full{grid-column:1/-1}.f-group{flex-direction:column;gap:4px;display:flex}.f-label{text-transform:uppercase;letter-spacing:.07em;color:var(--text-3);font-size:.6rem;font-weight:600}.f-label.missing{color:var(--again)}.f-input,.f-textarea{border:1px solid var(--border);border-radius:var(--r);width:100%;font-family:var(--sans);color:var(--text);appearance:none;background:0 0;outline:none;padding:9px 12px;font-size:.875rem;transition:border-color .15s}.f-select{border:1px solid var(--border);border-radius:var(--r);width:100%;font-family:var(--sans);color:var(--text);appearance:none;cursor:pointer;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath fill='%239E9A93' d='M0 0l5 6 5-6z'/%3E%3C/svg%3E") right 12px center no-repeat;outline:none;padding:9px 32px 9px 12px;font-size:.875rem;transition:border-color .15s}.f-input:focus,.f-textarea:focus,.f-select:focus{border-color:var(--accent)}.f-input.empty,.f-textarea.empty,.f-select.empty{border-color:#c0392b66}.f-textarea{resize:vertical;min-height:70px;line-height:1.55}.builder-actions{gap:8px;margin-top:6px;display:flex}.builder-actions .btn{flex:1}.nav-menu{position:relative}.dropdown{background:var(--bg);border:1px solid var(--border);border-radius:var(--r-lg);opacity:0;pointer-events:none;transform-origin:100% 0;min-width:200px;transition:opacity .18s var(--ease), transform .18s var(--ease);z-index:20;padding:4px;position:absolute;top:42px;right:0;transform:translateY(-6px)scale(.97);box-shadow:0 8px 32px #0000001f,0 2px 8px #0000000f}.dropdown.open{opacity:1;pointer-events:all;transform:none}.dd-item{border-radius:var(--r);width:100%;color:var(--text);font-family:var(--sans);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:10px;padding:8px 12px;font-size:.85rem;transition:background .1s;display:flex}.dd-item:hover{background:var(--surface-2)}.dd-icon{text-align:center;width:16px;color:var(--text-3);flex-shrink:0;font-size:.8rem}.dd-sep{background:var(--border);height:1px;margin:4px 0}.dd-badge{background:var(--accent-bg);color:var(--accent);border-radius:10px;margin-left:auto;padding:1px 6px;font-size:.62rem;font-weight:600}.loading{color:var(--text-3);text-align:center;padding:32px 0;font-size:.85rem}.loading:after{content:"";border:1.5px solid var(--border);border-top-color:var(--text-3);border-radius:50%;width:16px;height:16px;margin:12px auto 0;animation:.8s linear infinite spin;display:block}.err{color:var(--again);background:var(--again-bg);border-radius:var(--r);border:1px solid #c0392b33;margin-top:10px;padding:10px 14px;font-size:.8rem;line-height:1.55}.modal-overlay{z-index:100;opacity:0;pointer-events:none;transition:opacity .2s var(--ease);background:#0006;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}.modal-overlay.open{opacity:1;pointer-events:all}.modal-sheet{background:var(--bg);width:100%;max-width:500px;transition:transform .26s var(--ease);border-radius:16px 16px 0 0;padding:8px 20px 40px;transform:translateY(24px)}.modal-overlay.open .modal-sheet{transform:translateY(0)}.modal-handle{background:var(--border);border-radius:2px;width:32px;height:3px;margin:10px auto 20px}.modal-title{font-family:var(--sans);letter-spacing:-.02em;margin-bottom:14px;font-size:1rem;font-weight:700}
