:root{--bg-page: #F2F4F6;--bg-card: #FFFFFF;--bg-soft: #F9FAFB;--bg-tint: #EDF1F5;--text-1: #191F28;--text-2: #4E5968;--text-3: #8B95A1;--text-4: #B0B8C1;--border: #E5E8EB;--border-2: #D1D6DB;--brand: #3182F6;--brand-2: #1B64DA;--brand-soft:#E8F2FE;--success: #00C896;--success-soft:#E0F8F0;--warn: #FFA000;--warn-soft: #FFF6DD;--danger: #F04452;--danger-soft:#FDECEE;--r-xs: 8px;--r-sm: 12px;--r-md: 16px;--r-lg: 20px;--r-xl: 24px;--r-2xl: 32px;--r-full: 999px;--sh-1: 0 1px 2px rgba(0,0,0,.04), 0 0 0 1px rgba(0,0,0,.04);--sh-2: 0 4px 12px rgba(0,0,0,.06), 0 0 0 1px rgba(0,0,0,.04);--sh-3: 0 12px 32px rgba(0,0,0,.08);--sp-1: 4px;--sp-2: 8px;--sp-3: 12px;--sp-4: 16px;--sp-5: 20px;--sp-6: 24px;--sp-8: 32px;--sp-10: 40px;--z-cam: 30;--z-sheet: 40;--z-mega: 55;--z-toast: 60;--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px)}*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}html,body{height:100%;font-family:Pretendard Variable,Pretendard,-apple-system,BlinkMacSystemFont,Apple SD Gothic Neo,Segoe UI,system-ui,sans-serif;background:var(--bg-page);color:var(--text-1);overflow:hidden;-webkit-user-select:none;user-select:none;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;letter-spacing:-.02em;line-height:1.5}button{font:inherit;color:inherit;background:none;border:none;cursor:pointer;letter-spacing:-.02em}input{font:inherit;color:inherit}.hidden{display:none!important}.app{width:100%;max-width:480px;height:100dvh;margin:0 auto;display:flex;flex-direction:column;position:relative;overflow:hidden;padding-top:var(--safe-top);background:var(--bg-page)}.app.shake{animation:shake .4s}@keyframes shake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-10px)}20%,40%,60%,80%{transform:translate(10px)}}.topbar{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-4) var(--sp-5) var(--sp-3);min-height:56px;background:var(--bg-page)}.topbar .title{font-size:22px;font-weight:800;flex:1;letter-spacing:-.03em;color:var(--text-1)}.topbar .title-gradient{background:none;color:var(--text-1);filter:none}.topbar .icon-btn{width:40px;height:40px;border-radius:var(--r-full);background:var(--bg-card);border:1px solid var(--border);color:var(--text-1);display:flex;align-items:center;justify-content:center;font-size:18px;transition:transform .12s,background .15s}.topbar .icon-btn:active{transform:scale(.94);background:var(--bg-tint)}.tabview{flex:1;overflow-y:auto;overflow-x:hidden;padding:0 var(--sp-5) 120px;scroll-behavior:smooth;-webkit-overflow-scrolling:touch}.tabview::-webkit-scrollbar{width:0}.tabview.entering{animation:tabFadeIn .28s cubic-bezier(.16,1,.3,1)}@keyframes tabFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.bottom-nav{position:absolute;left:0;right:0;bottom:0;padding:8px 4px calc(8px + var(--safe-bottom));display:flex;justify-content:space-around;background:var(--bg-card);border-top:1px solid var(--border);z-index:5}.tab-btn{flex:1;padding:8px 4px;display:flex;flex-direction:column;align-items:center;gap:3px;color:var(--text-3);border-radius:var(--r-sm);transition:color .18s,transform .12s}.tab-btn .ic{font-size:22px;line-height:1;transition:transform .2s}.tab-btn .lb{font-size:10px;font-weight:600;letter-spacing:-.3px}.tab-btn.active{color:var(--brand)}.tab-btn.active .ic{animation:tabPop .32s cubic-bezier(.16,1,.3,1)}@keyframes tabPop{0%{transform:scale(.85)}60%{transform:scale(1.18)}to{transform:scale(1)}}.tab-btn:active{transform:scale(.92)}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);padding:var(--sp-4)}.section-title{font-size:13px;font-weight:700;color:var(--text-2);margin:var(--sp-6) var(--sp-1) var(--sp-3);letter-spacing:-.02em;display:flex;align-items:center;justify-content:space-between}.hero{background:var(--bg-card);border-radius:var(--r-xl);padding:var(--sp-5);position:relative;overflow:hidden;margin-top:var(--sp-2);border:1px solid var(--border)}.hero .greet{font-size:14px;color:var(--text-3);margin-bottom:4px;font-weight:500}.hero .title{font-size:22px;font-weight:800;line-height:1.25;margin-bottom:var(--sp-4);letter-spacing:-.04em;color:var(--text-1)}.hero .stats-row{display:flex;gap:0;margin-bottom:0;background:var(--bg-soft);border-radius:var(--r-md);padding:var(--sp-3) var(--sp-2)}.hero .stat{flex:1;text-align:center;border-right:1px solid var(--border)}.hero .stat:last-child{border-right:none}.hero .stat .num{font-size:22px;font-weight:800;letter-spacing:-.04em;font-variant-numeric:tabular-nums;color:var(--text-1);line-height:1.1}.hero .stat .lbl{font-size:11px;color:var(--text-3);font-weight:500;margin-top:4px}.level-bar{display:flex;align-items:center;gap:var(--sp-2);margin-top:var(--sp-3)}.level-tag{background:var(--brand-soft);color:var(--brand);padding:4px 10px;border-radius:var(--r-full);font-size:12px;font-weight:800;letter-spacing:-.02em}.xp-wrap{flex:1;height:6px;background:var(--bg-tint);border-radius:var(--r-full);overflow:hidden}.xp-bar{height:100%;width:0%;background:var(--brand);transition:width .6s cubic-bezier(.16,1,.3,1);border-radius:var(--r-full)}.xp-txt{font-size:11px;color:var(--text-3);font-variant-numeric:tabular-nums;font-weight:600}.level-setup-card{background:linear-gradient(135deg,#1b64da,#3182f6,#4fa3ff);color:#fff;border-radius:var(--r-xl);padding:var(--sp-4) var(--sp-5);margin-top:var(--sp-3)}.ls-header{margin-bottom:var(--sp-3)}.ls-title{font-size:17px;font-weight:800;letter-spacing:-.03em;margin-bottom:3px}.ls-sub{font-size:12px;color:#ffffffd1;font-weight:500}.ls-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-2)}.ls-btn{background:#ffffff24;border:1px solid rgba(255,255,255,.22);border-radius:var(--r-md);padding:var(--sp-3);text-align:left;color:#fff;transition:background .12s,transform .08s;cursor:pointer}.ls-btn:active{background:#ffffff42;transform:scale(.97)}.ls-icon{font-size:22px;margin-bottom:4px;line-height:1}.ls-name{font-size:14px;font-weight:700;letter-spacing:-.02em}.ls-desc{font-size:11px;color:#ffffffb8;margin-top:2px;font-weight:500}.my-level-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-md);padding:var(--sp-3) var(--sp-4);display:flex;align-items:center;justify-content:space-between;margin-top:var(--sp-3);box-shadow:var(--sh-1)}.ml-left{display:flex;align-items:center;gap:var(--sp-3)}.ml-icon{font-size:26px;line-height:1}.ml-name{font-size:14px;font-weight:700;color:var(--text-1);letter-spacing:-.02em}.ml-desc{font-size:11px;color:var(--text-3);margin-top:2px;font-weight:500}.ml-change{font-size:12px;font-weight:600;color:var(--brand);padding:5px 12px;background:var(--brand-soft);border-radius:var(--r-full);white-space:nowrap}.daily-card{position:relative;background:var(--brand);color:#fff;border-radius:var(--r-xl);padding:var(--sp-5);overflow:hidden;margin-top:var(--sp-2)}.daily-shine{display:none}.daily-content{position:relative;z-index:1}.daily-title{font-size:19px;font-weight:800;letter-spacing:-.03em;margin-bottom:4px;color:#fff}.daily-sub{font-size:13px;color:#ffffffd9;line-height:1.55;font-weight:500}.daily-sub b{font-size:14px;font-weight:700;color:#fff}.cat-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-2)}.cat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-md);padding:var(--sp-4);text-align:left;display:flex;flex-direction:column;gap:var(--sp-1);min-height:110px;transition:transform .12s,background .18s;color:var(--text-1);position:relative}.cat-card:after{content:"›";position:absolute;top:var(--sp-3);right:var(--sp-4);font-size:18px;color:var(--text-3);font-weight:600}.cat-card:active{transform:scale(.98);background:var(--bg-soft)}.cat-card .flag{font-size:28px;line-height:1}.cat-card .name{font-size:16px;font-weight:700;color:var(--text-1);margin-top:6px}.cat-card .progress{font-size:12px;color:var(--text-3);margin-top:auto;font-weight:500}.cat-card .bar{height:4px;background:var(--bg-tint);border-radius:var(--r-full);overflow:hidden;margin-top:4px}.cat-card .bar-fill{height:100%;background:var(--brand);border-radius:var(--r-full);transition:width .6s cubic-bezier(.16,1,.3,1)}.btn{background:var(--brand);color:#fff;padding:16px 24px;border-radius:var(--r-md);font-size:16px;font-weight:700;letter-spacing:-.02em;transition:transform .12s,background .15s;display:inline-flex;align-items:center;justify-content:center;gap:6px}.btn:active{transform:scale(.98);background:var(--brand-2)}.btn.full{width:100%}.btn.ghost{background:var(--bg-soft);color:var(--text-1);font-weight:600}.btn.ghost:active{background:var(--bg-tint)}.btn.purple{background:#fff;color:var(--brand)}.btn.purple:active{background:var(--bg-tint)}.btn.danger{background:var(--danger);color:#fff}.btn:disabled{opacity:.4;cursor:not-allowed;transform:none}.list-item{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-4);background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-md);margin-bottom:var(--sp-2);transition:background .18s,transform .12s}.list-item:active{background:var(--bg-soft);transform:scale(.99)}.list-item .li-icon{font-size:28px;width:40px;text-align:center;flex-shrink:0}.list-item .li-body{flex:1;min-width:0;text-align:left}.list-item .li-title{font-size:15px;font-weight:600;color:var(--text-1)}.list-item .li-sub{font-size:12px;color:var(--text-3);margin-top:2px;font-weight:500}.list-item .li-aside{font-size:13px;color:var(--text-3);font-weight:600}.pill-group{display:flex;gap:var(--sp-2);flex-wrap:wrap}.pill{background:var(--bg-soft);border:1px solid transparent;color:var(--text-2);padding:10px 16px;border-radius:var(--r-full);font-size:14px;font-weight:600;transition:all .15s;letter-spacing:-.02em}.pill:active{transform:scale(.96)}.pill.active{background:var(--brand);border-color:transparent;color:#fff;font-weight:700}.pill .sub{display:block;font-size:10px;opacity:.85;font-weight:500;margin-top:1px}.sheet-backdrop{position:fixed;inset:0;background:#0006;z-index:var(--z-sheet);opacity:0;pointer-events:none;transition:opacity .25s}.sheet-backdrop.show{opacity:1;pointer-events:auto}.sheet{position:fixed;left:50%;bottom:0;transform:translate(-50%) translateY(100%);width:100%;max-width:480px;background:var(--bg-card);border-top:1px solid var(--border);border-radius:var(--r-2xl) var(--r-2xl) 0 0;padding:var(--sp-3) var(--sp-5) calc(var(--sp-6) + var(--safe-bottom));z-index:calc(var(--z-sheet) + 1);transition:transform .32s cubic-bezier(.16,1,.3,1);max-height:85vh;overflow-y:auto;box-shadow:0 -8px 32px #0000001f}.sheet.show{transform:translate(-50%) translateY(0)}.sheet .handle{width:44px;height:4px;background:var(--border-2);border-radius:var(--r-full);margin:0 auto var(--sp-4)}.sheet .sheet-title{font-size:20px;font-weight:800;text-align:center;margin-bottom:6px;letter-spacing:-.03em;color:var(--text-1)}.sheet .sheet-sub{font-size:14px;color:var(--text-3);text-align:center;margin-bottom:var(--sp-5)}.field{margin-bottom:var(--sp-5)}.field .field-label{font-size:13px;color:var(--text-2);font-weight:700;margin-bottom:var(--sp-2);display:block}.game{display:flex;flex-direction:column;flex:1;min-height:0;padding:0 16px max(20px,env(safe-area-inset-bottom,0px));background:var(--bg-card);gap:8px}.game-top{display:flex;align-items:center;gap:8px;padding:10px 0 2px}.game-top .icon-btn{width:36px;height:36px;flex-shrink:0;border-radius:var(--r-full);background:var(--bg-card);border:1px solid var(--border);font-size:16px;display:flex;align-items:center;justify-content:center}.game-top .progress-text{background:var(--bg-card);border:1px solid var(--border);padding:5px 12px;border-radius:var(--r-full);font-size:12px;font-weight:700;color:var(--text-2)}.game-top .score-chip{margin-left:auto;font-size:12px;color:var(--text-3);font-weight:600;background:var(--bg-card);border:1px solid var(--border);padding:5px 12px;border-radius:var(--r-full);white-space:nowrap}.game-top .score-chip b{color:var(--text-1);font-size:13px;font-variant-numeric:tabular-nums;letter-spacing:-.03em}.g-timer{display:flex;align-items:center;gap:10px}.g-timer-bar-wrap{flex:1;height:6px;background:var(--bg-tint);border-radius:var(--r-full);overflow:hidden}.g-timer-fill{height:100%;width:100%;transform-origin:left;border-radius:var(--r-full);transition:transform .05s linear,background .25s}.g-timer-num{font-size:14px;font-weight:800;font-variant-numeric:tabular-nums;letter-spacing:-.03em;color:var(--brand);min-width:34px;text-align:right;flex-shrink:0;transition:color .2s}.g-timer-num.warn{color:var(--warn)}.g-timer-num.danger{color:var(--danger);animation:dangerPulse .4s infinite alternate}@keyframes dangerPulse{0%{transform:scale(1)}to{transform:scale(1.1)}}.combo-badge{align-self:flex-end;background:linear-gradient(135deg,#f97316,#f59e0b);color:#fff;padding:5px 14px;border-radius:var(--r-full);font-size:13px;font-weight:800;opacity:0;transition:opacity .3s;letter-spacing:-.01em;box-shadow:0 2px 10px #f9731659}.combo-badge.show{opacity:1;animation:comboPulse .45s cubic-bezier(.16,1,.3,1)}@keyframes comboPulse{0%{transform:scale(.6)}65%{transform:scale(1.15)}to{transform:scale(1)}}.photo{width:100%;height:250px;background:var(--bg-card);border-radius:var(--r-xl);display:flex;align-items:center;justify-content:center;font-size:110px;position:relative;overflow:hidden;flex-shrink:0;transition:filter .3s;border:1px solid var(--border);box-shadow:0 4px 24px #00000014}.photo.flashcard-mode{font-size:0;background:linear-gradient(135deg,#1b64da22,#3182f622)}.photo.flashcard-mode .photo-meaning{font-size:30px;font-weight:800;color:var(--text-1);text-align:center;padding:0 20px;line-height:1.3;letter-spacing:-.03em}.photo.flashcard-mode .photo-meaning:before{content:"💡 ";font-size:24px}.photo.paused{filter:blur(20px) brightness(.6)}.photo.flash-correct{animation:flashCorrect .55s cubic-bezier(.16,1,.3,1)}.photo.flash-wrong{animation:flashWrong .55s cubic-bezier(.16,1,.3,1)}.photo.pop{animation:popIn .38s cubic-bezier(.16,1,.3,1)}@keyframes flashCorrect{0%,to{box-shadow:0 4px 24px #00000014}50%{box-shadow:0 0 0 6px #00c89640,0 8px 32px #00c89633;transform:scale(1.02)}}@keyframes flashWrong{0%,to{box-shadow:0 4px 24px #00000014}50%{box-shadow:0 0 0 6px #f0445240,0 8px 32px #f0445233;transform:scale(1.02)}}@keyframes popIn{0%{transform:scale(.88);opacity:0}to{transform:scale(1);opacity:1}}.clue{background:var(--brand-soft);color:var(--brand);padding:9px 18px;border-radius:var(--r-full);font-size:14px;font-weight:600;text-align:center;letter-spacing:-.02em;align-self:center}.reveal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);padding:12px 16px;display:flex;align-items:center;gap:10px;box-shadow:var(--sh-1)}.reveal .tgt{font-size:28px;font-weight:800;color:var(--text-1);letter-spacing:-.03em;line-height:1;font-family:Microsoft YaHei,PingFang SC,Hiragino Sans,system-ui,sans-serif}.reveal .read{font-size:13px;color:var(--text-3);font-weight:500;margin-top:3px}.reveal .kr{font-size:12px;color:var(--text-3);font-weight:500}.reveal-info{flex:1}.reveal .tts{background:var(--brand-soft);color:var(--brand);border-radius:var(--r-full);padding:6px 12px;font-size:16px;flex-shrink:0}.choices{display:grid;gap:12px;flex:1;align-content:stretch}.choices.cols-4{grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr}.choices.cols-6{grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr 1fr}.choice{background:var(--bg-card);border:2px solid var(--border);color:var(--text-1);padding:14px 10px;border-radius:var(--r-xl);text-align:center;transition:transform .1s,background .12s,border-color .12s,box-shadow .12s;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;box-shadow:var(--sh-1)}.choice .target{font-size:28px;font-weight:800;font-family:Microsoft YaHei,PingFang SC,Hiragino Sans,system-ui,sans-serif;letter-spacing:-.01em;line-height:1.1}.choice .target.long{font-size:19px}.choice .reading{font-size:12px;color:var(--text-3);font-weight:500}.choice:active:not(:disabled){transform:scale(.95);box-shadow:none}.choice:disabled{cursor:not-allowed}.choice.correct{background:var(--success-soft);border-color:var(--success);box-shadow:0 0 0 3px #00c8961f}.choice.correct .target{color:var(--success)}.choice.correct .reading{color:var(--success);opacity:.75}.choice.wrong{background:var(--danger-soft);border-color:var(--danger);box-shadow:0 0 0 3px #f044521f}.choice.wrong .target{color:var(--danger)}.choice.wrong .reading{color:var(--danger);opacity:.75}.speech-zone{flex:1;display:flex;flex-direction:column;gap:12px}.speech-prompt{flex:1;font-size:17px;font-weight:700;color:var(--brand);text-align:center;padding:20px;background:var(--brand-soft);border-radius:var(--r-xl);letter-spacing:-.02em;display:flex;align-items:center;justify-content:center;border:1.5px solid rgba(49,130,246,.2);min-height:120px}.speech-prompt.reveal{background:var(--warn-soft);color:var(--text-1);border-color:#f59e0b33;font-size:16px}.speech-assess{display:flex;gap:10px}.assess-btn{flex:1;padding:18px 8px;border-radius:var(--r-lg);font-size:16px;font-weight:800;letter-spacing:-.02em;transition:transform .1s}.assess-btn:active{transform:scale(.96)}.assess-btn.correct{background:var(--success);color:#fff;box-shadow:0 4px 16px #00c8964d}.assess-btn.wrong{background:var(--bg-soft);color:var(--text-2);border:1.5px solid var(--border)}.mega{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;pointer-events:none;z-index:var(--z-mega);opacity:0}.mega.show.correct{animation:megaCorrect 1s cubic-bezier(.16,1,.3,1) forwards}.mega.show.wrong{animation:megaWrong .8s cubic-bezier(.16,1,.3,1) forwards}@keyframes megaCorrect{0%{opacity:0;transform:scale(.5)}35%{opacity:1;transform:scale(1.15)}60%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(1.2)}}@keyframes megaWrong{0%{opacity:0;transform:scale(.5)}30%{opacity:1;transform:scale(1.15) translate(0)}45%{transform:scale(1) translate(-10px)}60%{transform:scale(1) translate(10px)}75%{transform:scale(1) translate(-5px)}to{opacity:0;transform:scale(.9)}}.mega .ico{font-size:140px;font-weight:900;position:relative;z-index:2}.mega.correct .ico{color:var(--success)}.mega.wrong .ico{color:var(--danger)}.mega:before{content:"";position:absolute;width:280px;height:280px;border-radius:50%;z-index:1}.mega.correct:before{background:var(--success-soft)}.mega.wrong:before{background:var(--danger-soft)}.mega .lbl{position:absolute;bottom:28%;font-size:26px;font-weight:800;letter-spacing:-.03em;z-index:3}.mega.correct .lbl{color:var(--success)}.mega.wrong .lbl{color:var(--danger)}.confetti{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:calc(var(--z-mega) + 5)}.cf-particle{position:absolute;top:38%;width:10px;height:14px;border-radius:2px;animation:cfFall 1.4s cubic-bezier(.16,1,.3,1) forwards}@keyframes cfFall{0%{transform:translate(0) rotate(0);opacity:1}to{transform:translate(var(--dx),var(--dy)) rotate(var(--rot));opacity:0}}.toast{position:fixed;left:50%;bottom:90px;transform:translate(-50%) translateY(20px);background:var(--text-1);color:#fff;padding:12px 18px;border-radius:var(--r-md);font-size:14px;font-weight:600;z-index:var(--z-toast);opacity:0;pointer-events:none;box-shadow:var(--sh-3);max-width:90vw;letter-spacing:-.02em}.toast.show{animation:toastIn .28s ease forwards,toastOut .28s ease 2.4s forwards}@keyframes toastIn{to{opacity:1;transform:translate(-50%) translateY(0)}}@keyframes toastOut{to{opacity:0;transform:translate(-50%) translateY(20px)}}.toast.success{background:var(--success)}.toast.error{background:var(--danger)}.level-up-toast{position:absolute;top:32%;left:50%;transform:translate(-50%,-50%) scale(0);background:var(--brand);color:#fff;padding:28px 44px;border-radius:var(--r-xl);font-size:24px;font-weight:800;text-align:center;letter-spacing:-.03em;box-shadow:var(--sh-3);z-index:var(--z-toast);opacity:0;pointer-events:none}.level-up-toast.show{animation:levelUpAnim 2.4s cubic-bezier(.16,1,.3,1) forwards}@keyframes levelUpAnim{0%{transform:translate(-50%,-50%) scale(0);opacity:0}18%{transform:translate(-50%,-50%) scale(1.15);opacity:1}28%{transform:translate(-50%,-50%) scale(1)}80%{transform:translate(-50%,-50%) scale(1);opacity:1}to{transform:translate(-50%,-50%) scale(.85);opacity:0}}.selfie{position:fixed;top:72px;right:16px;width:112px;height:86px;border-radius:var(--r-sm);overflow:hidden;border:2px solid var(--brand);background:#000;z-index:var(--z-cam);box-shadow:var(--sh-3);cursor:grab;touch-action:none}.selfie.large{width:210px;height:158px}.selfie.dragging{cursor:grabbing}.selfie video{width:100%;height:100%;object-fit:cover;transform:scaleX(-1);background:#000}.cam-ctrl{position:absolute;top:4px;right:4px;display:flex;gap:3px}.cam-btn{background:#000000b3;color:#fff;width:22px;height:22px;border-radius:50%;font-size:10px;display:flex;align-items:center;justify-content:center}.rec-ind{position:absolute;top:6px;left:6px;background:var(--danger);color:#fff;padding:3px 8px;border-radius:5px;font-size:10px;font-weight:700;display:flex;align-items:center;gap:4px}.rec-dot{width:6px;height:6px;background:#fff;border-radius:50%;animation:recPulse 1s infinite}@keyframes recPulse{0%,to{opacity:1}50%{opacity:.4}}.rec-time{position:absolute;bottom:6px;left:6px;background:#000000bf;color:#fff;padding:2px 6px;border-radius:4px;font-size:10px;font-weight:600;font-variant-numeric:tabular-nums}.rec-fab{position:absolute;bottom:6px;right:6px;width:28px;height:28px;border-radius:50%;background:var(--danger);border:2px solid #fff;display:flex;align-items:center;justify-content:center}.rec-fab .ri{width:11px;height:11px;background:#fff;border-radius:50%;transition:all .2s}.rec-fab.recording .ri{border-radius:2px;width:9px;height:9px}.entry{display:flex;align-items:center;gap:var(--sp-3);background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-md);padding:var(--sp-3) var(--sp-4);margin-bottom:var(--sp-2);transition:background .18s}.entry:active{background:var(--bg-soft)}.entry .em{font-size:28px;width:38px;text-align:center;flex-shrink:0}.entry .ed{flex:1;min-width:0}.entry .et{font-size:16px;font-weight:700;color:var(--text-1);letter-spacing:-.02em}.entry .er{font-size:12px;color:var(--text-2);font-weight:500}.entry .ek{font-size:12px;color:var(--text-3);font-weight:500}.entry .cnt{background:var(--danger-soft);color:var(--danger);font-size:11px;font-weight:700;padding:4px 10px;border-radius:var(--r-full);flex-shrink:0}.entry .ebtn{background:var(--brand-soft);border:none;color:var(--brand);width:32px;height:32px;border-radius:50%;font-size:14px;display:flex;align-items:center;justify-content:center}.entry .edel{background:transparent;border:1px solid var(--border-2);color:var(--text-3);width:28px;height:28px;border-radius:50%;font-size:11px;display:flex;align-items:center;justify-content:center}.empty{text-align:center;color:var(--text-3);padding:var(--sp-8) var(--sp-4);font-size:14px}.empty .ic{font-size:56px;margin-bottom:var(--sp-3)}.empty .msg{line-height:1.6;font-weight:500}.video-preview{width:100%;max-width:380px;border-radius:var(--r-md);background:#000;display:block;margin:0 auto var(--sp-3);transform:scaleX(-1)}.stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-2)}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-md);padding:var(--sp-4);text-align:center}.stat-card .v{font-size:28px;font-weight:800;font-variant-numeric:tabular-nums;letter-spacing:-.04em;color:var(--text-1)}.stat-card .l{font-size:12px;color:var(--text-3);margin-top:4px;font-weight:500}.progress-row{display:flex;align-items:center;gap:var(--sp-3);background:var(--bg-card);padding:var(--sp-3) var(--sp-4);border-radius:var(--r-md);margin-bottom:var(--sp-2);border:1px solid var(--border)}.progress-row .pflag{font-size:22px}.progress-row .pname{color:var(--text-1);font-weight:600;flex:1;font-size:14px}.progress-row .pcnt{color:var(--text-1);font-weight:700;font-size:13px;font-variant-numeric:tabular-nums}.progress-row .pbar{flex:2;height:6px;background:var(--bg-tint);border-radius:var(--r-full);overflow:hidden}.progress-row .pfill{height:100%;background:var(--brand);transition:width .6s cubic-bezier(.16,1,.3,1)}.challenge-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}.challenge-cell{aspect-ratio:1;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-sm);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px;padding:4px;transition:transform .12s,background .2s;color:var(--text-3);position:relative;overflow:hidden}.challenge-cell:active{transform:scale(.94)}.challenge-cell .cc-day{font-size:11px;font-weight:600;letter-spacing:-.02em;color:var(--text-3)}.challenge-cell .cc-badge{font-size:16px;line-height:1}.challenge-cell .cc-score{font-size:10px;font-weight:700;color:var(--brand)}.challenge-cell.done{background:var(--success-soft);border-color:var(--success)}.challenge-cell.done .cc-day,.challenge-cell.done .cc-score{color:var(--success)}.challenge-cell.today{background:var(--brand);border-color:var(--brand)}.challenge-cell.today .cc-day{color:#ffffffd9}.challenge-cell.today .cc-badge{color:#fff}.challenge-cell.today.done{background:var(--success);border-color:var(--success)}.setting-row{display:flex;align-items:center;gap:var(--sp-3);background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-md);padding:var(--sp-4);margin-bottom:var(--sp-2);transition:background .18s}.setting-row:active{background:var(--bg-soft)}.setting-row .sr-icon{font-size:22px;width:30px;text-align:center}.setting-row .sr-body{flex:1}.setting-row .sr-title{font-size:15px;font-weight:600;color:var(--text-1)}.setting-row .sr-sub{font-size:12px;color:var(--text-3);margin-top:2px;font-weight:500}.switch{width:48px;height:28px;background:var(--border-2);border-radius:var(--r-full);position:relative;transition:background .25s;flex-shrink:0}.switch:after{content:"";position:absolute;top:2px;left:2px;width:24px;height:24px;background:#fff;border-radius:50%;transition:transform .25s cubic-bezier(.16,1,.3,1);box-shadow:0 2px 4px #00000026}.switch.on{background:var(--brand)}.switch.on:after{transform:translate(20px)}.streak-row{display:flex;gap:6px;justify-content:space-between}.streak-cell{flex:1;aspect-ratio:1;max-width:44px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-sm);display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:10px;color:var(--text-3);font-weight:500}.streak-cell.active{background:var(--brand);border-color:var(--brand);color:#fff}.streak-cell.today{border:2px solid var(--warn)}.streak-cell .num{font-size:13px;font-weight:700;letter-spacing:-.03em}.perm-step{display:flex;align-items:flex-start;gap:var(--sp-3);background:var(--bg-soft);border-radius:var(--r-md);padding:var(--sp-3) var(--sp-4);margin-bottom:var(--sp-2)}.perm-step .num{width:26px;height:26px;background:var(--brand);border-radius:50%;font-size:12px;font-weight:800;color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0}.perm-step .ptext{font-size:13px;color:var(--text-2);line-height:1.55;font-weight:500}.perm-step .ptext b{color:var(--text-1);font-weight:700}.perm-status{padding:12px 16px;border-radius:var(--r-md);font-size:14px;font-weight:600;text-align:center;margin-bottom:var(--sp-4)}.perm-status.ok{background:var(--success-soft);color:var(--success)}.perm-status.no{background:var(--danger-soft);color:var(--danger)}.perm-status.q{background:var(--warn-soft);color:var(--warn)}.rec-guide-card{display:flex;align-items:flex-start;gap:12px;background:var(--bg-soft);border:1px solid var(--border);border-radius:var(--r-lg);padding:14px 16px;margin-top:var(--sp-3)}.rg-icon{font-size:28px;flex-shrink:0}.rg-body{flex:1}.rg-title{font-size:14px;font-weight:700;color:var(--text-1);margin-bottom:6px}.rg-step{font-size:12px;color:var(--text-2);line-height:1.6}.rg-step b{color:var(--text-1)}.result-emoji{font-size:56px;text-align:center;margin-top:var(--sp-2)}.result-title{font-size:22px;font-weight:800;text-align:center;color:var(--text-1);letter-spacing:-.03em;margin-top:var(--sp-2)}.result-score{font-size:56px;font-weight:800;text-align:center;color:var(--brand);font-variant-numeric:tabular-nums;letter-spacing:-.05em;margin:var(--sp-2) 0;line-height:1}.result-meta{text-align:center;color:var(--text-3);font-size:13px;font-weight:500}.result-rank{text-align:center;font-size:16px;font-weight:700;color:var(--text-1);margin-top:var(--sp-3);margin-bottom:var(--sp-3);letter-spacing:-.02em}.result-section{background:var(--bg-soft);border-radius:var(--r-md);padding:var(--sp-3) var(--sp-4);margin-top:var(--sp-3)}.result-section .rs-label{font-size:12px;font-weight:700;color:var(--text-3);margin-bottom:var(--sp-2)}.result-words{display:flex;flex-direction:column;gap:6px}.result-word{display:flex;align-items:center;gap:var(--sp-2);font-size:14px}.result-word .em{font-size:22px;width:28px;text-align:center}.result-word .tgt{font-weight:700;color:var(--text-1)}.result-word .kr{color:var(--text-3);font-size:12px;margin-left:auto}@media (max-height: 720px){.photo{width:155px;height:155px;font-size:96px}.timer-cd{font-size:42px;min-width:62px}.choice{min-height:60px;padding:10px 8px}.choice .target{font-size:21px}.choice .target.long{font-size:16px}.mega .ico{font-size:110px}.mega .lbl{font-size:22px}.result-score{font-size:44px}}@media (max-height: 640px){.photo{width:130px;height:130px;font-size:80px}.timer-cd{font-size:36px;min-width:54px}.stage{gap:var(--sp-2)}.timer-section{padding:var(--sp-1) 0}}
