:root{--bg-base: #0d0905;--bg-card: #14100b;--bg-surface-1: #1f160f;--bg-surface-2: #2a1d13;--bg-surface-3: #3a2a1a;--text-primary: #e8e0d4;--text-secondary: #b8a895;--text-muted: #8d7a63;--accent: #d4a24c;--accent-bright: #e6b870;--accent-deep: #8a5d2e;--accent-glow: rgba(212, 162, 76, .4);--accent-glow-soft: rgba(212, 162, 76, .15);--hairline: rgba(245, 236, 217, .1);--hairline-strong: rgba(245, 236, 217, .16);--hairline-warm: rgba(217, 176, 114, .22);--hairline-gold: rgba(217, 176, 114, .55)}html,body,#root{width:100%;height:100%;background:var(--bg-card);color:var(--text-primary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;overflow:hidden;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}.app-root{position:fixed;inset:0;background:var(--bg-card);overflow:hidden}.scene-night{position:absolute;inset:0;z-index:0;overflow:hidden;background:radial-gradient(circle 80px at 78% 14%,rgba(220,226,240,.7) 0%,rgba(190,198,220,.25) 35%,transparent 70%),radial-gradient(ellipse 60% 35% at 78% 14%,rgba(120,150,200,.28) 0%,transparent 70%),radial-gradient(ellipse 75% 60% at 82% 55%,rgba(255,178,92,.55) 0%,rgba(212,130,50,.25) 35%,transparent 65%),radial-gradient(ellipse 60% 50% at 10% 60%,rgba(184,116,58,.45) 0%,transparent 60%),radial-gradient(ellipse 85% 45% at 30% 8%,rgba(60,90,130,.3) 0%,transparent 65%),radial-gradient(ellipse 95% 90% at 50% 55%,transparent 35%,rgba(0,0,0,.78) 100%),linear-gradient(180deg,#0d1424,#1a1424 25%,#2a1a14 60%,#14100b);pointer-events:none}.lantern{position:absolute;width:5px;height:5px;border-radius:50%;background:#fff1cc;box-shadow:0 0 8px 2px #ffdca0f2,0 0 22px 6px #ffb25cb3,0 0 60px 18px #d482326b,0 0 120px 40px #b85a1e38;z-index:2;pointer-events:none;animation:lantern-flicker 4s ease-in-out infinite}.lantern--left{top:38%;left:8%}.lantern--right{top:32%;right:10%;animation-delay:-1.3s}.lantern--mid-l{top:58%;left:24%;width:3px;height:3px;animation-delay:-2.1s}.lantern--mid-r{top:64%;right:22%;width:3px;height:3px;animation-delay:-3.4s}@keyframes lantern-flicker{0%,to{opacity:.92;transform:scale(1)}45%{opacity:1;transform:scale(1.12)}55%{opacity:.88;transform:scale(.97)}}.city-silhouette-back{position:absolute;bottom:60px;left:0;right:0;height:50px;opacity:.25;pointer-events:none;z-index:1}.city-silhouette{position:absolute;bottom:0;left:0;right:0;height:90px;opacity:.55;pointer-events:none;z-index:1}.portrait-wrap{position:absolute;top:env(safe-area-inset-top,44px);left:0;right:0;height:55vh;z-index:3;pointer-events:none}.portrait-wrap canvas{width:100%!important;height:100%!important;background:transparent!important}.portrait-wrap:after{content:"";position:absolute;inset:auto 0 0;height:80px;background:linear-gradient(180deg,transparent 0%,var(--bg-card) 80%);pointer-events:none}.m-header{position:absolute;top:env(safe-area-inset-top,44px);left:0;right:0;padding:12px 20px;display:flex;justify-content:space-between;align-items:flex-start;z-index:10;pointer-events:none}.m-header>*{pointer-events:auto}.m-title{font-family:Georgia,serif;font-weight:400;font-size:17px;color:var(--text-primary);letter-spacing:.02em;text-shadow:0 1px 4px rgba(0,0,0,.8)}.m-title small{display:block;font-style:italic;font-size:11px;color:var(--text-secondary);margin-top:2px}.m-icon-btn{width:44px;height:44px;background:#1f160fb3;border:1px solid var(--hairline-strong);border-radius:50%;color:var(--text-primary);font-size:18px;font-weight:300;display:flex;align-items:center;justify-content:center;cursor:pointer;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);transition:background .18s ease,transform .18s ease}.m-icon-btn:hover{background:#2d2016d9}.m-icon-btn:active{transform:scale(.94)}.m-icon-btn[aria-expanded=true]{background:#2d2016e6;border-color:#d9b07299}.m-menu-overlay{position:fixed;inset:0;z-index:90;background:transparent}.m-menu{position:absolute;top:calc(env(safe-area-inset-top,0px) + 60px);right:16px;z-index:100;min-width:240px;max-width:calc(100vw - 32px);background:#0f0a06eb;-webkit-backdrop-filter:blur(28px) saturate(170%);backdrop-filter:blur(28px) saturate(170%);border:1px solid rgba(217,176,114,.35);border-radius:14px;padding:6px;box-shadow:inset 0 1px #ffdcaa1a,0 16px 48px #0009,0 0 24px #d9b0721f;animation:m-menu-in .18s ease}@keyframes m-menu-in{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.m-menu-item{display:flex;align-items:flex-start;gap:12px;width:100%;padding:12px 14px;background:transparent;border:none;border-radius:10px;color:var(--text-primary);text-align:left;cursor:pointer;font-size:15px;line-height:1.3;transition:background .15s ease}.m-menu-item:hover,.m-menu-item:focus-visible{background:#d9b0721a;outline:none}.m-menu-item:active{background:#d9b0722e}.m-menu-item small{display:block;margin-top:3px;font-size:12px;color:var(--text-secondary, rgba(220, 200, 170, .55));font-weight:400}.m-menu-icon{flex-shrink:0;width:26px;height:26px;display:flex;align-items:center;justify-content:center;background:#d9b07226;border:1px solid rgba(217,176,114,.3);border-radius:50%;color:var(--accent-bright);font-size:14px;font-weight:500}.m-about-overlay{position:fixed;inset:0;z-index:150;background:#000000bf;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;padding:24px;animation:m-about-in .2s ease}@keyframes m-about-in{0%{opacity:0}to{opacity:1}}.m-about-card{max-width:360px;width:100%;background:linear-gradient(180deg,#231810f2,#140e09f2);border:1px solid rgba(217,176,114,.4);border-radius:20px;padding:28px 24px;text-align:center;box-shadow:inset 0 1px #ffdcaa26,0 20px 60px #000000b3}.m-about-title{margin:0 0 4px;font-size:24px;font-weight:500;color:var(--accent-bright);letter-spacing:.02em}.m-about-sub{font-size:13px;color:var(--text-secondary, rgba(220, 200, 170, .65));text-transform:uppercase;letter-spacing:.18em;margin-bottom:18px}.m-about-text{font-size:14px;line-height:1.55;color:var(--text-primary);margin:0 0 14px;text-align:left}.m-about-close{margin-top:8px;padding:10px 28px;background:linear-gradient(180deg,#d9b07240,#d9b0721a);border:1px solid rgba(217,176,114,.5);border-radius:100px;color:var(--accent-bright);font-size:14px;font-weight:500;letter-spacing:.04em;cursor:pointer;transition:background .18s ease}.m-about-close:hover{background:#d9b07240}.m-bottom{position:absolute;bottom:env(safe-area-inset-bottom,16px);left:0;right:0;padding:0 20px 24px;display:flex;flex-direction:column;align-items:center;gap:20px;z-index:10}.m-badge{display:inline-flex;align-items:center;gap:8px;padding:7px 16px;background:linear-gradient(180deg,#d9b07229,#d9b0720f),#0f0a06d1;-webkit-backdrop-filter:blur(20px) saturate(170%);backdrop-filter:blur(20px) saturate(170%);border:1px solid var(--hairline-gold);border-radius:100px;font-size:12px;font-weight:500;text-transform:uppercase;letter-spacing:.16em;color:var(--accent-bright);box-shadow:inset 0 1px #ffdcaa1a,0 4px 16px #00000073,0 0 20px #d9b07226}.m-badge--listening{color:#e6b870;border-color:#d9b072b3}.m-card{width:100%;background:#0f0a06b8;-webkit-backdrop-filter:blur(28px) saturate(170%) brightness(.85);backdrop-filter:blur(28px) saturate(170%) brightness(.85);border:1px solid rgba(255,200,140,.1);border-radius:18px;padding:22px 20px;text-align:center;box-shadow:inset 0 1px #ffdcaa1f,0 12px 40px #00000080;min-height:96px;display:flex;flex-direction:column;justify-content:center}.m-card-title{font-family:Georgia,serif;font-size:24px;font-weight:400;color:var(--text-primary);margin-bottom:8px;letter-spacing:.02em}.m-card-hint{font-size:13px;color:var(--text-secondary);line-height:1.55;font-style:italic}.m-subtitle{font-family:Georgia,serif;font-size:15px;line-height:1.55;color:var(--text-primary);text-align:left}.m-listening-pulse{display:inline-block;animation:pulse-text 1.4s ease-in-out infinite}@keyframes pulse-text{0%,to{opacity:.55}50%{opacity:1}}.m-mic{width:92px;height:92px;position:relative;cursor:pointer;border:0;border-radius:50%;background:radial-gradient(circle at 32% 28%,var(--accent-bright) 0%,var(--accent) 45%,var(--accent-deep) 85%,#5a3e1f 100%);display:flex;align-items:center;justify-content:center;color:#1a140e;box-shadow:inset 0 1px #ffebc84d,inset 0 -3px 10px #00000040,0 0 0 6px #d4a24c0f,0 0 32px var(--accent-glow),0 0 80px var(--accent-glow-soft),0 14px 28px #00000080;transition:transform .15s}.m-mic:active{transform:scale(.95)}.m-mic:before{content:"";position:absolute;inset:-8px;border-radius:50%;border:1px solid var(--hairline-gold);opacity:.6;pointer-events:none}.m-mic:after{content:"";position:absolute;inset:-14px;border-radius:50%;border:1px solid var(--hairline-warm);opacity:.3;pointer-events:none}.m-mic.is-listening{animation:mic-pulse 1.2s ease-in-out infinite}.m-mic.is-speaking{background:radial-gradient(circle at 32% 28%,#f0c891,#d4a24c 45%,#8a5d2e)}@keyframes mic-pulse{0%,to{box-shadow:inset 0 1px #ffebc84d,inset 0 -3px 10px #00000040,0 0 0 6px #d4a24c33,0 0 32px var(--accent-glow),0 0 80px var(--accent-glow-soft),0 14px 28px #00000080}50%{box-shadow:inset 0 1px #ffebc84d,inset 0 -3px 10px #00000040,0 0 0 12px #d4a24c59,0 0 50px var(--accent-glow),0 0 110px var(--accent-glow-soft),0 14px 28px #00000080}}.m-error{background:#c464642e;color:#e8b8b0;border:1px solid rgba(196,100,100,.5);border-radius:12px;padding:8px 14px;font-size:12px;text-align:center}.m-onboard-overlay{position:fixed;inset:0;z-index:50;background:#0a0704d9;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);display:flex;align-items:flex-end;padding:env(safe-area-inset-bottom,24px) 20px;padding-bottom:calc(env(safe-area-inset-bottom,24px) + 32px)}.m-onboard-content{width:100%;position:relative}.m-onboard-emblem{position:fixed;top:calc(env(safe-area-inset-top,0px) + 32px);left:50%;transform:translate(-50%);width:180px;max-width:50vw;height:auto;opacity:.94;filter:drop-shadow(0 0 24px rgba(217,176,114,.22)) drop-shadow(0 8px 22px rgba(0,0,0,.7));z-index:51;pointer-events:none;user-select:none;-webkit-user-select:none;-webkit-user-drag:none;animation:m-onboard-emblem-in .55s cubic-bezier(.2,.8,.2,1)}@keyframes m-onboard-emblem-in{0%{opacity:0;transform:translate(-50%,-8px) scale(.94)}to{opacity:.94;transform:translate(-50%) scale(1)}}@media(max-height:700px){.m-onboard-emblem{width:130px;top:calc(env(safe-area-inset-top,0px) + 18px)}}.m-onboard-card{background:#140e08f2;border:1px solid var(--hairline-warm);border-radius:24px;padding:32px 24px 24px;text-align:center;box-shadow:inset 0 1px #ffdcaa1f,0 20px 60px #000000b3;display:flex;flex-direction:column;align-items:center;gap:20px}.m-onboard-title{font-family:Georgia,serif;font-weight:400;font-size:26px;line-height:1.2;color:var(--text-primary);letter-spacing:.02em;margin:0}.m-onboard-text{font-size:15px;line-height:1.55;color:var(--text-secondary);margin:0;max-width:320px}.m-onboard-dots{display:flex;gap:8px}.m-onboard-dots span{width:6px;height:6px;border-radius:50%;background:var(--text-faint, #5a4a3a)}.m-onboard-dots span.active{background:var(--accent);width:20px;border-radius:3px}.m-onboard-btn{background:linear-gradient(180deg,var(--accent-bright) 0%,var(--accent) 100%);color:#1a140e;border:0;border-radius:100px;padding:16px 72px;font-size:16px;font-weight:500;font-family:Georgia,serif;cursor:pointer;box-shadow:0 8px 24px #d9b07240;margin-top:4px;min-height:48px}.m-onboard-skip{background:transparent;border:0;color:var(--text-muted);font-size:13px;padding:8px 16px;cursor:pointer}.grain-overlay{position:fixed;inset:0;pointer-events:none;z-index:100;opacity:.05;mix-blend-mode:overlay;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.8'/%3E%3C/svg%3E")}.m-splash{position:fixed;inset:0;z-index:250;display:flex;align-items:center;justify-content:center;animation:splashFade .4s ease-in;pointer-events:all}.m-splash-bg{position:absolute;inset:0;background:radial-gradient(ellipse 70% 50% at 50% 35%,#2a1a0e,#100806,#050201),#050201}.m-splash-content{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:16px;text-align:center;padding:0 32px}.m-splash-emblem{color:#d9b072;filter:drop-shadow(0 0 20px rgba(217,176,114,.3));animation:splashEmblem 2s ease-in-out infinite}.m-splash-title{font-family:Georgia,serif;font-size:32px;font-weight:600;color:#f0d8a8;margin:0;letter-spacing:.04em;text-shadow:0 2px 8px rgba(0,0,0,.5)}.m-splash-sub{color:#a08868;font-size:13px;letter-spacing:.12em;text-transform:uppercase;font-family:Georgia,serif;margin-top:-4px}.m-splash-dots{display:flex;gap:8px;margin-top:18px}.m-splash-dots span{width:6px;height:6px;border-radius:50%;background:#d9b072;opacity:.3;animation:splashDot 1.4s ease-in-out infinite}.m-splash-dots span:nth-child(2){animation-delay:.2s}.m-splash-dots span:nth-child(3){animation-delay:.4s}@keyframes splashFade{0%{opacity:0}to{opacity:1}}@keyframes splashEmblem{0%,to{opacity:.8;transform:scale(1)}50%{opacity:1;transform:scale(1.04)}}@keyframes splashDot{0%,to{opacity:.3;transform:scale(.8)}50%{opacity:1;transform:scale(1.2)}}.m-thinking-label{display:inline-block;vertical-align:middle;color:var(--text-secondary)}.m-thinking-dots{display:inline-flex;vertical-align:middle;gap:4px;margin-left:6px}.m-thinking-dots span{width:5px;height:5px;border-radius:50%;background:var(--accent, #d9b072);opacity:.3;animation:thinkDot 1.2s ease-in-out infinite}.m-thinking-dots span:nth-child(2){animation-delay:.15s}.m-thinking-dots span:nth-child(3){animation-delay:.3s}@keyframes thinkDot{0%,80%,to{opacity:.25;transform:scale(.85)}40%{opacity:1;transform:scale(1.15)}}.m-recognized{display:flex;flex-direction:column;gap:4px;padding-bottom:12px;margin-bottom:12px;border-bottom:1px solid var(--hairline-warm, rgba(217, 176, 114, .15))}.m-recognized-label{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted, #8a7560);opacity:.8}.m-recognized-text{font-size:15px;line-height:1.4;color:var(--text-primary, #f0d8a8);font-family:Georgia,serif;font-style:italic}.m-thinking-row{display:flex;align-items:center;gap:6px}.m-thinking-label{font-size:14px;color:var(--text-secondary, #a08868)}.m-thinking-dots span{width:7px;height:7px;box-shadow:0 0 8px #d9b07299}.m-streaming{display:flex;flex-direction:column;gap:8px}.m-streaming-text{font-size:14.5px;line-height:1.45;color:var(--text-primary, #f0d8a8);font-family:Georgia,serif;animation:streamFade .18s ease-out}@keyframes streamFade{0%{opacity:.5}to{opacity:1}}.m-thinking-dots--inline{align-self:flex-start;margin-top:2px}.admin-root{min-height:100vh;background:#f5f5f0;color:#2c2620;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;font-size:14px;overflow:auto}.admin-login{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:24px;background:linear-gradient(135deg,#1a140e,#2c2620)}.admin-login-card{background:#f5f5f0;border-radius:12px;padding:40px;width:100%;max-width:380px;box-shadow:0 20px 60px #0006}.admin-login-title{font-size:22px;font-weight:600;text-align:center;margin-bottom:4px;color:#2c2620}.admin-login-subtitle{text-align:center;font-size:13px;color:#8a7e6d;margin-bottom:28px}.admin-login-form{display:flex;flex-direction:column;gap:16px}.admin-input{width:100%;padding:12px 14px;border:1px solid #d6cfc1;border-radius:8px;font-size:14px;background:#fff;color:#2c2620;outline:none;transition:border-color .15s}.admin-input:focus{border-color:#8b6f47}.admin-btn{padding:12px 18px;background:#2c2620;color:#f5f5f0;border:0;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:background .15s}.admin-btn:hover:not(:disabled){background:#4a3f33}.admin-btn:disabled{opacity:.5;cursor:not-allowed}.admin-btn--secondary{background:transparent;color:#2c2620;border:1px solid #d6cfc1}.admin-btn--secondary:hover:not(:disabled){background:#ebe6dc}.admin-error{color:#b04040;font-size:13px;text-align:center;padding:8px 12px;background:#b0404014;border-radius:6px}.admin-layout{display:grid;grid-template-columns:220px 1fr;min-height:100vh}.admin-sidebar{background:#2c2620;color:#d6cfc1;padding:20px 0;display:flex;flex-direction:column}.admin-sidebar-brand{font-size:16px;font-weight:600;padding:0 20px 20px;border-bottom:1px solid rgba(214,207,193,.1);color:#f5f5f0}.admin-sidebar-brand small{display:block;font-size:11px;font-weight:400;color:#8a7e6d;margin-top:4px}.admin-sidebar-nav{flex:1;padding:16px 0;display:flex;flex-direction:column}.admin-sidebar-link{padding:10px 20px;color:#d6cfc1;text-decoration:none;font-size:14px;display:flex;align-items:center;gap:10px;transition:background .12s;border-left:3px solid transparent}.admin-sidebar-link:hover{background:#d6cfc10d}.admin-sidebar-link.active{background:#d6cfc114;color:#f5f5f0;border-left-color:#8b6f47;font-weight:500}.admin-sidebar-footer{padding:16px 20px;border-top:1px solid rgba(214,207,193,.1)}.admin-sidebar-logout{background:none;border:1px solid rgba(214,207,193,.2);color:#d6cfc1;padding:8px 14px;border-radius:6px;font-size:13px;cursor:pointer;width:100%;transition:background .12s}.admin-sidebar-logout:hover{background:#d6cfc114}.admin-content{padding:32px 40px;overflow:auto}.admin-page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid #e0d9c8}.admin-page-title{font-size:22px;font-weight:600;color:#2c2620}.admin-page-subtitle{font-size:13px;color:#8a7e6d;margin-top:4px}.admin-placeholder{background:#fff;border:1px dashed #d6cfc1;border-radius:8px;padding:60px 24px;text-align:center;color:#8a7e6d}.admin-placeholder h3{font-size:16px;font-weight:500;color:#2c2620;margin-bottom:8px}.admin-loading{display:flex;align-items:center;justify-content:center;min-height:100vh;color:#8a7e6d}.admin-textarea{resize:vertical;font-family:inherit;line-height:1.5}.admin-btn--danger{background:#b04040}.admin-btn--danger:hover:not(:disabled){background:#c95050}.admin-btn--danger-confirm{background:#c95050;animation:pulseDanger 1s ease infinite}@keyframes pulseDanger{0%,to{box-shadow:0 0 #c9505080}50%{box-shadow:0 0 0 8px #c9505000}}.event-quickadd{background:#fff;border:1px solid #d6cfc1;border-radius:10px;padding:12px 14px;margin-bottom:16px;position:relative}.event-quickadd-row{display:flex;align-items:center;gap:10px}.event-quickadd-icon{font-size:18px;opacity:.6}.event-quickadd-input{flex:1;border:0;outline:0;font-size:14px;background:transparent;color:#2c2620}.event-quickadd-input::placeholder{color:#a89a82}.event-quickadd-hints{margin-top:10px;padding-top:10px;border-top:1px solid #ebe6dc;display:flex;flex-direction:column;gap:6px}.event-quickadd-hint-label{font-size:12px;color:#8a7e6d;margin-bottom:2px}.event-quickadd-example{background:#f5f5f0;border:1px solid transparent;border-radius:6px;padding:8px 10px;font-size:13px;color:#4a3f33;cursor:pointer;text-align:left;font-family:inherit;transition:background .12s,border-color .12s}.event-quickadd-example:hover{background:#ebe6dc;border-color:#d6cfc1}.event-filters{display:flex;gap:10px;margin-bottom:14px;flex-wrap:wrap}.event-filters .admin-input{width:auto;min-width:150px}.event-filter-search{flex:1;min-width:240px}.event-table-wrap{background:#fff;border:1px solid #d6cfc1;border-radius:10px;overflow:hidden}.event-table{width:100%;border-collapse:collapse;font-size:14px}.event-table thead th{background:#ebe6dc;text-align:left;padding:10px 14px;font-weight:500;font-size:12px;color:#8a7e6d;text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid #d6cfc1}.event-row{cursor:pointer;transition:background .1s;border-bottom:1px solid #ebe6dc}.event-row:last-child{border-bottom:0}.event-row:hover{background:#f9f6ef}.event-row td{padding:12px 14px;vertical-align:top}.event-row-date{font-weight:500;color:#2c2620}.event-row-time{font-size:12px;color:#8a7e6d;margin-top:2px}.event-row-title{font-weight:500}.event-row-location{font-size:12px;color:#8a7e6d;margin-top:2px}.event-row-category{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;background:#f5f5f0;border-radius:6px;font-size:12px;color:#4a3f33}.event-row-status{display:inline-block;padding:3px 8px;border-radius:6px;font-size:12px;font-weight:500}.event-row-status.status-draft{background:#f0ebd9;color:#8a7e6d}.event-row-status.status-published{background:#e3efd9;color:#4a7032}.event-row-status.status-archived{background:#ebe6dc;color:#8a7e6d;text-decoration:line-through}.event-form-overlay{position:fixed;inset:0;background:#1c160e66;z-index:50;display:flex;justify-content:flex-end;animation:fadeIn .15s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.event-form-panel{background:#f5f5f0;width:480px;max-width:100vw;height:100%;display:flex;flex-direction:column;box-shadow:-8px 0 30px #0003;animation:slideIn .2s ease}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.event-form-header{display:flex;justify-content:space-between;align-items:center;padding:18px 24px;border-bottom:1px solid #e0d9c8}.event-form-title{font-size:17px;font-weight:600}.event-form-close{background:none;border:0;font-size:20px;cursor:pointer;color:#8a7e6d;padding:4px 8px;border-radius:4px;transition:background .12s,color .12s}.event-form-close:hover{background:#ebe6dc;color:#2c2620}.event-form-body{flex:1;overflow-y:auto;padding:20px 24px;display:flex;flex-direction:column;gap:14px}.event-form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.event-form-field{display:flex;flex-direction:column;gap:5px}.event-form-label{font-size:12px;font-weight:500;color:#6c5e4a;text-transform:uppercase;letter-spacing:.03em}.event-form-required{color:#b04040}.event-form-hint{font-size:11px;color:#8a7e6d;line-height:1.4}.event-form-footer{padding:16px 24px;border-top:1px solid #e0d9c8;display:flex;align-items:center;gap:10px}.stress-editor{background:#fff;border:1px solid #d6cfc1;border-radius:8px;padding:14px 16px;position:relative}.stress-editor-stats{font-size:11px;color:#8a7e6d;text-transform:uppercase;letter-spacing:.04em;margin-bottom:8px;padding-bottom:8px;border-bottom:1px solid #ebe6dc}.stress-editor-text{font-size:15px;line-height:1.7;color:#2c2620;white-space:pre-wrap}.stress-editor-word{display:inline-block;cursor:pointer;padding:0 2px;margin:0 -2px;border-radius:4px;transition:background .1s;outline:none}.stress-editor-word:hover{background:#f5edd6}.stress-editor-word:focus{background:#f5edd6;box-shadow:0 0 0 2px #8b6f474d}.stress-editor-word.editing{background:#f5edd6;box-shadow:0 0 0 2px #8b6f47}.stress-vowel{color:#8b6f47;font-weight:700;border-bottom:2px solid #8b6f47;padding-bottom:0}.stress-vowel--yo{color:#6c5e4a}.word-popover{background:#fff;border:1px solid #d6cfc1;border-radius:10px;box-shadow:0 10px 30px #0000002e;padding:14px 16px;width:360px;z-index:100;animation:popoverAppear .12s ease}@keyframes popoverAppear{0%{opacity:0;transform:translateY(-100%) scale(.95)}to{opacity:1;transform:translateY(-100%) scale(1)}}.word-popover--bottom{animation:popoverAppearBottom .12s ease}@keyframes popoverAppearBottom{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.word-popover-arrow{position:absolute;left:50%;transform:translate(-50%);width:12px;height:12px;background:#fff;border:1px solid #d6cfc1;border-top:0;border-left:0}.word-popover--top .word-popover-arrow{bottom:-7px;transform:translate(-50%) rotate(45deg)}.word-popover--bottom .word-popover-arrow{top:-7px;border:1px solid #d6cfc1;border-bottom:0;border-right:0;transform:translate(-50%) rotate(45deg)}.word-popover-letters{display:flex;justify-content:center;gap:4px;flex-wrap:wrap;margin-bottom:10px;font-size:22px;font-family:Georgia,serif}.word-popover-letter{display:inline-block;padding:4px 6px;border-radius:6px;min-width:26px;text-align:center;font-family:inherit;font-size:22px;position:relative}.word-popover-letter.consonant{color:#4a3f33}.word-popover-letter.vowel{background:#f5f5f0;border:1px solid #e0d9c8;cursor:pointer;color:#4a3f33;transition:background .12s,color .12s}.word-popover-letter.vowel:hover{background:#ebe6dc}.word-popover-letter.vowel.stressed{background:#8b6f47;color:#fff;border-color:#8b6f47}.word-popover-acute{display:inline-block;margin-left:-8px;position:relative;top:-2px}.word-popover-current{text-align:center;font-size:15px;color:#6c5e4a;background:#f9f6ef;border-radius:6px;padding:6px 10px;margin-bottom:12px;font-weight:500}.word-popover-actions{display:flex;gap:6px;flex-wrap:wrap}.word-popover-actions .admin-btn{padding:8px 12px;font-size:13px}.word-popover-error{margin-top:8px;font-size:12px}.announce-editor{display:flex;flex-direction:column;gap:10px}.announce-preview{background:#f9f6ef;border:1px solid #e0d9c8;border-radius:8px;padding:10px 12px}.announce-preview-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;gap:10px}.announce-preview-label{font-size:11px;font-weight:500;color:#6c5e4a;text-transform:uppercase;letter-spacing:.03em}.announce-preview-empty{color:#a89a82;font-size:13px;text-align:center;padding:16px 0}.announce-play{font-size:12px;padding:6px 12px}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{width:100%;height:100%;overflow:hidden;background:#0e0a08}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;color:#e8ddc8;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}.frame-vignette{position:absolute;inset:0;pointer-events:none;z-index:5;background:radial-gradient(ellipse 60% 75% at 50% 48%,transparent 0%,transparent 55%,rgba(14,10,8,.5) 80%,rgba(14,10,8,.95) 100%);mix-blend-mode:multiply}.header{position:absolute;top:20px;left:50%;transform:translate(-50%);z-index:10;text-align:center;pointer-events:none;user-select:none}.header-title{font-family:Playfair Display,Georgia,serif;font-size:26px;font-weight:900;letter-spacing:.4em;color:#d4c19a;text-shadow:0 2px 8px rgba(0,0,0,.8);border-top:1px solid rgba(212,193,154,.4);border-bottom:1px solid rgba(212,193,154,.4);padding:8px 24px;display:inline-block}.header-sub{margin-top:6px;font-size:11px;letter-spacing:.25em;color:#d4c19a99;text-transform:uppercase;font-style:italic}.speech-bubble{position:absolute;bottom:230px;right:30px;max-width:340px;z-index:8;opacity:0;transform:translateY(20px) scale(.95);transition:all .4s cubic-bezier(.34,1.56,.64,1);pointer-events:none}.speech-bubble.visible{opacity:1;transform:translateY(0) scale(1)}.speech-bubble-inner{position:relative;background:linear-gradient(180deg,#f4ead0,#e8d9b0);color:#2a1f10;padding:16px 20px;border-radius:14px;font-family:Georgia,Times New Roman,serif;font-size:16px;line-height:1.45;font-style:italic;box-shadow:0 10px 30px #0009,inset 0 1px #ffffff80,inset 0 -1px #00000026;border:1px solid #b89d6a}.speech-bubble-content{min-height:24px}.speech-bubble-content:after{content:"▌";display:inline-block;margin-left:2px;animation:blink .8s infinite;opacity:.6}.speech-bubble-tail{position:absolute;left:-14px;top:24px;width:0;height:0;border-style:solid;border-width:12px 16px 12px 0;border-color:transparent #e8d9b0 transparent transparent;filter:drop-shadow(-2px 0 2px rgba(0,0,0,.3))}@keyframes blink{0%,49%{opacity:.6}50%,to{opacity:0}}.controls{position:absolute;bottom:16px;left:50%;transform:translate(-50%);z-index:9;width:min(720px,calc(100vw - 32px));background:#140e0ad9;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);padding:14px 16px;border-radius:12px;border:1px solid rgba(212,193,154,.25);box-shadow:0 10px 40px #0009}.controls-status{display:flex;align-items:center;gap:10px;font-size:13px;color:#d4c19ab3;margin-bottom:10px;font-variant:small-caps;letter-spacing:.05em}.status-dot{width:8px;height:8px;border-radius:50%;background:#555;transition:all .3s}.status-dot.speaking{background:#6bcf6b;box-shadow:0 0 12px #6bcf6b;animation:pulse 1s infinite}@keyframes pulse{0%,to{box-shadow:0 0 8px #6bcf6b}50%{box-shadow:0 0 16px #6bcf6b}}.loudness-meter{margin-left:auto;height:4px;width:80px;background:#ffffff14;border-radius:2px;overflow:hidden}.loudness-meter>span{display:block;height:100%;background:linear-gradient(90deg,#6bcf6b,#d4c19a);transition:width .08s linear}.presets{display:flex;gap:6px;margin-bottom:8px;flex-wrap:wrap}.preset{padding:4px 10px;background:#d4c19a14;color:#d4c19ab3;border:1px solid rgba(212,193,154,.15);border-radius:4px;cursor:pointer;font-size:11px;letter-spacing:.05em;text-transform:uppercase;font-family:inherit;transition:all .2s}.preset:hover{background:#d4c19a26;color:#e8ddc8}.preset.active{background:#d4c19a33;color:#e8ddc8;border-color:#d4c19a80}.text-input{width:100%;padding:10px 12px;background:#0006;color:#e8ddc8;border:1px solid rgba(212,193,154,.2);border-radius:8px;font-size:14px;font-family:Georgia,serif;font-style:italic;resize:vertical;margin-bottom:10px;line-height:1.4}.text-input:focus{outline:none;border-color:#d4c19a80}.actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.btn{padding:9px 16px;border:1px solid rgba(212,193,154,.3);border-radius:6px;cursor:pointer;font-size:13px;font-family:inherit;letter-spacing:.03em;transition:all .2s}.btn-primary{background:linear-gradient(180deg,#b89d6a,#8a7449);color:#1a1208;font-weight:600}.btn-primary:hover{background:linear-gradient(180deg,#c8ad7a,#9a8459)}.btn-secondary{background:#3c1e1eb3;color:#e8ddc8}.btn-secondary:hover{background:#502828d9}.provider-badge{margin-left:8px;font-size:10px;letter-spacing:.05em;padding:2px 8px;border-radius:10px;background:#b89d6a26;color:#e8ddc8b3;border:1px solid rgba(212,193,154,.2);white-space:nowrap}.ttfa-badge{font-size:10px;padding:2px 6px;background:#6bcf6b26;color:#6bcf6be6;border-radius:6px;border:1px solid rgba(107,207,107,.3)}.voice-selector{display:flex;align-items:center;gap:8px;margin-bottom:10px}.voice-selector label{font-size:11px;color:#d4c19ab3;text-transform:lowercase;font-variant:small-caps;letter-spacing:.05em}.voice-select{flex:1;padding:6px 10px;background:#0006;color:#e8ddc8;border:1px solid rgba(212,193,154,.25);border-radius:6px;font-family:Georgia,serif;font-size:13px;cursor:pointer}.voice-select:focus{outline:none;border-color:#d4c19a99}.voice-select option{background:#1a1410;color:#e8ddc8}.error-banner{margin-top:8px;padding:8px 12px;background:#781e1e66;color:#fcc;border:1px solid rgba(255,100,100,.3);border-radius:6px;font-size:12px}.state-indicator{position:absolute;top:90px;left:50%;transform:translate(-50%);z-index:7;display:flex;align-items:center;gap:10px;padding:8px 18px;background:#140e0ad9;backdrop-filter:blur(12px);border:1px solid rgba(212,193,154,.3);border-radius:100px;font-size:13px;color:#d4c19a;font-variant:small-caps;letter-spacing:.08em;pointer-events:none;animation:fadeInDown .3s ease}.state-pulse{width:8px;height:8px;background:#6bcf6b;border-radius:50%;animation:pulse 1.3s infinite}.user-transcript{position:absolute;bottom:280px;left:30px;z-index:7;max-width:340px;padding:10px 14px;background:#786e50d9;backdrop-filter:blur(8px);border-left:3px solid #d4c19a;border-radius:4px 8px 8px 4px;font-family:Georgia,serif;font-size:14px;font-style:italic;color:#f4ead0;pointer-events:none;animation:fadeInLeft .3s ease}.user-transcript.faded{opacity:.55;font-size:13px}.user-transcript .label{font-style:normal;font-weight:700;color:#1a1208;background:#d4c19a99;padding:1px 6px;border-radius:3px;margin-right:6px;font-size:11px;letter-spacing:.05em}.avatar-subtitle{position:absolute;top:140px;left:50%;transform:translate(-50%);z-index:6;max-width:70%;padding:12px 24px;background:#f4ead0f2;backdrop-filter:blur(8px);border:1px solid rgba(184,157,106,.4);border-radius:12px;font-family:Georgia,serif;font-size:18px;line-height:1.4;color:#2a1f10;text-align:center;font-style:italic;box-shadow:0 8px 24px #00000080;pointer-events:none;animation:fadeInDown .25s ease}@keyframes fadeInDown{0%{opacity:0;transform:translate(-50%,-8px)}to{opacity:1;transform:translate(-50%)}}@keyframes fadeInLeft{0%{opacity:0;transform:translate(-12px)}to{opacity:1;transform:translate(0)}}.mic-row{display:flex;align-items:center;gap:12px;margin-bottom:10px}.mic-btn{flex-shrink:0;padding:12px 22px;background:linear-gradient(180deg,#6b8a45,#4d6630);color:#fff;border:1px solid rgba(212,193,154,.4);border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;font-family:inherit;letter-spacing:.02em;user-select:none;transition:all .15s}.mic-btn:hover:not(:disabled){background:linear-gradient(180deg,#7ba055,#5d763e)}.mic-btn:active:not(:disabled),.mic-btn.listening{background:linear-gradient(180deg,#c44,#922);box-shadow:0 0 12px #dc323299;transform:scale(.98)}.mic-btn:disabled{opacity:.4;cursor:not-allowed;background:#333}.interim-text{font-style:italic;color:#d4c19a99;font-family:Georgia,serif;font-size:13px}.chat-history{margin:10px 0;background:#0000004d;border:1px solid rgba(212,193,154,.15);border-radius:8px;padding:8px 12px;font-size:12px}.chat-history summary{cursor:pointer;color:#d4c19ab3;font-variant:small-caps;letter-spacing:.05em;padding:2px 0}.chat-messages{margin-top:8px;max-height:200px;overflow-y:auto;display:flex;flex-direction:column;gap:6px}.msg{padding:6px 8px;border-radius:6px;font-family:Georgia,serif;line-height:1.4}.msg-user{background:#b89d6a1a;color:#e8ddc8}.msg-assistant{background:#6b8a4526;color:#d4e6b8}.msg strong{font-style:normal;font-weight:700;color:#d4c19ae6;margin-right:6px}.msg.streaming{opacity:.85}.btn:disabled{opacity:.4;cursor:not-allowed}.manual-slider{flex:1;min-width:180px;display:flex;flex-direction:column;gap:2px}.manual-slider label{font-size:10px;color:#d4c19a80;text-transform:uppercase;letter-spacing:.1em}.manual-slider input[type=range]{width:100%;accent-color:#b89d6a}.note{margin-top:8px;font-size:11px;color:#d4c19a66;font-style:italic;text-align:center}
