:root{--purple-deep:#6b4d9e;--purple-mid:#9b72cf;--purple-light:#c4a6e8;--purple-glow:#dfc8f7;--sage-deep:#4a8a6a;--sage-mid:#6db89a;--sage-light:#a0d4be;--sage-glow:#d0eede;--rose-deep:#b8547a;--rose-mid:#d4789e;--rose-light:#eaa8c4;--rose-glow:#f7d4e5;--sky-deep:#5a7fa8;--sky-mid:#7ea8d4;--sky-light:#a8c8e8;--sky-glow:#d4e4f5;--bg-primary:#faf7f5;--bg-secondary:#f3ede8;--bg-card:#fff;--bg-input:#f7f3ef;--bg-hover:#ede5dd;--text-primary:#2a2438;--text-secondary:#6b5e7b;--text-muted:#7d7290;--border-color:#e2dbd4;--border-active:var(--purple-light);--danger:#c9444d;--success:var(--sage-mid);--warning:#c9a044;--font-display:"Fraunces", Georgia, serif;--font-mono:"DM Mono", "Menlo", monospace;--font-body:"Inter", -apple-system, sans-serif;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:24px;--shimmer-gradient:linear-gradient(135deg, #c4a6e8, #eaa8c4, #a8c8e8, #a0d4be, #dfc8f7);--tap-min:44px;--safe-bottom:env(safe-area-inset-bottom,0px);--safe-top:env(safe-area-inset-top,0px);--safe-left:env(safe-area-inset-left,0px);--safe-right:env(safe-area-inset-right,0px)}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{width:100%;height:100%}html{transition:background-color .3s,color .3s}body{font-family:var(--font-body);background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-webkit-tap-highlight-color:#9b72cf2e;line-height:1.5;transition:background-color .3s,color .3s}.safe-bottom{padding-bottom:calc(var(--safe-bottom) + 0px)}.safe-bottom-pad{padding-bottom:calc(var(--safe-bottom) + 14px)}.safe-top{padding-top:calc(var(--safe-top) + 0px)}.tap-target{min-height:var(--tap-min);min-width:var(--tap-min)}.truncate{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--purple-light);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--purple-mid)}@keyframes shimmer-shift{0%{background-position:0%}50%{background-position:100%}to{background-position:0%}}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(-12px)}to{opacity:1;transform:translate(0)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-3px)}}@keyframes breathe{0%,to{transform:scale(1)}50%{transform:scale(1.02)}}@keyframes pulseGlow{0%,to{opacity:.6}50%{opacity:1}}@keyframes shimmer{0%{opacity:.6}50%{opacity:1}to{opacity:.6}}@keyframes shimmerSweep{0%{background-position:-200%}to{background-position:200%}}@keyframes typingDot{0%,80%,to{opacity:.3;transform:scale(.8)}40%{opacity:1;transform:scale(1)}}.fade-in{animation:.3s forwards fadeIn}.slide-up{animation:.4s cubic-bezier(.22,1,.36,1) forwards slideUp}.slide-in{animation:.35s forwards slideIn}.float{animation:6s ease-in-out infinite float}.breathe{animation:8s ease-in-out infinite breathe}.pulse-glow{animation:3s ease-in-out infinite pulseGlow}.hover-lift{transition:transform .2s,box-shadow .2s}.hover-lift:hover{transform:translateY(-2px);box-shadow:0 4px 16px #6b4d9e1a}.stagger-1{animation-delay:50ms}.stagger-2{animation-delay:.1s}.stagger-3{animation-delay:.15s}.stagger-4{animation-delay:.2s}.stagger-5{animation-delay:.25s}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important}}.card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);transition:box-shadow .25s,transform .25s;overflow:hidden;box-shadow:0 2px 12px #6b4d9e0f,0 1px 3px #0000000a}.card:hover{box-shadow:0 4px 20px #6b4d9e1a,0 2px 6px #0000000a}.card-header{border-bottom:1px solid var(--border-color);font-family:var(--font-display);color:var(--text-primary);align-items:center;gap:10px;padding:14px 20px;font-size:17px;font-weight:600;display:flex;position:relative}.card-header:before{content:"";background:var(--shimmer-gradient);border-radius:0 0 3px 3px;height:3px;position:absolute;top:0;left:20px;right:20px}.card-body{padding:24px}.btn{border:1px solid var(--border-color);border-radius:var(--radius-md);font-family:var(--font-body);cursor:pointer;background:var(--bg-card);color:var(--text-primary);justify-content:center;align-items:center;gap:8px;padding:10px 20px;font-size:14px;font-weight:500;transition:all .2s;display:inline-flex}.btn:hover{background:var(--bg-hover);border-color:var(--purple-light);box-shadow:0 2px 8px #9b72cf1f}.btn:active{transform:scale(.97)}.btn:focus-visible{outline:2px solid var(--purple-mid);outline-offset:2px}.btn-primary{background:var(--purple-mid);color:#fff;border-color:#0000;position:relative;overflow:hidden}.btn-primary:hover{background:var(--purple-deep);box-shadow:0 2px 12px #9b72cf40}.btn-primary:after{content:"";opacity:0;background:linear-gradient(90deg,#0000 30%,#ffffff1f 50%,#0000 70%) 0 0/200% 100%;transition:opacity .3s;position:absolute;inset:0}.btn-primary:hover:after{opacity:1;animation:1.5s infinite shimmerSweep}.btn-rose{background:var(--rose-glow);border-color:var(--rose-light);color:var(--rose-deep)}.btn-rose:hover{background:var(--rose-light);color:#fff}.btn-sage{background:var(--sage-glow);border-color:var(--sage-light);color:var(--sage-deep)}.btn-sage:hover{background:var(--sage-light);color:#fff}.btn-sky{background:var(--sky-glow);border-color:var(--sky-light);color:var(--sky-deep)}.btn-sky:hover{background:var(--sky-light);color:#fff}.btn-ghost{color:var(--text-secondary);background:0 0;border-color:#0000}.btn-ghost:hover{background:var(--bg-hover);box-shadow:none;color:var(--text-primary);border-color:#0000}.btn-sm{padding:6px 14px;font-size:13px}.btn-xs{border-radius:var(--radius-sm);padding:4px 10px;font-size:12px}.btn:disabled{opacity:.4;cursor:not-allowed;transform:none}.input{background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-md);width:100%;color:var(--text-primary);font-family:var(--font-body);outline:none;padding:10px 14px;font-size:16px;transition:border-color .2s,box-shadow .2s}.input:focus{border-color:var(--purple-light);box-shadow:0 0 0 3px #9b72cf1f}.input::placeholder{color:var(--text-muted)}.label{font-family:var(--font-display);color:var(--text-secondary);margin-bottom:6px;font-size:15px;font-weight:500;display:block}.form-group{margin-bottom:18px}.input-select{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%237d7290' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10z'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:32px}.tab-bar{border-bottom:1px solid var(--border-color);display:flex}.tab-bar-item{color:var(--text-muted);font-family:var(--font-display);cursor:pointer;text-align:center;min-height:var(--tap-min);background:0 0;border:none;border-bottom:2px solid #0000;flex:1;justify-content:center;align-items:center;padding:12px;font-size:14px;font-weight:500;transition:all .2s;display:inline-flex}.tab-bar-item:hover{color:var(--text-secondary);background:#9b72cf0a}.tab-bar-item.active{border-bottom-color:var(--purple-mid);color:var(--purple-deep);background:#9b72cf14}[data-theme=dark] .tab-bar-item.active{color:var(--purple-glow)}.badge{font-family:var(--font-body);border-radius:20px;align-items:center;gap:4px;padding:3px 10px;font-size:12px;font-weight:500;display:inline-flex}.badge-purple{color:var(--purple-deep);border:1px solid var(--purple-light);background:#6b4d9e1a}.badge-sage{color:var(--sage-deep);border:1px solid var(--sage-light);background:#4a8a6a1a}.badge-rose{color:var(--rose-deep);border:1px solid var(--rose-light);background:#b8547a1a}.badge-sky{color:var(--sky-deep);border:1px solid var(--sky-light);background:#5a7fa81a}.badge-count{background:var(--rose-mid);color:#fff;border-radius:9px;justify-content:center;align-items:center;min-width:18px;height:18px;padding:0 5px;font-size:11px;font-weight:600;display:inline-flex}[data-theme=dark] .badge-purple{color:var(--purple-glow);background:#9b72cf33}[data-theme=dark] .badge-sage{color:var(--sage-glow);background:#6db89a33}[data-theme=dark] .badge-rose{color:var(--rose-glow);background:#d4789e33}[data-theme=dark] .badge-sky{color:var(--sky-glow);background:#7ea8d433}.avatar{font-family:var(--font-display);color:#fff;background:var(--purple-mid);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-weight:600;display:inline-flex}.avatar-sm{width:28px;height:28px;font-size:11px}.avatar-md{width:36px;height:36px;font-size:13px}.avatar-lg{width:48px;height:48px;font-size:17px}.avatar-xl{width:72px;height:72px;font-size:24px}.avatar-shimmer{background:var(--shimmer-gradient);background-size:200% 200%;animation:6s ease-in-out infinite shimmer-shift}.avatar-rose{background:var(--rose-mid)}.avatar-sage{background:var(--sage-mid)}.avatar-sky{background:var(--sky-mid)}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;background:#2a243866;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal-overlay .card{animation:.35s cubic-bezier(.22,1,.36,1) forwards slideUp}[data-theme=dark] .modal-overlay{background:#0f0c1480}.empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:48px 24px;display:flex}.empty-state-icon{opacity:.35;margin-bottom:16px;font-size:48px;animation:6s ease-in-out infinite float}.empty-state-title{font-family:var(--font-display);color:var(--text-primary);margin-bottom:8px;font-size:22px;font-weight:600}.empty-state-text{color:var(--text-muted);max-width:320px;font-size:14px;line-height:1.6}.loading-shimmer{background:linear-gradient(90deg, var(--bg-secondary) 25%, var(--bg-hover) 50%, var(--bg-secondary) 75%);border-radius:var(--radius-md);background-size:400% 100%;animation:1.8s infinite shimmerSweep}.loading-text{font-family:var(--font-display);background:var(--shimmer-gradient);-webkit-text-fill-color:transparent;background-size:200% 200%;-webkit-background-clip:text;background-clip:text;font-size:18px;font-weight:500;animation:3s ease-in-out infinite shimmer-shift}.typing-indicator{background:var(--bg-input);border-radius:var(--radius-md);border-bottom-left-radius:2px;align-items:center;gap:3px;padding:8px 14px;display:inline-flex}.typing-indicator span{background:var(--purple-light);border-radius:50%;width:6px;height:6px}.typing-indicator span:first-child{animation:1.4s infinite typingDot}.typing-indicator span:nth-child(2){animation:1.4s .2s infinite typingDot}.typing-indicator span:nth-child(3){animation:1.4s .4s infinite typingDot}.notice{border-radius:var(--radius-md);padding:10px 14px;font-size:13px;line-height:1.5}.notice-error{color:var(--danger);background:#c9444d0f;border:1px solid #c9444d40}.notice-success{border:1px solid var(--sage-mid);color:var(--sage-deep);background:#4a8a6a0f}.notice-info{color:var(--purple-deep);background:#9b72cf0f;border:1px solid #9b72cf33}[data-theme=dark] .notice-error{background:#e05a5a1a}[data-theme=dark] .notice-success{background:#6db89a1a}[data-theme=dark] .notice-info{background:#9b72cf1f}.app-layout{height:100vh;display:flex}.sidebar{background:var(--bg-secondary);border-right:1px solid var(--border-color);flex-direction:column;flex-shrink:0;width:280px;transition:transform .3s,width .3s;display:flex}.sidebar-header{border-bottom:1px solid var(--border-color);padding:16px 20px}.shimmer-name{background:var(--shimmer-gradient);-webkit-text-fill-color:transparent;background-size:200% 200%;-webkit-background-clip:text;background-clip:text;animation:6s ease-in-out infinite shimmer-shift;display:inline-block}.sidebar-header h1{font-family:var(--font-display);background:var(--shimmer-gradient);-webkit-text-fill-color:transparent;background-size:200% 200%;-webkit-background-clip:text;background-clip:text;font-size:24px;font-weight:700;animation:6s ease-in-out infinite shimmer-shift}.sidebar-section{padding:12px 16px}.sidebar-section-title{font-family:var(--font-display);color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;padding:0 4px;font-size:12px;font-weight:500}.sidebar-item{border-radius:var(--radius-md);cursor:pointer;color:var(--text-secondary);text-align:left;width:100%;min-height:var(--tap-min);background:0 0;border:none;align-items:center;gap:10px;padding:10px 12px;font-family:inherit;font-size:14px;transition:all .2s;display:flex}.sidebar-item:hover{background:var(--bg-hover);color:var(--text-primary)}.sidebar-item.active{color:var(--purple-deep);background:linear-gradient(135deg,#9b72cf1a,#eaa8c40f);font-weight:500}[data-theme=dark] .sidebar-item.active{color:var(--purple-glow)}.sidebar-item .circle-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.sidebar-item .nav-icon{text-align:center;flex-shrink:0;width:20px;font-size:16px}.nav-label-group{flex-direction:column;gap:1px;display:flex}.nav-sublabel{color:var(--text-muted);font-size:12px;font-weight:400;line-height:1.2}.sidebar-item.nav-item--awakening{background:#9b72cf0a;border-left:2px solid #9b72cf59}.sidebar-item.nav-item--awakening:hover{background:#9b72cf14}.sidebar-footer{border-top:1px solid var(--border-color);align-items:center;gap:10px;padding:12px 16px;display:flex}.main-content{flex-direction:column;flex:1;display:flex;overflow:hidden}.mobile-header{background:var(--bg-secondary);border-bottom:1px solid var(--border-color);align-items:center;gap:12px;padding:10px 16px;display:none}.mobile-header h2{font-family:var(--font-display);flex:1;font-size:17px;font-weight:600}.hamburger-btn{width:var(--tap-min);height:var(--tap-min);border-radius:var(--radius-sm);cursor:pointer;color:var(--text-primary);background:0 0;border:none;justify-content:center;align-items:center;font-size:22px;transition:background .2s;display:flex}.hamburger-btn:hover{background:var(--bg-hover)}.center-page{background:radial-gradient(ellipse at 20% 50%, #c4a6e826 0%, transparent 50%), radial-gradient(ellipse at 80% 20%, #a8c8e81f 0%, transparent 50%), radial-gradient(ellipse at 50% 80%, #eaa8c41f 0%, transparent 50%), var(--bg-primary);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.auth-card{width:100%;max-width:420px}.chat-container{flex-direction:column;flex:1;display:flex;overflow:hidden}.chat-header{border-bottom:1px solid var(--border-color);background:var(--bg-secondary);justify-content:space-between;align-items:center;padding:14px 20px;display:flex}.chat-header h2{font-family:var(--font-display);color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-size:20px;font-weight:600;overflow:hidden}.chat-header-meta{font-family:var(--font-mono);color:var(--text-muted);align-items:center;gap:6px;font-size:12px;display:flex}.chat-header-meta .lock-icon{font-size:11px}.chat-messages{flex-direction:column;flex:1;gap:4px;padding:16px 20px;display:flex;overflow-y:auto}.message{border-radius:var(--radius-md);word-break:break-word;max-width:70%;padding:10px 16px;font-size:14px;line-height:1.5;animation:.25s fadeIn}.message.own{background:var(--purple-deep);color:#fff;border-bottom-right-radius:2px;align-self:flex-end}.message.other{background:var(--bg-input);border-bottom-left-radius:2px;align-self:flex-start}.message .sender-name{font-family:var(--font-display);background:var(--shimmer-gradient);-webkit-text-fill-color:transparent;background-size:200% 200%;-webkit-background-clip:text;background-clip:text;margin-bottom:2px;font-size:13px;font-weight:500;animation:6s ease-in-out infinite shimmer-shift;display:inline-block}.message .timestamp{color:var(--text-muted);margin-top:4px;font-size:11px}.message.own .timestamp{color:#ffffffd9}.message.system{max-width:90%;color:var(--text-muted);text-align:center;background:0 0;align-self:center;padding:8px 0;font-size:12px;font-style:italic}.message.grouped{margin-top:-2px}.message.grouped .sender-name{display:none}.chat-input-area{border-top:1px solid var(--border-color);background:var(--bg-secondary);padding:14px 20px;padding-bottom:calc(14px + var(--safe-bottom));gap:10px;display:flex}.chat-input-area .input{flex:1}.dm-layout{flex:1;display:flex;overflow:hidden}.dm-thread-list{border-right:1px solid var(--border-color);background:var(--bg-secondary);flex-direction:column;width:300px;display:flex;overflow:hidden}.dm-thread-list-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.dm-thread-list-header h3{font-family:var(--font-display);font-size:17px;font-weight:600}.dm-threads{flex:1;overflow-y:auto}.dm-thread-item{cursor:pointer;border-bottom:1px solid #00000008;align-items:center;gap:10px;padding:12px 16px;transition:background .15s;display:flex}.dm-thread-item:hover{background:var(--bg-hover)}.dm-thread-item.active{background:#d4789e14}.dm-thread-item-content{flex:1;min-width:0}.dm-thread-item-name{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;font-size:14px;font-weight:500;overflow:hidden}.dm-thread-item-preview{color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;font-size:12px;overflow:hidden}.dm-thread-item-time{color:var(--text-muted);font-size:11px;font-family:var(--font-mono);flex-shrink:0}.dm-chat{flex-direction:column;flex:1;display:flex;overflow:hidden}.dm-back-btn{display:none}@media (width<=480px){.dm-back-btn{justify-content:center;align-items:center;display:inline-flex}}.message.dm-own{background:var(--rose-deep);color:#fff;border-bottom-right-radius:2px;align-self:flex-end}.message.dm-own .timestamp{color:#ffffffd9}.dm-msg-row{align-self:flex-start;align-items:flex-end;gap:8px;max-width:75%;display:flex}.dm-msg-row .dm-msg-avatar{text-align:center;color:#fff;border-radius:50%;flex-shrink:0;width:28px;height:28px;font-size:11px;font-weight:600;line-height:28px}.dm-msg-row .message{max-width:100%}.dm-msg-row.grouped .dm-msg-avatar{visibility:hidden}@media (forced-colors:active){.message{border:1px solid buttontext}.message.own,.message.dm-own{border:2px solid highlight}.avatar{border:1px solid buttontext}}.btn,.btn-sm,.btn-xs{min-height:44px}.member-list{border-left:1px solid var(--border-color);background:var(--bg-secondary);width:200px;padding:16px;overflow-y:auto}.member-list h3{font-family:var(--font-display);color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px;font-size:13px;font-weight:500}.member-divider{background:var(--border-color);height:1px;margin:10px 0}.member-entry{color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;align-items:center;gap:8px;padding:6px 4px;font-size:14px;transition:background .15s;display:flex}.member-entry:hover{background:var(--bg-hover)}.member-list--embedded{background:0 0;border-left:none;padding:0;width:100%!important;display:block!important}.members-btn-mobile{display:none}@media (width<=480px){.members-btn-mobile{display:inline-flex}}.member-entry .status-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.member-entry .status-dot.online{background:var(--sage-mid);box-shadow:0 0 6px var(--sage-glow)}.member-entry .status-dot.offline{border:1.5px solid var(--text-muted);background:0 0}.connections-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px;display:grid}.connection-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);align-items:center;gap:12px;padding:14px 16px;transition:all .2s;display:flex}.connection-card:hover{border-color:var(--purple-light);box-shadow:0 2px 12px #9b72cf14}.connection-info{flex:1;min-width:0}.connection-name{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;font-size:14px;font-weight:500;overflow:hidden}.connection-handle{color:var(--text-muted);font-size:12px;font-family:var(--font-mono)}.profile-header{border-bottom:1px solid var(--border-color);align-items:center;gap:20px;padding:24px;display:flex}.profile-header-info h2{font-family:var(--font-display);font-size:22px;font-weight:700}.profile-section{border-bottom:1px solid var(--border-color);padding:20px 24px}.profile-section:last-child{border-bottom:none}.profile-section-title{font-family:var(--font-display);color:var(--text-primary);margin-bottom:14px;font-size:15px;font-weight:600}.lineage-container{flex-direction:column;flex:1;display:flex;overflow:hidden}.lineage-canvas{flex:1;position:relative}.lineage-canvas svg{width:100%;height:100%;display:block}.heatmap-grid{gap:2px;padding:20px;display:grid}.heatmap-cell{aspect-ratio:1;cursor:pointer;border-radius:4px;transition:transform .15s}.heatmap-cell:hover{z-index:1;transform:scale(1.3)}.heatmap-tooltip{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-sm);pointer-events:none;z-index:10;padding:8px 12px;font-size:12px;position:absolute;box-shadow:0 4px 12px #0000001a}.tapestry-container{flex:1;display:flex;overflow:hidden}.tapestry-canvas{background:var(--bg-primary);flex:1;position:relative}.tapestry-canvas svg{width:100%;height:100%;display:block}.tapestry-sidebar{border-left:1px solid var(--border-color);background:var(--bg-secondary);width:320px;padding:20px;overflow-y:auto}.tapestry-sidebar h3{font-family:var(--font-display);color:var(--text-primary);margin-bottom:12px;font-size:15px;font-weight:600}.tapestry-sidebar h4{font-family:var(--font-display);color:var(--text-muted);margin-top:20px;margin-bottom:8px;font-size:13px;font-weight:500}.tapestry-stat{align-items:baseline;gap:8px;margin-bottom:6px;display:flex}.tapestry-stat .value{font-family:var(--font-display);color:var(--text-primary);font-size:28px;font-weight:700}.tapestry-stat .label{color:var(--text-muted);margin-bottom:0;font-size:13px;font-weight:400}.tapestry-weaver-item,.tapestry-overlap-item{border-radius:var(--radius-md);cursor:pointer;justify-content:space-between;align-items:center;margin-bottom:4px;padding:8px 10px;transition:background .15s;display:flex}.tapestry-weaver-item:hover,.tapestry-overlap-item:hover{background:var(--bg-hover)}.tapestry-scope-toggle{border:1px solid var(--border-color);border-radius:var(--radius-md);display:inline-flex;overflow:hidden}.tapestry-scope-toggle button{font-family:var(--font-body);cursor:pointer;background:var(--bg-card);color:var(--text-secondary);border:none;padding:6px 16px;font-size:13px;font-weight:500;transition:all .2s}.tapestry-scope-toggle button.active{background:var(--purple-mid);color:#fff}.shimmer-divider{background:var(--shimmer-gradient);opacity:.3;border-radius:1px;height:2px;margin:16px 0}.shimmer-text{background:var(--shimmer-gradient);-webkit-text-fill-color:transparent;background-size:200% 200%;-webkit-background-clip:text;background-clip:text;animation:6s ease-in-out infinite shimmer-shift}.away-message{font-family:var(--font-body);color:var(--text-muted);border-left:3px solid var(--rose-light);border-radius:0 var(--radius-sm) var(--radius-sm) 0;background:#eaa8c40f;padding:8px 12px;font-size:13px;font-style:italic}.toast{border-radius:var(--radius-md);background:var(--bg-card);border:1px solid var(--border-color);color:var(--text-primary);font-family:var(--font-body);z-index:1000;padding:12px 20px;font-size:14px;animation:.3s slideUp;position:fixed;bottom:20px;right:20px;box-shadow:0 4px 20px #6b4d9e1f}.text-center{text-align:center}.mt-1{margin-top:8px}.mt-2{margin-top:16px}.mt-3{margin-top:24px}.mb-1{margin-bottom:8px}.mb-2{margin-bottom:16px}.theme-toggle{border:1px solid var(--border-color);background:var(--bg-card);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:14px;transition:all .2s;display:flex}.theme-toggle:hover{background:var(--bg-hover);border-color:var(--purple-light)}@media (width<=1023px){.sidebar{width:240px}.member-list{width:180px}.tapestry-sidebar{width:280px}.dm-thread-list{width:260px}}@media (width<=767px){.sidebar{width:220px}.member-list{width:160px}.tapestry-sidebar,.dm-thread-list{width:240px}.connections-grid{grid-template-columns:1fr 1fr}}@media (width<=480px){.app-layout{flex-direction:column;position:relative}.sidebar{z-index:50;width:280px;padding-top:var(--safe-top);padding-bottom:var(--safe-bottom);position:fixed;top:0;bottom:0;left:0;transform:translate(-100%)}.sidebar.sidebar-open{transform:translate(0)}.sidebar-backdrop{z-index:49;background:#0f0c148c;display:none;position:fixed;inset:0}.sidebar-backdrop.visible{display:block}.sidebar-item{min-height:var(--tap-min);padding:12px;font-size:15px}.nav-sublabel{font-size:12px}.mobile-header{padding-top:calc(10px + var(--safe-top));display:flex}.mobile-header h2{text-overflow:ellipsis;white-space:nowrap;font-size:16px;overflow:hidden}.main-content{height:100vh}.member-list{display:none}.auth-card{max-width:100%}.center-page{padding:16px}.chat-header{padding:12px 16px}.chat-header h2{font-size:18px}.chat-input-area{padding:10px 12px;padding-bottom:calc(10px + var(--safe-bottom))}.message{max-width:80%}.dm-layout{flex-direction:column;position:relative}.dm-thread-list{border-right:none;border-bottom:1px solid var(--border-color);flex:1;width:100%;height:auto;max-height:none}.dm-chat{min-height:0}.dm-layout.dm-layout--list .dm-thread-list{display:flex}.dm-layout.dm-layout--list .dm-chat,.dm-layout.dm-layout--detail .dm-thread-list{display:none}.dm-layout.dm-layout--detail .dm-chat{flex:1;display:flex}.connections-grid{grid-template-columns:1fr}.tapestry-container{flex-direction:column}.tapestry-canvas{min-height:45vh}.tapestry-sidebar{border-left:none;border-top:1px solid var(--border-color);width:100%;max-height:35vh}.modal-overlay{padding:12px}.modal-overlay .card{max-width:100%}.heatmap-tooltip{max-width:none;top:8px!important;left:12px!important;right:12px!important}}@media (orientation:landscape) and (height<=500px){.sidebar{z-index:50;width:260px;position:fixed;top:0;bottom:0;left:0;transform:translate(-100%)}.sidebar.sidebar-open{transform:translate(0)}.sidebar-backdrop{z-index:49;background:#0f0c148c;display:none;position:fixed;inset:0}.sidebar-backdrop.visible{display:block}.mobile-header{display:flex}.member-list{display:none}}
