:root{--bg: #181818;--panel: #141414;--element: #262626;--element-hover: #333333;--text: #e5e5e5;--text-muted: #737373;--accent: #88c0d0;--accent-hover: #8ecece;--border: #262626;--font-mono: "Geist Mono", "SF Mono", "Menlo", "Monaco", monospace;--safe-top: env(safe-area-inset-top, 0px);--safe-right: env(safe-area-inset-right, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px);--safe-left: env(safe-area-inset-left, 0px)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-mono);background:var(--bg);color:var(--text);min-height:100vh;line-height:1.5;overscroll-behavior:none;-webkit-tap-highlight-color:transparent}.app{display:flex;flex-direction:column;min-height:100vh;padding-top:var(--safe-top);padding-left:var(--safe-left);padding-right:var(--safe-right)}.header{padding:0 24px 24px;border-bottom:1px solid var(--border)}.title{font-size:18px;font-weight:500;letter-spacing:-.01em;color:var(--text)}.subtitle{font-size:12px;color:var(--text-muted);margin-top:4px}.custom-titlebar{display:flex;justify-content:center;align-items:center;min-height:38px;padding:0 16px 0 76px;background:var(--bg);position:relative;width:100%;user-select:none;transition:opacity .2s ease}.custom-titlebar.custom-titlebar-hidden{opacity:0;visibility:hidden}.app-title{font-size:13px;font-weight:500;color:var(--text-muted);margin:0;position:absolute;left:50%;transform:translate(-50%);pointer-events:none;user-select:none}.header-controls{display:flex;align-items:center;gap:4px;position:absolute;right:16px}.custom-titlebar>.btn-icon{position:absolute;right:16px}.main{flex:1;position:relative;padding:0 24px;min-width:0;pointer-events:auto;display:flex;align-items:center;justify-content:center;padding-bottom:var(--safe-bottom)}.rsvp-reader{--rsvp-display-min-height: 7.5em;--rsvp-progress-gap: 1.25em;--rsvp-progress-top: calc( 50% + (var(--rsvp-display-min-height) / 2) + var(--rsvp-progress-gap) );--rsvp-controls-gap: 64px;position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;pointer-events:none;margin-bottom:10vh}.rsvp-reader>*{pointer-events:auto}.rsvp-empty{font-size:.8125em;color:var(--text-muted)}.rsvp-display{position:absolute;top:50%;left:48%;transform:translate(-50%,-50%);display:flex;justify-content:center;align-items:center;min-height:var(--rsvp-display-min-height);width:25em;max-width:100%}.rsvp-display.touch-enabled{cursor:pointer;padding:3em 2em;margin:-3em -2em}.tap-hint{position:absolute;bottom:-2.5em;left:50%;transform:translate(-50%);font-size:.75em;color:var(--text-muted);opacity:.6;letter-spacing:.1em;text-transform:uppercase;animation:tapHintPulse 2s ease-in-out infinite;pointer-events:none}@keyframes tapHintPulse{0%,to{opacity:.4}50%{opacity:.7}}.rsvp-guide-line{position:absolute;transform:translate(-50%);top:.3125em;bottom:.3125em;width:1px;background:linear-gradient(to bottom,var(--accent) 0%,var(--accent) 30%,transparent 30%,transparent 70%,var(--accent) 70%,var(--accent) 100%);opacity:.6;z-index:0}.rsvp-word{font-size:2em;font-family:var(--font-mono);color:var(--text);letter-spacing:.04em;position:relative;z-index:1;line-height:1;height:1em;white-space:nowrap;overflow:visible}.rsvp-word-orp{color:var(--accent);font-weight:500;white-space:nowrap;position:absolute;left:50%;top:50%;transform:translate(-50%,-50%)}.rsvp-word-before{color:var(--text-muted);white-space:nowrap;position:absolute;left:50%;top:50%;transform:translate(calc(-100% - .35em),-50%)}.rsvp-word-after{white-space:nowrap;position:absolute;left:50%;top:50%;transform:translate(.35em,-50%)}.rsvp-word-before,.rsvp-word-after{color:var(--text-muted)}.rsvp-word-orp{color:var(--accent);font-weight:500}@media (max-height: 560px){.rsvp-reader{--rsvp-progress-gap: .75em;--rsvp-controls-gap: 48px}}.rsvp-phantom{font-size:2em;font-family:var(--font-mono);color:var(--text-muted);letter-spacing:.04em;position:absolute;top:50%;transform:translateY(-50%);opacity:.2;z-index:0;pointer-events:none;white-space:nowrap}.rsvp-phantom-left{left:50%;transform:translate(calc(-100% - 5em),-50%)}.rsvp-phantom-right{left:50%;transform:translate(5em,-50%)}.progress{position:absolute;top:var(--rsvp-progress-top);left:50%;transform:translate(-50%);width:100%;max-width:600px;display:flex;flex-direction:column;gap:8px;padding:0 24px}.progress-bar{height:1px;background:var(--border);position:relative;overflow:hidden}.progress-fill{height:100%;background:var(--accent);transition:width .15s ease}.progress-info{display:flex;justify-content:space-between;font-size:11px;color:var(--text-muted)}.progress-percent,.progress-count{font-variant-numeric:tabular-nums}.controls-wrapper{display:contents}.controls-wrapper.hidden{visibility:hidden;pointer-events:none}.controls-wrapper.hidden .controls{display:none}.controls-wrapper.visible{visibility:visible;pointer-events:auto}.controls{position:absolute;top:calc(var(--rsvp-progress-top) + var(--rsvp-controls-gap));left:49%;transform:translate(-50%);display:flex;justify-content:center}.controls-group{display:flex;align-items:center;gap:4px;background:var(--element);padding:4px;border-radius:6px;position:relative}.skip-indicator{position:absolute;top:-24px;left:50%;transform:translate(-50%);font-size:10px;color:var(--accent);font-weight:500;font-variant-numeric:tabular-nums;white-space:nowrap;pointer-events:none;background:var(--panel);padding:2px 6px;border-radius:3px;border:1px solid var(--border);z-index:10}.btn{font-family:var(--font-mono);font-size:12px;color:var(--text);background:var(--element);border:1px solid var(--border);padding:8px 16px;border-radius:4px;cursor:pointer;transition:all .15s ease;letter-spacing:-.01em;touch-action:manipulation}.btn:hover{background:var(--element-hover)}.btn:active{transform:translateY(1px)}.btn-icon{padding:8px;border-radius:4px;display:flex;align-items:center;justify-content:center;position:relative;touch-action:manipulation}.custom-titlebar>.btn-icon{position:absolute;right:16px;padding:4px;background:transparent;border:none;color:var(--text-muted);cursor:pointer;transition:color .15s ease}.header-controls .btn-icon{padding:4px;background:transparent;border:none;color:var(--text-muted);cursor:pointer;transition:color .15s ease}.custom-titlebar>.btn-icon:hover,.header-controls .btn-icon:hover{color:var(--text)}.custom-titlebar>.btn-icon svg,.header-controls .btn-icon svg{display:block;width:14px;height:14px}.btn-play{padding:8px 12px;min-width:40px}.btn-play.playing,.btn-ramp.active{color:var(--accent)}.btn-speed{font-size:11px;padding:8px 12px;font-variant-numeric:tabular-nums}.wpm-input{width:60px;text-align:center;padding:8px;font-size:11px;font-variant-numeric:tabular-nums;-moz-appearance:textfield}.wpm-input::-webkit-outer-spin-button,.wpm-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.wpm-input:focus{outline:none;border-color:var(--accent);background:var(--element-hover)}.wpm-label{font-size:11px;color:var(--text-muted);margin-left:4px;font-variant-numeric:tabular-nums}.speed-control{position:relative;display:flex;align-items:center}.speed-dropdown{position:absolute;bottom:calc(100% + 4px);right:0;background:var(--panel);border:1px solid var(--border);border-radius:6px;padding:4px;min-width:100px;z-index:10}.speed-option{width:100%;text-align:left;font-size:11px;font-variant-numeric:tabular-nums;padding:6px 8px;color:var(--text);background:transparent;border:none;border-radius:3px;cursor:pointer;transition:background .1s}.speed-option:hover{background:var(--element)}.speed-option.active{color:var(--accent)}.actions{display:flex;gap:8px;margin-top:16px}.btn-accent{color:var(--accent);border-color:var(--accent)}.btn-accent:hover{background:#88c0d01a}.shortcuts{margin-top:48px;text-align:center}.shortcuts-title{font-size:11px;color:var(--text-muted);margin-bottom:12px;text-transform:uppercase;letter-spacing:.05em}.shortcuts-list{display:flex;gap:16px;font-size:11px;color:var(--text-muted)}.shortcuts-list span{display:flex;align-items:center;gap:6px}.shortcuts-group{display:flex;flex-direction:column;gap:6px;margin-top:12px;padding-top:12px;border-top:1px solid var(--border)}.shortcuts-group .shortcuts-title{margin-bottom:0}.shortcuts-list.vertical{flex-direction:column;gap:10px}.shortcuts-list.vertical span{justify-content:space-between}kbd{font-family:var(--font-mono);font-size:10px;padding:2px 6px;background:var(--element);border:1px solid var(--border);border-radius:3px;color:var(--text)}.file-upload{display:flex;flex-direction:column;width:100%;background:var(--panel);border:1px solid var(--border);border-radius:8px;overflow:hidden;position:relative}.file-upload-overlay{position:fixed;inset:0;background:#000000b3;backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.file-upload-modal{width:100%;max-width:480px;padding:0 16px;animation:scaleIn .2s ease}.file-upload-header{display:flex;justify-content:space-between;align-items:center;padding:16px;border-bottom:1px solid var(--border)}.file-upload-title{font-size:14px;font-weight:500}.file-upload-tabs{display:flex;border-bottom:1px solid var(--border);background:var(--element)}.file-upload-tab{flex:1;padding:12px 16px;background:transparent;border:none;color:var(--text-muted);font-size:12px;font-family:var(--font-mono);cursor:pointer;transition:all .15s ease;border-bottom:2px solid transparent;touch-action:manipulation}.file-upload-tab:hover{color:var(--text);background:var(--element-hover)}.file-upload-tab.active{color:var(--accent);border-bottom-color:var(--accent);background:var(--panel)}.file-upload-content{padding:24px}.file-input{display:none}.file-dropzone{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;border:1px dashed var(--border);border-radius:6px;cursor:pointer;transition:all .2s;touch-action:manipulation}.file-dropzone:hover{border-color:var(--accent);background:#88c0d005}.file-dropzone.dragging{border-color:var(--accent);border-style:solid;background:#88c0d014}.file-dropzone-icon{color:var(--text-muted);margin-bottom:16px}.file-dropzone-text{text-align:center}.file-dropzone-text p{font-size:13px;color:var(--text)}.file-dropzone-subtitle{font-size:11px;color:var(--text-muted);margin-top:4px}.file-upload-error{margin-top:16px;padding:12px;background:#ef44441a;border:1px solid rgba(239,68,68,.2);border-radius:4px;font-size:12px;color:#fca5a5}.file-formats{margin-top:24px}.file-formats-title{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:12px}.file-format{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--border)}.file-format:last-child{border-bottom:none}.file-format-ext{font-size:12px;color:var(--accent);font-family:var(--font-mono)}.file-format-name{font-size:12px;color:var(--text-muted)}.history-container{display:flex;flex-direction:column;min-height:200px}.history-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;color:var(--text-muted);text-align:center}.history-empty svg{margin-bottom:16px;opacity:.5}.history-empty p{font-size:14px;margin:0}.history-empty-hint{font-size:12px;margin-top:8px;opacity:.7}.history-list{display:flex;flex-direction:column;max-height:400px;overflow-y:auto;-webkit-overflow-scrolling:touch}.history-item{padding:12px 0;cursor:pointer;transition:background .15s ease;border-bottom:1px solid var(--border)}.history-item:last-child{border-bottom:none}.history-item:hover{background:var(--element)}.history-item-header{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:4px}.history-item-name{font-size:13px;color:var(--text);font-weight:500;flex:1;word-break:break-word}.history-item-edit{flex:1;padding:4px 8px;background:var(--panel);border:1px solid var(--accent);border-radius:4px;color:var(--text);font-size:13px;font-family:inherit;outline:none}.history-item-actions{display:flex;gap:2px;flex-shrink:0;opacity:0;transition:opacity .15s ease}.history-item:hover .history-item-actions{opacity:1}.history-action-btn{display:flex;align-items:center;justify-content:center;width:24px;height:24px;padding:0;background:transparent;border:none;border-radius:4px;color:var(--text-muted);cursor:pointer;transition:all .15s ease}.history-action-btn:hover{background:var(--element-hover);color:var(--text)}.history-action-delete:hover{color:#f87171;background:#f871711a}.history-item-meta{display:flex;align-items:center;gap:8px;font-size:11px;color:var(--text-muted)}.history-item-source{word-break:break-word}.history-item-words{flex-shrink:0}.history-item-time{margin-left:auto;flex-shrink:0;opacity:.7}.url-input-container{display:flex;flex-direction:column;gap:16px}.url-input-wrapper{display:flex;align-items:center;gap:12px;padding:12px;background:var(--element);border:1px solid var(--border);border-radius:6px;transition:all .15s ease}.url-input-wrapper:focus-within{border-color:var(--accent);background:var(--element-hover)}.url-icon{color:var(--text-muted);flex-shrink:0}.url-input{flex:1;background:transparent;border:none;color:var(--text);font-size:13px;font-family:var(--font-mono);outline:none}.url-input::placeholder{color:var(--text-muted)}.url-load-btn{width:100%;margin-top:8px}.paste-input{min-height:110px;resize:vertical}.paste-actions .url-load-btn{margin-top:0}.url-load-btn:disabled{opacity:.5;cursor:not-allowed}.link-supported{display:flex;flex-direction:column;align-items:center;margin-top:12px;gap:8px}.link-supported-label{font-size:11px;color:var(--text-muted);text-align:center}.link-supported-badges{display:flex;flex-direction:row;flex-wrap:wrap;align-items:center;gap:14px}.link-supported-item{display:inline-flex;align-items:center;gap:6px;padding:0;border:none;background:transparent;color:var(--text-muted);user-select:none}.link-supported-item:hover{color:var(--text)}.link-supported-icon{flex-shrink:0}.url-hint{font-size:11px;color:var(--text-muted);text-align:center;margin-top:-8px}.spinner{width:24px;height:24px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.titlebar{height:38px;width:100%;display:flex;align-items:center;padding-left:12px;background:transparent;flex-shrink:0;user-select:none}.titlebar-title{position:absolute;left:50%;transform:translate(-50%);font-size:12px;font-weight:500;color:var(--text-muted);letter-spacing:.02em;pointer-events:none}.traffic-lights{display:flex;gap:8px;-webkit-app-region:no-drag}.traffic-light{width:12px;height:12px;border-radius:50%;border:none;cursor:pointer;transition:filter .15s ease}.traffic-light-close{background:#ff5f57}.traffic-light-minimize{background:#ffbd2e}.traffic-light-maximize{background:#28c840}.traffic-light:hover{filter:brightness(.9)}.traffic-light:active{filter:brightness(.8)}@media not all and (pointer: fine){.titlebar{display:none}}.paste-hint{margin-top:32px;font-size:11px;color:var(--text-muted);text-align:center;opacity:.7}.paste-error{position:fixed;top:calc(var(--safe-top) + 46px);left:50%;transform:translate(-50%);z-index:1100;padding:12px 16px;background:#ef44441f;border:1px solid rgba(239,68,68,.25);border-radius:8px;font-size:12px;color:#fca5a5;text-align:center;max-width:min(400px,90vw);box-shadow:0 12px 32px #00000059}.loading-overlay{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:#181818e6;backdrop-filter:blur(8px);z-index:1000}.loading-content{display:flex;flex-direction:column;align-items:center;gap:16px}.loading-content p{font-size:13px;color:var(--text-muted)}.drag-overlay{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:#88c0d01a;backdrop-filter:blur(8px);border:2px dashed var(--accent);z-index:999;pointer-events:none}.drag-overlay-content{display:flex;flex-direction:column;align-items:center;gap:16px;padding:48px;background:#141414f2;border-radius:12px;border:1px solid var(--accent);box-shadow:0 8px 32px #88c0d033}.drag-overlay-icon{color:var(--accent);animation:drag-pulse 1.5s ease-in-out infinite}@keyframes drag-pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.8}}.drag-overlay-text{font-size:18px;font-weight:500;color:var(--text);margin:0}.drag-overlay-subtitle{font-size:12px;color:var(--text-muted);margin:0}.app.drag-over{position:relative}.app.drag-over:before{content:"";position:absolute;inset:0;border:2px dashed var(--accent);border-radius:8px;pointer-events:none;z-index:1;animation:drag-border-pulse 1.5s ease-in-out infinite}@keyframes drag-border-pulse{0%,to{opacity:.3}50%{opacity:.6}}.top-bar{position:fixed;top:0;left:0;right:0;display:flex;justify-content:space-between;align-items:flex-start;padding:6px 16px;z-index:100;height:32px}.app-title-container{position:absolute;left:50%;top:8px;transform:translate(-50%);pointer-events:none}.app-name{font-size:13px;font-weight:500;color:var(--text-muted);margin:0}.settings-overlay{position:fixed;inset:0;background:#000000b3;backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.settings-modal{width:100%;max-width:480px;padding:0 16px;animation:scaleIn .2s ease}.settings-modal{background:var(--panel);border:1px solid var(--border);border-radius:8px;box-shadow:0 20px 40px #0006;overflow:hidden}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.settings-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid var(--border);background:var(--element)}.settings-title{font-size:15px;font-weight:500;color:var(--text);margin:0}.settings-content{padding:24px;max-height:70vh;overflow-y:auto}.settings-section{margin-bottom:20px}.settings-section:last-child{margin-bottom:0}.settings-label{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:12px}.settings-option{display:flex;align-items:center;gap:12px;padding:8px 12px;margin:0 -12px;cursor:pointer;font-size:13px;color:var(--text);border-radius:6px;transition:all .15s ease}.settings-grid{display:grid;grid-template-columns:1fr 1fr;gap:4px 12px;margin:0 -12px}.settings-grid .settings-option{margin:0}.settings-option:hover{background:var(--element)}.settings-option input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:var(--accent);border-radius:4px}.settings-hint{font-size:11px;color:var(--muted);margin:-4px 0 4px;padding:0 12px;line-height:1.4}.settings-range{display:flex;align-items:center;gap:16px}.settings-range input[type=range]{flex:1;height:4px;background:var(--element);border-radius:2px;outline:none;cursor:pointer;-webkit-appearance:none}.settings-range input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;background:var(--accent);border-radius:50%;cursor:pointer;transition:all .15s ease;box-shadow:0 2px 4px #0000004d}.settings-range input[type=range]::-webkit-slider-thumb:hover{background:var(--accent-hover);transform:scale(1.1)}.settings-range input[type=range]::-moz-range-thumb{width:16px;height:16px;background:var(--accent);border:none;border-radius:50%;cursor:pointer;transition:all .15s ease;box-shadow:0 2px 4px #0000004d}.settings-range input[type=range]::-moz-range-thumb:hover{background:var(--accent-hover);transform:scale(1.1)}.settings-range-value{font-size:13px;font-variant-numeric:tabular-nums;color:var(--accent);min-width:48px;text-align:right}.settings-shortcuts-link{display:inline-flex;align-items:center;gap:6px;margin-top:10px;padding:0;background:none;border:none;color:var(--accent);font-size:12px;cursor:pointer;text-decoration:none}.settings-shortcuts-link:hover{color:var(--text)}.settings-shortcuts{margin-top:16px;padding:16px;border:1px solid var(--border);border-radius:10px;background:var(--element)}.settings-shortcuts .shortcuts-title{margin-bottom:10px}.settings-shortcuts .shortcuts-list.vertical{gap:10px}.settings-shortcuts .shortcuts-list.vertical span{display:flex;justify-content:space-between;gap:16px}.settings-shortcuts .shortcuts-list.vertical .shortcut-tray{display:flex;align-items:center;justify-content:space-between;gap:16px;padding-left:4px}.tray-key{display:inline-flex;align-items:center;justify-content:center}.tray-key img{width:14px;height:14px;filter:brightness(.9)}.settings-footer{margin-top:20px;padding-top:20px;border-top:1px solid var(--border)}.settings-toggles{display:flex;flex-direction:column;gap:0}.settings-toggle{display:flex;align-items:center;justify-content:space-between;padding:16px 0;border-bottom:1px solid var(--border);cursor:pointer;gap:12px}.settings-toggle:last-child{border-bottom:none}.settings-toggle>span,.toggle-label-group span{font-size:15px;color:var(--text)}.toggle-label-group{display:flex;flex-direction:column;gap:2px}.settings-hint-inline{font-size:12px;color:var(--text-muted);margin:0}.toggle-switch{position:relative;width:51px;height:31px;background:var(--element);border:none;border-radius:16px;cursor:pointer;transition:background-color .2s ease;padding:0;-webkit-appearance:none;appearance:none;display:inline-flex;align-items:center;justify-content:flex-start;flex-shrink:0;overflow:hidden}.toggle-switch.active{background:var(--accent)}.toggle-thumb{position:absolute;top:2px;left:2px;width:27px;height:27px;background:#fff;border-radius:50%;transition:transform .2s ease;box-shadow:0 1px 3px #0003;will-change:transform}.toggle-switch.active .toggle-thumb{transform:translate3d(20px,0,0)}.word-size-slider{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--element);border-radius:12px}.word-size-icon{color:var(--text-muted);flex-shrink:0}.word-size-icon.small{opacity:.6}.word-size-icon.large{opacity:.8}.word-size-range{flex:1;height:6px;background:var(--border);border-radius:3px;outline:none;cursor:pointer;-webkit-appearance:none;appearance:none}.word-size-range::-webkit-slider-thumb{-webkit-appearance:none;width:28px;height:28px;background:#fff;border-radius:50%;cursor:pointer;box-shadow:0 2px 6px #0000004d}.word-size-range::-moz-range-thumb{width:28px;height:28px;background:#fff;border:none;border-radius:50%;cursor:pointer;box-shadow:0 2px 6px #0000004d}.btn-ghost{width:100%;background:transparent;border-color:transparent;color:var(--text-muted)}.btn-ghost:hover{background:var(--element);color:var(--text)}.theme-selector{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.theme-option{display:flex;flex-direction:column;align-items:center;gap:6px;padding:12px;background:var(--element);border:1px solid var(--border);border-radius:6px;cursor:pointer;transition:all .15s ease;color:var(--text);font-size:12px;font-family:var(--font-mono)}.theme-option:hover{background:var(--element-hover);border-color:var(--accent)}.theme-option.active{border-color:var(--accent);background:#88c0d00d}.theme-preview{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;font-size:16px;font-weight:500;border:1px solid}.search-overlay{position:fixed;inset:0;background:#000000b3;backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.search-modal{width:100%;max-width:480px;padding:0 16px;animation:scaleIn .2s ease}.search-modal{max-height:80vh;background:var(--panel);border:1px solid var(--border);border-radius:8px;box-shadow:0 20px 40px #0006;overflow:hidden;display:flex;flex-direction:column}.search-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border);background:var(--element)}.search-title{font-size:14px;font-weight:500;color:var(--text);margin:0}.search-content{padding:20px;flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:12px}.search-input-wrapper{position:relative;display:flex;align-items:center}.search-input{width:100%;padding:10px 36px 10px 14px;font-family:var(--font-mono);font-size:13px;background:var(--element);border:1px solid var(--border);border-radius:6px;color:var(--text);outline:none;transition:all .15s ease}.search-input:focus{border-color:var(--accent);background:var(--element-hover)}.search-input::placeholder{color:var(--text-muted)}.search-clear{position:absolute;right:10px;background:transparent;border:none;color:var(--text-muted);padding:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:color .15s ease}.search-clear:hover{color:var(--text)}.search-results-info{font-size:11px;color:var(--text-muted);padding:0 4px}.search-results-list{display:flex;flex-direction:column;gap:4px;max-height:400px;overflow-y:auto}.search-result-item{padding:10px 12px;background:var(--element);border:1px solid var(--border);border-radius:6px;cursor:pointer;transition:all .15s ease;display:flex;flex-direction:column;gap:4px}.search-result-item:hover{background:var(--element-hover);border-color:var(--accent)}.search-result-item.selected{background:#88c0d01a;border-color:var(--accent)}.search-result-context{font-size:13px;color:var(--text);font-family:var(--font-mono);line-height:1.4}.search-context-before{color:var(--text-muted);margin-right:4px}.search-context-match{color:var(--accent);font-weight:500}.search-context-after{color:var(--text-muted);margin-left:4px}.search-highlight{color:var(--accent);background:#88c0d026;padding:0 2px;border-radius:2px;font-weight:500}.search-result-position{font-size:11px;color:var(--text-muted)}.search-no-results{text-align:center;padding:32px;color:var(--text-muted);font-size:13px}.search-footer{padding:16px 20px;border-top:1px solid var(--border);background:var(--element)}.search-footer .btn{width:100%}.empty-state-footer{position:fixed;bottom:0;left:0;right:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:16px 24px;padding-bottom:calc(16px + var(--safe-bottom, 0px));width:100%;background:var(--panel);border-top:1px solid var(--border);pointer-events:auto;z-index:10}.empty-state-tabs{display:flex;width:100%;max-width:320px}.empty-state-tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:12px 16px;background:transparent;border:none;color:var(--text-muted);font-family:var(--font-mono);font-size:11px;text-transform:uppercase;letter-spacing:.5px;cursor:pointer;transition:color .15s ease}.empty-state-tab:hover{color:var(--text)}.empty-state-tab:active{color:var(--accent)}.empty-state-tab svg{opacity:.6;transition:opacity .15s ease}.empty-state-tab:hover svg{opacity:.9}.empty-state-tab:active svg{opacity:1;color:var(--accent)}.empty-state-hints{display:flex;align-items:center;gap:8px;font-size:11px;color:var(--text-muted);opacity:.6}.empty-state-hints kbd{font-size:10px;padding:2px 5px}.hint-separator{opacity:.4}.mobile-footer{position:fixed;bottom:0;left:0;right:0;background:var(--panel);border-top:1px solid var(--border);padding:12px 0;padding-bottom:calc(12px + var(--safe-bottom, 0px));z-index:100;display:none}.mobile-footer-empty{display:flex;width:100%}.mobile-footer-btn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:8px 0;background:transparent;border:none;color:var(--text-muted);font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:.5px;cursor:pointer;transition:color .15s ease}.mobile-footer-btn:active{color:var(--accent)}.mobile-footer-btn svg{opacity:.6;transition:opacity .15s ease}.mobile-footer-btn:active svg{opacity:1;color:var(--accent)}.mobile-footer-controls{display:flex;flex-direction:column;gap:10px}.mobile-footer-progress{display:flex;align-items:center;gap:12px}.mobile-progress-bar{flex:1;height:3px;background:var(--border);border-radius:2px;overflow:hidden}.mobile-progress-fill{height:100%;background:var(--accent);transition:width .15s ease}.mobile-progress-text{font-size:11px;color:var(--text-muted);font-variant-numeric:tabular-nums;min-width:70px;text-align:right}.mobile-footer-buttons{display:flex;justify-content:center;align-items:center;gap:4px}.mobile-ctrl-btn{padding:10px;background:var(--element);border:1px solid var(--border);border-radius:6px;color:var(--text-muted);cursor:pointer;transition:all .15s ease;display:flex;align-items:center;justify-content:center;min-width:44px;min-height:44px}.mobile-ctrl-btn:active{background:var(--element-hover);color:var(--text)}.mobile-play-btn{padding:12px 16px;min-width:56px}.mobile-play-btn.playing{color:var(--accent);border-color:var(--accent)}.header-btn{padding:4px;background:transparent;border:none;color:var(--text-muted);cursor:pointer;transition:color .15s ease;display:flex;align-items:center;justify-content:center}.header-btn:hover{color:var(--text)}.header-btn svg{display:block}@media (hover: none) and (pointer: coarse){.custom-titlebar{justify-content:flex-start;padding-left:16px}.app-title{position:static;transform:none}.btn{padding:8px 12px;font-size:13px;min-height:36px}.btn-icon{padding:8px;min-height:40px;min-width:40px}.btn-play{min-width:48px;padding:8px 12px}.btn-speed,.wpm-input{font-size:13px;min-width:48px}.wpm-label{font-size:11px}.controls-group{gap:2px}.rsvp-reader{pointer-events:auto;font-size:1.5em}.rsvp-display{top:54%;left:48%!important;width:auto;max-width:calc(100vw - 32px);overflow:visible}.rsvp-word{font-size:2.2em;white-space:nowrap}.file-upload-tab{padding:14px 16px;font-size:13px}.file-dropzone{padding:48px 20px}.url-input-wrapper{padding:14px}.history-item{padding:14px 0}.history-item:hover{background:transparent}.history-item-actions{opacity:1}.history-action-btn{width:36px;height:36px}.history-action-btn:hover{background:transparent;color:var(--text-muted)}.history-action-delete:hover{background:transparent;color:#f87171}.history-item-name{font-size:14px}.history-item-meta{font-size:12px;flex-wrap:wrap;gap:6px}.history-item-source{flex-basis:100%}.empty-state-footer,.rsvp-reader .controls,.rsvp-reader .progress{display:none!important}.mobile-footer{display:block}.mobile-footer .controls{position:static;transform:none;display:flex!important;width:100%;padding:0}.mobile-footer .controls-group{width:100%;display:flex;justify-content:stretch;gap:1px;padding:0;background:var(--border);border-radius:0}.mobile-footer .controls-group .btn{flex:1;border-radius:0;border:none;background:var(--element);height:56px;margin:0;display:flex;align-items:center;justify-content:center;color:var(--text);-webkit-appearance:none;-moz-appearance:none;appearance:none}.mobile-footer .controls-group .btn:active{background:var(--element-hover)}.mobile-footer .controls-group .btn:focus{outline:none}.mobile-footer .controls-group .speed-control{flex:1;display:flex;align-items:center;justify-content:center;background:var(--element);position:relative;height:56px}.mobile-footer .controls-group .wpm-stepper{width:100%;height:100%;display:flex;align-items:center;justify-content:space-between}.mobile-footer .controls-group .wpm-stepper-btn{width:56px;height:56px;padding:0;border:none;border-radius:0;background:transparent}.mobile-footer .controls-group .wpm-stepper-btn:active{background:var(--element-hover)}.mobile-footer .controls-group .wpm-stepper-value{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;font-family:var(--font-mono);font-variant-numeric:tabular-nums;color:var(--text);line-height:1}.mobile-footer .controls-group .wpm-stepper-number{font-size:16px}.mobile-footer .controls-group .wpm-stepper-unit{font-size:11px;color:var(--text-muted)}.mobile-footer .controls-group .wpm-label{display:none}.mobile-footer .progress{position:static;transform:none;display:flex!important;flex-direction:column;width:100%;max-width:none;padding:0 16px;margin-bottom:12px}.custom-titlebar{padding:12px 16px;justify-content:flex-start}.app-title{font-size:14px;transition:opacity .3s ease}.app.minimal-view .app-title{opacity:0;pointer-events:none}.header-controls{margin-left:auto;gap:0}.header-controls .btn-icon{padding:14px;min-height:52px;min-width:52px}.header-controls .btn-icon svg{width:22px;height:22px}.settings-overlay,.file-upload-overlay{padding:20px}.search-overlay{align-items:flex-start;justify-content:center;padding:calc(24px + env(safe-area-inset-top,0px)) 20px 0;height:100vh;height:100dvh}.settings-modal,.search-modal,.file-upload-modal{width:100%;max-width:480px;padding:0 16px;animation:slideUpIsland .4s cubic-bezier(.19,1,.22,1)}.search-modal{display:flex;flex-direction:column;max-height:calc(100dvh - 48px - env(safe-area-inset-top,0px) - env(safe-area-inset-bottom,0px));height:calc(100dvh - 48px - env(safe-area-inset-top,0px) - env(safe-area-inset-bottom,0px))}.settings-modal,.search-modal{border-radius:28px;border:1px solid var(--border);box-shadow:0 20px 50px #0009;background:var(--panel);overflow:hidden}.file-upload-modal{background:transparent;border:none;box-shadow:none;overflow:visible;display:flex;max-height:none}.file-upload-modal .file-upload{width:100%;max-width:none;margin:0;border-radius:28px;border:1px solid var(--border);box-shadow:0 20px 50px #0009;height:calc(100dvh - 48px - env(safe-area-inset-top,0px) - env(safe-area-inset-bottom,0px));background:var(--panel);display:flex;flex-direction:column;overflow:hidden}@keyframes slideUpIsland{0%{transform:translateY(100%) scale(.95);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.settings-header,.search-header,.file-upload-header{padding:16px 24px;background:var(--panel);border-bottom:1px solid var(--border)}.settings-content,.file-upload-content{padding:24px;background:var(--panel)}.file-upload-header{order:1;flex-shrink:0}.file-upload-content{order:2;flex:1 1 auto;overflow-y:auto;min-height:0}.file-upload-tabs{order:3;flex-shrink:0;margin-top:auto;border-top:1px solid var(--border);border-bottom:none;padding-bottom:env(safe-area-inset-bottom,0px)}.search-content{padding:24px;background:var(--panel);flex:1;overflow:hidden;display:flex;flex-direction:column;gap:12px;min-height:0}.search-header,.search-input-wrapper,.search-results-info{flex-shrink:0}.search-results-list{flex:1;overflow-y:auto;min-height:0;-webkit-overflow-scrolling:touch}.search-footer{flex-shrink:0}.settings-modal{display:flex;flex-direction:column;max-height:calc(100dvh - 48px - env(safe-area-inset-top,0px) - env(safe-area-inset-bottom,0px));height:calc(100dvh - 48px - env(safe-area-inset-top,0px) - env(safe-area-inset-bottom,0px))}.settings-content{flex:1;overflow-y:auto;padding:16px}.settings-section{margin-bottom:16px}.settings-section:last-child{margin-bottom:0}.settings-label{margin-bottom:8px;font-size:13px}.settings-footer{padding:16px 24px;padding-bottom:calc(16px + env(safe-area-inset-bottom,0px));border-top:1px solid var(--border);margin-top:0}.file-upload-header{order:1;border-radius:28px 28px 0 0}.file-upload-title{font-size:16px;font-weight:600;color:var(--text)}.file-upload-content{order:2;flex:1;overflow-y:auto;padding:20px 24px;display:flex;flex-direction:column}.file-upload-tabs{order:3;border-bottom:none;border-top:1px solid var(--border);padding:8px 24px env(safe-area-inset-bottom,0px);background:var(--panel);border-radius:0 0 28px 28px}.file-upload-tab{font-size:14px;padding:10px 20px}.file-dropzone{padding:32px 24px;min-height:auto;flex:1}.file-dropzone-icon svg{width:40px;height:40px}.file-dropzone-text p{font-size:14px}.file-formats{margin-top:16px;padding-top:16px}.file-formats-title{font-size:12px}.file-format{font-size:13px}.url-input-container{gap:12px;margin:auto 0}.url-input{font-size:16px}.url-hint{font-size:12px}.btn:hover{background:var(--element)}.btn-icon:hover,.header-btn:hover,.custom-titlebar>.btn-icon:hover,.header-controls .btn-icon:hover{color:var(--text-muted)}.btn-accent:hover{background:transparent}.btn-ghost:hover{background:transparent;color:var(--text-muted)}.file-upload-tab:hover{color:var(--text-muted);background:transparent}.file-upload-tab.active:hover{color:var(--accent);background:var(--panel)}.file-dropzone:hover{border-color:var(--border);background:transparent}.settings-option:hover,.speed-option:hover{background:transparent}.theme-option:hover{background:var(--element);border-color:var(--border)}.theme-option.active:hover{border-color:var(--accent)}.search-clear:hover{color:var(--text-muted)}.search-result-item:hover{background:var(--element);border-color:var(--border)}.empty-state-upload:hover{background:var(--element);border-color:var(--border);color:var(--text)}}
