:root{--bg:#f6f4ee;--surface:#fff;--text:#1a1a1a;--muted:#6b6b6b;--accent:#d97706;--accent-soft:#fef3c7;--green:#15803d;--green-bg:#dcfce7;--red:#b91c1c;--red-bg:#fee2e2;--border:#e7e5e0;--shadow:0 1px 3px #0000000f, 0 8px 28px #00000012}*{box-sizing:border-box}html,body,#root{margin:0;padding:0}#root{width:100%;min-height:100dvh}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;overscroll-behavior-y:contain;min-height:100dvh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;line-height:1.5}button{-webkit-tap-highlight-color:transparent;font-family:inherit}.page{max-width:640px;padding:20px 16px 60px;padding-top:max(20px, env(safe-area-inset-top));padding-left:max(16px, env(safe-area-inset-left));padding-right:max(16px, env(safe-area-inset-right));padding-bottom:max(60px, env(safe-area-inset-bottom));margin:0 auto}header{flex-direction:column;align-items:center;gap:14px;margin-bottom:20px;display:flex;position:relative}.avatar-btn{background:var(--accent-soft);width:44px;height:44px;color:var(--accent);border:1px solid var(--border);cursor:pointer;border-radius:999px;justify-content:center;align-items:center;display:inline-flex;position:absolute;top:-4px;right:0}.avatar-btn:hover{filter:brightness(.95)}.avatar-btn:active{transform:scale(.96)}.menu-overlay{z-index:100;background:#0006;justify-content:flex-end;animation:.15s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.menu-panel{background:var(--surface);flex-direction:column;gap:24px;width:340px;max-width:90vw;height:100dvh;padding:24px 20px;animation:.22s cubic-bezier(.2,.8,.2,1) slideIn;display:flex;overflow-y:auto;box-shadow:-8px 0 24px #00000014}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.menu-account-section{border-bottom:1px solid var(--border);align-items:center;gap:14px;padding-bottom:18px;display:flex}.menu-avatar{background:var(--accent-soft);width:48px;height:48px;color:var(--accent);border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.menu-account-name{font-size:16px;font-weight:700}.menu-link{color:var(--muted);cursor:pointer;background:0 0;border:0;margin-top:2px;padding:0;font-size:13px}.menu-link:disabled{cursor:default;opacity:.7}.menu-section-title{text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-bottom:8px;font-size:11px;font-weight:700}.menu-list{flex-direction:column;gap:2px;margin:0;padding:0;list-style:none;display:flex}.menu-item{text-align:left;width:100%;color:var(--text);cursor:pointer;background:0 0;border:0;border-radius:10px;justify-content:space-between;align-items:center;padding:12px 14px;font-size:15px;font-weight:500;display:flex}.menu-item:hover{background:var(--bg)}.menu-item.active{background:var(--bg);font-weight:700}.menu-check{color:var(--accent);font-weight:700}.menu-close{background:var(--bg);border:1px solid var(--border);cursor:pointer;color:var(--text);border-radius:12px;margin-top:auto;padding:12px;font-size:15px;font-weight:600}.menu-account-info{flex:auto;min-width:0}.menu-account-tier{color:var(--accent);text-transform:uppercase;letter-spacing:.06em;margin-top:2px;font-size:12px;font-weight:700}.menu-account-actions{align-items:center;gap:6px;margin-top:4px;display:flex}.menu-link-action{color:var(--accent);cursor:pointer;background:0 0;border:0;padding:0;font-size:13px;font-weight:600}.menu-link-action:hover{text-decoration:underline}.menu-link-sep{color:var(--muted);font-size:13px}.menu-item-danger{color:var(--red);font-weight:600}.menu-item-danger:hover{background:var(--red-bg)}.avatar-initial{letter-spacing:-.02em;font-size:16px;font-weight:700}.auth-overlay{z-index:200;background:#00000080;justify-content:center;align-items:center;padding:16px;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.auth-panel{background:var(--surface);border-radius:20px;flex-direction:column;gap:16px;width:100%;max-width:380px;padding:22px 22px 18px;animation:.18s cubic-bezier(.2,.8,.2,1) scaleIn;display:flex;box-shadow:0 12px 40px #0000002e}@keyframes scaleIn{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}.auth-tabs{background:var(--bg);border-radius:999px;gap:4px;padding:4px;display:flex}.auth-tab{color:var(--muted);cursor:pointer;background:0 0;border:0;border-radius:999px;flex:1;padding:8px 12px;font-size:14px;font-weight:600}.auth-tab.active{background:var(--surface);color:var(--text);box-shadow:0 1px 2px #0000000f}.auth-form{flex-direction:column;gap:12px;display:flex}.auth-field{flex-direction:column;gap:4px;display:flex}.auth-field span{color:var(--muted);text-transform:uppercase;letter-spacing:.04em;font-size:12px;font-weight:600}.auth-field input{border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:10px;padding:11px 14px;font-family:inherit;font-size:15px}.auth-field input:focus{outline:2px solid var(--accent);outline-offset:-1px;border-color:var(--accent)}.auth-error{background:var(--red-bg);color:var(--red);border-radius:10px;padding:10px 12px;font-size:13px;line-height:1.4}.auth-submit{background:var(--text);color:var(--bg);cursor:pointer;border:0;border-radius:12px;margin-top:4px;padding:12px;font-size:15px;font-weight:700}.auth-submit:disabled{opacity:.6;cursor:not-allowed}.auth-submit:hover:not(:disabled){filter:brightness(1.1)}.auth-hint{color:var(--muted);text-align:center;margin:0;font-size:12px;line-height:1.45}.auth-cancel{color:var(--muted);cursor:pointer;background:0 0;border:0;padding:6px;font-size:13px;font-weight:500}.auth-cancel:hover{color:var(--text)}.btn-primary{background:var(--text);color:var(--bg);cursor:pointer;border:0;border-radius:999px;padding:12px 28px;font-size:15px;font-weight:600}.session-header{color:var(--muted);align-items:baseline;gap:8px;font-size:13px;display:flex}.session-bit{color:var(--text);font-weight:600}.session-dot{color:var(--muted)}.review-top{justify-content:space-between;align-items:center;gap:12px;width:100%;display:flex}.undo-btn{border:1px solid var(--border);color:var(--muted);cursor:pointer;background:0 0;border-radius:999px;padding:6px 14px;font-size:13px;font-weight:500}.undo-btn:hover{background:var(--surface);color:var(--text)}.brand h1{letter-spacing:-.02em;text-align:center;margin:0;font-size:26px;font-weight:700}.wordmark{align-items:baseline;gap:1px;line-height:1;display:inline-flex}.wordmark-lingo{color:var(--muted);letter-spacing:.01em;font-weight:400}.wordmark-sep{color:var(--accent);margin:0 2px;font-size:.85em;font-weight:700;display:inline-block;transform:translateY(-.18em)}.wordmark-chatul{color:var(--text);letter-spacing:-.02em;font-weight:800}.tagline{text-align:center;color:var(--muted);margin:2px 0 0;font-size:13px}.tabs{background:var(--surface);border:1px solid var(--border);border-radius:999px;gap:4px;padding:4px;display:flex}.tab{color:var(--muted);cursor:pointer;background:0 0;border:0;border-radius:999px;padding:7px 22px;font-size:14px;font-weight:600;transition:all .15s}.tab.active{background:var(--text);color:var(--bg)}.lang-switch{background:var(--surface);border:1px solid var(--border);border-radius:999px;gap:4px;padding:4px;display:flex}.lang-tab{color:var(--muted);cursor:pointer;background:0 0;border:0;border-radius:999px;padding:7px 18px;font-size:13px;font-weight:600;transition:all .15s}.lang-tab.active{background:var(--text);color:var(--bg)}.loading,.error,.empty-state{text-align:center;color:var(--muted);padding:80px 20px}.error{color:var(--red)}.empty-state h2{color:var(--text);margin:0 0 8px;font-size:24px}.empty-state p{margin:0 0 20px}.empty-glyph{margin-bottom:16px;font-size:56px;line-height:1}.streak-pill{background:var(--accent-soft);color:var(--accent);border-radius:999px;margin-bottom:16px;padding:8px 16px;font-size:14px;font-weight:700;display:inline-block}.stat-right{color:var(--green);font-weight:600}.stat-wrong{color:var(--red);font-weight:600}.review{flex-direction:column;align-items:center;gap:16px;display:flex}.progress{color:var(--muted);background:var(--surface);border:1px solid var(--border);border-radius:999px;padding:6px 16px;font-size:13px}.card-stage{flex-direction:column;align-items:center;gap:14px;width:100%;display:flex}.flip-card{perspective:1400px;cursor:pointer;-webkit-user-select:none;user-select:none;touch-action:pan-y;width:100%;max-width:560px;height:min(78dvh,760px);transition:transform .25s cubic-bezier(.2,.8,.2,1);position:relative}.flip-card.dragging{cursor:grabbing}.flip-card.flipped:not(.dragging){cursor:grab}.flip-card:focus,.flip-card:focus-visible{outline:none}.flip-inner{width:100%;height:100%;transform-style:preserve-3d;transition:transform .55s cubic-bezier(.4,0,.2,1);position:relative}.flip-card.flipped .flip-inner{transform:rotateY(180deg)}.flip-front,.flip-back{backface-visibility:hidden;background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:22px;flex-direction:column;display:flex;position:absolute;inset:0;overflow:hidden}.card-image-wrap{background:#eee;flex:0 0 52%;overflow:hidden}.card-image-wrap img{object-fit:cover;width:100%;height:100%;display:block}.card-text-area{text-align:center;flex-direction:column;flex:auto;justify-content:space-between;align-items:center;gap:8px;min-height:0;padding:16px 20px 14px;display:flex}.card-text-stack{flex-direction:column;flex:1;justify-content:center;align-items:center;gap:6px;display:flex}.native-large{letter-spacing:-.01em;word-break:keep-all;overflow-wrap:normal;font-size:clamp(28px,7vw,38px);font-weight:700;line-height:1.15}.romanization-large{color:var(--muted);font-size:14px;font-style:italic}.audio-btn{background:var(--accent-soft);color:var(--accent);cursor:pointer;border:0;border-radius:999px;min-height:44px;margin-top:6px;padding:11px 22px;font-size:15px;font-weight:600}.audio-btn:hover{filter:brightness(.95)}.flip-hint{text-align:center;color:var(--muted);letter-spacing:.02em;flex-shrink:0;font-size:12px}.flip-back{transform:rotateY(180deg)}.back-content{-webkit-overflow-scrolling:touch;flex-direction:column;flex:auto;gap:8px;min-height:0;padding:16px 20px 18px;display:flex;overflow-y:auto}.back-header{border-bottom:1px solid var(--border);flex-wrap:wrap;align-items:baseline;gap:10px;padding-bottom:10px;display:flex}.back-native{word-break:keep-all;font-size:18px;font-weight:700}.back-romanization{color:var(--muted);font-size:13px;font-style:italic}.english-row{justify-content:space-between;align-items:center;gap:12px;margin-top:6px;display:flex}.english-large{color:var(--accent);font-size:22px;font-weight:700}.audio-btn-icon{background:var(--accent-soft);width:40px;height:40px;color:var(--accent);cursor:pointer;-webkit-tap-highlight-color:transparent;border:0;border-radius:999px;flex:none;justify-content:center;align-items:center;padding:0 0 0 2px;font-size:14px;font-weight:700;display:inline-flex}.audio-btn-icon:hover{filter:brightness(.95)}.audio-btn-icon:active{transform:scale(.96)}.story{color:#2a2a2a;margin:4px 0 0;font-size:14px;line-height:1.55}.answer-buttons{grid-template-columns:repeat(4,1fr);gap:8px;width:100%;max-width:560px;display:grid}.btn{cursor:pointer;white-space:nowrap;border:0;border-radius:14px;flex-direction:column;justify-content:center;align-items:center;gap:2px;min-height:60px;padding:12px 6px;font-size:16px;font-weight:600;transition:transform .1s,filter .1s;display:inline-flex}.btn:active{transform:translateY(1px)}.btn:hover{filter:brightness(.97)}.btn-label{font-size:14px;font-weight:700}.btn-sub{opacity:.75;font-size:11px;font-weight:500}.btn-again{background:var(--red-bg);color:var(--red)}.btn-hard{color:#a16207;background:#fef9c3}.btn-good{background:var(--green-bg);color:var(--green)}.btn-easy{color:#1d4ed8;background:#dbeafe}.swipe-overlay{letter-spacing:.04em;text-transform:uppercase;pointer-events:none;opacity:0;background:#fffffff0;border:3px solid;border-radius:14px;padding:12px 24px;font-size:22px;font-weight:800;transition:opacity 50ms linear;position:absolute;top:50%;transform:translateY(-50%)rotate(-12deg)}.swipe-overlay-left{color:var(--red);left:24px}.swipe-overlay-right{color:var(--green);right:24px;transform:translateY(-50%)rotate(12deg)}.swipe-hint-text{color:var(--muted);letter-spacing:.02em;font-size:12px}.stats{flex-direction:column;gap:24px;display:flex}.stat-row{grid-template-columns:repeat(3,1fr);gap:10px;display:grid}.stat-card{background:var(--surface);border:1px solid var(--border);text-align:center;border-radius:16px;padding:16px 14px}.stat-card-accent{background:var(--accent-soft);border-color:#0000}.stat-card-value{letter-spacing:-.02em;color:var(--text);font-size:28px;font-weight:700;line-height:1.1}.stat-card-accent .stat-card-value{color:var(--accent)}.stat-card-label{color:var(--muted);text-transform:uppercase;letter-spacing:.04em;margin-top:4px;font-size:12px;font-weight:600}.stats-section h3{margin:0 0 6px;font-size:16px;font-weight:700}.stats-hint{color:var(--muted);margin:0 0 16px;font-size:13px;line-height:1.5}.box-list{flex-direction:column;gap:10px;margin:0;padding:0;list-style:none;display:flex}.box-row{grid-template-columns:110px 1fr 36px;align-items:center;gap:10px;display:grid}.box-label{flex-direction:column;display:flex}.box-num{font-size:14px;font-weight:700}.box-interval{color:var(--muted);font-size:11px}.box-bar{background:var(--border);border-radius:8px;height:14px;overflow:hidden}.box-fill{border-radius:8px;height:100%;transition:width .4s cubic-bezier(.2,.8,.2,1)}.box-fill-1{background:#f97316}.box-fill-2{background:#eab308}.box-fill-3{background:#84cc16}.box-fill-4{background:#22c55e}.box-fill-5{background:#15803d}.box-count{text-align:right;color:var(--text);font-size:14px;font-weight:700}.deck-grid{grid-template-columns:repeat(4,1fr);gap:10px;display:grid}.deck-stat{background:var(--surface);border:1px solid var(--border);text-align:center;border-radius:12px;padding:12px 8px}.deck-stat-value{color:var(--text);font-size:22px;font-weight:700}.deck-stat-label{color:var(--muted);text-transform:uppercase;letter-spacing:.04em;margin-top:2px;font-size:11px;font-weight:600}@media (width<=480px){.deck-grid{grid-template-columns:repeat(2,1fr)}.box-row{grid-template-columns:90px 1fr 30px}}.grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:18px;display:grid}.gallery-card{background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:16px;flex-direction:column;display:flex;overflow:hidden}.gallery-card img{aspect-ratio:1;object-fit:cover;width:100%}.gallery-card-body{flex-direction:column;gap:4px;padding:14px 16px 16px;display:flex}.gallery-card .native{word-break:keep-all;margin:0;font-size:22px;font-weight:700}.gallery-card .romanization{color:var(--muted);font-size:13px;font-style:italic}.gallery-card .english{color:var(--accent);margin-top:2px;font-size:15px;font-weight:600}.story-small{color:#444;margin:8px 0 10px;font-size:13px;line-height:1.5}audio{width:100%;height:32px}@media (width>=720px){.page{max-width:1100px}.review{gap:18px}.review .flip-card,.answer-buttons{max-width:560px}}@media (width<=480px){.page{padding:12px 8px 24px;padding-top:max(12px, env(safe-area-inset-top));padding-left:max(8px, env(safe-area-inset-left));padding-right:max(8px, env(safe-area-inset-right));padding-bottom:max(24px, env(safe-area-inset-bottom))}header{gap:10px;margin-bottom:14px}.brand h1{font-size:22px}.tagline{font-size:12px}.flip-card{max-width:100%;height:min(72dvh,640px)}.card-image-wrap{flex:0 0 56%}.card-text-area{padding:14px 16px 12px}.back-content{padding:14px 16px 16px}.answer-buttons{gap:10px;max-width:100%}.btn{padding:14px 10px;font-size:15px}}@media (width<=360px){.flip-card{height:min(70dvh,580px)}.native-large{font-size:clamp(24px,7vw,30px)}}
