*{margin:0;padding:0;box-sizing:border-box}:root,[data-theme=dark]{--bg-primary: #0a0e1a;--bg-secondary: #111827;--bg-card: #1a1f35;--bg-card-hover: #222845;--border: #2a3050;--text-primary: #e2e8f0;--text-secondary: #94a3b8;--text-muted: #64748b;--accent-blue: #3b82f6;--accent-purple: #8b5cf6;--accent-gradient: linear-gradient(135deg, #3b82f6, #8b5cf6);--accent-gold: #f59e0b;--accent-teal: #2dd4bf;--success: #10b981;--danger: #ef4444;--progress-track: #1e2540;--progress-fill: linear-gradient(90deg, #3b82f6, #8b5cf6);--progress-complete: linear-gradient(90deg, #10b981, #34d399);--progress-gold: linear-gradient(90deg, #f59e0b, #fbbf24)}[data-theme=light]{--bg-primary: #f0f2f5;--bg-secondary: #ffffff;--bg-card: #ffffff;--bg-card-hover: #f5f5ff;--border: #d1d5e0;--text-primary: #1a1a2e;--text-secondary: #4a5568;--text-muted: #8892a4;--accent-blue: #2563eb;--accent-purple: #7c3aed;--accent-gradient: linear-gradient(135deg, #2563eb, #7c3aed);--accent-gold: #d97706;--accent-teal: #0d9488;--success: #059669;--danger: #dc2626;--progress-track: #e2e8f0;--progress-fill: linear-gradient(90deg, #2563eb, #7c3aed);--progress-complete: linear-gradient(90deg, #059669, #10b981);--progress-gold: linear-gradient(90deg, #d97706, #f59e0b)}body{font-family:Pretendard,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg-primary);color:var(--text-primary);min-height:100vh;line-height:1.5;transition:background .3s,color .3s}#root{max-width:960px;margin:0 auto;padding:0;min-height:100vh}.app{min-height:100vh;display:flex;flex-direction:column;background:var(--bg-primary);transition:background .3s}.app-header{display:flex;justify-content:space-between;align-items:center;padding:20px 20px 12px;border-bottom:1px solid var(--border);background:var(--bg-secondary)}.logo-area{display:flex;align-items:baseline;gap:12px}.logo{font-size:1.8rem;font-weight:800;letter-spacing:-1px;background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.logo-2{color:var(--accent-blue);-webkit-text-fill-color:var(--accent-blue);font-size:2rem}.logo-sub{font-size:.75rem;color:var(--text-muted);letter-spacing:.5px}.version-wrap{position:relative;display:inline-flex;align-items:center;gap:6px}.last-saved{font-size:.6rem;color:var(--text-muted);font-weight:400;letter-spacing:.3px}.logo-version{font-size:.65rem;color:var(--accent-purple);background:#8b5cf61f;padding:1px 6px;border-radius:4px;font-weight:600;letter-spacing:.5px;cursor:pointer}.patch-notes-backdrop{position:fixed;inset:0;z-index:59}.patch-notes{display:block;position:absolute;top:calc(100% + 8px);left:0;right:auto;background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:12px 14px;width:260px;max-width:calc(100vw - 24px);max-height:70vh;overflow-y:auto;box-shadow:0 4px 20px #0000004d;z-index:60}.patch-notes strong{display:block;font-size:.78rem;color:var(--accent-purple);margin-bottom:8px}.patch-notes ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:4px}.patch-notes li{font-size:.72rem;color:var(--text-secondary);line-height:1.5;padding-left:12px;position:relative}.patch-notes li:before{content:"·";position:absolute;left:0;color:var(--accent-blue);font-weight:700}.header-actions{display:flex;gap:8px;align-items:center}.theme-btn,.settings-btn{background:transparent;border:1px solid var(--border);color:var(--text-secondary);width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;padding:0}.theme-btn:hover{border-color:var(--accent-gold);color:var(--accent-gold);background:#f59e0b1a}.settings-btn:hover{border-color:var(--accent-blue);color:var(--accent-blue);background:#3b82f61a}.lang-switcher{display:flex;border:1px solid var(--border);border-radius:8px;overflow:hidden;height:32px}.lang-btn{background:transparent;color:var(--text-dim);border:none;padding:0 10px;font-size:.7rem;font-weight:600;cursor:pointer;transition:all .2s;letter-spacing:.5px;position:relative}.lang-btn:not(:last-child):after{content:"";position:absolute;right:0;top:20%;height:60%;width:1px;background:var(--border)}.lang-btn:hover{background:#8b5cf614;color:var(--text)}.lang-btn.active{background:var(--accent-purple);color:#fff}.lang-btn.active:after{display:none}.lang-btn.active+.lang-btn:after{display:none}.content-nav-bar{display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 16px;background:linear-gradient(135deg,#6c8cff14,#a882ff14);border-bottom:1px solid var(--border);flex-wrap:wrap}.content-nav-hero{padding:8px 18px;border-radius:8px;font-size:.88rem;font-weight:700;color:var(--accent-blue);text-decoration:none;background:#3b82f61a;border:1px solid rgba(59,130,246,.2);transition:background .15s,transform .1s}.content-nav-hero:hover{background:#3b82f62e}.content-nav-hero:active{transform:scale(.98)}.content-nav-divider{width:1px;height:20px;background:var(--border);margin:0 4px}.content-nav-link{padding:8px 18px;border-radius:8px;font-size:.82rem;font-weight:600;color:var(--text-secondary);text-decoration:none;transition:background .15s,color .15s}.content-nav-link:hover{background:#8b5cf61a;color:var(--text-primary)}.image-guide-overlay{position:fixed;inset:0;background:#000000b3;z-index:9999;display:flex;align-items:center;justify-content:center;padding:16px}.image-guide-modal{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;max-width:720px;width:100%;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.image-guide-header{display:flex;align-items:center;padding:14px 20px;border-bottom:1px solid var(--border);gap:8px}.image-guide-header h3{font-size:.95rem;font-weight:700;flex:1;margin:0}.image-guide-page{font-size:.75rem;color:var(--text-muted);white-space:nowrap}.image-guide-body{flex:1;overflow-y:auto;padding:16px 20px;display:flex;flex-direction:column;gap:12px}.image-guide-img{width:100%;border-radius:8px;border:1px solid var(--border);object-fit:contain}.image-guide-desc{font-size:.85rem;line-height:1.6;color:var(--text-primary);margin:0}.image-guide-nav{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;border-top:1px solid var(--border);gap:12px}.image-guide-btn{background:var(--bg-secondary);border:1px solid var(--border);border-radius:6px;padding:6px 16px;font-size:.8rem;color:var(--text-primary);cursor:pointer;white-space:nowrap;transition:opacity .15s}.image-guide-btn:disabled{opacity:.3;cursor:not-allowed}.image-guide-btn:not(:disabled):hover{opacity:.7}.image-guide-dots{display:flex;gap:6px;justify-content:center;flex:1}.image-guide-dot{width:8px;height:8px;border-radius:50%;border:none;background:var(--text-muted);opacity:.3;cursor:pointer;padding:0;transition:opacity .15s}.image-guide-dot.active{opacity:1;background:var(--accent, #6c8cff)}@media(max-width:480px){.image-guide-overlay{padding:8px}.image-guide-modal{max-height:92vh}.image-guide-header{padding:10px 14px}.image-guide-header h3{font-size:.85rem}.image-guide-body{padding:12px 14px}.image-guide-nav{padding:10px 14px}.image-guide-btn{padding:6px 10px;font-size:.75rem}}.character-tabs{display:flex;gap:0;padding:0 16px;background:var(--bg-secondary);border-bottom:1px solid var(--border);overflow-x:auto;-webkit-overflow-scrolling:touch}.character-tabs::-webkit-scrollbar{display:none}.tab-btn{padding:10px 20px;border:none;background:transparent;color:var(--text-muted);font-size:.9rem;font-weight:600;cursor:pointer;border-bottom:2px solid transparent;transition:all .2s;white-space:nowrap;font-family:inherit}.tab-btn:hover{color:var(--text-secondary);background:#ffffff08}.tab-btn.active{color:var(--accent-blue);border-bottom-color:var(--accent-blue)}.tab-wrap{position:relative;display:flex;align-items:center;touch-action:none}.tab-wrap .tab-btn{padding-right:22px}.tab-delete-btn{position:absolute;right:2px;top:50%;transform:translateY(-50%);width:18px;height:18px;border:none;background:transparent;color:var(--text-muted);font-size:.85rem;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:50%;opacity:0;transition:all .15s;padding:0;line-height:1}.tab-wrap:hover .tab-delete-btn,.tab-wrap.active .tab-delete-btn{opacity:.6}.tab-delete-btn:hover{opacity:1!important;color:var(--accent-red, #ef4444);background:#ef44441a}.tab-edit-input{padding:8px 12px;border:none;border-bottom:2px solid var(--accent-blue);background:var(--bg-primary);color:var(--text-primary);font-size:.9rem;font-weight:600;font-family:inherit;outline:none;width:80px;text-align:center}.add-btn{color:var(--accent-purple);font-size:1.2rem;font-weight:700;padding:10px 16px}.add-btn:hover{color:var(--accent-blue);background:#8b5cf61a}.progress-overview{padding:16px 20px 8px;display:flex;flex-direction:column;gap:8px}.progress-bar-container{width:100%}.progress-bar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.progress-label{font-size:.8rem;color:var(--text-secondary);font-weight:500}.progress-value{font-size:.8rem;color:var(--text-primary);font-weight:700;font-variant-numeric:tabular-nums}.progress-bar-track{width:100%;height:6px;background:var(--progress-track);border-radius:3px;overflow:hidden}.progress-bar-fill{height:100%;background:var(--progress-fill);border-radius:3px;transition:width .4s cubic-bezier(.4,0,.2,1);min-width:0}.progress-bar-fill.complete{background:var(--progress-complete)}.progress-bar-container.gold .progress-bar-fill,.progress-bar-container.gold .progress-bar-fill.complete{background:var(--progress-gold)}.main-content{flex:1;padding:8px 16px 16px;display:flex;flex-direction:column;gap:16px}.main-column{display:flex;flex-direction:column;gap:16px}@media(min-width:768px){.main-content{flex-direction:row;align-items:flex-start}.main-column,.main-content>.task-section{flex:1;min-width:0}}.guide-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:300;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);padding:20px}.guide-popup{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;width:100%;max-width:520px;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 8px 40px #0006;animation:guidePopIn .2s ease-out}@keyframes guidePopIn{0%{opacity:0;transform:scale(.95) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.guide-popup-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}.guide-popup-header h3{font-size:1rem;font-weight:700;color:var(--text-primary);margin:0}.guide-close-btn{width:32px;height:32px;border-radius:8px;border:none;background:transparent;color:var(--text-muted);font-size:1.4rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s}.guide-close-btn:hover{background:#8080801f;color:var(--text-primary)}.guide-popup-body{padding:16px 20px 20px;overflow-y:auto;-webkit-overflow-scrolling:touch}.guide-list{list-style:none;display:flex;flex-direction:column;gap:8px;padding:0;margin:0}.guide-list li{font-size:.82rem;color:var(--text-secondary);line-height:1.55;padding-left:16px;position:relative}.guide-list li:before{content:"•";position:absolute;left:0;color:var(--accent-purple);font-weight:700}.guide-list li strong{color:var(--text-primary);font-weight:600}.guide-section-title{font-size:.85rem;font-weight:700;color:var(--accent-blue);margin:14px 0 6px;padding-bottom:4px;border-bottom:1px solid var(--border)}.guide-section-title:first-child{margin-top:0}.guide-disclaimer{margin-top:12px;padding-top:12px;border-top:1px solid var(--border);font-size:.78rem;color:var(--text-muted);line-height:1.5;text-align:center}@media(max-width:480px){.guide-overlay{padding:12px}.guide-popup{max-height:85vh}.guide-popup-header{padding:12px 16px}.guide-popup-body{padding:12px 16px 16px}.guide-list li{font-size:.78rem}}.task-section{background:var(--bg-card);border-radius:12px;border:1px solid var(--border);padding:16px;display:flex;flex-direction:column;gap:12px}.section-header{display:flex;justify-content:space-between;align-items:center}.toggle-header{cursor:pointer;-webkit-user-select:none;user-select:none}.toggle-header:hover{opacity:.8}.toggle-arrow{display:inline-block;margin-left:6px;font-size:.85em;transition:transform .2s;color:var(--text-muted)}.toggle-arrow.open{transform:rotate(90deg)}.toggle-section{gap:0}.toggle-section>:not(.section-header){margin-top:12px}.section-header h2{font-size:1.05rem;font-weight:700;color:var(--text-primary)}.reset-info{font-size:.7rem;color:var(--text-muted);background:#8080801a;padding:3px 8px;border-radius:4px}.task-list{display:flex;flex-direction:column;gap:4px}.task-item{display:flex;justify-content:space-between;align-items:center;padding:10px 12px 12px;background:var(--bg-secondary);border-radius:8px;border:1px solid transparent;transition:background .2s,border-color .2s,opacity .2s;cursor:default;position:relative;flex-wrap:wrap;overflow:hidden}.task-progress-track{position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--progress-track);border-radius:0 0 8px 8px}.task-progress-fill{height:100%;border-radius:0 0 0 8px;background:var(--progress-fill);opacity:.6;transition:width .3s ease}.task-progress-fill.complete{background:var(--progress-complete);border-radius:0 0 8px 8px;opacity:.7}.task-item:hover{background:var(--bg-card-hover);border-color:var(--border)}.task-item.done{opacity:.55}.task-item.done .task-name{text-decoration:line-through;color:var(--text-muted)}.drag-handle{color:var(--text-muted);font-size:.75rem;cursor:grab;margin-right:8px;opacity:.4;transition:opacity .15s;-webkit-user-select:none;user-select:none;flex-shrink:0;padding:4px;touch-action:none}.task-item:hover .drag-handle{opacity:.7}.drag-handle:active{cursor:grabbing;opacity:.9}.task-check-toggle{display:flex;align-items:center;cursor:pointer;flex-shrink:0}.task-check-toggle input[type=checkbox]{appearance:none;-webkit-appearance:none;width:18px;height:18px;border:2px solid var(--border);border-radius:4px;background:transparent;cursor:pointer;position:relative;transition:all .2s;flex-shrink:0}.task-check-toggle input[type=checkbox]:checked{background:var(--accent-gradient);border-color:var(--accent-blue)}.task-check-toggle input[type=checkbox]:checked:after{content:"✓";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:12px;font-weight:700}.task-name{font-size:.9rem;font-weight:500;color:var(--text-primary);display:flex;align-items:center;gap:6px;flex-wrap:wrap;flex:1;min-width:0}.task-note{font-size:.68rem;color:var(--accent-purple);background:#8b5cf61f;padding:1px 5px;border-radius:3px;white-space:nowrap}.task-right{display:flex;align-items:center;gap:6px;flex-shrink:0}.task-controls{display:flex;align-items:center;gap:4px}.counter-btn{width:28px;height:28px;border-radius:6px;border:1px solid var(--border);background:var(--bg-primary);color:var(--text-primary);font-size:1rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;padding:0;line-height:1;font-family:inherit}.counter-btn:hover:not(:disabled){border-color:var(--accent-blue);background:#3b82f626}.counter-btn:disabled{opacity:.3;cursor:not-allowed}.counter-btn.plus:hover:not(:disabled){border-color:var(--success);background:#10b98126;color:var(--success)}.counter-btn.minus:hover:not(:disabled){border-color:var(--danger);background:#ef44441a;color:var(--danger)}.counter-value{font-size:.85rem;font-weight:600;min-width:85px;text-align:center;font-variant-numeric:tabular-nums;color:var(--text-primary)}.remove-task-btn{width:22px;height:22px;border-radius:4px;border:none;background:transparent;color:var(--text-muted);font-size:.7rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;padding:0;flex-shrink:0;opacity:0;pointer-events:none}.task-item:hover .remove-task-btn{opacity:1;pointer-events:auto}.remove-task-btn:hover{color:var(--danger);background:#ef44441f}.custom-add-btn{width:100%;padding:10px;border-radius:8px;border:1px dashed var(--accent-purple);background:#8b5cf60f;color:var(--accent-purple);font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s;font-family:inherit}.custom-add-btn:hover{border-color:var(--accent-blue);color:var(--accent-blue);background:#3b82f61f;border-style:solid}.custom-add-panel{display:flex;flex-direction:column;gap:8px}.custom-add-form{display:flex;flex-direction:column;gap:6px;padding:10px;background:var(--bg-secondary);border-radius:8px;border:1px solid var(--border)}.custom-row{display:flex;flex-wrap:wrap;gap:6px}.custom-input{flex:1;min-width:80px;padding:6px 10px;border-radius:6px;border:1px solid var(--border);background:var(--bg-primary);color:var(--text-primary);font-size:.85rem;font-family:inherit;outline:none}.custom-input:focus{border-color:var(--accent-blue);box-shadow:0 0 0 2px #3b82f633}.custom-input-num{width:56px;min-width:56px;flex:0}.memo-type-row{display:flex;align-items:center;gap:8px}.memo-type-btns{display:flex;gap:0;border:1px solid var(--border);border-radius:6px;overflow:hidden}.memo-type-btn{padding:6px 12px;border:none;background:var(--bg-primary);color:var(--text-secondary);font-size:.82rem;font-family:inherit;cursor:pointer;transition:background .15s,color .15s;white-space:nowrap}.memo-type-btn:not(:last-child){border-right:1px solid var(--border)}.memo-type-btn.active{background:var(--accent-purple);color:#fff}.memo-type-btn:not(.active):hover{background:var(--bg-card-hover)}.custom-form-actions{display:flex;gap:6px}.custom-confirm-btn{padding:6px 14px;border-radius:6px;border:1px solid var(--accent-purple);background:#8b5cf626;color:var(--accent-purple);font-size:.8rem;font-weight:600;cursor:pointer;font-family:inherit;transition:all .15s}.custom-confirm-btn:hover{background:#8b5cf640}.custom-cancel-btn{padding:6px 14px;border-radius:6px;border:1px solid var(--border);background:transparent;color:var(--text-muted);font-size:.8rem;font-weight:500;cursor:pointer;font-family:inherit;transition:all .15s}.custom-cancel-btn:hover{border-color:var(--text-muted);color:var(--text-secondary)}.custom-suggestions{padding:8px 10px;background:#8b5cf60d;border:1px solid rgba(139,92,246,.15);border-radius:8px}.suggestions-label{font-size:.7rem;color:var(--text-muted);display:block;margin-bottom:6px}.suggestions-list{display:flex;flex-wrap:wrap;gap:4px}.suggestion-chip{padding:3px 8px;border-radius:4px;border:1px solid var(--accent-purple);background:#8b5cf61a;color:var(--accent-purple);font-size:.72rem;font-weight:500;cursor:pointer;font-family:inherit;transition:all .15s;white-space:nowrap}.suggestion-chip:hover{background:#8b5cf638}.suggestion-max{color:var(--text-muted);margin-left:2px;font-size:.65rem}.alarm-section .section-header h2{background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.alarm-list{display:flex;flex-direction:column;gap:4px}.alarm-item{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;background:var(--bg-secondary);border-radius:8px;border:1px solid transparent;transition:background .2s,border-color .2s,opacity .2s}.alarm-item:hover{background:var(--bg-card-hover);border-color:var(--border)}.alarm-item.alarm-off{opacity:.45}.alarm-info{display:flex;align-items:center;gap:8px;flex:1;min-width:0;flex-wrap:wrap}.alarm-name{font-size:.9rem;font-weight:500;color:var(--text-primary)}.alarm-schedule{font-size:.68rem;color:var(--accent-purple);background:#8b5cf61f;padding:1px 5px;border-radius:3px;white-space:nowrap}.alarm-threshold-wrap{display:flex;align-items:center;gap:4px}.alarm-threshold-input{width:52px;padding:1px 4px;border:1px solid var(--border);border-radius:4px;background:var(--bg-secondary);color:var(--text-primary);font-size:.72rem;text-align:center}.alarm-threshold-input:focus{outline:none;border-color:var(--accent-purple)}.alarm-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.alarm-remove-btn{opacity:0;pointer-events:none}.alarm-item:hover .alarm-remove-btn{opacity:1;pointer-events:auto}.alarm-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}.alarm-toggle{position:relative;display:inline-block;width:36px;height:20px;cursor:pointer;flex-shrink:0;-webkit-tap-highlight-color:transparent}.alarm-toggle input{position:absolute;width:100%;height:100%;opacity:0;z-index:1;cursor:pointer;margin:0}.toggle-slider{position:absolute;inset:0;background:var(--border);border-radius:10px;transition:background .2s}.toggle-slider:before{content:"";position:absolute;width:16px;height:16px;left:2px;bottom:2px;background:#fff;border-radius:50%;transition:transform .2s}.alarm-toggle input:checked+.toggle-slider{background:var(--accent-blue)}.alarm-toggle input:checked+.toggle-slider:before{transform:translate(16px)}.alarm-time-input{width:44px!important;min-width:44px!important;flex:0!important;text-align:center;font-size:.82rem;padding:4px}.alarm-colon{font-weight:600;color:var(--text-muted);font-size:.9rem}.alarm-unit{font-size:.75rem;color:var(--text-muted)}.settings-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:flex-start;justify-content:center;padding-top:80px;z-index:100;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.settings-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;width:90%;max-width:420px;max-height:calc(100vh - 120px);display:flex;flex-direction:column;animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.settings-header{display:flex;justify-content:space-between;align-items:center;padding:20px 20px 0;margin-bottom:16px;flex-shrink:0}.settings-body{padding:0 20px 20px;overflow-y:auto;flex:1;min-height:0}.settings-header h2{font-size:1.1rem;font-weight:700}.close-btn{background:transparent;border:none;color:var(--text-muted);font-size:1.2rem;cursor:pointer;padding:4px 8px;border-radius:4px}.close-btn:hover{color:var(--text-primary);background:#8080801a}.settings-body h3{font-size:.85rem;font-weight:600;color:var(--text-secondary);margin-bottom:12px;text-transform:uppercase;letter-spacing:.5px}.volume-control{display:flex;align-items:center;gap:10px;padding:8px 0}.volume-icon{font-size:1.1rem;width:24px;text-align:center}.volume-slider{flex:1;height:6px;-webkit-appearance:none;appearance:none;background:var(--progress-track);border-radius:3px;outline:none;cursor:pointer}.volume-slider::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:var(--accent-blue);cursor:pointer;border:2px solid var(--bg-card);box-shadow:0 1px 4px #0000004d}.volume-slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--accent-blue);cursor:pointer;border:2px solid var(--bg-card)}.volume-value{font-size:.78rem;font-weight:700;color:var(--text-primary);min-width:32px;text-align:right;font-variant-numeric:tabular-nums}.volume-test-btn{padding:5px 12px;border:1px solid var(--border);border-radius:6px;background:var(--bg-secondary);color:var(--text-secondary);font-size:.72rem;font-weight:600;cursor:pointer;font-family:inherit;white-space:nowrap;transition:border-color .15s,color .15s}.volume-test-btn:hover{border-color:var(--accent-blue);color:var(--text-primary)}.sound-picker{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px}.noti-perm{margin-bottom:14px;padding:10px 12px;background:var(--bg-primary);border-radius:8px;border:1px solid var(--border)}.noti-status{font-size:.82rem;font-weight:600}.noti-granted{color:var(--accent-green, #22c55e)}.noti-denied{color:var(--danger, #ef4444)}.noti-default{color:var(--text-muted)}.noti-guide{font-size:.75rem;color:var(--text-muted);margin-top:6px;line-height:1.5}.noti-allow-btn{margin-top:8px;padding:6px 14px;border-radius:6px;border:1px solid var(--accent-blue);background:#3b82f61f;color:var(--accent-blue);font-size:.8rem;font-weight:600;cursor:pointer;font-family:inherit;transition:all .15s}.noti-allow-btn:hover{background:#3b82f640}.sound-option{padding:6px 12px;border-radius:6px;border:1px solid var(--border);background:var(--bg-secondary);color:var(--text-secondary);font-size:.78rem;font-weight:500;cursor:pointer;transition:all .15s;font-family:inherit}.sound-option:hover{border-color:var(--accent-blue);color:var(--text-primary)}.sound-option.active{background:#3b82f626;border-color:var(--accent-blue);color:var(--accent-blue);font-weight:600}.settings-hint{font-size:.72rem;color:var(--text-muted);margin-bottom:10px}.char-list{list-style:none;display:flex;flex-direction:column;gap:8px}.char-item{padding:10px 12px;background:var(--bg-secondary);border-radius:8px;border:1px solid var(--border)}.char-display-row{display:flex;justify-content:space-between;align-items:center;gap:8px}.char-drag-handle{cursor:grab;color:var(--text-muted);font-size:.9rem;padding:2px 4px;-webkit-user-select:none;user-select:none;touch-action:none}.char-drag-handle:active{cursor:grabbing}.char-name-display{font-weight:600;font-size:.9rem;display:flex;align-items:center;gap:8px}.badge{font-size:.65rem;background:var(--accent-gradient);color:#fff;padding:2px 6px;border-radius:4px;font-weight:600}.char-actions{display:flex;gap:6px}.delete-btn{font-size:.75rem;padding:4px 10px;border-radius:6px;border:1px solid var(--danger);background:#ef44441a;color:var(--danger);cursor:pointer;font-weight:600;font-family:inherit}.delete-btn:hover{background:#ef444433}.legal-section{margin-top:16px;display:flex;flex-direction:column;gap:6px}.legal-toggle{border:1px solid var(--border);border-radius:8px;overflow:hidden}.legal-toggle-btn{width:100%;display:flex;justify-content:space-between;align-items:center;padding:10px 14px;border:none;background:var(--bg-primary);color:var(--text-secondary);font-size:.82rem;font-weight:600;cursor:pointer;font-family:inherit;transition:background .15s}.legal-toggle-btn:hover{background:#ffffff0a}.legal-arrow{font-size:.65rem;color:var(--text-muted)}.legal-content{padding:12px 14px;border-top:1px solid var(--border);background:var(--bg-secondary);font-size:.75rem;color:var(--text-muted);line-height:1.6}.legal-content p{margin:8px 0 4px}.legal-content p:first-child{margin-top:0}.legal-content strong{color:var(--text-secondary)}.legal-content ul{margin:4px 0;padding-left:18px}.legal-content li{margin:3px 0}.ad-section{display:flex;justify-content:center;padding:16px 0}.kakao-ad-wrap{display:flex;justify-content:center}.kakao-ad-pc{display:block}.kakao-ad-mobile{display:none}@media(max-width:768px){.kakao-ad-pc{display:none}.kakao-ad-mobile{display:block}}.coupon-section{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:12px 16px;margin:0 auto 12px;max-width:600px;width:100%}.coupon-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.coupon-title{font-size:.9rem;font-weight:700;color:var(--text-primary)}.coupon-register-link{font-size:.75rem;color:var(--accent-purple);text-decoration:none}.coupon-register-link:hover{text-decoration:underline}.coupon-list{display:flex;flex-direction:column;gap:6px}.coupon-item{display:flex;align-items:center;gap:8px;padding:6px 10px;background:var(--bg-main);border-radius:8px;border:1px solid var(--border)}.coupon-label{font-size:.78rem;color:var(--text-muted);white-space:nowrap}.coupon-code{font-size:.85rem;font-weight:600;color:var(--accent-purple);background:#8b5cf61a;padding:2px 8px;border-radius:4px;letter-spacing:.5px;flex:1;min-width:0}.coupon-copy-btn{font-size:.72rem;padding:3px 10px;border-radius:6px;border:1px solid var(--accent-purple);background:transparent;color:var(--accent-purple);cursor:pointer;white-space:nowrap;transition:all .15s}.coupon-copy-btn:hover{background:var(--accent-purple);color:#fff}.coupon-copy-btn.copied{background:var(--accent-purple);color:#fff;border-color:var(--accent-purple)}.app-footer{padding:16px 20px 24px;display:flex;justify-content:center;gap:12px;align-items:center;flex-wrap:wrap}.footer-shoutout{width:100%;text-align:center;font-size:.72rem;color:var(--accent-purple);font-weight:500;letter-spacing:.3px}.footer-contact{width:100%;text-align:center;font-size:.75rem;color:var(--text-muted);font-style:italic;margin-top:4px}.footer-disclaimer{width:100%;text-align:center;margin-top:12px;padding-top:10px;border-top:1px solid var(--border)}.footer-disclaimer p{font-size:.68rem;color:var(--text-muted);margin:2px 0;line-height:1.5;opacity:.7}.footer-links{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.footer-ext-link{color:var(--accent-teal, #2dd4bf);font-weight:600;font-size:.82rem;text-decoration:none;padding:6px 12px;border-radius:8px;background:#2dd4bf1a;transition:all .2s;white-space:nowrap}.footer-ext-link:hover{background:#2dd4bf33}.atool-link{display:inline-flex;align-items:center;gap:6px;padding:10px 20px;border-radius:8px;border:1px solid var(--accent-blue);background:#3b82f614;color:var(--accent-blue);font-size:.85rem;font-weight:600;text-decoration:none;transition:all .2s;font-family:inherit}.atool-link:hover{background:#3b82f62e}.reset-btn{padding:10px 24px;border-radius:8px;border:1px solid var(--danger);background:#ef444414;color:var(--danger);font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s;font-family:inherit}.reset-btn:hover{background:#ef44442e}@media(max-width:768px){.app-header{flex-wrap:wrap;gap:8px}.logo-sub{display:none}.content-nav-bar{gap:4px;padding:8px 10px}.content-nav-hero{padding:6px 12px;font-size:.75rem}.content-nav-link{padding:6px 10px;font-size:.72rem}.content-nav-divider{height:16px;margin:0 2px}.logo-area{gap:8px}.header-actions{margin-left:auto}.ticket-row-top{flex-direction:column}}@media(max-width:480px){.app-header{padding:12px 12px 10px}.logo-area{flex-direction:column;gap:2px}.logo{font-size:1.5rem}.logo-2{font-size:1.7rem}.header-actions{gap:6px}.login-hint{display:none}.user-email{max-width:80px;font-size:.65rem}.ticket-panel{padding:8px 12px 6px;flex-direction:column;gap:8px}.ticket-field{gap:2px;padding:4px 6px}.ticket-label{min-width:auto;font-size:.7rem}.ticket-col-hint{display:none}.ticket-sep-mobile{display:inline}.ticket-input-sm{width:34px;padding:3px 2px;font-size:.75rem}.ticket-inputs.ticket-inputs-grid{gap:12px 6px}.task-item{padding:6px 8px;gap:4px}.task-name{font-size:.78rem;gap:3px}.task-note{font-size:.6rem;padding:0 3px}.drag-handle{margin-right:4px;font-size:.65rem}.counter-btn{width:24px;height:24px;font-size:.85rem}.counter-value{min-width:55px;font-size:.75rem}.task-right{gap:3px}.remove-task-btn{width:20px;height:20px;font-size:.65rem}.remove-task-btn,.memo-remove-btn,.alarm-remove-btn{opacity:.6;pointer-events:auto}.main-content{padding:8px 10px 16px}.task-section{padding:12px}.tab-btn{padding:8px 14px;font-size:.82rem}.tab-wrap .tab-btn{padding-right:14px}.tab-delete-btn{display:none}.sidebar{right:10px;bottom:16px}.sidebar-btn{width:38px;height:38px}.app-footer{padding:12px 12px 20px;gap:8px}.atool-link,.reset-btn{padding:8px 16px;font-size:.8rem}.alarm-item{padding:8px 10px}.alarm-info{gap:6px}.settings-overlay{padding-top:50px}.settings-panel{width:calc(100% - 24px);max-width:calc(100% - 24px);max-height:calc(100vh - 80px)}.login-overlay{padding:40px 12px 20px}.login-card{padding:20px 22px;max-width:calc(100% - 24px)}.calc-popup{width:calc(100% - 24px);max-width:calc(100% - 24px)}.toast-container{top:12px;right:50px;left:10px;width:auto;max-width:none}.alarm-sound-dropdown{right:50px}}.toast-container{position:fixed;top:16px;right:56px;z-index:9999;display:flex;flex-direction:column;gap:8px;pointer-events:none;max-width:360px;width:calc(100% - 72px)}.toast-item{display:flex;align-items:center;gap:10px;padding:12px 14px;background:var(--bg-card);border:1px solid var(--accent-blue);border-radius:10px;box-shadow:0 4px 20px #0000004d;animation:toastSlideIn .3s ease-out;pointer-events:auto}@keyframes toastSlideIn{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:translate(0)}}.toast-icon{font-size:1.3rem;flex-shrink:0}.toast-content{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.toast-title{font-size:.8rem;font-weight:700;color:var(--accent-blue)}.toast-body{font-size:.78rem;color:var(--text-secondary)}.toast-close{background:transparent;border:none;color:var(--text-muted);font-size:.7rem;cursor:pointer;padding:4px;border-radius:4px;flex-shrink:0;transition:all .15s}.toast-close:hover{color:var(--text-primary);background:#80808026}.memo-list{display:flex;flex-direction:column;gap:4px}.memo-item{display:flex;align-items:center;padding:10px 12px;background:var(--bg-secondary);border-radius:8px;border:1px solid transparent;transition:background .2s,border-color .2s}.memo-item:hover{background:var(--bg-card-hover);border-color:var(--border)}.memo-text{flex:1;font-size:.88rem;color:var(--text-primary);white-space:pre-wrap;word-break:break-word;min-width:0}.memo-right{display:flex;align-items:center;gap:6px;flex-shrink:0}.memo-item.done{opacity:.55}.memo-item.done .memo-text{text-decoration:line-through;color:var(--text-muted)}.memo-remove-btn{opacity:0;pointer-events:none}.memo-item:hover .memo-remove-btn{opacity:1;pointer-events:auto}.alarm-sound-btn{width:26px;height:26px;border-radius:6px;border:1px solid transparent;background:transparent;color:var(--accent-blue);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;padding:0;flex-shrink:0}.alarm-sound-btn:hover{background:#3b82f61f;border-color:var(--accent-blue)}.alarm-sound-btn.muted{color:var(--text-muted)}.alarm-sound-btn.muted:hover{color:var(--danger);border-color:var(--danger);background:#ef44441a}.alarm-sound-wrap{position:relative}.alarm-sound-dropdown{position:absolute;right:0;top:100%;margin-top:4px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;box-shadow:0 4px 16px #0000004d;z-index:100;min-width:160px;max-height:260px;overflow-y:auto;padding:4px 0}@media(max-width:480px){.alarm-sound-dropdown{position:fixed;inset:auto 10px 60px;min-width:auto;max-height:50vh;z-index:200}}.alarm-sound-dropdown-item{display:block;width:100%;padding:7px 12px;border:none;background:transparent;color:var(--text-secondary);font-size:.78rem;font-family:inherit;text-align:left;cursor:pointer;transition:all .1s;white-space:nowrap}.alarm-sound-dropdown-item:hover{background:#3b82f61a;color:var(--text-primary)}.alarm-sound-dropdown-item.active{color:var(--accent-blue);font-weight:600}.alarm-sound-tag{font-size:.68rem;color:var(--accent-blue);background:#3b82f61a;padding:1px 6px;border-radius:4px;white-space:nowrap}.alarm-sound-picker-row{display:flex;align-items:center;gap:8px;margin-top:2px}.alarm-sound-picker-label{font-size:.8rem;color:var(--text-secondary);white-space:nowrap}.alarm-sound-picker-btn{flex:1;min-width:0;display:flex;align-items:center;justify-content:space-between;gap:6px;padding:6px 10px;border-radius:6px;border:1px solid var(--border);background:var(--bg-primary);color:var(--text-primary);font-size:.85rem;font-family:inherit;cursor:pointer;text-align:left}.alarm-sound-picker-btn:hover{border-color:var(--accent-blue)}.alarm-sound-picker-arrow{color:var(--text-muted);font-size:.75rem}.alarm-sound-picker-row .alarm-sound-dropdown{top:auto;bottom:100%;margin-top:0;margin-bottom:4px}.alarm-day-picker{display:flex;gap:4px;flex-wrap:wrap}.alarm-day-btn{width:34px;height:30px;border-radius:6px;border:1px solid var(--border);background:var(--bg-primary);color:var(--text-muted);font-size:.75rem;font-weight:600;cursor:pointer;transition:all .15s;font-family:inherit;padding:0}.alarm-day-btn:hover{border-color:var(--accent-blue);color:var(--text-secondary)}.alarm-day-btn.active{background:#3b82f626;border-color:var(--accent-blue);color:var(--accent-blue)}.alarm-sound-label{display:flex;align-items:center;gap:6px;font-size:.8rem;color:var(--text-secondary);cursor:pointer}.alarm-sound-label input[type=checkbox]{accent-color:var(--accent-blue)}.sidebar{position:fixed;right:14px;bottom:24px;display:flex;flex-direction:column;gap:8px;z-index:50}.sidebar-btn{width:42px;height:42px;border-radius:50%;border:1px solid var(--border);background:var(--bg-card);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 2px 10px #00000040;transition:all .2s;text-decoration:none;padding:0;font-family:inherit}.sidebar-btn:hover{background:var(--bg-card-hover);border-color:var(--accent-blue);color:var(--accent-blue);transform:scale(1.1)}.qr-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:200;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.qr-popup{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:20px;display:flex;flex-direction:column;align-items:center;gap:12px;animation:slideDown .2s ease-out;position:relative}.qr-popup .close-btn{position:absolute;top:10px;right:12px}.qr-image{width:200px;height:200px;border-radius:12px}.qr-text{font-size:.9rem;font-weight:600;color:var(--text-secondary)}.calc-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:200;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.calc-popup{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:16px;width:280px;max-width:90%;animation:slideDown .2s ease-out}.calc-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.calc-title{font-size:.95rem;font-weight:700;color:var(--text-primary)}.calc-close{background:transparent;border:none;color:var(--text-muted);font-size:.9rem;cursor:pointer;padding:4px 8px;border-radius:4px;transition:all .15s}.calc-close:hover{color:var(--text-primary);background:#8080801f}.calc-popup:focus{outline:none}.calc-display-area{background:var(--bg-primary);border:1px solid var(--border);border-radius:10px;padding:10px 16px 12px;margin-bottom:12px;text-align:right}.calc-expression{font-size:.78rem;color:var(--text-muted);min-height:1.1em;font-variant-numeric:tabular-nums}.calc-display{font-size:1.6rem;font-weight:600;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-variant-numeric:tabular-nums;min-height:1.6em;line-height:1.3;transition:opacity .15s}.calc-display.calc-display-dim{opacity:.25}.calc-buttons{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}.calc-btn{padding:14px;border-radius:8px;border:1px solid var(--border);background:var(--bg-secondary);color:var(--text-primary);font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .15s;font-family:inherit}.calc-btn:hover{background:var(--bg-card-hover)}.calc-btn:active{transform:scale(.95)}.calc-btn.func{background:#8080801f;color:var(--text-secondary)}.calc-btn.func:hover{background:#80808038}.calc-btn.op{background:#3b82f61f;color:var(--accent-blue);border-color:#3b82f633}.calc-btn.op:hover{background:#3b82f638}.calc-btn.op.equals{background:var(--accent-gradient);color:#fff;border-color:transparent}.calc-btn.op.equals:hover{opacity:.9}.calc-btn.dot-wide,.calc-btn.eq-wide{grid-column:span 2}.ticket-panel{padding:10px 20px 8px;display:flex;gap:12px;flex-wrap:wrap;align-items:flex-start;overflow:visible;min-width:0}.ticket-row-top{display:flex;gap:12px;align-items:flex-start}.ticket-row-top>.ticket-group:first-child{flex:1;min-width:0}.ticket-row-top>.ticket-group:not(:first-child){flex-shrink:0}.ticket-group-full{width:100%}.ticket-group{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.ticket-group:not(:first-child){flex-wrap:nowrap}.ticket-icon{width:24px;height:24px;object-fit:contain;flex-shrink:0}.ticket-title{font-size:.78rem;font-weight:600;color:var(--text-secondary);white-space:nowrap}.ticket-title-fun{font-style:italic;color:var(--text-muted);font-size:.72rem}.ticket-group-toggle{flex-direction:column;align-items:flex-start}.ticket-toggle-header{display:flex;align-items:center;gap:8px;cursor:pointer;-webkit-user-select:none;user-select:none}.ticket-toggle-arrow{font-size:.6rem;color:var(--text-muted);transition:transform .2s}.ticket-toggle-arrow.open{transform:rotate(90deg)}.ticket-inputs{display:flex;align-items:center;gap:4px;flex-wrap:wrap}.ticket-inputs.ticket-inputs-grid{margin-top:6px;margin-bottom:8px;display:grid;grid-template-columns:repeat(4,1fr);gap:10px 12px}@media(max-width:900px){.ticket-inputs.ticket-inputs-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:768px){.ticket-inputs.ticket-inputs-grid{grid-template-columns:1fr 1fr;gap:16px 14px}}.ticket-field{display:flex;align-items:center;gap:4px;padding:6px 8px;border:1px solid var(--border);border-radius:8px;background:var(--bg-secondary);min-width:0}.ticket-field-en{flex-wrap:wrap}.ticket-field-en .ticket-label{width:100%}.ticket-field-plain{border:none;background:transparent;padding:10;gap:0px}.ticket-label{font-size:.75rem;color:var(--text-primary);font-weight:600;white-space:nowrap;min-width:30px;margin-right:0}.ticket-help{font-size:.68rem;color:var(--text-muted);line-height:1.5;margin:4px 0 2px;padding:0}.ticket-help strong{color:var(--text-secondary)}.ticket-col-hint{font-size:.62rem;color:var(--text-muted);white-space:nowrap;background:#ffffff0d;padding:1px 4px;border-radius:3px;letter-spacing:-.3px}.ticket-col-hint-plus{color:var(--accent-teal);background:#2dd4bf14;margin-left:4px}.ticket-sep-mobile{display:none;font-size:.65rem;color:var(--text-muted)}.ticket-input{width:52px;padding:4px 6px;border-radius:6px;border:1px solid var(--border);background:var(--bg-secondary);color:var(--text-primary);font-size:.82rem;font-family:inherit;text-align:center;outline:none;font-variant-numeric:tabular-nums;-moz-appearance:textfield}.ticket-input::-webkit-outer-spin-button,.ticket-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.ticket-input:focus{border-color:var(--accent-blue);box-shadow:0 0 0 2px #3b82f626}.ticket-input-sm{width:40px}.step-input-wrap{position:relative;display:inline-flex;flex-direction:column;align-items:center}.step-btns{position:absolute;top:100%;left:50%;transform:translate(-50%);display:flex;gap:2px;margin-top:2px;z-index:20}.step-btn{width:22px;height:20px;border-radius:4px;border:1px solid var(--border);background:var(--bg-card);color:var(--text-primary);font-size:.8rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;line-height:1;transition:all .15s;font-family:inherit}.step-minus:hover{border-color:var(--danger);color:var(--danger);background:#ef44441a}.step-plus:hover{border-color:var(--success);color:var(--success);background:#10b9811a}.ticket-sep{font-size:.85rem;color:var(--text-muted);font-weight:600}.ticket-plus{font-size:.8rem;color:var(--accent-purple);font-weight:600}.max-bonus{font-size:.7rem;color:var(--text-muted);margin-right:2px}.max-recharged{color:var(--accent-teal)}.max-bonus-purple{color:var(--accent-purple)}.loading-content{text-align:center;display:flex;flex-direction:column;align-items:center;gap:16px}.loading-spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--accent-blue);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{font-size:.85rem;color:var(--text-muted)}.login-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:flex-start;justify-content:center;z-index:300;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);padding:60px 20px 40px;overflow-y:auto;-webkit-overflow-scrolling:touch}.login-card{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:24px 28px;width:100%;max-width:380px;display:flex;flex-direction:column;align-items:center;gap:16px;animation:slideDown .3s ease-out}.login-card-header{width:100%;display:flex;justify-content:space-between;align-items:center}.login-title{font-size:1.2rem;font-weight:700;background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.login-error{width:100%;padding:10px 14px;border-radius:8px;background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:var(--danger);font-size:.82rem;text-align:center}.login-success{width:100%;padding:10px 14px;border-radius:8px;background:#10b9811a;border:1px solid rgba(16,185,129,.3);color:var(--success);font-size:.82rem;text-align:center}.login-reset-btn{background:none;border:none;color:var(--text-muted);font-size:.78rem;cursor:pointer;font-family:inherit;padding:4px 0;text-decoration:underline;text-underline-offset:3px;transition:color .15s}.login-reset-btn:hover{color:var(--accent-blue)}.google-btn{width:100%;padding:12px;border-radius:8px;border:1px solid var(--border);background:var(--bg-secondary);color:var(--text-primary);font-size:.9rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;transition:all .2s;font-family:inherit}.google-btn:hover:not(:disabled){border-color:var(--accent-blue);background:var(--bg-card-hover)}.google-btn:disabled{opacity:.6;cursor:not-allowed}.gis-btn-wrap{width:100%;display:flex;justify-content:center}.login-divider{width:100%;display:flex;align-items:center;gap:12px;color:var(--text-muted);font-size:.75rem}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:var(--border)}.login-form{width:100%;display:flex;flex-direction:column;gap:10px}.login-input{width:100%;padding:12px 14px;border-radius:8px;border:1px solid var(--border);background:var(--bg-secondary);color:var(--text-primary);font-size:.88rem;font-family:inherit;outline:none;transition:border-color .2s,box-shadow .2s;box-sizing:border-box}.login-input:focus{border-color:var(--accent-blue);box-shadow:0 0 0 2px #3b82f633}.login-submit-btn{width:100%;padding:12px;border-radius:8px;border:none;background:var(--accent-gradient);color:#fff;font-size:.9rem;font-weight:700;cursor:pointer;transition:opacity .2s;font-family:inherit}.login-submit-btn:hover:not(:disabled){opacity:.9}.login-submit-btn:disabled{opacity:.6;cursor:not-allowed}.login-toggle-btn{background:transparent;border:none;color:var(--accent-blue);font-size:.8rem;cursor:pointer;padding:4px;font-family:inherit;transition:color .2s}.login-toggle-btn:hover{color:var(--accent-purple)}.login-inapp-notice{width:100%;padding:10px 14px;border-radius:8px;background:#f59e0b1a;border:1px solid rgba(245,158,11,.3);text-align:center}.login-inapp-notice p{font-size:.78rem;color:var(--accent-gold);line-height:1.5;margin-bottom:4px}.login-inapp-notice p:last-of-type{margin-bottom:10px}.login-inapp-actions{display:flex;flex-direction:column;gap:6px}.login-copy-btn{padding:6px 14px;border-radius:6px;border:1px solid var(--accent-blue);background:#3b82f61f;color:var(--accent-blue);font-size:.78rem;font-weight:600;cursor:pointer;font-family:inherit;transition:all .15s}.login-copy-btn:hover{background:#3b82f638}.login-security-notice{font-size:.68rem;color:var(--text-muted);text-align:center;line-height:1.6;opacity:.7}.user-info{display:flex;align-items:center;gap:6px}.user-email{font-size:.72rem;color:var(--text-muted);max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.logout-btn{background:transparent;border:1px solid var(--border);color:var(--text-secondary);width:32px;height:32px;border-radius:6px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;padding:0}.logout-btn:hover{border-color:var(--danger);color:var(--danger);background:#ef44441a}.header-login-btn{padding:6px 14px;border-radius:8px;border:1px solid var(--accent-blue);background:#3b82f61a;color:var(--accent-blue);font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s;font-family:inherit;white-space:nowrap}.header-login-btn:hover{background:#3b82f633}.login-hint{font-size:.7rem;color:var(--text-muted);white-space:nowrap}.loading-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:400;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.ticket-panel-bottom{padding-top:0;padding-bottom:4px}.sidebar-btn-guide{background:var(--accent-gradient);border-color:transparent;color:#fff}.sidebar-btn-guide:hover{background:var(--accent-gradient);border-color:transparent;color:#fff;transform:scale(1.1)}.sidebar-guide-icon{font-size:1.1rem;font-weight:800;line-height:1}.reset-btns{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}.reset-btn-all{border-color:var(--danger);color:var(--danger)}.reset-btn-all:hover{background:#ef444426}.membership-toggle{margin:8px 0 16px}.membership-label{display:flex;align-items:center;gap:10px;cursor:pointer;font-size:.85rem}.membership-label input[type=checkbox]{width:40px;height:22px;appearance:none;-webkit-appearance:none;background:var(--bg-secondary);border:1px solid var(--border);border-radius:11px;position:relative;cursor:pointer;transition:all .2s;flex-shrink:0}.membership-label input[type=checkbox]:after{content:"";position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:var(--text-muted);transition:all .2s}.membership-label input[type=checkbox]:checked{background:var(--accent-purple);border-color:var(--accent-purple)}.membership-label input[type=checkbox]:checked:after{left:20px;background:#fff}.membership-text{color:var(--text-secondary);font-size:.82rem}.ode-inputs{align-items:center}.ode-auto-recharge{font-size:.75rem;color:var(--accent-teal);font-weight:600;white-space:nowrap}.ode-paren{font-size:.85rem;color:var(--text-muted);font-weight:500}.ode-eq{font-size:.85rem;color:var(--text-muted);font-weight:500;margin:0 2px}.ode-total{font-size:.85rem;color:var(--text-primary);font-weight:700}.ode-display-total{font-size:.72rem;color:var(--text-secondary);width:100%;margin-top:2px;font-weight:500}.ode-display-line{white-space:nowrap}.ode-display-sub{display:block;color:var(--text-muted);font-size:.68rem;margin-top:1px}.ode-membership-badge{font-size:.62rem;color:var(--accent-purple);background:#8b5cf626;padding:1px 6px;border-radius:4px;font-weight:700;margin-right:4px}.ode-no-membership-badge{font-size:.62rem;color:var(--text-muted);background:#80808026;padding:1px 6px;border-radius:4px;font-weight:600;margin-right:4px}.ode-recharge-value{color:var(--accent-teal);font-weight:600}.ode-additional-value{color:var(--accent-purple);font-weight:600}.memo-sortable-wrap{display:flex;align-items:center;gap:4px}.memo-sortable-wrap .memo-item{flex:1;min-width:0}.memo-drag-handle{cursor:grab;color:var(--text-muted);font-size:.75rem;padding:4px 2px;-webkit-user-select:none;user-select:none;touch-action:none;flex-shrink:0;opacity:.5;transition:opacity .2s}.memo-drag-handle:hover{opacity:1}.memo-drag-handle:active{cursor:grabbing}@media(max-width:768px)and (min-width:481px){.ticket-group:not(:first-child){flex-wrap:wrap}.settings-overlay{padding-top:60px}.login-overlay{padding-top:40px}.login-card{padding:20px 24px}.toast-container{right:50px;width:calc(100% - 66px);max-width:320px}}@media(max-width:360px){.app-header{padding:10px 8px 8px}.logo{font-size:1.3rem}.logo-2{font-size:1.4rem}.user-email{max-width:50px;font-size:.6rem}.theme-btn,.settings-btn{width:32px;height:32px}.tab-btn{padding:6px 10px;font-size:.78rem}.sidebar{right:6px;bottom:12px}.sidebar-btn{width:34px;height:34px}.toast-container{top:10px;right:44px;left:8px;width:auto;max-width:none}.settings-overlay{padding-top:40px}.settings-panel{width:calc(100% - 20px);max-width:calc(100% - 20px)}.login-overlay{padding:30px 12px 12px}.login-card{padding:16px 18px}.calc-popup{width:calc(100% - 20px);max-width:calc(100% - 20px)}.counter-btn{width:22px;height:22px;font-size:.8rem}.counter-value{min-width:48px;font-size:.7rem}.task-name{font-size:.72rem}.app-footer{padding:10px 8px 16px}.atool-link,.reset-btn{padding:6px 12px;font-size:.75rem}}.page-container{min-height:100vh;display:flex;flex-direction:column;background:var(--bg-primary)}.page-nav{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;background:var(--bg-secondary);border-bottom:1px solid var(--border);gap:12px;flex-wrap:wrap}.page-nav-back{color:var(--accent-blue);font-size:.85rem;font-weight:600;text-decoration:none;white-space:nowrap}.page-nav-back:hover{text-decoration:underline}.page-nav-links{display:flex;gap:4px;flex-wrap:wrap}.page-nav-link{padding:6px 12px;border-radius:6px;font-size:.78rem;font-weight:600;white-space:nowrap;color:var(--text-secondary);text-decoration:none;transition:background .15s,color .15s}.page-nav-link:hover{background:#8b5cf614;color:var(--text-primary)}.page-nav-link.active{background:var(--accent-purple);color:#fff}.page-content{flex:1;padding:32px 20px;max-width:1060px;margin:0 auto;width:100%}.page-title{font-size:1.6rem;font-weight:800;background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:8px}.page-intro{font-size:.9rem;color:var(--text-secondary);line-height:1.6;margin-bottom:32px}.section-heading{font-size:1.15rem;font-weight:700;color:var(--text-primary);margin-bottom:16px;padding-bottom:8px;border-bottom:2px solid var(--accent-purple);display:inline-block}.guide-slider-section{margin-bottom:40px}.guide-slider-layout{display:flex;gap:24px;align-items:flex-start}.guide-slider-sticky{position:sticky;top:20px;flex:0 0 520px;background:var(--bg-card);border:1px solid var(--border);border-radius:12px;overflow:hidden;display:flex;flex-direction:column}.guide-slider-img-wrap{width:100%;height:380px;background:var(--bg-primary);display:flex;align-items:center;justify-content:center;overflow:hidden}.guide-slider-img{width:100%;height:100%;display:block;object-fit:contain}.guide-slider-controls{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-top:1px solid var(--border);gap:8px}.guide-slider-btn{background:var(--bg-secondary);border:1px solid var(--border);border-radius:6px;padding:6px 14px;font-size:.78rem;font-weight:600;color:var(--text-primary);cursor:pointer;white-space:nowrap;transition:opacity .15s;font-family:inherit}.guide-slider-btn:disabled{opacity:.25;cursor:not-allowed}.guide-slider-btn:not(:disabled):hover{opacity:.7}.guide-slider-dots{display:flex;gap:6px;justify-content:center;flex:1}.guide-slider-dot{width:8px;height:8px;border-radius:50%;border:none;background:var(--text-muted);opacity:.3;cursor:pointer;padding:0;transition:opacity .15s,transform .15s}.guide-slider-dot.active{opacity:1;background:var(--accent-purple);transform:scale(1.3)}.guide-slider-counter{display:block;text-align:center;font-size:.7rem;color:var(--text-muted);padding:0 0 10px}.guide-slider-content{flex:1;min-width:0}.guide-slider-title{font-size:1.1rem;font-weight:700;color:var(--text-primary);margin:0 0 16px;padding-bottom:12px;border-bottom:2px solid var(--accent-blue)}.guide-slider-desc{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:20px}.guide-slider-desc p{font-size:.88rem;color:var(--text-secondary);line-height:1.75;margin:0 0 8px}.guide-slider-desc p:last-child{margin-bottom:0}@media(max-width:768px){.guide-slider-layout{flex-direction:column;gap:16px}.guide-slider-sticky{position:relative;top:0;flex:none;width:100%}.guide-slider-img-wrap{height:360px}.guide-slider-title{font-size:1rem}}.guide-text-section{margin-bottom:32px}.guide-text-block{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:20px;margin-bottom:12px}.guide-text-heading{font-size:.95rem;font-weight:700;color:var(--accent-blue);margin:0 0 10px}.guide-text-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}.guide-text-list li{font-size:.82rem;color:var(--text-secondary);line-height:1.55;padding-left:16px;position:relative}.guide-text-list li:before{content:"";position:absolute;left:0;top:8px;width:6px;height:6px;border-radius:50%;background:var(--accent-purple)}.guide-disclaimer-block{text-align:center;padding:24px;margin-top:24px;border-top:1px solid var(--border)}.guide-disclaimer-block p{font-size:.75rem;color:var(--text-muted);line-height:1.6}.tips-grid{display:flex;flex-direction:column;gap:12px}.tip-card{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;overflow:hidden;cursor:pointer;transition:border-color .15s}.tip-card:hover{border-color:var(--accent-purple)}.tip-card-header{display:flex;align-items:center;gap:10px;padding:16px 20px}.tip-tag{font-size:.7rem;font-weight:700;padding:2px 8px;border-radius:4px;background:#8b5cf626;color:var(--accent-purple);white-space:nowrap}.tip-title{flex:1;font-size:.92rem;font-weight:700;color:var(--text-primary);margin:0}.tip-expand-icon{font-size:1.2rem;color:var(--text-muted);font-weight:300;width:24px;text-align:center}.tip-card-body{max-height:0;overflow:hidden;transition:max-height .3s ease,padding .3s ease;padding:0 20px}.tip-card.expanded .tip-card-body{max-height:600px;padding:0 20px 20px}.tip-card-body p{font-size:.84rem;color:var(--text-secondary);line-height:1.7;margin:0 0 6px}.cheatsheet-section{margin-bottom:32px}.cheatsheet-card{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;overflow:hidden;margin-bottom:12px;transition:border-color .15s}.cheatsheet-card:hover{border-color:var(--accent-purple)}.folder-wrap{display:inline-block;margin:0 12px 16px 0;vertical-align:top}.folder-shape{position:relative;display:block;width:56px;height:42px;padding:0;border:none;background:transparent;cursor:pointer;font-family:inherit;transition:transform .18s ease}.folder-shape:hover{transform:translateY(-2px)}.folder-wrap.open .folder-shape{transform:translateY(-1px)}.folder-tab{position:absolute;top:0;left:4px;width:24px;height:7px;background:linear-gradient(180deg,#fbbf24,#f59e0b);border:1px solid #d97706;border-bottom:none;border-radius:2px 5px 0 0;box-shadow:inset 0 1px #ffffff4d}.folder-body{position:absolute;inset:5px 0 0;background:linear-gradient(180deg,#fcd34d,#f59e0b);border:1px solid #d97706;border-radius:2px 4px 4px;box-shadow:inset 0 1px #fff6,0 2px 6px #00000026;display:flex;align-items:center;justify-content:center;padding:3px 4px;overflow:hidden}.folder-body:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:#ffffff80}.folder-name{font-size:.7rem;font-weight:700;color:#78350f;text-align:center;word-break:keep-all;line-height:1.15;text-shadow:0 1px 0 rgba(255,255,255,.4)}[data-theme=dark] .folder-tab{background:linear-gradient(180deg,#d97706,#b45309);border-color:#78350f}[data-theme=dark] .folder-body{background:linear-gradient(180deg,#f59e0b,#d97706);border-color:#78350f}[data-theme=dark] .folder-name{color:#451a03}.folder-contents{display:block;width:100%;margin-top:8px;padding:12px 16px;background:var(--bg-card);border:1px solid var(--border);border-radius:10px}.folder-nested-row{display:flex;flex-wrap:wrap;gap:12px}.folder-nested-row .folder-wrap{margin:0}.cheatsheet-folder-empty{padding:12px;text-align:center;color:var(--text-muted);font-size:.85rem;font-style:italic}.cheatsheet-folder-items{display:flex;flex-direction:column;gap:6px}.cheatsheet-folder-item{padding:8px 12px;background:#8b5cf60f;border:1px solid rgba(139,92,246,.15);border-radius:6px;font-size:.85rem;color:var(--text-primary)}.cheatsheet-folder-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:10px}@media(max-width:768px){.cheatsheet-folder-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(max-width:480px){.cheatsheet-folder-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.cheatsheet-folder-card{display:flex;flex-direction:column;background:#8b5cf60f;border:1px solid rgba(139,92,246,.2);border-radius:10px;overflow:hidden;text-decoration:none;color:var(--text-primary);transition:all .18s ease}.cheatsheet-folder-card:hover{background:#8b5cf61f;border-color:#8b5cf680;transform:translateY(-3px);box-shadow:0 6px 18px #8b5cf626}.cheatsheet-folder-thumb{width:100%;aspect-ratio:1 / 1;background:#00000026;overflow:hidden;display:flex;align-items:center;justify-content:center}[data-theme=light] .cheatsheet-folder-thumb{background:#0000000a}.cheatsheet-folder-thumb img{width:100%;height:100%;object-fit:cover;display:block}.cheatsheet-folder-caption{display:flex;justify-content:space-between;align-items:center;gap:6px;padding:8px 12px;font-size:.82rem;font-weight:500}.cheatsheet-folder-arrow{color:var(--accent-purple);font-size:.9rem;flex-shrink:0}.cheatsheet-header{display:flex;align-items:center;width:100%;padding:16px 20px;background:none;border:none;cursor:pointer;font-family:inherit;text-align:left}.cheatsheet-title{flex:1;font-size:.95rem;font-weight:700;color:var(--text-primary);margin:0}.cheatsheet-toggle{font-size:1.2rem;color:var(--text-muted);font-weight:300;width:24px;text-align:center}.cheatsheet-body{padding:0 12px 12px}.cheatsheet-controls{display:flex;align-items:center;justify-content:center;gap:8px;padding-bottom:10px}.cheatsheet-btn{background:var(--bg-secondary);border:1px solid var(--border);border-radius:6px;padding:6px 12px;font-size:.85rem;color:var(--text-primary);cursor:pointer;font-family:inherit;transition:opacity .15s}.cheatsheet-btn:disabled{opacity:.25;cursor:not-allowed}.cheatsheet-btn:not(:disabled):hover{opacity:.7}.cheatsheet-tabs{display:flex;gap:4px}.cheatsheet-tab{padding:5px 14px;border:1px solid var(--border);border-radius:6px;background:var(--bg-secondary);color:var(--text-secondary);font-size:.78rem;font-weight:600;cursor:pointer;font-family:inherit;transition:all .15s}.cheatsheet-tab:hover{border-color:var(--accent-purple);color:var(--text-primary)}.cheatsheet-tab.active{background:var(--accent-purple);border-color:var(--accent-purple);color:#fff}.cheatsheet-img-wrap{width:100%;border-radius:8px;overflow:hidden;background:var(--bg-primary)}.cheatsheet-img{width:100%;display:block}.cheatsheet-source{padding:8px 8px 0;font-size:.72rem;color:var(--text-muted)}.cheatsheet-source a{color:var(--accent-blue);text-decoration:none}.cheatsheet-source a:hover{text-decoration:underline}.cheatsheet-link{text-decoration:none;display:block}.cheatsheet-link .cheatsheet-toggle{color:var(--accent-blue)}.community-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px;flex-wrap:wrap}.community-cats{display:flex;gap:4px;flex-wrap:wrap}.community-cat-btn{padding:5px 12px;border:1px solid var(--border);border-radius:6px;background:var(--bg-card);color:var(--text-secondary);font-size:.78rem;font-weight:600;cursor:pointer;transition:all .15s;font-family:inherit}.community-cat-btn:hover{border-color:var(--accent-purple);color:var(--text-primary)}.community-cat-btn.active{background:var(--accent-purple);border-color:var(--accent-purple);color:#fff}.community-cat-btn.sort-btn{border-color:#f59e0b4d;color:var(--accent-gold)}.community-cat-btn.sort-btn:hover{border-color:var(--accent-gold)}.community-cat-btn.sort-btn.active{background:var(--accent-gold);border-color:var(--accent-gold);color:#fff}.community-write-btn{padding:8px 20px;border:none;border-radius:8px;background:var(--accent-gradient);color:#fff;font-size:.85rem;font-weight:700;cursor:pointer;font-family:inherit;transition:opacity .15s}.community-write-btn:hover{opacity:.85}.community-form{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:20px;margin-bottom:20px;display:flex;flex-direction:column;gap:10px}.community-form-row{display:flex;gap:10px}.community-input{padding:10px 14px;border:1px solid var(--border);border-radius:8px;background:var(--bg-primary);color:var(--text-primary);font-size:.85rem;font-family:inherit;outline:none;transition:border-color .15s;flex:1}.community-input:focus{border-color:var(--accent-blue)}.community-input-full{width:100%}.community-select{padding:10px 14px;border:1px solid var(--border);border-radius:8px;background:var(--bg-primary);color:var(--text-primary);font-size:.85rem;font-family:inherit;outline:none;cursor:pointer}.community-textarea{padding:12px 14px;border:1px solid var(--border);border-radius:8px;background:var(--bg-primary);color:var(--text-primary);font-size:.85rem;font-family:inherit;outline:none;resize:vertical;min-height:100px;line-height:1.6;transition:border-color .15s}.community-textarea:focus{border-color:var(--accent-blue)}.community-form-actions{display:flex;align-items:center;justify-content:space-between;gap:12px}.community-form-user{font-size:.75rem;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.community-submit-btn{padding:10px 28px;border:none;border-radius:8px;background:var(--accent-blue);color:#fff;font-size:.85rem;font-weight:700;cursor:pointer;font-family:inherit;transition:opacity .15s;white-space:nowrap}.community-submit-btn:hover{opacity:.85}.community-submit-btn:disabled{opacity:.5;cursor:not-allowed}.community-posts{display:flex;flex-direction:column;gap:10px}.community-empty{text-align:center;padding:48px 20px;color:var(--text-muted);font-size:.9rem}.community-post{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;overflow:hidden;transition:border-color .15s}.community-post:hover{border-color:#8b5cf64d}.community-post-header{display:flex;align-items:center;gap:10px;padding:14px 20px 0}.community-post-cat{font-size:.68rem;font-weight:700;padding:2px 7px;border-radius:4px;background:#3b82f61f;color:var(--accent-blue);white-space:nowrap}.community-post-title{font-size:.92rem;font-weight:700;color:var(--text-primary);margin:0;flex:1}.community-post-body{padding:8px 20px 12px}.community-post-body p{font-size:.84rem;color:var(--text-secondary);line-height:1.65;margin:0 0 4px}.community-post-footer{display:flex;align-items:center;gap:12px;padding:8px 20px 14px;border-top:1px solid var(--border)}.community-post-author{font-size:.78rem;font-weight:600;color:var(--accent-purple)}.community-post-date{font-size:.72rem;color:var(--text-muted)}.community-like-btn{margin-left:auto;padding:3px 10px;border:1px solid var(--border);border-radius:12px;background:transparent;color:var(--text-secondary);font-size:.75rem;cursor:pointer;font-family:inherit;transition:all .15s}.community-like-btn:hover{border-color:#ef4444;color:#ef4444;background:#ef444414}.community-like-btn.liked{border-color:#ef4444;color:#ef4444;background:#ef44441a}.community-login-banner{display:flex;align-items:center;gap:12px;padding:14px 20px;margin-bottom:16px;background:#3b82f61a;border:1px solid rgba(59,130,246,.25);border-radius:10px}.community-login-banner p{flex:1;font-size:.85rem;color:var(--text-primary);margin:0}.community-login-link{padding:6px 16px;border-radius:6px;background:var(--accent-blue);color:#fff;font-size:.8rem;font-weight:700;text-decoration:none;white-space:nowrap;transition:opacity .15s}.community-login-link:hover{opacity:.85}.community-login-close{border:none;background:transparent;color:var(--text-muted);font-size:1.2rem;cursor:pointer;padding:0 4px;line-height:1}.community-loading-spinner{width:28px;height:28px;border:3px solid var(--border);border-top-color:var(--accent-purple);border-radius:50%;animation:community-spin .7s linear infinite;margin:0 auto 12px}@keyframes community-spin{to{transform:rotate(360deg)}}.community-load-more{display:block;width:100%;padding:12px;margin-top:8px;border:1px solid var(--border);border-radius:8px;background:var(--bg-card);color:var(--text-secondary);font-size:.85rem;font-weight:600;cursor:pointer;font-family:inherit;transition:border-color .15s,color .15s}.community-load-more:hover{border-color:var(--accent-purple);color:var(--text-primary)}.community-load-more:disabled{opacity:.5;cursor:not-allowed}.community-delete-btn{padding:3px 8px;border:none;border-radius:4px;background:transparent;color:var(--text-muted);font-size:.7rem;cursor:pointer;font-family:inherit;transition:color .15s}.community-delete-btn:hover{color:var(--danger)}.page-footer{padding:24px 20px;border-top:1px solid var(--border);text-align:center;background:var(--bg-secondary)}.page-footer-links{display:flex;justify-content:center;gap:12px;margin-bottom:16px;flex-wrap:wrap}.page-footer-links a{color:var(--accent-blue);text-decoration:none;font-size:.82rem;font-weight:600}.page-footer-links a:hover{text-decoration:underline}.page-footer-disclaimer{font-size:.7rem;color:var(--text-muted);margin:2px 0;line-height:1.5}.patchnotes-official-link{display:inline-block;padding:10px 20px;margin-bottom:20px;border:1px solid rgba(59,130,246,.25);border-radius:8px;background:#3b82f614;color:var(--accent-blue);font-size:.85rem;font-weight:600;text-decoration:none;transition:background .15s}.patchnotes-official-link:hover{background:#3b82f626}.site-changelog{margin-bottom:20px}.site-changelog-title{font-size:1.05rem;font-weight:700;color:var(--accent-purple);margin-bottom:10px}.patchnotes-list{display:flex;flex-direction:column;gap:12px}.patchnote-card{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:18px 20px;cursor:pointer;transition:border-color .15s}.patchnote-card:hover{border-color:var(--accent-purple)}.patchnote-header{display:flex;align-items:center;gap:12px;margin-bottom:8px}.patchnote-date{font-size:.72rem;font-weight:700;color:var(--accent-purple);background:#8b5cf61a;padding:2px 8px;border-radius:4px;white-space:nowrap}.patchnote-title{font-size:.95rem;font-weight:700;color:var(--text-primary);margin:0;flex:1}.patchnote-summary{font-size:.85rem;color:var(--accent-blue);font-weight:600;margin:0 0 8px;line-height:1.5}.patchnote-details{padding:12px 0;border-top:1px solid var(--border)}.patchnote-details p{font-size:.84rem;color:var(--text-secondary);line-height:1.7;margin:0 0 4px}.patchnote-footer{display:flex;align-items:center;gap:12px;margin-top:8px}.patchnote-link{font-size:.78rem;font-weight:600;color:var(--accent-teal);text-decoration:none}.patchnote-link:hover{text-decoration:underline}.patchnote-expand{font-size:.72rem;color:var(--text-muted);margin-left:auto}.dungeon-legend{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:24px;padding:14px 18px;background:var(--bg-card);border:1px solid var(--border);border-radius:10px}.dungeon-legend-item{display:flex;align-items:center;gap:6px;font-size:.78rem;color:var(--text-secondary)}.dungeon-tag{font-size:.65rem;font-weight:700;padding:2px 7px;border-radius:4px;white-space:nowrap}.tag-ode{background:#f59e0b26;color:var(--accent-gold)}.tag-rechargeable{background:#10b9811f;color:var(--success)}.tag-weekly{background:#3b82f61f;color:var(--accent-blue)}.tag-fixed{background:#8b5cf61f;color:var(--accent-purple)}.dungeons-grid{display:flex;flex-direction:column;gap:12px}.dungeon-card{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;overflow:hidden}.dungeon-card-header{display:flex;align-items:center;gap:10px;padding:16px 20px;flex-wrap:wrap}.dungeon-card-tags{display:flex;gap:4px}.dungeon-card-title{flex:1;font-size:.95rem;font-weight:700;color:var(--text-primary);margin:0}.dungeon-difficulty{font-size:.75rem;color:var(--accent-gold);letter-spacing:1px}.dungeon-card-body{padding:0 20px 20px;border-top:1px solid var(--border)}.dungeon-card-body p{font-size:.84rem;color:var(--text-secondary);line-height:1.7;margin:0 0 6px}.dungeon-videos{margin-top:16px;padding-top:16px;border-top:1px solid var(--border)}.dungeon-videos-heading{font-size:.85rem;font-weight:700;color:var(--text-primary);margin:0 0 12px}.dungeon-videos-list{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.dungeon-video{display:flex;flex-direction:column;gap:8px;padding:8px;background:var(--bg-primary);border:1px solid var(--border);border-radius:8px;text-decoration:none;transition:border-color .15s,background .15s}.dungeon-video:hover{border-color:red;background:#ff00000a}.dungeon-video-thumb{width:100%;aspect-ratio:16/9;border-radius:6px;object-fit:cover}.dungeon-video-info{display:flex;flex-direction:column;gap:3px;min-width:0}.dungeon-video-title{font-size:.75rem;font-weight:600;color:var(--text-primary);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.dungeon-video-channel{font-size:.65rem;color:var(--text-muted)}.dungeon-videos-loading{padding:16px;text-align:center}.dungeon-videos-empty{font-size:.8rem;color:var(--text-muted);margin:0}.dungeon-yt-search-link{display:inline-block;padding:8px 16px;border:1px solid rgba(255,0,0,.2);border-radius:6px;background:#ff00000f;color:#ef4444;font-size:.82rem;font-weight:600;text-decoration:none;transition:background .15s}.dungeon-yt-search-link:hover{background:#ff00001f}@media(max-width:600px){.dungeon-videos-list{grid-template-columns:1fr}.dungeon-video{flex-direction:row;gap:10px}.dungeon-video-thumb{width:120px;flex-shrink:0}}@media(max-width:600px){.page-nav{flex-direction:column;align-items:flex-start;gap:8px;padding:12px 14px}.page-nav-links{width:100%;flex-wrap:wrap;gap:4px}.page-nav-link{padding:5px 10px;font-size:.72rem}.page-content{padding:20px 14px}.page-title{font-size:1.3rem}.guide-slider-layout,.community-form-row{flex-direction:column}.community-toolbar{flex-direction:column;align-items:stretch}.community-write-btn{width:100%}}.lab-page{min-height:100vh;padding:20px;background:radial-gradient(ellipse at top left,rgba(139,92,246,.08),transparent 50%),radial-gradient(ellipse at bottom right,rgba(59,130,246,.08),transparent 50%),var(--bg-primary);color:var(--text-primary)}[data-theme=light] .lab-page{background:radial-gradient(ellipse at top left,rgba(124,58,237,.05),transparent 50%),radial-gradient(ellipse at bottom right,rgba(37,99,235,.05),transparent 50%),var(--bg-primary)}.lab-header{display:flex;align-items:center;gap:16px;padding:12px 20px;margin-bottom:20px;background:#ffffff08;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(139,92,246,.2);border-radius:14px;box-shadow:0 0 24px #8b5cf614;flex-wrap:wrap;min-width:0}.lab-header .header-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end;margin-left:auto}[data-theme=light] .lab-header{background:#fff9}.lab-back{color:var(--accent-purple);text-decoration:none;font-size:.9rem;font-weight:500}.lab-back:hover{text-decoration:underline}.lab-title{font-size:1.6rem;font-weight:800;letter-spacing:-.5px;color:var(--text-primary)}.lab-subtitle{font-size:.78rem;color:var(--text-muted);margin-left:4px}.lab-logo-area{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.lab-version-wrap{display:flex;align-items:center;gap:8px;margin-left:4px;position:relative}.lab-task-bonus{color:var(--accent-purple);font-weight:700;margin-left:2px}.lab-footer{margin-top:24px}.lab-nav-bar{margin-bottom:16px}.lab-patch-portal .patch-notes-backdrop{position:fixed;inset:0;background:#00000080;backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);z-index:99998}.lab-patch-portal .patch-notes{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);right:auto;width:380px;max-width:calc(100vw - 32px);max-height:calc(100vh - 80px);overflow-y:auto;z-index:99999;background:var(--bg-card);border:1px solid rgba(139,92,246,.4);border-radius:12px;padding:16px 18px;box-shadow:0 16px 48px #0009,0 0 32px #8b5cf640}[data-theme=light] .lab-patch-portal .patch-notes{box-shadow:0 16px 48px #00000040,0 0 32px #7c3aed2e;border-color:#7c3aed73}.lab-overall-progress{display:flex;align-items:center;gap:12px;padding:10px 16px;margin-bottom:16px;background:#ffffff0a;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(56,189,248,.3);border-radius:12px;box-shadow:0 0 20px #38bdf81a}[data-theme=light] .lab-overall-progress{background:#fff;border-color:#0ea5e966}.lab-overall-label{font-size:.78rem;font-weight:700;color:#38bdf8;white-space:nowrap}[data-theme=light] .lab-overall-label{color:#0284c7}.lab-overall-bar{flex:1;position:relative;height:18px;background:#00000040;border-radius:999px;overflow:hidden}[data-theme=light] .lab-overall-bar{background:#f0f2f5}.lab-overall-fill{position:absolute;inset:0 auto 0 0;background:linear-gradient(90deg,#0ea5e9,#38bdf8 50%,#7dd3fc);border-radius:999px;box-shadow:0 0 14px #38bdf880;transition:width .5s cubic-bezier(.4,0,.2,1)}.lab-overall-value{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:.78rem;font-weight:700;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.5);font-variant-numeric:tabular-nums}.lab-badge{font-size:.7rem;padding:4px 10px;border-radius:999px;background:#8b5cf626;color:var(--accent-purple);border:1px solid rgba(139,92,246,.3)}.lab-layout{display:grid;grid-template-columns:320px 1fr;gap:20px;align-items:start}.lab-sidebar{position:sticky;top:20px;display:flex;flex-direction:column;gap:12px;max-height:calc(100vh - 40px);overflow-y:auto;scrollbar-width:none;-ms-overflow-style:none;overscroll-behavior:contain}.lab-sidebar::-webkit-scrollbar{display:none}.lab-main{min-width:0;width:100%}.lab-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(440px,100%),1fr));gap:16px}.lab-glass-card{background:#ffffff0a;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(139,92,246,.18);border-radius:14px;padding:14px 16px;box-shadow:0 4px 24px #00000026,0 0 0 1px #ffffff05 inset,0 0 16px #8b5cf60f;transition:box-shadow .2s,border-color .2s}.lab-glass-card:hover{border-color:#8b5cf659;box-shadow:0 4px 28px #0003,0 0 24px #8b5cf61f}[data-theme=light] .lab-glass-card{background:#fff;border:1px solid var(--border);box-shadow:0 2px 12px #0000000f,0 0 0 1px #8b5cf60d}[data-theme=light] .lab-glass-card:hover{border-color:#7c3aed66;box-shadow:0 4px 20px #00000014,0 0 16px #7c3aed1a}.lab-section-header{display:flex;justify-content:space-between;align-items:center;cursor:pointer;-webkit-user-select:none;user-select:none;margin-bottom:8px}.lab-section-header:hover{opacity:.85}.lab-section-title{font-size:.95rem;font-weight:700;color:var(--text-primary);display:flex;align-items:center;gap:8px}.lab-section-tag{font-size:.65rem;padding:2px 8px;border-radius:999px;background:#8b5cf626;color:var(--accent-purple);font-weight:500}.lab-section-icon{width:22px;height:22px;object-fit:contain}.lab-toggle-bar-label{display:flex;align-items:center;gap:4px}.lab-toggle-bar-icon{width:18px;height:18px;object-fit:contain;vertical-align:middle}.lab-toggle-arrow{display:inline-block;font-size:.85em;color:var(--text-muted);transition:transform .2s}.lab-toggle-arrow.open{transform:rotate(90deg)}.lab-empty-note{font-size:.75rem;color:var(--text-muted);font-style:italic;padding:8px 0}.lab-shared-list,.lab-server-ticket-list{display:flex;flex-direction:column;gap:8px}.lab-server-ticket-row{background:#ffffff08;border:1px solid rgba(255,255,255,.05);border-radius:10px;padding:8px 10px}[data-theme=light] .lab-server-ticket-row{background:#f8f9fc;border:1px solid var(--border)}.lab-server-ticket-label{font-size:.78rem;font-weight:600;color:var(--text-primary);margin-bottom:5px}.lab-server-ticket-inputs{display:flex;gap:6px}.lab-server-ticket-field{flex:1;display:flex;align-items:center;gap:4px;background:#00000026;border:1px solid rgba(255,255,255,.05);border-radius:6px;padding:3px 6px}[data-theme=light] .lab-server-ticket-field{background:#0000000a}.lab-server-ticket-field input{width:100%;min-width:0;background:transparent;border:none;color:var(--text-primary);font-size:.8rem;font-weight:600;text-align:center;outline:none;font-variant-numeric:tabular-nums;-moz-appearance:textfield}.lab-server-ticket-field input::-webkit-outer-spin-button,.lab-server-ticket-field input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.lab-number-field{display:flex;align-items:center;gap:2px;flex:1;min-width:0}.lab-number-field input{flex:1;min-width:0}.lab-num-btn{width:18px;height:18px;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;background:#8b5cf626;border:1px solid rgba(139,92,246,.3);border-radius:4px;color:var(--accent-purple);cursor:pointer;flex-shrink:0;padding:0;line-height:1}.lab-num-btn:hover{background:#8b5cf64d}[data-theme=light] .lab-num-btn{background:#7c3aed1a;border-color:#7c3aed4d}.lab-server-ticket-hint{font-size:.62rem;color:var(--text-muted);white-space:nowrap}.lab-server-ticket-hint.plus{color:var(--accent-purple);font-weight:600}.lab-server-ticket-max{font-size:.62rem;color:var(--text-muted)}.lab-kina-panel{display:flex;flex-direction:column;gap:8px;margin-top:4px;padding:10px;background:#f59e0b0f;border:1px solid rgba(245,158,11,.2);border-radius:10px}[data-theme=light] .lab-kina-panel{background:#f59e0b14;border-color:#d977064d}.lab-kina-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2px}.lab-kina-title{font-size:.78rem;font-weight:700;color:#f59e0b;display:inline-flex;align-items:center;gap:5px}[data-theme=light] .lab-kina-title{color:#d97706}.lab-kina-info{position:relative;display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;border-radius:50%;background:#f59e0b26;border:1px solid rgba(245,158,11,.4);color:#f59e0b;font-size:.62rem;font-weight:700;cursor:help;font-family:ui-sans-serif,system-ui,sans-serif}[data-theme=light] .lab-kina-info{background:#d977061a;border-color:#d9770666;color:#d97706}.lab-kina-tooltip,.lab-kina-tooltip-portal{position:absolute;display:flex;flex-direction:column;gap:4px;padding:8px 10px;min-width:220px;background:#1a1f35;border:1px solid rgba(245,158,11,.35);border-radius:8px;box-shadow:0 8px 24px #0006,0 0 16px #f59e0b26;font-size:.7rem;font-weight:500;color:#e2e8f0;white-space:nowrap;z-index:100;pointer-events:none}.lab-kina-tooltip-portal{position:fixed;z-index:99999}[data-theme=light] .lab-kina-tooltip,[data-theme=light] .lab-kina-tooltip-portal{background:#fff;border-color:#d9770673;color:#1a1a2e;box-shadow:0 8px 24px #00000026,0 0 16px #d9770626}.lab-kina-info:hover .lab-kina-tooltip{display:flex}.lab-kina-tooltip:before{content:"";position:absolute;top:-5px;left:8px;transform:rotate(45deg);width:8px;height:8px;background:#1a1f35;border-left:1px solid rgba(245,158,11,.35);border-top:1px solid rgba(245,158,11,.35)}[data-theme=light] .lab-kina-tooltip:before{background:#fff;border-left-color:#d9770673;border-top-color:#d9770673}.lab-kina-tooltip-row{display:block}.lab-kina-help{font-size:.62rem;color:var(--text-muted)}.lab-kina-row{display:flex;flex-direction:column;gap:3px;padding:6px 8px;background:#0000002e;border-radius:8px;border-left:3px solid #10b981}[data-theme=light] .lab-kina-row{background:#ffffffb3}.lab-kina-row.r100{border-left-color:#10b981}.lab-kina-row.r80{border-left-color:#84cc16}.lab-kina-row.r60{border-left-color:#eab308}.lab-kina-row.r40{border-left-color:#f97316}.lab-kina-row.r20{border-left-color:#ef4444}.lab-kina-row-top{display:flex;justify-content:space-between;align-items:baseline}.lab-kina-label{font-size:.74rem;font-weight:600;color:var(--text-primary)}.lab-kina-rate{font-size:.95rem;font-weight:800;font-variant-numeric:tabular-nums}.lab-kina-row.r100 .lab-kina-rate{color:#10b981}.lab-kina-row.r80 .lab-kina-rate{color:#84cc16}.lab-kina-row.r60 .lab-kina-rate{color:#eab308}.lab-kina-row.r40 .lab-kina-rate{color:#f97316}.lab-kina-row.r20 .lab-kina-rate{color:#ef4444}.lab-kina-row-mid{display:flex;justify-content:space-between;align-items:center;font-size:.66rem;color:var(--text-muted)}.lab-kina-count{font-weight:600;color:var(--text-secondary);font-variant-numeric:tabular-nums}.lab-kina-bar{height:4px;background:#ffffff0f;border-radius:999px;overflow:hidden}[data-theme=light] .lab-kina-bar{background:#0000000f}.lab-kina-bar-fill{height:100%;border-radius:999px;transition:width .4s cubic-bezier(.4,0,.2,1)}.lab-kina-row.r100 .lab-kina-bar-fill{background:linear-gradient(90deg,#10b981,#34d399)}.lab-kina-row.r80 .lab-kina-bar-fill{background:linear-gradient(90deg,#84cc16,#a3e635)}.lab-kina-row.r60 .lab-kina-bar-fill{background:linear-gradient(90deg,#eab308,#facc15)}.lab-kina-row.r40 .lab-kina-bar-fill{background:linear-gradient(90deg,#f97316,#fb923c)}.lab-kina-row.r20 .lab-kina-bar-fill{background:linear-gradient(90deg,#ef4444,#f87171)}.lab-events{display:flex;flex-direction:column;gap:8px}.lab-event-btn{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:#8b5cf614;border:1px solid rgba(139,92,246,.25);border-radius:8px;color:var(--text-primary);text-decoration:none;font-size:.82rem;font-weight:500;transition:all .15s}.lab-event-btn:hover{background:#8b5cf62e;border-color:#8b5cf673;box-shadow:0 0 12px #8b5cf626}.lab-event-arrow{color:var(--accent-purple);font-size:.9rem}.lab-coupon-block{display:flex;flex-direction:column;gap:6px;margin-top:4px}.lab-coupon-row{display:flex;align-items:center;gap:6px;padding:6px 8px;background:#00000026;border-radius:8px;border:1px solid rgba(255,255,255,.05)}[data-theme=light] .lab-coupon-row{background:#0000000a}.lab-coupon-label{font-size:.68rem;color:var(--text-muted);white-space:nowrap}.lab-coupon-code{flex:1;font-size:.75rem;font-weight:600;color:var(--accent-purple);background:#8b5cf61a;padding:2px 6px;border-radius:4px;letter-spacing:.3px;min-width:0;overflow:hidden;text-overflow:ellipsis}.lab-coupon-copy{padding:3px 8px;font-size:.68rem;background:transparent;color:var(--accent-purple);border:1px solid var(--accent-purple);border-radius:5px;cursor:pointer;white-space:nowrap;transition:all .15s}.lab-coupon-copy:hover,.lab-coupon-copy.copied{background:var(--accent-purple);color:#fff}.lab-task-row{background:#ffffff08;border:1px solid rgba(255,255,255,.05);border-radius:10px;padding:8px 10px;transition:all .15s}.lab-task-row:hover{border-color:#8b5cf640}[data-theme=light] .lab-task-row{background:#f8f9fc;border:1px solid var(--border)}[data-theme=light] .lab-task-row:hover{border-color:#7c3aed66}[data-theme=light] .lab-task-row.done{background:#10b98114;border-color:#10b98166}.lab-task-row.done{background:#10b98114;border-color:#10b9814d}.lab-task-info{display:grid;grid-template-columns:1fr auto auto;align-items:center;gap:8px;margin-bottom:6px}.lab-task-name{font-size:.8rem;font-weight:500;color:var(--text-primary);display:flex;align-items:center;gap:6px;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lab-task-count{font-size:.74rem;color:var(--text-muted);font-variant-numeric:tabular-nums;min-width:60px;text-align:right;white-space:nowrap}.lab-check{display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;border-radius:50%;background:#10b981;color:#fff;font-size:.6rem;font-weight:700;box-shadow:0 0 8px #10b98180;animation:lab-check-pop .3s ease-out}@keyframes lab-check-pop{0%{transform:scale(0)}60%{transform:scale(1.3)}to{transform:scale(1)}}.lab-task-bar{height:4px;background:#ffffff0f;border-radius:999px;overflow:hidden;margin-bottom:6px}.lab-task-bar-fill{height:100%;background:linear-gradient(90deg,var(--accent-purple),#3b82f6);border-radius:999px;transition:width .4s cubic-bezier(.4,0,.2,1)}.lab-task-actions{display:grid;grid-template-columns:repeat(4,1fr);gap:4px;width:100%}.lab-task-actions button,.lab-mini-actions button{padding:0;width:100%;height:22px;font-size:.82rem;background:#8b5cf61f;border:1px solid rgba(139,92,246,.3);border-radius:5px;color:var(--accent-purple);cursor:pointer;transition:all .12s;font-weight:700;display:inline-flex;align-items:center;justify-content:center;line-height:1}.lab-task-actions button:hover,.lab-mini-actions button:hover{background:#8b5cf647;transform:scale(1.05)}[data-theme=light] .lab-task-actions button,[data-theme=light] .lab-mini-actions button{background:#7c3aed1a;border-color:#7c3aed4d}.lab-reset-btn{color:#f59e0b!important;border-color:#f59e0b4d!important;background:#f59e0b14!important}.lab-reset-btn:hover{background:#f59e0b33!important}.lab-complete-btn{color:#10b981!important;border-color:#10b98159!important;background:#10b9811a!important}.lab-complete-btn:hover{background:#10b98140!important;box-shadow:0 0 8px #10b98159}.lab-char-card{background:#ffffff0a;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(139,92,246,.18);border-radius:16px;padding:16px;display:flex;flex-direction:column;gap:12px;cursor:pointer;transition:all .2s;box-shadow:0 4px 24px #00000026,0 0 16px #8b5cf60d}[data-theme=light] .lab-char-card{background:#fff;border:1px solid var(--border);box-shadow:0 2px 16px #0000000f,0 0 0 1px #8b5cf60a}[data-theme=light] .lab-char-card:hover{border-color:#7c3aed66;box-shadow:0 6px 24px #0000001a,0 0 22px #7c3aed1f}[data-theme=light] .lab-char-card.active{border-color:#7c3aed99;box-shadow:0 8px 28px #0000001f,0 0 28px #7c3aed33,0 0 0 1px #7c3aed80 inset}.lab-char-card:hover{transform:translateY(-2px);border-color:#8b5cf659;box-shadow:0 8px 32px #0003,0 0 28px #8b5cf626}.lab-char-card.active{border-color:#8b5cf699;box-shadow:0 8px 32px #00000040,0 0 32px #8b5cf640,0 0 0 1px #8b5cf666 inset}.lab-char-header{display:flex;justify-content:space-between;align-items:center;gap:8px}.lab-char-collapse-btn{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:#8b5cf61a;border:1px solid rgba(139,92,246,.25);border-radius:6px;color:var(--accent-purple);cursor:pointer;flex-shrink:0}.lab-char-collapse-btn:hover{background:#8b5cf633}.lab-char-name{font-size:1.05rem;font-weight:700;display:flex;align-items:baseline;gap:4px}.lab-char-name-wrap{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.lab-char-server{font-size:.75rem;font-weight:500;color:var(--text-muted)}.lab-char-plaync{display:flex;align-items:center;gap:6px;font-size:.72rem;flex-wrap:wrap}.lab-char-plaync.loading{opacity:.6}.lab-plaync-cp{font-weight:700;color:#f59e0b;font-variant-numeric:tabular-nums}[data-theme=light] .lab-plaync-cp{color:#d97706}.lab-plaync-il{color:var(--accent-purple);font-weight:600;font-variant-numeric:tabular-nums}.lab-plaync-class{color:var(--text-muted);padding:1px 6px;background:#8b5cf61a;border-radius:4px;font-size:.65rem}[data-theme=light] .lab-plaync-class{background:#7c3aed14}.lab-plaync-loading{color:var(--text-muted);font-style:italic}.lab-char-card.collapsed{padding-bottom:14px}.lab-char-name{font-size:1.05rem;font-weight:700;color:var(--text-primary)}.lab-char-name-input{font-size:1.05rem;font-weight:700;background:#ffffff0d;border:1px solid var(--accent-purple);border-radius:6px;color:var(--text-primary);padding:2px 8px;outline:none}.lab-char-meta{display:flex;gap:6px}.lab-char-del{width:22px;height:22px;border-radius:50%;background:#ef44441f;border:1px solid rgba(239,68,68,.3);color:#ef4444;font-size:.85rem;cursor:pointer;display:flex;align-items:center;justify-content:center}.lab-char-del:hover{background:#ef444440}.lab-progress-row{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.lab-gauge{display:flex;flex-direction:column;gap:4px}.lab-gauge-label{font-size:.68rem;color:var(--text-muted);text-align:center}.lab-gauge-track{height:6px;background:#ffffff0f;border-radius:999px;overflow:hidden}.lab-gauge-fill{height:100%;border-radius:999px;transition:width .5s cubic-bezier(.4,0,.2,1)}.lab-gauge-value{font-size:.7rem;font-weight:600;text-align:center;color:var(--text-primary);font-variant-numeric:tabular-nums}.lab-toggle-bar{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:#8b5cf60f;border-radius:8px;font-size:.78rem;color:var(--text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none;border:1px solid rgba(139,92,246,.25)}.lab-toggle-bar:hover{background:#8b5cf614}.lab-ode-ticket-area{display:flex;flex-direction:column;gap:8px;padding:10px;background:#00000026;border-radius:8px;border:1px solid rgba(139,92,246,.2);width:100%;max-width:100%;overflow:hidden;min-width:0}[data-theme=light] .lab-ode-ticket-area{background:#0000000a}.lab-ode-ticket-area .ticket-panel{padding:8px;margin:0;width:100%;max-width:100%;box-sizing:border-box}.lab-ode-ticket-area .ticket-panel-top{margin-bottom:4px}.lab-ode-ticket-area .ticket-row-top{flex-direction:column;gap:8px}.lab-ode-ticket-area .ticket-group{width:100%;flex-wrap:wrap}.lab-ode-ticket-area .ticket-inputs-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:6px}.lab-ode-ticket-area .ticket-field{min-width:0}.lab-ode-ticket-area .ode-display-total{font-size:.7rem}.lab-char-card{min-width:0;overflow:hidden}[data-theme=light] .lab-ode-ticket-area{background:#0000000a;border-color:#8b5cf633}[data-theme=light] .lab-toggle-bar{background:#8b5cf60f;border-color:#8b5cf633;color:var(--text-secondary)}.lab-ode-row{display:flex;flex-direction:column;gap:4px}.lab-ode-label{font-size:.72rem;color:var(--text-muted);display:flex;align-items:center;gap:4px}.lab-mem-tag{font-size:.6rem;padding:1px 5px;background:var(--accent-purple);color:#fff;border-radius:4px}.lab-ode-bar{position:relative;height:18px;background:#ffffff0d;border-radius:6px;overflow:hidden}.lab-ode-bar-fill{position:absolute;inset:0 auto 0 0;background:linear-gradient(90deg,#10b981,#3b82f6);border-radius:6px;box-shadow:0 0 12px #3b82f666;transition:width .4s ease}.lab-ode-text{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:600;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.6);font-variant-numeric:tabular-nums}.lab-ode-actions{display:flex;gap:4px;justify-content:flex-end}.lab-ode-actions button{padding:2px 8px;font-size:.7rem;background:#10b9811f;border:1px solid rgba(16,185,129,.3);color:#10b981;border-radius:5px;cursor:pointer}.lab-ticket-mini-title{font-size:.72rem;color:var(--text-muted);margin-bottom:4px}.lab-ticket-mini-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:4px}.lab-ticket-chip{display:flex;justify-content:space-between;padding:3px 8px;background:#ffffff0d;border-radius:5px;font-size:.68rem}.lab-ticket-num{color:var(--accent-purple);font-weight:700;font-variant-numeric:tabular-nums}.lab-task-section-title{font-size:.78rem;font-weight:600;color:var(--accent-purple);margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}.lab-mini-task-list{display:flex;flex-direction:column;gap:5px}.lab-mini-task-list-2col{display:grid;grid-template-columns:1fr 1fr;gap:5px 8px}.lab-mini-task-list-1col{display:flex;flex-direction:column;gap:5px}.lab-mini-row{display:flex;flex-direction:column;gap:4px;padding:8px 10px;background:#ffffff08;border-radius:8px;border:1px solid rgba(255,255,255,.04);transition:all .15s}.lab-mini-row:hover{border-color:#8b5cf633}.lab-mini-row.done{background:#10b98114;border-color:#10b98140}[data-theme=light] .lab-mini-row{background:#f8f9fc;border:1px solid var(--border)}[data-theme=light] .lab-mini-row:hover{border-color:#7c3aed59}[data-theme=light] .lab-mini-row.done{background:#10b9811a;border-color:#10b98166}.lab-mini-info{display:grid;grid-template-columns:1fr auto auto;align-items:center;gap:6px}.lab-mini-name{font-size:.78rem;font-weight:500;display:flex;align-items:center;gap:4px;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lab-mini-count{font-size:.74rem;color:var(--text-muted);font-variant-numeric:tabular-nums;min-width:56px;text-align:right;white-space:nowrap}.lab-mini-bar{height:4px;background:#ffffff0f;border-radius:999px;overflow:hidden}.lab-mini-bar-fill{height:100%;background:linear-gradient(90deg,var(--accent-purple),#3b82f6);transition:width .4s cubic-bezier(.4,0,.2,1)}.lab-mini-actions{display:grid;grid-template-columns:repeat(4,1fr);gap:4px;width:100%}.lab-mini-actions button{width:100%!important;height:20px!important;padding:0!important;font-size:.78rem!important;display:flex;align-items:center;justify-content:center;font-weight:700;border-radius:5px;line-height:1}.lab-mini-remove{width:16px;height:16px;display:flex;align-items:center;justify-content:center;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:4px;color:#ef4444;font-size:.7rem;cursor:pointer;padding:0;line-height:1}.lab-mini-remove:hover{background:#ef444440}.lab-add-wrap{margin-top:6px}.lab-add-wrap .custom-add-btn{width:100%;padding:8px;background:transparent;border:1.5px dashed rgba(139,92,246,.4);border-radius:8px;color:var(--accent-purple);font-size:.75rem;cursor:pointer;transition:all .15s}.lab-add-wrap .custom-add-btn:hover{background:#8b5cf614;border-color:#8b5cf699;border-style:solid}.lab-add-item-btn{width:100%;padding:8px;margin-top:6px;background:transparent;border:1.5px dashed rgba(139,92,246,.4);border-radius:8px;color:var(--accent-purple);font-size:.75rem;cursor:pointer;transition:all .15s}.lab-add-item-btn:hover{background:#8b5cf614;border-color:#8b5cf699;border-style:solid}.lab-add-card{background:transparent;border:2px dashed rgba(139,92,246,.35);border-radius:16px;padding:40px 20px;color:var(--accent-purple);font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s;min-height:220px;display:flex;align-items:center;justify-content:center}.lab-add-card:hover{background:#8b5cf60f;border-color:#8b5cf699;border-style:solid;box-shadow:0 0 24px #8b5cf626}.lab-char-reset-btn{margin-top:4px;padding:6px;background:#f59e0b14;border:1px solid rgba(245,158,11,.3);color:#f59e0b;border-radius:8px;font-size:.72rem;cursor:pointer;transition:all .15s}.lab-char-reset-btn:hover{background:#f59e0b2e}.char-search-overlay{position:fixed;inset:0;background:#000000b3;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.char-search-modal{width:100%;max-width:480px;max-height:80vh;background:var(--bg-card);border:1px solid var(--border);border-radius:14px;box-shadow:0 20px 60px #00000080,0 0 32px #8b5cf626;display:flex;flex-direction:column;overflow:hidden}[data-theme=light] .char-search-modal{background:#fff;box-shadow:0 20px 60px #0003}.char-search-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border)}.char-search-header h2{font-size:1.05rem;font-weight:700;color:var(--text-primary)}.char-search-close{width:28px;height:28px;background:transparent;border:none;color:var(--text-muted);font-size:1.5rem;cursor:pointer;border-radius:6px;display:flex;align-items:center;justify-content:center;line-height:1}.char-search-close:hover{background:#ffffff0d;color:var(--text-primary)}.char-search-body{padding:16px 20px;overflow-y:auto}.char-search-section-title{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--accent-purple);margin-bottom:8px}.char-search-form{display:flex;gap:8px;margin-bottom:8px}.char-search-input{flex:1;padding:9px 12px;background:#00000026;border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:.85rem;outline:none}.char-search-input:focus{border-color:var(--accent-purple);box-shadow:0 0 0 2px #8b5cf626}[data-theme=light] .char-search-input{background:#f8f9fc}.char-search-btn{padding:9px 16px;background:var(--accent-purple);color:#fff;border:none;border-radius:8px;font-size:.82rem;font-weight:600;cursor:pointer;white-space:nowrap}.char-search-btn:disabled{opacity:.5;cursor:not-allowed}.char-search-btn:hover:not(:disabled){filter:brightness(1.1)}.char-search-btn.manual{background:transparent;color:var(--accent-purple);border:1px solid var(--accent-purple)}.char-search-error{padding:8px 12px;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:6px;font-size:.75rem;color:#ef4444;margin-bottom:8px}.char-search-results-meta{font-size:.7rem;color:var(--text-muted);margin-bottom:6px}.char-search-list{display:flex;flex-direction:column;gap:6px;list-style:none;padding:0;margin:0;max-height:280px;overflow-y:auto}.char-search-item{padding:10px 12px;background:#00000026;border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:all .15s}[data-theme=light] .char-search-item{background:#f8f9fc}.char-search-item:hover{border-color:var(--accent-purple);background:#8b5cf614}.char-search-item.selecting{border-color:var(--accent-purple);background:#8b5cf626}.char-search-item-main{display:flex;justify-content:space-between;align-items:baseline;gap:8px}.char-search-item-name{font-size:.9rem;font-weight:700;color:var(--text-primary)}.char-search-item-server{font-size:.72rem;color:var(--accent-purple);font-weight:600;padding:2px 8px;background:#8b5cf61f;border-radius:999px}.char-search-item-sub{font-size:.7rem;color:var(--text-muted);margin-top:3px;display:flex;justify-content:space-between}.char-search-loading{color:var(--accent-purple);font-weight:600}.char-search-divider{position:relative;text-align:center;margin:16px 0;font-size:.7rem;color:var(--text-muted)}.char-search-divider:before,.char-search-divider:after{content:"";position:absolute;top:50%;width:40%;height:1px;background:var(--border)}.char-search-divider:before{left:0}.char-search-divider:after{right:0}.char-search-divider span{background:var(--bg-card);padding:0 10px;position:relative}[data-theme=light] .char-search-divider span{background:#fff}@media(max-width:1024px){.lab-layout{grid-template-columns:1fr}.lab-sidebar{position:static;max-height:none}}@media(max-width:900px){.lab-page{padding:12px}.lab-header{flex-wrap:wrap;padding:10px 12px;gap:10px}.lab-logo-area{width:100%;justify-content:flex-start;gap:6px}.lab-title{font-size:1.3rem}.lab-subtitle{display:none}.lab-header .header-actions{width:100%;margin-left:0;justify-content:flex-start;gap:6px}.lab-header .login-hint{display:none}.lab-header .user-email{max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lab-grid{grid-template-columns:1fr}}@media(max-width:600px){.lab-mini-task-list-2col{grid-template-columns:1fr}.lab-char-card{padding:12px;gap:10px}.lab-overall-progress{padding:8px 12px;gap:8px}.lab-overall-label{font-size:.72rem}.lab-progress-row{gap:6px}.lab-gauge-label{font-size:.62rem}.lab-gauge-value{font-size:.66rem}}@media(max-width:480px){.lab-header .user-email{max-width:80px;font-size:.7rem}.lab-header .header-actions{gap:4px}.lab-header .lang-switcher .lang-btn{padding:4px 6px;font-size:.7rem}.last-saved{font-size:.65rem}.lab-mini-count,.lab-task-count{min-width:48px;font-size:.68rem}.lab-mini-name,.lab-task-name{font-size:.74rem}.lab-char-name{font-size:.95rem}.lab-char-plaync{font-size:.66rem}.lab-num-btn{width:16px;height:16px;font-size:.68rem}}@media(max-width:600px){.char-search-overlay{padding:12px}.char-search-modal{max-height:90vh}.char-search-header,.char-search-body{padding:12px 16px}.char-search-list{max-height:50vh}}@media(max-width:360px){.lab-page{padding:8px}.lab-header{padding:8px 10px}.lab-title{font-size:1.1rem}.last-saved{display:none}.lab-glass-card{padding:10px 12px}.lab-server-ticket-inputs{flex-direction:column;gap:4px}}
