:root{--bg-primary: #0a0a1a;--bg-secondary: #1a1a2e;--bg-tertiary: #12122a;--border: #2a2a4e;--text-primary: #e0e0e0;--text-secondary: #888;--text-muted: #555;--accent: #3a5a9e;--accent-glow: #4a6aaeee;--success: #4a9e5a;--warning: #9e8a3a;--phase-terrain: #5a8a9e;--phase-scenes: #7a6a9e;--phase-diagram: #9e6a6a;--phase-cross-exam: #6a9e6a;--phase-integration: #9e9a5a}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;background:var(--bg-primary);color:var(--text-primary);height:100vh;height:100dvh;overflow:hidden;overscroll-behavior:none}#root{height:100vh;height:100dvh}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.app{display:flex;height:100%}.sidebar{width:240px;background:var(--bg-secondary);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0}.sidebar-header{padding:16px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:12px}.sidebar-header h1{font-size:18px;font-weight:600;letter-spacing:-.5px}.sidebar-nav{flex:1;padding:8px;display:flex;flex-direction:column;gap:2px;overflow-y:auto;min-height:0}.nav-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;cursor:pointer;font-size:14px;color:var(--text-secondary);border:none;background:none;width:100%;text-align:left;transition:all .15s}.nav-item:hover{background:var(--bg-tertiary);color:var(--text-primary)}.nav-item.active{background:var(--accent);color:#fff}.sidebar-footer{padding:12px 16px;border-top:1px solid var(--border);font-size:12px;color:var(--text-muted)}.main{flex:1;display:flex;flex-direction:column;min-width:0;height:100%;overflow:hidden}.main-header{padding:12px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;background:var(--bg-secondary)}.main-header h2{font-size:15px;font-weight:500;color:var(--text-secondary)}.main-content{flex:1;overflow-y:auto;display:flex;flex-direction:column}.chat-container{flex:1;display:flex;flex-direction:column;max-width:800px;width:100%;margin:0 auto;padding:0 20px;min-height:0}.chat-messages{flex:1;height:0;padding:20px 0;overflow-y:auto;display:flex;flex-direction:column;gap:16px;min-height:0}.message{display:flex;flex-direction:column;gap:6px;max-width:85%}.message.user{align-self:flex-end}.message.assistant{align-self:flex-start}.message-label{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.message-bubble{padding:12px 16px;border-radius:12px;font-size:15px;line-height:1.6;white-space:pre-wrap;word-break:break-word}.message.user .message-bubble{background:var(--accent);color:#fff;border-bottom-right-radius:4px}.message.assistant .message-bubble{background:var(--bg-secondary);border:1px solid var(--border);border-bottom-left-radius:4px}.chat-input-area{padding:16px 0 20px;border-top:1px solid var(--border)}.chat-input-row{display:flex;gap:8px;align-items:flex-end}.chat-input{flex:1;background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;padding:12px 16px;color:var(--text-primary);font-size:15px;font-family:inherit;resize:none;min-height:48px;max-height:200px;outline:none;transition:border-color .15s}.chat-input:focus{border-color:var(--accent)}.chat-input::placeholder{color:var(--text-muted)}.send-btn{width:48px;height:48px;border-radius:12px;background:var(--accent);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:20px;transition:opacity .15s;flex-shrink:0}.send-btn:hover{opacity:.85}.send-btn:disabled{opacity:.4;cursor:not-allowed}.phase-indicator{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:20px;font-size:12px;font-weight:500;background:var(--bg-tertiary);border:1px solid var(--border)}.phase-dot{width:8px;height:8px;border-radius:50%}.phase-terrain .phase-dot{background:var(--phase-terrain)}.phase-scenes .phase-dot{background:var(--phase-scenes)}.phase-diagram .phase-dot{background:var(--phase-diagram)}.phase-cross-exam .phase-dot{background:var(--phase-cross-exam)}.phase-integration .phase-dot{background:var(--phase-integration)}.quick-capture{position:fixed;bottom:80px;right:24px;z-index:10}.quick-capture-btn{width:56px;height:56px;border-radius:50%;background:var(--accent);color:#fff;border:none;cursor:pointer;font-size:24px;box-shadow:0 4px 20px #3a5a9e66;transition:transform .15s,box-shadow .15s}.quick-capture-btn:hover{transform:scale(1.05);box-shadow:0 6px 25px #3a5a9e99}.quick-capture-panel{position:absolute;bottom:64px;right:0;width:320px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;padding:16px;box-shadow:0 8px 30px #00000080}.quick-capture-panel textarea{width:100%;min-height:100px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:8px;padding:10px;color:var(--text-primary);font-family:inherit;font-size:14px;resize:none;outline:none}.quick-capture-panel textarea:focus{border-color:var(--accent)}.quick-capture-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:10px}.btn{padding:8px 16px;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;border:none;transition:opacity .15s}.btn:hover{opacity:.85}.btn-primary{background:var(--accent);color:#fff}.btn-ghost{background:transparent;color:var(--text-secondary);border:1px solid var(--border)}.dream-dump{padding:20px;max-width:800px;margin:0 auto;width:100%}.dream-dump h2{font-size:20px;margin-bottom:16px}.fragment-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:10px;padding:14px 16px;margin-bottom:10px;cursor:pointer;transition:border-color .15s}.fragment-card:hover{border-color:var(--accent)}.fragment-date{font-size:11px;color:var(--text-muted);margin-bottom:6px}.fragment-preview{font-size:14px;color:var(--text-secondary);line-height:1.5}.vault-browser{padding:20px;max-width:800px;margin:0 auto;width:100%}.vault-browser h2{font-size:20px;margin-bottom:16px}.session-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:10px;padding:14px 16px;margin-bottom:10px;cursor:pointer;transition:border-color .15s}.session-card:hover{border-color:var(--accent)}.session-meta{display:flex;gap:12px;align-items:center;margin-bottom:8px}.session-date{font-size:13px;color:var(--text-secondary)}.session-tags{display:flex;gap:6px}.session-tag{font-size:11px;padding:2px 8px;border-radius:10px;background:var(--bg-tertiary);color:var(--text-muted)}.setup-wizard{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;padding:40px;max-width:480px;margin:0 auto;text-align:center;overflow-y:auto;-webkit-overflow-scrolling:touch}.setup-wizard h2{font-size:28px;margin-bottom:8px}.setup-wizard .subtitle{color:var(--text-secondary);margin-bottom:32px}.auth-description{font-size:15px;color:var(--text-secondary);line-height:1.7;text-align:left;margin-bottom:32px}.auth-description p{margin-bottom:16px}.auth-description strong{color:var(--text-primary)}.setup-step{width:100%;text-align:left}.setup-step label{display:block;font-size:13px;color:var(--text-secondary);margin-bottom:6px}.setup-step input{width:100%;background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;padding:10px 14px;color:var(--text-primary);font-size:14px;font-family:inherit;outline:none;margin-bottom:16px}.setup-step input:focus{border-color:var(--accent)}.setup-actions{margin-top:24px;display:flex;gap:12px;justify-content:center}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--text-muted);gap:12px;padding:40px;text-align:center}.empty-state .icon{font-size:48px;opacity:.5}.empty-state p{font-size:15px;max-width:300px}.toast{position:fixed;bottom:20px;left:50%;transform:translate(-50%);background:var(--bg-secondary);border:1px solid var(--border);border-radius:10px;padding:10px 20px;font-size:14px;z-index:100;box-shadow:0 4px 20px #0006}@media (max-width: 768px){.sidebar{position:fixed;left:0;top:0;bottom:0;z-index:50;transform:translate(-100%);transition:transform .2s}.sidebar.open{transform:translate(0)}.sidebar-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:49}.menu-btn{display:flex}}@media (min-width: 769px){.menu-btn{display:none}}.menu-btn{width:36px;height:36px;border-radius:8px;background:none;border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;align-items:center;justify-content:center;font-size:18px}.voice-section{display:flex;flex-direction:column;gap:12px}.voice-indicator{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-secondary)}.voice-dot{width:10px;height:10px;border-radius:50%;background:var(--text-muted);transition:background .2s}.voice-indicator.recording .voice-dot{background:#e05050;animation:pulse 1.2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.3)}}.voice-interim{font-size:14px;color:var(--text-muted);font-style:italic;min-height:20px;padding:8px 0}.voice-transcript{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:8px;padding:10px}.voice-transcript-label{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.voice-transcript-text{font-size:14px;color:var(--text-primary);line-height:1.5;margin-bottom:10px}.voice-transcript-actions{display:flex;gap:8px;justify-content:flex-end}.voice-controls{display:flex;align-items:center;justify-content:center;gap:12px;padding:8px 0}.voice-btn{width:56px;height:56px;border-radius:50%;background:var(--bg-tertiary);border:2px solid var(--border);color:var(--text-primary);font-size:24px;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center}.voice-btn:hover{border-color:var(--accent);background:var(--bg-secondary)}.voice-btn.active{background:#e05050;border-color:#e05050;color:#fff;animation:pulse 1.2s ease-in-out infinite}.voice-error{font-size:12px;color:#e05050;padding:4px 0}.splash-page{display:flex;align-items:center;justify-content:center;min-height:100vh;min-height:100dvh;background:var(--bg-primary);padding:24px}.splash-content{text-align:center;max-width:480px}.splash-icon{font-size:72px;margin-bottom:24px;opacity:.9}.splash-content h1{font-size:40px;font-weight:300;letter-spacing:4px;text-transform:uppercase;margin:0 0 12px;color:var(--text-primary)}.splash-tagline{font-size:16px;color:var(--text-secondary);font-style:italic;margin:0 0 32px}.splash-cta{font-size:16px;padding:14px 40px;letter-spacing:1px}.splash-footer{font-size:12px;color:var(--text-muted);margin-top:32px}
