*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--primary:#2563eb;--primary-hover:#1d4ed8;--bg:#eef2f7;--surface:#fff;--surface-2:#f8fafc;--border:#cbd5e1;--border-strong:#94a3b8;--text:#0f172a;--text-secondary:#475569;--accent:#3b82f6;--sidebar-bg:#111827;--sidebar-text:#9ca3af;--sidebar-text-active:#fff;--sidebar-hover:#1f2937;--sidebar-active:#2563eb;--sidebar-footer:#0d1117;--radius:8px;font-size:16px}[data-theme=dark]{--primary:#3b82f6;--primary-hover:#2563eb;--bg:#0d1117;--surface:#161b22;--surface-2:#1c2128;--border:#30363d;--border-strong:#484f58;--text:#e6edf3;--text-secondary:#8b949e;--accent:#58a6ff;--sidebar-bg:#0d1117;--sidebar-text:#8b949e;--sidebar-text-active:#e6edf3;--sidebar-hover:#1c2128;--sidebar-active:#1d4ed8;--sidebar-footer:#080c10}body{background:var(--bg);color:var(--text);height:100dvh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;transition:background .2s,color .2s;overflow:hidden}#root{flex-direction:column;height:100dvh;display:flex}button{cursor:pointer;border-radius:var(--radius);border:none;padding:8px 16px;font-family:inherit;font-size:14px;transition:background .15s,opacity .15s}button:disabled{opacity:.5;cursor:not-allowed}input,select,textarea{border:1.5px solid var(--border);border-radius:var(--radius);background:var(--surface);width:100%;color:var(--text);outline:none;padding:10px 12px;font-family:inherit;font-size:16px;transition:border-color .15s,background .2s}input:focus,select:focus,textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb, var(--accent) 15%, transparent)}.app{height:100dvh;display:flex;overflow:hidden}.sidebar{background:var(--sidebar-bg);flex-direction:column;flex-shrink:0;width:280px;transition:width .2s,transform .25s;display:flex;overflow:hidden}.sidebar-header{border-bottom:1px solid #1f2937;align-items:center;gap:10px;padding:18px 16px 14px;display:flex}.sidebar-title{color:var(--sidebar-text-active);letter-spacing:.3px;font-size:15px;font-weight:700}.sidebar-scroll{flex:1;padding:8px 0;overflow-y:auto}.sidebar-footer{background:var(--sidebar-footer);border-top:1px solid #1f2937;flex-direction:column;gap:0;display:flex}.btn-dark-toggle{color:var(--sidebar-text);min-height:unset;background:0 0;border:1px solid #374151;border-radius:6px;align-items:center;gap:7px;padding:6px 12px;font-size:12px;font-weight:500;transition:background .15s,color .15s,border-color .15s;display:flex}.btn-dark-toggle:hover{background:var(--sidebar-hover);color:var(--sidebar-text-active);border-color:#4b5563}.btn-dark-toggle-icon{font-size:14px}.sidebar-scroll::-webkit-scrollbar{width:4px}.sidebar-scroll::-webkit-scrollbar-thumb{background:#475569;border-radius:4px}.tree-row{cursor:pointer;color:var(--sidebar-text);-webkit-user-select:none;user-select:none;border-radius:0;align-items:center;gap:6px;padding:8px 12px;font-size:13px;transition:background .1s;display:flex}.tree-row:hover{background:var(--sidebar-hover)}.tree-row.active{background:var(--sidebar-active);color:var(--sidebar-text-active);font-weight:600}.tree-chevron{opacity:.6;flex-shrink:0;justify-content:center;align-items:center;width:16px;height:16px;transition:transform .15s;display:flex}.tree-chevron.open{transform:rotate(90deg)}.tree-chevron.hidden{visibility:hidden}.tree-icon{flex-shrink:0;font-size:14px}.tree-label{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.tree-badge{color:var(--sidebar-text);background:#334155;border-radius:10px;padding:1px 6px;font-size:10px}.tree-level-0 .tree-row{padding-left:12px}.tree-level-1 .tree-row{padding-left:28px}.tree-level-2 .tree-row{padding-left:44px}.tree-children{overflow:hidden}.tree-message{color:#64748b;padding:6px 12px 6px 44px;font-size:12px;font-style:italic}.main-content{flex-direction:column;flex:1;gap:20px;padding:24px;display:flex;overflow-y:auto}.content-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px 24px;box-shadow:0 1px 3px #0000000f}.content-title{color:var(--text);margin-bottom:4px;font-size:20px;font-weight:700}.content-subtitle{color:var(--text-secondary);margin-bottom:16px;font-size:13px}.detail-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;display:grid}.detail-item{flex-direction:column;gap:2px;display:flex}.detail-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:600}.detail-value{color:var(--text);font-size:14px;font-weight:500}.empty-state{color:var(--text-secondary);text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:12px;padding:60px 20px;display:flex}.empty-icon{font-size:56px}.empty-title{color:var(--text);font-size:18px;font-weight:600}.empty-desc{max-width:320px;font-size:14px;line-height:1.5}.system-view{flex-direction:column;gap:16px;display:flex}.system-banner{flex-direction:column;gap:6px;display:flex}.system-banner-title{color:var(--text);align-items:center;gap:8px;font-size:18px;font-weight:700;display:flex}.system-banner-code{color:var(--primary);background:color-mix(in srgb, var(--primary) 10%, transparent);border:1px solid color-mix(in srgb, var(--primary) 25%, transparent);border-radius:4px;padding:2px 8px;font-size:13px;font-weight:600}.system-banner-meta{color:var(--text-secondary);align-items:center;gap:8px;font-size:13px;display:flex}.device-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);transition:border-color .2s;overflow:hidden;box-shadow:0 1px 3px #0000000f}.device-section-header{border-bottom:1px solid var(--border);background:var(--surface-2);border-left:4px solid #0000;justify-content:space-between;align-items:center;padding:14px 18px;display:flex}.device-section-toggle{color:var(--text);text-align:left;cursor:pointer;min-height:unset;background:0 0;border:none;border-radius:0;flex:1;align-items:center;gap:8px;padding:0;font-size:15px;font-weight:700;display:flex}.device-section-toggle:hover{color:var(--primary);background:0 0}.device-section-title-text{flex:1}.device-icon{font-size:18px}.device-section-count{background:var(--primary);color:#fff;text-align:center;border-radius:10px;min-width:20px;padding:2px 7px;font-size:11px;font-weight:700}.device-section-spinner{color:var(--text-secondary);font-size:12px}.section-chevron{color:var(--text-secondary);font-size:14px;transition:transform .2s;display:inline-block}.section-chevron.open{transform:rotate(180deg)}.btn-add{background:var(--primary);color:#fff;border-radius:6px;align-items:center;gap:5px;min-height:36px;padding:7px 14px;font-size:13px;font-weight:600;display:flex}.btn-add:hover{background:var(--primary-hover)}.device-loading{color:var(--text-secondary);padding:12px 18px;font-size:13px;font-style:italic}.device-empty{color:var(--text-secondary);padding:16px 18px;font-size:13px;font-style:italic}.device-list{flex-direction:column;gap:0;display:flex}.saved-card{border-bottom:1px solid var(--border);background:var(--surface);transition:background .12s}.saved-card:last-child{border-bottom:none}.saved-card-header{align-items:center;gap:8px;min-height:44px;padding:11px 18px;display:flex}.saved-card-toggle{cursor:pointer;-webkit-user-select:none;user-select:none;flex:1;align-items:center;gap:8px;min-width:0;display:flex}.saved-card-toggle:hover .saved-code{color:var(--primary)}.saved-card-chevron{color:var(--text-secondary);opacity:.7;flex-shrink:0;justify-content:center;align-items:center;transition:transform .18s;display:flex}.saved-card-chevron.open{transform:rotate(90deg)}.saved-code{color:var(--text);flex-shrink:0;font-size:13px;font-weight:700;transition:color .12s}.saved-card-summary{color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-size:12px;overflow:hidden}.saved-card-actions{flex-shrink:0;align-items:center;gap:8px;display:flex}.btn-edit{color:var(--primary);border:1.5px solid var(--primary);min-height:unset;background:0 0;border-radius:5px;padding:3px 10px;font-size:11px;font-weight:600}.btn-edit:hover{background:color-mix(in srgb, var(--primary) 10%, transparent)}.saved-date{color:var(--text-secondary);white-space:nowrap;font-size:11px}.saved-card-body{border-top:1px dashed var(--border);flex-direction:column;gap:10px;margin:0 18px;padding:12px 18px 14px;display:flex}.saved-attr-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px 20px;display:grid}.saved-attr{flex-direction:column;gap:2px;display:flex}.saved-attr-label{letter-spacing:.5px;text-transform:uppercase;color:var(--text-secondary);font-size:10px;font-weight:700}.saved-attr-value{color:var(--text);font-size:13px;font-weight:500}.saved-notes{color:var(--text-secondary);font-size:13px;font-style:italic;line-height:1.4}.saved-fields{flex-wrap:wrap;gap:12px;display:flex}.saved-field{color:var(--text-secondary);font-size:13px}.draft-card{border-bottom:1px solid var(--border);background:color-mix(in srgb, var(--primary) 5%, var(--surface));border-left:3px solid var(--primary);flex-direction:column;gap:12px;padding:16px 18px;display:flex}.draft-card:last-child{border-bottom:none}.draft-card-title{color:var(--primary);text-transform:uppercase;letter-spacing:.5px;font-size:13px;font-weight:700}.form-row{flex-wrap:wrap;gap:12px;display:flex}.form-group{flex-direction:column;flex:1;gap:4px;min-width:140px;display:flex}.form-group--wide{flex:2;min-width:200px}.form-group label{color:var(--text-secondary);font-size:12px;font-weight:600}.checkbox-group{flex-direction:column;gap:8px;padding:8px 0 4px;display:flex}.checkbox-group .checkbox-label{color:var(--text);cursor:pointer;align-items:center;gap:8px;font-size:13px;font-weight:400;line-height:1.4;display:flex}.checkbox-group .checkbox-label input[type=checkbox]{cursor:pointer;width:15px;height:15px;accent-color:var(--primary);flex-shrink:0;margin:0}.draft-card-sections{flex-direction:column;gap:20px;display:flex}.form-section{flex-direction:column;gap:12px;display:flex}.form-section-header{color:var(--text-secondary);align-items:center;gap:7px;display:flex}.form-section-header:after{content:"";background:var(--border);flex:1;height:1px}.form-section-icon{color:var(--primary);flex-shrink:0;justify-content:center;align-items:center;display:flex}.form-section-title{letter-spacing:.8px;text-transform:uppercase;color:var(--text-secondary);white-space:nowrap;font-size:10px;font-weight:700}.form-grid{gap:12px;display:grid}.form-grid-3{grid-template-columns:repeat(3,1fr)}.form-grid-2{grid-template-columns:repeat(2,1fr)}.form-col-2{grid-column:span 2}.form-col-3{grid-column:span 3}.checkbox-inline-group{flex-wrap:wrap;align-items:center;gap:6px 20px;padding:7px 0 3px;display:flex}@media (width<=860px){.form-grid-3{grid-template-columns:repeat(2,1fr)}.form-col-2,.form-col-3{grid-column:span 2}}@media (width<=480px){.form-grid-3,.form-grid-2{grid-template-columns:1fr}.form-col-2,.form-col-3{grid-column:span 1}}.required{color:#ef4444}.card-error{color:#dc2626;background:#fef2f2;border:1px solid #fecaca;border-radius:6px;padding:8px 12px;font-size:13px}.card-actions{justify-content:flex-end;gap:8px;display:flex}.btn-ghost{color:var(--text-secondary);border:1.5px solid var(--border);background:0 0;min-height:38px}.btn-ghost:hover{background:var(--surface-2)}.btn-primary{background:var(--primary);color:#fff;min-width:80px;min-height:38px;font-weight:600}.btn-primary:hover:not(:disabled){background:var(--primary-hover)}.login-page{background-color:var(--bg);background-image:radial-gradient(circle, var(--border) 1px, transparent 1px);background-size:28px 28px;justify-content:center;align-items:center;height:100dvh;display:flex}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:18px;flex-direction:column;width:100%;max-width:380px;padding:40px 40px 32px;display:flex;box-shadow:0 8px 40px #0000001a,0 1px 4px #0000000f}.login-brand{align-items:center;gap:16px;margin-bottom:24px;display:flex}.login-brand-text{flex-direction:column;gap:3px;display:flex}.login-title{color:var(--text);font-size:22px;font-weight:800;line-height:1.2}.login-subtitle{color:var(--text-secondary);font-size:13px;line-height:1.4}.login-divider{background:var(--border);width:100%;height:1px}.login-action{flex-direction:column;align-items:center;gap:12px;padding:24px 0 20px;display:flex}.login-loading{color:var(--text-secondary);align-items:center;gap:10px;font-size:14px;display:flex}.login-spinner{border:2px solid var(--border);border-top-color:var(--primary);border-radius:50%;flex-shrink:0;width:18px;height:18px;animation:.75s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.login-error{color:#dc2626;text-align:center;background:#fef2f2;border:1px solid #fecaca;border-radius:6px;width:100%;padding:8px 12px;font-size:13px}.login-footer{color:var(--text-secondary);text-align:center;opacity:.6;border-top:1px solid var(--border);letter-spacing:.3px;padding-top:16px;font-size:11px}.sidebar-user{border-bottom:1px solid #1f2937;align-items:center;gap:8px;padding:10px 14px;display:flex}.sidebar-avatar{object-fit:cover;border-radius:50%;flex-shrink:0;width:32px;height:32px}.sidebar-avatar-fallback{background:var(--primary);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:14px;font-weight:700;display:flex}.sidebar-user-info{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.sidebar-user-name{color:var(--sidebar-text-active);white-space:nowrap;text-overflow:ellipsis;font-size:12px;font-weight:600;overflow:hidden}.sidebar-user-email{color:var(--sidebar-text);white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.sidebar-logout{color:var(--sidebar-text);min-height:unset;background:0 0;border:1px solid #374151;border-radius:5px;flex-shrink:0;padding:4px 8px;font-size:14px}.sidebar-logout:hover{color:#fff;background:#1f2937}.photo-strip{border-top:1px solid var(--border);margin-top:6px}.photo-toggle{width:100%;color:var(--text-secondary);text-align:left;background:0 0;border:none;border-radius:0;align-items:center;gap:6px;padding:8px 0;font-size:13px;font-weight:600;display:flex}.photo-toggle:hover{color:var(--primary);background:0 0}.photo-toggle-icon{font-size:15px}.photo-toggle-chevron{margin-left:auto;font-size:12px;transition:transform .15s;display:inline-block}.photo-toggle-chevron.open{transform:rotate(180deg)}.photo-strip-body{flex-direction:column;gap:10px;padding-bottom:10px;display:flex}.photo-loading{color:var(--text-secondary);font-size:12px;font-style:italic}.photo-grid{flex-wrap:wrap;gap:8px;display:flex}.photo-thumb-wrapper{flex-shrink:0;display:inline-block;position:relative}.photo-thumb-btn{border:2px solid var(--border);background:var(--bg);border-radius:6px;flex-shrink:0;width:72px;height:72px;padding:0;overflow:hidden}.photo-thumb-btn:hover{border-color:var(--primary)}.photo-thumb{object-fit:cover;width:100%;height:100%;display:block}.photo-delete-btn{color:#fff;cursor:pointer;z-index:1;background:#e53e3e;border:none;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;padding:0;font-size:10px;line-height:1;display:flex;position:absolute;top:-6px;right:-6px}.photo-delete-btn:hover{background:#c53030}.photo-thumb-name{color:var(--text-muted,#666);text-align:center;text-overflow:ellipsis;white-space:nowrap;width:72px;margin:4px 0 0;font-size:10px;font-weight:600;overflow:hidden}.photo-upload-row{align-items:center;display:flex}.photo-file-input{width:auto;display:none}.btn-photo-add{color:var(--primary);border:1.5px dashed var(--primary);cursor:pointer;background:0 0;border-radius:6px;align-items:center;gap:4px;padding:6px 14px;font-size:13px;font-weight:600;transition:background .15s;display:inline-flex}.btn-photo-add:hover{background:color-mix(in srgb, var(--primary) 10%, transparent)}.photo-pending{align-items:flex-start;gap:12px;display:flex}.photo-preview-item{flex-direction:column;align-items:center;gap:4px;display:flex}.photo-name-input{border:1px solid var(--border);background:var(--input-bg,#fff);width:80px;color:var(--text);text-align:center;border-radius:4px;padding:2px 4px;font-size:11px}.photo-preview{object-fit:cover;border:1px solid var(--border);border-radius:6px;flex-shrink:0;width:80px;height:80px}.photo-pending-controls{flex-direction:column;flex:1;gap:8px;display:flex}.photo-modal-overlay{z-index:1000;background:#000c;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.photo-modal-content{background:var(--surface);border-radius:var(--radius);flex-direction:column;max-width:90vw;max-height:90dvh;display:flex;position:relative;overflow:hidden}.photo-modal-close{color:#fff;z-index:1;background:#00000080;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;padding:0;font-size:14px;display:flex;position:absolute;top:8px;right:8px}.photo-modal-close:hover{background:#000000bf}.photo-modal-img{object-fit:contain;max-width:90vw;max-height:75dvh;display:block}.photo-modal-meta{flex-direction:column;gap:2px;padding:10px 16px 4px;display:flex}.photo-modal-name{color:var(--text);font-size:14px;font-weight:600}.photo-modal-caption{color:var(--text-secondary);font-size:13px}.photo-modal-date{color:var(--text-secondary);padding:2px 16px 12px;font-size:12px}.btn-photo-camera{color:#fff;background:var(--primary);cursor:pointer;border:none;border-radius:6px;align-items:center;gap:4px;padding:6px 14px;font-size:13px;font-weight:600;transition:background .15s;display:inline-flex}.btn-photo-camera:hover{background:var(--primary-hover)}.photo-upload-row{gap:8px}.mobile-topbar,.sidebar-backdrop{display:none}@media (width<=767px){.mobile-topbar{background:var(--sidebar-bg);z-index:200;border-bottom:1px solid #1f2937;flex-shrink:0;align-items:center;gap:12px;height:52px;padding:0 16px;display:flex;position:sticky;top:0}.mobile-topbar-title{color:#fff;text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:15px;font-weight:700;overflow:hidden}.mobile-hamburger{background:0 0;border:none;border-radius:6px;flex-direction:column;flex-shrink:0;justify-content:center;gap:5px;width:36px;height:36px;padding:6px;display:flex}.mobile-hamburger span{background:#fff;border-radius:2px;height:2px;display:block}.mobile-hamburger:hover{background:#1f2937}.sidebar{z-index:300;width:280px;height:100dvh;transition:transform .25s;position:fixed;top:0;left:0;transform:translate(-100%);box-shadow:4px 0 24px #0000004d}.sidebar.mobile-open{transform:translate(0)}.sidebar-backdrop{z-index:299;background:#00000080;display:block;position:fixed;inset:0}.app{flex-direction:column;padding-top:0}.main-content{gap:12px;padding:12px}.system-banner-title{flex-wrap:wrap;font-size:15px}.system-banner-meta{flex-wrap:wrap;font-size:12px}.device-section-header{padding:12px 14px}.device-section-toggle{font-size:14px}.saved-card-header{padding:10px 14px}.saved-card-body{margin:0 14px}.saved-attr-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}.draft-card{padding:14px}.form-row{gap:10px}.form-group,.form-group--wide{flex:calc(50% - 5px);min-width:calc(50% - 5px)}.photo-pending{flex-direction:column}.photo-preview{width:100%;height:160px}.photo-upload-row{flex-direction:column;align-items:stretch}.btn-photo-add,.btn-photo-camera{text-align:center;justify-content:center;padding:10px 14px;font-size:14px}.btn-add{min-height:40px}.btn-edit{min-height:32px;padding:5px 12px}.detail-grid{grid-template-columns:1fr 1fr}.content-card{padding:14px 16px}.login-card{padding:32px 24px}}.admin-panel{background:var(--bg);flex-direction:column;height:100dvh;display:flex;overflow:hidden}.admin-topbar{background:var(--sidebar-bg);border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:12px;height:56px;padding:0 20px;display:flex}.admin-back-btn{color:var(--sidebar-text);border:1px solid var(--border);border-radius:var(--radius);background:0 0;padding:6px 14px;font-size:13px;transition:color .15s,border-color .15s}.admin-back-btn:hover{color:var(--sidebar-text-active);border-color:var(--border-strong)}.admin-topbar-title{color:var(--sidebar-text-active);flex:1;font-size:15px;font-weight:600}.btn-dark-toggle.compact{color:var(--sidebar-text);border:1px solid var(--border);background:0 0;padding:6px 10px;font-size:13px}.btn-dark-toggle.compact:hover{color:var(--sidebar-text-active);border-color:var(--border-strong)}.admin-status-full{color:var(--text-secondary);flex:1;justify-content:center;align-items:center;font-size:14px;display:flex}.admin-status-error{color:#f87171}.admin-body{flex:1;display:flex;overflow:hidden}.admin-user-pane{border-right:1px solid var(--border);background:var(--surface);flex-direction:column;flex-shrink:0;width:300px;display:flex}.admin-pane-header{text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);border-bottom:1px solid var(--border);padding:14px 16px 10px;font-size:12px;font-weight:600}.admin-search-wrap{border-bottom:1px solid var(--border);padding:10px 12px}.admin-search{border:1.5px solid var(--border);border-radius:var(--radius);background:var(--surface-2);width:100%;color:var(--text);padding:7px 10px;font-size:13px}.admin-search:focus{border-color:var(--primary);outline:none}.admin-user-list{flex:1;padding:4px 0;overflow-y:auto}.admin-empty{color:var(--text-secondary);text-align:center;padding:20px 16px;font-size:13px}.admin-user-row{cursor:pointer;border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:10px 14px;transition:background .1s;display:flex}.admin-user-row:hover{background:var(--surface-2)}.admin-user-row.active{background:color-mix(in srgb, var(--primary) 12%, transparent)}.admin-avatar{object-fit:cover;border-radius:50%;flex-shrink:0;width:36px;height:36px}.admin-avatar-lg{object-fit:cover;border-radius:50%;flex-shrink:0;width:52px;height:52px}.admin-avatar-fallback{background:var(--primary);color:#fff;flex-shrink:0;justify-content:center;align-items:center;font-size:14px;font-weight:600;display:flex}.admin-avatar-fallback.admin-avatar{border-radius:50%;width:36px;height:36px}.admin-avatar-fallback.admin-avatar-lg{border-radius:50%;width:52px;height:52px;font-size:20px}.admin-user-meta{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.admin-user-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:500;overflow:hidden}.admin-user-email{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.admin-role-pill{background:color-mix(in srgb, var(--primary) 15%, transparent);color:var(--primary);white-space:nowrap;border-radius:20px;flex-shrink:0;padding:2px 7px;font-size:10px;font-weight:600}.admin-detail-pane{flex-direction:column;flex:1;gap:24px;padding:24px;display:flex;overflow-y:auto}.admin-detail-empty{color:var(--text-secondary);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:12px;font-size:14px;display:flex}.admin-detail-empty-icon{font-size:40px}.admin-detail-header{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);align-items:center;gap:16px;padding:20px;display:flex}.admin-detail-name{color:var(--text);font-size:18px;font-weight:600}.admin-detail-email{color:var(--text-secondary);margin-top:2px;font-size:13px}.admin-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.admin-section-title{text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);border-bottom:1px solid var(--border);background:var(--surface-2);padding:12px 16px;font-size:12px;font-weight:600}.admin-table{border-collapse:collapse;width:100%;font-size:13px}.admin-table th{text-align:left;text-transform:uppercase;letter-spacing:.04em;color:var(--text-secondary);background:var(--surface-2);border-bottom:1px solid var(--border);padding:8px 14px;font-size:11px;font-weight:600}.admin-table td{border-bottom:1px solid var(--border);color:var(--text);padding:10px 14px}.admin-table tr:last-child td{border-bottom:none}.admin-table tr:hover td{background:var(--surface-2)}.admin-scope-type{color:var(--text-secondary);background:var(--surface-2);border:1px solid var(--border);border-radius:4px;padding:2px 7px;font-size:11px;font-weight:500}.admin-remove-btn{color:#f87171;border-radius:var(--radius);background:0 0;border:1px solid #f87171;padding:4px 10px;font-size:11px;transition:background .15s,color .15s}.admin-remove-btn:hover:not(:disabled){color:#fff;background:#f87171}.admin-remove-btn:disabled{opacity:.5}.admin-grant-form{padding:14px 16px}.admin-grant-row{flex-wrap:wrap;align-items:flex-end;gap:10px;display:flex}.admin-grant-row select{flex:1;min-width:160px;padding:8px 10px;font-size:13px}.admin-grant-row .btn-primary{flex-shrink:0;padding:8px 20px;font-size:13px}.admin-error-inline{color:#f87171;margin-top:8px;font-size:12px}.sidebar-footer-btn{width:100%;color:var(--sidebar-text);text-align:left;min-height:unset;background:0 0;border:1px solid #374151;border-radius:6px;align-items:center;gap:7px;padding:7px 12px;font-size:12px;font-weight:500;transition:background .15s,color .15s,border-color .15s;display:flex}.sidebar-footer-btn:hover{background:var(--sidebar-hover);color:var(--sidebar-text-active);border-color:#4b5563}@media (width<=480px){.form-row{flex-direction:column;gap:10px}.form-group,.form-group--wide{flex:100%;min-width:100%}}@media (width<=640px){.admin-body{flex-direction:column}.admin-user-pane{border-right:none;border-bottom:1px solid var(--border);width:100%;height:220px}.admin-detail-pane{gap:14px;padding:14px}.admin-grant-row{flex-direction:column}.admin-grant-row select{min-width:unset;width:100%}}.sidebar-header-icon{color:var(--primary);flex-shrink:0;justify-content:center;align-items:center;display:flex}.tree-count{color:#60a5fa;background:#1e3a5f;border-radius:10px;flex-shrink:0;padding:1px 6px;font-size:10px;font-weight:600}.tree-row.active .tree-count{color:#fff;background:#fff3}.device-section-header{border-left-color:var(--primary)}.breadcrumb{flex-wrap:wrap;align-items:center;gap:4px;font-size:13px;display:flex}.breadcrumb-item{color:var(--text-secondary);align-items:center;gap:4px;display:flex}.breadcrumb-sep{color:var(--border-strong);font-size:14px;line-height:1}.breadcrumb-current{color:var(--text);font-weight:600}.system-banner .system-banner-code{margin-left:8px}.empty-illustration{opacity:.85;justify-content:center;align-items:center;margin-bottom:4px;display:flex}.detail-card{flex-direction:column;gap:16px;display:flex}.detail-card-header{align-items:center;gap:14px;display:flex}.detail-card-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;display:flex}.detail-card-icon--project{color:#f59e0b;background:#f59e0b26}.detail-card-icon--site{background:color-mix(in srgb, var(--primary) 15%, transparent);color:var(--primary)}.detail-type-badge{letter-spacing:.5px;text-transform:uppercase;background:color-mix(in srgb, var(--primary) 12%, transparent);color:var(--primary);border-radius:4px;align-items:center;margin-right:8px;padding:2px 7px;font-size:10px;font-weight:700;display:inline-flex}.detail-card-header .content-subtitle{align-items:center;margin-bottom:0;display:flex}.sidebar-search{background:#0d1117;border-bottom:1px solid #1f2937;align-items:center;gap:7px;padding:8px 12px;display:flex}.sidebar-search-icon{color:#4b5563;flex-shrink:0;align-items:center;display:flex}.sidebar-search-input{color:var(--sidebar-text-active);width:100%;box-shadow:none;background:0 0;border:none;border-radius:0;outline:none;flex:1;padding:0;font-size:12px}.sidebar-search-input::placeholder{color:#4b5563}.sidebar-search-input:focus{box-shadow:none;border-color:#0000}.sidebar-search-clear{color:#6b7280;min-height:unset;background:0 0;border:none;border-radius:3px;flex-shrink:0;padding:1px 4px;font-size:12px;line-height:1}.sidebar-search-clear:hover{color:var(--sidebar-text-active);background:#1f2937}.tree-project{margin-bottom:4px}.tree-project-header{align-items:center;gap:6px;margin-top:4px;padding:10px 12px 5px;display:flex}.tree-project-icon{color:#f59e0b;opacity:.9;flex-shrink:0;align-items:center;display:flex}.tree-project-name{letter-spacing:.7px;text-transform:uppercase;color:#6b7280;white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:10px;font-weight:700;overflow:hidden}.tree-project .tree-badge{color:#6b7280;background:#1a2332;font-size:9px}.tree-device-strip{align-items:center;gap:2px;padding:3px 12px 5px 56px;display:flex}.tree-device-btn{color:#6b7280;width:26px;height:26px;min-height:unset;background:0 0;border:none;border-radius:5px;flex-shrink:0;justify-content:center;align-items:center;padding:0;transition:background .12s,color .12s;display:flex}.tree-device-btn:hover{color:var(--sidebar-text-active);background:#1f2937}.tree-device-btn.active{background:var(--sidebar-active);color:#fff}.sidebar-footer-controls{flex-direction:column;gap:4px;padding:8px 10px;display:flex}
