@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=Material+Symbols+Outlined:wght@300;400;500&display=swap";:root{color-scheme:dark;font-family:Inter,system-ui,sans-serif;--background: #131313;--surface: #131313;--surface-low: #1c1b1b;--surface-high: #2a2a2a;--surface-highest: #353534;--surface-inset: #0e0e0e;--text: #e5e2e1;--text-muted: #c8c5cc;--text-soft: #8e8ea0;--primary: #c5c5d8;--primary-container: #8f8fa1;--secondary-container: #46464d;--outline: rgba(71, 70, 76, .28);--outline-soft: rgba(71, 70, 76, .14);--error: #ffb4ab;--error-surface: rgba(147, 0, 10, .42);--success-surface: rgba(197, 197, 216, .08);--shadow: 0 32px 60px -18px rgba(0, 0, 0, .55)}*{box-sizing:border-box}html,body,#root{min-height:100%}body{margin:0;min-height:100vh;background:radial-gradient(circle at top left,rgba(197,197,216,.04),transparent 28%),linear-gradient(180deg,#171717,#131313 48%,#101010);color:var(--text)}body,button,input,select,textarea{font:inherit}button,input,select,textarea{color:inherit}button{cursor:pointer}.material-symbols-outlined{font-family:Material Symbols Outlined;font-weight:300;font-style:normal;font-size:20px;line-height:1;letter-spacing:normal;text-transform:none;display:inline-block;white-space:nowrap;word-wrap:normal;direction:ltr;-webkit-font-smoothing:antialiased}.shell{min-height:100vh;padding:0 3vw 0 0;overflow:hidden}.shell-content{width:100%;min-width:0;margin-left:292px;padding:24px 0 48px;transition:margin-left .28s ease}.shell.shell-collapsed .shell-content{margin-left:108px}.sidebar{position:fixed;inset:0 auto 0 0;z-index:10;width:256px;padding:24px 12px 18px;display:grid;align-content:start;gap:18px;background:var(--surface-low);box-shadow:40px 0 60px -10px #e5e2e10d;overflow:hidden;transition:width .28s ease,padding .28s ease}.sidebar.collapsed{width:76px;padding-left:8px;padding-right:8px;overflow:visible}.sidebar-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.sidebar-brand{min-width:0}.sidebar-brand-title{margin:0;font-size:1.05rem;font-weight:700;letter-spacing:-.04em;color:var(--text)}.sidebar-copy{margin:4px 0 0;font-size:.64rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:#c8c5cc9e}.sidebar-toggle{width:36px;height:36px;min-width:36px;display:inline-flex;align-items:center;justify-content:center;border:none;border-radius:10px;padding:0;background:transparent;color:var(--text-soft);transition:background .18s ease,color .18s ease}.sidebar-toggle:hover{background:var(--surface-high);color:var(--text)}.view-switcher{display:grid;gap:6px}.sidebar-utility{margin-top:auto;padding-top:12px}.sidebar-utility-button{width:100%;display:flex;align-items:center;gap:10px;padding:10px 12px;border:none;border-radius:12px;background:transparent;color:#c8c5cc8f;text-align:left;transition:background .18s ease,color .18s ease}.sidebar-utility-button:hover{background:var(--surface-high);color:var(--text)}.sidebar.collapsed .sidebar-utility-button{justify-content:center;padding-inline:0}.view-button{width:100%;min-width:0;display:flex;align-items:center;gap:12px;padding:10px 12px;border:none;border-radius:12px;background:transparent;color:var(--text-soft);text-align:left;transition:background .18s ease,color .18s ease,transform .18s ease}.view-button:hover{background:var(--surface-high);color:var(--text)}.view-button.active{background:var(--surface-high);color:var(--primary);transform:scale(.98)}.view-icon{width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;border-radius:10px;flex:0 0 auto}.view-button.active .view-icon{background:#c5c5d814}.view-copy-block{display:grid;gap:2px;min-width:0}.view-title{font-size:.92rem;font-weight:600;letter-spacing:-.02em}.view-copy{font-size:.72rem;color:#c8c5ccad}.sidebar.collapsed .sidebar-header{justify-content:center}.sidebar.collapsed .sidebar-brand,.sidebar.collapsed .view-copy-block{display:none}.sidebar.collapsed .view-button{justify-content:center;padding:8px 0;position:relative;overflow:visible}.sidebar.collapsed .view-icon{width:36px;height:36px}.sidebar.collapsed .sidebar-toggle,.sidebar.collapsed .sidebar-utility-button{position:relative;overflow:visible}.sidebar.collapsed .sidebar-toggle:after,.sidebar.collapsed .view-button:after,.sidebar.collapsed .sidebar-utility-button:after{content:attr(data-tooltip);position:absolute;z-index:24;left:calc(100% + 12px);top:50%;transform:translateY(-50%) translate(-4px);padding:7px 10px;border-radius:10px;background:#0a0a0af0;border:1px solid rgba(255,255,255,.08);box-shadow:0 14px 28px #00000047;color:var(--text);font-size:.74rem;font-weight:600;letter-spacing:-.01em;white-space:nowrap;pointer-events:none;opacity:0;visibility:hidden;transition:opacity .16s ease,transform .16s ease,visibility .16s ease}.sidebar.collapsed .sidebar-toggle:hover:after,.sidebar.collapsed .sidebar-toggle:focus-visible:after,.sidebar.collapsed .view-button:hover:after,.sidebar.collapsed .view-button:focus-visible:after,.sidebar.collapsed .sidebar-utility-button:hover:after,.sidebar.collapsed .sidebar-utility-button:focus-visible:after{opacity:1;visibility:visible;transform:translateY(-50%) translate(0)}.app-topbar{position:sticky;top:0;z-index:8;width:min(1400px,calc(100% - 24px));margin:0 auto 28px;padding:14px 22px;display:flex;align-items:center;justify-content:space-between;gap:18px;background:#131313bd;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.app-topbar-copy,.app-topbar-meta{display:flex;align-items:center;gap:14px}.app-topbar-copy{min-width:0}.app-brand{font-size:1.15rem;font-weight:700;letter-spacing:-.06em;color:var(--text);white-space:nowrap}.app-divider{width:1px;height:18px;background:#47464c59}.app-topbar-title{margin:0;font-size:.9rem;font-weight:600;color:var(--text)}.app-topbar-subtitle{margin:2px 0 0;max-width:62ch;font-size:.76rem;color:#c8c5cca8}.surface-pill,.context-chip{display:inline-flex;align-items:center;min-height:34px;padding:0 12px;border-radius:999px;white-space:nowrap}.surface-pill,.context-chip{background:var(--surface-high);color:var(--text-muted);font-size:.74rem;font-weight:600}.workspace{width:min(1400px,calc(100% - 24px));margin:0 auto}.workspace-header{margin-bottom:28px}.workspace-header-centered{max-width:56rem;margin-inline:auto;text-align:center}.workspace-kicker,.section-label{margin:0 0 12px;font-size:.64rem;font-weight:700;letter-spacing:.24em;text-transform:uppercase;color:#c8c5cca3}.workspace-header h1,.workspace-header h2,.chat-empty-state h3{margin:0;font-size:clamp(2.2rem,5vw,4rem);font-weight:300;letter-spacing:-.06em;line-height:.98;color:var(--text)}.workspace-header h1 span{font-weight:600}.workspace-copy{max-width:56ch;margin:18px auto 0 0;font-size:1rem;line-height:1.7;color:#c8c5ccc2}.workspace-header-centered .workspace-copy{margin-inline:auto}.prototype-card,.chat-feed-card,.discussion-voice-hero,.music-generation-card,.music-results,.study-passage-sheet{background:var(--surface-low);border-radius:24px;box-shadow:var(--shadow)}.prototype-card,.music-results{padding:24px}.card-header,.chat-feed-header,.study-passage-heading{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:18px}.card-header h2,.card-header h3,.chat-feed-header h2,.study-passage-heading h3{margin:0;font-size:1.35rem;font-weight:600;letter-spacing:-.04em}.card-stack{display:grid;gap:22px}.field{display:grid;gap:8px}.field span,.toggle-row span{font-size:.76rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#c8c5cc9e}input,select,textarea{width:100%;border:none;border-radius:18px;padding:14px 16px;background:var(--surface-inset);color:var(--text);resize:vertical;transition:background .18s ease,box-shadow .18s ease}input:focus,select:focus,textarea:focus{outline:none;background:#171717;box-shadow:0 0 0 1px #c5c5d82e}textarea{min-height:96px}.primary-button,.secondary-button,.ghost-button,.danger-button{border:none;border-radius:14px;padding:12px 16px;font-weight:700;letter-spacing:-.02em;transition:transform .18s ease,opacity .18s ease,background .18s ease}.primary-button{background:linear-gradient(90deg,var(--primary) 0%,var(--primary-container) 100%);color:#2e2f3e}.secondary-button{background:var(--surface-high);color:var(--text)}.ghost-button{background:#2a2a2a9e;color:var(--text-muted)}.danger-button{background:linear-gradient(90deg,#ffb4ab,#93000a);color:#200507}.primary-button:hover,.secondary-button:hover,.ghost-button:hover,.danger-button:hover{transform:translateY(-1px)}.primary-button:disabled,.secondary-button:disabled,.ghost-button:disabled,.danger-button:disabled{opacity:.58;transform:none;cursor:not-allowed}.wide-button{width:100%;justify-content:center}.round-button{width:56px;height:56px;padding:0;display:inline-flex;align-items:center;justify-content:center;border-radius:999px}.call-button{display:inline-flex;align-items:center;gap:10px;min-height:56px;padding-inline:24px;border-radius:999px}.muted-text,.empty-state,.prompt-note,.question-note,.usage-note,.composer-disclaimer{margin:0;line-height:1.66;color:#c8c5ccbd}.error-banner{margin:0;padding:14px 16px;border-radius:16px;background:var(--error-surface);color:var(--error)}.workspace-chat{display:grid;gap:28px}.chat-prototype-layout{width:100%;max-width:960px;margin:0 auto}.chat-feed-card{padding:28px 28px 22px}.context-stack{display:flex;flex-wrap:wrap;gap:8px}.chat-log,.discussion-transcript-list{display:grid;gap:18px;max-height:58vh;overflow-y:auto;padding-right:4px}.assistant-badge-row{display:flex;align-items:center;gap:10px;margin-bottom:10px}.assistant-avatar{width:30px;height:30px;display:inline-flex;align-items:center;justify-content:center;border-radius:10px;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-container) 100%);color:#2e2f3e}.assistant-label{font-size:.68rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:#c8c5ccad}.chat-message{display:grid}.chat-message.user{justify-items:end}.chat-message.assistant{justify-items:start}.chat-message-body{max-width:min(100%,760px)}.chat-message.user .chat-message-body{background:var(--surface-low);padding:16px 18px;border-radius:20px 20px 8px}.chat-message.assistant .chat-message-body{padding:0}.chat-message-body p{margin:0;white-space:pre-wrap;line-height:1.74;color:var(--text)}.chat-empty-state{display:grid;gap:12px;justify-items:center;text-align:center;padding:60px 20px}.chat-empty-state h3{max-width:18ch;font-size:clamp(2rem,4vw,3rem)}.chat-composer-shell{max-width:56rem;width:100%;margin:0 auto}.chat-composer{padding:10px;border:1px solid rgba(197,197,216,.12);background:#181818;border-radius:22px;box-shadow:var(--shadow);transition:border-color .18s ease,box-shadow .18s ease,background .18s ease}.chat-composer:focus-within{border-color:#c5c5d847;background:#1b1b1b;box-shadow:var(--shadow),0 0 0 1px #c5c5d81f}.chat-composer textarea{background:#101010;min-height:72px;padding:12px 14px;border-radius:16px}.chat-composer textarea::placeholder{color:#c8c5cc6b}.chat-composer-actions{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:0 8px 6px}.composer-hints{display:flex;align-items:center;gap:8px;color:#c8c5cc9e}.composer-disclaimer{margin-top:14px;text-align:center;font-size:.72rem}.study-prototype{display:grid;grid-template-columns:minmax(0,1fr) 380px;gap:24px;align-items:start}.study-main-column{min-width:0}.study-side-column{display:grid;gap:20px;align-content:start}.study-selector-bar,.study-goal-bar{display:flex;align-items:center;gap:14px;padding:12px;border-radius:18px;background:var(--surface-low);box-shadow:var(--shadow)}.study-selector-bar{margin-bottom:16px}.study-goal-bar{margin-bottom:24px}.study-selector-field{flex:1 1 auto;min-width:0;display:flex;align-items:center;gap:10px}.study-book-selector{position:relative;padding:0 12px;border-radius:14px;background:var(--surface-inset);box-shadow:inset 0 0 0 1px #ffffff0a;transition:background .18s ease,box-shadow .18s ease}.study-book-selector:focus-within{background:#171717;box-shadow:inset 0 0 0 1px #c5c5d82e}.study-selector-field input,.study-selector-bar select,.study-range-input{background:transparent;padding:8px 0}.study-book-selector input{flex:1 1 auto;padding-left:6px;padding-right:6px}.study-selector-caret-button{flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;border:none;border-radius:10px;background:transparent;cursor:pointer;transition:background .18s ease}.study-selector-caret-button:hover{background:#ffffff0a}.study-selector-caret{color:#c8c5cc94;transition:transform .18s ease,color .18s ease}.study-selector-caret-button.open .study-selector-caret{color:var(--text);transform:rotate(180deg)}.study-book-dropdown{position:absolute;top:calc(100% + 10px);left:0;right:0;z-index:12;max-height:280px;overflow-y:auto;padding:8px;border-radius:18px;background:#171717;box-shadow:0 24px 48px -16px #000000a3}.study-book-option{width:100%;border:none;border-radius:12px;background:transparent;padding:10px 12px;text-align:left;color:var(--text-muted);transition:background .18s ease,color .18s ease}.study-book-option:hover,.study-book-option.active{background:var(--surface-high);color:var(--text)}.study-book-empty{margin:0;padding:10px 12px;color:#c8c5ccb8}.study-range-input{max-width:160px;min-height:44px;padding-inline:12px;border-radius:14px;background:var(--surface-inset)}.study-selector-divider{width:1px;height:20px;background:#47464c59}.field-note{margin:-4px 0 14px;font-size:.8rem;color:#ffb4abd1}.study-goal-bar .field{flex:1 1 auto}.study-goal-bar .field input{min-height:52px}.study-passage-sheet{padding:28px}.study-verse-flow{display:grid;gap:14px}.study-verse-row{position:relative;padding-left:34px}.study-verse-number{position:absolute;left:0;top:3px;font-size:.76rem;font-weight:700;color:#c5c5d8b8}.study-verse-row p,.study-passage-text{margin:0;font-size:1.03rem;line-height:1.86;color:#e5e2e1eb}.prototype-card h4,.music-results h4{margin:0 0 10px;font-size:.92rem;font-weight:700;letter-spacing:-.02em}.prototype-list{margin:0;padding-left:18px;display:grid;gap:10px;line-height:1.62}.prototype-list.ordered{padding-left:20px}.image-preview{width:100%;aspect-ratio:4 / 5;object-fit:cover;border-radius:18px;background:var(--surface-inset)}.toggle-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.toggle-row input[type=checkbox]{width:18px;height:18px;min-height:18px;margin:0}.music-prototype{display:grid;gap:32px}.music-generation-card{max-width:54rem;width:100%;margin:0 auto;padding:28px;background:var(--surface-low);border-radius:24px;box-shadow:var(--shadow)}.music-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.music-results{max-width:54rem;width:100%;margin:0 auto}.track-row{display:grid;grid-template-columns:auto 1fr auto;gap:16px;align-items:center}.track-icon{width:48px;height:48px;display:inline-flex;align-items:center;justify-content:center;border-radius:14px;background:var(--surface-high);color:var(--primary)}.track-meta h3{margin:0;font-size:1rem}.track-meta p{margin:6px 0 0;color:#c8c5ccb8}.job-status{display:inline-flex;align-items:center;min-height:32px;padding:0 12px;border-radius:999px;font-size:.72rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.job-status.queued,.job-status.in_progress{background:#c5c5d814;color:var(--primary)}.job-status.completed{background:var(--success-surface);color:var(--text)}.job-status.failed{background:var(--error-surface);color:var(--error)}.discussion-prototype{display:grid;gap:28px}.discussion-voice-hero{padding:28px;display:grid;gap:24px}.discussion-voice-meta,.discussion-status-cluster,.discussion-controls{display:flex;align-items:center;justify-content:space-between;gap:16px}.discussion-status-cluster{flex-wrap:wrap;justify-content:flex-end}.voice-visualizer-shell{display:flex;justify-content:center;padding:22px 0}.voice-orbit{position:relative;width:320px;height:320px;display:flex;align-items:center;justify-content:center;border-radius:50%;border:1px solid rgba(197,197,216,.08)}.voice-orbit:before,.voice-orbit:after{content:"";position:absolute;top:28px;right:28px;bottom:28px;left:28px;border-radius:50%;border:1px solid rgba(197,197,216,.12)}.voice-orbit:after{top:56px;right:56px;bottom:56px;left:56px;border-color:#c5c5d82e}.voice-orbit.active{box-shadow:0 0 0 18px #c5c5d808}.voice-orbit-inner{width:136px;height:136px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--surface-inset)}.voice-bars{display:flex;align-items:end;gap:6px;height:56px}.voice-bars span{width:5px;border-radius:999px;background:var(--primary)}.voice-bars span:nth-child(1){height:24px;opacity:.45}.voice-bars span:nth-child(2){height:42px}.voice-bars span:nth-child(3){height:56px}.voice-bars span:nth-child(4){height:36px}.voice-bars span:nth-child(5){height:48px}.voice-bars span:nth-child(6){height:20px;opacity:.45}.discussion-grid{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(320px,.8fr);gap:24px;align-items:start}.mini-action-row{display:grid;gap:14px}audio{width:100%}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@media (max-width: 1200px){.study-prototype,.chat-prototype-layout,.discussion-grid{grid-template-columns:1fr}.chat-log,.discussion-transcript-list{max-height:none}}@media (max-width: 1080px){.shell{padding-left:0;padding-right:0}.shell-content,.shell.shell-collapsed .shell-content{margin-left:0;padding-top:0}.sidebar,.sidebar.collapsed{position:static;width:100%;padding:14px;box-shadow:none}.sidebar.collapsed .sidebar-brand,.sidebar.collapsed .view-copy-block{display:block}.sidebar.collapsed .view-button,.sidebar.collapsed .sidebar-utility-button{justify-content:flex-start;padding:10px 12px}.view-switcher{grid-template-columns:repeat(2,minmax(0,1fr))}.app-topbar,.workspace{width:min(100%,calc(100% - 24px))}}@media (max-width: 760px){.app-topbar,.app-topbar-copy,.app-topbar-meta,.discussion-voice-meta,.discussion-controls,.chat-composer-actions,.study-selector-bar,.study-goal-bar{flex-direction:column;align-items:stretch}.workspace-header h1,.chat-empty-state h3{font-size:clamp(1.9rem,10vw,2.8rem)}.music-grid,.view-switcher{grid-template-columns:1fr}.study-range-input{max-width:none}.track-row{grid-template-columns:1fr;justify-items:start}.voice-orbit{width:240px;height:240px}}
