*{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;--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;--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-a{font-size:2rem}.logo-sub{font-size:.75rem;color:var(--text-muted);letter-spacing:.5px}.logo-version{font-size:.65rem;color:var(--accent-purple);background:#8b5cf61f;padding:1px 6px;border-radius:4px;font-weight:600;letter-spacing:.5px}.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}.ad-banner{background:var(--bg-secondary);border-bottom:1px solid var(--border);padding:8px 20px;text-align:center}.ad-text{font-size:.75rem;color:var(--text-muted);font-style:italic}.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)}.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-panel{background:var(--bg-card);border-radius:12px;border:1px solid var(--border);overflow:hidden}.guide-toggle{width:100%;padding:12px 16px;border:none;background:transparent;color:var(--text-secondary);font-size:.88rem;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:8px;font-family:inherit;transition:color .2s}.guide-toggle:hover{color:var(--text-primary)}.guide-toggle-icon{width:20px;height:20px;border-radius:50%;background:var(--accent-gradient);color:#fff;font-size:.75rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.guide-arrow{margin-left:auto;font-size:.65rem;color:var(--text-muted)}.guide-content{padding:0 16px 14px}.guide-list{list-style:none;display:flex;flex-direction:column;gap:6px;padding:0;margin:0}.guide-list li{font-size:.78rem;color:var(--text-secondary);line-height:1.5;padding-left:14px;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-disclaimer{margin-top:10px;padding-top:10px;border-top:1px solid var(--border);font-size:.85rem;color:var(--text-muted);line-height:1.5;text-align:center}.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}.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;background:var(--bg-secondary);border-radius:8px;border:1px solid transparent;transition:background .2s,border-color .2s,opacity .2s;cursor:default}.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:.3;transition:opacity .15s;-webkit-user-select:none;user-select:none;flex-shrink:0}.task-item:hover .drag-handle{opacity:.7}.drag-handle:active{cursor:grabbing}.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:48px;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}.custom-select{padding:6px 8px;border-radius:6px;border:1px solid var(--border);background:var(--bg-primary);color:var(--text-primary);font-size:.85rem;font-family:inherit;outline:none;cursor:pointer}.custom-select:focus{border-color:var(--accent-blue)}.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-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-toggle{position:relative;display:inline-block;width:36px;height:20px;cursor:pointer;flex-shrink:0}.alarm-toggle input{opacity:0;width:0;height:0;position:absolute}.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;padding:20px;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;margin-bottom:16px}.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}.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}.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}.edit-btn,.save-btn{font-size:.75rem;padding:4px 10px;border-radius:6px;border:1px solid var(--accent-blue);background:#3b82f61a;color:var(--accent-blue);cursor:pointer;font-weight:600;font-family:inherit}.edit-btn:hover,.save-btn:hover{background:#3b82f633}.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}.char-edit-row{display:flex;gap:8px;align-items:center}.char-name-input{flex:1;padding:6px 10px;border-radius:6px;border:1px solid var(--accent-blue);background:var(--bg-primary);color:var(--text-primary);font-size:.9rem;font-family:inherit;outline:none}.char-name-input:focus{box-shadow:0 0 0 2px #3b82f64d}.app-footer{padding:16px 20px 24px;display:flex;justify-content:center;gap:12px;align-items:center;flex-wrap:wrap}.footer-contact{width:100%;text-align:center;font-size:.75rem;color:var(--text-muted);font-style:italic;margin-top:4px}.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:480px){.task-item{flex-direction:column;align-items:flex-start;gap:8px}.task-right{align-self:flex-end}.logo-area{flex-direction:column;gap:2px}.logo{font-size:1.5rem}.logo-a{font-size:1.7rem}}.toast-container{position:fixed;top:16px;right:16px;z-index:9999;display:flex;flex-direction:column;gap:8px;pointer-events:none;max-width:360px;width:calc(100% - 32px)}.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-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;display:flex;gap:16px;flex-wrap:wrap;align-items:flex-start}.ticket-group{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.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-inputs{display:flex;align-items:center;gap:4px;flex-wrap:wrap}.ticket-field{display:flex;align-items:center;gap:3px}.ticket-label{font-size:.72rem;color:var(--text-muted);white-space:nowrap}.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:10}.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(--accent-purple);margin-right:2px}.loading-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-primary)}.loading-content{text-align:center;display:flex;flex-direction:column;align-items:center;gap:16px}.loading-logo{font-size:2.2rem;font-weight:800;letter-spacing:-1px;background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.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:center;justify-content:center;z-index:300;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);padding:20px}.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}.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}.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)}.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)}
