.space-slot{align-items:center;display:inline-flex;height:72px;justify-content:center;width:26px}.space-symbol{color:#777;font-size:16px}.filled-slot{align-items:center;display:inline-flex;height:72px;justify-content:center;margin:2px 4px;width:32px}.filled-jamo{color:#333;font-size:27px;font-weight:700}.jamo-slot{align-items:center;background-color:initial;border:none;cursor:pointer;display:inline-flex;height:72px;justify-content:center;margin:2px 0;padding:0;transition:all .2s ease;width:32px}.jamo-slot.group-end{margin-right:12px}.jamo-slot.completed,.jamo-slot.selected,.jamo-slot:hover{background-color:initial}.slot-content{align-items:center;border-radius:4px;display:flex;flex-direction:column;gap:4px;height:68px;justify-content:center;transition:background-color .2s ease;width:34px}.jamo-slot.selected .slot-content{background-color:#7ed321}.jamo-slot.wrong .slot-content{animation:slot-shake .35s ease-in-out;background-color:#ffd6d6}.jamo-slot.wrong .slot-underline{border-bottom-color:#d32f2f}.jamo-slot.wrong .user-jamo{color:#d32f2f}.user-jamo{color:#222;font-size:27px;font-weight:700;line-height:1;min-height:27px}.jamo-slot.completed .user-jamo{color:#2e7d32}.slot-underline{border-bottom:2px solid #222;height:0;width:24px}.jamo-number{color:#777;font-size:24px;font-weight:700;line-height:1;min-height:24px}@media (max-width:600px){.space-slot{height:56px;width:18px}.filled-slot{height:56px;margin:1px 2px;width:26px}.jamo-slot{height:56px;margin:1px 0;width:26px}.jamo-slot.group-end{margin-right:7px}.slot-content{gap:2px;height:52px;width:30px}.user-jamo{font-size:24px;min-height:24px}.slot-underline{width:20px}.jamo-number{font-size:20px;min-height:20px}}@keyframes slot-shake{0%{transform:translateX(0)}20%{transform:translateX(-3px)}40%{transform:translateX(3px)}60%{transform:translateX(-2px)}80%{transform:translateX(2px)}to{transform:translateX(0)}}.palette-container{background-color:#f5f5f5;border-top:1px solid #ddd;bottom:0;bottom:var(--ad-banner-offset,0);flex-shrink:0;overflow:hidden;padding:6px 8px;position:-webkit-sticky;position:sticky;z-index:20}.jamo-section{display:flex;flex-direction:column;gap:3px;margin-bottom:0}.jamo-row{align-items:stretch;display:flex}.jamo-row,.jamo-row-first{gap:3px;justify-content:center}.jamo-row-first .hint-side-button{margin-left:auto}.jamo-row-last{gap:3px;justify-content:center}.nav-arrow-left{margin-right:auto}.nav-arrow-right{margin-left:auto}.jamo-button{align-items:center;background-color:#fff;border:1px solid #ddd;border-radius:6px;cursor:pointer;display:flex;flex-basis:calc(14.28571% - 2.57143px);flex-grow:0;flex-shrink:0;height:52px;justify-content:center;min-width:0;transition:background-color .2s}.jamo-button:hover{background-color:#f0f0f0}.selected-jamo{background-color:#2196f3!important;border-color:#1976d2}.jamo-button-text{color:#333;font-size:21px;font-weight:700}.selected-jamo-text{color:#fff!important}.used-jamo{background-color:#4caf50!important;border-color:#388e3c}.used-jamo-text{color:#fff!important}.completed-jamo{border-color:#757575;cursor:not-allowed!important;opacity:.6}.completed-jamo,.completed-jamo:hover{background-color:#9e9e9e!important}.nav-arrow-button{align-items:center;background-color:#e8e8e8;border:1px solid #ccc;border-radius:6px;color:#444;cursor:pointer;display:flex;flex-basis:calc(18.57143% - 3.34286px);flex-grow:0;flex-shrink:0;font-size:22px;font-weight:700;height:52px;justify-content:center;min-width:0;transition:background-color .15s}.nav-arrow-button:active{background-color:#d0d0d0}.hint-side-button{align-items:center;background-color:#2f7edb;border:1px solid #1e5fa8;border-radius:10px;color:#fff;cursor:pointer;display:flex;flex-basis:calc(14.28571% - 2.57143px);flex-grow:0;flex-shrink:0;height:52px;justify-content:center;min-width:0;position:relative}.hint-side-button:disabled{background-color:#a9c4e7;border-color:#8fb1dc;cursor:not-allowed}.hint-side-button.empty{background-color:#2f7edb;border-color:#1e5fa8}.hint-icon{font-size:24px}.hint-count-badge{align-items:center;background:#2f7edb;border:2px solid #fff;border-radius:50%;color:#fff;display:flex;font-size:14px;font-weight:700;height:24px;justify-content:center;left:-8px;position:absolute;top:-8px;width:24px}@media (max-width:600px){.palette-container{padding:4px 6px calc(4px + env(safe-area-inset-bottom));padding-bottom:calc(4px + env(safe-area-inset-bottom) + var(--ad-banner-offset, 0px))}.jamo-section{margin-bottom:0}.jamo-button{border-radius:5px}.jamo-button-text{font-size:20px}.hint-icon{font-size:22px}.hint-count-badge{font-size:13px;height:22px;left:-7px;top:-7px;width:22px}}.tutorial-overlay{align-items:center;background-color:#000000b3;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.tutorial-modal{background:#fff;border-radius:20px;box-shadow:0 10px 30px #0000004d;max-height:85vh;max-width:400px;overflow-y:auto;padding:24px;position:relative;width:90%}.tutorial-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:25px}.tutorial-close{background:#e0e0e0;border:none;border-radius:8px;color:#555;cursor:pointer;flex-shrink:0;font-size:18px;line-height:1.6;padding:2px 10px}.tutorial-close:hover{background:#ccc}.tutorial-title{color:#333;font-size:22px;font-weight:700;margin:0}.tutorial-step{text-align:center}.tutorial-example{background:#f8f9fa;border-radius:10px;margin-bottom:25px;padding:20px}.tutorial-sentence{color:#333;font-size:24px;font-weight:700;letter-spacing:2px;margin-bottom:15px}.tutorial-jamo-grid{display:flex;flex-wrap:wrap;gap:5px;justify-content:center;margin-bottom:15px}.tutorial-jamo-item{align-items:center;display:flex;flex-direction:column;gap:2px}.tutorial-jamo{align-items:center;background:#fff;border:2px solid #ddd;border-radius:4px;display:inline-block;display:flex;font-size:14px;font-weight:700;height:25px;justify-content:center;width:25px}.tutorial-jamo.selected{background-color:#e8f5e8;border-color:#4caf50;color:#4caf50}.tutorial-jamo.filled{background-color:#4caf50;border-color:#4caf50;color:#fff}.tutorial-jamo.empty{background-color:#f9f9f9;border-color:#ddd;color:#999}.tutorial-linear{margin-bottom:10px}.tutorial-linear,.tutorial-numbers{display:flex;flex-wrap:wrap;gap:3px;justify-content:center}.number{align-items:center;color:#666;display:inline-block;display:flex;font-size:12px;height:20px;justify-content:center;width:25px}.number.highlighted{background:#4caf50;border-radius:4px;color:#fff;font-weight:700}.tutorial-palette{margin:15px 0}.tutorial-consonants,.tutorial-vowels{display:flex;flex-wrap:wrap;gap:5px;justify-content:center;margin:10px 0}.tutorial-key{align-items:center;background:#fff;border:2px solid #ddd;border-radius:6px;cursor:pointer;display:inline-block;display:flex;font-size:14px;font-weight:700;height:30px;justify-content:center;width:30px}.tutorial-key.highlighted{background-color:#e8f5e8;color:#4caf50}.tutorial-key.highlighted,.tutorial-key.used{background-color:#4caf50;border-color:#4caf50;color:#fff}.hint-palette{padding-bottom:48px;position:relative}.tutorial-hint-button{align-items:center;background:#2f7edb;border-radius:10px;bottom:6px;box-shadow:0 4px 10px #00000026;color:#fff;display:flex;height:44px;justify-content:center;position:absolute;right:8px;width:44px}.tutorial-hint-icon{font-size:20px;line-height:1}.tutorial-hint-count{align-items:center;background:#2f7edb;border:2px solid #fff;border-radius:50%;color:#fff;display:flex;font-size:11px;font-weight:700;height:18px;justify-content:center;left:-6px;position:absolute;top:-6px;width:18px}.space{width:15px}.tutorial-description{color:#666;font-size:16px;line-height:1.5;margin:0}.intro-description{text-align:left}.intro-title{color:#111;font-size:18px;font-weight:800;margin-bottom:6px;text-align:center}.intro-subtitle{color:#666;font-size:14px;font-style:italic;margin-bottom:14px;text-align:center}.intro-section{margin-bottom:12px}.intro-section-title{color:#111;font-weight:700;margin-bottom:4px}.intro-section-body{color:#444;font-size:14px;line-height:1.45}.compact-step .tutorial-example{margin-bottom:14px;padding:14px}.compact-step .tutorial-description{font-size:14px;line-height:1.4}.compact-step .intro-section{margin-bottom:8px}.compact-step .hint-palette{padding-bottom:42px}.text-only-step .tutorial-description{margin-top:10px}.intro-title-small{font-size:16px;margin-top:16px}.intro-accent .intro-section-body{color:#2f6fe4;font-weight:600}.tutorial-dots{display:flex;gap:8px;justify-content:center;margin:25px 0}.tutorial-dot{background:#ddd;border-radius:50%;cursor:pointer;height:10px;width:10px}.tutorial-dot.active{background:#4caf50}.tutorial-footer{text-align:center}.tutorial-button{background:#4caf50;border:none;border-radius:25px;color:#fff;cursor:pointer;font-size:18px;font-weight:700;padding:12px 40px;transition:background-color .3s}.tutorial-button:hover{background:#45a049}@media (max-width:480px){.tutorial-modal{margin:20px;padding:20px}.tutorial-sentence{font-size:20px}.tutorial-key{font-size:12px;height:25px;width:25px}}.lb-overlay{align-items:flex-end;background:#00000080;display:flex;inset:0;justify-content:center;padding-bottom:0;padding-bottom:var(--ad-banner-offset,0);position:fixed;z-index:1000}.lb-modal{background:#fff;border-radius:20px 20px 0 0;display:flex;flex-direction:column;max-height:75vh;max-width:480px;overflow:hidden;width:100%}.lb-header{align-items:center;border-bottom:1px solid #f0f0f0;display:flex;justify-content:space-between;padding:18px 20px 14px}.lb-title{color:#1a1a1a;font-size:18px;font-weight:700}.lb-close{background:none;border:none;color:#999;cursor:pointer;font-size:24px;line-height:1;padding:0 4px}.lb-list{flex:1 1;overflow-y:auto;padding:8px 0 16px}.lb-status{color:#999;font-size:15px;padding:40px 20px;text-align:center}.lb-row{align-items:center;border-bottom:1px solid #f8f8f8;display:flex;gap:12px;padding:12px 20px}.lb-row-top{background:#fafafa}.lb-row-me{background:#f0f6ff}.lb-rank{color:#666;flex-shrink:0;font-size:20px;font-weight:600;text-align:center;width:36px}.lb-row-top .lb-rank{font-size:22px}.lb-name{color:#1a1a1a;flex:1 1;font-size:15px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lb-row-me .lb-name:after{color:#4a90e2;content:" (나)";font-size:13px}.lb-level{color:#4a90e2;flex-shrink:0;font-size:14px;font-weight:700}.lb-preview{background:#f8f9fa;border-radius:12px;display:flex;flex-direction:column;gap:6px;margin:0 auto 12px;max-width:280px;padding:10px 16px;width:100%}.lb-preview-row{align-items:center;display:flex;gap:8px}.lb-preview-rank{flex-shrink:0;font-size:16px;width:24px}.lb-preview-name{color:#333;flex:1 1;font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lb-preview-level{color:#4a90e2;flex-shrink:0;font-size:13px;font-weight:700}.lb-open-button{align-items:center;background:none;border:1.5px solid #ddd;border-radius:20px;color:#555;cursor:pointer;display:flex;font-size:14px;gap:6px;margin:0 auto 16px;padding:8px 20px}.shop-overlay{align-items:flex-end;background:#00000080;display:flex;inset:0;justify-content:center;padding-bottom:0;padding-bottom:var(--ad-banner-offset,0);position:fixed;z-index:1100}.shop-modal{background:#fff;border-radius:20px 20px 0 0;display:flex;flex-direction:column;max-height:85vh;max-width:480px;overflow:hidden;width:100%}.shop-header{align-items:center;border-bottom:1px solid #f0f0f0;display:flex;flex-shrink:0;justify-content:center;padding:16px 20px 12px;position:relative}.shop-title{color:#222;font-size:18px;font-weight:800;letter-spacing:2px}.shop-close{align-items:center;background:#eee;border:none;border-radius:50%;color:#555;cursor:pointer;display:flex;font-size:14px;height:28px;justify-content:center;position:absolute;right:16px;top:50%;transform:translateY(-50%);width:28px}.shop-scroll{flex:1 1;gap:6px;overflow-y:auto;padding:12px 16px}.shop-scroll,.shop-section-header{display:flex;flex-direction:column}.shop-section-header{gap:2px;padding:14px 4px 6px}.shop-section-title{color:#333;font-size:15px;font-weight:700}.shop-section-desc{color:#888;font-size:12px}.shop-row{align-items:center;background:#f8f8f8;border-radius:14px;cursor:pointer;display:flex;gap:10px;padding:12px 14px;position:relative;transition:background .15s}.shop-row:active{background:#f0f0f0}.shop-row-disabled{cursor:default;opacity:.7}.shop-row-forever{background:linear-gradient(135deg,#f5f0ff,#ede8ff);border:1.5px solid #d4c8ff}.shop-row-icon{flex-shrink:0;font-size:22px;text-align:center;width:28px}.shop-row-info{display:flex;flex:1 1;flex-direction:column;gap:2px;min-width:0}.shop-row-name{color:#222;flex:1 1;font-size:14px;font-weight:600}.shop-row-desc{color:#888;font-size:12px}.shop-price-btn{background:#3b82f6;color:#fff}.shop-free-btn,.shop-price-btn{border-radius:10px;flex-shrink:0;font-size:13px;font-weight:700;padding:6px 12px;white-space:nowrap}.shop-free-btn{align-items:center;display:flex;justify-content:center;min-height:36px}.shop-free-btn.ready{background:#22c55e;color:#fff}.shop-free-btn.cooldown{background:#e5e7eb;color:#6b7280}.shop-badge{border-radius:20px;font-size:10px;font-weight:800;left:12px;letter-spacing:.5px;padding:2px 7px;position:absolute;top:-8px;z-index:1}.shop-badge.forever{background:#7c3aed;color:#fff}.shop-badge.best{background:#ef4444;color:#fff}.shop-footer{align-items:center;border-top:1px solid #f0f0f0;display:flex;flex-shrink:0;gap:8px;justify-content:center;padding:12px 16px}.shop-footer-link{background:none;border:none;color:#9ca3af;cursor:pointer;font-size:12px;padding:0;text-decoration:underline}.shop-footer-sep{color:#d1d5db;font-size:12px}.shop-open-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:14px;color:#fff;cursor:pointer;font-size:15px;font-weight:700;max-width:280px;padding:10px 24px;width:100%}.settings-overlay{align-items:center;background:#00000073;display:flex;inset:0;justify-content:center;position:fixed;z-index:300}.settings-modal{background:#fff;border-radius:20px;box-shadow:0 8px 32px #0000002e;display:flex;flex-direction:column;max-height:80vh;width:min(360px,92vw)}.settings-header{align-items:center;border-bottom:1px solid #00000014;display:flex;justify-content:space-between;padding:16px 20px 12px}.settings-title{color:#111;font-size:18px;font-weight:700}.settings-close{background:#e0e0e0;border:none;border-radius:8px;color:#555;cursor:pointer;font-size:18px;line-height:1.6;padding:2px 10px}.settings-scroll{flex:1 1;overflow-y:auto;padding:8px 0}.settings-section-label{color:#888;font-size:11px;font-weight:600;letter-spacing:.8px;padding:14px 20px 6px;text-transform:uppercase}.settings-row{align-items:center;background:#fff;border:none;border-bottom:1px solid #0000000f;color:#111;display:flex;gap:12px;padding:14px 20px;text-align:left;width:100%}.settings-row-btn{cursor:pointer}.settings-row-btn:active{background:#f5f5f5}.account-row{cursor:default}.settings-row-icon{flex-shrink:0;font-size:20px;text-align:center;width:28px}.settings-row-info{display:flex;flex:1 1;flex-direction:column;gap:2px}.settings-row-name{color:#111;flex:1 1;font-size:15px;font-weight:500}.settings-radio-label{align-items:center;color:#333;cursor:pointer;display:inline-flex;font-size:13px;gap:4px;margin-left:10px}.settings-radio-label input[type=radio]{accent-color:#2196f3;margin:0}.nickname-edit-icon{cursor:pointer;display:inline-block;font-size:14px;margin-left:4px;vertical-align:middle}.settings-row-sub{color:#888;font-size:12px}.settings-row-arrow{color:#bbb;font-size:20px;margin-left:auto}.settings-legal-links{align-items:center;display:flex;gap:8px;justify-content:center;padding:16px 20px 4px}.settings-legal-link{color:#aaa;cursor:pointer;font-size:11px;text-decoration:underline}.settings-legal-separator{color:#ccc;font-size:11px}.settings-version{border-top:1px solid #0000000f;color:#aaa;font-size:13px;padding:14px 16px;text-align:center}.nickname-edit-overlay{align-items:center;background:#00000080;display:flex;inset:0;justify-content:center;position:fixed;z-index:400}.nickname-edit-modal{background:#fff;border-radius:16px;box-shadow:0 8px 32px #0003;padding:24px 20px;width:min(300px,85vw)}.nickname-edit-title{color:#111;font-size:17px;font-weight:700;margin-bottom:16px;text-align:center}.nickname-edit-input{border:1.5px solid #ddd;border-radius:10px;box-sizing:border-box;font-size:15px;outline:none;padding:10px 12px;transition:border-color .2s;width:100%}.nickname-edit-input:focus{border-color:#4285f4}.nickname-edit-hint{color:#999;font-size:12px;margin-top:6px;text-align:right}.nickname-edit-actions{display:flex;gap:10px;margin-top:16px}.nickname-edit-btn{border:none;border-radius:10px;cursor:pointer;flex:1 1;font-size:15px;font-weight:600;padding:10px 0}.nickname-edit-btn.cancel{background:#e0e0e0;color:#555}.nickname-edit-btn.confirm{background:#4285f4;color:#fff}.container{background-color:#f2f2f7;display:flex;flex-direction:column;min-height:100vh}.header{background-color:#fff;border-bottom:1px solid #eee;padding:12px 16px}.top-bar{align-items:flex-start;display:flex;gap:12px;justify-content:space-between}.hearts-panel{min-width:140px}.heart-area,.hearts-panel{align-items:center;display:flex;gap:8px}.heart-area{background:#0000;border:none;height:44px;justify-content:flex-start;padding:0;position:relative;width:120px}.heart-icon-wrap{flex:0 0 auto;height:36px;position:relative;width:36px}.heart-area.clickable{cursor:pointer}.heart-area:disabled{cursor:default;opacity:1}.heart-icon{align-items:center;color:#e53935;display:inline-flex;height:100%;justify-content:center;width:100%}.heart-icon svg{fill:currentColor;display:block;height:100%;width:100%}.heart-count{align-items:center;background:#e53935;border:2px solid #fff;border-radius:50%;bottom:-6px;color:#fff;display:flex;font-size:12px;font-weight:700;height:20px;justify-content:center;position:absolute;right:-6px;width:20px}.heart-timer{background:#f1f1f1;border-radius:12px;color:#666;font-size:12px;font-weight:600;line-height:1;margin-left:-4px;min-width:78px;padding:6px 10px;text-align:center;white-space:nowrap}.heart-plus-btn{align-items:center;background:#2196f3;border:none;border-radius:50%;box-shadow:0 4px 10px #2196f359;color:#fff;cursor:pointer;display:flex;font-size:16px;font-weight:700;height:28px;justify-content:center;position:relative;width:28px;z-index:2}.heart-plus-btn:hover{background:#1e88e5}.heart-modal-overlay{align-items:center;background:#00000073;display:flex;inset:0;justify-content:center;position:fixed;z-index:60}.heart-modal{background:#f8f0f0;border-radius:20px;box-shadow:0 14px 30px #00000040;display:flex;flex-direction:column;gap:12px;padding:20px 18px 18px;position:relative;text-align:center;width:min(340px,90vw)}.heart-modal-close{background:#efe6e6;border:none;border-radius:50%;box-shadow:0 6px 12px #0000002e;color:#8c7070;cursor:pointer;font-size:22px;font-weight:700;height:36px;position:absolute;right:-12px;top:-14px;width:36px}.heart-modal-title{color:#8b6d6d;font-size:20px;font-weight:800}.heart-modal-card{background:#fff;border-radius:16px;box-shadow:inset 0 0 0 2px #f4dada;margin:4px 0 6px;padding:22px 16px;position:relative}.heart-modal-badge{background:#f04b4b;border-radius:10px;box-shadow:0 6px 12px #f04b4b59;color:#fff;font-size:16px;font-weight:800;left:14px;padding:6px 10px;position:absolute;top:12px}.heart-modal-icon{align-items:center;background:#f5eef0;border-radius:50%;box-shadow:inset 0 0 0 10px #f0e5e7;display:inline-flex;font-size:42px;height:84px;justify-content:center;width:84px}.heart-modal-actions{display:flex;flex-direction:column;gap:10px}.heart-modal-button{border:none;border-radius:14px;cursor:pointer;font-size:14px;font-weight:800;padding:12px 14px}.heart-modal-button:disabled{cursor:not-allowed;opacity:.65}.heart-modal-button.ad{background:#ffd45c;box-shadow:inset 0 -3px 0 #f2b948;color:#7a4a00}.heart-modal-button.purchase{background:#fff;border:2px solid #f0b2b2;color:#d33a3a}.hint-modal-overlay{align-items:center;background:#00000073;display:flex;inset:0;justify-content:center;position:fixed;z-index:60}.hint-modal{background:#f7ecec;border-radius:20px;box-shadow:0 14px 30px #00000040;display:flex;flex-direction:column;gap:12px;padding:18px 16px 16px;position:relative;width:min(360px,92vw)}.hint-modal-close{background:#efe6e6;border:none;border-radius:50%;box-shadow:0 6px 12px #0000002e;color:#8c7070;cursor:pointer;font-size:22px;font-weight:700;height:36px;position:absolute;right:-12px;top:-14px;width:36px}.hint-modal-title{color:#8b6d6d;font-size:20px;font-weight:800;text-align:center}.hint-modal-list{display:flex;flex-direction:column;gap:10px}.hint-modal-row{align-items:center;background:#efe3e3;border:none;border-radius:16px;cursor:pointer;display:flex;gap:10px;padding:10px 12px}.hint-modal-icon{align-items:center;background:#4b7bd3;border-radius:50%;box-shadow:inset 0 0 0 4px #3f6ec6;color:#fff;display:inline-flex;font-size:18px;height:34px;justify-content:center;width:34px}.hint-modal-text{color:#8b6d6d;flex:1 1;font-size:14px;font-weight:700}.hint-modal-action{border-radius:12px;font-size:14px;font-weight:800;min-width:74px;padding:8px 14px;text-align:center}.hint-modal-action.free{background:#1fab57;box-shadow:inset 0 -3px 0 #168948;color:#fff}.hint-modal-action.free.cooldown{background:#b7c2cc;box-shadow:inset 0 -3px 0 #9aa7b3;color:#fff}.hint-modal-action.price{background:#2e7be8;box-shadow:inset 0 -3px 0 #2567c2;color:#fff}.miss-panel{align-items:center;display:flex;flex:1 1;flex-direction:column;gap:6px;text-align:center}.miss-title{color:#222;font-size:16px;font-weight:600}.miss-circles{display:flex;gap:6px}.miss-circle{align-items:center;border:1.5px solid #111;border-radius:50%;color:#111;display:flex;font-size:12px;height:18px;justify-content:center;width:18px}.level-panel{align-items:flex-end;display:flex;flex-direction:column;gap:6px;min-width:80px}.header-actions{align-items:center;display:flex;gap:8px}.settings-wrapper{position:relative}.home-button,.ingame-shop-button,.settings-button{align-items:center;background-color:#fff;border:1px solid #e0e0e0;border-radius:10px;box-shadow:0 1px 3px #0000001a;color:#333;cursor:pointer;display:flex;height:44px;justify-content:center;padding:0;transition:background-color .2s;width:44px}.home-button svg,.settings-button svg{fill:#333;height:24px;width:24px}.ingame-shop-button{font-size:20px}.home-button:hover,.ingame-shop-button:hover,.settings-button:hover{background-color:#f5f5f5}.exit-confirm-overlay{align-items:center;background:#00000073;display:flex;inset:0;justify-content:center;position:fixed;z-index:50}.exit-confirm-modal{align-items:center;background:#fff;border-radius:16px;box-shadow:0 8px 32px #0003;display:flex;flex-direction:column;gap:12px;padding:28px 24px 20px;width:min(300px,88vw)}.exit-confirm-title{color:#222;font-size:20px;font-weight:700}.exit-confirm-desc{color:#555;font-size:15px;text-align:center}.exit-confirm-heart{color:#e53935}.exit-confirm-actions{display:flex;gap:10px;margin-top:8px;width:100%}.exit-confirm-btn{border:none;border-radius:10px;cursor:pointer;flex:1 1;font-size:16px;font-weight:700;padding:12px 0}.exit-confirm-btn.cancel{background-color:#eee;color:#444}.exit-confirm-btn.cancel:hover{background-color:#ddd}.exit-confirm-btn.confirm{background-color:#e53935;color:#fff}.exit-confirm-btn.confirm:hover{background-color:#c62828}.settings-menu{background:#fff;border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 6px 18px #00000026;padding:6px;position:absolute;right:0;top:36px;z-index:30}.settings-item{background:#0000;border:none;color:#222;cursor:pointer;font-size:14px;padding:8px 12px;white-space:nowrap}.settings-item:hover{background:#f3f3f3;border-radius:6px}.level-title{color:#222;font-size:16px;font-weight:600}.difficulty-pill{border-radius:6px;color:#fff;font-size:12px;font-weight:700;padding:4px 10px}.difficulty-pill.easy{background-color:#6abf4b}.difficulty-pill.medium{background-color:#ff9800}.difficulty-pill.hard{background-color:#f44336}.help-button{align-items:center;background-color:#4a4a4a;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:16px;font-weight:700;height:30px;justify-content:center;transition:background-color .2s;width:30px}.help-button:hover{background-color:#2f2f2f}.game-area{flex:1 1;min-height:0;overflow:visible;padding:16px}.section{margin-bottom:24px}.section-title{color:#333;font-size:16px;font-weight:700;margin-bottom:8px;margin-top:0}.linear-jamo-container{align-items:center;background-color:#fff;border:none;border-radius:8px;display:flex;flex-direction:row;flex-wrap:wrap;gap:6px;justify-content:center;min-height:80px;padding:12px}.completed-sentence{background-color:#e8f5e8;border:2px solid #4caf50;border-radius:8px;color:#2196f3;font-size:24px;font-weight:700;padding:16px;text-align:center}.completion-page{align-items:center;background-color:#fff;display:flex;flex:1 1;flex-direction:column;gap:12px;justify-content:center;min-height:100vh;padding:24px 16px}.completion-level{color:#222;font-size:16px;font-weight:600}.completion-title{color:#333;font-size:18px;font-weight:700}.completed-hint{color:#555;display:flex;flex-direction:column;font-size:21px;gap:4px;margin-top:10px;text-align:center}.completed-hint-category{color:#2f7edb;font-weight:700}.completed-hint-text{color:#666}.continue-button{background:#2f7edb;border:none;border-radius:8px;color:#fff;cursor:pointer;display:block;font-weight:700;margin:12px auto 0;padding:10px 18px}.continue-button:hover{background:#1e5fa8}.home-screen{flex:1 1;gap:36px;justify-content:center;padding:24px 20px 48px}.home-icon,.home-screen{align-items:center;display:flex;flex-direction:column}.home-icon{gap:12px}.home-icon-row{display:flex;gap:12px}.home-tile{align-items:center;background:#fff;border-radius:16px;border-top:4px solid #0000;box-shadow:0 2px 8px #0000001a;display:flex;flex-direction:column;gap:4px;height:90px;justify-content:center;width:80px}.home-tile-char{color:#1a1a1a;font-size:38px;font-weight:900;line-height:1}.home-tile-underline{background:#00000038;border-radius:2px;height:3px;width:52px}.home-tile-num{color:#444;font-size:20px;font-weight:700}.tile-blue{border-top-color:#4a9ebe}.tile-purple{border-top-color:#9b72b0}.tile-orange{border-top-color:#e88320}.tile-cyan{border-top-color:#50b8d8}.tile-teal{border-top-color:#42b49e}.tile-green{border-top-color:#6abf3a}.home-title{color:#222;font-size:24px;font-weight:700;letter-spacing:1px;text-align:center}.home-heart-btn{align-items:center;background:none;border:none;cursor:pointer;display:flex;gap:10px;padding:6px 8px}.home-heart-icon-wrap{flex:0 0 auto;height:36px;position:relative;width:36px}.home-heart-icon{align-items:center;color:#e53935;display:flex;height:36px;width:36px}.home-heart-icon svg{fill:currentColor;height:100%;width:100%}.home-heart-count-badge{background:#e53935;font-size:11px;min-width:18px;padding:0 2px;top:-6px}.home-heart-count-badge,.home-heart-plus-badge{align-items:center;border:2px solid #fff;border-radius:9px;color:#fff;display:flex;font-weight:700;height:18px;justify-content:center;line-height:1;position:absolute;right:-8px}.home-heart-plus-badge{background:#2196f3;bottom:-6px;font-size:13px;width:18px}.home-heart-full{color:#e53935;font-size:14px;font-weight:700}.home-heart-timer{color:#888;font-size:13px;font-weight:600;white-space:nowrap}.home-tiles-divider{background:#e0e0e0;border-radius:1px;height:1.5px;margin:4px auto 0;max-width:280px;width:75%}.home-buttons-row{display:flex;gap:12px;max-width:280px;width:100%}.lb-open-button,.shop-open-button{align-items:center;background:#fff;border:1.5px solid #ddd;border-radius:12px;box-shadow:0 1px 4px #00000012;color:#333;cursor:pointer;display:flex;flex:1 1;font-size:16px;font-weight:600;height:48px;justify-content:center;padding:0}.lb-open-button:active,.shop-open-button:active{background:#f5f5f5}.start-button{align-items:center;border:none;border-radius:12px;color:#fff;cursor:pointer;display:flex;flex-direction:column;font-weight:700;gap:2px;min-width:180px;padding:14px 40px}.start-button.easy{background-color:#6abf4b}.start-button.medium{background-color:#ff9800}.start-button.hard{background-color:#f44336}.start-button:disabled{background-color:#aaa;cursor:not-allowed}.start-button-label{font-size:20px}.start-button-level{font-size:13px;opacity:.85}.gameover-overlay{align-items:center;background:#00000073;display:flex;inset:0;justify-content:center;position:fixed;z-index:50}.gameover-modal{align-items:center;background:#fff7f7;border-radius:16px;box-shadow:0 10px 30px #0003;display:flex;flex-direction:column;gap:10px;padding:20px 18px;position:relative;text-align:center;width:min(320px,90vw)}.gameover-close{background:none;border:none;color:#aaa;cursor:pointer;font-size:18px;line-height:1;padding:4px 6px;position:absolute;right:12px;top:10px}.gameover-close:hover{color:#555}.gameover-title{color:#6b4b4b;font-size:18px;font-weight:700}.gameover-subtitle{color:#8a6b6b;font-size:14px}.gameover-button{border:none;border-radius:12px;cursor:pointer;font-weight:700;padding:12px 14px;width:100%}.gameover-button.retry{background:#f2e7e7;border:1px solid #d7c3c3;color:#7a5a5a}.gameover-button.revive{background:#ffd36a;border:1px solid #f0b94a;color:#7a4a00;cursor:not-allowed;opacity:.7}.message{border-radius:6px;font-size:16px;font-weight:700;margin:8px 0;padding:12px 16px;text-align:center}.toast-message{box-shadow:0 6px 18px #00000026;left:50%;margin:0;position:fixed;top:72px;transform:translateX(-50%);width:min(320px,calc(100vw - 24px));z-index:40}.error-message{background-color:#ffebee;border:1px solid #f44336;color:#f44336}.info-message{background-color:#fff3e0;border:1px solid #ff9800;color:#ff9800}.hint-section{background-color:#f0f8ff;border:2px solid #2196f3;border-radius:8px;margin-bottom:16px;padding:16px;text-align:center}.hint-category{color:#1976d2;font-size:18px;font-weight:700;margin-bottom:8px}.hint-text{color:#555;font-size:14px;font-style:italic}.color-legend{background-color:#f8f9fa;border-top:1px solid #dee2e6;color:#6c757d;display:flex;flex-wrap:wrap;font-size:12px;gap:40px;justify-content:center;padding:16px}.legend-section{display:flex;flex-direction:column;gap:8px}.legend-title{color:#495057;font-weight:700;margin-bottom:4px;text-align:center}.legend-items{display:flex;flex-wrap:wrap;gap:16px;justify-content:center}.legend-item{align-items:center;display:flex;gap:6px}.legend-color{border:1px solid;border-radius:3px;height:16px;width:16px}.legend-color.chosung{background-color:#fff3e0;border-color:#ff5722}.legend-color.jungsung{background-color:#e3f2fd;border-color:#2196f3}.legend-color.jongsung{background-color:#f3e5f5;border-color:#9c27b0}.legend-color.used{background-color:#4caf50;border-color:#388e3c}.legend-color.completed{background-color:#9e9e9e;border-color:#757575}.input-help{background-color:#f8f9fa;border:1px solid #dee2e6;border-radius:6px;color:#495057;font-size:14px;padding:12px;text-align:center}.hint-row,.input-help{margin-top:12px}.preview-box{align-items:center;background:#e6e6e6;border-radius:6px;color:#444;display:flex;font-size:21px;gap:6px;margin:10px auto 0;max-width:100%;padding:6px 10px;text-align:center;width:-webkit-fit-content;width:fit-content}.preview-label{color:#555;font-weight:600}.preview-text{font-weight:700;letter-spacing:2px;white-space:nowrap}.hint-row-inner{align-items:center;display:flex;flex-direction:row;gap:10px;justify-content:flex-end}.hint-row-inner.hint-revealed-inner{align-items:flex-end;flex-direction:column;gap:6px}.hint-category-label{color:#222;font-size:21px}.hint-actions,.magnifier-button{align-items:center;display:flex}.magnifier-button{background-color:#2f7edb;border:1px solid #1e5fa8;border-radius:6px;color:#fff;cursor:pointer;height:54px;justify-content:center;position:relative;width:66px}.magnifier-button:disabled{background-color:#a9c4e7;border-color:#8fb1dc;cursor:not-allowed}.magnifier-icon{font-size:27px}.magnifier-count{align-items:center;background:#2f7edb;border:2px solid #fff;border-radius:50%;color:#fff;display:flex;font-size:14px;font-weight:700;height:24px;justify-content:center;left:-8px;position:absolute;top:-8px;width:24px}.hint-detail-pill{background-color:#69a84a;border-radius:6px;color:#fff;font-size:20px;font-weight:600;padding:6px 10px}.puzzle-section{background-color:#fff;border:none;border-radius:12px;box-shadow:none;margin:6px 0;padding:8px}.puzzle-header{margin-bottom:16px;text-align:center}.puzzle-title{color:#1976d2;font-size:24px;font-weight:700;margin:0 0 8px}.puzzle-instruction{color:#666;font-size:14px;font-style:italic;margin:0}.puzzle-board{align-items:center;background-color:#fff;border:1px solid #e6e6e6;border-radius:8px;display:flex;justify-content:center;min-height:120px;padding:12px}@media (max-width:600px){.container{height:100dvh;min-height:100dvh;overflow:hidden}.header{padding:4px 8px;position:-webkit-sticky;position:sticky;top:0;z-index:20}.top-bar{gap:6px}.hearts-panel{gap:4px;min-width:112px}.heart-area{gap:6px;height:36px;width:100px}.heart-icon-wrap{height:28px;width:28px}.heart-timer{font-size:11px;min-width:66px;padding:4px 8px}.heart-plus-btn{height:26px;width:26px}.level-panel,.miss-panel{gap:4px}.level-title,.miss-title{font-size:13px}.miss-circle{font-size:10px;height:15px;width:15px}.difficulty-pill{font-size:11px;padding:3px 8px}.header-actions{gap:6px}.settings-item.auth-login,.settings-item.auth-logout{display:none}.game-area{overflow-y:auto;overscroll-behavior:contain;padding:4px 6px 6px}.container.hint-revealed .game-area{overflow-y:hidden}.section{margin-bottom:6px}.puzzle-section{margin:2px 0;padding:2px}.puzzle-board{min-height:70px;padding:6px}.linear-jamo-container{gap:4px;min-height:64px;padding:6px}.preview-box{font-size:18px;margin-top:4px;padding:4px 8px}.home-screen{gap:28px;padding:16px 16px 40px}.home-tile{border-radius:14px;height:76px;width:68px}.home-tile-char{font-size:32px}.home-tile-underline{width:44px}.home-tile-num{font-size:17px}.home-icon,.home-icon-row{gap:10px}.home-title{font-size:21px}.start-button{border-radius:14px;min-width:200px;padding:16px 48px}.start-button-label{font-size:22px}.start-button-level{font-size:14px}.hint-row{margin-top:6px}.hint-row-inner{gap:6px}.hint-category-label{font-size:18px}.hint-detail-pill{font-size:18px;padding:4px 8px}.magnifier-button{height:45px;width:57px}.magnifier-icon{font-size:24px}.toast-message{top:60px}}.jamo-legend-compact{background-color:#f8f9fa;border:1px solid #dee2e6;border-radius:6px;padding:12px}.legend-row{align-items:center;display:flex;gap:12px;margin-bottom:8px}.legend-title-small{color:#495057;font-size:13px;font-weight:700;min-width:80px}.legend-items-horizontal{display:flex;flex-wrap:wrap;gap:16px}.input-help-compact{border-top:1px solid #dee2e6;color:#666;font-size:12px;padding-top:8px;text-align:left}.help-section{background-color:#f8f9fa;border-left:3px solid #2196f3;border-radius:4px;margin-bottom:8px;padding:6px 8px}.help-section:last-child{margin-bottom:0}.help-section strong{color:#1976d2;display:inline-block;margin-bottom:2px}.bottom-legend{background-color:#f8f9fa;border-top:1px solid #dee2e6;display:flex;font-size:12px;justify-content:center;padding:12px 16px}.bottom-legend .legend-section{align-items:center;display:flex;gap:12px}.App{background-color:#f5f5f5;display:flex;flex-direction:column;min-height:100vh;padding-bottom:0;padding-bottom:var(--ad-banner-offset,0)}.App.platform-mobile{height:100dvh;min-height:100dvh;overflow:hidden}*{box-sizing:border-box}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}body,html{height:100%}body.mobile-app{overflow:hidden}#root{height:100%;min-height:100vh}body.mobile-app #root{overflow:visible}