.app-header{display:flex;align-items:center;justify-content:space-between;height:56px;padding:0 var(--space-8);border-bottom:1px solid var(--color-surface-tint);background:var(--md-sys-color-surface-container-lowest);flex-shrink:0;margin-bottom:var(--space-1)}.app-header__logo-link{display:flex;align-items:center}.app-header__logo{height:32px;width:auto;display:block;opacity:.9;transition:opacity var(--transition-fast)}.app-header__logo-link:hover .app-header__logo{opacity:1}.app-header__actions{display:flex;align-items:center;gap:var(--space-2)}.app-header__theme-toggle{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;font-size:15px;color:var(--md-sys-color-on-surface-variant);background:transparent;transition:background var(--transition-fast),color var(--transition-fast)}.app-header__theme-toggle:hover{background:var(--color-on-surface-tint);color:var(--md-sys-color-on-surface)}.app-header__user{display:flex;align-items:center;justify-content:center;width:36px;height:36px;font-size:18px;color:var(--md-sys-color-on-surface-variant)}.app-header__user-menu{position:relative}.app-header__avatar-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;font-size:18px;background:transparent;border:none;border-radius:50%;color:var(--md-sys-color-on-surface-variant);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast)}.app-header__avatar-btn:hover{background:var(--md-sys-color-surface-container-high);color:var(--md-sys-color-on-surface)}.app-header__dropdown{position:absolute;top:calc(100% + 8px);right:0;min-width:220px;background:var(--md-sys-color-surface-container-high);border:1px solid var(--md-sys-color-outline-variant);border-radius:.75rem;box-shadow:0 4px 16px #0000004d;z-index:100;overflow:hidden}.app-header__dropdown-identity{display:flex;flex-direction:column;gap:2px;padding:.75rem 1rem}.app-header__dropdown-name{font-size:.9rem;font-weight:600;color:var(--md-sys-color-on-surface)}.app-header__dropdown-email{font-size:.8rem;color:var(--md-sys-color-on-surface-variant)}.app-header__dropdown-divider{margin:0;border:none;border-top:1px solid var(--md-sys-color-outline-variant)}.app-header__dropdown-item{display:flex;align-items:center;gap:.625rem;width:100%;padding:.625rem 1rem;background:transparent;border:none;font-size:.875rem;color:var(--md-sys-color-on-surface-variant);cursor:pointer;text-align:left;transition:background var(--transition-fast),color var(--transition-fast)}.app-header__dropdown-item:hover{background:var(--md-sys-color-surface-container-highest);color:var(--md-sys-color-on-surface)}.app-header__signout{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;background:transparent;border:none;border-radius:50%;color:var(--md-sys-color-on-surface-variant);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast)}.app-header__signout:hover{background:var(--md-sys-color-surface-container-high);color:var(--md-sys-color-on-surface)}.app-layout{min-height:100vh;display:flex;flex-direction:column}.app-layout__main{flex:1}.app-footer{display:flex;align-items:center;gap:var(--space-3);height:44px;padding:0 var(--space-8);border-top:1px solid var(--md-sys-color-outline-variant);background:var(--md-sys-color-surface-container-lowest);font-size:var(--md-sys-typescale-label-small);color:var(--md-sys-color-outline);flex-shrink:0}.app-footer__brand{font-weight:600;color:var(--md-sys-color-on-surface-variant);letter-spacing:.01em}.app-footer__sep{width:3px;height:3px;border-radius:50%;background:var(--md-sys-color-outline-variant)}.tag-chip{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:999px;font-size:var(--md-sys-typescale-label-small);font-weight:500;line-height:1.4;letter-spacing:.01em;background:var(--md-sys-color-surface-container-high);color:var(--md-sys-color-on-surface-variant);white-space:nowrap;-webkit-user-select:none;user-select:none;transition:background var(--transition-fast),color var(--transition-fast)}.tag-chip--interactive{cursor:pointer}.tag-chip--interactive:hover{background:var(--md-sys-color-surface-container-highest);color:var(--md-sys-color-on-surface)}.tag-chip--interactive:focus-visible{outline:2px solid var(--md-sys-color-primary);outline-offset:2px}.tag-chip--selected{background:var(--md-sys-color-primary-container);color:var(--md-sys-color-on-primary-container)}.tag-chip--selected:hover{background:color-mix(in srgb,var(--md-sys-color-primary-container) 85%,var(--md-sys-color-primary) 15%)}.tag-chip__remove{display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;margin-left:2px;border-radius:50%;font-size:12px;line-height:1;color:inherit;opacity:.65;transition:opacity var(--transition-fast),background var(--transition-fast)}.tag-chip__remove:hover{opacity:1;background:#ffffff1f}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:500;background:var(--md-sys-color-scrim);display:flex;align-items:center;justify-content:center;padding:var(--space-4)}.modal{background:var(--md-sys-color-surface-container-high);border:1px solid var(--md-sys-color-outline-variant);border-radius:var(--radius-xl);box-shadow:var(--md-sys-elevation-3);width:100%;max-width:560px;max-height:90vh;overflow-y:auto;padding:var(--space-6)}.modal__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-6)}.modal__header h2{font-size:var(--md-sys-typescale-headline-small);font-weight:600;color:var(--md-sys-color-on-surface);display:flex;align-items:center;gap:var(--space-3)}.modal__close{width:36px;height:36px;display:flex;align-items:center;justify-content:center;font-size:var(--text-xl);color:var(--md-sys-color-on-surface-variant);border-radius:50%;transition:background var(--transition-fast),color var(--transition-fast)}.modal__close:hover{background:#c4c5ce14;color:var(--md-sys-color-on-surface)}.modal__actions{display:flex;justify-content:flex-end;gap:var(--space-3);margin-top:var(--space-6)}.import__field{margin-bottom:var(--space-4)}.import__field label{display:block;font-size:var(--md-sys-typescale-label-large);color:var(--md-sys-color-on-surface-variant);margin-bottom:var(--space-2)}.import__text-input{width:100%;padding:var(--space-2) var(--space-3);background:transparent;border:1px solid var(--md-sys-color-outline-variant);border-radius:var(--radius-sm);font-size:var(--md-sys-typescale-body-large);color:var(--md-sys-color-on-surface);transition:border-color var(--transition-fast)}.import__text-input:focus{border-color:var(--md-sys-color-primary)}.import__dropzone{padding:var(--space-8);border:1px dashed var(--md-sys-color-outline-variant);border-radius:var(--radius-md);text-align:center;cursor:pointer;transition:border-color var(--transition-fast),background var(--transition-fast);margin-bottom:var(--space-4)}.import__dropzone p{color:var(--md-sys-color-on-surface-variant);font-size:var(--md-sys-typescale-label-large)}.import__dropzone:hover{border-color:var(--md-sys-color-outline);background:#c4c5ce0a}.import__dropzone--active{border-color:var(--md-sys-color-primary);background:var(--color-btn-tint)}.workspace{max-width:1120px;margin:0 auto;padding:var(--space-10) var(--space-8)}.workspace__heading{flex:1;min-width:0}.workspace__title{font-size:2.5rem;font-weight:600;color:var(--md-sys-color-on-surface);line-height:1.1;margin-bottom:var(--space-2)}.workspace__tagline{font-size:var(--md-sys-typescale-body-large);color:var(--md-sys-color-on-surface-variant);max-width:56ch}.workspace__header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-6);margin-bottom:var(--space-10)}.workspace__brand{display:flex;align-items:baseline;gap:var(--space-3)}.workspace__logo{height:60px;width:auto;display:block}.workspace__header-actions{display:flex;align-items:center;gap:var(--space-3);flex-shrink:0}.workspace__theme-toggle{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;font-size:15px;color:var(--md-sys-color-on-surface-variant);background:transparent;transition:background var(--transition-fast),color var(--transition-fast)}.workspace__theme-toggle:hover{background:var(--color-on-surface-tint);color:var(--md-sys-color-on-surface)}.workspace__controls{display:flex;flex-direction:column;gap:var(--space-3);margin-bottom:var(--space-8)}.workspace__search-row{display:flex;align-items:center;gap:var(--space-3)}.workspace__search-wrap{position:relative;flex:1}.workspace__search-icon{position:absolute;left:var(--space-4);top:50%;transform:translateY(-50%);font-size:13px;color:var(--md-sys-color-outline);pointer-events:none}.workspace__search{width:100%;height:44px;padding:0 var(--space-8) 0 2.5rem;background:var(--md-sys-color-surface-container-low);border-radius:var(--radius-md);border:none;font-size:var(--md-sys-typescale-body-large);color:var(--md-sys-color-on-surface);transition:background var(--transition-fast)}.workspace__search::placeholder{color:var(--md-sys-color-outline)}.workspace__search:focus{background:var(--md-sys-color-surface-container);outline:none}.workspace__search::-webkit-search-cancel-button{display:none}.workspace__search-clear{position:absolute;right:var(--space-3);top:50%;transform:translateY(-50%);width:22px;height:22px;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:16px;color:var(--md-sys-color-outline);transition:color var(--transition-fast),background var(--transition-fast)}.workspace__search-clear:hover{color:var(--md-sys-color-on-surface);background:#ffffff0f}.workspace__sort{display:flex;gap:2px;background:var(--md-sys-color-surface-container-low);border-radius:var(--radius-md);padding:4px;flex-shrink:0}.workspace__sort-btn{height:36px;padding:0 var(--space-4);border-radius:var(--radius-sm);font-size:var(--md-sys-typescale-label-large);font-weight:500;color:var(--md-sys-color-on-surface-variant);background:transparent;transition:background var(--transition-fast),color var(--transition-fast);white-space:nowrap}.workspace__sort-btn:hover{color:var(--md-sys-color-on-surface)}.workspace__sort-btn--active{background:var(--md-sys-color-surface-container-high);color:var(--md-sys-color-on-surface)}.workspace__tag-row{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-2)}.workspace__tags-clear{font-size:var(--md-sys-typescale-label-medium);color:var(--md-sys-color-primary);padding:2px var(--space-3);border-radius:var(--radius-sm);margin-left:var(--space-1);transition:background var(--transition-fast)}.workspace__tags-clear:hover{background:var(--color-accent-muted)}.workspace__loading,.workspace__error{text-align:center;padding:var(--space-16);color:var(--md-sys-color-on-surface-variant);font-size:var(--md-sys-typescale-body-large)}.workspace__error{color:var(--md-sys-color-error)}.workspace__empty{text-align:center;padding:var(--space-16) var(--space-8)}.workspace__empty-icon{font-size:3rem;margin-bottom:var(--space-4);opacity:.35}.workspace__empty h2{font-size:var(--md-sys-typescale-title-large);font-weight:400;margin-bottom:var(--space-2);color:var(--md-sys-color-on-surface)}.workspace__empty p{color:var(--md-sys-color-on-surface-variant);margin-bottom:var(--space-6)}.workspace__empty-actions{display:flex;gap:var(--space-3);justify-content:center}.workspace__no-results{text-align:center;padding:var(--space-12) var(--space-8)}.workspace__no-results p{color:var(--md-sys-color-on-surface-variant);margin-bottom:var(--space-4)}.workspace__no-results-actions{display:flex;gap:var(--space-2);justify-content:center}.workspace__filter-count{font-size:var(--md-sys-typescale-label-medium);color:var(--md-sys-color-outline);margin-bottom:var(--space-4);font-variant-numeric:tabular-nums}.workspace__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-4)}.script-card{text-align:left;padding:var(--space-6) var(--space-6) var(--space-5);background:var(--md-sys-color-surface-container-low);border:none;border-top:1px solid var(--color-surface-tint);border-radius:var(--radius-md);box-shadow:var(--md-sys-elevation-0);width:100%;min-height:130px;display:flex;flex-direction:column;transition:background var(--transition-normal),box-shadow var(--transition-normal),border-color var(--transition-normal)}.script-card:hover{background:var(--md-sys-color-surface-container);box-shadow:var(--md-sys-elevation-2);border-top-color:var(--color-surface-tint-hover)}.script-card__title{font-size:1.0625rem;font-weight:600;line-height:1.4;color:var(--md-sys-color-on-surface);margin-bottom:var(--space-4);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.script-card__tags{display:flex;flex-wrap:wrap;align-items:flex-start;gap:4px;min-height:22px;margin-bottom:var(--space-4);flex:1}.script-card__footer{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);margin-top:auto}.script-card__meta{display:flex;align-items:center;gap:var(--space-2);font-size:var(--md-sys-typescale-label-medium);color:var(--md-sys-color-outline);font-variant-numeric:tabular-nums}.script-card__footer-sep{opacity:.4}.script-card__duration{display:inline-flex;align-items:center;gap:5px;font-size:var(--md-sys-typescale-label-large);font-variant-numeric:tabular-nums;font-weight:600;color:var(--md-sys-color-primary);white-space:nowrap;flex-shrink:0}.script-card__duration i{font-size:10px;opacity:.6}@media(max-width:640px){.workspace{padding:var(--space-6) var(--space-4)}.workspace__logo{height:36px}.workspace__search-row{flex-direction:column;align-items:stretch}.workspace__sort{align-self:flex-start}.workspace__grid{grid-template-columns:1fr}}.tag-input{position:relative;margin-bottom:var(--space-4)}.tag-input__row{display:flex;align-items:flex-start;gap:var(--space-3)}.tag-input__label{font-size:var(--md-sys-typescale-label-small);color:var(--md-sys-color-outline);text-transform:uppercase;letter-spacing:.06em;font-size:10px;padding-top:5px;white-space:nowrap;flex-shrink:0}.tag-input__chips{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-1);flex:1;min-width:0;cursor:text}.tag-input__field{flex:1;min-width:80px;max-width:200px;padding:2px 4px;font-size:var(--md-sys-typescale-label-medium);color:var(--md-sys-color-on-surface);background:transparent;border:none;outline:none}.tag-input__field::placeholder{color:var(--md-sys-color-outline)}.tag-input__dropdown{position:absolute;top:calc(100% + var(--space-1));left:0;z-index:50;min-width:160px;background:var(--md-sys-color-surface-container-high);border-radius:var(--radius-md);box-shadow:var(--md-sys-elevation-2);padding:var(--space-1) 0;overflow:hidden}.tag-input__option{display:flex;align-items:center;gap:var(--space-2);width:100%;padding:var(--space-2) var(--space-4);text-align:left;font-size:var(--md-sys-typescale-body-medium);color:var(--md-sys-color-on-surface);transition:background var(--transition-fast)}.tag-input__option:hover{background:#ffffff0f}.tag-input__option--new{color:var(--md-sys-color-primary);font-style:italic}.tag-input__option--new i{font-size:10px;opacity:.7}.tag-input__empty{display:block;padding:var(--space-2) var(--space-4);font-size:var(--md-sys-typescale-label-small);color:var(--md-sys-color-outline);font-style:italic}.present-dropdown{position:relative;display:inline-flex}.present-dropdown__toggle{display:inline-flex;align-items:center;gap:var(--space-2)}.present-dropdown__chevron{font-size:2em;line-height:1;vertical-align:middle;position:relative;top:-.1em}.present-dropdown__menu{position:absolute;top:calc(100% + var(--space-1));right:0;min-width:140px;background:var(--md-sys-color-surface-container-high);border:1px solid var(--md-sys-color-outline-variant);border-radius:var(--radius-md);box-shadow:var(--md-sys-elevation-2);z-index:100;overflow:hidden}.present-dropdown__item{display:flex;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-3) var(--space-4);font-size:var(--md-sys-typescale-label-large);color:var(--md-sys-color-on-surface);text-align:left;transition:background var(--transition-fast)}.present-dropdown__item:hover{background:var(--color-on-surface-tint)}.present-dropdown__item-icon{font-size:1em;width:1.2em;text-align:center;color:var(--md-sys-color-on-surface-variant)}.confirm-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#0009;display:flex;align-items:center;justify-content:center}.confirm-modal{background:var(--md-sys-color-surface-container-high);border:1px solid var(--md-sys-color-outline-variant);border-radius:var(--radius-lg);box-shadow:var(--md-sys-elevation-3);padding:var(--space-8) var(--space-8) var(--space-6);width:min(420px,calc(100vw - var(--space-8) * 2));display:flex;flex-direction:column;gap:var(--space-4)}.confirm-modal__title{font-size:var(--md-sys-typescale-title-large);font-weight:600;color:var(--md-sys-color-on-surface)}.confirm-modal__message{font-size:var(--md-sys-typescale-body-medium);color:var(--md-sys-color-on-surface-variant);line-height:1.5}.confirm-modal__actions{display:flex;justify-content:flex-end;gap:var(--space-3);margin-top:var(--space-2)}.confirm-modal__actions .btn--danger{background:#c0392b;color:#fff}.confirm-modal__actions .btn--danger:hover{background:#e74c3c;filter:none;box-shadow:var(--md-sys-elevation-1)}.editor__rehearsals{margin-top:var(--space-6);padding:var(--space-4) var(--space-5);border-radius:var(--radius-md);background:var(--color-bg-elevated);border:1px solid var(--color-border)}.editor__rehearsals-title{font-size:var(--text-sm);font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em;margin:0;cursor:pointer;list-style:none;display:flex;align-items:center;gap:var(--space-2);-webkit-user-select:none;user-select:none}.editor__rehearsals-title::-webkit-details-marker{display:none}.editor__rehearsals-title:before{content:"›";display:inline-block;transition:transform .15s ease;font-size:1rem;color:var(--color-text-secondary)}.editor__rehearsals[open] .editor__rehearsals-title:before{transform:rotate(90deg)}.editor__rehearsals-body{margin-top:var(--space-3)}.rehearsal-history__table{width:100%;border-collapse:collapse;font-size:var(--text-sm)}.rehearsal-history__table th{text-align:left;padding:var(--space-1) var(--space-2);color:var(--color-text-secondary);font-weight:500;border-bottom:1px solid var(--color-border)}.rehearsal-history__table td{padding:var(--space-2) var(--space-2);border-bottom:1px solid var(--color-border);color:var(--color-text-primary)}.rehearsal-history__table tr:last-child td{border-bottom:none}.editor__format-bar{display:flex;gap:var(--space-1);padding:var(--space-2) 0 var(--space-1)}.editor__format-btn{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-sm);border:1px solid var(--md-sys-color-outline-variant);color:var(--md-sys-color-on-surface-variant);font-size:var(--md-sys-typescale-label-large);transition:background var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast);-webkit-user-select:none;user-select:none}.editor__format-btn:hover{background:var(--color-on-surface-tint);color:var(--md-sys-color-on-surface);border-color:var(--md-sys-color-outline)}.editor__delete-btn{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-sm);border:1px solid var(--md-sys-color-outline-variant);color:var(--md-sys-color-outline);transition:color var(--transition-fast),background var(--transition-fast),border-color var(--transition-fast)}.editor__delete-btn:hover{color:var(--md-sys-color-error);background:var(--md-sys-color-error-container);border-color:var(--md-sys-color-error)}.editor-page{display:flex;flex-direction:column;min-height:100vh;background:var(--md-sys-color-surface)}.editor-page>.editor{flex:1;margin:var(--space-10) auto;height:calc(100vh - 56px - var(--space-10) * 2)}.editor{display:flex;flex-direction:column;max-width:960px;width:100%;background:var(--md-sys-color-surface-container-low);border-radius:var(--radius-lg);padding:var(--space-8) var(--space-10);box-shadow:var(--md-sys-elevation-1)}.editor__loading,.editor__error{text-align:center;padding:var(--space-16);color:var(--md-sys-color-on-surface-variant)}.editor__error{display:flex;flex-direction:column;align-items:center;gap:var(--space-4)}.editor__toolbar{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-6);padding:0;margin-bottom:var(--space-2);background:transparent;border:none;border-radius:0;flex-wrap:wrap}.editor__toolbar-left{display:flex;flex-direction:column;gap:var(--space-1);flex:1;min-width:0}.editor__toolbar-right{display:flex;gap:var(--space-2);align-items:center;padding-top:var(--space-2);flex-shrink:0}.editor__title-input{font-size:var(--md-sys-typescale-headline-medium);font-weight:400;flex:1;min-width:0;padding:0;border-bottom:none;transition:color var(--transition-fast);color:var(--md-sys-color-on-surface);line-height:1.2}.editor__title-input::placeholder{color:var(--md-sys-color-outline)}.editor__title-input:focus{border-bottom-color:transparent}.editor__save-status{font-size:var(--md-sys-typescale-label-small);color:var(--md-sys-color-outline);white-space:nowrap;height:1.2em}.editor__back-btn{display:inline-flex;align-items:center;gap:var(--space-2);font-size:var(--md-sys-typescale-label-medium);color:var(--md-sys-color-outline);margin-bottom:var(--space-4);padding:var(--space-1) 0;transition:color var(--transition-fast);letter-spacing:.01em}.editor__back-btn:hover{color:var(--md-sys-color-primary)}.editor__meta{display:flex;align-items:center;gap:var(--space-3);padding:0;background:transparent;border:none;border-radius:0;margin-bottom:var(--space-6);font-size:var(--md-sys-typescale-label-small)}.editor__meta-item{display:flex;align-items:baseline;gap:4px}.editor__meta-label{color:var(--md-sys-color-outline);text-transform:uppercase;letter-spacing:.06em;font-size:10px}.editor__meta-value{font-weight:600;color:var(--md-sys-color-on-surface-variant);font-variant-numeric:tabular-nums}.editor__meta-sep{width:3px;height:3px;border-radius:50%;background:var(--md-sys-color-outline)}.editor__meta-note{margin-left:auto;color:var(--md-sys-color-outline);font-size:10px}.editor__content{flex:1;width:100%;padding:var(--space-4) var(--space-6) var(--space-4) 0;background:transparent;border:none;border-top:1px solid rgba(255,255,255,.04);border-radius:0;font-family:var(--font-sans);font-size:1.0625rem;line-height:1.85;resize:none;color:var(--md-sys-color-on-surface);letter-spacing:.005em}.editor__content:focus{border-color:#ffffff0a;outline:none}.editor__content::placeholder{color:var(--md-sys-color-outline);line-height:1.85}.presenter-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background-color:var(--md-sys-color-surface);display:flex;flex-direction:column;overflow:hidden;cursor:none}.presenter-overlay.cursor-visible{cursor:default}.scroll-script{position:absolute;top:0;right:0;bottom:0;left:0;overflow-y:scroll;scrollbar-width:none;-ms-overflow-style:none;-webkit-mask-image:linear-gradient(to bottom,transparent 0%,black 18%,black 82%,transparent 100%);mask-image:linear-gradient(to bottom,transparent 0%,black 18%,black 82%,transparent 100%)}.scroll-script::-webkit-scrollbar{display:none}.scroll-script__spacer{height:50vh}.scroll-chunk{width:100%;max-width:var(--presenter-max-width);margin:0 auto;padding:var(--space-10) var(--space-8);text-align:center;font-family:var(--presenter-font-family, var(--font-sans));font-size:var(--presenter-font-size);line-height:var(--presenter-line-height);color:var(--md-sys-color-on-surface);transition:opacity .5s ease,transform .5s ease}.scroll-chunk p{margin:0}.presenter-content{flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:var(--space-8);position:relative;max-width:var(--presenter-max-width);margin:0 auto;width:100%;overflow:hidden}.chunk-stack{width:100%;display:flex;flex-direction:column;justify-content:center;align-items:center}.chunk-stack--out-next,.chunk-stack--out-prev{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;justify-content:center;align-items:center}.chunk-zone{width:100%;display:flex;align-items:center;justify-content:center;text-align:center;font-family:var(--presenter-font-family, var(--font-sans));line-height:var(--presenter-line-height)}.chunk-zone--previous{flex:0 0 auto;max-height:28%;font-size:calc(var(--presenter-font-size) * .78);color:var(--md-sys-color-on-surface);overflow:hidden;padding-bottom:var(--space-8);-webkit-mask-image:linear-gradient(to bottom,transparent 0%,rgba(0,0,0,.25) 40%,rgba(0,0,0,.65) 100%);mask-image:linear-gradient(to bottom,transparent 0%,rgba(0,0,0,.25) 40%,rgba(0,0,0,.65) 100%)}.chunk-zone--current{flex:0 1 auto;opacity:1;font-size:var(--presenter-font-size);color:var(--md-sys-color-on-surface);font-weight:400;letter-spacing:-.01em;padding:var(--space-4) 0}.chunk-zone--next{flex:0 0 auto;max-height:28%;font-size:calc(var(--presenter-font-size) * .72);color:var(--md-sys-color-on-surface);overflow:hidden;padding-top:var(--space-8);-webkit-mask-image:linear-gradient(to bottom,rgba(0,0,0,.6) 0%,rgba(0,0,0,.2) 60%,transparent 100%);mask-image:linear-gradient(to bottom,rgba(0,0,0,.6) 0%,rgba(0,0,0,.2) 60%,transparent 100%)}.chunk-stack--fading-out{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;justify-content:center;align-items:center;animation:chunkFadeOut .6s ease-out forwards;pointer-events:none}.chunk-stack--fading-in{animation:chunkFadeIn .6s ease-in forwards}@keyframes chunkFadeOut{0%{opacity:1}to{opacity:0}}@keyframes chunkFadeIn{0%{opacity:0}to{opacity:1}}.presenter-progress{position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--md-sys-color-surface-container-highest)}.presenter-progress__fill{height:100%;background:var(--md-sys-color-primary);opacity:.7;transition:width var(--transition-normal)}.presenter-controls{position:absolute;bottom:var(--space-8);left:50%;transform:translate(-50%);display:flex;align-items:center;gap:var(--space-2);padding:6px 10px;background:var(--md-sys-color-surface-container-highest);border-radius:100px;border:1px solid var(--md-sys-color-outline-variant);box-shadow:var(--md-sys-elevation-3);opacity:0;transition:opacity .22s cubic-bezier(.2,0,0,1)}.presenter-overlay:hover .presenter-controls,.presenter-overlay.cursor-visible .presenter-controls{opacity:1}.presenter-controls__btn{width:44px;height:44px;border-radius:50%;background:transparent;color:var(--md-sys-color-on-surface-variant);display:flex;align-items:center;justify-content:center;transition:background var(--transition-fast),color var(--transition-fast);font-size:var(--text-lg)}.presenter-controls__btn:hover:not(:disabled){background:var(--color-on-surface-tint);color:var(--md-sys-color-on-surface)}.presenter-controls__btn:disabled{opacity:.25;cursor:default}.presenter-controls__divider{width:1px;height:24px;background:var(--md-sys-color-outline-variant);margin:0 var(--space-1);flex-shrink:0}.presenter-controls__btn--hidden{opacity:0!important;pointer-events:none}.presenter-controls__btn--paused{color:var(--md-sys-color-primary)}.presenter-controls__btn--paused:hover:not(:disabled){background:var(--color-btn-tint);color:var(--color-accent-hover)}.presenter-controls__btn--mic{position:relative}.presenter-controls__btn--mic-active{color:var(--md-sys-color-primary)}.presenter-controls__btn--mic-active:hover:not(:disabled){background:var(--color-accent-muted);color:var(--color-accent-hover)}.presenter-controls__stat{font-size:var(--md-sys-typescale-label-large);font-variant-numeric:tabular-nums;color:var(--md-sys-color-on-surface-variant);white-space:nowrap;padding:0 var(--space-1);transition:color .5s ease}.presenter-controls__stat-label{color:var(--md-sys-color-outline);font-size:var(--md-sys-typescale-label-small)}.presenter-controls__stat--good{color:#22a03ce6}[data-theme=dark] .presenter-controls__stat--good{color:#69db7ce6}.presenter-controls__stat--slow{color:#b47800e6}[data-theme=dark] .presenter-controls__stat--slow{color:#f0b429e6}.presenter-controls__stat--fast{color:#c82828e6}[data-theme=dark] .presenter-controls__stat--fast{color:#ff6b6be6}.presenter-controls__stat--placeholder{color:var(--md-sys-color-outline-variant)}.presenter-settings{position:absolute;top:var(--space-4);right:var(--space-4);opacity:0;transition:opacity var(--transition-fast)}.presenter-overlay:hover .presenter-settings,.presenter-overlay.cursor-visible .presenter-settings{opacity:1}.presenter-settings__toggle{width:36px;height:36px;border-radius:50%;background:var(--md-sys-color-surface-container-high);border:1px solid var(--md-sys-color-outline-variant);color:var(--md-sys-color-on-surface-variant);display:flex;align-items:center;justify-content:center;font-size:var(--text-base);box-shadow:var(--md-sys-elevation-1);transition:background var(--transition-fast),color var(--transition-fast)}.presenter-settings__toggle:hover{background:var(--md-sys-color-surface-container-highest);color:var(--md-sys-color-on-surface)}.presenter-settings__panel{position:absolute;top:44px;right:0;width:260px;background:var(--md-sys-color-surface-container-high);border:1px solid var(--md-sys-color-outline-variant);border-radius:var(--radius-md);box-shadow:var(--md-sys-elevation-3);padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-4)}.presenter-settings__row{display:flex;flex-direction:column;gap:var(--space-1)}.presenter-settings__row label{font-size:var(--md-sys-typescale-label-medium);color:var(--md-sys-color-on-surface-variant);text-transform:uppercase;letter-spacing:.05em}.presenter-settings__row input[type=range]{width:100%;accent-color:var(--md-sys-color-primary)}.presenter-settings__row .value-display{font-size:var(--md-sys-typescale-label-small);color:var(--md-sys-color-outline);text-align:right;font-variant-numeric:tabular-nums}.presenter-speech{position:absolute;top:var(--space-4);left:var(--space-4);opacity:0;transition:opacity var(--transition-fast)}.presenter-overlay:hover .presenter-speech,.presenter-overlay.cursor-visible .presenter-speech{opacity:1}.presenter-speech:has(.speech-indicator--active){opacity:1}.session-summary-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:var(--md-sys-color-scrim);z-index:50;animation:fadeIn .4s ease forwards}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.session-summary{background:var(--md-sys-color-surface-container-high);border:1px solid var(--md-sys-color-outline-variant);border-radius:var(--radius-xl);box-shadow:var(--md-sys-elevation-5);padding:var(--space-10) var(--space-10);min-width:340px;max-width:480px;width:90%;display:flex;flex-direction:column;gap:var(--space-6);animation:slideUp .4s cubic-bezier(.16,1,.3,1) forwards}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.session-summary__title{font-size:var(--md-sys-typescale-headline-small);font-weight:500;color:var(--md-sys-color-on-surface);text-align:center}.session-summary__stats{display:flex;justify-content:space-around;gap:var(--space-4)}.session-stat{display:flex;flex-direction:column;align-items:center;gap:2px}.session-stat__value{font-size:var(--text-3xl);font-weight:600;font-variant-numeric:tabular-nums;color:var(--md-sys-color-on-surface);letter-spacing:-.03em;line-height:1}.session-stat__sub{font-size:var(--md-sys-typescale-body-medium);color:var(--md-sys-color-outline);margin-top:-2px}.session-stat__label{font-size:var(--md-sys-typescale-label-small);color:var(--md-sys-color-outline);text-transform:uppercase;letter-spacing:.06em;margin-top:var(--space-1)}.session-accuracy-bar{height:4px;background:var(--md-sys-color-surface-container-highest);border-radius:2px;overflow:hidden}.session-accuracy-bar__fill{height:100%;border-radius:2px;transition:width .8s cubic-bezier(.16,1,.3,1)}.session-summary__hint{font-size:var(--md-sys-typescale-body-medium);color:var(--md-sys-color-on-surface-variant);text-align:center;line-height:1.5}.session-summary__actions{display:flex;gap:var(--space-3);justify-content:center}.speech-controls{display:flex;flex-direction:column;align-items:center;gap:var(--space-2)}.speech-pause-btn{width:30px;height:30px;border-radius:50%;background:#e4e1e60f;color:var(--md-sys-color-on-surface-variant);display:flex;align-items:center;justify-content:center;transition:background var(--transition-fast),color var(--transition-fast);border:none;cursor:pointer}.speech-pause-btn:hover{background:#e4e1e61f;color:var(--md-sys-color-on-surface)}.speech-indicator{position:relative;width:36px;height:36px;border-radius:50%;background:#e4e1e60f;color:var(--md-sys-color-outline);display:flex;align-items:center;justify-content:center;transition:background var(--transition-fast),color var(--transition-fast)}.speech-indicator--paused{background:#f0b4291f;color:#f0b429}.speech-indicator:hover{background:#e4e1e61f;color:var(--md-sys-color-on-surface-variant)}.speech-indicator--active{background:var(--md-sys-color-primary-container);color:var(--md-sys-color-on-primary-container)}.speech-indicator--active:hover{background:var(--md-sys-color-primary-container);filter:brightness(1.1)}.speech-indicator--unsupported{opacity:.25;cursor:not-allowed}.speech-indicator__pulse{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;border:1px solid var(--md-sys-color-primary);animation:speechPulse 2.6s ease-out infinite;pointer-events:none}@keyframes speechPulse{0%{transform:scale(1);opacity:.35}to{transform:scale(1.5);opacity:0}}.landing{display:flex;align-items:center;justify-content:center;min-height:100dvh;background:var(--md-sys-color-surface)}.landing__card{display:flex;flex-direction:column;align-items:center;gap:1.25rem;padding:3rem 4rem;background:var(--md-sys-color-surface-container-low);border:1px solid var(--md-sys-color-outline-variant);border-radius:1.5rem;text-align:center;max-width:460px;width:100%}.landing__logo{height:48px;width:auto}.landing__tagline{margin:0;font-size:1.1rem;font-weight:500;color:var(--md-sys-color-on-surface)}.landing__features{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.6rem;text-align:left;width:100%;color:var(--md-sys-color-on-surface-variant);font-size:.9rem}.landing__features li{display:flex;align-items:center;gap:.625rem}.landing__features i{width:16px;color:var(--md-sys-color-primary);flex-shrink:0}.landing__signin{margin-top:.5rem;width:100%;display:flex;align-items:center;justify-content:center;gap:.5rem}:root{--md-sys-color-surface: #121215;--md-sys-color-surface-dim: #121215;--md-sys-color-surface-container-lowest: #0d0d10;--md-sys-color-surface-container-low: #1a1a1e;--md-sys-color-surface-container: #1e1e22;--md-sys-color-surface-container-high: #282830;--md-sys-color-surface-container-highest: #333338;--md-sys-color-on-surface: #e4e1e6;--md-sys-color-on-surface-variant: #c4c5ce;--md-sys-color-primary: #a5b4fc;--md-sys-color-on-primary: #1e1b7e;--md-sys-color-primary-container: #312e81;--md-sys-color-on-primary-container: #e0e7ff;--md-sys-color-secondary: #bec6dc;--md-sys-color-on-secondary: #283141;--md-sys-color-secondary-container: #3e4759;--md-sys-color-on-secondary-container: #dae2f9;--md-sys-color-error: #ffb4ab;--md-sys-color-on-error: #561e14;--md-sys-color-error-container: #73342a;--md-sys-color-on-error-container: #ffdad5;--md-sys-color-outline: #8e9099;--md-sys-color-outline-variant: #44464e;--md-sys-color-scrim: rgba(0, 0, 0, .32);--md-sys-color-inverse-surface: #e4e1e6;--md-sys-color-inverse-on-surface: #313033;--color-bg: var(--md-sys-color-surface);--color-bg-elevated: var(--md-sys-color-surface-container);--color-bg-hover: var(--md-sys-color-surface-container-high);--color-bg-active: var(--md-sys-color-surface-container-highest);--color-surface: var(--md-sys-color-surface-container-low);--color-border: var(--md-sys-color-outline-variant);--color-border-subtle: rgba(255, 255, 255, .06);--color-text-primary: var(--md-sys-color-on-surface);--color-text-secondary: var(--md-sys-color-on-surface-variant);--color-text-tertiary: var(--md-sys-color-outline);--color-text-muted: #5a5a64;--color-accent: var(--md-sys-color-primary);--color-accent-hover: #c7d2fe;--color-accent-muted: rgba(165, 180, 252, .12);--color-accent-soft: rgba(165, 180, 252, .06);--color-accent-ring: #a5b4fc;--color-danger: var(--md-sys-color-error);--color-danger-hover: #ffc9c2;--color-danger-muted: rgba(255, 180, 171, .12);--color-success: #7dd594;--color-surface-tint: rgba(255, 255, 255, .05);--color-surface-tint-hover: rgba(165, 180, 252, .18);--color-btn-tint: rgba(165, 180, 252, .08);--color-on-surface-tint: rgba(228, 225, 230, .08);--brand-violet: #8B5CF6;--brand-purple: #A855F7;--brand-blue: #3B82F6;--brand-cyan: #22D3EE;--brand-gradient: linear-gradient(135deg, #7C3AED 0%, #3B82F6 100%);--md-sys-elevation-0: none;--md-sys-elevation-1: 0 1px 3px 1px rgba(0, 0, 0, .15), 0 1px 2px rgba(0, 0, 0, .3);--md-sys-elevation-2: 0 2px 6px 2px rgba(0, 0, 0, .15), 0 1px 2px rgba(0, 0, 0, .3);--md-sys-elevation-3: 0 4px 8px 3px rgba(0, 0, 0, .15), 0 1px 3px rgba(0, 0, 0, .3);--md-sys-elevation-4: 0 6px 10px 4px rgba(0, 0, 0, .15), 0 2px 3px rgba(0, 0, 0, .3);--md-sys-elevation-5: 0 8px 12px 6px rgba(0, 0, 0, .15), 0 4px 4px rgba(0, 0, 0, .3);--font-sans: "Open Sans", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono: "SF Mono", "Fira Code", "Cascadia Code", monospace;--md-sys-typescale-display-large: 3.5625rem;--md-sys-typescale-headline-large: 2rem;--md-sys-typescale-headline-medium: 1.75rem;--md-sys-typescale-headline-small: 1.5rem;--md-sys-typescale-title-large: 1.375rem;--md-sys-typescale-title-medium: 1rem;--md-sys-typescale-body-large: 1rem;--md-sys-typescale-body-medium: .875rem;--md-sys-typescale-body-small: .75rem;--md-sys-typescale-label-large: .875rem;--md-sys-typescale-label-medium: .75rem;--md-sys-typescale-label-small: .6875rem;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 2rem;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--sidebar-width: 232px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 28px;--transition-fast: .15s cubic-bezier(.2, 0, 0, 1);--transition-normal: .25s cubic-bezier(.2, 0, 0, 1);--transition-slow: .4s cubic-bezier(.2, 0, 0, 1);--presenter-font-size: 2.4rem;--presenter-line-height: 1.7;--presenter-max-width: 60ch;--presenter-font-family: "Open Sans", sans-serif}[data-theme=light]{--md-sys-color-surface: #f6f6fa;--md-sys-color-surface-dim: #e8e8ee;--md-sys-color-surface-container-lowest: #ffffff;--md-sys-color-surface-container-low: #f2f2f7;--md-sys-color-surface-container: #ebebf0;--md-sys-color-surface-container-high: #e2e2e8;--md-sys-color-surface-container-highest: #d8d8de;--md-sys-color-on-surface: #1a1a1e;--md-sys-color-on-surface-variant: #44464f;--md-sys-color-primary: #4f46e5;--md-sys-color-on-primary: #ffffff;--md-sys-color-primary-container: #e0e7ff;--md-sys-color-on-primary-container: #1e1b7e;--md-sys-color-secondary: #565d6e;--md-sys-color-on-secondary: #ffffff;--md-sys-color-secondary-container: #dae2f9;--md-sys-color-on-secondary-container: #131c2c;--md-sys-color-error: #ba1a1a;--md-sys-color-on-error: #ffffff;--md-sys-color-error-container: #ffdad5;--md-sys-color-on-error-container: #410002;--md-sys-color-outline: #73747d;--md-sys-color-outline-variant: #c4c5d0;--md-sys-color-inverse-surface: #313033;--md-sys-color-inverse-on-surface: #f3eff4;--color-border-subtle: rgba(0, 0, 0, .06);--color-text-muted: #8e8f9a;--color-accent-hover: #4338ca;--color-accent-muted: rgba(79, 70, 229, .1);--color-accent-soft: rgba(79, 70, 229, .05);--color-accent-ring: #4f46e5;--color-danger-hover: #9e1212;--color-danger-muted: rgba(186, 26, 26, .1);--color-success: #1a6b30;--color-surface-tint: rgba(0, 0, 0, .05);--color-surface-tint-hover: rgba(79, 70, 229, .12);--color-btn-tint: rgba(79, 70, 229, .07);--color-on-surface-tint: rgba(26, 26, 30, .06);--md-sys-elevation-1: 0 1px 3px 1px rgba(0, 0, 0, .08), 0 1px 2px rgba(0, 0, 0, .1);--md-sys-elevation-2: 0 2px 6px 2px rgba(0, 0, 0, .08), 0 1px 2px rgba(0, 0, 0, .1);--md-sys-elevation-3: 0 4px 8px 3px rgba(0, 0, 0, .08), 0 1px 3px rgba(0, 0, 0, .1)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);background-color:var(--md-sys-color-surface);color:var(--md-sys-color-on-surface);font-size:var(--md-sys-typescale-body-large);line-height:1.5;min-height:100vh;letter-spacing:0}#root{min-height:100vh}:focus-visible{outline:3px solid var(--md-sys-color-primary);outline-offset:2px;border-radius:var(--radius-sm)}a{color:var(--md-sys-color-primary);text-decoration:none}a:hover{color:var(--color-accent-hover)}button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit;font-size:inherit}input,textarea{font-family:inherit;font-size:inherit;color:inherit;background:none;border:none;outline:none}textarea{resize:vertical}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--md-sys-color-outline-variant);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--md-sys-color-outline)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);height:40px;padding:0 var(--space-6);border-radius:100px;font-size:var(--md-sys-typescale-label-large);font-weight:600;letter-spacing:.01em;white-space:nowrap;border:none;cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast),box-shadow var(--transition-fast)}.btn--filled{background:var(--md-sys-color-primary);color:var(--md-sys-color-on-primary);box-shadow:var(--md-sys-elevation-0)}.btn--filled:hover{box-shadow:var(--md-sys-elevation-1);background:var(--color-accent-hover);color:var(--md-sys-color-on-primary)}.btn--tonal{background:var(--md-sys-color-secondary-container);color:var(--md-sys-color-on-secondary-container);box-shadow:var(--md-sys-elevation-0)}.btn--tonal:hover{box-shadow:var(--md-sys-elevation-1);filter:brightness(1.08)}.btn--outlined{background:transparent;color:var(--md-sys-color-primary);border:1px solid var(--md-sys-color-outline)}.btn--outlined:hover{background:var(--color-btn-tint)}.btn--text{background:transparent;color:var(--md-sys-color-primary);padding:0 var(--space-3)}.btn--text:hover{background:var(--color-btn-tint)}.btn--danger{background:var(--md-sys-color-error-container);color:var(--md-sys-color-on-error-container)}.btn--danger:hover{filter:brightness(1.08);box-shadow:var(--md-sys-elevation-1)}.btn--primary{background:var(--md-sys-color-primary);color:var(--md-sys-color-on-primary)}.btn--primary:hover{box-shadow:var(--md-sys-elevation-1);background:var(--color-accent-hover);color:var(--md-sys-color-on-primary)}.btn--secondary{background:transparent;color:var(--md-sys-color-on-surface-variant);border:1px solid var(--md-sys-color-outline-variant)}.btn--secondary:hover{background:var(--color-on-surface-tint);color:var(--md-sys-color-on-surface)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}
