.invite-modal{max-width:440px;width:95vw}.invite-modal__body{padding:var(--space-4) var(--space-5);min-height:200px;display:flex;flex-direction:column;align-items:center;justify-content:center}.invite-modal__loading{text-align:center;color:var(--text-secondary)}.invite-modal__spinner{width:32px;height:32px;border:3px solid var(--border-subtle, rgba(255,255,255,.1));border-top-color:var(--accent-primary, #6366f1);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto var(--space-3)}@keyframes spin{to{transform:rotate(360deg)}}.invite-modal__instruction{text-align:center;color:var(--text-secondary);font-size:.9rem;margin:0 0 var(--space-4);line-height:1.5}.invite-modal__qr-wrapper{display:flex;justify-content:center;margin-bottom:var(--space-4)}.invite-modal__qr-wrapper canvas{border-radius:var(--radius-lg);border:2px solid var(--border-subtle, rgba(255,255,255,.1))}.invite-modal__link-row{display:flex;gap:var(--space-2);width:100%;margin-bottom:var(--space-4)}.invite-modal__link-input{flex:1;padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);background:var(--bg-tertiary, #1e1f33);border:1px solid var(--border-subtle, rgba(255,255,255,.1));color:var(--text-primary);font-size:.8rem;font-family:JetBrains Mono,Fira Code,monospace;min-width:0}.invite-modal__copy-btn{white-space:nowrap;flex-shrink:0}.invite-modal__status{display:flex;align-items:center;gap:var(--space-2);color:var(--text-secondary);font-size:.85rem}.invite-modal__pulse{width:10px;height:10px;border-radius:50%;background:#22c55e;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}.invite-modal__handshake{text-align:center;padding:var(--space-4) 0}.invite-modal__handshake h3{margin:0 0 var(--space-2);font-size:1.1rem;color:var(--text-primary)}.invite-modal__guest-info,.invite-modal__step{color:var(--text-secondary);font-size:.85rem;margin:var(--space-1) 0}.invite-modal__success{text-align:center;padding:var(--space-4) 0}.invite-modal__success-icon{width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,#22c55e,#16a34a);display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:#fff;margin:0 auto var(--space-3)}.invite-modal__success h3{margin:0 0 var(--space-2);font-size:1.1rem;color:var(--text-primary)}.invite-modal__success p{margin:var(--space-1) 0;color:var(--text-secondary);font-size:.9rem}.invite-modal__success-desc{margin-top:var(--space-3)!important;margin-bottom:var(--space-4)!important;font-size:.85rem!important;line-height:1.5}.invite-modal__error{text-align:center;padding:var(--space-4) 0}.invite-modal__error-icon{width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,#ef4444,#dc2626);display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:#fff;margin:0 auto var(--space-3)}.invite-modal__error h3{margin:0 0 var(--space-2);color:var(--text-primary)}.invite-modal__error p{color:var(--text-secondary);font-size:.9rem;margin-bottom:var(--space-4)}.invite-modal__accept-section{width:100%}.invite-modal__invite-card{background:var(--bg-tertiary, #1e1f33);border:1px solid var(--border-subtle, rgba(255,255,255,.1));border-radius:var(--radius-lg);padding:var(--space-4);margin-bottom:var(--space-4)}.invite-modal__invite-host{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-3)}.invite-modal__invite-avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--accent-primary, #6366f1),var(--accent-secondary, #818cf8));display:flex;align-items:center;justify-content:center;font-size:1.2rem;font-weight:700;color:#fff;flex-shrink:0}.invite-modal__invite-host-name{font-weight:600;font-size:1rem;color:var(--text-primary)}.invite-modal__invite-host-sub{font-size:.85rem;color:var(--text-secondary);margin-top:2px}.invite-modal__invite-role{font-size:.85rem;color:var(--text-secondary);padding-top:var(--space-2);border-top:1px solid var(--border-subtle, rgba(255,255,255,.06))}.invite-modal__accept-actions{display:flex;gap:var(--space-2);justify-content:center}.profile-page{max-width:680px;margin:0 auto;padding:var(--space-6) var(--space-4);animation:fadeIn .3s ease}.profile-page__loading{text-align:center;padding:var(--space-8);color:var(--text-secondary)}.profile-page__header{display:flex;align-items:center;gap:var(--space-5);margin-bottom:var(--space-8)}.profile-page__avatar{width:96px;height:96px;border-radius:24px;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary, #6366f1));display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 8px 24px #6366f140}.profile-page__avatar-initial{font-size:2.5rem;font-weight:700;color:#fff;text-transform:uppercase;line-height:1}.profile-page__header-info{display:flex;flex-direction:column;gap:var(--space-1)}.profile-page__title{font-size:1.75rem;font-weight:700;color:var(--text-primary);margin:0}.profile-page__subtitle{font-size:.875rem;color:var(--text-secondary)}.profile-page__section{margin-bottom:var(--space-7)}.profile-page__section-title{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0 0 var(--space-4);padding-bottom:var(--space-2);border-bottom:1px solid var(--border-subtle)}.profile-page__field{margin-bottom:var(--space-4)}.profile-page__label{display:block;font-size:.75rem;font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-1)}.profile-page__value{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-3);border-radius:var(--radius-md);background:var(--bg-tertiary);border:1px solid transparent;cursor:pointer;font-size:.95rem;color:var(--text-primary);transition:all .15s ease;min-height:42px}.profile-page__value:hover{border-color:var(--border-interactive);background:var(--bg-secondary)}.profile-page__value--bio{align-items:flex-start;white-space:pre-wrap;min-height:60px}.profile-page__edit-icon{opacity:0;color:var(--text-secondary);font-size:.85rem;transition:opacity .15s;flex-shrink:0;margin-left:var(--space-2)}.profile-page__value:hover .profile-page__edit-icon{opacity:1}.profile-page__placeholder{color:var(--text-secondary);font-style:italic}.profile-page__input-row{display:flex;gap:var(--space-2);align-items:flex-start;flex-wrap:wrap}.profile-page__input{flex:1;padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);background:var(--bg-tertiary);border:1px solid var(--accent-primary);color:var(--text-primary);font-size:.95rem;font-family:inherit;outline:none;min-width:0}.profile-page__textarea{width:100%;padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);background:var(--bg-tertiary);border:1px solid var(--accent-primary);color:var(--text-primary);font-size:.95rem;font-family:inherit;outline:none;resize:vertical;min-height:60px}.profile-page__input-actions{display:flex;gap:var(--space-2);margin-top:var(--space-2)}.profile-page__btn{padding:var(--space-1) var(--space-3);border-radius:var(--radius-sm);border:1px solid var(--border-subtle);background:var(--bg-tertiary);color:var(--text-primary);font-size:.85rem;cursor:pointer;transition:all .15s}.profile-page__btn:hover{background:var(--bg-secondary)}.profile-page__btn--primary{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff}.profile-page__btn--primary:hover{filter:brightness(1.1)}.profile-page__did-container{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-3);border-radius:var(--radius-md);background:var(--bg-tertiary);cursor:pointer;transition:all .15s;margin-bottom:var(--space-4)}.profile-page__did-container:hover{background:var(--bg-secondary)}.profile-page__did-value{font-family:JetBrains Mono,Fira Code,monospace;font-size:.8rem;color:var(--text-secondary);word-break:break-all}.profile-page__did-copy{flex-shrink:0;margin-left:var(--space-3);font-size:.8rem;color:var(--accent-primary);white-space:nowrap}.profile-page__did-card{background:linear-gradient(135deg,var(--bg-tertiary),var(--bg-secondary));border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-6) var(--space-4);text-align:center;display:flex;flex-direction:column;align-items:center;gap:var(--space-3)}.profile-page__did-card-avatar{position:relative;width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary, #6366f1));display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;color:#fff}.profile-page__did-card-badge{position:absolute;bottom:-2px;right:-2px;width:20px;height:20px;border-radius:50%;background:#22c55e;color:#fff;font-size:.65rem;display:flex;align-items:center;justify-content:center;border:2px solid var(--bg-primary)}.profile-page__did-card-title{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0}.profile-page__did-card-desc{font-size:.85rem;color:var(--text-secondary);line-height:1.5;max-width:380px;margin:0}.profile-page__toast{position:fixed;bottom:var(--space-4);left:50%;transform:translate(-50%);background:var(--accent-primary);color:#fff;padding:var(--space-2) var(--space-5);border-radius:var(--radius-lg);font-size:.85rem;font-weight:500;box-shadow:0 4px 16px #0000004d;animation:slideUp .3s ease;z-index:1000}@keyframes slideUp{0%{transform:translate(-50%) translateY(20px);opacity:0}to{transform:translate(-50%) translateY(0);opacity:1}}@media (max-width: 640px){.profile-page{padding:var(--space-4) var(--space-3)}.profile-page__header{flex-direction:column;text-align:center}.profile-page__avatar{width:80px;height:80px;border-radius:20px}.profile-page__avatar-initial{font-size:2rem}}:root{--color-bg-primary: #0f0f13;--color-bg-secondary: #16161d;--color-bg-tertiary: #1e1e28;--color-bg-elevated: #252532;--color-bg-hover: #2a2a3a;--color-bg-active: #32324a;--color-surface: #1a1a24;--color-surface-hover: #22222e;--color-surface-border: rgba(255, 255, 255, .06);--color-text-primary: #e8e8ed;--color-text-secondary: #9d9dab;--color-text-tertiary: #6b6b7b;--color-text-accent: #a29bfe;--color-text-inverse: #0f0f13;--color-accent: #6C5CE7;--color-accent-hover: #7c6ff0;--color-accent-soft: rgba(108, 92, 231, .15);--color-accent-glow: rgba(108, 92, 231, .3);--color-success: #00cec9;--color-success-soft: rgba(0, 206, 201, .15);--color-warning: #fdcb6e;--color-warning-soft: rgba(253, 203, 110, .15);--color-danger: #ff6b6b;--color-danger-soft: rgba(255, 107, 107, .15);--color-info: #74b9ff;--color-info-soft: rgba(116, 185, 255, .15);--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--text-xs: .75rem;--text-sm: .8125rem;--text-base: .9375rem;--text-lg: 1.125rem;--text-xl: 1.375rem;--text-2xl: 1.75rem;--text-3xl: 2.25rem;--leading-tight: 1.25;--leading-normal: 1.5;--leading-relaxed: 1.75;--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;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .5);--shadow-glow: 0 0 20px var(--color-accent-glow);--transition-fast: .12s ease;--transition-base: .2s ease;--transition-slow: .35s ease;--sidebar-width: 260px;--sidebar-collapsed: 56px;--topbar-height: 48px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}body{font-family:var(--font-sans);font-size:var(--text-base);line-height:var(--leading-normal);color:var(--color-text-primary);background-color:var(--color-bg-primary);overflow:hidden;height:100vh;width:100vw}#root{height:100%;width:100%}a{color:var(--color-text-accent);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-accent-hover)}button{font-family:inherit;font-size:inherit;cursor:pointer;border:none;background:none;color:inherit}input,textarea,select{font-family:inherit;font-size:inherit;color:inherit;background:transparent;border:1px solid var(--color-surface-border);border-radius:var(--radius-md);padding:var(--space-2) var(--space-3);outline:none;transition:border-color var(--transition-fast)}input:focus,textarea:focus,select:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-soft)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-bg-hover);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-text-tertiary)}.app-layout{display:flex;height:100vh;height:100dvh;width:100vw;overflow:hidden}.floating-toggle-btn{position:absolute;top:var(--space-3);z-index:60;background:var(--color-surface);border:1px solid var(--color-surface-border);box-shadow:var(--shadow-md);color:var(--color-text-secondary);width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;opacity:.5}.floating-toggle-btn:hover{opacity:1;color:var(--color-text-primary);background:var(--color-bg-hover)}@media (max-width: 768px){.floating-toggle-btn{display:none}}.space-rail-wrapper{position:relative;height:100%;display:flex}.space-rail{width:220px;min-width:220px;height:100%;background:var(--color-bg-primary);border-right:1px solid var(--color-surface-border);display:flex;flex-direction:column;transition:width .2s ease,min-width .2s ease;overflow:hidden}.space-rail--collapsed{width:0;min-width:0;border-right:none}.space-rail__header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-surface-border)}.space-rail__title{font-weight:700;font-size:var(--text-sm);color:var(--color-text-primary);white-space:nowrap}.space-rail__actions{display:flex;gap:var(--space-1)}.space-rail__btn{background:none;border:none;color:var(--color-text-tertiary);cursor:pointer;padding:2px 6px;border-radius:var(--radius-sm);font-size:var(--text-sm);transition:background .15s,color .15s}.space-rail__btn:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}.space-rail__list{flex:1;overflow-y:auto;padding:var(--space-2) var(--space-2)}.space-rail__search{padding:0 var(--space-4) var(--space-2)}.space-rail__search-inner{display:flex;align-items:center;gap:var(--space-2);background:var(--color-bg-tertiary);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md)}.space-rail__search-icon{font-size:13px;opacity:.6}.space-rail__search-input{background:none;border:none;color:var(--color-text-primary);font-size:var(--text-sm);width:100%;outline:none}.space-rail__space{display:flex;align-items:center;gap:var(--space-3);width:calc(100% - var(--space-4));padding:6px var(--space-3);margin:2px var(--space-2);border:none;background:none;border-radius:6px;cursor:pointer;transition:background .15s;text-align:left}.space-rail__space:hover{background:var(--color-bg-hover)}.space-rail__space--active{background:var(--color-accent-soft)}.space-rail__space-letter{width:24px;height:24px;border-radius:4px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px;color:#fff;flex-shrink:0}.space-rail__space-img{width:32px;height:32px;border-radius:var(--radius-md);object-fit:cover;flex-shrink:0}.space-rail__space-name{font-size:var(--text-sm);color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.space-rail__footer{padding:var(--space-3) var(--space-4);border-top:1px solid var(--color-surface-border);margin-top:auto;display:flex;flex-direction:column;gap:var(--space-2)}.space-rail__profile-btn{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2);border-radius:var(--radius-sm);cursor:pointer;transition:background .15s}.space-rail__profile-btn:hover{background:var(--color-surface-hover)}.space-rail__profile-btn--active{background:var(--color-accent-bg)}.space-rail__profile-avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--accent-primary, #6366f1),var(--accent-secondary, #818cf8));display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;color:#fff;flex-shrink:0}.space-rail__profile-name{font-size:.85rem;font-weight:500;color:var(--text-primary, #e2e8f0);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.app-sidebar{width:260px;min-width:260px;height:100%;background:var(--color-bg-secondary);border-right:1px solid var(--color-surface-border);display:flex;flex-direction:column;overflow:hidden;transition:width .2s ease,min-width .2s ease}.app-layout--sidebar-collapsed .app-sidebar{width:0;min-width:0;border-right:none}.sidebar-panel{display:flex;flex-direction:column;height:100%;overflow-y:auto;overflow-x:hidden}.sidebar-panel__header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-surface-border);position:relative}.sidebar-panel__space-info{display:flex;align-items:center;gap:var(--space-3);cursor:pointer;flex:1;padding:var(--space-1);border-radius:var(--radius-sm);transition:background .15s;min-width:0}.sidebar-panel__space-info:hover{background:var(--color-surface-hover)}.sidebar-panel__space-menu{position:absolute;top:100%;left:var(--space-4);background:var(--color-surface);border:1px solid var(--color-surface-border);border-radius:var(--radius-md);box-shadow:var(--shadow-xl);z-index:100;min-width:220px;display:flex;flex-direction:column;padding:var(--space-1) 0;animation:fadeIn .15s ease-out}.sidebar-panel__space-menu-item{background:none;border:none;width:100%;text-align:left;padding:var(--space-2) var(--space-3);font-size:var(--text-sm);color:var(--color-text-primary);cursor:pointer;display:flex;align-items:center;gap:var(--space-2)}.sidebar-panel__space-menu-item:hover{background:var(--color-surface-hover)}.sidebar-panel__space-logo{width:28px;height:28px;border-radius:var(--radius-md);object-fit:cover;flex-shrink:0}.sidebar-panel__space-letter{width:28px;height:28px;border-radius:var(--radius-md);background:var(--color-accent);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:var(--text-xs);color:#fff;flex-shrink:0}.sidebar-panel__space-name{font-weight:600;font-size:var(--text-sm);color:var(--color-text-primary);white-space:nowrap}.sidebar-panel__space-desc{font-size:var(--text-xs);color:var(--color-text-tertiary)}.sidebar-panel__collapse-btn{background:none;border:none;color:var(--color-text-tertiary);cursor:pointer;padding:2px 6px;border-radius:var(--radius-sm);font-size:var(--text-sm);transition:background .15s}.sidebar-panel__collapse-btn:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}.sidebar-panel__actions{display:flex;gap:var(--space-2);padding:var(--space-3) var(--space-4)}.sidebar-panel__actions-box{width:100%;background:var(--color-bg-tertiary);border:1px solid var(--color-surface-border);border-radius:var(--radius-md);overflow:visible}.sidebar-panel__actions-box>:first-child,.sidebar-panel__actions-box>:first-child .sidebar-panel__action-row{border-top-left-radius:var(--radius-md);border-top-right-radius:var(--radius-md)}.sidebar-panel__actions-box>:last-child,.sidebar-panel__actions-box>:last-child .sidebar-panel__action-row{border-bottom-left-radius:var(--radius-md);border-bottom-right-radius:var(--radius-md)}.sidebar-panel__action-row{width:100%;display:flex;align-items:center;gap:var(--space-3);padding:8px var(--space-3);background:none;border:none;border-bottom:1px solid var(--color-surface-border);color:var(--color-text-secondary);font-size:var(--text-sm);cursor:pointer;text-align:left}.sidebar-panel__action-row:last-child{border-bottom:none}.sidebar-panel__action-row:hover{background:var(--color-surface-hover);color:var(--color-text-primary)}.sidebar-panel__action-icon{font-size:16px}.sidebar-panel__action-text{flex:1}.sidebar-panel__action-chevron{font-size:14px}.sidebar-panel__section{letter-spacing:.04em;cursor:pointer}.sidebar-panel__list{list-style:none;padding:0;margin:0}.sidebar-panel__item{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);cursor:pointer;font-size:var(--text-sm);color:var(--color-text-secondary);transition:background .15s,color .15s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-panel__item:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}.sidebar-panel__item--active{background:var(--color-accent-soft);color:var(--color-text-accent)}.sidebar-panel__item-icon{flex-shrink:0;width:20px;text-align:center}.sidebar-panel__footer{padding:var(--space-3) var(--space-4);border-top:1px solid var(--color-surface-border);margin-top:auto;display:flex;flex-direction:column;gap:var(--space-2)}.sidebar-panel__profile-btn{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-2);border-radius:var(--radius-sm);cursor:pointer;transition:background .15s}.sidebar-panel__profile-btn:hover{background:var(--color-surface-hover)}.sidebar-panel__profile-btn--active{background:var(--color-accent-bg)}.sidebar-panel__profile-avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--accent-primary, #6366f1),var(--accent-secondary, #818cf8));display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;color:#fff;flex-shrink:0}.sidebar-panel__profile-name{font-size:.85rem;font-weight:500;color:var(--text-primary, #e2e8f0);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-inner{display:flex;flex-direction:column;height:100%;overflow-y:auto;overflow-x:hidden}.app-main{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--color-bg-primary)}.app-content{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:var(--space-8)}.sidebar-header{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-4);border-bottom:1px solid var(--color-surface-border)}.sidebar-header__logo{width:28px;height:28px;border-radius:var(--radius-sm)}.sidebar-header__title{font-size:var(--text-base);font-weight:600;color:var(--color-text-primary)}.sidebar-section{padding:var(--space-3) var(--space-2)}.sidebar-section__label{font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-tertiary);padding:var(--space-1) var(--space-3);margin-bottom:var(--space-1)}.sidebar-nav{list-style:none;display:flex;flex-direction:column;gap:1px}.sidebar-nav__item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);color:var(--color-text-secondary);transition:all var(--transition-fast);cursor:pointer;font-size:var(--text-sm)}.sidebar-nav__item:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}.sidebar-nav__item--active{background:var(--color-accent-soft);color:var(--color-text-accent)}.sidebar-nav__icon{font-size:var(--text-lg);width:20px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.topbar{height:var(--topbar-height);min-height:var(--topbar-height);display:flex;align-items:center;padding:0 var(--space-6);border-bottom:1px solid var(--color-surface-border);background:var(--color-bg-primary);gap:var(--space-4)}.topbar__breadcrumb{font-size:var(--text-sm);color:var(--color-text-secondary);display:flex;align-items:center;gap:var(--space-2)}.topbar__breadcrumb span{color:var(--color-text-tertiary)}.topbar__space-select{background:transparent;border:1px solid var(--color-surface-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:var(--text-sm);padding:var(--space-1) var(--space-2);cursor:pointer;max-width:180px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.topbar__space-select option{background:var(--color-bg-secondary);color:var(--color-text-primary)}.card{background:var(--color-surface);border:1px solid var(--color-surface-border);border-radius:var(--radius-lg);padding:var(--space-5);transition:all var(--transition-base)}.card:hover{border-color:#ffffff1a;box-shadow:var(--shadow-md)}.card__title{font-size:var(--text-sm);font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.04em;margin-bottom:var(--space-4)}.object-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast)}.object-item:hover{background:var(--color-bg-hover)}.object-item__icon{font-size:var(--text-lg);flex-shrink:0}.object-item__info{flex:1;min-width:0}.object-item__name{font-size:var(--text-sm);font-weight:500;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.object-item__snippet{font-size:var(--text-xs);color:var(--color-text-tertiary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.object-item__time{font-size:var(--text-xs);color:var(--color-text-tertiary);flex-shrink:0}.btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:500;transition:all var(--transition-fast);white-space:nowrap}.btn--primary{background:var(--color-accent);color:#fff}.btn--primary:hover{background:var(--color-accent-hover);box-shadow:var(--shadow-glow)}.btn--ghost{color:var(--color-text-secondary)}.btn--ghost:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-16) var(--space-8);text-align:center}.empty-state__icon{font-size:3rem;margin-bottom:var(--space-4);opacity:.4}.empty-state__title{font-size:var(--text-lg);font-weight:600;color:var(--color-text-primary);margin-bottom:var(--space-2)}.empty-state__description{font-size:var(--text-sm);color:var(--color-text-tertiary);max-width:360px}.search-input{display:flex;align-items:center;gap:var(--space-2);background:var(--color-bg-tertiary);border:1px solid var(--color-surface-border);border-radius:var(--radius-md);padding:var(--space-2) var(--space-3);margin:var(--space-2) var(--space-3)}.search-input input{border:none;flex:1;font-size:var(--text-sm);background:transparent;padding:0}.search-input input:focus{box-shadow:none}.search-input__icon{color:var(--color-text-tertiary);font-size:var(--text-sm)}.widget-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--space-5)}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn var(--transition-base) ease-out}@keyframes slideInLeft{0%{opacity:0;transform:translate(-12px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.pulse{animation:pulse 2s ease-in-out infinite}.badge{display:inline-flex;align-items:center;padding:2px var(--space-2);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:500}.badge--accent{background:var(--color-accent-soft);color:var(--color-text-accent)}.badge--success{background:var(--color-success-soft);color:var(--color-success)}.badge--warning{background:var(--color-warning-soft);color:var(--color-warning)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:100;animation:fadeIn var(--transition-fast) ease-out}.modal-content{background:var(--color-bg-secondary);border:1px solid var(--color-surface-border);border-radius:var(--radius-xl);padding:var(--space-6);width:90%;max-width:480px;max-height:85vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:fadeIn var(--transition-base) ease-out}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4)}.modal-title{font-size:var(--text-lg);font-weight:600;color:var(--color-text-primary)}.block-editor{max-width:720px;margin:0 auto;padding:var(--space-2) 0}.editor-block{outline:none;padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);margin:var(--space-1) 0;border:2px solid transparent;transition:border-color var(--transition-fast);line-height:var(--leading-relaxed);min-height:1.6em;word-break:break-word}.editor-block--focused{border-color:var(--color-accent-soft)}.editor-block:empty:before{content:attr(data-placeholder);color:var(--color-text-tertiary);pointer-events:none}.editor-block--paragraph{font-size:var(--text-base)}.editor-block--heading1{font-size:var(--text-3xl);font-weight:700;margin:var(--space-6) 0 var(--space-2)}.editor-block--heading2{font-size:var(--text-2xl);font-weight:600;margin:var(--space-5) 0 var(--space-2)}.editor-block--heading3{font-size:var(--text-xl);font-weight:600;margin:var(--space-4) 0 var(--space-1)}.editor-block--code{background:var(--color-bg-tertiary);border:1px solid var(--color-surface-border);border-radius:var(--radius-md);padding:var(--space-4);margin:var(--space-3) 0}.editor-block--code code{font-family:var(--font-mono);font-size:var(--text-sm);outline:none;display:block;white-space:pre-wrap}.editor-block--quote{border-left:3px solid var(--color-accent);padding-left:var(--space-5);color:var(--color-text-secondary);font-style:italic;margin:var(--space-3) 0}.editor-block--todo{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-2) var(--space-3)}.editor-todo__checkbox{width:18px;height:18px;margin-top:3px;accent-color:var(--color-accent);cursor:pointer;flex-shrink:0}.editor-todo__text{flex:1;outline:none;min-height:1.4em}.editor-todo__text--done{text-decoration:line-through;opacity:.5}.editor-block--divider{padding:var(--space-4) var(--space-3);cursor:default}.editor-block--divider hr{border:none;border-top:1px solid var(--color-surface-border)}.editor-block--callout{display:flex;align-items:flex-start;gap:var(--space-3);background:var(--color-info-soft);border:1px solid rgba(116,185,255,.2);border-radius:var(--radius-lg);padding:var(--space-4);margin:var(--space-3) 0}.editor-callout__icon{font-size:var(--text-xl);flex-shrink:0}.editor-callout__text{flex:1;outline:none;min-height:1.4em}.editor-block--image{padding:var(--space-3)}.editor-image{max-width:100%;border-radius:var(--radius-md);display:block}.editor-image__placeholder{background:var(--color-bg-tertiary);border:2px dashed var(--color-surface-border);border-radius:var(--radius-md);padding:var(--space-6);text-align:center;font-size:var(--text-sm);color:var(--color-text-tertiary);outline:none}.editor-block--link{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--color-accent-soft);border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast)}.editor-block--link:hover{background:var(--color-accent-glow)}.editor-link__icon{font-size:var(--text-base)}.editor-link__name{font-weight:500;color:var(--color-text-accent)}.editor-link__target{font-size:var(--text-xs);color:var(--color-text-tertiary);margin-left:auto}.block-editor__add-hint{padding:var(--space-4) var(--space-3);color:var(--color-text-tertiary);font-size:var(--text-sm);cursor:pointer;opacity:.4;transition:opacity var(--transition-fast)}.block-editor__add-hint:hover{opacity:.8}.slash-menu{position:fixed;z-index:200;background:var(--color-bg-secondary);border:1px solid var(--color-surface-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:280px;max-height:320px;overflow-y:auto;animation:fadeIn var(--transition-fast) ease-out}.slash-menu__header{padding:var(--space-2) var(--space-3);border-bottom:1px solid var(--color-surface-border);font-size:var(--text-sm);color:var(--color-text-tertiary)}.slash-menu__filter{font-family:var(--font-mono)}.slash-menu__cursor{animation:pulse 1s infinite;color:var(--color-accent)}.slash-menu__items{padding:var(--space-1)}.slash-menu__item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast)}.slash-menu__item--selected,.slash-menu__item:hover{background:var(--color-bg-hover)}.slash-menu__item-icon{font-size:var(--text-lg);width:28px;text-align:center;flex-shrink:0}.slash-menu__item-label{font-size:var(--text-sm);font-weight:500}.slash-menu__item-desc{font-size:var(--text-xs);color:var(--color-text-tertiary)}.slash-menu__empty{padding:var(--space-4);text-align:center;color:var(--color-text-tertiary);font-size:var(--text-sm)}.link-menu__input{width:100%;background:transparent;border:none;font-size:var(--text-sm);color:var(--color-text-primary);padding:0}.link-menu__input:focus{box-shadow:none}.object-page{max-width:800px;margin:0 auto}.object-page__top-actions{display:flex;align-items:center;gap:var(--space-2);justify-content:flex-end;margin-bottom:var(--space-2)}.object-page__pin-btn{background:none;border:1px solid transparent;border-radius:var(--radius-md);padding:4px 8px;font-size:1rem;cursor:pointer;opacity:.4;transition:all .2s ease;filter:grayscale(100%)}.object-page__pin-btn:hover{opacity:.8;background:var(--color-bg-tertiary);filter:grayscale(0%)}.object-page__pin-btn--active{opacity:1;filter:grayscale(0%);transform:rotate(-45deg)}.object-page__header{display:flex;align-items:flex-start;gap:var(--space-4);margin-bottom:var(--space-6)}.object-page__icon{font-size:2.5rem;flex-shrink:0}.object-page__title-area{flex:1;min-width:0}.object-page__title{font-size:var(--text-2xl);font-weight:700;cursor:pointer;padding:var(--space-1) 0;border-bottom:2px solid transparent;transition:border-color var(--transition-fast)}.object-page__title:hover{border-color:var(--color-accent-soft)}.object-page__title-input{width:100%;font-size:var(--text-2xl);font-weight:700;background:var(--color-bg-tertiary);border-radius:var(--radius-md);padding:var(--space-1) var(--space-2)}.object-page__meta{display:flex;align-items:center;gap:var(--space-2);margin-top:var(--space-2)}.object-page__backlinks{margin-top:var(--space-8);padding:var(--space-5);background:var(--color-surface);border:1px solid var(--color-surface-border);border-radius:var(--radius-lg)}.dropdown-menu{position:absolute;background:var(--color-surface);border:1px solid var(--color-surface-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:1000;padding:var(--space-2);display:flex;flex-direction:column;gap:2px;min-width:220px}.dropdown-menu--sub{position:absolute;top:0;right:100%;margin-right:var(--space-2)}@media (max-width: 768px){.dropdown-menu--sub{position:relative;right:auto;top:auto;margin-right:0;margin-top:var(--space-1);width:100%;box-shadow:none;border:none;background:var(--color-bg-tertiary);border-radius:var(--radius-md);padding:var(--space-2)}}.dropdown-menu--scrollable{max-height:300px;overflow-y:auto}.dropdown-menu__header{font-size:var(--text-xs);font-weight:600;color:var(--color-text-tertiary);padding:var(--space-2) var(--space-3);letter-spacing:.02em}.dropdown-menu__divider{height:1px;background:var(--color-surface-border);margin:var(--space-2) 4px}.dropdown-menu__item{display:flex;align-items:center;gap:var(--space-3);width:100%;text-align:left;padding:var(--space-2) var(--space-3);background:transparent;border:none;border-radius:var(--radius-md);cursor:pointer;font-size:var(--text-sm);color:var(--color-text-primary);transition:background var(--transition-fast),color var(--transition-fast);box-sizing:border-box}.dropdown-menu__item:hover{background:var(--color-bg-hover)}.dropdown-menu__item--active{background:var(--color-surface-hover)}.dropdown-menu__item--danger{color:var(--color-danger)}.dropdown-menu__item--danger:hover{background:#ff6b6b1a}.dropdown-menu__item-icon{font-size:1.1rem;flex-shrink:0;display:flex;align-items:center;justify-content:center;width:24px}.object-list__header{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:var(--space-4);margin-bottom:var(--space-6)}.object-list__actions{display:flex;gap:var(--space-2);flex-wrap:wrap}.object-list__filters{display:flex;gap:var(--space-2);flex-wrap:wrap;margin-bottom:var(--space-5)}.btn--active{background:var(--color-accent-soft)!important;color:var(--color-text-accent)!important}.object-list__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:var(--space-4)}.object-card{background:var(--color-surface);border:1px solid var(--color-surface-border);border-radius:var(--radius-lg);padding:var(--space-4);cursor:pointer;transition:all var(--transition-base)}.object-card:hover{border-color:#ffffff1f;box-shadow:var(--shadow-md);transform:translateY(-1px)}.object-card__header{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-2)}.object-card__icon{font-size:var(--text-xl)}.object-card__checkbox{width:18px;height:18px;cursor:pointer;accent-color:var(--color-primary);flex-shrink:0}.object-card__type{font-size:var(--text-xs);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.04em}.object-card__fav{margin-left:auto}.object-card__name{font-weight:600;font-size:var(--text-sm);margin-bottom:var(--space-1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.object-card__name--done{text-decoration:line-through;opacity:.5}.object-card__snippet{font-size:var(--text-xs);color:var(--color-text-tertiary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.object-card__date{font-size:var(--text-xs);color:var(--color-text-tertiary);margin-top:var(--space-2)}.topbar__menu-btn{display:none;font-size:var(--text-xl);padding:var(--space-1) var(--space-2);border-radius:var(--radius-md);background:none;border:none;color:var(--color-text-primary);cursor:pointer}.sidebar-overlay{display:none}.set-builder{background:var(--color-surface);border:1px solid var(--color-surface-border);border-radius:var(--radius-lg);padding:var(--space-4);margin-bottom:var(--space-4)}.set-builder__chips{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-bottom:var(--space-3)}.set-chip{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);background:var(--color-primary);color:#fff;border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:500;white-space:nowrap}.set-chip__remove{background:none;border:none;color:#ffffffb3;cursor:pointer;font-size:1rem;padding:0 2px;line-height:1}.set-chip__remove:hover{color:#fff}.set-builder__row{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-bottom:var(--space-3)}.set-select,.set-search{padding:var(--space-2) var(--space-3);background:var(--color-bg-tertiary);border:1px solid var(--color-surface-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:var(--text-sm);min-width:0;flex:1;min-height:40px}.set-select{cursor:pointer;flex:0 1 auto;min-width:130px}.set-select option{background:var(--color-bg-primary);color:var(--color-text-primary)}.set-search{width:100%}.set-btn{min-height:40px;white-space:nowrap}.btn--active{background:var(--color-primary)!important;color:var(--color-text-inverse)}.pwa-toast{position:fixed;bottom:var(--space-6);right:var(--space-6);z-index:1000;background:var(--color-surface);border:1px solid var(--color-surface-border);border-radius:var(--radius-lg);padding:var(--space-4);box-shadow:var(--shadow-xl);display:flex;flex-direction:column;gap:var(--space-3);max-width:320px;animation:slideUp .3s cubic-bezier(.4,0,.2,1)}.pwa-toast__message{font-size:var(--text-sm);color:var(--color-text-primary);font-weight:500}.pwa-toast__actions{display:flex;gap:var(--space-2);justify-content:flex-end}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@media (max-width: 768px){.pwa-toast{bottom:var(--space-4);right:var(--space-4);left:var(--space-4);max-width:none}}.graph-page{display:flex;flex-direction:column;height:calc(100vh - 56px);overflow:hidden}.graph-filters{display:flex;flex-wrap:wrap;gap:var(--space-2);padding:var(--space-3) 0;flex-shrink:0}.graph-filter-btn{font-size:var(--text-xs);padding:var(--space-1) var(--space-3);white-space:nowrap}.graph-container{position:relative;flex:1;border-radius:var(--radius-lg);overflow:hidden;background:var(--color-bg-primary);border:1px solid var(--color-surface-border)}.graph-container canvas{display:block;width:100%;height:100%}.graph-toolbar{position:absolute;top:var(--space-3);right:var(--space-3);display:flex;flex-direction:column;gap:var(--space-1)}.graph-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--color-surface)!important;border:1px solid var(--color-surface-border)!important;border-radius:var(--radius-md)!important;font-size:1.1rem;font-weight:700}.graph-tooltip{position:absolute;padding:var(--space-1) var(--space-2);background:var(--color-surface);border:1px solid var(--color-surface-border);border-radius:var(--radius-md);font-size:var(--text-xs);color:var(--color-text-primary);pointer-events:none;transform:translate(-50%);white-space:nowrap;box-shadow:var(--shadow-lg);z-index:10}.graph-stats{position:absolute;bottom:var(--space-3);left:var(--space-3);font-size:var(--text-xs);color:var(--color-text-tertiary);background:var(--color-surface);padding:var(--space-1) var(--space-2);border-radius:var(--radius-md);border:1px solid var(--color-surface-border)}@media (max-width: 768px){.app-layout{flex-direction:column;height:100vh;height:100dvh;overflow:hidden}.space-rail-wrapper{display:none!important}.app-sidebar{position:fixed;left:-300px;top:0;z-index:100;width:280px;min-width:280px;height:100vh;height:100dvh;transition:left .3s cubic-bezier(.4,0,.2,1);box-shadow:var(--shadow-xl);background:var(--color-bg-secondary);overflow-y:auto;-webkit-overflow-scrolling:touch}.app-sidebar--open{left:0}.app-main{width:100vw;height:100%;min-width:0;flex:1;display:flex;flex-direction:column;overflow:hidden}.app-content{overflow-y:auto;-webkit-overflow-scrolling:touch;flex:1}.sidebar-overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:90}.topbar__menu-btn{display:flex;align-items:center}.app-content{padding:var(--space-4) var(--space-3)}.object-page__header{flex-direction:column;gap:var(--space-2)}.object-page__icon{font-size:2rem}.object-page__title,.object-page__title-input{font-size:var(--text-xl)}.object-list__grid{grid-template-columns:1fr}.object-list__header{flex-direction:column;align-items:flex-start}.object-list__actions{width:100%;overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch}.object-list__actions .btn{flex:0 0 auto;justify-content:center;min-width:0;white-space:nowrap}.widget-grid{grid-template-columns:1fr}.slash-menu{width:calc(100vw - var(--space-6));max-width:320px;left:var(--space-3)!important}.modal-content{width:95%;max-height:90vh;padding:var(--space-4)}.sidebar-nav__item{padding:var(--space-3) var(--space-3);min-height:44px}.btn{padding:var(--space-3) var(--space-4);min-height:44px}.editor-block{padding:var(--space-2);font-size:var(--text-base)}.editor-todo__checkbox{width:22px;height:22px}.block-editor{padding:0}.topbar{padding:0 var(--space-3);gap:var(--space-2)}.set-builder__row{flex-direction:column}.set-select{min-width:100%}.graph-page{height:calc(100dvh - 56px)}.graph-filters{overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch;padding-bottom:var(--space-2)}.graph-btn{width:44px;height:44px}}@media (max-width: 400px){.object-page__meta{flex-wrap:wrap}.editor-block--heading1{font-size:var(--text-2xl)}.editor-block--heading2{font-size:var(--text-xl)}.editor-block--heading3{font-size:var(--text-lg)}.object-list__actions .btn{font-size:var(--text-xs);padding:var(--space-2)}}
