:root{--color-dark-0: #0a0a0e;--color-dark-1: #1a1a2e;--color-dark-2: #2d2d44;--color-dark-3: #3d3d5c;--color-purple-primary: #9d4edd;--color-purple-light: #c77dff;--color-crimson: #e63946;--color-gold: #d4af37;--color-slate: #64748b;--color-success: #10b981;--color-warning: #f59e0b;--color-danger: #e63946;--color-info: #3b82f6;--text-primary: #f5f5f7;--text-secondary: #a0aec0;--text-muted: #6b7280;--border-color: rgba(157, 78, 221, .2);--border-color-strong: rgba(157, 78, 221, .4);--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", sans-serif;--font-serif: "Garamond", "Georgia", serif;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .2s cubic-bezier(.4, 0, .2, 1);--transition-slow: .3s cubic-bezier(.4, 0, .2, 1);--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .5);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .6), 0 2px 4px -1px rgba(0, 0, 0, .4);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .7), 0 4px 6px -2px rgba(0, 0, 0, .5);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .8);--glow-purple: 0 0 20px rgba(157, 78, 221, .3);--glow-crimson: 0 0 20px rgba(230, 57, 70, .3)}*{margin:0;padding:0;box-sizing:border-box}html{font-size:16px}body{background:linear-gradient(135deg,var(--color-dark-0) 0%,var(--color-dark-1) 100%);color:var(--text-primary);font-family:var(--font-sans);line-height:1.6;overflow:hidden;min-height:100vh}#root{width:100%;height:100%;display:flex;flex-direction:column}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-dark-1)}::-webkit-scrollbar-thumb{background:var(--color-purple-primary);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--color-purple-light)}.text-primary{color:var(--text-primary)}.text-secondary{color:var(--text-secondary)}.text-muted{color:var(--text-muted)}.text-sm{font-size:.875rem}.text-lg{font-size:1.125rem}.text-xl{font-size:1.5rem}.font-serif{font-family:var(--font-serif)}.font-bold{font-weight:600}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.gap-lg{gap:var(--spacing-lg)}.p-md{padding:var(--spacing-md)}.p-lg{padding:var(--spacing-lg)}.transition-all{transition:all var(--transition-base)}.transition-colors{transition:background-color var(--transition-base),border-color var(--transition-base),color var(--transition-base)}.app{display:flex;flex-direction:column;width:100%;height:100vh;background:linear-gradient(135deg,var(--color-dark-0) 0%,var(--color-dark-1) 100%)}.app.loading{justify-content:center;align-items:center;gap:var(--spacing-md);font-size:1.125rem}.spinner{width:32px;height:32px;border:3px solid rgba(157,78,221,.3);border-top-color:var(--color-purple-primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}nav.navbar{background:var(--color-dark-1);border-bottom:1px solid var(--border-color-strong);padding:var(--spacing-md) var(--spacing-lg);display:flex;justify-content:space-between;align-items:center;flex-shrink:0}.navbar-left{display:flex;align-items:center;gap:var(--spacing-lg)}.navbar-brand{display:flex;align-items:center;gap:var(--spacing-sm);font-size:1.5rem;font-weight:700;color:var(--color-purple-light);text-decoration:none}.navbar-status{display:flex;align-items:center;gap:var(--spacing-sm);font-size:.875rem;color:var(--text-secondary)}.status-indicator{width:8px;height:8px;border-radius:50%;background:var(--color-success)}.status-indicator.offline{background:var(--color-danger)}.navbar-tabs{display:flex;gap:var(--spacing-sm);overflow-x:auto;flex:1;margin:0 var(--spacing-lg);padding:0;list-style:none}.navbar-tabs::-webkit-scrollbar{height:4px}.nav-tab{padding:var(--spacing-sm) var(--spacing-md);border:none;background:transparent;color:var(--text-secondary);cursor:pointer;font-size:.875rem;font-weight:500;text-transform:uppercase;letter-spacing:.05em;transition:all var(--transition-base);border-bottom:2px solid transparent;white-space:nowrap}.nav-tab:hover{color:var(--color-purple-light)}.nav-tab.active{color:var(--color-purple-light);border-bottom-color:var(--color-purple-primary)}.navbar-right{display:flex;align-items:center;gap:var(--spacing-lg)}.navbar-actions{display:flex;gap:var(--spacing-md)}.nav-action{width:32px;height:32px;border-radius:50%;border:1px solid var(--border-color);background:transparent;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-base)}.nav-action:hover{background:rgba(157,78,221,.1);color:var(--color-purple-light);border-color:var(--border-color-strong)}.main-content{flex:1;overflow-y:auto;overflow-x:hidden;padding:var(--spacing-xl)}.grid{display:grid;gap:var(--spacing-lg)}.grid-2{grid-template-columns:repeat(auto-fit,minmax(400px,1fr))}.grid-3{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}@media (max-width: 1200px){.grid-3{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.grid-2,.grid-3{grid-template-columns:1fr}.navbar-tabs{display:none}}.card{background:var(--color-dark-2);border:1px solid var(--border-color);border-radius:8px;padding:var(--spacing-lg);transition:all var(--transition-slow);position:relative;overflow:hidden}.card:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,rgba(157,78,221,.05),transparent);pointer-events:none}.card:hover{border-color:var(--border-color-strong);box-shadow:var(--glow-purple);transform:translateY(-2px)}.card>*{position:relative;z-index:1}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--border-color)}.card-title{font-size:1.125rem;font-weight:600;color:var(--text-primary)}.card-subtitle{font-size:.875rem;color:var(--text-secondary);font-style:italic}.card-content{display:flex;flex-direction:column;gap:var(--spacing-md)}button{font-family:inherit}.btn{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--border-color);border-radius:6px;background:transparent;color:var(--text-primary);cursor:pointer;font-size:.875rem;font-weight:500;transition:all var(--transition-base);white-space:nowrap}.btn:hover{background:rgba(157,78,221,.1);border-color:var(--border-color-strong)}.btn-primary{background:var(--color-purple-primary);border-color:var(--color-purple-primary);color:#fff}.btn-primary:hover{background:var(--color-purple-light);border-color:var(--color-purple-light);box-shadow:var(--glow-purple)}.btn-danger{background:transparent;border-color:var(--color-danger);color:var(--color-danger)}.btn-danger:hover{background:rgba(230,57,70,.1)}.btn-sm{padding:var(--spacing-xs) var(--spacing-sm);font-size:.75rem}.btn-lg{padding:var(--spacing-md) var(--spacing-lg);font-size:1rem}.btn:disabled{opacity:.5;cursor:not-allowed}.emotional-weather{display:flex;flex-direction:column;gap:var(--spacing-md)}.weather-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:var(--spacing-md)}.emotion-item{display:flex;flex-direction:column;gap:var(--spacing-sm)}.emotion-bar{width:100%;height:4px;border-radius:2px;background:linear-gradient(90deg,#64748b,#9d4edd);transition:all var(--transition-base);box-shadow:0 0 10px #9d4edd4d}.emotion-label{font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);display:flex;justify-content:space-between;align-items:center}.emotion-state{font-size:.7rem;color:var(--color-gold);font-weight:600}.relationship-metrics{display:flex;flex-direction:column;gap:var(--spacing-md)}.metric-row{display:flex;flex-direction:column;gap:var(--spacing-sm)}.metric-label{display:flex;justify-content:space-between;align-items:center;font-size:.875rem;font-weight:500}.metric-value{color:var(--color-purple-light);font-weight:600;min-width:32px;text-align:right}.metric-bar-container{width:100%;height:8px;background:rgba(157,78,221,.1);border-radius:4px;border:1px solid var(--border-color);overflow:hidden}.metric-bar{height:100%;background:linear-gradient(90deg,var(--color-purple-primary),var(--color-purple-light));border-radius:4px;transition:width var(--transition-slow);box-shadow:0 0 8px #c77dff66}.memory-web{width:100%;height:300px;background:radial-gradient(ellipse at center,rgba(157,78,221,.05),transparent);border:1px solid var(--border-color);border-radius:8px;display:flex;align-items:center;justify-content:center;overflow:hidden}.memory-web svg{width:100%;height:100%}.memory-node{cursor:move}.memory-node circle{transition:all var(--transition-base)}.memory-node circle:hover{r:14;filter:drop-shadow(0 0 8px rgba(199,125,255,.6))}.memory-node title{font-size:12px;color:var(--text-primary)}.page{display:flex;flex-direction:column;gap:var(--spacing-xl)}.hero-section{padding:var(--spacing-2xl);background:linear-gradient(135deg,rgba(157,78,221,.1),rgba(230,57,70,.05));border:1px solid var(--border-color);border-radius:8px;text-align:center}.hero-content{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-lg)}.hero-title{font-size:3rem;font-weight:700;color:var(--color-purple-light);font-family:var(--font-serif);letter-spacing:-.02em}.stance-display{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);background:rgba(0,0,0,.3);border-radius:6px;border:1px solid var(--border-color)}.stance-indicator{width:12px;height:12px;border-radius:50%;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.stance-label{font-weight:600;font-size:1.125rem;letter-spacing:.05em}.hero-subtitle{color:var(--text-secondary);font-style:italic;max-width:400px}.memories-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.memory-item{padding:var(--spacing-md);background:rgba(157,78,221,.05);border:1px solid var(--border-color);border-radius:6px;display:flex;flex-direction:column;gap:var(--spacing-sm);transition:all var(--transition-base)}.memory-item:hover{background:rgba(157,78,221,.1);border-color:var(--border-color-strong)}.memory-class-badge{display:inline-flex;width:fit-content;padding:4px 8px;background:rgba(212,175,55,.2);border:1px solid var(--color-gold);border-radius:4px;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-gold)}.memory-content{color:var(--text-primary);font-size:.95rem;line-height:1.5}.memory-meta{display:flex;justify-content:space-between;font-size:.8rem;color:var(--text-muted)}.memory-weight{color:var(--color-purple-light);font-weight:500}.memory-date{color:var(--text-muted)}.relationship-page{--}.relationship-arc{display:flex;flex-direction:column;gap:var(--spacing-lg)}.arc-stage{padding:var(--spacing-lg);background:rgba(157,78,221,.05);border:1px solid var(--border-color);border-radius:6px}.arc-stage-title{font-size:1.25rem;font-weight:600;color:var(--color-purple-light);margin-bottom:var(--spacing-md)}.arc-stage-content{color:var(--text-secondary);line-height:1.6}.memory-filters{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.memory-filter-btn{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--border-color);background:transparent;color:var(--text-secondary);border-radius:6px;cursor:pointer;font-size:.875rem;transition:all var(--transition-base)}.memory-filter-btn.active{background:var(--color-purple-primary);border-color:var(--color-purple-primary);color:#fff}.memory-filter-btn:hover{border-color:var(--border-color-strong);color:var(--color-purple-light)}.brain-state{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-lg)}.activity-item{padding:var(--spacing-md);background:rgba(157,78,221,.05);border:1px solid var(--border-color);border-radius:6px;display:flex;flex-direction:column;gap:var(--spacing-sm)}.activity-type{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-gold)}.activity-title{font-size:1rem;font-weight:500;color:var(--text-primary)}.activity-description{font-size:.875rem;color:var(--text-secondary)}.health-metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--spacing-lg)}.health-metric{padding:var(--spacing-lg);background:rgba(157,78,221,.05);border:1px solid var(--border-color);border-radius:6px}.health-metric-title{font-weight:600;margin-bottom:var(--spacing-md);color:var(--color-purple-light)}.health-metric-value{font-size:2rem;font-weight:700;color:var(--color-gold);margin-bottom:var(--spacing-md)}.health-meter{width:100%;height:12px;background:rgba(0,0,0,.3);border-radius:6px;overflow:hidden;border:1px solid var(--border-color)}.health-meter-fill{height:100%;background:linear-gradient(90deg,var(--color-purple-primary),var(--color-purple-light));border-radius:6px;transition:width var(--transition-slow)}
