:root{--bg-primary: #0a0a0b;--bg-secondary: #18181b;--bg-tertiary: #27272a;--reading-bg: #0f0f10;--text-primary: #fafafa;--text-secondary: #a1a1aa;--text-tertiary: #71717a;--accent: #ff7a59;--accent-soft: #ffb4a2;--accent-dark: #4a1b0c;--success: #4ade80;--warning: #fbbf24;--border: rgba(255, 255, 255, .06);--ease-out: cubic-bezier(.23, 1, .32, 1);--ease-drawer: cubic-bezier(.32, .72, 0, 1);--font-ui: "Pretendard Variable", -apple-system, system-ui, sans-serif;--font-serif: "Lora", Georgia, serif;--font-mono: "JetBrains Mono", monospace}*{box-sizing:border-box;margin:0;padding:0}html,body{background:#000}body{font-family:var(--font-ui);-webkit-font-smoothing:antialiased;display:flex;justify-content:center}#root{width:100%;max-width:430px;min-height:100vh;background:var(--bg-primary);color:var(--text-primary);position:relative;overflow-x:hidden}button{font-family:inherit;border:none;background:none;color:inherit;cursor:pointer;transition:transform .14s var(--ease-out)}button:active{transform:scale(.97)}::-webkit-scrollbar{width:0}.screen{padding-bottom:88px;animation:fade .28s var(--ease-out)}@keyframes fade{0%{opacity:0}to{opacity:1}}.hdr{display:flex;align-items:center;padding:22px 20px 12px}.logo{display:flex;align-items:center;gap:7px;font-size:16px;font-weight:600;letter-spacing:-.02em}.drip-dot{width:7px;height:7px;border-radius:50%;background:var(--accent);animation:pulse 2.4s var(--ease-out) infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.8)}}.streak{margin-left:auto;display:flex;align-items:center;gap:5px;background:var(--bg-secondary);padding:6px 11px;border-radius:999px;font-size:13px;font-weight:600}.h-title{font-family:var(--font-serif);font-size:25px;font-weight:600;padding:6px 20px 0;letter-spacing:-.01em}.h-sub{display:flex;align-items:center;gap:8px;padding:7px 20px 16px;font-size:13px;color:var(--text-tertiary)}.cd{display:inline-flex;align-items:center;gap:6px;color:var(--text-secondary)}.cd-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);animation:pulse 2s var(--ease-out) infinite}.cards{padding:0 16px;display:flex;flex-direction:column;gap:12px}.card{position:relative;border-radius:16px;overflow:hidden;background:var(--bg-secondary);border:1px solid var(--border);text-align:left;width:100%;display:block}.card.hero{min-height:248px}.card-img{position:absolute;top:3px;right:0;bottom:0;left:0;width:100%;height:calc(100% - 3px);object-fit:cover;z-index:0}.card-line{height:3px;position:relative;z-index:3}.card .tint{position:absolute;top:3px;right:0;bottom:0;left:0;z-index:1}.card-body{padding:16px 18px;position:relative;z-index:2}.card.hero .card-body{position:absolute;bottom:0;left:0;right:0}.card.compact{min-height:150px;display:flex;flex-direction:column}.card.compact .card-body{margin-top:auto}.card-meta{display:flex;align-items:center;gap:8px;margin-bottom:9px}.card-cat{font-size:11px;font-weight:600;letter-spacing:.08em;color:var(--accent)}.card.hero .card-cat{color:var(--accent-soft)}.card-read{font-size:11px;color:var(--text-secondary)}.card-title{font-family:var(--font-serif);line-height:1.3;font-weight:600;color:var(--text-primary)}.card.hero .card-title{font-size:21px}.card.compact .card-title{font-size:17px}.card-sum{font-size:12.5px;line-height:1.55;color:var(--text-secondary);margin-top:8px}.h-progress{padding:0 20px 4px;font-size:12px;color:var(--accent-soft)}.card.read{opacity:.6;transition:opacity .32s var(--ease-out)}.card.read .card-title{text-decoration:line-through;text-decoration-color:var(--accent);text-decoration-thickness:2px}.done-stamp{position:absolute;top:12px;right:12px;z-index:4;font-size:10px;font-weight:700;letter-spacing:.04em;color:var(--accent-dark);background:var(--accent-soft);padding:3px 9px;border-radius:999px;transform:rotate(-7deg)}.card.just .done-stamp{animation:stampPop .45s var(--ease-out) backwards}@keyframes stampPop{0%{opacity:0;transform:rotate(-7deg) scale(1.6)}60%{transform:rotate(-7deg) scale(.92)}to{opacity:1;transform:rotate(-7deg) scale(1)}}.review-badge{display:flex;align-items:center;gap:7px;font-size:12px;color:var(--accent-soft);background:#ff7a5914;border:1px solid rgba(255,122,89,.2);border-radius:999px;padding:8px 14px;margin-bottom:16px}.expr-blank{border-bottom:1.5px dashed var(--accent);background:#ff7a591f;border-radius:3px;color:transparent;cursor:pointer;letter-spacing:.5px;transition:background .16s var(--ease-out)}.expr-blank:active{background:#ff7a5938}.cta-ghost{background:var(--bg-secondary);color:var(--text-secondary)}.nav{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:430px;display:flex;padding:10px 8px calc(10px + env(safe-area-inset-bottom));background:#0a0a0beb;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-top:1px solid var(--border)}.nav-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;font-size:10px;color:var(--text-tertiary)}.nav-item.on{color:var(--accent)}.nav-ico{width:22px;height:22px}.a-top{position:sticky;top:0;z-index:5;display:flex;align-items:center;gap:14px;padding:16px 18px 12px;background:var(--reading-bg)}.a-top .sp{margin-left:auto;display:flex;gap:18px;align-items:center}.progress{height:2px;background:var(--bg-tertiary);position:sticky;top:54px;z-index:5}.progress>div{height:100%;background:var(--accent);transition:width 80ms linear}.a-cover-wrap{position:relative;width:100%;height:230px;overflow:hidden}.a-cover{width:100%;height:100%;object-fit:cover;display:block}.a-cover-fade{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(transparent 55%,var(--reading-bg))}.a-inner{padding:16px 20px 0;background:var(--reading-bg);position:relative}.a-cover-wrap+.a-inner{margin-top:-40px}.pills{display:inline-flex;gap:4px;padding:4px;background:var(--bg-secondary);border-radius:999px;margin-bottom:20px}.pill{padding:7px 15px;border-radius:999px;font-size:12.5px;color:var(--text-secondary);white-space:nowrap}.pill.on{background:var(--accent);color:var(--accent-dark);font-weight:600}.a-meta{display:flex;align-items:center;gap:8px;font-size:12px;margin-bottom:14px}.a-meta .c{color:var(--accent);font-weight:600}.a-meta .m{color:var(--text-secondary)}.a-title{font-family:var(--font-serif);font-size:27px;line-height:1.25;font-weight:600;letter-spacing:-.01em;margin-bottom:18px}.a-body{font-family:var(--font-serif);font-size:18px;line-height:1.8}.body-p{margin:0 0 1.35em}.body-p:last-child{margin-bottom:0}.expr-mark{border-bottom:1.5px dotted var(--accent-soft);text-underline-offset:3px;cursor:pointer;transition:background .2s var(--ease-out);border-radius:2px}.expr-mark:active{background:#ff7a591f}.lang-cap{font-size:11px;letter-spacing:.06em;color:var(--text-tertiary);margin-bottom:12px}.ko-first{font-family:var(--font-ui);color:var(--text-primary)}.ko-p{font-size:16.5px;line-height:1.9;margin:0 0 1.25em;letter-spacing:-.003em}.ko-p:last-child{margin-bottom:0}.lang-divider{display:flex;align-items:center;gap:12px;margin:28px 0 20px}.lang-divider:before,.lang-divider:after{content:"";flex:1;height:1px;background:var(--border)}.lang-divider span{font-size:12px;color:var(--accent-soft);white-space:nowrap}.sod{margin:40px 0 0;padding:20px;border-radius:18px;background:#1c1410;border:1px solid rgba(255,122,89,.28)}.sod-l{font-size:10px;letter-spacing:.12em;color:var(--accent-soft);margin-bottom:9px}.sod-en{font-family:var(--font-serif);font-size:22px;line-height:1.4}.sod-ko{font-size:13px;color:var(--text-secondary);margin-top:9px}.learn-card{background:var(--bg-secondary);border-radius:18px;padding:18px 16px 20px;margin-top:16px}.sec-head{margin-bottom:15px}.sec-eyebrow{font-size:10px;letter-spacing:.14em;color:var(--accent);font-weight:600;margin-bottom:4px}.sec-titlerow{display:flex;align-items:center;gap:8px}.sec-title{font-size:18px;font-weight:600;color:var(--text-primary)}.sec-chip{font-size:12px;color:var(--text-secondary);background:var(--bg-tertiary);padding:2px 9px;border-radius:999px}.expr-list{display:flex;flex-direction:column;gap:8px}.expr-card{display:block;width:100%;text-align:left;background:var(--reading-bg);border-radius:12px;padding:13px 14px 13px 16px;border-left:2px solid var(--accent-soft);transition:transform .14s var(--ease-out),background .14s var(--ease-out)}.expr-card:active{transform:scale(.99);background:#141416}.expr-row{display:flex;align-items:center}.expr-phrase{font-family:var(--font-mono);font-size:16px;font-weight:500;color:var(--text-primary)}.expr-mean{font-size:13px;color:var(--text-secondary);margin-left:9px}.expr-row .chev{margin-left:auto;color:#52525b;display:inline-flex}.expr-nuance-prev{font-size:12.5px;color:var(--accent-soft);margin-top:7px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sec{font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--text-tertiary);margin:38px 0 14px;display:flex;align-items:center;gap:10px}.sec:after{content:"";flex:1;height:1px;background:var(--border)}.qz{padding:4px 0 16px}.qz+.qz{border-top:1px solid var(--border);padding-top:16px}.qz-t{font-size:11px;letter-spacing:.08em;color:var(--accent);margin-bottom:8px}.qz-quote{font-family:var(--font-serif);font-style:italic;color:var(--text-secondary);padding-left:12px;border-left:1px solid var(--accent);margin:8px 0;line-height:1.5}.qz-opt{font-size:14px;padding:12px 14px;border-radius:10px;margin-top:8px;background:var(--bg-tertiary);color:#d4d4d8;border:1px solid transparent;cursor:pointer;transition:background .2s var(--ease-out),border-color .2s var(--ease-out),color .2s var(--ease-out)}.qz-opt:active{transform:scale(.99)}.qz-opt.correct{background:#143420;border-color:#4ade8073;color:var(--success)}.qz-opt.wrong{background:#2a1414;border-color:#f8717166;color:#f87171}.qz-exp{font-size:13px;color:var(--text-secondary);margin-top:12px;line-height:1.6}.match-hint{font-size:12px;color:var(--text-tertiary);margin:2px 0 12px}.mg-wrap{position:relative;display:flex;gap:46px;align-items:flex-start}.mg-svg{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none;overflow:visible;z-index:2}.mg-path{stroke-dasharray:1;stroke-dashoffset:1;animation:mgdraw .45s var(--ease-out) forwards}@keyframes mgdraw{to{stroke-dashoffset:0}}.mg-col{flex:1;min-width:0;display:flex;flex-direction:column;gap:10px}.mg-item{position:relative;z-index:1;width:100%;text-align:left;background:var(--reading-bg);border:1px solid var(--border);border-radius:12px;padding:12px 13px;transition:transform .14s var(--ease-out),border-color .16s var(--ease-out),box-shadow .16s var(--ease-out),background .16s var(--ease-out)}.mg-col.right .mg-item{text-align:right}.mg-item:not(:disabled):active{transform:scale(.98)}.mg-phrase{font-family:var(--font-mono);font-size:14px;color:var(--text-primary)}.mg-mean{font-size:13px;color:var(--text-secondary);line-height:1.45}.mg-item.on{border-color:var(--accent);box-shadow:0 0 0 1.5px var(--accent);background:#ff7a5912;transform:scale(1.02)}.mg-item.matched{border-color:#ffb4a259;background:#161318;opacity:.92}.mg-item.matched .mg-phrase,.mg-item.matched .mg-mean{color:var(--accent-soft)}.mg-item.no{border-color:#f8717180;background:#2a1414;animation:shake .4s var(--ease-out)}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.cta{margin:24px 0 8px;display:flex;align-items:center;justify-content:center;gap:8px;width:100%;background:var(--accent);color:var(--accent-dark);font-weight:600;font-size:15px;padding:15px;border-radius:12px}.sheet-scrim{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:20;animation:fade .2s var(--ease-out)}.sheet{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:430px;background:var(--bg-secondary);border-radius:22px 22px 0 0;z-index:21;padding:8px 22px 30px;animation:rise .32s var(--ease-drawer);max-height:72vh;overflow-y:auto}@keyframes rise{0%{transform:translate(-50%,100%)}to{transform:translate(-50%)}}.sheet-grip{width:36px;height:4px;border-radius:999px;background:var(--bg-tertiary);margin:8px auto 18px}.sheet-phrase{font-family:var(--font-mono);font-size:20px;font-weight:500}.sheet-ipa{font-family:var(--font-mono);font-size:13px;color:var(--text-tertiary);margin-top:4px}.sheet-mean{font-size:15px;color:var(--text-secondary);margin:16px 0 12px}.sheet-nuance{font-size:14px;line-height:1.65;background:var(--reading-bg);padding:14px 16px;border-radius:12px}.sheet-nuance b{color:var(--accent-soft)}.sheet-ex{font-family:var(--font-serif);font-size:14.5px;line-height:1.6;color:var(--text-primary);margin-top:14px}.sheet-ex .ko{color:var(--text-tertiary)}.loading{display:grid;place-items:center;height:100vh;color:var(--text-tertiary);font-size:14px}.tab-screen{padding:26px 20px 100px}.tab-title{font-family:var(--font-serif);font-size:26px;font-weight:600;margin-bottom:18px}.tab-note{color:var(--text-tertiary);font-size:14px;line-height:1.6}.star-btn{color:var(--text-tertiary);display:inline-flex}.star-btn.on{color:var(--accent)}.a-toast{position:fixed;left:50%;bottom:96px;transform:translate(-50%);z-index:30;background:var(--bg-secondary);color:var(--text-primary);font-size:13px;padding:10px 16px;border-radius:999px;border:1px solid var(--border);animation:fade .2s var(--ease-out)}.auth-screen{min-height:100vh;background:var(--bg-primary);padding:18px;position:relative}.auth-close{position:absolute;top:18px;left:16px;color:var(--text-secondary)}.auth-inner{max-width:360px;margin:0 auto;padding-top:84px}.auth-logo{display:flex;align-items:center;gap:7px;font-size:16px;font-weight:600}.auth-h{font-family:var(--font-serif);font-size:27px;line-height:1.3;font-weight:600;margin:22px 0 10px}.auth-sub{color:var(--text-secondary);font-size:14px;line-height:1.6;margin-bottom:22px}.auth-kakao{width:100%;background:#fee500;color:#191600;font-weight:600;font-size:15px;padding:14px;border-radius:12px;margin-bottom:12px}.auth-field{display:flex;flex-direction:column;gap:8px}.auth-field input{width:100%;background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;padding:14px;color:var(--text-primary);font-size:15px;font-family:inherit}.auth-field input:focus{outline:none;border-color:var(--accent)}.auth-primary{background:var(--accent);color:var(--accent-dark);font-weight:600;font-size:15px;padding:14px;border-radius:12px}.auth-primary:disabled{opacity:.5}.auth-err{color:#f87171;font-size:13px;margin-top:10px}.auth-sent{margin-top:6px}.auth-fine{color:var(--text-tertiary);font-size:12px;margin-top:22px;line-height:1.5}.my-guest{background:var(--bg-secondary);border-radius:16px;padding:22px;display:flex;flex-direction:column;gap:16px}.my-guest p{color:var(--text-secondary);font-size:14px;line-height:1.6}.my-card{background:var(--bg-secondary);border-radius:16px;padding:16px 18px;margin-bottom:12px}.my-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;font-size:14px;color:var(--text-secondary)}.my-row b{color:var(--text-primary);font-weight:600}.my-row b.plus{color:var(--accent)}.my-label{font-size:12px;color:var(--text-tertiary);margin-bottom:10px}.my-logout{width:100%;background:var(--bg-secondary);color:var(--text-secondary);padding:13px;border-radius:12px;font-size:14px;margin-top:8px}.arc-list{display:flex;flex-direction:column;gap:10px}.arc-item{text-align:left;width:100%;background:var(--bg-secondary);border:1px solid var(--border);border-radius:14px;padding:16px;transition:transform .14s var(--ease-out)}.arc-item:active{transform:scale(.99)}.arc-cat{font-size:11px;font-weight:600;letter-spacing:.06em;color:var(--accent);margin-bottom:6px}.arc-title{font-family:var(--font-serif);font-size:17px;font-weight:600;line-height:1.3}.arc-sum{font-size:13px;color:var(--text-secondary);margin-top:6px;line-height:1.5}
