:root{--font-serif:"Noto Serif SC", "Georgia", serif;--font-mono:"Consolas", "Menlo", monospace;--font-size:16px;--ease-out:cubic-bezier(.16, 1, .3, 1);--dur-fast:.15s;--dur-normal:.3s;--dur-slow:.55s;--dur-line:.42s;--z-toast:100;--bg-base-override:var(--bg-base);--theme-color:#b9872f;--accent:color-mix(in srgb, var(--theme-color) 84%, black);--accent-dim:color-mix(in srgb, var(--theme-color) 14%, transparent);--border-focus:color-mix(in srgb, var(--theme-color) 62%, transparent);--scrollbar:color-mix(in srgb, var(--theme-color) 24%, transparent)}[data-theme=dark]{--bg-base:#0c0e13;--bg-surface:#12151d;--bg-elevated:#191d27;--bg-hover:#ffffff0d;--border:#ffffff0f;--text-primary:#c5c5c5;--text-secondary:#9c9c9c;--text-muted:#4e4840;--text-inverse:#0c0e13;--success:#5a9f6e;--danger:#c45858;--danger-bg:#c458580f;--overlay-bg:#000000a6;--shadow-md:0 6px 24px #0006;--shadow-lg:0 20px 56px #0009;--log-req:#5a9f6e12;--log-res:#5a789f12;--log-err:#c4585817}[data-theme=light]{--bg-base:#f4efe6;--bg-surface:#faf6ee;--bg-elevated:#fff;--bg-hover:#0000000a;--border:#00000014;--text-primary:#2a1f0e;--text-secondary:#6b5a40;--text-muted:#b0997a;--text-inverse:#faf6ee;--success:#2e7d4f;--danger:#9b2828;--danger-bg:#9b28280f;--overlay-bg:#000000a6;--shadow-md:0 6px 24px #0000001a;--shadow-lg:0 20px 56px #00000026;--log-req:#2e7d4f0f;--log-res:#1e508c0f;--log-err:#9b282812}*,:before,:after{box-sizing:border-box;-webkit-user-select:none;user-select:none;margin:0;padding:0}.story-line,.story-line *,.player-choice-text,.choice-text,.textarea,.input,.edit-textarea,.custom-choice-input{-webkit-user-select:text;user-select:text}html{overscroll-behavior:none;-webkit-tap-highlight-color:transparent;touch-action:pan-x pan-y;height:100%;overflow:hidden}body{overscroll-behavior:none;height:100%;font-family:var(--font-serif);font-size:var(--font-size);background:var(--bg-base-override,var(--bg-base));color:var(--text-primary);-webkit-font-smoothing:antialiased;touch-action:pan-x pan-y;line-height:1.8;overflow:hidden}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--scrollbar);border-radius:2px}::selection{background:var(--selection-bg,var(--accent-dim));color:var(--text-primary)}#app{flex-direction:column;height:100%;display:flex;position:relative;overflow:hidden}.hidden{display:none!important}.material-symbols-rounded{font-variation-settings:"FILL" 0, "wght" 300, "GRAD" 0, "opsz" 24;vertical-align:-3px;-webkit-user-select:none;user-select:none;flex-shrink:0;font-size:18px;line-height:1}.screen{background:var(--bg-base-override,var(--bg-base));flex-direction:column;min-width:0;min-height:0;display:flex;position:absolute;inset:0}.screen-enter-right{animation:slide-in-right var(--dur-slow) var(--ease-out) both}.screen-exit-left{animation:slide-out-left var(--dur-slow) var(--ease-out) both}.screen-enter-left{animation:slide-in-left var(--dur-slow) var(--ease-out) both}.screen-exit-right{animation:slide-out-right var(--dur-slow) var(--ease-out) both}.screen-fade-in{animation:fadeIn var(--dur-slow) ease both}@keyframes slide-in-right{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@keyframes slide-out-left{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(-24%)}}@keyframes slide-in-left{0%{opacity:0;transform:translate(-24%)}to{opacity:1;transform:translate(0)}}@keyframes slide-out-right{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(100%)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.top-bar{padding:0 max(10px, env(safe-area-inset-left)) 0 max(10px, env(safe-area-inset-right));background:var(--bg-base-override,var(--bg-base));flex-shrink:0;align-items:center;gap:5px;min-width:0;min-height:50px;display:flex}.top-bar-back{color:var(--accent);cursor:pointer;font-size:14px;font-family:var(--font-serif);transition:background var(--dur-fast) ease;background:0 0;border:none;border-radius:6px;align-items:center;gap:5px;padding:6px 10px;display:flex}.top-bar-back:hover{background:var(--bg-hover)}.top-bar-title{color:var(--accent);letter-spacing:1px;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-size:14px;overflow:hidden}.top-bar-logo{color:var(--accent);letter-spacing:2px;font-size:18px;font-weight:700}.top-bar-game-title{color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;flex-shrink:0;max-width:140px;font-size:12px;overflow:hidden}.top-bar-actions{flex-shrink:0;align-items:center;gap:4px;margin-left:auto;display:flex}.game-top-main{flex:1;align-items:center;gap:10px;min-width:0;display:flex}.game-top-status{align-items:center;gap:10px;min-width:0;display:flex;overflow:hidden}.btn{font-family:var(--font-serif);color:var(--text-secondary);cursor:pointer;transition:background var(--dur-fast) ease, color var(--dur-fast) ease, opacity var(--dur-fast) ease;white-space:nowrap;-webkit-user-select:none;user-select:none;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;gap:5px;min-width:32px;min-height:32px;padding:8px 10px;font-size:14px;text-decoration:none;display:inline-flex}.btn:focus-visible,.choice-btn:focus-visible,.settings-tab:focus-visible,.color-swatch:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.btn:hover{background:var(--bg-hover);color:var(--text-primary)}.btn:active{opacity:.75}.btn.active{background:var(--accent-dim);color:var(--accent)}.btn[disabled]{opacity:.45;cursor:not-allowed;pointer-events:none}.btn-primary{background:var(--accent);color:var(--text-inverse)!important}.btn-primary:hover{filter:brightness(1.06);background:var(--accent)!important;color:var(--text-inverse)!important}.btn-primary:active{opacity:.85;filter:none}.btn-ghost{background:0 0}.btn-ghost:hover{background:var(--bg-hover)}.btn.active:hover{background:var(--accent-dim);color:var(--accent)}.btn-danger{color:var(--danger)}.btn-danger:hover{background:var(--danger-bg);color:var(--danger)}.btn-sm{padding:4px 11px;font-size:14px}.btn-icon{aspect-ratio:1;padding:8px}.field{flex-direction:column;gap:5px;display:flex}.field-row{align-items:flex-end;gap:10px;min-width:0;display:flex}.field-label{color:var(--text-secondary);letter-spacing:0;align-items:center;gap:5px;font-size:12px;display:flex}.field-hint{color:var(--text-muted);font-size:12px}.input,.textarea,.select{border:1px solid var(--border);width:100%;font-family:var(--font-serif);color:var(--text-primary);background:var(--bg-elevated);transition:border-color var(--dur-fast) ease, box-shadow var(--dur-fast) ease;resize:none;-webkit-appearance:none;border-radius:8px;outline:none;padding:8px 15px;font-size:14px}.input:focus,.textarea:focus,.select:focus{border-color:var(--accent);box-shadow:0 0 4px var(--accent-dim)}.input::placeholder,.textarea::placeholder{color:var(--text-muted)}.textarea{min-height:50px;line-height:1.5}.input-error{border-color:var(--danger)!important;box-shadow:0 0 4px var(--danger-bg)!important}.select{cursor:pointer;appearance:none;padding-right:34px}.select-wrapper{width:100%;display:flex;position:relative}.select-wrapper:after{content:"expand_more";pointer-events:none;color:var(--accent);font-family:Material Symbols Rounded;font-size:20px;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.switch{flex-shrink:0;width:44px;height:24px;display:inline-block;position:relative}.switch input{opacity:0;width:0;height:0}.switch-slider{cursor:pointer;background-color:var(--border);border-radius:999px;transition:all .2s;position:absolute;inset:0}.switch-slider:before{content:"";background-color:var(--text-primary);border-radius:50%;width:18px;height:18px;transition:all .2s;position:absolute;bottom:3px;left:3px}input:checked+.switch-slider{background-color:var(--accent)}input:checked+.switch-slider:before{background-color:var(--bg-base);transform:translate(20px)}.range{appearance:none;cursor:pointer;background:var(--border);border-radius:2px;outline:none;width:100%;height:4px}.range::-webkit-slider-thumb{-webkit-appearance:none;background:var(--accent);cursor:pointer;width:14px;height:14px;box-shadow:0 0 4px var(--accent-dim);transition:transform var(--dur-fast) ease;border-radius:50%}.range::-webkit-slider-thumb:hover{transform:scale(1.2)}.vol-row{align-items:center;gap:10px;display:flex}.vol-pct{color:var(--text-muted);text-align:right;flex-shrink:0;font-size:12px}.page-body{flex-direction:column;flex:1;gap:20px;min-height:0;padding:10px 15px;display:flex;overflow-y:auto}.page-section{flex-direction:column;gap:12px;display:flex}.setup-page{overscroll-behavior:none;background:var(--bg-base-override,var(--bg-base));flex-direction:column;flex:1;padding:0;display:flex;overflow-y:auto}.setup-header{text-align:center;flex-shrink:0;padding:35px 25px 15px}.setup-title{color:var(--accent);font-size:32px}.setup-subtitle{color:var(--text-muted);font-size:14px}.setup-body{flex-direction:column;flex:1;gap:12px;width:100%;max-width:540px;margin:0 auto;padding:0 25px 30px;display:flex}.setup-tabs{background:var(--bg-surface);border-radius:8px;grid-template-columns:repeat(2,minmax(0,1fr));padding:4px;display:grid}.setup-tab{height:40px;color:var(--text-secondary);font-family:var(--font-serif);cursor:pointer;transition:background var(--dur-fast) ease, color var(--dur-fast) ease;background:0 0;border:0;border-radius:8px;justify-content:center;align-items:center;gap:5px;font-size:14px;display:inline-flex}.setup-tab:hover{background:var(--bg-hover);color:var(--text-primary)}.setup-tab.active{background:var(--bg-elevated);color:var(--accent)}.setup-panel{flex-direction:column;gap:16px;display:none}.setup-panel.active{display:flex}.setup-empty{min-height:100px;color:var(--text-muted);background:var(--bg-surface);border-radius:8px;justify-content:center;align-items:center;gap:5px;display:flex}.setup-section-label{color:var(--accent);letter-spacing:1px;text-transform:uppercase;align-items:center;gap:5px;font-size:12px;display:flex}.setup-recent{flex-direction:column;display:flex}.setup-actions{flex-wrap:wrap;justify-content:flex-end;gap:10px;display:flex}.recent-save-item{background:var(--bg-elevated);transition:background var(--dur-fast) ease;border-radius:8px;align-items:center;gap:12px;min-width:0;padding:10px 14px;display:flex}.recent-save-item:hover{background:var(--bg-hover)}.recent-save-item.recent-save-newest{background:var(--accent-dim)}.recent-save-info{flex:1;min-width:0}.recent-save-name{white-space:nowrap;text-overflow:ellipsis;font-size:14px;display:block;overflow:hidden}.recent-save-meta{color:var(--text-muted);font-size:12px}.recent-save-actions{flex-shrink:0;align-items:center;gap:5px;display:flex}.recent-save-load{margin-left:6px}#su-recent-list{flex-direction:column;gap:10px;display:flex}.settings-tabs{background:var(--bg-base-override,var(--bg-base));border-bottom:1px solid var(--border);scrollbar-width:none;flex-shrink:0;display:flex;overflow:auto hidden}.settings-tabs::-webkit-scrollbar{display:none}.settings-tab{font-family:var(--font-serif);color:var(--text-muted);cursor:pointer;transition:all var(--dur-fast) ease;white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;align-items:center;gap:5px;padding:10px 14px 9px;font-size:14px;display:flex}.settings-tab:hover{color:var(--text-secondary);background:var(--bg-hover)}.settings-tab.active{color:var(--accent);border-bottom-color:var(--accent);background:var(--accent-dim)}.key-textarea{font-family:var(--font-mono)!important;font-size:12px!important}.key-count{color:var(--text-muted);text-align:right;font-size:11px}.model-chips{flex-wrap:wrap;gap:5px;margin-top:5px;display:flex}.prompt-footer{flex-wrap:wrap;align-items:center;gap:10px;margin-top:4px;display:flex}.code-tag{font-family:var(--font-mono);background:var(--accent-dim);color:var(--accent);border-radius:4px;padding:1px 6px;font-size:12px}.color-grid{grid-template-columns:repeat(10,1fr);gap:5px;margin-top:4px;display:grid}.color-swatch{aspect-ratio:1;cursor:pointer;width:100%;transition:transform var(--dur-fast) ease, border-color var(--dur-fast) ease;appearance:none;border:2px solid #0000;border-radius:50%}.color-swatch:hover{transform:scale(1.15)}.color-swatch.selected{border-color:var(--accent);transform:scale(1.1)}.game-screen{flex-direction:column;flex:1;display:flex;overflow:hidden}.text-area{scroll-behavior:smooth;overscroll-behavior:none;outline:none;flex:1;min-height:0;overflow-y:auto}.text-container{flex-direction:column;width:100%;max-width:720px;margin:0 auto;padding:20px;display:flex}.story-line{opacity:0;transition:opacity var(--dur-line) ease, transform var(--dur-line) var(--ease-out);color:var(--text-primary);overflow-wrap:anywhere;font-size:16px;line-height:1.9;transform:translateY(4px)}.story-line.streaming,.story-line.visible{opacity:1;transform:translateY(0)}.story-line.click-to-continue{cursor:pointer}.story-line.click-to-continue:after{content:none}.message-block.click-to-continue{cursor:pointer}.message-block.click-to-continue:after{content:none}.continue-cue{color:var(--accent);vertical-align:middle;justify-content:center;align-items:center;margin-left:6px;font-size:20px;line-height:1;animation:.6s ease-in-out infinite alternate bounce-vertical;display:inline-flex}@keyframes bounce-vertical{0%{transform:translateY(-2px)}to{transform:translateY(2px)}}.floating-context-menu{z-index:10000;background:var(--bg-elevated);border:1px solid var(--border);border-radius:8px;flex-direction:column;padding:4px;animation:.1s ease-out menu-fade-in;display:flex;position:fixed}@keyframes menu-fade-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.floating-context-menu .menu-item{color:var(--text-normal);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:6px;align-items:center;gap:10px;width:100%;padding:8px 12px;font-size:14px;transition:background .15s,color .15s;display:flex}.floating-context-menu .menu-item:hover{background:var(--bg-hover);color:var(--accent)}.floating-context-menu .menu-item .material-symbols-rounded{font-size:18px}.stream-cursor{width:2px;height:var(--font-size);background:var(--accent);vertical-align:-2px;border-radius:1px;margin-left:2px;animation:.75s step-end infinite cur-blink;display:inline-block}@keyframes cur-blink{50%{opacity:0}}.speech-line{background:var(--accent-dim);border-radius:8px;margin:5px 0;padding:8px 34px 8px 10px;display:block;position:relative}.tts-inline-btn{width:24px;height:24px;color:var(--accent);opacity:.6;background:0 0;border-radius:50%;justify-content:center;align-items:center;padding:0;transition:all .2s;display:flex;position:absolute;top:6px;right:6px}.tts-inline-btn:hover{opacity:1;background:var(--bg-hover)}.tts-inline-btn.playing{opacity:1;background:var(--accent-dim);color:var(--accent)}.tts-inline-btn .material-symbols-rounded{font-size:16px}.speaker-name{color:var(--accent);letter-spacing:1px;margin-bottom:2px;font-size:12px;display:block}.turn-divider{color:var(--text-muted);align-items:center;gap:10px;margin:16px 0;font-size:14px;display:flex}.divider-line{background:var(--border);flex:1;height:1px}.player-choice-line{color:var(--accent);-webkit-user-select:none;user-select:none;flex-wrap:wrap;align-items:center;gap:12px;width:100%;padding:16px 0;font-size:14px;display:flex;position:relative}.player-choice-text{text-align:center;overflow-wrap:anywhere;max-width:calc(100% - 80px);line-height:1.5}.choices-area{width:100%;max-width:720px;margin:0 auto;padding:0 28px 28px}.choices-title{color:var(--accent);letter-spacing:1px;text-transform:uppercase;align-items:center;gap:5px;margin-bottom:8px;font-size:14px;display:flex}.choices-list{flex-direction:column;gap:5px;display:flex}.choice-btn{text-align:left;background:var(--bg-elevated);width:100%;min-height:44px;color:var(--text-primary);font-family:var(--font-serif);cursor:pointer;transition:background var(--dur-fast) ease, border-color var(--dur-fast) ease, transform var(--dur-fast) ease, color var(--dur-fast) ease;opacity:0;border:1px solid #0000;border-radius:8px;align-items:center;gap:10px;padding:8px 10px;font-size:14px;line-height:1.5;display:flex;transform:translate(-4px)}.choice-btn.visible{opacity:1;transition:opacity .3s ease, transform .3s var(--ease-out), background var(--dur-fast) ease, border-color var(--dur-fast) ease, color var(--dur-fast) ease;transform:translate(0)}.choice-btn:hover{background:var(--accent-dim);border-color:var(--border-focus);color:var(--accent);transform:translate(3px)}.choice-btn.selected{background:var(--accent-dim);color:var(--accent)}.choice-btn:disabled{opacity:.3;cursor:not-allowed;transform:none!important}.choice-num{border:1px solid var(--accent-dim);width:19px;height:19px;color:var(--accent);transition:all var(--dur-fast) ease;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:11px;display:inline-flex}.choice-btn:hover .choice-num{background:var(--accent);color:var(--text-inverse);border-color:var(--accent)}.choice-text{overflow-wrap:anywhere;flex:1;min-width:0}.choice-arrow{color:var(--text-muted);opacity:0;transition:opacity var(--dur-fast) ease, transform var(--dur-fast) ease}.choice-btn:hover .choice-arrow{opacity:1;transform:translate(2px)}.turn-badge{color:var(--text-muted);flex-shrink:0;align-items:center;gap:5px;font-size:12px;display:flex}.turn-badge strong{color:var(--accent)}.music-badge{color:var(--accent);align-items:center;gap:10px;min-width:0;font-size:12px;display:flex;overflow:hidden}.music-tags-container{flex-wrap:nowrap;align-items:center;gap:5px;min-width:0;display:flex;overflow:hidden}.music-tag{transition:all var(--dur-fast) ease;white-space:nowrap;border-radius:6px;align-items:center;padding:2px 8px;font-size:11px;font-weight:500;display:inline-flex}.music-tag.tag-style{background:var(--accent-dim);border-color:var(--border-focus);color:var(--accent)}.music-tag.tag-mood{background:var(--bg-hover);border-color:var(--border);color:var(--text-secondary)}.music-icon{animation:5s linear infinite spin-slow;display:inline-block}@keyframes spin-slow{to{transform:rotate(360deg)}}.save-card{background:var(--bg-elevated);transition:background var(--dur-fast) ease;border-radius:8px;align-items:center;gap:12px;min-width:0;padding:12px 14px;display:flex}.save-card:hover{background:var(--bg-hover)}.save-card-info{flex:1;min-width:0}.save-card-name{white-space:nowrap;text-overflow:ellipsis;font-size:14px;overflow:hidden}.save-card-meta{color:var(--text-muted);margin-top:2px;font-size:11px}.save-card-actions{flex-shrink:0;gap:4px;display:flex}.logs-section{gap:8px!important}.logs-header{justify-content:space-between;align-items:center;display:flex}.log-list{flex-direction:column;gap:5px;display:flex}.log-item{border:1px solid #0000;border-radius:6px;overflow:hidden}.log-request{background:var(--log-req)}.log-response{background:var(--log-res)}.log-error{background:var(--log-err)}.log-item-header{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background var(--dur-fast) ease;align-items:center;gap:10px;padding:8px 12px;display:flex}.log-item-header:hover{background:var(--bg-hover)}.voice-item{border-color:var(--border)}.voice-item .voice-delete{opacity:.72}.voice-item .voice-delete:hover{opacity:1}.log-icon{font-size:15px!important}.log-request .log-icon{color:var(--success)}.log-response .log-icon{color:var(--accent)}.log-error .log-icon{color:var(--danger)}.log-label{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-size:14px;overflow:hidden}.log-meta{color:var(--text-muted);flex-shrink:0;font-size:11px}.log-expand{color:var(--text-muted);transition:transform var(--dur-fast) ease}.log-content{font-family:var(--font-mono);border-top:1px solid var(--border);color:var(--text-secondary);white-space:pre-wrap;word-break:break-all;max-height:300px;padding:8px 12px;font-size:11px;line-height:1.5;overflow-y:auto}.empty-state{text-align:center;color:var(--text-muted);padding:28px 16px;font-size:14px}.error-box{background:var(--danger-bg);color:var(--danger);word-break:break-all;overflow-wrap:anywhere;white-space:pre-wrap;border-radius:8px;flex-wrap:wrap;align-items:flex-start;gap:10px;margin:6px 0;padding:12px 14px;font-size:14px;line-height:1.6;display:flex}.error-icon{flex-shrink:0;margin-top:2px}.error-msg{word-break:break-all;overflow-wrap:anywhere;white-space:pre-wrap;flex:1}.retry-btn{flex-shrink:0;margin-left:auto}.loading-line{color:var(--text-muted);align-items:center;gap:10px;font-size:14px;display:flex}.spinner{border:2px solid var(--border);border-top-color:var(--accent);vertical-align:middle;border-radius:50%;flex-shrink:0;width:16px;height:16px;animation:.6s linear infinite spin;display:inline-block}.btn .spinner{border-color:var(--border)!important;border-top-color:currentColor!important}@keyframes spin{to{transform:rotate(360deg)}}.tag{background:var(--accent-dim);color:var(--accent);border-radius:4px;padding:2px 8px;font-size:11px;display:inline-flex}.toast-container{z-index:var(--z-toast);pointer-events:none;flex-direction:column;align-items:center;gap:5px;display:flex;position:fixed;bottom:15px;right:15px;transform:none}.toast{background:var(--bg-elevated);border-radius:8px;padding:8px 10px;font-size:14px}.toast.success{color:var(--success)}.toast.error{color:var(--danger)}@keyframes toast-in{0%{opacity:0;transform:translateY(4px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}@media (width<=540px){.setup-header{padding:20px 15px 15px}.setup-body{padding:10px 15px 20px}.text-container{padding:15px}.choices-area{padding:0 15px 20px}.settings-tab span{display:none}.settings-tab .material-symbols-rounded{display:inline-block;font-size:20px!important}.top-bar-game-title{display:none}.game-screen .top-bar{flex-wrap:wrap;row-gap:5px;padding-top:5px;padding-bottom:5px}.game-screen .top-bar-logo{flex:1}.game-screen .top-bar-actions{margin-left:0}.game-top-main{flex-basis:100%;order:2}.game-top-status{justify-content:space-between;width:100%}.recent-save-item,.save-card{align-items:flex-start}.recent-save-actions,.save-card-actions{align-self:flex-start}.music-tags-container{justify-content:flex-end}.confirm-actions{justify-content:stretch}.confirm-actions .btn{flex:1}}.confirm-overlay{background:var(--overlay-bg);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;opacity:0;pointer-events:auto;justify-content:center;align-items:center;transition:opacity .2s;display:flex;position:fixed;inset:0}.confirm-overlay.active{opacity:1}.confirm-box{background:var(--bg-surface);border:1px solid var(--border);width:90%;max-width:400px;box-shadow:var(--shadow-lg);border-radius:12px;flex-direction:column;gap:16px;max-height:min(86vh,720px);padding:20px;transition:transform .2s cubic-bezier(.16,1,.3,1);display:flex;overflow-y:auto;transform:scale(.92)}.confirm-overlay.active .confirm-box{transform:scale(1)}.confirm-title{color:var(--accent);font-size:16px;font-weight:700}.confirm-msg{color:var(--text-secondary);font-size:14px;line-height:1.6}.modal-preformatted{white-space:pre-wrap;text-align:left;overflow-wrap:anywhere;max-height:min(48vh,420px);margin:0;overflow-y:auto}.confirm-actions{flex-wrap:wrap;justify-content:flex-end;gap:12px;margin-top:8px;display:flex}.auth-box{max-width:340px}.auth-toggle:hover{text-decoration:underline}.message-block{cursor:default;flex-direction:column;display:flex;position:relative}.message-toolbar{background:var(--bg-surface);border:1px solid var(--border);opacity:0;pointer-events:none;max-height:0;transition:opacity var(--dur-fast) ease, max-height var(--dur-fast) ease, margin-top var(--dur-fast) ease;-webkit-user-select:none;user-select:none;z-index:10;border-radius:6px;align-self:flex-end;gap:4px;margin-top:0;padding:2px;display:inline-flex;position:static;overflow:hidden}.text-container.edit-mode .message-action-host>.message-toolbar{opacity:1;pointer-events:auto;max-height:38px;margin-top:5px}.player-choice-line>.message-toolbar{flex-basis:100%;margin-left:auto}.message-toolbar .btn{gap:4px;height:auto;padding:2px 5px;font-size:11px}.message-toolbar .material-symbols-rounded{vertical-align:middle;margin-top:-1px;font-size:14px!important}.message-edit-box{background:var(--bg-surface);border:1px solid var(--border);width:100%;box-shadow:var(--shadow-md);cursor:default;border-radius:8px;flex-direction:column;gap:5px;margin-top:10px;padding:10px;display:flex}.message-edit-box .edit-textarea{resize:vertical;min-height:140px}.edit-choice-options{flex-direction:column;gap:5px;display:flex}.edit-option-btn{border:1px solid var(--border);background:var(--bg-elevated);width:100%;color:var(--text-primary);font-family:var(--font-serif);text-align:left;cursor:pointer;transition:background var(--dur-fast) ease, border-color var(--dur-fast) ease, color var(--dur-fast) ease;border-radius:8px;align-items:center;gap:10px;padding:8px 10px;font-size:14px;line-height:1.5;display:flex}.edit-option-btn:hover,.edit-option-btn.active{background:var(--accent-dim);border-color:var(--border-focus);color:var(--accent)}.edit-option-btn span:last-child{overflow-wrap:anywhere;flex:1}.custom-choice-wrap.choice-btn{cursor:default;align-items:center;gap:10px;min-height:44px;padding:8px 15px;display:flex}.custom-choice-wrap.choice-btn:focus-within{background:var(--accent-dim);color:var(--accent);transform:translate(3px)}.custom-choice-wrap.choice-btn:hover .choice-num,.custom-choice-wrap.choice-btn:focus-within .choice-num{background:var(--accent);color:var(--text-inverse);border-color:var(--accent)}.custom-choice-form{flex:1;align-items:center;gap:10px;min-width:0;min-height:28px;margin:0;padding:0;display:flex}.custom-choice-input{min-width:0;font-family:inherit;font-size:inherit;color:var(--text-primary);height:28px;caret-color:var(--accent);background:0 0;border:none;outline:none;flex:1;margin:0;padding:0;line-height:1.5}.custom-choice-input::placeholder{color:var(--text-muted)}.custom-choice-send{border-radius:50%;flex-shrink:0;width:28px;height:28px}.context-usage-btn{background:var(--bg-elevated);width:28px;height:28px;color:var(--text-secondary);cursor:pointer;border:0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex;position:relative}.context-usage-btn svg{width:28px;height:28px;position:absolute;inset:0;transform:rotate(-90deg)}.context-ring-bg,.context-ring-value{fill:none;stroke-width:3px}.context-ring-bg{stroke:var(--border)}.context-ring-value{stroke:var(--ctx-color);stroke-linecap:round;stroke-dasharray:var(--ctx-dash) 75.4}.context-usage-btn span{z-index:1;font-size:10px;font-family:var(--font-mono);position:relative}.auth-box .field{margin-top:12px}.auth-error-box{background:var(--danger-bg);border:1px solid var(--danger);color:var(--danger);word-break:break-all;border-radius:6px;margin-top:10px;padding:8px 12px;font-size:12px}.auth-toggle-btn{color:var(--accent);cursor:pointer;text-align:right;-webkit-user-select:none;user-select:none;margin-top:14px;font-size:12px}.auth-toggle-btn:hover{text-decoration:underline}.auth-box .confirm-actions{margin-top:20px}.text-area.typing-active{scroll-behavior:auto!important}.btn-icon{aspect-ratio:1!important;border-radius:50%!important;justify-content:center!important;align-items:center!important;width:32px!important;height:32px!important;padding:0!important;display:inline-flex!important}.empty-state-hint{color:var(--text-muted);margin-top:8px;display:block}.save-card-tag{margin-left:6px}.flex-1{flex:1}.align-self-end{align-self:flex-end}.cloud-sync-section{border-top:1px solid var(--border);margin-top:12px;padding-top:12px}.cloud-sync-row{justify-content:space-between;align-items:center;gap:10px;display:flex}.cloud-sync-status{color:var(--text-secondary);font-size:14px}.cloud-sync-btn{border:1px solid var(--border);margin-left:auto}.settings-btn-row{flex-wrap:wrap;gap:10px;display:flex}.settings-backup-btn{border:1px solid var(--border);flex:1}.backup-row{align-items:center;gap:10px;min-width:0;display:flex}
