@import"https://fonts.googleapis.com/css2?family=Hanken+Grotesk:wght@400;500;600;700;800&family=Geist:wght@400;500;600;700&family=Space+Grotesk:wght@400;500;600;700&family=DM+Sans:opsz,wght@9..40,400;9..40,500;9..40,600;9..40,700&family=Newsreader:opsz,wght@6..72,400;6..72,500;6..72,600;6..72,700&display=swap";*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app-root{--bg: #f7f4ee;--bg-2: #efe9df;--surface: #ffffff;--surface-2: #f6f2ec;--surface-3: #efe9e0;--border: #e7ded0;--border-strong: #d8ccb8;--text: #27241c;--text-muted: #6b6354;--text-faint: #9a917f;--accent: #3d7a1e;--accent-fg: #ffffff;--ok: #1f9d57;--warn: #c47d10;--danger: #d23b3b;--radius: 22px;--radius-sm: 17px;--radius-lg: 28px;--font: "Hanken Grotesk", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;--font-display: "Hanken Grotesk", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;--ring: color-mix(in srgb, var(--accent) 38%, transparent);--accent-soft: color-mix(in srgb, var(--accent) 14%, var(--surface));--accent-soft-2: color-mix(in srgb, var(--accent) 22%, var(--surface));--accent-border: color-mix(in srgb, var(--accent) 42%, var(--border));--ok-soft: color-mix(in srgb, var(--ok) 16%, var(--surface));--warn-soft: color-mix(in srgb, var(--warn) 18%, var(--surface));--danger-soft: color-mix(in srgb, var(--danger) 16%, var(--surface));--shadow-sm: 0 1px 2px rgba(20,20,30,.06);--shadow: 0 1px 3px rgba(20,20,30,.06), 0 8px 24px -12px rgba(20,20,30,.12);--shadow-lg: 0 12px 40px -8px rgba(20,20,30,.22);--sidebar-w: 252px;font-family:var(--font);font-size:var(--fs);color:var(--text);background:var(--bg);line-height:1.5;height:100%;position:relative}.app-root[data-mode=dark]{--bg: #14130f;--bg-2: #100f0b;--surface: #1d1b15;--surface-2: #26241c;--surface-3: #2f2c22;--border: #322e24;--border-strong: #433d2f;--text: #f1ede3;--text-muted: #a99f8c;--text-faint: #7d7464;--accent: #7cc746;--accent-fg: #1a1a1a;--ok: #34d27b;--warn: #f0b429;--danger: #f87171;--shadow: 0 1px 3px rgba(0,0,0,.4), 0 10px 30px -12px rgba(0,0,0,.6);--shadow-lg: 0 16px 48px -8px rgba(0,0,0,.7);--shadow-sm: 0 1px 2px rgba(0,0,0,.4)}.app-root[data-density=regular]{--fs: 14.5px;--pad: 24px;--gap: 18px;--card-pad: 20px;--ctl-h: 38px;--tpad: 12px 16px;--rpad: 13px 16px}.app-root[data-density=compact]{--fs: 13.5px;--pad: 18px;--gap: 12px;--card-pad: 15px;--ctl-h: 33px;--tpad: 8px 13px;--rpad: 10px 13px}.app-root[data-density=comfy]{--fs: 15.5px;--pad: 32px;--gap: 24px;--card-pad: 26px;--ctl-h: 42px;--tpad: 15px 18px;--rpad: 16px 18px}h1,h2,h3,h4{font-family:var(--font-display);font-weight:600;line-height:1.2;letter-spacing:-.01em;color:var(--text)}code,.code-chip{font-family:ui-monospace,SFMono-Regular,Menlo,monospace}button{font-family:inherit}.app-root{height:100%;display:block}.app-root:before{content:"";position:fixed;inset:0;z-index:-1;background:linear-gradient(160deg,var(--bg) 0%,var(--bg-2) 100%)}.layout-topnav{display:flex;flex-direction:column;height:100%}.main{display:flex;flex-direction:column;min-width:0;height:100%;overflow:hidden}.content{flex:1;overflow-y:auto;padding:var(--pad)}.sidebar-brand{display:flex;align-items:center;gap:11px;padding:18px 18px 16px}.sidebar-brand.inline{padding:0}.brand-home{border:none;background:none;cursor:pointer;color:inherit;flex-shrink:0}.brand-home:hover .brand-mark{filter:brightness(1.05)}.brand-mark{width:38px;height:38px;border-radius:var(--radius-sm);display:grid;place-items:center;color:var(--accent);background:var(--accent-soft);flex-shrink:0}.brand-text{display:flex;flex-direction:column;line-height:1.15}.brand-name{font-family:var(--font-display);font-weight:700;font-size:1.02rem;letter-spacing:-.02em;white-space:nowrap}.brand-sub{font-size:.72rem;color:var(--text-faint)}.topnav{border-bottom:1px solid var(--border);background:color-mix(in srgb,var(--surface) 70%,var(--bg))}.topnav-bar{display:flex;align-items:center;gap:28px;padding:12px var(--pad)}.topnav-bar .topbar-right{margin-left:auto}.topnav-primary{display:flex;gap:4px}.topnav-link{border:none;background:none;color:var(--text-muted);padding:8px 14px;border-radius:var(--radius-sm);cursor:pointer;font-size:.92rem;font-weight:600}.topnav-link:hover{background:var(--surface-3);color:var(--text)}.topnav-link.on{background:var(--accent-soft);color:var(--accent)}.topnav-sub{display:flex;gap:2px;padding:4px var(--pad) 0;border-top:1px solid var(--border);overflow-x:auto}.subnav-link{display:flex;align-items:center;gap:7px;border:none;background:none;color:var(--text-muted);padding:11px 12px;cursor:pointer;font-size:.85rem;font-weight:500;border-bottom:2px solid transparent;white-space:nowrap}.subnav-link:hover{color:var(--text)}.subnav-link.on{color:var(--accent);border-bottom-color:var(--accent)}.layout-topnav .content{padding:var(--pad)}.topbar-right{display:flex;align-items:center;gap:8px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;height:var(--ctl-h);padding:0 15px;border-radius:var(--radius-sm);border:1px solid transparent;font-size:.88rem;font-weight:600;cursor:pointer;transition:all .13s;white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-lg{height:calc(var(--ctl-h) + 8px);font-size:.95rem;padding:0 20px}.btn-sm{height:calc(var(--ctl-h) - 6px);padding:0 10px;font-size:.82rem}.btn-block{width:100%}.btn-primary{background:var(--accent);color:var(--accent-fg);box-shadow:var(--shadow-sm)}.btn-primary:hover:not(:disabled){filter:brightness(1.07);box-shadow:var(--shadow)}.btn-secondary{background:var(--surface);color:var(--text);border-color:var(--border-strong)}.btn-secondary:hover:not(:disabled){background:var(--surface-2)}.btn-ghost{background:none;color:var(--text-muted)}.btn-ghost:hover:not(:disabled){background:var(--surface-3);color:var(--text)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){filter:brightness(1.06)}.btn-danger-ghost{color:var(--danger)}.btn-danger-ghost:hover:not(:disabled){background:var(--danger-soft)}.icon-btn{display:inline-grid;place-items:center;width:34px;height:34px;border:none;background:none;color:var(--text-muted);border-radius:var(--radius-sm);cursor:pointer;transition:all .12s}.icon-btn:hover{background:var(--surface-3);color:var(--text)}.icon-btn-danger:hover{background:var(--danger-soft);color:var(--danger)}.input{width:100%;height:var(--ctl-h);padding:0 13px;border:1px solid var(--border-strong);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);font-size:.9rem;font-family:inherit;transition:border-color .12s,box-shadow .12s}textarea.input{height:auto;padding:10px 13px}.input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--ring)}.input::placeholder{color:var(--text-faint)}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}.field-label{font-size:.82rem;font-weight:600;color:var(--text)}.field-hint{font-size:.78rem;color:var(--text-faint)}.select-wrap{position:relative}.select-wrap select{appearance:none;padding-right:36px;cursor:pointer}.select-chev{position:absolute;right:11px;top:50%;transform:translateY(-50%);color:var(--text-faint);pointer-events:none}.form-2col{display:grid;grid-template-columns:1fr 1fr;gap:0 14px}.page{max-width:1180px;margin:0 auto;display:flex;flex-direction:column;gap:var(--gap)}.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;flex-wrap:wrap}.page-title{font-size:1.7rem;font-weight:700}.page-desc{color:var(--text-muted);margin-top:4px;font-size:.95rem}.page-actions{display:flex;gap:8px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}.section-card{padding:var(--card-pad);display:flex;flex-direction:column;gap:4px}.section-card .field:last-child,.section-card .btn{margin-bottom:0}.card-head{margin-bottom:12px}.card-head h3{font-size:1.02rem}.card-sub{font-size:.85rem;color:var(--text-muted);margin-top:2px}.list-card{padding:var(--card-pad)}.list-card .card-head{margin-bottom:6px}.table-card{overflow:hidden}.split{display:grid;grid-template-columns:1fr 1fr;gap:var(--gap);align-items:start}.stat-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:var(--gap)}.stat{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:var(--card-pad);display:flex;flex-direction:column;gap:3px;box-shadow:var(--shadow-sm)}.stat-value{font-family:var(--font-display);font-size:1.5rem;font-weight:700}.stat-label{font-size:.82rem;color:var(--text-muted)}.stat-sub{font-size:.72rem;color:var(--text-faint)}.list{display:flex;flex-direction:column}.list-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:var(--rpad);border-radius:var(--radius-sm)}.list-row+.list-row{border-top:1px solid var(--border)}.list-row.compact{padding:9px 4px}.list-row.row-dim{opacity:.55}.list-lead{display:flex;align-items:center;gap:12px;min-width:0}.list-text{display:flex;flex-direction:column;min-width:0}.list-title{font-weight:600;font-size:.92rem;display:flex;align-items:center;gap:8px}.list-sub{font-size:.8rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.list-trail{display:flex;align-items:center;gap:10px}.row-icon{width:36px;height:36px;border-radius:var(--radius-sm);background:var(--surface-3);color:var(--text-muted);display:grid;place-items:center;flex-shrink:0}.data-table{width:100%;border-collapse:collapse;font-size:.88rem}.data-table thead th{text-align:left;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-faint);padding:11px 16px;border-bottom:1px solid var(--border);background:var(--surface-2);white-space:nowrap}.data-table tbody td{padding:var(--tpad);border-bottom:1px solid var(--border);vertical-align:middle}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr.row-click{cursor:pointer}.data-table tbody tr.row-click:hover,.data-table tbody tr:hover{background:color-mix(in srgb,var(--accent) 5%,transparent)}.data-table tr.row-dim{opacity:.5}.cell-strong{font-weight:600;color:var(--text)}.cell-muted{color:var(--text-muted);white-space:nowrap}.cell-warn{color:var(--warn);font-weight:600}.cell-actions{display:flex;gap:4px;justify-content:flex-end;align-items:center}.user-cell{display:flex;align-items:center;gap:10px}.user-cell .cell-strong{white-space:nowrap}.code-chip{font-size:.82rem;background:var(--surface-3);color:var(--text-muted);padding:2px 7px;border-radius:5px}.badge-row{display:flex;gap:5px;flex-wrap:wrap}.log-date{color:var(--text-faint);font-size:.8rem}.matrix-table thead th.matrix-user,.matrix-table .matrix-cell{text-align:center}.matrix-user-inner{display:flex;flex-direction:column;align-items:center;gap:4px}.matrix-user-inner span{font-size:.72rem;color:var(--text-muted);text-transform:none;letter-spacing:0;font-weight:500}.matrix-check{width:26px;height:26px;border-radius:7px;border:1.5px solid var(--border-strong);background:var(--surface);color:var(--accent-fg);display:grid;place-items:center;cursor:pointer;transition:all .12s}.matrix-check.on{background:var(--accent);border-color:var(--accent)}.svc-mini{width:30px;height:30px;border-radius:8px;display:grid;place-items:center;font-size:15px;flex-shrink:0}.svc-mini.lg{width:38px;height:38px;font-size:19px}.badge{display:inline-flex;align-items:center;gap:4px;font-size:.72rem;font-weight:600;padding:2px 8px;border-radius:999px;line-height:1.5;white-space:nowrap}.badge-neutral{background:var(--surface-3);color:var(--text-muted)}.badge-accent{background:var(--accent-soft);color:var(--accent)}.badge-ok{background:var(--ok-soft);color:var(--ok)}.badge-warn{background:var(--warn-soft);color:var(--warn)}.badge-danger{background:var(--danger-soft);color:var(--danger)}.status-dot{width:9px;height:9px;border-radius:50%;display:inline-block;flex-shrink:0}.status-dot.pulse{box-shadow:0 0 color-mix(in srgb,var(--ok) 60%,transparent);animation:dotpulse 2s infinite}@keyframes dotpulse{0%{box-shadow:0 0 color-mix(in srgb,var(--ok) 55%,transparent)}70%{box-shadow:0 0 0 6px transparent}to{box-shadow:0 0 0 0 transparent}}.ui-toggle{position:relative;width:40px;height:23px;border:none;border-radius:999px;background:var(--surface-3);cursor:pointer;transition:background .15s;flex-shrink:0;box-shadow:inset 0 0 0 1px var(--border)}.ui-toggle[data-on="1"]{background:var(--accent);box-shadow:none}.ui-toggle i{position:absolute;top:2px;left:2px;width:19px;height:19px;border-radius:50%;background:#fff;box-shadow:0 1px 3px #0000004d;transition:transform .15s}.ui-toggle[data-on="1"] i{transform:translate(17px)}.switch-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:4px 0 16px;font-size:.88rem;font-weight:500}.modal-overlay{position:fixed;inset:0;z-index:1000;background:#0f121973;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;padding:24px;animation:fade .15s ease}@keyframes fade{0%{opacity:0}}.modal{width:100%;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);max-height:88vh;display:flex;flex-direction:column;animation:pop .18s cubic-bezier(.3,.7,.4,1)}@keyframes pop{0%{opacity:0;transform:translateY(8px) scale(.98)}}.modal-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:18px 20px;border-bottom:1px solid var(--border)}.modal-title{font-size:1.12rem}.modal-sub{font-size:.85rem;color:var(--text-muted);margin-top:3px}.modal-body{padding:20px;overflow-y:auto}.modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:14px 20px;border-top:1px solid var(--border)}.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:18px}.detail-grid>div{display:flex;flex-direction:column;gap:2px}.detail-k{font-size:.76rem;color:var(--text-faint);text-transform:uppercase;letter-spacing:.04em}.detail-v{font-size:.92rem;font-weight:500}.detail-h{font-size:.9rem;margin:4px 0 8px}.services-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:var(--gap)}.service-card{display:flex;flex-direction:column;gap:6px;padding:var(--card-pad);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);cursor:pointer;text-decoration:none;color:inherit;transition:transform .14s,box-shadow .14s,border-color .14s}.service-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:var(--accent-border)}.service-top{display:flex;align-items:flex-start;justify-content:space-between}.service-tile{width:48px;height:48px;border-radius:var(--radius-sm);display:grid;place-items:center}.service-emoji{font-size:25px;line-height:1}.service-ext{color:var(--text-faint);opacity:0;transition:opacity .14s}.service-card:hover .service-ext{opacity:1}.service-title{font-size:1.04rem;font-weight:700;margin-top:4px}.service-desc{font-size:.85rem;color:var(--text-muted)}.check-grid{display:flex;flex-direction:column;gap:7px}.check-pill{display:flex;align-items:center;gap:9px;padding:9px 12px;border:1px solid var(--border-strong);border-radius:var(--radius-sm);cursor:pointer;font-size:.85rem}.check-pill.on{border-color:var(--accent);background:var(--accent-soft)}.check-pill input{accent-color:var(--accent);width:15px;height:15px}.check-desc{color:var(--text-muted)}.svc-chips,.emoji-pick,.color-pick{display:flex;flex-wrap:wrap;gap:7px}.svc-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 11px;border:1px solid var(--border-strong);background:var(--surface);border-radius:999px;cursor:pointer;font-size:.82rem;font-weight:500;color:var(--text-muted);white-space:nowrap}.svc-chip.on{border-color:var(--accent);background:var(--accent-soft);color:var(--accent)}.svc-chip-emoji{font-size:14px}.emoji-opt{width:40px;height:40px;border-radius:var(--radius-sm);border:1px solid var(--border-strong);background:var(--surface);font-size:20px;cursor:pointer;display:grid;place-items:center}.emoji-opt.on{border-color:var(--accent);background:var(--accent-soft)}.color-opt{width:32px;height:32px;border-radius:50%;border:2px solid transparent;cursor:pointer;box-shadow:0 0 0 1px var(--border)}.color-opt.on{border-color:var(--surface);box-shadow:0 0 0 2px var(--text)}.invite-form{gap:0}.invite-form .btn{margin-top:4px}.token-reveal{display:flex;gap:8px;align-items:center;background:var(--surface-3);border:1px solid var(--border);border-radius:var(--radius-sm);padding:11px 13px;margin-bottom:14px}.token-reveal code{flex:1;font-size:.85rem;word-break:break-all}.callout{display:flex;gap:10px;align-items:flex-start;padding:11px 13px;border-radius:var(--radius-sm);font-size:.83rem;line-height:1.45}.callout svg{flex-shrink:0;margin-top:1px}.callout-warn{background:var(--warn-soft);color:color-mix(in srgb,var(--warn) 75%,var(--text))}.toolbar{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.seg-tabs{display:inline-flex;gap:2px;background:var(--surface-3);padding:3px;border-radius:var(--radius-sm)}.seg-tab{border:none;background:none;color:var(--text-muted);padding:6px 13px;border-radius:calc(var(--radius-sm) - 2px);cursor:pointer;font-size:.82rem;font-weight:600}.seg-tab.on{background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm)}.reorder{display:flex;flex-direction:column;align-items:center;gap:1px}.reorder-btn{border:none;background:none;color:var(--text-faint);cursor:pointer;padding:1px;line-height:0;border-radius:4px}.reorder-btn:hover:not(:disabled){color:var(--text);background:var(--surface-3)}.reorder-btn:disabled{opacity:.3;cursor:default}.reorder-num{font-size:.72rem;color:var(--text-faint);font-weight:600}.health-summary{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:var(--card-pad);border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);box-shadow:var(--shadow-sm)}.health-summary.tone-degraded{border-left:4px solid var(--warn)}.health-summary.tone-down{border-left:4px solid var(--danger)}.health-summary.tone-healthy{border-left:4px solid var(--ok)}.health-summary-main{display:flex;align-items:center;gap:14px}.health-summary-main>div{display:flex;flex-direction:column}.health-big{font-family:var(--font-display);font-size:1.5rem;font-weight:700}.health-small{font-size:.83rem;color:var(--text-muted)}.health-breakdown{display:flex;gap:8px}.hb{font-size:.8rem;font-weight:600;padding:4px 10px;border-radius:999px}.hb-warn{background:var(--warn-soft);color:var(--warn)}.hb-down{background:var(--danger-soft);color:var(--danger)}.hb-ok{background:var(--ok-soft);color:var(--ok)}.health-status{display:flex;align-items:center;gap:8px}.health-detail-status{display:flex;align-items:center;gap:9px;font-weight:600;margin-bottom:16px}.mode-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:8px}.mode-card{border:1.5px solid var(--border-strong);border-radius:var(--radius);padding:14px;cursor:pointer;background:var(--surface);display:flex;flex-direction:column;gap:10px}.mode-card.on{border-color:var(--accent)}.mode-preview{height:56px;border-radius:var(--radius-sm);display:grid;place-items:center}.mode-preview-light{background:#f3f1ec;color:#c47d10}.mode-preview-dark{background:#1b1b22;color:#cfd6ff}.mode-label{display:flex;align-items:center;gap:6px;font-weight:600;font-size:.9rem}.mode-label svg{color:var(--accent);margin-left:auto}.style-current{display:flex;align-items:center;gap:14px}.style-swatch{width:52px;height:52px;border-radius:var(--radius-sm);background:linear-gradient(135deg,var(--accent),color-mix(in srgb,var(--accent) 40%,var(--surface-3)));flex-shrink:0}.style-current-text .list-sub{white-space:normal}.empty{padding:40px 24px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:8px}.empty-icon{width:52px;height:52px;border-radius:var(--radius);background:var(--surface-3);color:var(--text-faint);display:grid;place-items:center}.empty-title{font-weight:600}.empty-desc{font-size:.86rem;color:var(--text-muted);max-width:360px}.login-stage{height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;padding:24px}.login-card{width:100%;max-width:400px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:32px}.login-brand{display:flex;flex-direction:column;align-items:center;gap:8px;margin-bottom:24px}.login-mark{width:64px;height:64px;border-radius:var(--radius);background:var(--accent-soft);color:var(--accent);display:grid;place-items:center}.login-name{font-size:1.55rem;font-weight:700;letter-spacing:-.02em;white-space:nowrap}.login-tag{color:var(--text-muted);font-size:.88rem}.login-form{display:flex;flex-direction:column;gap:14px}.login-form .field{margin-bottom:0}.login-note{font-size:.78rem;color:var(--text-faint);text-align:center;line-height:1.5}.login-action{display:flex;flex-direction:column;gap:14px}.login-welcome{display:flex;align-items:center;gap:12px;padding:12px;background:var(--surface-2);border-radius:var(--radius)}.login-welcome-hi{font-size:.82rem;color:var(--text-muted)}.login-welcome-name{font-weight:700;font-size:1.02rem}.login-auth{display:flex;flex-direction:column;align-items:center;gap:12px;padding:16px 0;text-align:center}.login-auth-text{font-weight:600}.muted-sm{font-size:.8rem;color:var(--text-muted)}.login-foot{font-size:.76rem;color:var(--text-faint)}.alert-inline{padding:10px 13px;border-radius:var(--radius-sm);font-size:.84rem}.alert-error{background:var(--danger-soft);color:var(--danger)}.spinner{width:30px;height:30px;border:3px solid var(--surface-3);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}.spinner-sm{width:16px;height:16px;border-width:2px}@keyframes spin{to{transform:rotate(360deg)}}.center-pad{display:grid;place-items:center;padding:48px}.user-menu-wrap{position:relative}.user-chip{display:flex;align-items:center;gap:8px;padding:4px 8px 4px 4px;border:1px solid transparent;border-radius:999px;background:none;cursor:pointer;color:var(--text)}.user-chip:hover{background:var(--surface-3)}.user-chip-name{font-size:.86rem;font-weight:600;white-space:nowrap}.user-chip-avatar{position:relative;display:inline-flex;flex-shrink:0}.dropdown-label{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-faint);padding:6px 10px 4px}.menu-scrim{position:fixed;inset:0;z-index:40}.dropdown{position:absolute;right:0;top:calc(100% + 8px);z-index:50;width:240px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:6px;animation:pop .14s ease}.dropdown-head{display:flex;align-items:center;gap:10px;padding:8px 10px 10px;border-bottom:1px solid var(--border);margin-bottom:5px}.dropdown-item{display:flex;align-items:center;gap:10px;width:100%;padding:9px 10px;border:none;background:none;color:var(--text);border-radius:var(--radius-sm);cursor:pointer;font-size:.88rem;font-weight:500;text-align:left}.dropdown-item:hover{background:var(--surface-3)}.dropdown-item.danger{color:var(--danger)}.dropdown-item.danger:hover{background:var(--danger-soft)}.dropdown-sep{height:1px;background:var(--border);margin:5px 0}.toast-wrap{position:fixed;bottom:20px;left:50%;transform:translate(-50%);z-index:2000;display:flex;flex-direction:column;gap:8px;align-items:center}.toast{display:flex;align-items:center;gap:8px;background:var(--text);color:var(--bg);padding:10px 16px;border-radius:999px;font-size:.86rem;font-weight:600;box-shadow:var(--shadow-lg);animation:pop .18s ease}.toast svg{color:var(--ok)}@media(max-width:1024px){.app-root[data-density=comfy]{--pad: 22px;--gap: 18px;--card-pad: 20px}.app-root[data-density=regular]{--pad: 20px}.split,.form-2col,.detail-grid,.mode-grid{grid-template-columns:1fr}.page-title{font-size:1.5rem}}@media(max-width:768px){.app-root[data-density=comfy]{--pad: 16px;--gap: 16px;--card-pad: 18px}.app-root[data-density=regular]{--pad: 14px;--gap: 14px}.app-root[data-density=compact]{--pad: 14px}.topnav-bar{gap:8px;padding:10px var(--pad)}.brand-name,.brand-sub{display:none}.topnav-primary{flex:1;min-width:0;gap:2px;overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch}.topnav-primary::-webkit-scrollbar{display:none}.topnav-link{padding:7px 11px;font-size:.85rem}.user-chip-name{display:none}.topbar-right{gap:4px;flex-shrink:0}.page-head{gap:10px}.page-title{font-size:1.4rem}.page-actions{width:100%}.page-actions .btn{flex:1}.table-card{overflow-x:auto;-webkit-overflow-scrolling:touch}.data-table{min-width:560px}.matrix-table{min-width:520px}.health-summary{flex-direction:column;align-items:flex-start;gap:12px}.health-summary-main,.toolbar{width:100%}.seg-tabs{overflow-x:auto;max-width:100%;scrollbar-width:none}.seg-tabs::-webkit-scrollbar{display:none}.input{font-size:16px}.services-grid{grid-template-columns:1fr 1fr}.modal-overlay{padding:0;align-items:flex-end}.modal{max-width:none!important;width:100%;max-height:92vh;border-bottom-left-radius:0;border-bottom-right-radius:0;animation:sheet .22s cubic-bezier(.3,.7,.4,1)}.modal-header,.modal-body{padding:16px}.modal-footer{padding:12px 16px}.modal-footer .btn{flex:1}.dropdown{width:min(280px,calc(100vw - 24px))}.notif-dropdown{width:min(300px,calc(100vw - 24px))}}@keyframes sheet{0%{transform:translateY(100%)}}@media(max-width:480px){.services-grid,.stat-row,.style-grid{grid-template-columns:1fr 1fr}.data-table{font-size:.82rem}.page-title{font-size:1.3rem}.login-card{padding:24px 20px}.login-stage{padding:16px}.modal-footer{flex-wrap:wrap}}.app-root[data-surface=glass]:before{background:radial-gradient(900px 600px at 8% -5%,color-mix(in srgb,var(--accent) 26%,transparent),transparent 60%),radial-gradient(800px 700px at 100% 0%,color-mix(in srgb,#7c5cff 22%,transparent),transparent 55%),radial-gradient(700px 600px at 60% 110%,color-mix(in srgb,var(--accent) 18%,transparent),transparent 60%),linear-gradient(160deg,var(--bg) 0%,var(--bg-2) 100%)}.app-root[data-surface=glass] .topnav{background:var(--surface-2);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}.app-root[data-surface=glass] .card,.app-root[data-surface=glass] .stat,.app-root[data-surface=glass] .health-summary{backdrop-filter:blur(16px) saturate(140%);-webkit-backdrop-filter:blur(16px) saturate(140%)}.app-root[data-surface=glass] .service-card{backdrop-filter:blur(14px) saturate(140%);-webkit-backdrop-filter:blur(14px) saturate(140%)}.app-root[data-surface=glass] .login-card,.app-root[data-surface=glass] .modal,.app-root[data-surface=glass] .dropdown{backdrop-filter:blur(20px) saturate(150%);-webkit-backdrop-filter:blur(20px) saturate(150%)}.style-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px;margin-top:8px}.style-preview{height:60px;border-radius:var(--radius-sm);padding:9px;display:flex;align-items:flex-end;gap:6px;overflow:hidden}.style-preview .sp-card{flex:1;height:70%;border-radius:6px}.style-preview .sp-dot{width:16px;height:16px;border-radius:50%;flex-shrink:0}.notif-btn{position:relative}.notif-badge{position:absolute;top:0;right:0;min-width:16px;height:16px;padding:0 4px;border-radius:999px;background:var(--danger);color:#fff;font-size:.62rem;font-weight:700;display:grid;place-items:center;line-height:1;box-shadow:0 0 0 2px var(--surface)}.notif-dropdown{width:300px}.notif-dropdown .dropdown-head{justify-content:space-between}.notif-empty{display:flex;align-items:center;gap:8px;padding:12px 10px;font-size:.85rem;color:var(--text-muted)}.notif-empty svg{color:var(--ok)}.notif-item{align-items:flex-start}.notif-item .status-dot{margin-top:5px}.notif-text{display:flex;flex-direction:column;min-width:0}.notif-title{font-weight:600;font-size:.88rem}.icon-search{margin-bottom:8px}.icon-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(44px,1fr));gap:7px;max-height:230px;overflow-y:auto;padding:4px;border:1px solid var(--border);border-radius:var(--radius-sm)}.icon-empty{font-size:.82rem;color:var(--text-faint);padding:14px;text-align:center}
