@import "https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;600&family=Manrope:wght@400;500;600;700&display=swap";
*{box-sizing:border-box;margin:0;padding:0}:root{--bg-primary:#0a0d12;--bg-secondary:#12161e;--bg-tertiary:#1a1f2a;--bg-hover:#232936;--border:#252b38;--border-light:#2d3545;--text-primary:#f0f2f7;--text-secondary:#a0a8b8;--text-muted:#5c6575;--accent:#3b82f6;--accent-hover:#2563eb;--accent-glow:#3b82f633;--danger:#ef4444;--danger-hover:#dc2626;--success:#22c55e;--warning:#f59e0b;--sidebar-width:260px}html,body{height:100%}body{background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;font-family:Manrope,system-ui,sans-serif;line-height:1.5}.login-page{background:radial-gradient(ellipse at 50% 0%,var(--bg-tertiary)0%,var(--bg-primary)60%);justify-content:center;align-items:center;min-height:100vh;padding:1.5rem;display:flex}.login-card{background:var(--bg-secondary);border:1px solid var(--border);text-align:center;border-radius:20px;width:100%;max-width:400px;padding:2.5rem}.login-brand{margin-bottom:1.5rem}.login-logo{color:var(--accent);margin-bottom:.5rem;font-size:3rem;display:block}.login-card h1{letter-spacing:-.02em;font-size:1.75rem;font-weight:700}.login-desc{color:var(--text-secondary);margin-bottom:2rem;font-size:.95rem;line-height:1.6}.login-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:12px;width:100%;padding:1rem;font-size:1rem;font-weight:600;transition:all .15s}.login-btn:hover:not(:disabled){background:var(--accent-hover);box-shadow:0 8px 30px var(--accent-glow);transform:translateY(-1px)}.login-btn:disabled{opacity:.6;cursor:not-allowed}.login-hint{color:var(--text-muted);margin-top:1.5rem;font-size:.85rem}.login-warning{color:var(--danger);background:#ef44441a;border-radius:8px;margin-top:1rem;padding:.75rem;font-size:.85rem}.app-layout{min-height:100vh;display:flex}.mobile-header{background:var(--bg-secondary);border-bottom:1px solid var(--border);z-index:100;justify-content:space-between;align-items:center;height:56px;padding:0 1rem;display:none;position:fixed;top:0;left:0;right:0}.menu-toggle{width:40px;height:40px;color:var(--text-primary);cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;font-size:1.25rem;display:flex}.menu-toggle:hover{background:var(--bg-hover)}.mobile-title{align-items:center;gap:.5rem;font-weight:600;display:flex}.mobile-title .logo{color:var(--accent);font-size:1.25rem}.status-dot{border-radius:50%;width:10px;height:10px}.status-dot.connected{background:var(--success);box-shadow:0 0 8px var(--success)}.status-dot.disconnected{background:var(--warning)}.sidebar{width:var(--sidebar-width);background:var(--bg-secondary);border-right:1px solid var(--border);z-index:200;flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-header{border-bottom:1px solid var(--border);padding:1.5rem}.brand{align-items:center;gap:.75rem;margin-bottom:.75rem;display:flex}.brand .logo{color:var(--accent);font-size:1.5rem}.brand-name{letter-spacing:-.02em;font-size:1.25rem;font-weight:700}.status-indicator{border-radius:6px;width:fit-content;padding:.35rem .6rem;font-size:.75rem;font-weight:500}.status-indicator.connected{color:var(--success);background:#22c55e26}.status-indicator.disconnected{color:var(--warning);background:#f59e0b26}.sidebar-nav{flex-direction:column;flex:1;gap:.25rem;padding:1rem .75rem;display:flex}.nav-item{color:var(--text-secondary);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:10px;align-items:center;gap:.75rem;width:100%;padding:.75rem 1rem;font-size:.95rem;font-weight:500;transition:all .15s;display:flex}.nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-item.active{background:var(--accent);color:#fff}.nav-icon{text-align:center;width:24px;font-size:1.1rem}.sidebar-footer{border-top:1px solid var(--border);padding:1rem .75rem}.entity-info{background:var(--bg-tertiary);border-radius:10px;margin-bottom:.75rem;padding:.75rem 1rem}.entity-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:.25rem;font-size:.7rem;display:block}.entity-id{color:var(--text-secondary);font-family:JetBrains Mono,monospace;font-size:.85rem}.copyable-entity-id{border-radius:4px;margin:-.125rem -.25rem;padding:.125rem .25rem;font-family:JetBrains Mono,monospace;transition:all .15s}.copyable-entity-id:hover{background:var(--bg-hover);color:var(--accent)}.copyable-entity-id.copied{background:var(--success);color:#fff}.logout-btn{border:1px solid var(--border);width:100%;color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:10px;padding:.75rem;font-size:.9rem;font-weight:500;transition:all .15s}.logout-btn:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-light)}.sidebar-overlay{display:none}.main-content{margin-left:var(--sidebar-width);flex:1;max-width:800px;padding:2rem}.section{animation:.2s fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.section-header{align-items:center;gap:.75rem;margin-bottom:.5rem;display:flex}.section-header h2{letter-spacing:-.02em;font-size:1.5rem;font-weight:700}.badge{background:var(--bg-tertiary);color:var(--text-secondary);border-radius:6px;padding:.25rem .6rem;font-size:.8rem;font-weight:600}.section-desc{color:var(--text-secondary);margin-bottom:2rem;font-size:.95rem}.subsection{border-top:1px solid var(--border);margin-top:2rem;padding-top:1.5rem}.subsection:first-of-type{border-top:none;margin-top:0;padding-top:0}.subsection h3{color:var(--text-primary);margin-bottom:.5rem;font-size:1rem;font-weight:600}.subsection-desc{color:var(--text-muted);margin-bottom:1rem;font-size:.9rem}input,select{background:var(--bg-tertiary);border:1px solid var(--border);width:100%;color:var(--text-primary);border-radius:10px;padding:.75rem 1rem;font-family:inherit;font-size:.95rem;transition:all .15s}input:focus,select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow);outline:none}input::placeholder{color:var(--text-muted)}input:disabled,select:disabled{opacity:.5;cursor:not-allowed}.input-small{max-width:150px}button{background:var(--accent);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:10px;padding:.75rem 1.25rem;font-family:inherit;font-size:.95rem;font-weight:600;transition:all .15s}button:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-1px)}button:disabled{opacity:.6;cursor:not-allowed}button.small{border-radius:8px;padding:.5rem .75rem;font-size:.85rem}button.secondary{background:var(--bg-tertiary);color:var(--text-secondary)}button.secondary:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary)}button.danger{background:var(--danger)}button.danger:hover:not(:disabled){background:var(--danger-hover)}.add-property-form{gap:.75rem;margin-bottom:1.5rem;display:flex}.add-property-form input:first-child{flex:none;width:150px}.add-property-form input:nth-child(2){flex:1}.property-list{flex-direction:column;gap:.5rem;list-style:none;display:flex}.property-item{background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;align-items:center;gap:.75rem;padding:1rem;transition:all .15s;display:flex}.property-item:hover{border-color:var(--border-light)}.property-content{cursor:pointer;flex-direction:column;flex:1;gap:.25rem;display:flex}.property-key{color:var(--text-primary);font-size:.95rem;font-weight:600}.property-value{color:var(--text-secondary);word-break:break-all;font-family:JetBrains Mono,monospace;font-size:.9rem}.property-value .empty{color:var(--text-muted);font-style:italic}.property-edit{flex-direction:column;flex:1;gap:.75rem;display:flex}.property-edit input{flex:1}.property-actions{gap:.5rem;display:flex}.share-form{gap:.75rem;margin-bottom:1rem;display:flex}.share-form select,.share-form input{flex:1}.share-code-box,.invite-code-box{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:12px;flex-direction:column;gap:.5rem;padding:1rem;display:flex}.share-code-label,.invite-code-label{color:var(--text-muted);font-size:.85rem}.share-code,.invite-code{color:var(--accent);letter-spacing:.05em;font-family:JetBrains Mono,monospace;font-size:1.25rem;font-weight:600}.share-code-expires,.invite-code-expires{color:var(--text-muted);font-size:.8rem}.share-list{flex-direction:column;gap:.5rem;list-style:none;display:flex}.share-item{background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;justify-content:space-between;align-items:center;gap:1rem;padding:1rem;display:flex}.share-info{flex-direction:column;gap:.25rem;display:flex}.share-source,.share-target{color:var(--text-muted);font-family:JetBrains Mono,monospace;font-size:.8rem}.share-property{color:var(--text-primary);font-weight:600}.share-value{color:var(--success);font-family:JetBrains Mono,monospace;font-size:.9rem}.share-list.incoming .share-item{background:#22c55e0d;border-color:#22c55e33}.link-form{gap:.75rem;display:flex}.link-form input{flex:1}.info-grid{background:var(--bg-tertiary);border-radius:12px;gap:.25rem;padding:1rem;display:grid}.info-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-size:.8rem}.info-value{color:var(--text-secondary);word-break:break-all;font-family:JetBrains Mono,monospace;font-size:.9rem}.danger-zone{background:#ef44440d;border:1px solid #ef444433;border-radius:12px;margin-top:2rem;padding:1.5rem}.danger-zone h3{color:var(--danger)}.empty-state{text-align:center;color:var(--text-muted);padding:3rem 1.5rem}.empty-icon{opacity:.4;margin-bottom:1rem;font-size:2.5rem;display:block}.empty-state p{margin-bottom:.5rem;font-size:1rem}.empty-hint{font-size:.85rem}@media (max-width:768px){.mobile-header{display:flex}.sidebar{transition:transform .25s;transform:translate(-100%)}.sidebar.open{transform:translate(0)}.sidebar-overlay{z-index:150;background:#0009;display:block;position:fixed;inset:0}.main-content{margin-top:56px;margin-left:0;padding:1.25rem}.add-property-form{flex-direction:column}.add-property-form input:first-child{width:100%}.share-form,.link-form{flex-direction:column}.property-item{flex-direction:column;align-items:stretch}.property-item>button{align-self:flex-end;margin-top:.5rem}}@media (min-width:769px) and (max-width:1024px){:root{--sidebar-width:220px}}
