:root{--bg:#eef2ee;--surface:#fff;--text:#3f4a45;--text-strong:#14201d;--muted:#697770;--border:#d9e0da;--focus:#c15a35;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}html{scroll-behavior:smooth}body{min-width:320px;min-height:100svh;margin:0}button,input{font:inherit}button:focus-visible,a:focus-visible,input:focus-visible{outline-offset:3px;outline:3px solid #c15a356b}h1,h2,p{margin:0}.app-shell{background:var(--bg);min-height:100svh;color:var(--text);grid-template-columns:280px minmax(0,1fr);display:grid}.sidebar{border-right:1px solid var(--border);background:#f8faf8;flex-direction:column;gap:28px;min-height:100svh;padding:28px 18px;display:flex;position:sticky;top:0}.brand,.nav-list a,.primary-action,.session-item,.review-item{align-items:center;display:flex}.brand{gap:12px;padding:0 8px}.brand-mark{color:#f9fafb;background:#1d4f4a;border-radius:8px;place-items:center;width:44px;height:44px;display:grid}.brand strong,.study-item strong,.session-item strong,.phrase-item strong,.sidebar-panel strong,.metrics-grid strong{color:var(--text-strong)}.brand span,.study-item span,.session-item span,.metrics-grid span{color:var(--muted);font-size:.88rem;display:block}.nav-list{gap:6px;display:grid}.nav-list a{min-height:42px;color:var(--text);border-radius:8px;gap:10px;padding:0 12px;font-weight:700;text-decoration:none}.nav-list a:hover,.nav-list a.active{color:#103b36;background:#e6f1ed}.sidebar-panel{border:1px solid var(--border);background:#fff;border-radius:8px;margin-top:auto;padding:18px}.sidebar-panel p{color:var(--muted);margin-top:8px;font-size:.92rem}.workspace{padding:32px}.topbar,.section-heading,.hero-stats,.content-grid,.metrics-grid{display:grid}.topbar{grid-template-columns:minmax(0,1fr) auto;align-items:start;gap:20px}.topbar h1{max-width:820px;color:var(--text-strong);margin:6px 0 0;font-size:2.4rem;font-weight:800;line-height:1.12}.eyebrow{color:#3b716b;letter-spacing:.08em;text-transform:uppercase;margin:0;font-size:.76rem;font-weight:800}.primary-action{color:#fff;min-height:42px;font:inherit;cursor:pointer;background:#1d4f4a;border:0;border-radius:8px;gap:8px;padding:0 15px;font-weight:800}.auth-panel{background:#fff9d8;border:1px solid #e3d7a3;border-radius:8px;grid-template-columns:minmax(0,1fr) minmax(280px,.62fr);gap:18px;margin-top:24px;padding:20px;display:grid}.auth-copy h2{color:var(--text-strong);margin-top:4px;font-size:1.2rem}.auth-copy p:last-child{color:#5b5542;margin-top:8px}.auth-actions{align-content:start;gap:12px;display:grid}.kakao-login-button{color:#191600;min-height:44px;font:inherit;cursor:pointer;background:#fee500;border:0;border-radius:8px;justify-content:center;align-items:center;gap:8px;font-weight:900;display:inline-flex}.kakao-login-button:disabled{cursor:not-allowed;opacity:.58}.auth-actions dl{overflow-wrap:anywhere;background:#ffffffb8;border-radius:8px;margin:0;padding:12px}.auth-actions dt{color:#6d674f;font-size:.78rem;font-weight:900}.auth-actions dd{color:var(--text-strong);margin:4px 0 0;font-size:.86rem}.auth-notice{color:#5b5542;background:#ffffffa8;border-radius:8px;grid-column:1/-1;padding:12px 14px}.auth-notice strong,.auth-notice span{display:block}.auth-notice strong{color:var(--text-strong);margin-bottom:3px}.auth-notice.success{color:#17443d;background:#e6f1ed}.auth-notice.error{color:#71301c;background:#fff0e8}.auth-notice code{overflow-wrap:anywhere;max-width:100%;color:var(--text-strong);background:#ffffffb8;border-radius:6px;margin-top:6px;padding:3px 6px;display:inline-block}.language-picker{border:1px solid var(--border);background:var(--surface);border-radius:8px;margin-top:24px;padding:20px}.language-picker-head,.language-columns,.language-route,.language-options{display:grid}.language-picker-head{grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:16px}.language-picker h2{color:var(--text-strong);margin-top:4px;font-size:1.2rem}.language-route{color:#1d4f4a;background:#e6f1ed;border-radius:8px;grid-auto-flow:column;align-items:center;gap:8px;min-height:38px;padding:0 12px;font-weight:800}.language-route span{color:var(--muted)}.language-columns{grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;margin-top:18px}.language-picker fieldset{border:0;min-width:0;margin:0;padding:0}.language-picker legend{color:var(--text-strong);margin-bottom:10px;font-weight:800}.language-options{grid-template-columns:repeat(auto-fit,minmax(118px,1fr));gap:8px}.language-options button{min-height:64px;color:var(--text);text-align:left;cursor:pointer;background:#f8faf8;border:1px solid #d9e0da;border-radius:8px;padding:10px 12px}.language-options button:hover,.language-options button.selected{background:#e6f1ed;border-color:#2d6f65}.language-options button.selected{box-shadow:inset 0 0 0 1px #2d6f65}.language-options span,.language-options small{display:block}.language-options span{color:var(--text-strong);font-weight:900}.language-options small{color:var(--muted);margin-top:3px}.hero-band{color:#f8fafc;background-color:#0000;background-image:linear-gradient(135deg,#0e2d29eb,#2a5d55d6),url(https://images.unsplash.com/photo-1456513080510-7bf3a84b82f8?auto=format&fit=crop&w=1600&q=80);background-position:50%;background-repeat:repeat,repeat;background-size:cover;background-attachment:scroll,scroll;background-origin:padding-box,padding-box;background-clip:border-box,border-box;border-radius:8px;grid-template-columns:minmax(0,1.45fr) minmax(280px,.85fr);align-items:end;gap:28px;margin-top:28px;padding:28px;display:grid}.hero-band .eyebrow,.hero-band p{color:#d7efe8}.hero-band h2{color:#fff;max-width:820px;margin:10px 0 12px;font-size:2rem;line-height:1.18}.hero-band p{max-width:760px}.hero-stats{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.hero-stats div{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffff1f;border:1px solid #ffffff47;border-radius:8px;min-height:102px;padding:14px}.hero-stats strong{color:#fff;font-size:2rem;line-height:1;display:block}.hero-stats span{color:#d7efe8;margin-top:8px;font-size:.88rem;display:block}.metrics-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin-top:18px}.metrics-grid article,.panel{border:1px solid var(--border);background:var(--surface);border-radius:8px}.metrics-grid article{align-content:start;gap:9px;min-height:118px;padding:18px;display:grid}.metrics-grid svg{color:#c15a35}.content-grid{grid-template-columns:minmax(0,1.08fr) minmax(320px,.92fr);gap:18px;margin-top:18px}.panel{padding:20px}.section-heading{grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:12px;margin-bottom:16px}.section-heading h2{color:var(--text-strong);margin:3px 0 0;font-size:1.22rem}.icon-button{border:1px solid var(--border);width:34px;height:34px;color:var(--text);cursor:pointer;background:#fff;border-radius:8px;place-items:center;display:grid}.study-list,.session-list,.phrase-list,.review-list{gap:12px;display:grid}.study-item{background:#f8faf8;border-radius:8px;padding:16px}.progress{background:#dfe9e4;border-radius:999px;height:8px;margin-top:14px;overflow:hidden}.progress span{border-radius:inherit;background:#2d6f65;height:100%;display:block}.session-item{background:#fff7f1;border-radius:8px;align-items:flex-start;gap:12px;padding:14px}.avatar{color:#fff;background:#c15a35;border-radius:8px;flex:none;place-items:center;width:42px;height:42px;font-weight:900;display:grid}.session-item p{color:var(--text-strong);margin:7px 0;font-weight:700}.session-item small{color:var(--muted);align-items:center;gap:5px;display:inline-flex}.phrase-item{border:1px solid #e4e7df;border-radius:8px;padding:15px}.phrase-item span{color:#1d4f4a;background:#e6f1ed;border-radius:999px;margin-bottom:8px;padding:3px 8px;font-size:.78rem;font-weight:800;display:inline-flex}.phrase-item p{color:var(--muted)}.phrase-item strong{margin-top:4px;display:block}.review-item{min-height:44px;color:var(--text-strong);cursor:pointer;gap:10px;font-weight:700}.review-item input{opacity:0;block-size:1px;inline-size:1px;position:absolute}.review-item span{color:#0000;border:1px solid #afbab4;border-radius:6px;place-items:center;width:22px;height:22px;display:grid}.review-item input:checked+span{color:#fff;background:#1d4f4a;border-color:#1d4f4a}.mobile-nav{display:none}@media (width<=1060px){.app-shell{grid-template-columns:1fr}.sidebar{border-right:0;border-bottom:1px solid var(--border);min-height:auto;padding:18px 20px;position:static}.nav-list,.sidebar-panel{display:none}.workspace{padding:24px 20px 92px}}@media (width<=820px){.topbar,.auth-panel,.language-picker-head,.language-columns,.hero-band,.metrics-grid,.content-grid{grid-template-columns:1fr}.topbar h1{font-size:1.95rem}.primary-action{justify-content:center;width:100%}.language-route{justify-content:start}.hero-band{align-items:start;padding:22px}.hero-band h2{font-size:1.55rem}.hero-stats{grid-template-columns:repeat(3,1fr)}.hero-stats div{min-height:86px;padding:12px}.hero-stats strong{font-size:1.55rem}.mobile-nav{z-index:20;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#fffffff0;border:1px solid #103b3626;border-radius:8px;grid-template-columns:repeat(4,1fr);align-items:center;height:58px;display:grid;position:fixed;bottom:14px;left:16px;right:16px;box-shadow:0 18px 40px #10182829}.mobile-nav a{min-height:58px;color:var(--muted);place-items:center;display:grid}.mobile-nav a.active{color:#1d4f4a}}@media (width<=520px){.workspace{padding-inline:14px}.topbar h1{font-size:1.65rem}.hero-stats{grid-template-columns:1fr}.panel,.metrics-grid article{padding:16px}}
