:root{--bg: #0d1117;--panel: #161c25;--panel-2: #1f2733;--line: #2b3442;--text: #e8eef5;--muted: #8b97a7;--accent: #5aa2ff;--accent-2: #2f6fd0;--blue: #5aa2ff;--red: #ff6b6b;--green: #34d399;--gold: #f5c451;--radius: 16px;--maxw: 1000px;--shadow: 0 6px 24px rgba(0, 0, 0, .28);--shadow-lg: 0 14px 40px rgba(0, 0, 0, .38);--ring: 0 0 0 3px rgba(90, 162, 255, .35);--ease: cubic-bezier(.22, .61, .36, 1);--font: "Pretendard", "Pretendard Variable", "Apple SD Gothic Neo", "Malgun Gothic", system-ui, -apple-system, "Segoe UI", sans-serif}*{box-sizing:border-box}html,body,#root{height:100%}html{scroll-behavior:smooth}body{margin:0;background:radial-gradient(900px 500px at 85% -8%,rgba(90,162,255,.1) 0%,transparent 55%),radial-gradient(1100px 600px at 10% -10%,rgba(52,211,153,.06) 0%,transparent 55%),var(--bg);color:var(--text);font-family:var(--font);line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}.main>*{animation:fade-in .32s var(--ease) both}@keyframes fade-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}button:focus-visible,a:focus-visible,input:focus-visible,textarea:focus-visible{outline:none;box-shadow:var(--ring);border-radius:8px}@media (prefers-reduced-motion: reduce){*{animation:none!important;transition:none!important;scroll-behavior:auto}}.app{min-height:100%;display:flex;flex-direction:column}.main{width:100%;max-width:var(--maxw);margin:0 auto;padding:24px 20px 60px;flex:1}.header{position:sticky;top:0;z-index:10;display:flex;align-items:center;justify-content:space-between;padding:12px 20px;background:#0f1419d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}.brand{background:none;border:none;color:var(--text);font-size:22px;font-weight:800;cursor:pointer;letter-spacing:-.5px}.brand span{color:var(--accent)}.header-right{display:flex;align-items:center;gap:16px}.nick-chip{background:var(--panel-2);border:1px solid var(--line);color:var(--text);border-radius:99px;padding:7px 14px;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit}.nick-chip:hover{border-color:var(--accent)}.pro-tag{background:var(--gold);color:#1a1300;font-size:10px;font-weight:800;border-radius:4px;padding:1px 5px;margin:0 4px}.pro-tag.big{font-size:13px;padding:2px 8px;vertical-align:middle}.header-progress{font-size:13px;color:var(--muted);text-align:right}.header-progress .bar{width:160px;height:6px;background:var(--line);border-radius:99px;margin-top:5px;overflow:hidden}.header-progress .bar-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--green));transition:width .4s ease}.btn{font-family:inherit;font-size:15px;font-weight:600;border-radius:10px;border:1px solid var(--line);background:var(--panel-2);color:var(--text);padding:10px 18px;cursor:pointer;transition:.15s}.btn:hover{border-color:var(--accent)}.btn.primary{background:linear-gradient(180deg,var(--accent),var(--accent-2));border:none;color:#fff}.btn.primary:hover{filter:brightness(1.08)}.btn.primary:disabled{opacity:.45;cursor:not-allowed;filter:none}.btn.ghost{background:transparent}.btn.tiny{font-size:12px;padding:5px 10px}.hero{text-align:center;padding:30px 0 10px}.hero h1{font-size:34px;margin:0 0 8px;letter-spacing:-1px}.hero-sub{color:var(--muted);font-size:17px}.hero-sub b{color:var(--text)}.unit-cards{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:26px}.unit-card{text-align:left;border:1px solid var(--line);background:var(--panel);border-radius:var(--radius);padding:22px;cursor:pointer;color:var(--text);font-family:inherit;transition:.18s}.unit-card.open:hover{transform:translateY(-3px);border-color:var(--accent)}.unit-card.locked{opacity:.6;cursor:pointer}.unit-card h3{margin:10px 0 8px;font-size:21px}.unit-card p{color:var(--muted);margin:0 0 14px;font-size:14px}.unit-tag{font-size:12px;font-weight:700;color:var(--accent);letter-spacing:.5px}.unit-foot{font-size:13px;color:var(--muted);border-top:1px solid var(--line);padding-top:10px}.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:22px;margin-bottom:22px}.section-title{font-size:22px;margin:28px 0 4px}.section-desc{color:var(--muted);margin:0 0 16px}.muted{color:var(--muted)}.prologue{padding:0;overflow:hidden}.prologue-toggle{width:100%;text-align:left;background:var(--panel-2);border:none;color:var(--text);font-size:17px;font-weight:700;padding:16px 20px;cursor:pointer}.prologue-body{padding:8px 20px 20px}.prologue-body .lead{font-size:17px;color:var(--text);font-weight:600}.prologue-body p{color:var(--muted)}.promise{background:var(--panel-2);border:1px solid var(--line);border-radius:12px;padding:16px 18px;margin-top:14px}.promise h4{margin:0 0 6px;color:var(--gold)}.promise ul{margin:8px 0 14px;padding-left:18px}.promise li{margin:4px 0}.sign-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.text-input{background:var(--bg);border:1px solid var(--line);border-radius:8px;color:var(--text);padding:9px 12px;font-family:inherit;font-size:15px}.signed{color:var(--green);font-weight:600}.part-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px;margin-bottom:8px}.part-card{text-align:left;background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:16px;cursor:pointer;color:var(--text);font-family:inherit;transition:.15s}.part-card:hover{border-color:var(--accent);transform:translateY(-2px)}.part-card.done{border-color:#34d39980}.part-card-head{display:flex;justify-content:space-between;align-items:center}.part-title{font-weight:700;font-size:15px}.badge{color:var(--green);font-weight:800}.part-sub{color:var(--muted);font-size:12px;margin:4px 0}.part-msg{font-size:14px;margin:6px 0 12px;color:var(--text)}.part-foot{display:flex;justify-content:space-between;align-items:center;font-size:12px}.status-tag{font-size:11px;font-weight:700;color:var(--muted);border:1px solid var(--line);border-radius:99px;padding:3px 9px}.status-tag.done{color:var(--green);border-color:#34d39980}.bonus h3{margin:0 0 4px}.bonus-list{list-style:none;padding:0;margin:14px 0 0;display:grid;grid-template-columns:1fr 1fr;gap:8px 20px}.bonus-list li{display:flex;gap:8px;align-items:baseline;border-bottom:1px solid var(--line);padding-bottom:6px}.bonus-list .bk{color:var(--muted);font-size:13px;min-width:44%}.bonus-list .arrow{color:var(--accent)}.bonus-list .be{font-weight:600}.trainer-top{display:flex;align-items:center;gap:14px;margin-bottom:14px;flex-wrap:wrap}.trainer-top h2{font-size:20px;margin:0}.done-badge{color:var(--green);font-weight:700;font-size:13px;border:1px solid rgba(52,211,153,.5);border-radius:99px;padding:4px 12px}.done-badge.sm{font-size:12px;padding:3px 10px}.study-toolbar{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:12px 14px;margin-bottom:16px}.memo-group,.test-group{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.memo-label{font-weight:800;font-size:15px;margin-right:4px}.btn.chip{font-size:13px;padding:7px 14px;border-radius:99px;background:var(--panel-2)}.btn.chip.active{background:var(--accent-2);border-color:var(--accent);color:#fff}.test-btn{font-size:14px;padding:8px 16px;background:var(--panel-2);border-color:var(--gold);color:var(--gold);font-weight:700}.test-btn.active{background:var(--gold);color:#1a1300;border-color:var(--gold)}.board-hint{font-size:13px;margin:0 0 12px}.complete-msg{color:var(--green);font-weight:700;margin-right:14px}.en-line.example{color:var(--text);font-weight:600}.explain .subtitle{color:var(--muted);margin:0}.explain .message{font-size:20px;font-weight:700;color:var(--accent);margin:8px 0 18px}.explain h4{margin:16px 0 6px}.explain p{margin:0 0 8px}.mistakes{padding-left:18px;color:var(--muted)}.mistakes li{margin:6px 0}.level-head{display:flex;align-items:center;gap:12px;margin-bottom:14px;flex-wrap:wrap}.level-chip{background:var(--accent);color:#fff;font-weight:700;font-size:13px;padding:5px 12px;border-radius:99px}.sentence-list{list-style:none;padding:0;margin:0;counter-reset:s}.sentence-item{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:16px 18px;margin-bottom:12px}.ko-line{color:var(--muted);font-size:15px;margin-bottom:10px}.ko-line:before{counter-increment:s;content:counter(s) ". ";color:var(--accent);font-weight:700}.en-line{font-size:17px;line-height:2.4}.word{display:inline}.word.shown{margin:0 2px}.word.blank{display:inline-flex;align-items:baseline}.input-wrap{display:inline-flex;flex-direction:column;align-items:flex-start;vertical-align:baseline}.punct{white-space:pre}.cloze-input{background:var(--bg);border:none;border-bottom:2px solid var(--accent);color:var(--text);font-family:Consolas,monospace;font-size:16px;padding:2px 4px;min-width:3ch;text-align:center;outline:none}.cloze-input::placeholder{color:#51607a;letter-spacing:2px}.cloze-input.correct{color:var(--blue);border-color:var(--blue)}.cloze-input.wrong{color:var(--red);border-color:var(--red)}.answer-tag{font-size:12px;color:var(--green);margin-top:2px;font-family:Consolas,monospace}.answer-tag.block{display:block;margin-top:8px}.en-line.full .skeleton{font-family:Consolas,monospace;color:#6b7891;letter-spacing:1px;font-size:16px;margin-bottom:8px}.cloze-textarea{width:100%;background:var(--bg);border:1px solid var(--line);border-radius:8px;color:var(--text);font-family:inherit;font-size:16px;padding:10px 12px;resize:vertical}.cloze-textarea.correct{border-color:var(--blue);color:var(--blue)}.cloze-textarea.wrong{border-color:var(--red);color:var(--red)}.actions{margin-top:18px}.en-line .ph{font-family:Consolas,monospace;color:#6b7891;letter-spacing:1px}.test-actions{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.confirm-slot{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.nav-btns{display:flex;gap:8px}.nav-btns .btn:disabled{opacity:.4;cursor:not-allowed}.review-next-row{display:flex;justify-content:center}.review-next{width:100%;max-width:520px;padding:14px;font-size:16px}.step-dots{display:flex;gap:8px;justify-content:center;margin-top:22px}.step-dots .dot{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;background:var(--panel-2);border:1px solid var(--line);color:var(--muted);font-size:13px;font-weight:700}.step-dots .dot.on{background:var(--accent-2);color:#fff;border-color:var(--accent)}.step-dots .dot.active{box-shadow:0 0 0 3px #4f9cff40}.locked-card{text-align:center;padding:40px}.lock-icon{font-size:48px}.phase-note{background:var(--panel-2);border:1px dashed var(--line);border-radius:10px;padding:14px;margin-top:14px;color:var(--muted)}.footer{border-top:1px solid var(--line);padding:14px 20px;display:flex;justify-content:space-between;align-items:center;font-size:12px;max-width:var(--maxw);width:100%;margin:0 auto}.skeleton{font-family:Consolas,monospace;color:#6b7891;letter-spacing:1px;font-size:16px;margin-bottom:8px}.answer-tag.block.good{color:var(--blue)}.answer-tag.block.bad{color:var(--red)}.u2-head{display:flex;justify-content:space-between;align-items:baseline;flex-wrap:wrap;gap:8px}.u2-usage{font-size:13px}.empty{margin-top:16px}.my-scripts{list-style:none;padding:0;margin:18px 0 0}.my-script{display:flex;align-items:center;gap:10px;border:1px solid var(--line);border-radius:12px;padding:6px 10px 6px 6px;margin-bottom:10px}.ms-open{flex:1;text-align:left;background:var(--panel);border:none;color:var(--text);padding:10px 12px;border-radius:8px;cursor:pointer;display:flex;flex-direction:column;gap:3px;font-family:inherit}.ms-open:hover{background:var(--panel-2)}.ms-title{font-weight:700}.create-script .field{margin-top:8px}.length-options{display:flex;gap:10px;flex-wrap:wrap;margin:16px 0}.len-chip{position:relative;background:var(--panel-2);border:1px solid var(--line);color:var(--text);border-radius:10px;padding:12px 16px;cursor:pointer;font-family:inherit;font-size:14px;font-weight:600}.len-chip.active{border-color:var(--accent);background:var(--accent-2);color:#fff}.paid-badge{font-size:10px;background:var(--gold);color:#1a1300;border-radius:4px;padding:1px 5px;margin-left:6px;font-weight:800;vertical-align:middle}.notice{background:#f5c4511f;border:1px solid var(--gold);color:var(--gold);border-radius:10px;padding:12px 14px;margin:12px 0;font-size:14px}.voice-panel .voice-row{border-top:1px solid var(--line);padding:14px 0}.voice-label{font-weight:700;margin-bottom:10px}.voice-speed{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:8px}.voice-speed audio{height:32px}.voice-speed .muted{min-width:52px}.login-screen{min-height:100vh;display:grid;place-items:center;padding:24px}.login-card{width:100%;max-width:420px;background:var(--panel);border:1px solid var(--line);border-radius:18px;padding:32px}.brand.big{font-size:34px;font-weight:800;letter-spacing:-1px;margin-bottom:6px}.brand.big span{color:var(--accent)}.login-lead{font-weight:600;margin:0 0 8px}.login-card .muted{font-size:14px}.field{display:block;margin-top:16px}.field span{display:block;font-size:13px;color:var(--muted);margin-bottom:6px}.field .text-input{width:100%}.login-err{color:var(--red);font-size:14px;margin-top:12px}.btn.block{width:100%;margin-top:18px;padding:12px;font-size:16px}.login-note{font-size:12px;margin-top:14px}.review-head{display:flex;justify-content:space-between;align-items:baseline}.review-head h3{margin:0}.review-desc{margin:4px 0 14px;font-size:13px}.review-card{background:var(--panel-2);border:1px solid var(--line);border-radius:12px;padding:26px 20px;text-align:center}.review-ko{font-size:22px;font-weight:700;margin-bottom:16px}.review-en{font-size:20px;color:var(--accent);font-weight:600}.btn.show-en{background:transparent;border:1px dashed var(--accent);color:var(--accent)}.review-part{font-size:12px;margin-top:14px}.account .card p{margin:6px 0}.completed-list{margin-top:14px}.completed-list h4{margin:0 0 6px}.completed-list ul{margin:0;padding-left:18px;color:var(--muted);columns:2}.completed-list li{margin:3px 0}.script-list{list-style:none;padding:0;margin:10px 0 0}.script-row{border:1px solid var(--line);border-radius:10px;padding:12px 14px;margin-bottom:10px}.script-title{font-weight:600;margin-bottom:8px}.script-dls{display:flex;gap:8px;flex-wrap:wrap}.account-actions{display:flex;justify-content:space-between;align-items:center;margin-top:8px}a.btn{text-decoration:none;display:inline-block}@media (max-width: 680px){.unit-cards,.bonus-list{grid-template-columns:1fr}.hero h1{font-size:27px}.completed-list ul{columns:1}.header-right{gap:10px}.header-progress .bar{width:100px}}.btn{transition:transform .08s var(--ease),border-color .15s,background .15s,box-shadow .15s}.btn:active{transform:translateY(1px) scale(.99)}.btn.primary{box-shadow:0 4px 14px #2f6fd059}.btn.primary:hover{box-shadow:0 6px 18px #2f6fd073;transform:translateY(-1px)}.btn.chip,.len-chip,.nick-chip,.test-btn{transition:all .15s var(--ease)}.text-input,.cloze-textarea{transition:border-color .15s,box-shadow .15s,background .15s}.text-input:focus,.cloze-textarea:focus{border-color:var(--accent);box-shadow:var(--ring);background:var(--bg)}.card{box-shadow:var(--shadow)}.header{box-shadow:0 1px #ffffff05,0 6px 18px #00000040}.brand{display:inline-flex;align-items:center;gap:1px}.brand:before{content:"";width:9px;height:9px;border-radius:3px;margin-right:8px;background:linear-gradient(135deg,var(--accent),var(--green));box-shadow:0 0 12px #5aa2ff99}.hero{padding:44px 0 14px}.hero h1{font-size:40px;font-weight:800;letter-spacing:-1.5px;line-height:1.15;background:linear-gradient(180deg,#fff,#b8c6d8);-webkit-background-clip:text;background-clip:text;color:transparent}.unit-card{position:relative;overflow:hidden;box-shadow:var(--shadow)}.unit-card.open:before{content:"";position:absolute;inset:0 0 auto 0;height:3px;background:linear-gradient(90deg,var(--accent),var(--green));opacity:0;transition:opacity .2s}.unit-card.open:hover{box-shadow:var(--shadow-lg)}.unit-card.open:hover:before{opacity:1}.unit-tag{display:inline-block;background:#5aa2ff1f;padding:3px 9px;border-radius:99px}.part-card{box-shadow:0 2px 8px #0000002e}.part-card:hover{box-shadow:var(--shadow)}.part-card.done{background:linear-gradient(180deg,rgba(52,211,153,.06),var(--panel))}.header-progress .bar-fill{box-shadow:0 0 8px #34d39980}.sentence-item{transition:border-color .15s,box-shadow .15s}.sentence-item:focus-within{border-color:var(--accent);box-shadow:0 0 0 1px #5aa2ff40}.study-toolbar{box-shadow:var(--shadow)}.cloze-input:focus{box-shadow:0 2px 0 var(--accent)}.cloze-textarea.correct{background:#5aa2ff0f}.cloze-textarea.wrong{background:#ff6b6b0f}.login-card{box-shadow:var(--shadow-lg)}.login-screen{position:relative}.login-screen:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;background:radial-gradient(600px 300px at 50% 0%,rgba(90,162,255,.1),transparent 60%)}.voice-speed audio{border-radius:8px}.empty{text-align:center;padding:28px;border:1px dashed var(--line);border-radius:12px;margin-top:18px}::-webkit-scrollbar{width:12px;height:12px}::-webkit-scrollbar-thumb{background:var(--line);border-radius:99px;border:3px solid var(--bg)}::-webkit-scrollbar-thumb:hover{background:#3a4554}@media (max-width: 680px){.main{padding:18px 14px 56px}.hero h1{font-size:28px}.header{padding:10px 14px}.brand{font-size:20px}.trainer-top{gap:8px}.trainer-top h2{font-size:18px}.study-toolbar{flex-direction:column;align-items:stretch;gap:10px}.memo-group,.test-group{justify-content:center}.test-actions{flex-direction:column-reverse;align-items:stretch}.test-actions .nav-btns{display:grid;grid-template-columns:1fr 1fr}.test-actions .nav-btns .btn,.confirm-slot .btn.primary{width:100%}.part-grid{grid-template-columns:1fr}.voice-speed{align-items:flex-start}.length-options{flex-direction:column}.len-chip{width:100%;text-align:left}.review-ko{font-size:19px}.en-line{font-size:16px;line-height:2.2}}
