.navbar{width:100%;background:linear-gradient(135deg,#1a1a4e,#2a2a8a);box-shadow:0 2px 12px #00000026;position:sticky;top:0;z-index:100}.navbar-inner{max-width:1400px;margin:0 auto;display:flex;align-items:center;padding:0 1.5rem;height:56px;gap:1.5rem}.navbar-brand{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.navbar-logo{font-size:1.5rem}.navbar-title{font-size:1.2rem;font-weight:800;color:#fff;letter-spacing:-.02em}.navbar-menu{display:flex;gap:4px;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;padding:4px 0}.navbar-menu::-webkit-scrollbar{display:none}.navbar-item{display:flex;align-items:center;gap:.35rem;padding:.4rem .75rem;border:1px solid transparent;border-radius:8px;background:transparent;color:#ffffffa6;font-size:.82rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:all .2s}.navbar-item:hover{background:#ffffff1a;color:#fff}.navbar-item.active{background:#ffffff2e;color:#fff;border-color:#ffffff40;box-shadow:0 0 8px #648cff33}.navbar-item-icon{font-size:1rem}.navbar-right{margin-left:auto;flex-shrink:0;display:flex;align-items:center;gap:.5rem}.navbar-settings{border-left:1px solid rgba(255,255,255,.1);padding-left:.85rem;margin-left:.25rem}.navbar-signin-btn{padding:.4rem 1rem;border:1px solid rgba(255,255,255,.5);border-radius:8px;background:transparent;color:#fff;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}.navbar-signin-btn:hover{background:#ffffff26;border-color:#fff}.navbar-auth{position:relative}.navbar-avatar-btn{display:flex;align-items:center;gap:.4rem;padding:.3rem .6rem;border:1px solid rgba(255,255,255,.3);border-radius:99px;background:#ffffff1a;color:#fff;cursor:pointer;transition:all .2s}.navbar-avatar-btn:hover{background:#fff3;border-color:#fff9}.navbar-avatar-img{width:26px;height:26px;border-radius:50%;object-fit:cover}.navbar-avatar-fallback{width:26px;height:26px;border-radius:50%;background:#ffffff40;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700}.navbar-avatar-name{font-size:.82rem;font-weight:600;max-width:80px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.navbar-avatar-caret{font-size:.65rem;opacity:.7}.navbar-dropdown{position:absolute;top:calc(100% + 8px);right:0;min-width:200px;background:#fff;border-radius:10px;box-shadow:0 8px 24px #00000026;overflow:hidden;z-index:200}.navbar-dropdown-header{padding:.875rem 1rem .75rem}.navbar-dropdown-nick{font-size:.9rem;font-weight:700;color:#111;margin:0 0 .15rem}.navbar-dropdown-email{font-size:.75rem;color:#888;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.navbar-dropdown-divider{margin:0;border:none;border-top:1px solid #f0f0f0}.navbar-dropdown-item{display:block;width:100%;padding:.7rem 1rem;background:none;border:none;text-align:left;font-size:.875rem;color:#333;cursor:pointer;transition:background .15s}.navbar-dropdown-item:hover{background:#f5f5f5}.navbar-dropdown-signout{color:#dc2626}.navbar-dropdown-signout:hover{background:#fef2f2}@media(max-width:768px){.navbar-inner{padding:0 .75rem;gap:.75rem}.navbar-title{display:none}.navbar-item{padding:.35rem .5rem;font-size:.75rem}.navbar-item-label{display:none}.navbar-item-icon{font-size:1.2rem}.navbar-avatar-name,.navbar-avatar-caret{display:none}}.hangul-keyboard{width:100%;max-width:860px;align-self:center;background:#1a1a2e;border-radius:16px;padding:1rem 1rem 1.1rem;box-shadow:0 8px 32px #00000059;box-sizing:border-box}.hkbd-label-guide{display:flex;align-items:center;gap:.4rem;margin-bottom:.6rem;font-size:.75rem;flex-wrap:wrap}.guide-ref{padding:.15rem .5rem;border-radius:4px;background:#64a0ff26;color:#8bf;font-weight:700}.guide-arrow{color:#335;font-size:.9rem}.guide-ko{padding:.15rem .5rem;border-radius:4px;background:#ffa03c21;color:#fa5;font-weight:700}.guide-desc{color:#44446a;font-size:.68rem;margin-left:.2rem}.hkbd-phase-guide{display:flex;align-items:center;gap:.45rem;color:#9090b8;font-size:.82rem;margin-bottom:.55rem;padding:.28rem .6rem;background:#ffffff09;border-radius:7px}.guide-dot{width:8px;height:8px;border-radius:50%;background:#444;flex-shrink:0;transition:background .25s}.guide-dot[data-phase=EMPTY]{background:#555}.guide-dot[data-phase=INITIAL]{background:#4fc3f7}.guide-dot[data-phase=MEDIAL]{background:#81c784}.guide-dot[data-phase=FINAL]{background:#ffb74d}.hkbd-board{display:flex;flex-direction:column;gap:4px}.hkbd-row{display:flex;gap:3px}.hkbd-row.row-0{padding-left:0}.hkbd-row.row-1{padding-left:4%}.hkbd-row.row-2{padding-left:0}.hkbd-row.row-fn{padding-left:0;margin-top:3px}.hkbd-key{position:relative;width:calc((100% - 27px)*.1);aspect-ratio:1 / .9;min-width:0;border-radius:7px;border:1.5px solid #252542;background:#1c1c36;cursor:pointer;transition:background .12s,border-color .12s,transform .1s,box-shadow .12s;user-select:none;-webkit-user-select:none;display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;padding:4px 5px;box-sizing:border-box}.hkbd-key.consonant-slot.active{background:linear-gradient(160deg,#1a2e20,#1d3525);border-color:#2d5535}.hkbd-key.consonant-slot.active:hover{background:linear-gradient(160deg,#223a28,#284030);border-color:#4a8855;transform:translateY(-2px);box-shadow:0 4px 10px #32964647}.hkbd-key.consonant-slot.active.shift-mode{background:linear-gradient(160deg,#1e2a3a,#1e3045);border-color:#2d4a70}.hkbd-key.consonant-slot.active.shift-mode:hover{border-color:#4a7aaa;box-shadow:0 4px 10px #3264c84d}.hkbd-key.vowel-slot.active{background:linear-gradient(160deg,#2d2416,#33291a);border-color:#5a3f18}.hkbd-key.vowel-slot.active:hover{background:linear-gradient(160deg,#3a2e1e,#403520);border-color:#8a6025;transform:translateY(-2px);box-shadow:0 4px 10px #c8821e47}.hkbd-key.inactive{background:#112;border-color:#181828;opacity:.3;cursor:default;pointer-events:none}.hkbd-key:active{transform:translateY(0)!important;box-shadow:none!important}.k-tl{grid-column:1;grid-row:1;display:flex;align-items:flex-start;justify-content:flex-start;line-height:1;overflow:hidden}.k-tr{grid-column:2;grid-row:1;display:flex;align-items:flex-start;justify-content:flex-end;line-height:1;overflow:hidden}.k-bl{grid-column:1;grid-row:2;display:flex;align-items:flex-end;justify-content:flex-start;line-height:1;overflow:hidden}.k-br{grid-column:2;grid-row:2;display:flex;align-items:flex-end;justify-content:flex-end;line-height:1;overflow:hidden}.k-center{grid-column:1 / -1;grid-row:1 / -1;display:flex;align-items:center;justify-content:center;line-height:1}.ref-shift{font-size:clamp(.45rem,1.2vw,.6rem);font-weight:600;color:#57c}.ref-base{font-size:clamp(.65rem,2vw,.95rem);font-weight:700;color:#79e}.hangul-shift{font-size:clamp(.45rem,1.2vw,.6rem);font-weight:600;color:#b72}.hangul-base{font-size:clamp(.7rem,2.2vw,1rem);font-weight:700;color:#fa5}.hkbd-key:not(.has-label) .hangul-base{font-size:clamp(.85rem,2.8vw,1.35rem);color:#fb6}.hkbd-key:not(.has-label) .hangul-shift{font-size:clamp(.5rem,1.4vw,.68rem);color:#c83}.hkbd-fn{flex:1;height:clamp(38px,6vw,46px);border-radius:7px;border:1.5px solid #222240;background:#1c1c38;color:#77a;font-size:clamp(.7rem,1.8vw,.85rem);font-weight:600;cursor:pointer;transition:all .12s;-webkit-user-select:none;user-select:none;white-space:nowrap;min-width:0;padding:0 .3rem}.hkbd-fn:hover{background:#272748;color:#aac;border-color:#3f3f99}.hkbd-fn:active{transform:translateY(0)}.backspace-key{flex:1.5}.space-key{flex:5;letter-spacing:.02em}.enter-key{flex:2}.shift-key{flex:1.5;background:#252545;color:#aad;border-color:#336;font-size:clamp(.9rem,2vw,1.1rem)}.shift-key:hover{background:#2e2e5a;color:#ccf;border-color:#55a}.shift-key.shift-active{background:#2a4a7a;color:#6bf;border-color:#48c;box-shadow:0 0 8px #50a0ff59}.sym-toggle-key{flex:1.8;background:#252545;color:#aad;border-color:#336;font-size:clamp(.72rem,1.8vw,.88rem);font-weight:700;letter-spacing:.04em}.sym-toggle-key:hover{background:#2e2e5a;color:#ccf;border-color:#55a}.sym-toggle-key.active-mode{background:#1e3a5f;color:#6af;border-color:#36a}.sym-page-key{flex:1.8;background:#252545;color:#aad;border-color:#336;font-size:clamp(.7rem,1.7vw,.82rem);font-weight:700}.sym-page-key:hover{background:#2e2e5a;color:#ccf}.hkbd-row.row-sym{padding-left:0}.hkbd-row.row-sym-3{padding-left:0;gap:3px}.hkbd-key.sym-key{background:#1e1e38;border-color:#2e2e50}.hkbd-key.sym-key:hover{background:#282848;border-color:#44a;transform:translateY(-2px);box-shadow:0 4px 10px #5050c838}.hkbd-key.sym-key:active{transform:translateY(0)!important;box-shadow:none!important}.sym-char{font-size:clamp(.85rem,2.5vw,1.1rem);font-weight:600;color:#cce}.guide-dot[data-phase=SYM]{background:#96f}.text-display{width:100%;max-width:860px;align-self:center;min-height:80px;background:#fff;border:2px solid #dde;border-radius:12px;padding:1rem 2.5rem 1rem 1.25rem;margin-bottom:1rem;font-size:1.6rem;line-height:1.8;position:relative;transition:border-color .2s;cursor:text;box-sizing:border-box}.text-display:focus-within{border-color:#66c;box-shadow:0 0 0 3px #6464c81a}.text-display-inner{display:inline;word-break:break-all}.committed-text{color:#222}.composing-text{color:#44c;background:#4444cc14;border-bottom:2px solid #4444cc;padding:0 2px;border-radius:2px}.cursor-blink{color:#44c;font-weight:300;animation:blink 1s step-end infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.placeholder-text{position:absolute;top:1rem;left:1.25rem;color:#aaa;font-size:1rem;pointer-events:none}.text-action-btns{position:absolute;top:.5rem;right:.5rem;display:flex;gap:.35rem;z-index:1}.text-speak-btn{width:28px;height:28px;border:none;border-radius:50%;background:#e8e8f8;color:#55b;font-size:.85rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;line-height:1}.text-speak-btn:hover{background:#55b;color:#fff;transform:scale(1.1)}.text-speak-btn:active{transform:scale(.95)}.text-speak-btn.speaking{background:#55b;color:#fff;animation:pulse-speak 1s ease-in-out infinite}@keyframes pulse-speak{0%,to{box-shadow:0 0 #5555bb80}50%{box-shadow:0 0 0 6px #55b0}}.text-clear-btn{width:28px;height:28px;border:none;border-radius:50%;background:#eee;color:#888;font-size:.85rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;line-height:1;z-index:1}.text-clear-btn:hover{background:#ff4d4d;color:#fff;transform:scale(1.1)}.text-clear-btn:active{transform:scale(.95)}.dict-panel{width:100%;background:#fff;border-radius:16px;box-shadow:0 4px 20px #00000014;overflow:hidden;display:flex;flex-direction:column;min-height:400px;max-height:calc(100vh - 120px)}.dict-header{display:flex;align-items:center;gap:.5rem;padding:.85rem 1.25rem;background:linear-gradient(135deg,#2a2a8a,#44c);color:#fff;flex-shrink:0}.dict-header-text{flex:1}.dict-header h2{font-size:1.05rem;font-weight:700;line-height:1.2}.dict-stats{font-size:.7rem;opacity:.75}.dict-icon{font-size:1.3rem}.dict-api-badge{font-size:.7rem;background:#fff3;border:1px solid rgba(255,255,255,.3);padding:.2rem .5rem;border-radius:20px;white-space:nowrap}.dict-api-notice{display:flex;align-items:flex-start;gap:.4rem;padding:.6rem 1rem;font-size:.75rem;color:#888;background:#fafafe;border-bottom:1px solid #f0f0f5;line-height:1.5;flex-shrink:0}.dict-api-notice code{background:#eeeef8;padding:.05rem .3rem;border-radius:4px;font-size:.72rem;color:#55b}.dict-api-notice a{color:#55b;text-decoration:none}.dict-api-notice a:hover{text-decoration:underline}.dict-loading{display:flex;align-items:center;gap:.6rem;padding:1rem 1.25rem;color:#888;font-size:.9rem;flex-shrink:0}.dict-loading-spinner{width:16px;height:16px;border:2px solid #dde;border-top-color:#55b;border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}@keyframes spin{to{transform:rotate(360deg)}}.dict-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;color:#999;text-align:center}.dict-empty-icon{font-size:2.5rem;margin-bottom:.75rem}.dict-empty p{font-size:.95rem;line-height:1.5}.dict-empty-sub{font-size:.8rem!important;color:#bbb;margin-top:.25rem}.dict-body{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}.dict-section{padding:.75rem 1rem;border-bottom:1px solid #f0f0f5}.dict-section:last-child{border-bottom:none}.dict-section-label{font-size:.75rem;font-weight:600;color:#888;text-transform:uppercase;letter-spacing:.03em;margin-bottom:.6rem}.dict-entries{display:flex;flex-direction:column;gap:.5rem}.dict-entry{padding:.75rem .85rem;border-radius:10px;transition:all .2s}.dict-entry.matched{background:#f0f4ff;border:1px solid #d0d8ff}.dict-entry.api{background:#f0f8f0;border:1px solid #c0ddc0}.dict-entry.suggestion{background:#fafafa;border:1px solid #eee}.dict-entry:hover{transform:translate(2px);box-shadow:0 2px 8px #0000000f}.dict-entry-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.3rem;gap:.5rem}.dict-word{font-size:1.3rem;font-weight:800;color:#222;flex-shrink:0}.dict-word-matched{color:#44c}.dict-word-rest{color:#aaa}.dict-entry-badges{display:flex;flex-wrap:wrap;gap:.25rem;justify-content:flex-end}.dict-category{font-size:.65rem;font-weight:600;color:#888;background:#f0f0f5;padding:.15rem .5rem;border-radius:20px;text-transform:uppercase;white-space:nowrap}.dict-level{font-size:.65rem;font-weight:700;padding:.15rem .45rem;border-radius:20px;white-space:nowrap}.level-A{background:#e8f5e9;color:#388e3c}.level-B{background:#fff3e0;color:#f57c00}.level-C{background:#fce4ec;color:#c62828}.dict-meaning{font-size:.95rem;color:#444;font-weight:500;margin-bottom:.15rem}.dict-pronunciation{font-size:.8rem;color:#999;font-style:italic}.dict-source{font-size:.68rem;color:#aaa;margin-top:.3rem}@media(max-width:1024px){.dict-panel{min-height:auto;max-height:none;border-radius:12px}.dict-entries{max-height:none}}.challenge-panel{width:100%;max-width:860px;background:#fff;border:2px solid #e0e4f0;border-radius:14px;padding:1.25rem;margin-bottom:1rem;transition:all .3s}.challenge-panel.complete{border-color:#81c784;background:#f5fff5}.challenge-breadcrumb{display:flex;align-items:center;gap:.4rem;margin-bottom:.9rem;flex-wrap:wrap}.challenge-back-btn{background:none;border:none;color:#67c;font-size:.82rem;font-weight:700;cursor:pointer;padding:0;transition:color .15s}.challenge-back-btn:hover{color:#45a}.challenge-bc-sep{color:#ccc;font-size:.8rem}.challenge-bc-cat{font-size:.82rem;font-weight:700;color:#555}.challenge-bc-diff{font-size:.82rem;font-weight:700}.challenge-progress{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.challenge-progress-bar{flex:1;height:6px;background:#eee;border-radius:3px;overflow:hidden}.challenge-progress-fill{height:100%;background:linear-gradient(90deg,#44c,#81c784);border-radius:3px;transition:width .4s ease}.challenge-progress-text{font-size:.75rem;font-weight:700;color:#888;min-width:40px;text-align:right}.challenge-info{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.challenge-difficulty{font-size:.7rem;font-weight:700;padding:.15rem .5rem;border-radius:20px;text-transform:uppercase}.challenge-difficulty.easy{background:#e8f5e9;color:#2e7d32}.challenge-difficulty.medium{background:#fff3e0;color:#e65100}.challenge-difficulty.hard{background:#fce4ec;color:#c62828}.challenge-number{font-size:.75rem;color:#aaa;font-weight:600}.challenge-target{margin-bottom:.6rem}.challenge-target-chars{display:flex;flex-wrap:wrap;gap:4px}.target-char{display:inline-flex;align-items:center;justify-content:center;min-width:40px;height:48px;font-size:1.6rem;font-weight:800;border-radius:8px;border:2px solid #ddd;background:#fafafa;color:#bbb;transition:all .2s}.target-char.current{border-color:#44c;background:#f0f0ff;color:#44c;box-shadow:0 0 8px #44c3;animation:pulse-border 1.5s ease-in-out infinite}.target-char.correct{border-color:#81c784;background:#e8f5e9;color:#2e7d32}.target-char.wrong{border-color:#e57373;background:#fce4ec;color:#c62828}@keyframes pulse-border{0%,to{box-shadow:0 0 8px #44c3}50%{box-shadow:0 0 16px #44c6}}.challenge-details{margin-bottom:.5rem}.challenge-meaning{font-size:1rem;color:#555;font-weight:600;margin-bottom:.25rem}.challenge-pronunciation-row{display:flex;align-items:center;gap:.5rem}.challenge-pronunciation{font-size:.85rem;color:#999;font-style:italic}.challenge-tts-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;border:1.5px solid #d0d4e8;background:#f4f5fb;font-size:.9rem;cursor:pointer;flex-shrink:0;transition:all .15s;line-height:1;padding:0}.challenge-tts-btn:hover{background:#e8eaf6;border-color:#99c;transform:scale(1.08)}.challenge-tts-btn.speaking{background:#e8f5e9;border-color:#81c784;animation:tts-pulse 1.2s ease-in-out infinite}@keyframes tts-pulse{0%,to{box-shadow:0 0 #81c78480}50%{box-shadow:0 0 0 5px #81c78400}}.challenge-success{padding:.5rem;text-align:center;font-size:1.05rem;font-weight:700;color:#2e7d32;background:#e8f5e9;border-radius:8px;margin-bottom:.5rem;animation:pop-in .3s ease}@keyframes pop-in{0%{transform:scale(.8);opacity:0}to{transform:scale(1);opacity:1}}.challenge-skip{display:block;width:100%;padding:.5rem;border:1px solid #ddd;border-radius:8px;background:transparent;color:#888;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s}.challenge-skip:hover{background:#f5f5f5;color:#555;border-color:#bbb}@media(max-width:640px){.target-char{min-width:34px;height:42px;font-size:1.3rem}}.kpop-panel{width:100%;max-width:860px;align-self:center}.kpop-step-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem}.kpop-step-title{font-size:1.3rem;font-weight:800;color:#1a1a2e}.kpop-step-desc{font-size:.9rem;color:#888;margin-bottom:1rem}.kpop-back-btn{background:none;border:1px solid #dde;border-radius:8px;padding:.3rem .75rem;font-size:.85rem;color:#666;cursor:pointer;transition:all .2s;white-space:nowrap}.kpop-back-btn:hover{background:#f5f5f5;border-color:#bbb}.kpop-artist-badge{display:flex;align-items:center;gap:.4rem;padding:.3rem .85rem;border-radius:20px;color:#fff}.kpop-artist-badge-kr{font-size:.95rem;font-weight:800}.kpop-artist-badge-en{font-size:.75rem;opacity:.85}.kpop-filter-hint{font-size:.85rem;color:#888;margin-bottom:.75rem;padding:.4rem .75rem;background:#f8f8ff;border-radius:8px;border:1px solid #e8e8f8}.kpop-filter-query{font-weight:700;color:#44c}.kpop-filter-none{color:#e57373}.kpop-artist-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.75rem}.kpop-artist-card{background:#fff;border:2px solid #eee;border-radius:14px;padding:1rem .85rem;cursor:pointer;text-align:center;transition:all .2s;position:relative;overflow:hidden}.kpop-artist-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--artist-color)}.kpop-artist-card:hover{border-color:var(--artist-color);transform:translateY(-3px);box-shadow:0 6px 20px #0000001a}.kpop-artist-name-kr{font-size:1.05rem;font-weight:800;color:#1a1a2e;margin-bottom:.2rem}.kpop-artist-name-en{font-size:.75rem;color:#888;margin-bottom:.5rem}.kpop-artist-meta{display:flex;align-items:center;justify-content:center;gap:.4rem;margin-top:.4rem}.kpop-artist-debut{font-size:.7rem;color:#aaa;font-weight:600}.kpop-artist-member-count{font-size:.7rem;color:#fff;background:var(--artist-color);padding:.1rem .45rem;border-radius:20px}.kpop-member-view{display:flex;flex-direction:column;border-radius:14px;overflow:hidden;border:2px solid #e0e4f0;background:#fafafe}.kpop-lyrics-row{padding:.9rem 1.25rem;border-bottom:1px solid #eee;transition:all .25s ease;position:relative}.kpop-lyrics-row:last-child{border-bottom:none}.kpop-lyrics-row.active{background:#fff;border-left:4px solid var(--artist-color, #4444cc);padding-left:1rem;box-shadow:0 2px 12px #0000000f}.kpop-lyrics-row.future{background:#fafafe;opacity:.5}.kpop-active-chars{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:.6rem}.kpop-active-meta{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;margin-bottom:.5rem}.kpop-active-pronunciation{font-size:.8rem;color:#999;font-style:italic}.kpop-tts-btn{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:50%;border:1.5px solid #d0d4e8;background:#f4f5fb;font-size:.85rem;cursor:pointer;flex-shrink:0;transition:all .15s;padding:0;line-height:1}.kpop-tts-btn:hover{background:#e8eaf6;border-color:#99c;transform:scale(1.1)}.kpop-tts-btn.speaking{background:#e8f5e9;border-color:#81c784;animation:kpop-tts-pulse 1.2s ease-in-out infinite}@keyframes kpop-tts-pulse{0%,to{box-shadow:0 0 #81c78480}50%{box-shadow:0 0 0 5px #81c78400}}.kpop-inactive-member{display:flex;align-items:center;gap:.6rem}.kpop-inactive-text{font-size:1.1rem;font-weight:600;color:#999}.kpop-inactive-en{font-size:.8rem;color:#bbb;font-weight:600}.kpop-member-name-en{font-size:.9rem;font-weight:700;color:#444}.kpop-member-position{font-size:.8rem;color:#888;background:#f0f0f5;padding:.1rem .45rem;border-radius:20px}.kpop-progress{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.kpop-progress-bar{flex:1;height:6px;background:#eee;border-radius:3px;overflow:hidden}.kpop-progress-fill{height:100%;border-radius:3px;transition:width .4s ease}.kpop-progress-text{font-size:.75rem;font-weight:700;color:#888;min-width:36px;text-align:right}.kpop-char{display:inline-flex;align-items:center;justify-content:center;min-width:40px;height:48px;font-size:1.6rem;font-weight:800;border-radius:8px;border:2px solid #ddd;background:#fafafa;color:#bbb;transition:all .15s}.kpop-char.current{border-color:#44c;background:#f0f0ff;color:#44c;box-shadow:0 0 8px #4444cc40;animation:pulse-char 1.5s ease-in-out infinite}.kpop-char.correct{border-color:#81c784;background:#e8f5e9;color:#2e7d32}.kpop-char.wrong{border-color:#e57373;background:#fce4ec;color:#c62828}@keyframes pulse-char{0%,to{box-shadow:0 0 8px #44c3}50%{box-shadow:0 0 16px #4444cc73}}.kpop-line-complete{text-align:center;font-size:1.05rem;font-weight:700;color:#2e7d32;background:#e8f5e9;padding:.5rem;border-radius:8px;animation:pop-in .3s ease}@keyframes pop-in{0%{transform:scale(.85);opacity:0}to{transform:scale(1);opacity:1}}.kpop-skip-btn{display:block;width:100%;padding:.5rem;border:1px solid #ddd;border-radius:8px;background:transparent;color:#888;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s}.kpop-skip-btn:hover{background:#f5f5f5;border-color:#bbb}.kpop-song-complete{text-align:center;padding:2rem 1rem}.kpop-complete-emoji{font-size:3rem;margin-bottom:.5rem;animation:pop-in .4s ease}.kpop-complete-title{font-size:1.8rem;font-weight:900;color:#1a1a2e;margin-bottom:.25rem}.kpop-complete-sub{font-size:1rem;color:#888;margin-bottom:1.5rem}.kpop-complete-actions{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap}.kpop-complete-btn{padding:.65rem 2rem;border:none;border-radius:12px;color:#fff;font-size:1rem;font-weight:700;cursor:pointer;transition:filter .2s,transform .2s}.kpop-complete-btn:hover{filter:brightness(1.1);transform:translateY(-2px)}.kpop-complete-btn-outline{background:transparent!important;border:2px solid #dde;color:#666!important}.kpop-complete-btn-outline:hover{background:#f5f5f5!important;border-color:#bbb}@media(max-width:640px){.kpop-artist-grid{grid-template-columns:repeat(2,1fr)}.kpop-char{min-width:34px;height:42px;font-size:1.3rem}}.translate-panel{width:100%;max-width:860px;align-self:center;background:#fff;border:2px solid #e0e4f0;border-radius:14px;padding:1.1rem 1.25rem;margin-bottom:1rem;display:flex;flex-direction:column;gap:.9rem}.tp-input-section{display:flex;flex-direction:column;gap:.5rem}.tp-input-header{display:flex;align-items:center;justify-content:space-between}.tp-input-label{font-size:.8rem;font-weight:700;color:#555;text-transform:uppercase;letter-spacing:.04em}.tp-hint{font-size:.72rem;color:#bbb}.tp-textarea{width:100%;padding:.65rem .85rem;border:1.5px solid #dde0f0;border-radius:10px;background:#fafbff;font-size:.95rem;color:#333;resize:vertical;min-height:72px;font-family:inherit;line-height:1.55;transition:border-color .15s;box-sizing:border-box}.tp-textarea:focus{outline:none;border-color:#78e;background:#fff;box-shadow:0 0 0 3px #6478f014}.tp-textarea:disabled{opacity:.6;cursor:not-allowed}.tp-textarea::placeholder{color:#bbbbc8;font-size:.88rem}.tp-actions{display:flex;gap:.5rem}.tp-btn-translate{flex:1;padding:.55rem 1rem;background:linear-gradient(135deg,#56d,#78f);color:#fff;border:none;border-radius:9px;font-size:.9rem;font-weight:700;cursor:pointer;transition:all .15s}.tp-btn-translate:hover:not(:disabled){background:linear-gradient(135deg,#45c,#67e);transform:translateY(-1px);box-shadow:0 4px 12px #5064dc40}.tp-btn-translate:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.tp-btn-reset{padding:.55rem .85rem;background:transparent;color:#aaa;border:1.5px solid #ddd;border-radius:9px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .15s}.tp-btn-reset:hover{background:#f5f5f5;color:#666;border-color:#bbb}.tp-loading{display:flex;align-items:center;justify-content:center;gap:.5rem}.tp-spinner{width:14px;height:14px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:tp-spin .7s linear infinite}@keyframes tp-spin{to{transform:rotate(360deg)}}.tp-error{padding:.45rem .7rem;background:#fff0f0;border:1px solid #ffcccc;border-radius:7px;color:#c62828;font-size:.82rem}.tp-result-section{display:flex;flex-direction:column;gap:.3rem;padding:.8rem 1rem;background:#f7f8ff;border:1.5px solid #e0e4ff;border-radius:10px}.tp-original,.tp-korean-row{display:flex;align-items:center;gap:.5rem;width:100%}.tp-original-label,.tp-korean-label{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;min-width:42px;flex-shrink:0}.tp-original-label{color:#aaa}.tp-korean-label{color:#56d}.tp-original-text{font-size:.88rem;color:#888;font-style:italic}.tp-arrow{font-size:.9rem;color:#ccd0f0;padding-left:.2rem}.tp-korean-row{display:flex;align-items:center;gap:.5rem}.tp-korean-main{display:flex;align-items:baseline;gap:.5rem;flex:1;min-width:0}.tp-korean-text{font-size:1.15rem;font-weight:800;color:#34c;line-height:1.3}.tp-tts-btn{width:32px;height:32px;flex-shrink:0;border:none;border-radius:50%;background:#e8eaff;color:#56d;font-size:.9rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .18s;line-height:1}.tp-tts-btn:hover{background:#56d;color:#fff;transform:scale(1.1)}.tp-tts-btn.speaking{background:#56d;color:#fff;animation:tp-pulse-tts 1.2s ease-in-out infinite}@keyframes tp-pulse-tts{0%,to{box-shadow:0 0 #5566dd73}50%{box-shadow:0 0 0 6px #56d0}}.tp-romanized{display:flex;align-items:baseline;gap:.5rem;padding-top:.2rem;border-top:1px solid #e8eaff;margin-top:.15rem}.tp-romanized-label{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#aaa;min-width:42px;flex-shrink:0}.tp-romanized-text{font-size:.88rem;color:#78b;font-style:italic;font-weight:500;letter-spacing:.02em}.tp-typing-target{padding:.85rem .9rem;background:#fafafa;border:2px solid #e0e0e8;border-radius:10px;transition:border-color .3s,background .3s}.tp-typing-target.complete{border-color:#81c784;background:#f5fff5}.tp-typing-label{font-size:.75rem;color:#aaa;font-weight:600;margin-bottom:.6rem;text-transform:uppercase;letter-spacing:.04em}.tp-typing-target.complete .tp-typing-label{color:#2e7d32}.tp-target-chars{display:flex;flex-wrap:wrap;gap:4px}.tp-char{display:inline-flex;align-items:center;justify-content:center;min-width:40px;height:48px;font-size:1.6rem;font-weight:800;border-radius:8px;border:2px solid #ddd;background:#fafafa;color:#ccc;transition:all .15s}.tp-char.current{border-color:#56d;background:#f0f0ff;color:#56d;box-shadow:0 0 8px #56d3;animation:tp-pulse 1.5s ease-in-out infinite}.tp-char.correct{border-color:#81c784;background:#e8f5e9;color:#2e7d32}.tp-char.wrong{border-color:#e57373;background:#fce4ec;color:#c62828}@keyframes tp-pulse{0%,to{box-shadow:0 0 8px #56d3}50%{box-shadow:0 0 16px #56d6}}@media(max-width:540px){.tp-char{min-width:34px;height:42px;font-size:1.3rem}}.ps-container{width:100%;max-width:860px;animation:ps-fade-in .25s ease}@keyframes ps-fade-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.ps-header{margin-bottom:1.25rem}.ps-back{background:none;border:none;color:#67c;font-size:.85rem;font-weight:700;cursor:pointer;padding:.2rem 0;margin-bottom:.75rem;display:inline-block;transition:color .15s}.ps-back:hover{color:#9af}.ps-selected-cat{display:flex;align-items:center;gap:.9rem}.ps-selected-icon{font-size:2.2rem;line-height:1}.ps-title{font-size:1.35rem;font-weight:800;color:#224;margin:0 0 .15rem}.ps-subtitle{font-size:.85rem;color:#888;margin:0}.ps-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:.75rem}.ps-card{display:flex;align-items:center;gap:.85rem;padding:1rem 1.1rem;background:#fff;border:2px solid #e8eaf6;border-radius:14px;cursor:pointer;text-align:left;transition:all .18s;width:100%}.ps-card:hover{border-color:#67c;box-shadow:0 4px 16px #505ac81f;transform:translateY(-2px)}.ps-card-icon{font-size:2rem;flex-shrink:0;line-height:1}.ps-card-body{flex:1;display:flex;flex-direction:column;gap:.1rem;min-width:0}.ps-card-name{font-size:1rem;font-weight:800;color:#224}.ps-card-name-ko{font-size:.8rem;font-weight:600;color:#67c}.ps-card-desc{font-size:.75rem;color:#aaa}.ps-card-counts{display:flex;flex-direction:column;gap:3px;flex-shrink:0}.ps-count{font-size:.65rem;font-weight:700;padding:.1rem .4rem;border-radius:20px;text-align:center}.ps-count.easy{background:#e8f5e9;color:#2e7d32}.ps-count.medium{background:#fff3e0;color:#e65100}.ps-count.hard{background:#fce4ec;color:#c62828}.ps-diff-list{display:flex;flex-direction:column;gap:.65rem}.ps-diff-card{display:flex;align-items:center;gap:1rem;padding:1.1rem 1.3rem;background:#fff;border:2px solid #e8eaf6;border-radius:14px;cursor:pointer;text-align:left;transition:all .18s;width:100%}.ps-diff-card:hover{transform:translateY(-2px);box-shadow:0 4px 18px #0000001a}.ps-diff-card.easy:hover{border-color:#81c784}.ps-diff-card.medium:hover{border-color:#ffb74d}.ps-diff-card.hard:hover{border-color:#e57373}.ps-diff-emoji{font-size:2rem;flex-shrink:0;line-height:1}.ps-diff-body{flex:1;display:flex;flex-direction:column;gap:.2rem}.ps-diff-label{font-size:1.1rem;font-weight:800;color:#224}.ps-diff-desc{font-size:.8rem;color:#999}.ps-diff-count{font-size:.8rem;font-weight:700;color:#aaa;white-space:nowrap}.ps-diff-card.easy .ps-diff-label{color:#2e7d32}.ps-diff-card.medium .ps-diff-label{color:#e65100}.ps-diff-card.hard .ps-diff-label{color:#c62828}@media(max-width:600px){.ps-grid{grid-template-columns:1fr}}.settings-panel{width:100%;max-width:560px;animation:sp-fade-in .22s ease}@keyframes sp-fade-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.sp-header{margin-bottom:1.5rem}.sp-title{font-size:1.35rem;font-weight:800;color:#224;margin:0 0 .2rem}.sp-subtitle{font-size:.85rem;color:#999;margin:0}.sp-section{background:#fff;border:2px solid #e8eaf6;border-radius:14px;padding:1rem 1.2rem;margin-bottom:1rem}.sp-section-title{font-size:.82rem;font-weight:800;color:#67c;text-transform:uppercase;letter-spacing:.06em;margin:0 0 .85rem}.sp-row{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;padding:.3rem 0}.sp-row+.sp-row{border-top:1px solid #f0f1f8;margin-top:.75rem;padding-top:.75rem}.sp-row-text{display:flex;flex-direction:column;gap:.2rem;flex:1;min-width:0}.sp-row-label{font-size:.95rem;font-weight:700;color:#224}.sp-row-desc{font-size:.78rem;color:#aaa;line-height:1.4}.sp-toggle{position:relative;width:44px;height:26px;border-radius:13px;border:none;cursor:pointer;flex-shrink:0;transition:background .2s;padding:0}.sp-toggle.off{background:#dde0f0}.sp-toggle.on{background:#67c}.sp-toggle-thumb{position:absolute;top:3px;width:20px;height:20px;border-radius:50%;background:#fff;box-shadow:0 1px 4px #0000002e;transition:left .2s}.sp-toggle.off .sp-toggle-thumb{left:3px}.sp-toggle.on .sp-toggle-thumb{left:21px}.gs-container{width:100%;max-width:700px;animation:gs-fade-in .22s ease;align-self:center;margin:0 auto}@keyframes gs-fade-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.gs-header{margin-bottom:1.25rem}.gs-title{font-size:1.35rem;font-weight:800;color:#224;margin:0 0 .2rem}.gs-subtitle{font-size:.85rem;color:#999;margin:0}.gs-grid{display:flex;flex-direction:column;gap:.65rem}.gs-card{display:flex;align-items:center;gap:1rem;padding:1rem 1.2rem;background:#fff;border:2px solid #e8eaf6;border-radius:14px;cursor:pointer;text-align:left;transition:all .18s;width:100%;position:relative}.gs-card:not(.coming-soon):hover{border-color:#67c;box-shadow:0 4px 18px #505ac821;transform:translateY(-2px)}.gs-card.coming-soon{opacity:.5;cursor:default;background:#fafafa}.gs-card-icon{font-size:2rem;flex-shrink:0;line-height:1}.gs-card-body{flex:1;display:flex;flex-direction:column;gap:.2rem;min-width:0}.gs-card-name{font-size:1rem;font-weight:800;color:#224}.gs-card-desc{font-size:.78rem;color:#999;line-height:1.4}.gs-badge{font-size:.68rem;font-weight:700;padding:.2rem .55rem;border-radius:20px;background:#f0f0f5;color:#aaa;white-space:nowrap;flex-shrink:0}.gs-arrow{font-size:1.1rem;color:#99c;flex-shrink:0;transition:transform .15s}.gs-card:not(.coming-soon):hover .gs-arrow{transform:translate(4px);color:#67c}.wpg-selector{width:100%;max-width:700px;animation:wpg-fade .22s ease;align-self:center;margin:0 auto}@keyframes wpg-fade{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.wpg-sel-header{margin-bottom:1.25rem}.wpg-back-btn{background:none;border:none;color:#67c;font-size:.85rem;font-weight:700;cursor:pointer;padding:0;margin-bottom:.6rem;display:inline-block;transition:color .15s}.wpg-back-btn:hover{color:#45a}.wpg-sel-title{font-size:1.35rem;font-weight:800;color:#224;margin:0 0 .15rem}.wpg-sel-sub{font-size:.85rem;color:#999;margin:0}.wpg-cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:.65rem}.wpg-cat-card{display:flex;align-items:center;gap:.85rem;padding:.9rem 1rem;background:#fff;border:2px solid #e8eaf6;border-radius:13px;cursor:pointer;text-align:left;transition:all .18s;width:100%}.wpg-cat-card:hover{border-color:#67c;box-shadow:0 4px 14px #505ac81f;transform:translateY(-2px)}.wpg-cat-icon{font-size:1.8rem;flex-shrink:0;line-height:1}.wpg-cat-body{flex:1;display:flex;flex-direction:column;gap:.1rem}.wpg-cat-name{font-size:.95rem;font-weight:800;color:#224}.wpg-cat-name-ko{font-size:.78rem;font-weight:600;color:#89c}.wpg-cat-arrow{font-size:1rem;color:#99c;transition:transform .15s}.wpg-cat-card:hover .wpg-cat-arrow{transform:translate(4px);color:#67c}.wpg-diff-list{display:flex;flex-direction:column;gap:.65rem}.wpg-diff-card{display:flex;align-items:center;gap:1rem;padding:1rem 1.2rem;background:#fff;border:2px solid #e8eaf6;border-radius:14px;cursor:pointer;text-align:left;transition:all .18s;width:100%}.wpg-diff-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #0000001a}.wpg-diff-card.easy:hover{border-color:#81c784}.wpg-diff-card.medium:hover{border-color:#ffb74d}.wpg-diff-card.hard:hover{border-color:#e57373}.wpg-diff-emoji{font-size:2rem;flex-shrink:0;line-height:1}.wpg-diff-body{flex:1;display:flex;flex-direction:column;gap:.2rem}.wpg-diff-label{font-size:1rem;font-weight:800}.wpg-diff-desc{font-size:.78rem;color:#999}.wpg-diff-meta{display:flex;flex-direction:column;align-items:flex-end;gap:.2rem;flex-shrink:0}.wpg-diff-time{font-size:.75rem;color:#aaa;font-weight:600}.wpg-diff-count{font-size:.72rem;color:#bbb}.wpg-game{width:100%;max-width:860px;display:flex;flex-direction:column;gap:.6rem;animation:wpg-fade .2s ease}.wpg-game.flash-correct{animation:flash-correct .4s ease}.wpg-game.flash-wrong{animation:flash-wrong .4s ease}@keyframes flash-correct{0%,to{background:transparent}30%{background:#4caf501f;border-radius:16px}}@keyframes flash-wrong{0%,to{background:transparent}30%{background:#f443361a;border-radius:16px}}.wpg-game-header{display:flex;align-items:center;gap:.75rem;padding:.6rem .2rem}.wpg-header-center{flex:1;display:flex;align-items:center;gap:.5rem;justify-content:center}.wpg-header-cat{font-size:.85rem;font-weight:700;color:#555}.wpg-header-diff{font-size:.85rem;font-weight:800}.wpg-score-box{display:flex;flex-direction:column;align-items:flex-end;min-width:64px}.wpg-score{font-size:1.1rem;font-weight:900;color:#224;line-height:1}.wpg-combo{font-size:.72rem;font-weight:800;color:#f70;animation:combo-pop .3s ease}@keyframes combo-pop{0%{transform:scale(.7);opacity:0}60%{transform:scale(1.15)}to{transform:scale(1);opacity:1}}.wpg-progress-row{display:flex;align-items:center;gap:.65rem}.wpg-progress-bar{flex:1;height:5px;background:#eee;border-radius:3px;overflow:hidden}.wpg-progress-fill{height:100%;background:linear-gradient(90deg,#44c,#77e);border-radius:3px;transition:width .35s ease}.wpg-progress-text{font-size:.72rem;font-weight:700;color:#aaa;min-width:32px;text-align:right}.wpg-timer-bar{height:6px;background:#eee;border-radius:3px;overflow:hidden}.wpg-timer-fill{height:100%;border-radius:3px;transition:width 1s linear,background .5s}.wpg-timer-num{font-size:.8rem;font-weight:800;text-align:right;transition:color .5s;line-height:1}.wpg-question{background:#fff;border:2px solid #e8eaf6;border-radius:16px;padding:1.25rem 1.4rem;transition:all .2s;animation:wpg-q-in .15s ease}@keyframes wpg-q-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.wpg-question.shake{animation:shake .4s ease;border-color:#e57373;background:#fff5f5}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-6px)}40%{transform:translate(6px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}.wpg-meaning{font-size:1.05rem;font-weight:700;color:#444;margin-bottom:.75rem}.wpg-hint{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:.65rem}.wpg-hint-char{display:inline-flex;align-items:center;justify-content:center;min-width:42px;height:50px;font-size:1.55rem;font-weight:800;border-radius:9px;border:2px solid;transition:all .15s}.wpg-hint-char.shown{background:#f0f2ff;border-color:#c0c8f0;color:#34a}.wpg-hint-char.blank{background:#f8f8f8;border-color:#ddd;border-style:dashed;color:#ccc;font-size:1.2rem}.wpg-hint-char.space{background:transparent;border-color:transparent;min-width:20px}.wpg-pronunciation{font-size:.82rem;color:#aaa;font-style:italic}.wpg-input-preview{min-height:56px;background:#fafafe;border:2px solid #dde;border-radius:12px;padding:.75rem 1rem;font-size:1.5rem;font-weight:700;color:#34c;display:flex;align-items:center}.wpg-placeholder{color:#ccc;font-size:.9rem;font-weight:400}.wpg-hint-shown{color:#555;font-weight:700}.wpg-filled{color:#35c;font-weight:900;border-bottom:2px solid #3355cc;padding-bottom:1px}.wpg-blank{color:#ccc;font-weight:700}.wpg-skip-btn{align-self:flex-end;background:none;border:1px solid #dde;border-radius:8px;padding:.4rem 1rem;font-size:.82rem;font-weight:600;color:#aaa;cursor:pointer;transition:all .15s}.wpg-skip-btn:hover{background:#f5f5f5;color:#666;border-color:#bbb}.wpg-result{width:100%;max-width:700px;animation:wpg-fade .25s ease;align-self:center;margin:0 auto}.wpg-result-hero{background:#fff;border:2px solid #e8eaf6;border-radius:16px;padding:1.75rem 1.5rem 1.5rem;text-align:center;margin-bottom:1rem}.wpg-result-emoji{font-size:3rem;line-height:1;margin-bottom:.5rem;animation:wpg-pop .4s ease}.wpg-result-title{font-size:1.5rem;font-weight:900;color:#224;margin-bottom:.25rem}.wpg-result-score{font-size:2rem;font-weight:900;color:#44c;margin-bottom:1rem}@keyframes wpg-pop{0%{transform:scale(.6);opacity:0}70%{transform:scale(1.15)}to{transform:scale(1);opacity:1}}.wpg-result-stats{display:flex;align-items:center;justify-content:center;gap:1.5rem;flex-wrap:wrap}.wpg-stat{display:flex;flex-direction:column;align-items:center;gap:.15rem}.wpg-stat-val{font-size:1.1rem;font-weight:800;color:#224}.wpg-stat-label{font-size:.72rem;color:#aaa;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.wpg-stat-divider{width:1px;height:32px;background:#eee}.wpg-result-list{background:#fff;border:2px solid #e8eaf6;border-radius:14px;overflow:hidden;margin-bottom:1rem}.wpg-result-row{display:flex;align-items:center;gap:.65rem;padding:.65rem 1rem;border-bottom:1px solid #f0f0f5;font-size:.88rem}.wpg-result-row:last-child{border-bottom:none}.wpg-result-row.correct{background:#f8fff8}.wpg-result-row.wrong{background:#fff8f8}.wpg-result-icon{font-size:1rem;flex-shrink:0}.wpg-result-word{font-size:1rem;font-weight:800;color:#224;min-width:80px}.wpg-result-meaning{flex:1;color:#777}.wpg-result-user{font-size:.78rem;color:#e57373;font-style:italic}.wpg-result-actions{display:flex;gap:.65rem;flex-wrap:wrap}.wpg-btn-retry{flex:1;padding:.75rem;background:#44c;color:#fff;border:none;border-radius:12px;font-size:.95rem;font-weight:700;cursor:pointer;transition:all .15s;min-width:120px}.wpg-btn-retry:hover{background:#33a;transform:translateY(-1px)}.wpg-btn-back{flex:1;padding:.75rem;background:transparent;color:#666;border:2px solid #dde;border-radius:12px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .15s;min-width:120px}.wpg-btn-back:hover{background:#f5f5f5;border-color:#bbb}@media(max-width:600px){.wpg-cat-grid{grid-template-columns:1fr}.wpg-hint-char{min-width:36px;height:44px;font-size:1.3rem}}.cw-select{width:100%;max-width:600px;animation:cw-fade .22s ease;align-self:center;margin:0 auto}@keyframes cw-fade{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.cw-select-header{margin-bottom:1.25rem}.cw-back-btn{background:none;border:none;color:#67c;font-size:.85rem;font-weight:700;cursor:pointer;padding:0;margin-bottom:.5rem;display:inline-block;transition:color .15s}.cw-back-btn:hover{color:#45a}.cw-select-title{font-size:1.35rem;font-weight:800;color:#224;margin:0 0 .15rem;display:block}.cw-select-sub{font-size:.85rem;color:#999}.cw-puzzle-list{display:flex;flex-direction:column;gap:.65rem}.cw-puzzle-card{display:flex;align-items:center;gap:1rem;padding:1rem 1.2rem;background:#fff;border:2px solid #e8eaf6;border-radius:14px;cursor:pointer;text-align:left;transition:all .18s;width:100%}.cw-puzzle-card:hover{border-color:#67c;box-shadow:0 4px 16px #505ac821;transform:translateY(-2px)}.cw-puzzle-num{font-size:1.2rem;font-weight:900;color:#67c;min-width:28px}.cw-puzzle-info{flex:1;display:flex;flex-direction:column;gap:.15rem}.cw-puzzle-title{font-size:1rem;font-weight:800;color:#224}.cw-puzzle-meta{font-size:.78rem;color:#aaa}.cw-puzzle-arrow{font-size:1rem;color:#99c;transition:transform .15s}.cw-puzzle-card:hover .cw-puzzle-arrow{transform:translate(4px);color:#67c}.cw-game{width:100%;max-width:860px;display:flex;flex-direction:column;gap:.65rem;animation:cw-fade .2s ease}.cw-game-header{display:flex;align-items:center;gap:.75rem;padding:.3rem 0}.cw-game-title{flex:1;font-size:1rem;font-weight:800;color:#224;text-align:center}.cw-game-progress{font-size:.85rem;font-weight:700;color:#67c;min-width:40px;text-align:right}.cw-body{display:flex;gap:1rem;align-items:flex-start}.cw-grid-wrap{flex-shrink:0}.cw-grid{display:grid;gap:2px;background:#333;border:2px solid #333;border-radius:6px;overflow:hidden;width:min(calc(100vw - 2rem),380px);aspect-ratio:1 / 1}.cw-cell{position:relative;display:flex;align-items:center;justify-content:center;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .1s}.cw-cell.black{background:#2a2a44;cursor:default}.cw-cell.white{background:#fff}.cw-cell.white:hover{background:#f0f2ff}.cw-cell.white.active{background:#dde4ff}.cw-cell.white.cursor{background:#abf}.cw-cell.correct{background:#e8f5e9!important}.cw-cell.wrong{background:#fce4ec!important}.cw-cell-num{position:absolute;top:2px;left:3px;font-size:clamp(.45rem,1.5vw,.6rem);font-weight:800;color:#555;line-height:1}.cw-cell-char{font-size:clamp(.9rem,3.5vw,1.4rem);font-weight:800;color:#224;line-height:1}.cw-cell.correct .cw-cell-char{color:#2e7d32}.cw-cell.wrong .cw-cell-char{color:#c62828}.cw-cell.cursor .cw-cell-char{color:#23a}.cw-clues{flex:1;min-width:0;display:flex;flex-direction:column;gap:.75rem;max-height:380px;overflow-y:auto;scrollbar-width:thin}.cw-clue-heading{font-size:.72rem;font-weight:800;color:#67c;text-transform:uppercase;letter-spacing:.06em;margin-bottom:.4rem;padding-bottom:.3rem;border-bottom:2px solid #e8eaf6}.cw-clue-item{display:flex;gap:.4rem;padding:.35rem .5rem;border-radius:7px;border:none;background:none;cursor:pointer;text-align:left;width:100%;transition:background .12s}.cw-clue-item:hover{background:#f0f2ff}.cw-clue-item.active{background:#dde4ff}.cw-clue-item.solved{opacity:.45;text-decoration:line-through}.cw-clue-item.solved.active{opacity:.7}.cw-clue-num{font-size:.78rem;font-weight:800;color:#67c;min-width:20px;flex-shrink:0}.cw-clue-text{font-size:.78rem;color:#555;line-height:1.35}.cw-active-clue{display:flex;align-items:flex-start;gap:.5rem;padding:.55rem .85rem;background:#eef0ff;border-radius:10px;border:1.5px solid #c8cef8}.cw-active-num{font-size:.82rem;font-weight:800;color:#45c;flex-shrink:0}.cw-active-text{font-size:.88rem;color:#333;font-weight:600}.cw-header-right{display:flex;align-items:center;gap:.6rem}.cw-hint-wrap{position:relative}.cw-hint-btn{display:flex;align-items:center;gap:.3rem;padding:.32rem .75rem;background:#f0f2ff;border:1.5px solid #c8cef8;border-radius:8px;color:#45c;font-size:.82rem;font-weight:700;cursor:pointer;transition:all .15s;white-space:nowrap}.cw-hint-btn:hover{background:#e4e8ff;border-color:#9aaaf0}.cw-hint-btn.open{background:#dde4ff;border-color:#78e}.cw-hint-menu{position:absolute;top:calc(100% + 6px);right:0;width:280px;background:#fff;border:2px solid #e0e4f8;border-radius:12px;box-shadow:0 8px 24px #3c50c826;z-index:50;overflow:hidden;animation:hint-drop .15s ease}@keyframes hint-drop{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.cw-hint-option{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;width:100%;border:none;background:none;cursor:pointer;text-align:left;transition:background .12s;border-bottom:1px solid #f0f2f8}.cw-hint-option:last-child{border-bottom:none}.cw-hint-option:hover:not(:disabled){background:#f4f6ff}.cw-hint-option:disabled{opacity:.45;cursor:default}.cw-hint-option.active{background:#eef0ff}.cw-hint-option-icon{font-size:1.2rem;flex-shrink:0;line-height:1}.cw-hint-option-body{flex:1;display:flex;flex-direction:column;gap:.1rem;min-width:0}.cw-hint-option-label{font-size:.85rem;font-weight:700;color:#224}.cw-hint-option-desc{font-size:.72rem;color:#999;line-height:1.3}.cw-hint-option-badge{font-size:.68rem;font-weight:700;padding:.15rem .4rem;border-radius:20px;background:#eef0ff;color:#56c;white-space:nowrap;flex-shrink:0}.cw-hint-option-badge.empty{background:#fce4ec;color:#c62828}.cw-cell.revealed{background:#fff8e1!important}.cw-cell.revealed .cw-cell-char{color:#f57f17!important}.cw-cell-chosung{position:absolute;bottom:2px;right:3px;font-size:clamp(.4rem,1.2vw,.55rem);font-weight:800;color:#78d;line-height:1;pointer-events:none}.cw-active-body{flex:1;display:flex;flex-direction:column;gap:.15rem;min-width:0}.cw-active-initials{font-size:.82rem;font-weight:800;color:#78d;letter-spacing:.15em}.cw-hint-notice{font-size:.82rem;color:#ff9800;font-weight:600}.cw-complete{width:100%;max-width:500px;text-align:center;padding:2.5rem 1rem;animation:cw-fade .25s ease;align-self:center;margin:0 auto}.cw-complete-emoji{font-size:3.5rem;margin-bottom:.75rem;animation:cw-pop .4s ease}.cw-complete-title{font-size:1.8rem;font-weight:900;color:#224;margin-bottom:.3rem}.cw-complete-sub{font-size:1rem;color:#888;margin-bottom:2rem}@keyframes cw-pop{0%{transform:scale(.6);opacity:0}70%{transform:scale(1.2)}to{transform:scale(1);opacity:1}}.cw-complete-actions{display:flex;flex-direction:column;gap:.65rem;align-items:center}.cw-btn-primary{padding:.75rem 2rem;background:#44c;color:#fff;border:none;border-radius:12px;font-size:.95rem;font-weight:700;cursor:pointer;transition:all .15s;width:100%;max-width:300px}.cw-btn-primary:hover{background:#33a;transform:translateY(-1px)}.cw-btn-secondary{padding:.65rem 2rem;background:transparent;color:#666;border:2px solid #dde;border-radius:12px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .15s;width:100%;max-width:300px}.cw-btn-secondary:hover{background:#f5f5f5}@media(max-width:640px){.cw-body{flex-direction:column}.cw-grid{width:min(calc(100vw - 1rem),340px)}.cw-clues{max-height:200px}}.wr-ready{width:100%;max-width:500px;display:flex;flex-direction:column;gap:1.2rem;animation:wr-fade .22s ease;align-self:center;margin:0 auto}@keyframes wr-fade{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.wr-back-btn{background:none;border:none;color:#67c;font-size:.85rem;font-weight:700;cursor:pointer;padding:0;align-self:flex-start;transition:color .15s}.wr-back-btn:hover{color:#45a}.wr-ready-hero{text-align:center;padding:.5rem 0}.wr-ready-icon{font-size:3rem;margin-bottom:.5rem}.wr-ready-title{font-size:1.8rem;font-weight:900;color:#224;margin:0 0 .5rem}.wr-ready-desc{font-size:.92rem;color:#888;line-height:1.6}.wr-level-list{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center}.wr-level-card{display:flex;flex-direction:column;align-items:center;gap:.2rem;padding:.7rem 1rem;background:#fff;border:2px solid #e8eaf6;border-radius:12px;cursor:pointer;min-width:80px;transition:all .15s}.wr-level-card:hover{border-color:#67c;transform:translateY(-2px)}.wr-level-card.selected{border-color:#45c;background:#eef0ff;box-shadow:0 4px 12px #465ac82e}.wr-level-num{font-size:.75rem;font-weight:800;color:#67c}.wr-level-label{font-size:.95rem;font-weight:800;color:#224}.wr-level-speed{font-size:.7rem;color:#aaa}.wr-start-btn{padding:.85rem;background:linear-gradient(135deg,#45c,#67e);color:#fff;border:none;border-radius:14px;font-size:1.05rem;font-weight:800;cursor:pointer;transition:all .15s;letter-spacing:.03em}.wr-start-btn:hover{filter:brightness(1.1);transform:translateY(-2px)}.wr-gameover{width:100%;max-width:500px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:1.2rem;animation:wr-fade .25s ease;align-self:center;margin:0 auto}.wr-gameover-icon{font-size:3.5rem;animation:wr-pop .4s ease}.wr-gameover-title{font-size:1.8rem;font-weight:900;color:#224;margin:0}@keyframes wr-pop{0%{transform:scale(.6);opacity:0}70%{transform:scale(1.2)}to{transform:scale(1);opacity:1}}.wr-gameover-stats{display:flex;gap:1.5rem;justify-content:center;flex-wrap:wrap}.wr-stat-box{display:flex;flex-direction:column;align-items:center;gap:.2rem;padding:.75rem 1.25rem;background:#fff;border:2px solid #e8eaf6;border-radius:12px;min-width:80px}.wr-stat-val{font-size:1.5rem;font-weight:900;color:#224;line-height:1}.wr-stat-label{font-size:.72rem;color:#aaa;font-weight:600;text-transform:uppercase}.wr-gameover-actions{display:flex;flex-direction:column;gap:.6rem;width:100%;max-width:280px}.wr-back-btn2{padding:.65rem;background:transparent;color:#666;border:2px solid #dde;border-radius:12px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .15s}.wr-back-btn2:hover{background:#f5f5f5;border-color:#bbb}.wr-game{width:100%;max-width:860px;display:flex;flex-direction:column;gap:.4rem}.wr-game.miss-flash{animation:wr-miss .4s ease}@keyframes wr-miss{0%,to{background:transparent}30%{background:#dc323214;border-radius:12px}}.wr-hud{display:flex;align-items:center;justify-content:space-between;padding:.3rem .2rem;gap:.5rem}.wr-hud-left{display:flex;align-items:center;gap:.5rem;flex:1}.wr-hud-center{flex:1;text-align:center}.wr-hud-right{flex:1;text-align:right}.wr-pause-btn{background:none;border:1.5px solid #dde;border-radius:6px;color:#888;font-size:.75rem;font-weight:700;padding:.2rem .45rem;cursor:pointer;transition:all .15s}.wr-pause-btn:hover{background:#fee;border-color:#e77;color:#c44}.wr-level-badge{font-size:.78rem;font-weight:800;color:#67c;background:#eef0ff;padding:.18rem .55rem;border-radius:20px}.wr-combo{font-size:.78rem;font-weight:800;color:#f70;animation:wr-combo-pop .3s ease}@keyframes wr-combo-pop{0%{transform:scale(.7);opacity:0}60%{transform:scale(1.15)}to{transform:scale(1);opacity:1}}.wr-score{font-size:1.3rem;font-weight:900;color:#224}.wr-lives{font-size:1rem;letter-spacing:.1em}.wr-level-bar{height:6px;background:#eee;border-radius:3px;overflow:visible;position:relative}.wr-level-fill{height:100%;background:linear-gradient(90deg,#67e,#4af);border-radius:3px;transition:width .3s ease}.wr-level-text{position:absolute;right:0;top:-5px;font-size:.65rem;color:#aaa;font-weight:600;white-space:nowrap}.wr-field{position:relative;width:100%;height:280px;background:linear-gradient(180deg,#f8f9ff,#eef0ff);border:2px solid #d8dcf0;border-radius:14px;overflow:hidden}.wr-ground{position:absolute;bottom:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#e57373,#ef5350);box-shadow:0 0 8px #e5737380}.wr-word{position:absolute;display:flex;flex-direction:column;align-items:center;gap:1px;transform:translate(-50%);cursor:default}@keyframes wr-sway{0%{margin-left:-3px}to{margin-left:3px}}.wr-word-text{display:flex;gap:1px;background:#ffffffeb;border:1.5px solid #c8cef0;border-radius:8px;padding:.3rem .6rem;font-size:clamp(.95rem,2.5vw,1.1rem);font-weight:800;color:#224;white-space:nowrap;box-shadow:0 2px 8px #505ac81a;transition:border-color .15s,box-shadow .15s}.wr-word.danger .wr-word-text{border-color:#e57373;background:#ffebebf2;box-shadow:0 2px 10px #e573734d;animation:wr-sway 3s ease-in-out infinite alternate,wr-danger-pulse .8s ease-in-out infinite}@keyframes wr-danger-pulse{0%,to{box-shadow:0 2px 8px #e573734d}50%{box-shadow:0 2px 16px #e5737399}}.wr-word.target .wr-word-text{border-color:#67c;background:#eef0fff7;box-shadow:0 2px 12px #6478dc59}.wr-ch{color:#224}.wr-ch.matched{color:#36c;font-weight:900}.wr-ch.current{color:#68f;text-decoration:underline}.wr-word-meaning{font-size:.62rem;color:#999;font-weight:600;white-space:nowrap}.wr-cleared-pop{position:absolute;top:30%;left:50%;transform:translate(-50%);font-size:1.1rem;font-weight:900;color:#45c;background:#eef0fff2;padding:.35rem 1rem;border-radius:20px;border:1.5px solid #aabbff;animation:wr-pop-up .7s ease forwards;pointer-events:none;white-space:nowrap}@keyframes wr-pop-up{0%{opacity:1;transform:translate(-50%) translateY(0)}to{opacity:0;transform:translate(-50%) translateY(-30px)}}.wr-input-area{padding:.3rem 0}.wr-input-display{min-height:44px;background:#fff;border:2px solid #c8cef0;border-radius:10px;padding:.55rem 1rem;font-size:1.2rem;font-weight:800;color:#34c;display:flex;align-items:center}.wr-input-placeholder{color:#bbb;font-size:.9rem;font-weight:400}@media(max-width:640px){.wr-field{height:220px}.wr-word-text{font-size:.88rem;padding:.22rem .45rem}}.app-footer{width:100%;padding:1rem 2rem;text-align:center;border-top:1px solid rgba(0,0,0,.07);background:#fff6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.app-footer-inner{max-width:1280px;margin:0 auto;display:flex;flex-direction:column;gap:.35rem}.footer-stats{font-size:.78rem;color:#aaa}.footer-stats strong{color:#777;font-weight:600}.footer-stats-divider{margin:0 .4rem;opacity:.4}.footer-copy{font-size:.78rem;color:#999}.footer-privacy{font-size:.73rem;color:#bbb;line-height:1.5}.footer-privacy a{color:#aaa;text-decoration:underline;text-underline-offset:2px}.footer-privacy a:hover{color:#777}.app.dark .app-footer{border-color:#ffffff0d;background:#0e0e1a99}.app.dark .footer-stats{color:#44446a}.app.dark .footer-stats strong{color:#77a}.app.dark .footer-copy{color:#44446a}.app.dark .footer-privacy{color:#33334a}.app.dark .footer-privacy a{color:#44446a}.app.dark .footer-privacy a:hover{color:#77a}@media(max-width:640px){.app-footer{padding:.75rem 1rem}}.dp-container{width:100%;max-width:860px;margin:0 auto;padding-bottom:2rem}.dp-header{margin-bottom:1.25rem}.dp-title{font-size:1.5rem;font-weight:800;color:var(--text-primary, #222244);margin-bottom:.35rem;letter-spacing:-.02em}.dp-desc{font-size:.83rem;color:var(--text-muted, #999);line-height:1.6}.dp-controls{display:flex;flex-wrap:wrap;gap:.6rem;margin-bottom:.75rem;align-items:center}.dp-search-wrap{display:flex;align-items:center;flex:1;min-width:200px;background:var(--bg-card, #fff);border:1.5px solid var(--border-input, #dde);border-radius:10px;padding:0 .75rem;gap:.5rem;transition:border-color .15s}.dp-search-wrap:focus-within{border-color:var(--accent, #4444cc)}.dp-search-icon{font-size:.9rem;opacity:.5}.dp-search{flex:1;border:none;outline:none;background:transparent;font-size:.88rem;color:var(--text-primary, #222244);padding:.6rem 0}.dp-search::placeholder{color:var(--text-placeholder, #aaa)}.dp-search-clear{background:none;border:none;cursor:pointer;font-size:.75rem;color:var(--text-muted, #999);padding:.2rem;line-height:1}.dp-search-clear:hover{color:var(--text-primary, #333)}.dp-sort-group{display:flex;gap:4px;background:var(--bg-card, #fff);border:1.5px solid var(--border-input, #dde);border-radius:10px;padding:3px}.dp-sort-btn{padding:.35rem .75rem;border:none;border-radius:7px;background:transparent;color:var(--text-muted, #999);font-size:.82rem;font-weight:600;cursor:pointer;transition:all .15s;white-space:nowrap}.dp-sort-btn.active{background:var(--accent, #4444cc);color:#fff}.dp-sort-arrow{margin-left:3px;font-size:.75rem;opacity:.85}.dp-sort-btn:not(.active):hover{background:var(--accent-light, rgba(68,68,204,.08));color:var(--accent, #4444cc)}.dp-filter-group{display:flex;gap:4px;flex-wrap:wrap}.dp-filter-btn{padding:.3rem .65rem;border:1.5px solid var(--border-input, #dde);border-radius:8px;background:transparent;color:var(--text-muted, #999);font-size:.78rem;font-weight:600;cursor:pointer;transition:all .15s;white-space:nowrap}.dp-filter-btn:hover{border-color:var(--accent, #4444cc);color:var(--accent, #4444cc)}.dp-filter-btn.active{background:var(--accent, #4444cc);color:#fff;border-color:var(--accent, #4444cc)}.dp-filter-btn.level-a.active{background:#16a34a;border-color:#16a34a}.dp-filter-btn.level-b.active{background:#d97706;border-color:#d97706}.dp-filter-btn.level-c.active{background:#dc2626;border-color:#dc2626}.dp-cats{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:.75rem}.dp-cat-chip{padding:.25rem .7rem;border:1.5px solid var(--border-input, #dde);border-radius:999px;background:transparent;color:var(--text-secondary, #555);font-size:.78rem;font-weight:500;cursor:pointer;transition:all .15s;white-space:nowrap}.dp-cat-chip:hover{border-color:var(--accent, #4444cc);color:var(--accent, #4444cc)}.dp-cat-chip.active{background:var(--accent, #4444cc);color:#fff;border-color:var(--accent, #4444cc)}.dp-count{font-size:.78rem;color:var(--text-muted, #999);margin-bottom:.6rem}.dp-list{list-style:none;display:flex;flex-direction:column;gap:1px}.dp-item{display:flex;gap:1rem;align-items:flex-start;padding:.75rem 1rem;background:var(--bg-card, #fff);border:1px solid var(--border-card, #e8eaf6);border-radius:10px;transition:box-shadow .12s}.dp-item:hover{box-shadow:var(--shadow-sm, 0 2px 8px rgba(0,0,0,.06))}.dp-item-left{display:flex;flex-direction:column;align-items:flex-start;gap:2px;min-width:110px;flex-shrink:0}.dp-word{font-size:1.15rem;font-weight:700;color:var(--text-primary, #222244);letter-spacing:-.01em}.dp-pronunciation{font-size:.72rem;color:var(--text-muted, #999);font-family:monospace}.dp-item-right{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}.dp-meaning{font-size:.9rem;color:var(--text-secondary, #555);font-weight:500}.dp-example{font-size:.78rem;color:var(--text-muted, #999);font-style:italic;line-height:1.4}.dp-badges{display:flex;gap:5px;flex-wrap:wrap;margin-top:2px}.dp-badge{font-size:.68rem;padding:.1rem .45rem;border-radius:4px;font-weight:600}.dp-badge-cat{background:var(--accent-light, rgba(68,68,204,.08));color:var(--accent, #4444cc)}.dp-badge-level.level-a{background:#16a34a1a;color:#16a34a}.dp-badge-level.level-b{background:#d977061a;color:#d97706}.dp-badge-level.level-c{background:#dc26261a;color:#dc2626}.dp-highlight{background:#4444cc26;color:var(--accent, #4444cc);border-radius:2px;padding:0 1px;font-style:normal;font-weight:700}.app.dark .dp-highlight{background:#7878ff40;color:#a0a0ff}.dp-empty{text-align:center;padding:3rem 1rem;color:var(--text-muted, #999);font-size:.9rem}.app.dark .dp-title{color:var(--text-primary)}.app.dark .dp-desc{color:var(--text-muted)}.app.dark .dp-search-wrap{background:var(--bg-input);border-color:var(--border-input)}.app.dark .dp-search{color:var(--text-primary)}.app.dark .dp-sort-group{background:var(--bg-card);border-color:var(--border-card)}.app.dark .dp-sort-btn{color:var(--text-muted)}.app.dark .dp-sort-btn:not(.active):hover{background:var(--accent-light)}.app.dark .dp-filter-btn{border-color:var(--border-card);color:var(--text-muted)}.app.dark .dp-cat-chip{border-color:var(--border-card);color:var(--text-secondary)}.app.dark .dp-item{background:var(--bg-card);border-color:var(--border-card)}.app.dark .dp-word{color:var(--text-primary)}.app.dark .dp-meaning{color:var(--text-secondary)}.app.dark .dp-badge-cat{background:var(--accent-light);color:var(--accent)}@media(max-width:640px){.dp-item{flex-direction:column;gap:.4rem}.dp-item-left{flex-direction:row;align-items:baseline;gap:.5rem;min-width:unset}.dp-controls{flex-direction:column;align-items:stretch}.dp-search-wrap{min-width:unset}}.page-meta-bar{width:100%;padding:.35rem 0 .6rem;margin-bottom:.25rem}.page-meta-subtitle{font-size:.78rem;color:var(--text-muted, #999);letter-spacing:.01em}.app{min-height:100vh;display:flex;flex-direction:column;background:linear-gradient(135deg,#f0f2ff,#e8eaf6,#f5f0ff);--bg-page: linear-gradient(135deg, #f0f2ff 0%, #e8eaf6 50%, #f5f0ff 100%);--bg-card: #ffffff;--bg-card-hover: #f8f9ff;--bg-input: #ffffff;--border-card: #e8eaf6;--border-input: #dde;--text-primary: #222244;--text-secondary: #555;--text-muted: #999;--text-placeholder: #aaa;--accent: #4444cc;--accent-light: rgba(68, 68, 204, .08);--accent-border: #6666cc;--shadow-card: 0 4px 20px rgba(0, 0, 0, .08);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .06)}.app.dark{background:linear-gradient(135deg,#0e0e1a,#12121f,#0f0e1a);--bg-page: linear-gradient(135deg, #0e0e1a 0%, #12121f 50%, #0f0e1a 100%);--bg-card: #1a1a2e;--bg-card-hover: #1e1e36;--bg-input: #16162a;--border-card: #2a2a44;--border-input: #2a2a44;--text-primary: #e8e8ff;--text-secondary: #b0b0cc;--text-muted: #6a6a88;--text-placeholder: #4a4a66;--accent: #7777ee;--accent-light: rgba(119, 119, 238, .12);--accent-border: #8888ee;--shadow-card: 0 4px 20px rgba(0, 0, 0, .4);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .3)}.app.dark .challenge-panel{background:var(--bg-card);border-color:var(--border-card);color:var(--text-primary)}.app.dark .challenge-panel.complete{background:#0e2218;border-color:#2a5a3a}.app.dark .challenge-meaning{color:var(--text-secondary)}.app.dark .challenge-pronunciation,.app.dark .challenge-number{color:var(--text-muted)}.app.dark .challenge-bc-cat{color:var(--text-secondary)}.app.dark .challenge-bc-sep{color:#3a3a55}.app.dark .challenge-back-btn{color:#89f}.app.dark .challenge-back-btn:hover{color:#abf}.app.dark .challenge-progress-bar{background:#2a2a44}.app.dark .challenge-progress-text{color:var(--text-muted)}.app.dark .challenge-skip{background:transparent;border-color:#2a2a44;color:var(--text-muted)}.app.dark .challenge-skip:hover{background:#22223a;color:var(--text-secondary)}.app.dark .target-char{background:#16162a;border-color:#2a2a44;color:#4a4a66}.app.dark .target-char.current{background:#1a1a3a;border-color:var(--accent);color:var(--accent)}.app.dark .target-char.correct{background:#0e2218;border-color:#2a5a3a;color:#6c8}.app.dark .target-char.wrong{background:#2a0e0e;border-color:#5a2a2a;color:#c66}.app.dark .challenge-tts-btn{background:#22223a;border-color:#3a3a55;color:var(--text-secondary)}.app.dark .challenge-tts-btn:hover{background:#2a2a4a;border-color:var(--accent)}.app.dark .challenge-success{background:#0e2218;color:#6c8}.app.dark .ps-title{color:var(--text-primary)}.app.dark .ps-subtitle{color:var(--text-muted)}.app.dark .ps-back{color:#89f}.app.dark .ps-back:hover{color:#abf}.app.dark .ps-card{background:var(--bg-card);border-color:var(--border-card)}.app.dark .ps-card:hover{border-color:var(--accent);box-shadow:0 4px 16px #6464dc33}.app.dark .ps-card-name{color:var(--text-primary)}.app.dark .ps-card-name-ko{color:#89f}.app.dark .ps-card-desc{color:var(--text-muted)}.app.dark .ps-diff-card{background:var(--bg-card);border-color:var(--border-card)}.app.dark .ps-diff-card.easy:hover{border-color:#4a6}.app.dark .ps-diff-card.medium:hover{border-color:#c83}.app.dark .ps-diff-card.hard:hover{border-color:#c44}.app.dark .ps-diff-label{color:var(--text-primary)}.app.dark .ps-diff-card.easy .ps-diff-label{color:#6c8}.app.dark .ps-diff-card.medium .ps-diff-label{color:#fa4}.app.dark .ps-diff-card.hard .ps-diff-label{color:#f66}.app.dark .ps-diff-desc{color:var(--text-muted)}.app.dark .ps-diff-count{color:#4a4a66}.app.dark .settings-panel .sp-title{color:var(--text-primary)}.app.dark .settings-panel .sp-subtitle{color:var(--text-muted)}.app.dark .sp-section{background:var(--bg-card);border-color:var(--border-card)}.app.dark .sp-section-title{color:#89f}.app.dark .sp-row+.sp-row{border-color:#22223a}.app.dark .sp-row-label{color:var(--text-primary)}.app.dark .sp-row-desc{color:var(--text-muted)}.app.dark .sp-toggle.off{background:#2a2a44}.app.dark .sp-toggle.on{background:var(--accent)}.app.dark .text-display{background:var(--bg-card);border-color:var(--border-input);color:var(--text-primary)}.app.dark .text-display:focus-within{border-color:var(--accent-border);box-shadow:0 0 0 3px #7777ee26}.app.dark .committed-text{color:var(--text-primary)}.app.dark .composing-text{color:#aaf;background:#7777ee1f;border-bottom-color:#aaf}.app.dark .cursor-blink{color:#aaf}.app.dark .placeholder-text{color:var(--text-placeholder)}.app.dark .text-clear-btn{background:#2a2a44;color:var(--text-muted)}.app.dark .text-clear-btn:hover{background:#c33;color:#fff}.app.dark .text-speak-btn{background:#2a2a44;color:#88d}.app.dark .text-speak-btn:hover,.app.dark .text-speak-btn.speaking{background:var(--accent);color:#fff}.app.dark .dict-panel{background:var(--bg-card);box-shadow:var(--shadow-card)}.app.dark .dict-api-notice{background:#14142a;border-color:#22223a;color:var(--text-muted)}.app.dark .dict-api-notice code{background:#1e1e38;color:#88d}.app.dark .dict-api-notice a{color:#88d}.app.dark .dict-empty{color:var(--text-muted)}.app.dark .dict-section{border-color:#1e1e38}.app.dark .dict-section-label{color:#4a4a66}.app.dark .dict-word{color:var(--text-primary)}.app.dark .dict-word-matched{color:#89f}.app.dark .dict-word-rest{color:#3a3a55}.app.dark .dict-category{background:#22223a;color:var(--text-muted)}.app.dark .dict-meaning{color:var(--text-secondary)}.app.dark .dict-pronunciation{color:var(--text-muted)}.app.dark .dict-source{color:#3a3a55}.app.dark .dict-entry.matched{background:#16183a;border-color:#2a2a5a}.app.dark .dict-entry.api{background:#0e2218;border-color:#1a3a28}.app.dark .dict-entry.suggestion{background:#16162a;border-color:#22223a}.app.dark .dict-entry:hover{box-shadow:var(--shadow-sm)}.app.dark .level-A{background:#0e2218;color:#6c8}.app.dark .level-B{background:#221a0e;color:#fa4}.app.dark .level-C{background:#2a0e0e;color:#f66}.app.dark .translate-panel{color:var(--text-primary)}.app.dark .tp-input-label{color:var(--text-secondary)}.app.dark .tp-hint{color:var(--text-muted)}.app.dark .tp-textarea{background:var(--bg-input);border-color:var(--border-input);color:var(--text-primary)}.app.dark .tp-textarea:focus{border-color:var(--accent-border);box-shadow:0 0 0 3px #7777ee26}.app.dark .tp-textarea::placeholder{color:var(--text-placeholder)}.app.dark .tp-result-section{background:#16162a;border-color:#2a2a44}.app.dark .tp-original-label,.app.dark .tp-korean-label,.app.dark .tp-romanized-label{color:#4a4a66}.app.dark .tp-original-text{color:var(--text-secondary)}.app.dark .tp-korean-text{color:#aaf}.app.dark .tp-romanized-text{color:var(--text-muted)}.app.dark .tp-arrow{color:#3a3a55}.app.dark .tp-tts-btn{background:#22223a;border-color:#3a3a55}.app.dark .tp-tts-btn:hover{background:var(--accent);border-color:var(--accent);color:#fff}.app.dark .tp-typing-target{background:#14142a;border-color:#22223a}.app.dark .tp-typing-label{color:var(--text-muted)}.app.dark .tp-char{color:#3a3a55;border-color:#22223a;background:#16162a}.app.dark .tp-char.current{border-color:var(--accent);color:var(--accent);background:#1a1a3a}.app.dark .tp-char.correct{border-color:#2a5a3a;color:#6c8;background:#0e2218}.app.dark .tp-char.wrong{border-color:#5a2a2a;color:#f66;background:#2a0e0e}.app.dark .cw-hint-btn:hover{background:#22274a;border-color:#45a}.app.dark .cw-hint-btn.open{background:#22274a;border-color:#56b}.app.dark .cw-hint-option:hover:not(:disabled){background:#1e2245}.app.dark .cw-hint-option.active{background:#1e2245}.app.dark .cw-hint-option-badge{background:#22223a;color:#89f}.app.dark .cw-cell.revealed .cw-cell-char{color:#fa3!important}.app.dark .cw-cell-chosung,.app.dark .cw-active-initials{color:#67c}.app.dark .cw-hint-notice{color:#fa3}.app.dark .cw-select-title{color:var(--text-primary)}.app.dark .cw-select-sub{color:var(--text-muted)}.app.dark .cw-back-btn{color:#89f}.app.dark .cw-back-btn:hover{color:#abf}.app.dark .cw-puzzle-card{background:var(--bg-card);border-color:var(--border-card)}.app.dark .cw-puzzle-card:hover{border-color:var(--accent)}.app.dark .cw-puzzle-title{color:var(--text-primary)}.app.dark .cw-puzzle-meta{color:var(--text-muted)}.app.dark .cw-puzzle-num{color:var(--accent)}.app.dark .cw-puzzle-arrow{color:#4a4a77}.app.dark .cw-game-title{color:var(--text-primary)}.app.dark .cw-game-progress{color:var(--accent)}.app.dark .cw-grid{background:#112;border-color:#112}.app.dark .cw-cell.black{background:#112}.app.dark .cw-cell.white{background:#1e1e38}.app.dark .cw-cell.white:hover{background:#22223a}.app.dark .cw-cell.white.active{background:#1e2450}.app.dark .cw-cell.white.cursor{background:#2a3570}.app.dark .cw-cell.correct{background:#0e2218!important}.app.dark .cw-cell.wrong{background:#2a0e0e!important}.app.dark .cw-cell-num{color:#67a}.app.dark .cw-cell-char{color:var(--text-primary)}.app.dark .cw-cell.correct .cw-cell-char{color:#6c8}.app.dark .cw-cell.wrong .cw-cell-char{color:#f66}.app.dark .cw-cell.cursor .cw-cell-char{color:#abf}.app.dark .cw-clue-heading{color:var(--accent);border-color:var(--border-card)}.app.dark .cw-clue-item:hover{background:#1e1e38}.app.dark .cw-clue-item.active{background:#1e2450}.app.dark .cw-clue-num{color:var(--accent)}.app.dark .cw-clue-text{color:var(--text-secondary)}.app.dark .cw-active-text,.app.dark .cw-complete-title{color:var(--text-primary)}.app.dark .cw-complete-sub{color:var(--text-muted)}.app.dark .cw-btn-secondary{border-color:var(--border-card);color:var(--text-muted)}.app.dark .cw-btn-secondary:hover{background:#22223a}.app.dark .gs-title{color:var(--text-primary)}.app.dark .gs-subtitle{color:var(--text-muted)}.app.dark .gs-card{background:var(--bg-card);border-color:var(--border-card)}.app.dark .gs-card:not(.coming-soon):hover{border-color:var(--accent);box-shadow:0 4px 16px #6464dc33}.app.dark .gs-card.coming-soon{background:#141428}.app.dark .gs-card-name{color:var(--text-primary)}.app.dark .gs-card-desc{color:var(--text-muted)}.app.dark .gs-badge{background:#22223a;color:#4a4a66}.app.dark .gs-arrow{color:#4a4a77}.app.dark .cw-hint-btn{background:#1a1e3a;border-color:#2a2e5a;color:#89f}.app.dark .cw-hint-btn:hover{background:#22283a}.app.dark .cw-hint-btn.open{background:#1e2450;border-color:#34a}.app.dark .cw-hint-menu{background:var(--bg-card);border-color:var(--border-card);box-shadow:0 8px 24px #0006}.app.dark .cw-hint-option:hover:not(:disabled){background:#1e1e38}.app.dark .cw-hint-option.active{background:#1e2450}.app.dark .cw-hint-option{border-color:#1e1e38}.app.dark .cw-hint-option-label{color:var(--text-primary)}.app.dark .cw-hint-option-desc{color:var(--text-muted)}.app.dark .cw-hint-option-badge{background:#1e2450;color:#89f}.app.dark .cw-hint-option-badge.empty{background:#2a0e0e;color:#f66}.app.dark .cw-cell.revealed{background:#2a2000!important}.app.dark .cw-cell.revealed .cw-cell-char{color:#ffb74d!important}.app.dark .cw-cell-chosung,.app.dark .cw-active-initials{color:#67b}.app.dark .cw-active-body .cw-active-text{color:var(--text-primary)}.app.dark .cw-active-clue{background:#1a1e3a;border-color:#2a2e5a}.app.dark .cw-active-num{color:#89f}.app.dark .cw-hint-notice{color:#ffb74d}.app.dark .wr-ready-title{color:var(--text-primary)}.app.dark .wr-ready-desc{color:var(--text-muted)}.app.dark .wr-level-card{background:var(--bg-card);border-color:var(--border-card)}.app.dark .wr-level-card:hover{border-color:var(--accent)}.app.dark .wr-level-card.selected{background:#1e2450;border-color:var(--accent)}.app.dark .wr-level-label{color:var(--text-primary)}.app.dark .wr-level-num{color:var(--accent)}.app.dark .wr-level-speed{color:var(--text-muted)}.app.dark .wr-gameover-title{color:var(--text-primary)}.app.dark .wr-stat-box{background:var(--bg-card);border-color:var(--border-card)}.app.dark .wr-stat-val{color:var(--text-primary)}.app.dark .wr-back-btn2{border-color:var(--border-card);color:var(--text-muted)}.app.dark .wr-back-btn2:hover{background:#22223a}.app.dark .wr-score{color:var(--text-primary)}.app.dark .wr-level-badge{background:#1a1e3a;color:var(--accent)}.app.dark .wr-level-bar{background:#2a2a44}.app.dark .wr-level-text{color:var(--text-muted)}.app.dark .wr-field{background:linear-gradient(180deg,#0e0e1a,#12121f);border-color:#2a2a44}.app.dark .wr-word-text{background:#1a1a2ef2;border-color:#3a3a66;color:var(--text-primary)}.app.dark .wr-word.target .wr-word-text{background:#1e2450f7;border-color:var(--accent)}.app.dark .wr-word.danger .wr-word-text{background:#2a0e0ef2;border-color:#c55}.app.dark .wr-ch{color:var(--text-primary)}.app.dark .wr-ch.matched{color:#8af}.app.dark .wr-ch.current{color:#abf}.app.dark .wr-word-meaning{color:var(--text-muted)}.app.dark .wr-input-display{background:var(--bg-input);border-color:var(--border-input);color:#abf}.app.dark .wr-cleared-pop{background:#1a1e3af2;border-color:#56b;color:#89f}.app.dark .wpg-sel-title{color:var(--text-primary)}.app.dark .wpg-sel-sub{color:var(--text-muted)}.app.dark .wpg-back-btn{color:#89f}.app.dark .wpg-back-btn:hover{color:#abf}.app.dark .wpg-cat-card{background:var(--bg-card);border-color:var(--border-card)}.app.dark .wpg-cat-card:hover{border-color:var(--accent)}.app.dark .wpg-cat-name{color:var(--text-primary)}.app.dark .wpg-cat-name-ko{color:#67b}.app.dark .wpg-cat-arrow{color:#4a4a77}.app.dark .wpg-diff-card{background:var(--bg-card);border-color:var(--border-card)}.app.dark .wpg-diff-card.easy:hover{border-color:#4a6}.app.dark .wpg-diff-card.medium:hover{border-color:#c83}.app.dark .wpg-diff-card.hard:hover{border-color:#c44}.app.dark .wpg-diff-desc{color:var(--text-muted)}.app.dark .wpg-diff-time{color:#4a4a66}.app.dark .wpg-diff-count{color:#3a3a55}.app.dark .wpg-score{color:var(--text-primary)}.app.dark .wpg-header-cat{color:var(--text-secondary)}.app.dark .wpg-progress-bar,.app.dark .wpg-timer-bar{background:#2a2a44}.app.dark .wpg-question{background:var(--bg-card);border-color:var(--border-card)}.app.dark .wpg-question.shake{background:#2a0e0e;border-color:#5a2a2a}.app.dark .wpg-meaning{color:var(--text-secondary)}.app.dark .wpg-pronunciation{color:var(--text-muted)}.app.dark .wpg-hint-char.shown{background:#1a1e3a;border-color:#2a3066;color:#89e}.app.dark .wpg-hint-char.blank{background:#16162a;border-color:#2a2a44;color:#3a3a55}.app.dark .wpg-input-preview{background:#16162a;border-color:#2a2a44;color:#89f}.app.dark .wpg-skip-btn{border-color:#2a2a44;color:var(--text-muted)}.app.dark .wpg-skip-btn:hover{background:#22223a;color:var(--text-secondary)}.app.dark .wpg-result-hero{background:var(--bg-card);border-color:var(--border-card)}.app.dark .wpg-result-title{color:var(--text-primary)}.app.dark .wpg-result-score{color:var(--accent)}.app.dark .wpg-stat-val{color:var(--text-primary)}.app.dark .wpg-stat-label{color:var(--text-muted)}.app.dark .wpg-stat-divider{background:#2a2a44}.app.dark .wpg-result-list{background:var(--bg-card);border-color:var(--border-card)}.app.dark .wpg-result-row{border-color:#1e1e38}.app.dark .wpg-result-row.correct{background:#0e2218}.app.dark .wpg-result-row.wrong{background:#2a0e0e}.app.dark .wpg-result-word{color:var(--text-primary)}.app.dark .wpg-result-meaning{color:var(--text-muted)}.app.dark .wpg-btn-back{border-color:#2a2a44;color:var(--text-muted)}.app.dark .wpg-btn-back:hover{background:#22223a}.app-content{flex:1;width:100%;max-width:1280px;margin:0 auto;padding:1.25rem 2rem 3rem;display:flex;gap:1.5rem;align-items:stretch;box-sizing:border-box}.app-main{flex:1;min-width:0;display:flex;flex-direction:column;align-items:stretch}.app-sidebar{width:320px;flex-shrink:0;position:sticky;top:72px}@media(max-width:1024px){.app-content{flex-direction:column;padding:.75rem 1rem 2rem;align-items:stretch}.app-main{flex:0 0 auto;width:100%}.app-sidebar{width:100%;position:static;flex:0 0 auto}}@media(max-width:640px){.app-content{padding:.4rem .5rem 1.5rem;gap:.75rem}}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem 1rem;background:var(--bg, #f5f5f5)}.auth-card{background:var(--surface, #fff);border-radius:12px;box-shadow:0 2px 16px #0000001a;padding:2.5rem 2rem;width:100%;max-width:420px}.auth-title{font-size:1.5rem;font-weight:700;margin:0 0 .25rem;color:var(--text, #111)}.auth-subtitle{font-size:.9rem;color:var(--auth-muted, #666);margin:0 0 1.75rem}.auth-form{display:flex;flex-direction:column;gap:1rem}.auth-label{display:flex;flex-direction:column;gap:.375rem;font-size:.875rem;font-weight:500;color:var(--text, #111)}.auth-label input,.auth-label select{padding:.625rem .75rem;border:1px solid var(--border, #ddd);border-radius:8px;font-size:.9rem;background:var(--input-bg, #fff);color:var(--text, #111);transition:border-color .15s}.auth-label input:focus,.auth-label select:focus{outline:none;border-color:var(--primary, #4f46e5)}.auth-forgot{text-align:right;font-size:.8rem;margin-top:-.5rem}.auth-consents{display:flex;flex-direction:column;gap:.625rem;padding:1rem;background:var(--consent-bg, #f9f9f9);border-radius:8px;border:1px solid var(--border, #eee)}.auth-consent-row{display:flex;align-items:flex-start;gap:.5rem;font-size:.82rem;color:var(--text, #333);cursor:pointer}.auth-consent-row input[type=checkbox]{margin-top:2px;flex-shrink:0;accent-color:var(--primary, #4f46e5)}.auth-error{font-size:.85rem;color:#dc2626;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;padding:.625rem .75rem;margin:0}.auth-btn{width:100%;padding:.7rem;background:var(--primary, #4f46e5);color:#fff;border:none;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:opacity .15s}.auth-btn:disabled{opacity:.6;cursor:not-allowed}.auth-btn-google{background:#fff;color:#333;border:1px solid var(--border, #ddd);display:flex;align-items:center;justify-content:center;gap:.5rem}.auth-btn-google:hover:not(:disabled){background:#f5f5f5}.auth-divider{display:flex;align-items:center;gap:.75rem;margin:1.25rem 0;color:var(--auth-muted, #999);font-size:.8rem}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--border, #eee)}.auth-footer{text-align:center;font-size:.875rem;color:var(--auth-muted, #666);margin:1.25rem 0 0}.auth-footer a,.auth-consent-row a,.auth-forgot a{color:var(--primary, #4f46e5);text-decoration:none}.auth-footer a:hover,.auth-consent-row a:hover{text-decoration:underline}.dark .auth-page{--bg: #0f0f0f}.dark .auth-card{--surface: #1a1a1a;box-shadow:0 2px 16px #0006}.dark .auth-label input,.dark .auth-label select{--input-bg: #262626;--border: #333;color:#eee}.dark .auth-consents{--consent-bg: #1e1e1e;--border: #333}.dark .auth-btn-google{background:#1e1e1e;color:#eee;--border: #444}.dark .auth-btn-google:hover:not(:disabled){background:#2a2a2a}.profile-card{max-width:480px}.profile-loading{display:flex;justify-content:center;align-items:center;height:100vh;color:#999}.profile-avatar-wrap{display:flex;flex-direction:column;align-items:center;gap:.5rem;margin-bottom:.5rem}.profile-avatar-btn{position:relative;width:80px;height:80px;border-radius:50%;border:2px solid var(--border, #ddd);background:var(--input-bg, #f5f5f5);cursor:pointer;overflow:hidden;padding:0;transition:border-color .2s}.profile-avatar-btn:hover{border-color:var(--primary, #4f46e5)}.profile-avatar-img{width:100%;height:100%;object-fit:cover}.profile-avatar-fallback{display:flex;align-items:center;justify-content:center;width:100%;height:100%;font-size:2rem;font-weight:700;color:var(--primary, #4f46e5)}.profile-avatar-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#00000059;font-size:1.3rem;opacity:0;transition:opacity .2s}.profile-avatar-btn:hover .profile-avatar-overlay{opacity:1}.profile-avatar-hint{font-size:.75rem;color:var(--auth-muted, #999);margin:0}.profile-save-ok{font-size:.875rem;color:#16a34a;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:8px;padding:.625rem .75rem;margin:0}.profile-danger-zone{margin-top:2rem;padding-top:1.5rem;border-top:1px solid #fee2e2}.profile-danger-title{font-size:.875rem;font-weight:700;color:#dc2626;margin:0 0 .75rem;text-transform:uppercase;letter-spacing:.05em}.profile-danger-btn{padding:.5rem 1rem;background:#dc2626;color:#fff;border:none;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:opacity .15s}.profile-danger-btn:disabled{opacity:.45;cursor:not-allowed}.profile-danger-btn:not(:disabled):hover{background:#b91c1c}.profile-delete-confirm{display:flex;flex-direction:column;gap:.75rem}.profile-delete-desc{font-size:.85rem;color:#555;line-height:1.6;margin:0}.profile-delete-input{padding:.6rem .75rem;border:1px solid #fca5a5;border-radius:8px;font-size:.9rem;background:#fff5f5;color:#333}.profile-delete-input:focus{outline:none;border-color:#dc2626}.profile-delete-actions{display:flex;gap:.75rem;justify-content:flex-end}.profile-cancel-btn{padding:.5rem 1rem;background:transparent;border:1px solid var(--border, #ddd);border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;color:#555;transition:background .15s}.profile-cancel-btn:hover{background:#f5f5f5}.dark .profile-delete-desc{color:#aaa}.dark .profile-delete-input{background:#1e1e1e;color:#eee;border-color:#7f1d1d}.dark .profile-cancel-btn{color:#aaa;border-color:#444}.dark .profile-cancel-btn:hover{background:#2a2a2a}.community-wrap{max-width:860px;margin:0 auto;padding:2rem 1.5rem 4rem}.community-loading,.community-empty{text-align:center;padding:4rem 0;color:#999;font-size:.95rem}.community-login-hint{text-align:center;font-size:.875rem;color:#999;margin-top:1.5rem}.community-login-hint button{background:none;border:none;color:#4f46e5;cursor:pointer;font-weight:600;text-decoration:underline}.community-admin-hint{text-align:center;font-size:.8rem;color:#f59e0b;margin-top:.5rem}.community-tabs{display:flex;align-items:center;gap:.375rem;border-bottom:2px solid #e5e7eb;margin-bottom:1rem;padding-bottom:0}.community-tab{padding:.5rem 1rem;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;background:none;color:#888;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .15s}.community-tab:hover{color:#333}.community-tab.active{color:#4f46e5;border-bottom-color:#4f46e5}.community-write-btn{margin-left:auto;padding:.4rem .875rem;background:#4f46e5;color:#fff;border:none;border-radius:8px;font-size:.8rem;font-weight:600;cursor:pointer;transition:opacity .15s}.community-write-btn:hover{opacity:.85}.post-badge{display:inline-block;padding:.15rem .5rem;border-radius:4px;font-size:.7rem;font-weight:700;flex-shrink:0}.post-badge-general{background:#eff6ff;color:#3b82f6}.post-badge-notice{background:#fef3c7;color:#d97706}.post-badge-inquiry{background:#f0fdf4;color:#16a34a}.post-list{list-style:none;margin:0;padding:0}.post-item{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.75rem .5rem;border-bottom:1px solid #f0f0f0;cursor:pointer;transition:background .1s}.post-item:hover{background:#fafafa}.post-item.pinned{background:#fffbeb}.post-item-left{display:flex;align-items:center;gap:.5rem;min-width:0}.post-title{font-size:.9rem;font-weight:500;color:#111;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.post-thumb{width:36px;height:36px;border-radius:4px;object-fit:cover;flex-shrink:0;border:1px solid #eee}.post-comment-count{font-size:.8rem;color:#4f46e5;font-weight:600;flex-shrink:0}.post-item-right{display:flex;align-items:center;gap:.75rem;flex-shrink:0;font-size:.78rem;color:#999}.post-author{color:#666}.community-pagination{display:flex;justify-content:center;gap:.25rem;margin-top:1.5rem}.community-pagination button{min-width:32px;height:32px;border:1px solid #e5e7eb;border-radius:6px;background:#fff;font-size:.85rem;cursor:pointer;transition:all .1s}.community-pagination button:hover:not(:disabled){background:#f5f5f5}.community-pagination button.active{background:#4f46e5;color:#fff;border-color:#4f46e5}.community-pagination button:disabled{opacity:.35;cursor:not-allowed}.post-form-card{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 2px 12px #00000012}.post-form-title{font-size:1.25rem;font-weight:700;margin:0 0 1.5rem;color:#111}.post-form{display:flex;flex-direction:column;gap:1rem}.post-form-label{display:flex;flex-direction:column;gap:.375rem;font-size:.875rem;font-weight:500;color:#333}.post-form-label input,.post-form-label select,.post-form-label textarea{padding:.625rem .75rem;border:1px solid #ddd;border-radius:8px;font-size:.9rem;color:#111;resize:vertical;transition:border-color .15s;font-family:inherit}.post-form-label input:focus,.post-form-label select:focus,.post-form-label textarea:focus{outline:none;border-color:#4f46e5}.post-image-list{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.25rem}.post-image-thumb{position:relative;width:80px;height:80px;border-radius:8px;overflow:hidden;border:1px solid #ddd}.post-image-thumb img{width:100%;height:100%;object-fit:cover}.post-image-remove{position:absolute;top:2px;right:2px;width:20px;height:20px;border-radius:50%;border:none;background:#0000008c;color:#fff;font-size:.65rem;cursor:pointer;display:flex;align-items:center;justify-content:center}.post-image-add{width:80px;height:80px;border:1px dashed #ccc;border-radius:8px;background:#fafafa;color:#999;font-size:.8rem;cursor:pointer;transition:all .15s}.post-image-add:hover{border-color:#4f46e5;color:#4f46e5}.post-image-hint{font-size:.75rem;color:#aaa}.post-form-error{font-size:.85rem;color:#dc2626;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;padding:.625rem .75rem}.post-form-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:.5rem}.post-cancel-btn{padding:.6rem 1.25rem;border:1px solid #ddd;border-radius:8px;background:#fff;color:#555;font-size:.9rem;font-weight:600;cursor:pointer}.post-submit-btn{padding:.6rem 1.5rem;border:none;border-radius:8px;background:#4f46e5;color:#fff;font-size:.9rem;font-weight:600;cursor:pointer}.post-submit-btn:disabled{opacity:.5;cursor:not-allowed}.post-detail{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 2px 12px #00000012}.post-detail-header{border-bottom:1px solid #f0f0f0;padding-bottom:1rem;margin-bottom:1.5rem}.post-detail-meta{display:flex;gap:.5rem;margin-bottom:.75rem}.post-badge-pin{font-size:.75rem;color:#d97706}.post-detail-title{font-size:1.35rem;font-weight:700;color:#111;margin:0 0 .75rem;line-height:1.4}.post-detail-info{display:flex;gap:1rem;font-size:.8rem;color:#999}.post-detail-body{min-height:120px;line-height:1.75;color:#333;font-size:.95rem;margin-bottom:1.5rem}.post-detail-body p{margin:0}.post-detail-images{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.post-detail-image{max-width:100%;border-radius:8px;border:1px solid #eee}.post-detail-actions{display:flex;gap:.5rem;justify-content:flex-end;padding-top:1rem;border-top:1px solid #f0f0f0}.post-action-btn{padding:.4rem .875rem;border:1px solid #ddd;border-radius:6px;background:#fff;font-size:.8rem;font-weight:600;cursor:pointer;color:#555;transition:all .15s}.post-action-btn:hover{background:#f5f5f5}.post-action-btn.danger{color:#dc2626;border-color:#fca5a5}.post-action-btn.danger:hover{background:#fef2f2}.comments-section{margin-top:2rem}.comments-title{font-size:1rem;font-weight:700;color:#111;margin:0 0 1rem}.comments-title span{color:#888;font-weight:400}.comment{border-top:1px solid #f5f5f5;padding:.875rem 0}.comment.reply{padding-left:1.5rem;background:#fafafa;border-radius:6px;padding:.75rem .75rem .75rem 1.5rem;margin-top:.25rem}.comment-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.4rem}.comment-reply-mark{color:#aaa;font-size:.9rem}.comment-author{font-size:.85rem;font-weight:600;color:#333}.comment-date{font-size:.75rem;color:#aaa}.comment-actions{margin-left:auto;display:flex;gap:.4rem}.comment-reply-btn,.comment-delete-btn,.comment-delete-confirm,.comment-cancel{background:none;border:none;font-size:.75rem;cursor:pointer;color:#aaa;padding:0}.comment-reply-btn:hover{color:#4f46e5}.comment-delete-btn:hover{color:#dc2626}.comment-delete-confirm{color:#dc2626;font-weight:600}.comment-cancel{color:#999}.comment-body{font-size:.9rem;color:#333;line-height:1.6;margin:0}.reply-form{margin-top:.5rem;display:flex;flex-direction:column;gap:.375rem}.reply-form textarea{width:100%;padding:.5rem .75rem;border:1px solid #ddd;border-radius:8px;font-size:.875rem;font-family:inherit;resize:none;box-sizing:border-box}.reply-form textarea:focus{outline:none;border-color:#4f46e5}.reply-form-actions{display:flex;justify-content:flex-end;gap:.5rem}.reply-form-actions button{padding:.35rem .75rem;border-radius:6px;border:1px solid #ddd;background:#fff;font-size:.8rem;cursor:pointer;color:#555}.reply-submit{background:#4f46e5!important;color:#fff!important;border-color:#4f46e5!important}.reply-submit:disabled{opacity:.5;cursor:not-allowed!important}.comment-form{margin-top:1rem;display:flex;flex-direction:column;gap:.5rem}.comment-form textarea{width:100%;padding:.625rem .75rem;border:1px solid #ddd;border-radius:8px;font-size:.9rem;font-family:inherit;resize:none;box-sizing:border-box}.comment-form textarea:focus{outline:none;border-color:#4f46e5}.comment-submit{align-self:flex-end;padding:.5rem 1.25rem;border:none;border-radius:8px;background:#4f46e5;color:#fff;font-size:.875rem;font-weight:600;cursor:pointer}.comment-submit:disabled{opacity:.5;cursor:not-allowed}.dark .post-item:hover{background:#1a1a2e}.dark .post-item.pinned{background:#1e1a0e}.dark .post-title{color:#eee}.dark .post-form-card,.dark .post-detail{background:#1a1a1a;box-shadow:0 2px 12px #0006}.dark .post-form-label{color:#ccc}.dark .post-form-label input,.dark .post-form-label select,.dark .post-form-label textarea{background:#262626;border-color:#333;color:#eee}.dark .post-detail-title{color:#eee}.dark .post-detail-body,.dark .comment-body{color:#ccc}.dark .comment-author{color:#eee}.dark .community-tab{color:#888}.dark .community-tab:hover{color:#eee}.dark .community-tab.active{color:#818cf8;border-bottom-color:#818cf8}.dark .community-tabs{border-bottom-color:#333}.dark .post-item{border-bottom-color:#222}.dark .comment{border-top-color:#222}.dark .comment.reply{background:#1e1e1e}@media(max-width:640px){.community-wrap{padding:1rem 1rem 3rem}.post-item-right{display:none}.post-detail,.post-form-card{padding:1.25rem}}.rte-wrap{border:1px solid #ddd;border-radius:8px;overflow:hidden;background:#fff;transition:border-color .15s}.rte-wrap:focus-within{border-color:#4f46e5}.rte-toolbar{display:flex;align-items:center;flex-wrap:wrap;gap:2px;padding:6px 8px;background:#f8f8f8;border-bottom:1px solid #e5e7eb}.rte-btn{min-width:30px;height:28px;padding:0 6px;border:1px solid transparent;border-radius:5px;background:none;font-size:.85rem;cursor:pointer;color:#444;transition:all .1s;line-height:1}.rte-btn:hover{background:#ececec;border-color:#ddd}.rte-btn.active{background:#ede9fe;border-color:#c4b5fd;color:#4f46e5}.rte-divider{width:1px;height:20px;background:#e5e7eb;margin:0 4px}.rte-content{min-height:280px;padding:.75rem 1rem;font-size:.95rem;line-height:1.75;color:#333}.rte-content .tiptap{outline:none;min-height:260px}.rte-content h2{font-size:1.35rem;font-weight:700;margin:1rem 0 .5rem}.rte-content h3{font-size:1.1rem;font-weight:700;margin:.875rem 0 .375rem}.rte-content p{margin:0 0 .5rem}.rte-content ul,.rte-content ol{padding-left:1.5rem;margin:0 0 .5rem}.rte-content li{margin-bottom:.25rem}.rte-content strong{font-weight:700}.rte-content em{font-style:italic}.rte-content u{text-decoration:underline}.rte-content img{max-width:100%;border-radius:6px;margin:.5rem 0;display:block}.rte-content .tiptap p.is-editor-empty:first-child:before{content:attr(data-placeholder);color:#aaa;pointer-events:none;float:left;height:0}.dark .rte-wrap{border-color:#333;background:#262626}.dark .rte-toolbar{background:#1e1e1e;border-bottom-color:#333}.dark .rte-btn{color:#ccc}.dark .rte-btn:hover{background:#333;border-color:#444}.dark .rte-btn.active{background:#2e2a4e;border-color:#4f46e5;color:#818cf8}.dark .rte-divider{background:#333}.dark .rte-content{color:#ccc}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Pretendard,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background-color:#f8f9fa;color:#333;min-height:100vh}#root{min-height:100vh;display:flex;flex-direction:column}
