:root{--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-full: 100px;--font-serif: "Literata", Georgia, "Times New Roman", serif;--font-sans: "Inter", system-ui, -apple-system, sans-serif;--font-mono: "DM Mono", "Consolas", "Courier New", monospace;--ease: cubic-bezier(.4, 0, .2, 1);--ease-bounce: cubic-bezier(.34, 1.56, .64, 1);--duration: .25s;--duration-slow: .5s;--duration-theme: .6s}[data-mode=sepia]{--c-bg: #f4e8d1;--c-surface: #efe2ca;--c-surface-2: #e8dbc2;--c-border: #d9ccb2;--c-border-hover: #c4b89e;--c-text: #3d3028;--c-text-2: #6b5d52;--c-text-3: #97897d;--c-text-4: #bfb3a7;--c-accent: #b8622e;--c-accent-hover: #cc7a42;--c-accent-soft: rgba(184, 98, 46, .12);--c-accent-glow: rgba(184, 98, 46, .25);--c-pivot: #b8422e;--c-shadow-sm: 0 1px 3px rgba(60, 48, 40, .08);--c-shadow: 0 2px 12px rgba(60, 48, 40, .08);--c-shadow-lg: 0 8px 32px rgba(60, 48, 40, .12);--c-toast-bg: #3d3028;--c-toast-text: #f4e8d1}[data-mode=light]{--c-bg: #faf8f5;--c-surface: #f2f0ec;--c-surface-2: #eae8e3;--c-border: #dddbd5;--c-border-hover: #ccc9c2;--c-text: #2a2724;--c-text-2: #5a5754;--c-text-3: #8a8784;--c-text-4: #b5b2ae;--c-accent: #b8622e;--c-accent-hover: #cc7a42;--c-accent-soft: rgba(184, 98, 46, .1);--c-accent-glow: rgba(184, 98, 46, .2);--c-pivot: #b8422e;--c-shadow-sm: 0 1px 3px rgba(0, 0, 0, .05);--c-shadow: 0 2px 12px rgba(0, 0, 0, .06);--c-shadow-lg: 0 8px 32px rgba(0, 0, 0, .08);--c-toast-bg: #2a2724;--c-toast-text: #faf8f5}[data-mode=dark]{--c-bg: #1a1816;--c-surface: #242120;--c-surface-2: #2e2b29;--c-border: #3a3735;--c-border-hover: #4a4744;--c-text: #d6d0c8;--c-text-2: #a8a29a;--c-text-3: #787370;--c-text-4: #4a4744;--c-accent: #d4884f;--c-accent-hover: #e09a62;--c-accent-soft: rgba(212, 136, 79, .15);--c-accent-glow: rgba(212, 136, 79, .3);--c-pivot: #d46040;--c-shadow-sm: 0 1px 3px rgba(0, 0, 0, .25);--c-shadow: 0 2px 12px rgba(0, 0, 0, .25);--c-shadow-lg: 0 8px 32px rgba(0, 0, 0, .35);--c-toast-bg: #d6d0c8;--c-toast-text: #1a1816}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{font-family:var(--font-serif);background:var(--c-bg);color:var(--c-text);min-height:100vh;overflow-x:hidden;transition:background var(--duration-theme) var(--ease),color var(--duration-theme) var(--ease);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body:after{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background-image:url("data:image/svg+xml,%3Csvg width='200' height='200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence baseFrequency='0.65' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.025'/%3E%3C/svg%3E");pointer-events:none;z-index:0}.app{position:relative;z-index:1;width:90%;max-width:820px;margin:0 auto;padding:var(--space-xl) 0 var(--space-2xl)}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--c-border);border-radius:3px}::selection{background:var(--c-accent-soft);color:var(--c-text)}:focus-visible{outline:2px solid var(--c-accent);outline-offset:2px;border-radius:4px}.mode-switcher{position:fixed;top:var(--space-md);right:var(--space-md);display:flex;gap:4px;background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius-full);padding:3px;z-index:100;box-shadow:var(--c-shadow-sm);transition:background var(--duration-theme) var(--ease),border-color var(--duration-theme) var(--ease)}.mode-btn{width:30px;height:30px;border-radius:50%;border:none;background:transparent;color:var(--c-text-3);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--duration) var(--ease)}.mode-btn:hover{color:var(--c-text-2)}.mode-btn.active{background:var(--c-accent);color:#fff;box-shadow:0 2px 8px var(--c-accent-glow)}.input-card{background:var(--c-surface);border-radius:var(--radius-md);overflow:hidden;margin-bottom:var(--space-xl);box-shadow:var(--c-shadow-sm);transition:background var(--duration-theme) var(--ease),box-shadow var(--duration) var(--ease)}.input-card:hover{box-shadow:var(--c-shadow)}.input-tabs{display:flex;border-bottom:1px solid var(--c-border)}.input-tab{flex:1;padding:.72rem var(--space-sm);background:transparent;border:none;font-family:var(--font-sans);font-size:.78rem;font-weight:500;color:var(--c-text-4);cursor:pointer;transition:all var(--duration) var(--ease);position:relative}.input-tab:hover{color:var(--c-text-2);background:var(--c-surface-2)}.input-tab.active{color:var(--c-accent)}.input-tab.active:after{content:"";position:absolute;bottom:-1px;left:20%;right:20%;height:2px;background:var(--c-accent);border-radius:1px}.input-panel{display:none;padding:var(--space-md)}.input-panel.active{display:block}textarea{width:100%;height:140px;background:var(--c-bg);border:1px solid var(--c-border);border-radius:var(--radius-sm);color:var(--c-text);font-family:var(--font-serif);font-size:.9rem;line-height:1.75;padding:.85rem var(--space-md);resize:vertical;transition:all var(--duration) var(--ease)}textarea:focus{outline:none;border-color:var(--c-accent);box-shadow:0 0 0 3px var(--c-accent-soft)}textarea::placeholder{color:var(--c-text-4);font-style:italic}.url-row{display:flex;gap:var(--space-sm)}.url-input{flex:1;background:var(--c-bg);border:1px solid var(--c-border);border-radius:var(--radius-sm);color:var(--c-text);font-family:var(--font-sans);font-size:.85rem;padding:.65rem .85rem;transition:all var(--duration) var(--ease)}.url-input:focus{outline:none;border-color:var(--c-accent);box-shadow:0 0 0 3px var(--c-accent-soft)}.url-input::placeholder{color:var(--c-text-4)}.btn-extract{padding:.65rem 1.15rem;background:var(--c-accent);color:#fff;border:none;border-radius:var(--radius-sm);font-family:var(--font-sans);font-size:.82rem;font-weight:600;cursor:pointer;transition:all var(--duration) var(--ease);white-space:nowrap;display:flex;align-items:center;gap:.4rem;min-width:85px;justify-content:center}.btn-extract:hover{background:var(--c-accent-hover)}.btn-extract:disabled{opacity:.7;cursor:not-allowed}.url-status{display:flex;align-items:center;gap:.45rem;margin-top:.6rem;padding:.5rem .75rem;background:var(--c-surface-2);border-radius:var(--radius-sm);animation:fade-in .2s var(--ease)}.url-status-dot{width:7px;height:7px;border-radius:50%;background:var(--c-accent);flex-shrink:0;animation:url-dot-pulse 1s ease-in-out infinite}.url-status[data-state=success] .url-status-dot{background:#4caf50;animation:none}.url-status[data-state=error] .url-status-dot{background:#e53935;animation:none}.url-status-text{font-family:var(--font-sans);font-size:.75rem;color:var(--c-text-2)}@keyframes url-dot-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.8)}}.url-chips{display:flex;flex-wrap:wrap;gap:.3rem;margin-top:.6rem}.url-chip{font-family:var(--font-sans);font-size:.62rem;color:var(--c-text-4);background:var(--c-surface-2);padding:.2rem .55rem;border-radius:var(--radius-full);transition:all var(--duration) var(--ease)}.url-chip.active{background:var(--c-accent-soft);color:var(--c-accent);font-weight:600}.drop-area{border:2px dashed var(--c-border);border-radius:var(--radius-sm);padding:var(--space-xl) var(--space-md);text-align:center;cursor:pointer;transition:all var(--duration) var(--ease);background:var(--c-bg)}.drop-area:hover,.drop-area.dragover{border-color:var(--c-accent);background:var(--c-accent-soft)}.drop-icon{color:var(--c-text-4);margin-bottom:var(--space-sm)}.drop-area:hover .drop-icon{color:var(--c-accent)}.drop-text{font-family:var(--font-sans);font-size:.85rem;color:var(--c-text-3)}.drop-hint{font-family:var(--font-sans);font-size:.72rem;color:var(--c-text-4);margin-top:.2rem}.drop-area input[type=file]{display:none}.progress{display:flex;align-items:center;gap:.75rem;margin-bottom:var(--space-lg)}.progress-track{flex:1;height:3px;background:var(--c-surface-2);border-radius:2px;overflow:visible;cursor:pointer;position:relative;transition:height .2s var(--ease),background var(--duration-theme) var(--ease)}.progress-track:hover{height:6px}.progress-fill{height:100%;width:0%;background:var(--c-accent);border-radius:2px;transition:width .15s linear}.progress-label{font-family:var(--font-sans);font-size:.72rem;color:var(--c-text-4);min-width:70px;text-align:right;font-variant-numeric:tabular-nums}.transport{display:flex;align-items:center;justify-content:center;gap:.65rem;margin-bottom:var(--space-lg)}.transport-btn{width:42px;height:42px;border-radius:50%;background:var(--c-surface);border:1px solid var(--c-border);color:var(--c-text-3);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--duration) var(--ease)}.transport-btn:hover{background:var(--c-surface-2);color:var(--c-text);border-color:var(--c-border-hover);transform:scale(1.06)}.transport-btn:active{transform:scale(.94)}.transport-btn.bookmarked{color:var(--c-accent)}.play-btn{width:60px;height:60px;border-radius:50%;background:var(--c-accent);border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--duration) var(--ease);box-shadow:0 4px 20px var(--c-accent-glow);position:relative;overflow:hidden}.play-btn:hover{background:var(--c-accent-hover);transform:scale(1.06);box-shadow:0 6px 28px var(--c-accent-glow)}.play-btn:active{transform:scale(.95)}.play-icon{display:flex;align-items:center;justify-content:center;transition:transform .15s var(--ease)}.play-btn .ripple{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;background:#ffffff4d;transform:scale(0);animation:ripple-out .6s ease-out forwards}.stats{display:flex;justify-content:center;align-items:center;gap:var(--space-lg);margin-bottom:var(--space-lg)}.stat{text-align:center}.stat-value{display:block;font-family:var(--font-mono);font-size:1.05rem;font-weight:500;color:var(--c-text);transition:color var(--duration-theme) var(--ease);font-variant-numeric:tabular-nums}.stat-label{font-family:var(--font-sans);font-size:.62rem;color:var(--c-text-4);text-transform:uppercase;letter-spacing:.1em;font-weight:500}.stat-divider{width:1px;height:24px;background:var(--c-border);transition:background var(--duration-theme) var(--ease)}.settings{background:var(--c-surface);border-radius:var(--radius-md);padding:var(--space-lg);margin-bottom:var(--space-lg);box-shadow:var(--c-shadow-sm);display:grid;grid-template-columns:1fr 1fr;gap:var(--space-lg);transition:background var(--duration-theme) var(--ease)}.setting{display:flex;flex-direction:column;gap:.35rem}.setting-label{font-family:var(--font-sans);font-size:.65rem;text-transform:uppercase;letter-spacing:.1em;color:var(--c-text-4);font-weight:600}.setting-control{display:flex;align-items:center;gap:var(--space-sm)}input[type=range]{flex:1;-webkit-appearance:none;-moz-appearance:none;appearance:none;height:3px;background:var(--c-surface-2);border-radius:2px;outline:none;transition:background var(--duration-theme) var(--ease)}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:15px;height:15px;border-radius:50%;background:var(--c-accent);cursor:pointer;box-shadow:0 1px 4px var(--c-accent-glow);transition:transform .15s var(--ease)}input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.25)}input[type=range]::-moz-range-thumb{width:15px;height:15px;border-radius:50%;background:var(--c-accent);cursor:pointer;border:none}.setting-output{font-family:var(--font-mono);font-size:.8rem;font-weight:500;color:var(--c-accent);min-width:55px;text-align:right;font-variant-numeric:tabular-nums}.chunk-group,.position-group{display:flex;gap:.3rem}.chunk-btn,.position-btn{flex:1;padding:.42rem;border:1px solid var(--c-border);background:var(--c-bg);color:var(--c-text-4);border-radius:var(--radius-sm);font-family:var(--font-sans);font-size:.76rem;font-weight:500;cursor:pointer;text-align:center;transition:all var(--duration) var(--ease)}.chunk-btn:hover,.position-btn:hover{border-color:var(--c-border-hover);color:var(--c-text-2)}.chunk-btn.active{background:var(--c-accent);color:#fff;border-color:var(--c-accent)}.shortcuts{text-align:center;font-family:var(--font-sans);font-size:.68rem;color:var(--c-text-4);margin-bottom:var(--space-xl);line-height:2}kbd{background:var(--c-surface);border:1px solid var(--c-border);border-radius:3px;padding:.15em .45em;font-family:var(--font-sans);font-size:.82em;margin:0 .05em;box-shadow:0 1px 0 var(--c-border);transition:all var(--duration-theme) var(--ease)}.divider{width:40px;height:0;border:none;border-top:2px solid var(--c-border);margin:0 auto var(--space-xl);transition:border-color var(--duration-theme) var(--ease)}.teaser{background:var(--c-surface);border-radius:var(--radius-md);padding:var(--space-lg);display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-lg);box-shadow:var(--c-shadow-sm);border-left:3px solid var(--c-accent);transition:all var(--duration-theme) var(--ease)}.teaser-icon{width:44px;height:44px;background:var(--c-accent-soft);border-radius:12px;display:flex;align-items:center;justify-content:center;color:var(--c-accent);flex-shrink:0}.teaser-body{flex:1}.teaser-title{font-family:var(--font-sans);font-size:.88rem;font-weight:600;color:var(--c-text);margin-bottom:.15rem;display:flex;align-items:center;gap:var(--space-sm);transition:color var(--duration-theme) var(--ease)}.badge{font-family:var(--font-sans);font-size:.55rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;background:var(--c-accent);color:#fff;padding:.2em .55em;border-radius:3px}.teaser-desc{font-family:var(--font-sans);font-size:.75rem;color:var(--c-text-3);line-height:1.5}.teaser-notify{padding:.5rem .9rem;background:transparent;border:1px solid var(--c-border);color:var(--c-text-3);border-radius:var(--radius-sm);font-family:var(--font-sans);font-size:.75rem;font-weight:500;cursor:pointer;transition:all var(--duration) var(--ease);white-space:nowrap}.teaser-notify:hover{border-color:var(--c-accent);color:var(--c-accent)}.teaser-notify.done{background:var(--c-accent);color:#fff;border-color:var(--c-accent);pointer-events:none}.bookmarklet{background:var(--c-surface);border-radius:var(--radius-md);padding:var(--space-md) var(--space-lg);margin-bottom:var(--space-xl);box-shadow:var(--c-shadow-sm);transition:background var(--duration-theme) var(--ease)}.bookmarklet-title{font-family:var(--font-sans);font-size:.85rem;font-weight:600;color:var(--c-text);margin-bottom:.35rem;display:flex;align-items:center;gap:var(--space-sm);transition:color var(--duration-theme) var(--ease)}.bookmarklet-title svg{color:var(--c-accent)}.bookmarklet-desc{font-family:var(--font-sans);font-size:.72rem;color:var(--c-text-3);margin-bottom:.75rem;line-height:1.5}.extension-features{display:flex;flex-direction:column;gap:.4rem;margin-bottom:.85rem}.ext-feature{display:flex;align-items:center;gap:.45rem;font-family:var(--font-sans);font-size:.72rem;color:var(--c-text-2);line-height:1.4}.ext-icon{display:flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;background:var(--c-accent-soft);color:var(--c-accent);flex-shrink:0}.bookmarklet-link{display:inline-flex;align-items:center;gap:.4rem;padding:.55rem 1.2rem;background:var(--c-accent);color:#fff;text-decoration:none;border-radius:var(--radius-sm);font-family:var(--font-sans);font-size:.78rem;font-weight:600;cursor:pointer;transition:all var(--duration) var(--ease)}.bookmarklet-link:hover{background:var(--c-accent-hover);transform:translateY(-1px);box-shadow:0 3px 10px var(--c-accent-glow)}.bookmarklet-link svg{flex-shrink:0}.bookmarklet-fallback{font-family:var(--font-sans);font-size:.68rem;color:var(--c-text-4);margin-top:.6rem;line-height:1.5}.footer{text-align:center;font-family:var(--font-sans);font-size:.68rem;color:var(--c-text-4);padding:var(--space-md) 0;border-top:1px solid var(--c-border);transition:all var(--duration-theme) var(--ease)}.toast{position:fixed;bottom:2rem;left:50%;transform:translate(-50%) translateY(20px);background:var(--c-toast-bg);color:var(--c-toast-text);font-family:var(--font-sans);font-size:.82rem;font-weight:500;padding:.65rem 1.25rem;border-radius:var(--radius-full);box-shadow:var(--c-shadow-lg);opacity:0;transition:all .4s var(--ease-bounce);z-index:2000;pointer-events:none}.toast.visible{opacity:1;transform:translate(-50%) translateY(0)}.spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spinner .5s linear infinite}.hero{text-align:center;margin-bottom:var(--space-2xl);padding-top:var(--space-lg)}.hero-rsvp{height:56px;display:flex;align-items:center;justify-content:center;margin-bottom:var(--space-lg);position:relative}.hero-rsvp:before{content:"";position:absolute;top:4px;bottom:4px;left:50%;width:2px;background:var(--c-accent);opacity:.1;border-radius:1px}.hero-rsvp-word{font-family:var(--font-mono);font-size:2rem;font-weight:500;color:var(--c-text);letter-spacing:.04em;white-space:nowrap;transition:color var(--duration-theme) var(--ease);position:relative;z-index:1}.hero-rsvp-word .pivot{color:var(--c-pivot)}.hero-rsvp-word.pop{animation:hero-word-pop .13s var(--ease) forwards}@keyframes hero-word-pop{0%{transform:scale(.85);opacity:0}50%{transform:scale(1.04)}to{transform:scale(1);opacity:1}}.hero-title{font-family:var(--font-serif);font-size:clamp(2rem,6vw,3.2rem);font-weight:700;line-height:1.15;letter-spacing:-.03em;color:var(--c-text);margin-bottom:var(--space-md);transition:color var(--duration-theme) var(--ease)}.hero-title-line{display:block}.hero-word{display:inline-block;opacity:0;transform:translateY(20px);margin-right:.2em}.hero-word.revealed{animation:hero-reveal .6s var(--ease-bounce) forwards}.hero-accent{color:var(--c-accent);position:relative}.hero-accent:after{content:"";position:absolute;bottom:-2px;left:-4px;right:-4px;height:6px;background:var(--c-accent);opacity:.2;border-radius:3px;transform:scaleX(0);transform-origin:left}.hero-accent.revealed:after{animation:swoosh .5s .3s var(--ease) forwards}@keyframes hero-reveal{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes swoosh{0%{transform:scaleX(0)}to{transform:scaleX(1)}}.hero-sub{font-family:var(--font-sans);font-size:1rem;color:var(--c-text-3);font-weight:400;margin-bottom:var(--space-lg);min-height:1.5em}.hero-sub-inner{opacity:0}.hero-sub-inner.visible{animation:fade-in .5s var(--ease) forwards}.hero-cycle{display:inline-block;color:var(--c-accent);font-weight:600;position:relative;min-width:70px}.hero-cycle.swapping{animation:cycle-out .2s var(--ease) forwards}.hero-cycle.swapping-in{animation:cycle-in .25s var(--ease) forwards}@keyframes cycle-out{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-12px)}}@keyframes cycle-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.hero-bar{width:100px;height:3px;background:var(--c-surface-2);border-radius:2px;margin:0 auto;overflow:hidden;opacity:0}.hero-bar.visible{opacity:1;transition:opacity .5s var(--ease)}.hero-bar-fill{display:block;width:100%;height:100%;background:var(--c-accent);border-radius:2px;transform:scaleX(0);transform-origin:left}.hero-bar.visible .hero-bar-fill{animation:bar-fill 1.5s .2s var(--ease) forwards}@keyframes bar-fill{0%{transform:scaleX(0)}to{transform:scaleX(1)}}@media(prefers-reduced-motion:reduce){.hero-word{opacity:1;transform:none}.hero-rsvp-word.pop,.hero-cycle.swapping,.hero-cycle.swapping-in{animation:none}}.stage-container{margin-bottom:var(--space-lg)}.stage{position:relative;background:var(--c-bg);border:1px solid var(--c-border);border-radius:var(--radius-md);min-height:180px;display:flex;align-items:center;justify-content:center;box-shadow:var(--c-shadow);overflow:hidden;cursor:pointer;transition:background var(--duration-theme) var(--ease),border-color var(--duration-theme) var(--ease),box-shadow var(--duration) var(--ease)}.stage:hover{box-shadow:var(--c-shadow-lg)}.stage:before{content:"";position:absolute;top:0;right:0;width:0;height:0;border-style:solid;border-width:0 24px 24px 0;border-color:transparent var(--c-surface) transparent transparent;z-index:3;transition:border-color var(--duration-theme) var(--ease)}.stage:after{content:"";position:absolute;top:0;left:0;width:24px;height:100%;background:linear-gradient(90deg,rgba(0,0,0,.03),transparent);pointer-events:none;z-index:2}.stage-pip{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:2px;height:50%;background:var(--c-accent);opacity:.06;border-radius:1px}.stage-content{position:relative;z-index:2;padding:3rem 2rem}.stage-word{font-family:var(--font-mono);font-size:3rem;font-weight:500;letter-spacing:.03em;color:var(--c-text);white-space:nowrap;transition:color var(--duration-theme) var(--ease)}.stage-word .pivot{color:var(--c-pivot)}.stage-idle{font-family:var(--font-serif);font-size:1rem;color:var(--c-text-4);font-style:italic;font-weight:300}.stage-done{font-family:var(--font-serif);font-size:1.05rem;color:var(--c-text-3);text-align:center;line-height:1.7}.stage-done strong{color:var(--c-accent);font-weight:600}.stage-hint{position:absolute;bottom:.6rem;right:.85rem;font-family:var(--font-sans);font-size:.62rem;color:var(--c-text-4);opacity:0;transition:opacity var(--duration) var(--ease);z-index:3}.stage:hover .stage-hint{opacity:.6}.stage-close{position:absolute;top:1.2rem;right:1.2rem;width:36px;height:36px;border-radius:50%;background:var(--c-surface);border:1px solid var(--c-border);color:var(--c-text-3);font-size:1.2rem;cursor:pointer;display:none;align-items:center;justify-content:center;z-index:10;transition:all var(--duration) var(--ease)}.stage-close:hover{color:var(--c-accent);border-color:var(--c-accent)}.stage.fullscreen{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;border-radius:0;min-height:100vh;border:none}.stage.fullscreen:before{display:none}.stage.fullscreen .stage-hint{display:none}.stage.fullscreen .stage-close{display:flex}.stage.fs-entering{animation:page-turn-in .5s var(--ease) forwards}[data-animate=fade-up]{opacity:0;transform:translateY(20px)}[data-animate=fade-up].animated{animation:fade-up .7s var(--ease) forwards}[data-animate][data-delay="0"].animated{animation-delay:0ms}[data-animate][data-delay="1"].animated{animation-delay:60ms}[data-animate][data-delay="2"].animated{animation-delay:.12s}[data-animate][data-delay="3"].animated{animation-delay:.18s}[data-animate][data-delay="4"].animated{animation-delay:.24s}[data-animate][data-delay="5"].animated{animation-delay:.3s}[data-animate][data-delay="6"].animated{animation-delay:.36s}[data-animate][data-delay="7"].animated{animation-delay:.42s}[data-animate][data-delay="8"].animated{animation-delay:.48s}[data-animate][data-delay="9"].animated{animation-delay:.54s}[data-animate][data-delay="10"].animated{animation-delay:.6s}@keyframes fade-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.input-panel.active{animation:fade-in .25s var(--ease)}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.input-tab.active:after{animation:scale-x .25s var(--ease)}@keyframes scale-x{0%{transform:scaleX(0)}to{transform:scaleX(1)}}.word-pop{animation:word-pop .1s var(--ease)}@keyframes word-pop{0%{transform:scale(.93);opacity:.5}60%{transform:scale(1.02)}to{transform:scale(1);opacity:1}}@keyframes ripple-out{to{transform:scale(2.5);opacity:0}}.play-btn.breathing{animation:breathe 2s ease-in-out infinite}@keyframes breathe{0%,to{box-shadow:0 4px 20px var(--c-accent-glow)}50%{box-shadow:0 4px 32px var(--c-accent-glow)}}@keyframes page-turn-in{0%{transform:perspective(1200px) rotateY(-6deg);opacity:.6}to{transform:perspective(1200px) rotateY(0);opacity:1}}@keyframes spinner{to{transform:rotate(360deg)}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}[data-animate=fade-up]{opacity:1;transform:none}}@media(max-width:640px){.app{width:94%;padding:var(--space-md) 0 var(--space-xl)}.hero{margin-bottom:var(--space-xl)}.hero-rsvp-word{font-size:1.5rem}.hero-rsvp{height:44px}.hero-sub{font-size:.88rem}.stage-word,.stage-content .stage-word{font-size:2rem}.stage-content{padding:2rem 1rem}.stage{min-height:140px}.settings{grid-template-columns:1fr;gap:var(--space-md)}.transport{gap:var(--space-sm)}.play-btn{width:52px;height:52px}.transport-btn{width:38px;height:38px}.stats{gap:var(--space-md)}.stat-value{font-size:.9rem}.teaser{flex-direction:column;text-align:center;gap:.75rem}.teaser-title{justify-content:center}.mode-switcher{top:var(--space-sm);right:var(--space-sm)}.input-tab{font-size:.72rem;padding:.6rem .3rem}}@media(max-width:380px){.shortcuts{display:none}.stats{gap:var(--space-sm)}.stat-divider{display:none}}@media(min-width:900px){.app{padding-top:var(--space-2xl)}.hero{margin-bottom:3rem;padding-top:var(--space-xl)}.hero-rsvp{height:72px;margin-bottom:var(--space-xl)}.hero-rsvp-word{font-size:2.6rem}.hero-sub{font-size:1.15rem}.stage{min-height:240px}.stage-content{padding:4rem 3rem}.stage-word{font-size:3.8rem}.stage-idle,.stage-done{font-size:1.2rem}textarea{height:180px;font-size:1rem;line-height:1.8}.input-tab{font-size:.88rem;padding:.85rem var(--space-md)}.transport-btn{width:48px;height:48px}.play-btn{width:68px;height:68px}.play-btn svg{width:26px;height:26px}.stat-value{font-size:1.2rem}.stat-label{font-size:.7rem}.stats{gap:var(--space-xl);margin-bottom:var(--space-xl)}.settings{padding:var(--space-xl);gap:var(--space-xl)}.setting-label{font-size:.72rem}.setting-output{font-size:.88rem;min-width:65px}.shortcuts{font-size:.78rem}.teaser{padding:var(--space-xl)}.bookmarklet{padding:var(--space-lg) var(--space-xl)}}@media(min-width:1400px){.app{max-width:920px}.hero-rsvp{height:84px}.hero-rsvp-word{font-size:3rem}.hero-sub{font-size:1.25rem}.stage{min-height:280px;border-radius:var(--radius-lg)}.stage-content{padding:5rem 3.5rem}.stage-word{font-size:4.2rem}textarea{height:200px;font-size:1.05rem}.transport-btn{width:52px;height:52px}.play-btn{width:74px;height:74px}.stat-value{font-size:1.35rem}.input-card,.settings,.teaser,.bookmarklet{border-radius:var(--radius-lg)}}
