:root{--bg-1:#fbfbfc;--bg-2:#f3f4f6;--surface:#ffffff;--surface-2:#f6f7f9;--text:#18181b;--text-muted:#6b7280;--border:rgba(17,24,39,0.1);--border-strong:rgba(17,24,39,0.18);--accent:#334155;--accent-strong:#1e293b;--accent-soft:#eef1f5;--accent-text:#334155;--accent-glow:rgba(51,65,85,0.16);--accent-2:#475569;--accent-2-glow:rgba(71,85,105,0.14);--danger-soft:#fdecec;--danger-text:#b42424;--success:#2f9e44;--success-soft:#e8f6ec;--success-text:#237a36;--radius:10px;--radius-sm:7px;--radius-pill:999px;--shadow-sm:0 1px 2px rgba(16,24,40,0.05);--shadow-md:0 1px 3px rgba(16,24,40,0.07),0 1px 2px rgba(16,24,40,0.04);--shadow-lg:0 8px 24px rgba(16,24,40,0.09),0 2px 6px rgba(16,24,40,0.04);--font-mono:ui-monospace,SFMono-Regular,"SF Mono",Menlo,Consolas,monospace}*{box-sizing:border-box}body,html{margin:0;padding:0;min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,SF Pro Text,system-ui,Segoe UI,Roboto,Arial,sans-serif;color:var(--text);background:var(--bg-1);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body:before{content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;background-image:radial-gradient(rgba(17,24,39,.045) 1px,transparent 0);background-size:22px 22px}@keyframes aurora{0%{transform:translate3d(-3%,-2%,0) scale(1)}50%{transform:translate3d(3%,2%,0) scale(1.08)}to{transform:translate3d(-2%,3%,0) scale(1.03)}}@media (prefers-reduced-motion:reduce){body:before{animation:none}}.wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}.card{max-width:420px;width:100%;background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:40px;box-shadow:var(--shadow-lg)}.card h1{font-size:22px;font-weight:600;letter-spacing:-.02em;margin:0 0 10px}.card p{margin:0 0 8px;line-height:1.55}.muted{color:var(--text-muted);font-size:14px}.field{display:flex;flex-direction:column;gap:7px;margin:18px 0}.field label{font-size:13px;font-weight:500;color:var(--text)}.field input{padding:12px 14px;border:1px solid var(--border-strong);border-radius:12px;font-size:16px;font-family:inherit;color:var(--text);background:var(--surface-2);transition:border-color .15s,box-shadow .15s,background .15s}.field input:focus{outline:none;border-color:var(--accent);background:var(--surface);box-shadow:0 0 0 4px var(--accent-glow)}.btn{display:inline-flex;align-items:center;justify-content:center;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);padding:12px 20px;font-size:15px;font-weight:600;font-family:inherit;cursor:pointer;box-shadow:var(--shadow-sm);transition:transform .12s,box-shadow .15s,background .15s}.btn:hover{background:var(--accent-strong);box-shadow:var(--shadow-md)}.btn:active{transform:translateY(1px)}.btn:disabled{opacity:.55;cursor:default;box-shadow:none}.btn-sm{padding:8px 14px;font-size:13px;border-radius:10px}.notice{font-size:14px;padding:11px 14px;border-radius:12px;margin:12px 0;line-height:1.45}.notice.ok{background:var(--accent-soft);color:var(--accent-text)}.notice.err{background:var(--danger-soft);color:var(--danger-text)}.linkbtn{display:block;background:none;border:none;color:var(--text-muted);font-size:13px;cursor:pointer;text-decoration:none;padding:0;margin-top:14px}.linkbtn:hover{color:var(--accent);text-decoration:underline}.shell{min-height:100vh}.sidebar{position:fixed;top:0;left:0;z-index:30;width:248px;height:100vh;display:flex;flex-direction:column;padding:18px 14px;background:rgba(255,255,255,.82);backdrop-filter:saturate(180%) blur(14px);-webkit-backdrop-filter:saturate(180%) blur(14px);border-right:1px solid var(--border)}.shell-main{margin-left:248px;min-height:100vh}.sidebar-brand{display:flex;align-items:center;gap:9px;font-weight:600;font-size:15px;letter-spacing:-.01em;color:var(--text);text-decoration:none;padding:8px 10px 16px}.sidebar-brand:before{content:"";width:10px;height:10px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-2));box-shadow:0 0 0 3px var(--accent-soft),0 0 14px var(--accent-2-glow);flex-shrink:0}.sidebar-nav{display:flex;flex-direction:column;gap:2px;flex:1 1;overflow-y:auto}.nav-item{display:flex;align-items:center;gap:11px;padding:9px 11px;border-radius:10px;color:var(--text);text-decoration:none;font-size:14px;font-weight:500;transition:background .15s,color .15s}.nav-item svg{color:var(--text-muted);flex-shrink:0}.nav-item:hover{background:var(--surface-2)}.nav-item.is-active{background:var(--accent-soft);font-weight:600}.nav-item.is-active,.nav-item.is-active svg{color:var(--accent-text)}.nav-item.is-soon{cursor:default;color:var(--text-muted)}.nav-item.is-soon svg{opacity:.65}.nav-item.is-soon:hover{background:none}.nav-soon-badge{margin-left:auto;font-size:10px;letter-spacing:.02em;background:var(--accent-soft);color:var(--accent-text);padding:2px 7px;border-radius:var(--radius-pill)}.nav-label,.nav-soon-badge{font-family:var(--font-mono);font-weight:700;text-transform:uppercase}.nav-label{font-size:11px;letter-spacing:.04em;color:var(--text-muted);padding:14px 11px 6px}.nav-sep{height:1px;background:var(--border);margin:10px 8px}.sidebar-foot{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding:12px 10px 4px;border-top:1px solid var(--border);margin-top:8px}.sidebar-foot form{width:100%}.acc-avatar{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;font-weight:700;font-size:15px;flex-shrink:0}.acc-info{display:flex;flex-direction:column;min-width:0;flex:1 1}.acc-email{font-size:12.5px;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.acc-role{font-size:11.5px;color:var(--accent-text)}.acc-clock{font-size:11.5px;margin-top:2px}.acc-clock,.acc-logout{color:var(--text-muted)}.acc-logout{width:100%;margin-top:4px;background:var(--surface);border:1px solid var(--border-strong);border-radius:9px;padding:7px 10px;font-size:13px;font-family:inherit;cursor:pointer;transition:border-color .15s,color .15s,background .15s}.acc-logout:hover{border-color:var(--accent);color:var(--accent-text);background:var(--accent-soft)}.mobile-bar,.sidebar-backdrop{display:none}.brand-mini{font-weight:600;font-size:14px;color:var(--text);text-decoration:none}.mobile-burger{width:34px;height:34px;border-radius:8px;border:1px solid var(--border-strong);background:var(--surface);display:flex;flex-direction:column;gap:3px;align-items:center;justify-content:center;cursor:pointer}.mobile-burger span{display:block;width:16px;height:2px;background:var(--text);border-radius:2px}@media (max-width:860px){.sidebar{transform:translateX(-100%);transition:transform .2s ease;box-shadow:8px 0 30px rgba(16,24,40,.12)}.sidebar.is-open{transform:translateX(0)}.shell-main{margin-left:0;padding-top:56px}.mobile-bar{display:flex;align-items:center;gap:12px;position:fixed;top:0;left:0;right:0;z-index:20;height:56px;padding:0 16px;background:rgba(255,255,255,.85);backdrop-filter:saturate(180%) blur(14px);-webkit-backdrop-filter:saturate(180%) blur(14px);border-bottom:1px solid var(--border)}.sidebar-backdrop{display:block;position:fixed;inset:0;z-index:25;background:rgba(17,24,39,.28)}}@media (prefers-reduced-motion:reduce){.sidebar{transition:none}}.dashboard{max-width:1200px;margin:0 auto;padding:40px 32px}.dash-head{margin-bottom:28px}.dash-head h1{font-size:28px;font-weight:600;letter-spacing:-.02em;margin:0 0 4px}.dash-date{color:var(--text-muted);font-size:15px;margin:0}.dash-section{margin-bottom:32px}.dash-h2{font-size:16px;font-weight:600;letter-spacing:-.01em;margin:0 0 14px}.tile-icon{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:11px;background:var(--accent-soft);color:var(--accent-text);margin-bottom:12px}.content{flex:1 1;width:100%;max-width:1000px;margin:0 auto;padding:40px 28px}.content h1{font-size:26px;font-weight:600;letter-spacing:-.02em;margin:0 0 6px}.content .sub{color:var(--text-muted);font-size:15px;margin:0 0 28px}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));grid-gap:18px;gap:18px}.tile{display:block;position:relative;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:22px;text-decoration:none;color:var(--text);box-shadow:var(--shadow-md);transition:transform .15s,box-shadow .2s,border-color .2s}.tile-active{cursor:pointer}.tile-active:hover{transform:translateY(-3px);border-color:rgba(79,124,255,.35);box-shadow:var(--shadow-lg),0 10px 30px var(--accent-glow)}.tile-coming_soon,.tile-disabled{box-shadow:var(--shadow-sm)}.tile-disabled{opacity:.65}.tile-name{font-size:17px;font-weight:600;letter-spacing:-.01em;margin:0 0 6px}.tile-desc{font-size:13px;color:var(--text-muted);margin:0;line-height:1.45}.badge{display:inline-block;margin-top:14px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;padding:4px 10px;border-radius:var(--radius-pill)}.badge-coming_soon{background:var(--accent-soft);color:var(--accent-text)}.badge-disabled{background:#eef0f3;color:#8a8f98}.empty{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:40px;text-align:center;color:var(--text-muted);font-size:15px;line-height:1.6}.admin-section{margin-bottom:36px}.admin-section>h2{font-size:18px;font-weight:600;letter-spacing:-.01em;margin:0 0 14px}.adduser{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:18px}.adduser input{flex:1 1;min-width:260px;padding:10px 12px;border:1px solid var(--border-strong);border-radius:10px;font-size:15px;font-family:inherit;color:var(--text);background:var(--surface-2);transition:border-color .15s,box-shadow .15s,background .15s}.adduser input:focus{outline:none;border-color:var(--accent);background:var(--surface);box-shadow:0 0 0 4px var(--accent-glow)}.notice.inline{display:inline-block;margin:0;padding:7px 11px}.kpi-bar{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:14px;gap:14px;margin:4px 0 30px}@media (max-width:720px){.kpi-bar{grid-template-columns:repeat(2,1fr)}}.kpi-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:18px 20px;display:flex;flex-direction:column;gap:6px}.kpi-num{font-size:28px;font-weight:700;letter-spacing:-.02em;color:var(--accent-text);line-height:1}.kpi-sub{font-size:16px}.kpi-label,.kpi-sub{font-weight:600;color:var(--text-muted)}.kpi-label{font-family:var(--font-mono);font-size:12px;text-transform:uppercase;letter-spacing:.02em}.admin-page{flex:1 1;width:100%;max-width:1400px;margin:0 auto;padding:36px 32px}.admin-page h1{font-size:26px;font-weight:600;letter-spacing:-.02em;margin:0 0 6px}.admin-page .sub{color:var(--text-muted);font-size:15px;margin:0 0 26px}.admin-panel{min-width:0}.admin-tabs{display:flex;gap:4px;border-bottom:1px solid var(--border);margin-bottom:18px}.admin-tabs button{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border:none;border-bottom:2px solid transparent;background:none;color:var(--text-muted);font-size:14.5px;font-weight:600;font-family:inherit;cursor:pointer;margin-bottom:-1px;transition:color .15s,border-color .15s}.admin-tabs button:hover{color:var(--text)}.admin-tabs button.is-active{color:var(--accent-text);border-bottom-color:var(--accent)}.tab-count{font-size:12px;font-weight:600;color:var(--text-muted);background:var(--surface-2);border-radius:var(--radius-pill);padding:1px 8px;min-width:22px;text-align:center}.admin-tabs button.is-active .tab-count{background:var(--accent-soft);color:var(--accent-text)}.admin-filterbar{justify-content:space-between;gap:14px;margin-bottom:14px}.admin-filterbar,.filterbar-controls{display:flex;align-items:center;flex-wrap:wrap}.filterbar-controls{gap:10px}.admin-filterbar .adduser{margin-bottom:0}.filter-select{padding:9px 12px;border:1px solid var(--border-strong);border-radius:10px;font-size:14px;font-family:inherit;color:var(--text);background:var(--surface-2);cursor:pointer}.filter-select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-glow)}.table-hint{font-size:12.5px;color:var(--text-muted);margin:10px 2px 0}.admin-search{position:relative;display:flex;align-items:center}.admin-search-icon{position:absolute;left:11px;font-size:13px;opacity:.7;pointer-events:none}.admin-search input{padding:9px 12px 9px 32px;border:1px solid var(--border-strong);border-radius:10px;font-size:14px;font-family:inherit;color:var(--text);background:var(--surface-2);min-width:240px;transition:border-color .15s,box-shadow .15s,background .15s}.admin-search input:focus{outline:none;border-color:var(--accent);background:var(--surface);box-shadow:0 0 0 4px var(--accent-glow)}.admin-table-wrap{overflow-x:auto;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm)}.admin-table{width:100%;border-collapse:collapse;font-size:14px}.admin-table th{text-align:left;font-family:var(--font-mono);font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.02em;color:var(--text-muted);padding:13px 16px;border-bottom:1px solid var(--border-strong);background:var(--surface-2);white-space:nowrap}.admin-table td{padding:13px 16px;border-bottom:1px solid var(--border);vertical-align:top}.admin-table tbody tr:last-child td{border-bottom:none}.admin-table tbody tr:hover{background:var(--surface-2)}.cell-user{display:flex;align-items:center;gap:8px}.cell-user strong{font-size:14.5px;font-weight:600;word-break:break-all}.cell-sub{display:block;font-size:12px;margin-top:3px}.cell-nowrap,.cell-sub{color:var(--text-muted)}.cell-nowrap{white-space:nowrap}.admin-empty-row{text-align:center;color:var(--text-muted);padding:28px}.tag-self{font-size:11px;padding:1px 7px;background:var(--accent-soft);color:var(--accent-text)}.badge-role,.tag-self{font-weight:600;border-radius:var(--radius-pill)}.badge-role{display:inline-block;font-size:12px;padding:3px 9px;background:#eef0f3;color:#6b7280}.badge-role.is-admin{background:var(--accent-soft);color:var(--accent-text)}.badge-status{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;padding:3px 9px;border-radius:var(--radius-pill)}.badge-status .dot{width:7px;height:7px;border-radius:50%}.badge-status.is-active{background:var(--success-soft);color:var(--success-text)}.badge-status.is-active .dot{background:var(--success)}.badge-status.is-inactive{background:#eef0f3;color:#8a8f98}.badge-status.is-inactive .dot{background:#b6bcc4}.badge-app{display:inline-block;font-size:12px;font-weight:600;padding:3px 9px;border-radius:var(--radius-pill)}.badge-app.badge-active{background:var(--success-soft);color:var(--success-text)}.badge-app.badge-coming_soon{background:var(--accent-soft);color:var(--accent-text)}.badge-app.badge-disabled{background:#eef0f3;color:#8a8f98}.cell-toggle{display:inline-block;margin-top:8px;background:var(--surface);color:var(--accent-text);border:1px solid var(--border-strong);border-radius:8px;padding:5px 10px;font-size:12px;font-family:inherit;cursor:pointer;transition:border-color .15s,background .15s}.cell-toggle:hover:not(:disabled){border-color:var(--accent);background:var(--accent-soft)}.cell-toggle:disabled{opacity:.4;cursor:default}.cell-grants{display:flex;gap:7px;flex-wrap:wrap}.cell-grants form{display:contents}.chip{background:var(--surface-2);color:var(--text);border:1px solid var(--border-strong);border-radius:999px;padding:6px 12px;font-size:13px;font-family:inherit;cursor:pointer;transition:border-color .15s,background .15s,box-shadow .15s}.chip:hover:not(:disabled){border-color:var(--accent)}.chip:disabled{opacity:.45;cursor:default}.chip-on{background:var(--accent-soft);color:var(--accent-text);border-color:transparent}.status-form{display:flex;gap:8px;align-items:center}.status-form .cell-toggle{margin-top:0}.status-form select{padding:7px 10px;border:1px solid var(--border-strong);border-radius:10px;font-size:13px;font-family:inherit;color:var(--text);background:var(--surface-2)}.col-tool{text-align:center;width:84px}.th-tool{display:inline-flex;flex-direction:column;align-items:center;gap:4px;color:var(--accent-text)}.th-tool-name{font-size:10px;font-weight:600;text-transform:none;letter-spacing:0;color:var(--text-muted);max-width:76px;line-height:1.2}.mark-on{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:6px;background:var(--success-soft);color:var(--success-text);font-size:13px;font-weight:700}.mark-off{color:#c2c7cf;font-weight:700}.row-click{cursor:pointer}.row-click:hover{background:var(--surface-2)}.row-selected,.row-selected:hover{background:var(--accent-soft)}.row-click:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}.cell-app{display:flex;align-items:center;gap:12px}.cell-app-icon{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:10px;background:var(--accent-soft);color:var(--accent-text);flex-shrink:0}.cell-app strong{display:block;font-size:14.5px;font-weight:600}.act-type{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;font-weight:600;padding:3px 10px;border-radius:var(--radius-pill)}.act-tool{background:var(--accent-soft);color:var(--accent-text)}.act-security{background:#fff4e6;color:#b6741b}.cell-detail{color:var(--text-muted);font-size:13px}.drawer-backdrop{position:fixed;inset:0;z-index:40;background:rgba(17,24,39,.28);-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px);animation:drawer-fade .16s ease}.drawer{position:fixed;top:0;right:0;z-index:41;height:100vh;width:420px;max-width:92vw;background:var(--surface);border-left:1px solid var(--border);box-shadow:-16px 0 40px rgba(16,24,40,.16);display:flex;flex-direction:column;animation:drawer-slide .2s ease}@keyframes drawer-fade{0%{opacity:0}}@keyframes drawer-slide{0%{transform:translateX(24px);opacity:.4}}@media (prefers-reduced-motion:reduce){.drawer,.drawer-backdrop{animation:none}}.drawer-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:20px 22px;border-bottom:1px solid var(--border)}.drawer-head-main{min-width:0}.drawer-close{flex-shrink:0;width:32px;height:32px;border-radius:8px;border:1px solid var(--border-strong);background:var(--surface);color:var(--text-muted);font-size:15px;cursor:pointer;transition:background .15s,color .15s,border-color .15s}.drawer-close:hover{background:var(--surface-2);color:var(--text);border-color:var(--accent)}.drawer-body{flex:1 1;overflow-y:auto;padding:8px 22px 24px}.drawer-section{padding:18px 0;border-bottom:1px solid var(--border)}.drawer-section:last-child{border-bottom:none}.drawer-section>h3{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);margin:0 0 12px}.drawer-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}.drawer-row:last-child{margin-bottom:0}.drawer-access{display:flex;flex-direction:column;gap:8px}.drawer-access-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.drawer-access-name{display:inline-flex;align-items:center;gap:9px;font-size:14px;color:var(--text)}.drawer-access-name svg{color:var(--accent-text)}.drawer-activity{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}.drawer-activity li{display:flex;flex-direction:column;gap:1px;font-size:13px;border-left:2px solid var(--border-strong);padding-left:10px}.da-time{font-size:11.5px;color:var(--text-muted)}.da-action{font-weight:600}.da-detail,.hz-back{color:var(--text-muted)}.hz-back{display:inline-block;font-size:13px;text-decoration:none;margin-bottom:12px}.hz-back:hover{color:var(--accent)}.hz-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:22px;gap:22px;align-items:start}@media (max-width:860px){.hz-grid{grid-template-columns:1fr}}.hz-col{display:flex;flex-direction:column;min-width:0}.hz-label{font-size:13px;font-weight:600;color:var(--text-muted);margin-bottom:8px}.hz-textarea{width:100%;min-height:440px;resize:vertical;padding:16px;border:1px solid var(--border-strong);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);font-family:inherit;font-size:14px;line-height:1.55;box-shadow:var(--shadow-sm)}.hz-textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-glow)}.hz-meta{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:8px;font-size:12.5px;color:var(--text-muted)}.hz-counter-over{color:var(--danger-text);font-weight:600}.hz-run{margin-top:16px;align-self:center;min-width:200px}.hz-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin-top:16px}.hz-copy{background:var(--surface);color:var(--accent-text);border:1px solid var(--border-strong);box-shadow:none}.hz-copy:hover{filter:none;background:var(--accent-soft);box-shadow:none}.hz-output{min-height:440px;padding:16px 18px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);box-shadow:var(--shadow-sm);font-size:14px;line-height:1.6}.hz-placeholder{text-align:center}.hz-loading,.hz-placeholder{color:var(--text-muted);display:flex;align-items:center;justify-content:center}.hz-loading{gap:12px}.hz-spinner{width:18px;height:18px;border-radius:50%;border:2px solid var(--accent-soft);border-top-color:var(--accent);animation:hz-spin .8s linear infinite}@keyframes hz-spin{to{transform:rotate(1turn)}}@media (prefers-reduced-motion:reduce){.hz-spinner{animation:none}}.hz-rendered h2{font-size:19px;font-weight:600;letter-spacing:-.01em;margin:18px 0 8px}.hz-rendered h2:first-child{margin-top:0}.hz-rendered h3{font-size:16px;font-weight:600;margin:16px 0 6px}.hz-rendered p{margin:0 0 12px}.hz-rendered ol,.hz-rendered ul{margin:0 0 12px;padding-left:22px}.hz-rendered li{margin-bottom:4px}.hz-rendered a{color:var(--accent-text)}.md-drop{margin-top:8px;display:flex;align-items:center;justify-content:center;min-height:180px;padding:28px;text-align:center;border:1.5px dashed var(--border-strong);border-radius:var(--radius);background:var(--surface);box-shadow:var(--shadow-sm);cursor:pointer;transition:border-color .15s,background .15s,box-shadow .15s}.md-drop-over,.md-drop:hover{border-color:var(--accent)}.md-drop-over{background:var(--accent-soft);box-shadow:0 0 0 4px var(--accent-glow)}.md-prompt{display:flex;flex-direction:column;gap:6px}.md-prompt-main{font-size:15px;font-weight:600;color:var(--text)}.md-prompt-sub{font-size:13px;color:var(--text-muted)}.md-file{display:flex;flex-direction:column;gap:4px}.md-file strong{font-size:15px;word-break:break-all}.md-filemeta{font-size:13px;color:var(--text-muted)}.md-actions{display:flex;gap:10px;align-items:center;margin-top:18px}.md-reset{background:var(--surface);color:var(--accent-text);border:1px solid var(--border-strong);box-shadow:none}.md-reset:hover{filter:none;background:var(--accent-soft);box-shadow:none}.md-report{margin-top:26px}.md-h2{font-size:16px;font-weight:600;letter-spacing:-.01em;margin:22px 0 10px}.md-warn-item{margin:8px 0}.md-table{width:100%;border-collapse:collapse;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);overflow:hidden}.md-table td{padding:11px 14px;font-size:14px;border-bottom:1px solid var(--border);vertical-align:top}.md-table tr:last-child td{border-bottom:none}.md-td-label{width:38%;font-weight:600;color:var(--text-muted)}.md-td-value{color:var(--text);word-break:break-word}.dash-grid{display:grid;grid-template-columns:1.6fr 1fr;grid-gap:20px;gap:20px;align-items:start}@media (max-width:900px){.dash-grid{grid-template-columns:1fr}}.dash-col-main,.dash-col-side{display:flex;flex-direction:column;gap:20px;min-width:0}.dash-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:18px 20px}.dash-card-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}.dash-card-head h3{margin:0;font-size:15px;font-weight:600;letter-spacing:-.01em}.card-sub{font-size:12.5px;color:var(--text-muted)}.card-action{background:none;border:none;color:var(--accent-text);font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;padding:2px 4px}.card-action:hover{text-decoration:underline}.seg{display:inline-flex;background:var(--surface-2);border:1px solid var(--border);border-radius:9px;padding:2px}.seg button{border:none;background:none;font-family:inherit;font-size:12.5px;font-weight:600;color:var(--text-muted);padding:4px 10px;border-radius:7px;cursor:pointer}.seg button.is-active{background:var(--surface);color:var(--accent-text);box-shadow:var(--shadow-sm)}.task-add{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}.task-add input[name=title]{flex:1 1;min-width:140px}.task-add input,.task-add select{padding:8px 10px;border:1px solid var(--border-strong);border-radius:9px;font-size:13px;font-family:inherit;color:var(--text);background:var(--surface-2)}.task-add input:focus,.task-add select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.task-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:2px}.task-list-done{margin-top:6px;opacity:.7}.task-item{display:flex;align-items:flex-start;gap:10px;padding:8px 6px;border-radius:9px}.task-item:hover{background:var(--surface-2)}.task-check{flex-shrink:0;width:20px;height:20px;margin-top:1px;border-radius:6px;border:1.5px solid var(--border-strong);background:var(--surface);color:#fff;font-size:12px;font-weight:700;line-height:1;cursor:pointer}.task-check.is-on{background:var(--success);border-color:var(--success)}.task-main{flex:1 1;min-width:0;display:flex;flex-direction:column;gap:2px}.task-title{font-size:14px;line-height:1.4}.task-item.is-done .task-title{text-decoration:line-through;color:var(--text-muted)}.task-meta{display:flex;gap:10px;flex-wrap:wrap;font-size:12px;color:var(--text-muted)}.task-due.is-overdue{color:var(--danger-text);font-weight:600}.task-del{flex-shrink:0;background:none;border:none;color:var(--text-muted);font-size:13px;cursor:pointer;padding:2px 6px;border-radius:6px}.task-del:hover{background:var(--danger-soft);color:var(--danger-text)}.task-empty{margin:4px 0}.task-toggle-done{margin-top:10px;background:none;border:none;color:var(--accent-text);font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;padding:0}.task-toggle-done:hover{text-decoration:underline}.ann-form{display:flex;flex-direction:column;gap:8px;margin-bottom:14px}.ann-form input,.ann-form textarea{padding:9px 11px;border:1px solid var(--border-strong);border-radius:9px;font-size:13.5px;font-family:inherit;color:var(--text);background:var(--surface-2);resize:vertical}.ann-form input:focus,.ann-form textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.ann-form .btn{align-self:flex-start}.ann-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:14px}.ann-item{border-left:2px solid var(--accent-soft);padding-left:12px}.ann-item-head{display:flex;align-items:center;justify-content:space-between;gap:8px}.ann-item-head strong{font-size:14px}.ann-body{margin:4px 0 6px;font-size:13.5px;line-height:1.5;white-space:pre-wrap}.ann-meta{font-size:11.5px;color:var(--text-muted)}.ql-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:2px}.ql-link{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px;border-radius:8px;text-decoration:none;color:var(--text);font-size:13.5px}.ql-link:hover{background:var(--surface-2);color:var(--accent-text)}.ql-link svg{flex-shrink:0}.ql-hint,.ql-link svg{color:var(--text-muted)}.ql-hint{display:block;font-size:11px;padding:0 8px 6px}.stats-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.stats-list li{display:flex;align-items:center;justify-content:space-between;gap:10px;font-size:13.5px}.stats-name{display:inline-flex;align-items:center;gap:8px}.stats-count,.stats-name svg{color:var(--accent-text)}.stats-count{font-weight:700}.dash-card-link{display:flex;align-items:center;justify-content:space-between;text-decoration:none;color:var(--text);font-size:14px;font-weight:600;transition:border-color .15s,box-shadow .2s}.dash-card-link:hover{border-color:rgba(79,124,255,.35);box-shadow:var(--shadow-md),0 8px 22px var(--accent-glow);color:var(--accent-text)}.help-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:22px 24px;margin-bottom:18px}.help-section>h2{font-size:18px;font-weight:600;letter-spacing:-.01em;margin:0 0 10px}.help-section h3{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);margin:18px 0 6px}.help-section li,.help-section p{font-size:14.5px;line-height:1.6}.help-section ol,.help-section ul{margin:0 0 6px;padding-left:22px}.faq-q{font-weight:600;margin:12px 0 2px}.faq-a{margin:0 0 6px;color:var(--text-muted)}.section-head{display:flex;align-items:baseline;gap:10px;margin-bottom:6px}.section-head h2{margin:0;font-size:18px;font-weight:600;letter-spacing:-.01em}.section-count{font-size:13px;color:var(--text-muted)}.link-add{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}.link-add input{flex:1 1;min-width:140px;padding:9px 11px;border:1px solid var(--border-strong);border-radius:9px;font-size:13.5px;font-family:inherit;color:var(--text);background:var(--surface-2)}.link-add input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.link-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.link-row{gap:10px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);padding:10px 12px}.link-edit,.link-row{display:flex;align-items:center;flex-wrap:wrap}.link-edit{gap:8px;flex:1 1;min-width:0}.link-edit input{padding:7px 10px;border:1px solid var(--border-strong);border-radius:8px;font-size:13px;font-family:inherit;color:var(--text);background:var(--surface-2)}.link-edit input[name=label]{flex:1 1;min-width:120px}.link-edit input[name=url]{flex:1.4 1;min-width:160px}.link-edit input[name=hint]{flex:1 1;min-width:110px}.link-edit input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.link-tools{display:flex;gap:4px;align-items:center}.link-tools form{display:contents}.link-icon-btn{width:28px;height:28px;border:1px solid var(--border-strong);border-radius:8px;background:var(--surface);color:var(--text-muted);cursor:pointer;font-size:13px}.link-icon-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent-text)}.link-icon-btn:disabled{opacity:.4;cursor:default}.adduser-wrap{margin-bottom:16px}.adduser input{min-width:150px}.adduser-temp{margin-top:10px;line-height:1.5}.adduser-temp code,.notice code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;background:rgba(17,24,39,.08);padding:2px 7px;border-radius:6px;font-weight:700;font-size:.95em}.pw-form{max-width:460px;margin-top:18px}.acc-link{width:100%;text-align:center;margin-top:6px;font-size:12.5px;color:var(--text-muted);text-decoration:none}.acc-link:hover{color:var(--accent-text);text-decoration:underline}.srv-dash{display:flex;flex-direction:column;gap:26px}.srv-updated{font-size:12.5px;color:var(--text-muted);margin-top:-4px}.srv-section{display:flex;flex-direction:column;gap:14px}.srv-section h3{font-size:15px;font-weight:600;letter-spacing:-.01em;margin:0}.srv-notice{margin:0;font-size:13px;color:var(--danger-text);background:var(--danger-soft);border-radius:var(--radius-sm);padding:8px 12px}.srv-gauges{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:14px;gap:14px}.srv-gauge-tile{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:16px 18px;display:flex;align-items:center;gap:16px}.srv-gauge-wrap{position:relative;width:80px;height:80px;flex-shrink:0}.srv-gauge-val{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:17px;font-weight:700;color:var(--text)}.srv-gauge-meta{display:flex;flex-direction:column;gap:5px;min-width:0}.srv-gauge-detail{font-size:13px;color:var(--text-muted)}.srv-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:14px;gap:14px}.srv-tile{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:16px 18px;display:flex;flex-direction:column;gap:6px;min-width:0}.srv-tile-num{font-size:26px;font-weight:700;letter-spacing:-.02em;color:var(--accent-text);line-height:1}.srv-tile-val{font-size:17px;font-weight:600;color:var(--text)}.srv-tile-sub{font-size:12.5px;color:var(--text-muted)}.srv-charts{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:14px;gap:14px}.srv-chart{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:14px 16px;display:flex;flex-direction:column;gap:10px}.srv-spark{width:100%;height:30px;display:block}.srv-spark-empty{height:30px;display:flex;align-items:center;font-size:12px;color:var(--text-muted)}.srv-pill{display:inline-flex;align-items:center;font-size:12.5px;font-weight:600;border-radius:var(--radius-pill);padding:3px 11px;line-height:1.4}.srv-pill.is-ok{background:var(--success-soft);color:var(--success-text)}.srv-pill.is-warn{background:#fff5e6;color:#9a6212}.srv-pill.is-crit{background:var(--danger-soft);color:var(--danger-text)}.srv-containers{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden}.srv-container-row{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;align-items:center;grid-gap:10px;gap:10px;padding:12px 18px;border-top:1px solid var(--border);font-size:14px}.srv-container-row:first-child{border-top:none}.srv-container-head{font-size:11.5px;text-transform:uppercase;letter-spacing:.04em;font-weight:600;color:var(--text-muted);background:var(--surface-2)}.srv-cname{font-weight:600;color:var(--text)}.srv-muted{color:var(--text-muted)}.srv-bytool{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden}.srv-bytool-row{display:grid;grid-template-columns:1fr auto auto;align-items:center;grid-gap:16px;gap:16px;padding:11px 18px;border-top:1px solid var(--border);font-size:14px}.srv-bytool-row:first-child{border-top:none}.srv-bytool-cost{font-weight:700;color:var(--accent-text);min-width:64px;text-align:right}@media (max-width:860px){.srv-charts,.srv-gauges{grid-template-columns:1fr}.srv-grid{grid-template-columns:repeat(2,1fr)}}.pg-tabs{display:inline-flex;gap:4px;padding:4px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-pill);margin-bottom:22px}.pg-tab{border:none;background:none;font:inherit;font-weight:600;font-size:14px;color:var(--text-muted);padding:9px 22px;border-radius:var(--radius-pill);cursor:pointer;transition:background .15s,color .15s}.pg-tab:hover{color:var(--text)}.pg-tab.is-active{background:var(--surface);color:var(--accent-text);box-shadow:0 1px 4px rgba(17,24,39,.08)}.pg-panel{gap:22px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:24px}.pg-field,.pg-panel{display:flex;flex-direction:column}.pg-field{gap:10px}.pg-field-head{display:flex;align-items:baseline;justify-content:space-between}.pg-label{font-size:13px;font-weight:600;color:var(--text);letter-spacing:.01em}.pg-num{font-feature-settings:"tnum";font-variant-numeric:tabular-nums;font-weight:700;font-size:16px;color:var(--accent-text)}.pg-hint{margin:0;font-size:13px;color:var(--text-muted)}.pg-range{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:6px;border-radius:var(--radius-pill);background:var(--accent-soft);outline:none}.pg-range::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-2));box-shadow:0 2px 6px var(--accent-glow);cursor:pointer}.pg-range::-moz-range-thumb{width:20px;height:20px;border:none;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-2));box-shadow:0 2px 6px var(--accent-glow);cursor:pointer}.pg-checks{display:flex;flex-wrap:wrap;gap:10px 20px}.pg-check{display:inline-flex;align-items:center;gap:8px;font-size:14px;color:var(--text);cursor:pointer}.pg-check input{width:16px;height:16px;accent-color:var(--accent);cursor:pointer}.pg-seg{display:inline-flex;flex-wrap:wrap;gap:4px;padding:4px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm)}.pg-seg-btn{border:none;background:none;font:inherit;font-size:13px;font-weight:600;color:var(--text-muted);padding:7px 14px;border-radius:8px;cursor:pointer;transition:background .15s,color .15s}.pg-seg-btn:hover{color:var(--text)}.pg-seg-btn.is-on{background:var(--surface);color:var(--accent-text);box-shadow:0 1px 3px rgba(17,24,39,.1)}.pg-strength{display:flex;flex-direction:column;gap:6px}.pg-strength-track{height:8px;border-radius:var(--radius-pill);background:var(--surface-2);border:1px solid var(--border);overflow:hidden}.pg-strength-track span{display:block;height:100%;border-radius:var(--radius-pill);transition:width .2s,background .2s}.pg-strength-track.lvl-1 span{background:#e0564f}.pg-strength-track.lvl-2 span{background:#e8a13a}.pg-strength-track.lvl-3 span{background:#4cae7a}.pg-strength-track.lvl-4 span{background:linear-gradient(135deg,var(--accent),var(--accent-2))}.pg-strength-label{font-size:13px;font-weight:600;color:var(--text-muted)}.pg-actions{display:flex;align-items:center;gap:14px;flex-wrap:wrap}.pg-meta{font-size:13px}.pg-btn-ghost{background:var(--surface);color:var(--accent-text);border:1px solid var(--border-strong);box-shadow:none}.pg-btn-ghost:hover{filter:none;background:var(--accent-soft);box-shadow:none}.pg-results{display:flex;flex-direction:column;gap:10px}.pg-results-head{display:flex;align-items:center;justify-content:space-between;gap:12px}.pg-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.pg-item{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm)}.pg-value{flex:1 1;min-width:0;font-family:ui-monospace,SFMono-Regular,SF Mono,Menlo,Consolas,monospace;font-size:15px;color:var(--text);word-break:break-all;line-height:1.5;background:none;padding:0}.pg-copy{flex-shrink:0}@media (max-width:560px){.pg-tabs{display:flex;width:100%}.pg-tab{flex:1 1;padding:9px 0}.pg-item{flex-direction:column;align-items:stretch}}:root{color-scheme:light}[data-theme=dark]{color-scheme:dark;--bg-1:#0e1116;--bg-2:#141922;--surface:#171d26;--surface-2:#1e242e;--text:#e6e8eb;--text-muted:#98a2af;--border:rgba(255,255,255,0.1);--border-strong:rgba(255,255,255,0.2);--accent:#475569;--accent-strong:#5b6b80;--accent-soft:#1f2733;--accent-text:#cbd5e1;--accent-glow:rgba(148,163,184,0.18);--accent-2:#64748b;--accent-2-glow:rgba(100,116,139,0.16);--danger-soft:#3a1f1f;--danger-text:#f4a8a8;--success:#4ade80;--success-soft:#16271c;--success-text:#86efac;--shadow-sm:0 1px 2px rgba(0,0,0,0.4);--shadow-md:0 1px 3px rgba(0,0,0,0.5),0 1px 2px rgba(0,0,0,0.3);--shadow-lg:0 8px 24px rgba(0,0,0,0.55),0 2px 6px rgba(0,0,0,0.35)}[data-theme=dark] .btn{color:#fff}[data-theme=dark] body:before{background-image:radial-gradient(rgba(255,255,255,.04) 1px,transparent 0)}[data-theme=dark] .mobile-bar,[data-theme=dark] .sidebar{background:rgba(23,29,38,.82)}.modal-backdrop{position:fixed;inset:0;z-index:60;background:rgba(10,14,24,.5);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:flex-start;justify-content:center;padding:64px 16px 24px;overflow-y:auto}.modal{width:100%;max-width:460px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:22px 22px 18px}.modal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}.modal-head h2{font-size:18px;font-weight:600;letter-spacing:-.01em;margin:0}.modal-form{margin-top:8px}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:18px}.drawer-name-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:12px;gap:12px}.drawer-name-form .field{margin:0 0 12px}.theme-toggle{width:100%;margin-top:6px;display:inline-flex;align-items:center;justify-content:center;gap:8px;background:var(--surface);color:var(--text-muted);border:1px solid var(--border-strong);border-radius:var(--radius-sm);padding:7px 10px;font-size:13px;font-family:inherit;cursor:pointer;transition:border-color .15s,color .15s,background .15s}.theme-toggle:hover{color:var(--text);border-color:var(--accent)}