*,*:before,*:after{box-sizing:border-box}html,body{height:100%}body{margin:0;font-family:var(--font-body);background:var(--color-bg);color:var(--color-text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,h2,h3,h4,h5,h6,p{margin:0}ul,ol{list-style:none;margin:0;padding:0}button{font:inherit;background:none;border:none;color:inherit;cursor:pointer;padding:0}button:disabled{cursor:not-allowed;opacity:.7}img,svg{display:block;max-width:100%}a{color:inherit;text-decoration:none}:root{--color-bg: #0a0a0a;--color-bg-elevated: #141418;--color-bg-raised: #1c1c22;--color-border: #2a2a33;--color-border-strong: #3a3a45;--color-text: #f2f2f4;--color-text-dim: #a0a0aa;--color-text-muted: #6a6a74;--color-accent: #c9a961;--color-green: #22c55e;--color-amber: #f59e0b;--color-red: #ef4444;--color-grey: #6a6a74;--color-green-bg: rgba(34, 197, 94, .08);--color-amber-bg: rgba(245, 158, 11, .1);--color-red-bg: rgba(239, 68, 68, .12);--color-grey-bg: rgba(106, 106, 116, .08);--color-red-glow: rgba(239, 68, 68, .4);--font-display: "Syne", system-ui, sans-serif;--font-body: "DM Sans", system-ui, sans-serif;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 24px;--space-6: 32px;--space-7: 48px;--space-8: 64px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--shadow-tile: 0 1px 3px rgba(0, 0, 0, .3);--shadow-tile-hover: 0 4px 12px rgba(0, 0, 0, .5)}.noc-page{min-height:100vh;background:var(--color-bg);color:var(--color-text);display:flex;flex-direction:column}.noc-page.noc-fullscreen{padding:0}.noc-page.noc-fullscreen .noc-header{padding:var(--space-4) var(--space-6)}.noc-page.noc-fullscreen .noc-grid{padding:var(--space-5)}.noc-header{display:flex;align-items:baseline;justify-content:space-between;padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--color-border);gap:var(--space-5);flex-wrap:wrap}.noc-title{font-family:var(--font-display);font-size:2rem;font-weight:700;letter-spacing:-.01em;color:var(--color-text)}.noc-subtitle{font-family:var(--font-body);font-size:.875rem;color:var(--color-text-dim);margin-top:var(--space-1)}.noc-controls{display:inline-flex;align-items:center;gap:var(--space-3)}.noc-live-banner{display:inline-flex;align-items:center;gap:var(--space-2);font-family:var(--font-body);font-size:.75rem;color:var(--color-green);text-transform:uppercase;letter-spacing:.1em;font-weight:600}.noc-live-banner:before{content:"";width:8px;height:8px;border-radius:999px;background:var(--color-green);box-shadow:0 0 #22c55e80;animation:noc-live-pulse 2s ease-in-out infinite}@keyframes noc-live-pulse{0%,to{box-shadow:0 0 #22c55e80}50%{box-shadow:0 0 0 6px #22c55e00}}.noc-grid{display:grid;gap:var(--space-4);padding:var(--space-5);grid-template-columns:1fr}@media (min-width: 640px){.noc-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (min-width: 1024px){.noc-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (min-width: 1440px){.noc-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}@media (min-width: 1920px){.noc-grid{grid-template-columns:repeat(5,minmax(0,1fr))}}.noc-tile{display:flex;flex-direction:column;gap:var(--space-3);padding:var(--space-5);border-radius:var(--radius-lg);border:1px solid var(--color-border);background:var(--color-bg-elevated);box-shadow:var(--shadow-tile);transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease,background-color .2s ease;min-height:160px;text-align:left;width:100%}.noc-tile:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-tile-hover)}.noc-tile:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.noc-tile--green{background:var(--color-green-bg);border-left:4px solid var(--color-green)}.noc-tile--amber{background:var(--color-amber-bg);border-left:4px solid var(--color-amber)}.noc-tile--red{background:var(--color-red-bg);border-left:4px solid var(--color-red)}.noc-tile--grey{background:var(--color-grey-bg);border-left:4px solid var(--color-grey)}.noc-tile__name{font-family:var(--font-display);font-size:1.5rem;font-weight:700;letter-spacing:.01em;color:var(--color-text)}.noc-tile__stats{display:flex;flex-wrap:wrap;gap:var(--space-4);margin-top:var(--space-2)}.noc-tile__stat{display:flex;flex-direction:column;gap:var(--space-1);min-width:0}.noc-tile__stat-value{font-family:var(--font-display);font-size:1.75rem;font-weight:700;color:var(--color-text);font-variant-numeric:tabular-nums;line-height:1}.noc-tile__stat-label{font-family:var(--font-body);font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted)}.noc-tile__sla{display:flex;align-items:baseline;justify-content:space-between;gap:var(--space-3);margin-top:auto;padding-top:var(--space-3);border-top:1px solid var(--color-border);font-family:var(--font-body);font-size:.875rem}.noc-tile__sla-label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.08em;font-size:.75rem}.noc-tile__sla-value{color:var(--color-text);font-variant-numeric:tabular-nums;font-weight:600}@keyframes noc-pulse{0%,to{box-shadow:0 0 0 0 var(--color-red-glow),var(--shadow-tile)}50%{box-shadow:0 0 0 8px #ef444400,var(--shadow-tile)}}.noc-tile--pulse{animation:noc-pulse 2s ease-in-out infinite}@keyframes noc-badge-pulse{0%,to{box-shadow:0 0 0 0 var(--color-red-glow)}50%{box-shadow:0 0 0 4px #ef444400}}.noc-nav-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;border-radius:999px;font-family:var(--font-body);font-size:.75rem;font-weight:700;background:var(--color-red);color:#fff;font-variant-numeric:tabular-nums;animation:noc-badge-pulse 2s ease-in-out infinite}.noc-nav-badge--zero{background:var(--color-grey-bg);color:var(--color-text-muted);animation:none}@media (prefers-reduced-motion: reduce){.noc-tile--pulse,.noc-nav-badge,.noc-live-banner:before{animation:none}}.noc-fullscreen-toggle{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border:1px solid var(--color-border-strong);border-radius:var(--radius-md);color:var(--color-text-dim);font-family:var(--font-body);font-size:.875rem;transition:border-color .15s ease,color .15s ease,background-color .15s ease;background:transparent}.noc-fullscreen-toggle:hover{border-color:var(--color-accent);color:var(--color-text)}.noc-fullscreen-toggle:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.noc-loading,.noc-error,.noc-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-3);padding:var(--space-8);text-align:center;color:var(--color-text-dim);font-family:var(--font-body)}.noc-error{border-top:2px solid var(--color-red);background:var(--color-red-bg);border-radius:var(--radius-md);margin:var(--space-5)}.noc-error button{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border:1px solid var(--color-border-strong);border-radius:var(--radius-md);color:var(--color-text-dim);font-family:var(--font-body);font-size:.875rem;transition:border-color .15s ease,color .15s ease;background:transparent}.noc-error button:hover{border-color:var(--color-accent);color:var(--color-text)}.noc-error button:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}@media (max-width: 639px){.noc-header{flex-direction:column;align-items:flex-start;gap:var(--space-3);padding:var(--space-4)}.noc-title{font-size:1.5rem}.noc-grid,.noc-tile{padding:var(--space-4)}.noc-tile__stats{gap:var(--space-3)}}.topology-page{display:flex;flex-direction:column;min-height:100vh;background:var(--color-bg);color:var(--color-text);font-family:var(--font-body)}.topology-page--fullscreen{height:100vh;min-height:100vh;overflow:hidden}.topology-header{position:sticky;top:0;z-index:10;display:flex;align-items:center;justify-content:space-between;gap:var(--space-5);padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--color-border);background:var(--color-bg)}.topology-header__left{display:flex;align-items:center;gap:var(--space-3);min-width:0}.topology-header__title{font-family:var(--font-display);font-size:1.5rem;font-weight:700;letter-spacing:-.01em;color:var(--color-text);margin:0}.topology-header__center{display:flex;align-items:center;justify-content:center}.topology-header__status{display:flex;align-items:center;gap:var(--space-4);justify-content:flex-end;font-size:.8125rem;color:var(--color-text-dim)}.topology-header__refresh{text-transform:uppercase;letter-spacing:.08em;font-size:.6875rem;color:var(--color-text-muted)}.topology-header__updated{font-variant-numeric:tabular-nums}.topology-header__live{display:inline-flex;align-items:center;gap:var(--space-2);font-size:.6875rem;text-transform:uppercase;letter-spacing:.1em;font-weight:600;color:var(--color-green)}.topology-header__live-dot{width:8px;height:8px;border-radius:999px;background:var(--color-green);box-shadow:0 0 #22c55e80;animation:topology-live-pulse 2s ease-in-out infinite}@keyframes topology-live-pulse{0%,to{box-shadow:0 0 #22c55e80}50%{box-shadow:0 0 0 6px #22c55e00}}.topology-canvas-wrap{position:relative;flex:1;overflow:hidden;background:var(--color-bg);cursor:grab}.topology-canvas-wrap.is-panning{cursor:grabbing}.topology-page--noc .topology-canvas-wrap{cursor:default}.topology-page--execution .topology-canvas-wrap{cursor:grab}.topology-page--execution .topology-canvas-wrap.is-panning{cursor:grabbing}.topology-canvas{display:block;width:100%;height:100%}.topology-node{fill-opacity:.85;stroke-width:2;transition:fill-opacity .15s ease,filter .15s ease,stroke-width .15s ease}.topology-page--execution .topology-node:hover{fill-opacity:1;filter:brightness(1.1)}.topology-node:focus-visible{outline:none;stroke:var(--color-accent);stroke-width:3}.topology-node--green{fill:var(--color-green-bg);stroke:var(--color-green)}.topology-node--amber{fill:var(--color-amber-bg);stroke:var(--color-amber)}.topology-node--red{fill:var(--color-red-bg);stroke:var(--color-red)}.topology-node--grey{fill:var(--color-grey-bg);stroke:var(--color-grey)}.topology-node__label{font-family:var(--font-display);font-size:.875rem;text-anchor:middle;fill:var(--color-text);pointer-events:none}@keyframes topology-node-pulse{0%,to{filter:drop-shadow(0 0 0 var(--color-red-glow));stroke-width:2}50%{filter:drop-shadow(0 0 6px var(--color-red-glow));stroke-width:3}}.topology-node--pulse{animation:topology-node-pulse 2s ease-in-out infinite}.topology-link{stroke-linecap:round;stroke-width:2;fill:none;transition:stroke .2s ease,stroke-width .2s ease}.topology-link--green{stroke:var(--color-green)}.topology-link--amber{stroke:var(--color-amber)}.topology-link--red{stroke:var(--color-red);stroke-width:3}.topology-link--grey{stroke:var(--color-grey);stroke-dasharray:4 4}.topology-site{fill:none;stroke:var(--color-border-strong);stroke-width:1;stroke-dasharray:6 4;rx:12;ry:12;opacity:.5}.topology-site__label{font-family:var(--font-display);font-size:.75rem;text-transform:uppercase;letter-spacing:.1em;fill:var(--color-text-dim)}.topology-legend-panel{position:absolute;bottom:var(--space-5);left:var(--space-5);z-index:5;display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-3) var(--space-4);background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-tile);font-size:.75rem;color:var(--color-text-dim)}.topology-legend-panel__row{display:flex;align-items:center;gap:var(--space-2)}.topology-legend-panel__dot{width:10px;height:10px;border-radius:999px;flex-shrink:0}.topology-legend-panel__dot--green{background:var(--color-green)}.topology-legend-panel__dot--amber{background:var(--color-amber)}.topology-legend-panel__dot--red{background:var(--color-red)}.topology-legend-panel__dot--grey{background:var(--color-grey)}.topology-legend-panel__label{font-family:var(--font-body);letter-spacing:.02em}.topology-overlay{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:4}.topology-badge{position:absolute;display:inline-flex;align-items:center;justify-content:center;font-family:var(--font-body);font-size:.75rem;line-height:1;padding:2px 6px;border-radius:999px;background:var(--color-bg-elevated);border:1px solid var(--color-border);color:var(--color-text);font-variant-numeric:tabular-nums;white-space:nowrap;transform:translate(-50%,-50%)}.topology-badge--incident{background:var(--color-red);border-color:var(--color-red);color:#fff;font-weight:700;min-width:20px;height:20px;padding:0 6px}.topology-badge--sla{background:var(--color-bg-raised);border-color:var(--color-border-strong);color:var(--color-text-dim)}.topology-badge--sla-breached{color:var(--color-red);border-color:var(--color-red)}.mode-toggle{display:inline-flex;align-items:center;gap:2px;padding:2px;border:1px solid var(--color-border-strong);border-radius:var(--radius-md);background:var(--color-bg-raised)}.mode-toggle__btn{padding:var(--space-2) var(--space-4);border:none;border-radius:var(--radius-sm);background:transparent;color:var(--color-text-dim);font-family:var(--font-body);font-size:.8125rem;font-weight:600;cursor:pointer;transition:background-color .15s ease,color .15s ease}.mode-toggle__btn:hover{color:var(--color-text)}.mode-toggle__btn--active{background:var(--color-accent);color:var(--color-bg)}.mode-toggle__btn--active:hover{color:var(--color-bg)}.mode-toggle__btn:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}@media (max-width: 639px){.topology-header{flex-direction:column;align-items:flex-start;gap:var(--space-3);padding:var(--space-3) var(--space-4)}.topology-header__center,.topology-header__status{width:100%;justify-content:flex-start;flex-wrap:wrap}.topology-header__title{font-size:1.25rem}.topology-legend-panel{bottom:auto;left:auto;top:var(--space-4);right:var(--space-4)}}@media (prefers-reduced-motion: reduce){.topology-header__live-dot,.topology-node--pulse{animation:none}.topology-node,.topology-link,.mode-toggle__btn{transition:none}}.action-menu{position:absolute;background:var(--color-bg-elevated);border:1px solid var(--color-border-strong);border-radius:var(--radius-md);padding:4px 0;min-width:220px;box-shadow:0 12px 32px #0009;z-index:100;font-family:var(--font-body);display:flex;flex-direction:column}.action-menu__item{width:100%;background:transparent;border:0;text-align:left;padding:10px 16px;display:flex;flex-direction:column;gap:2px;cursor:pointer;font-family:var(--font-body);font-size:.875rem;transition:background .1s ease;outline:none}.action-menu__item:hover,.action-menu__item:focus{background:var(--color-bg-raised)}.action-menu__item--destructive .action-menu__item-label:before{content:"!";display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;border-radius:50%;background:var(--color-red);color:var(--color-bg);font-size:.625rem;font-weight:700;margin-right:8px;vertical-align:middle}.action-menu__item-label{color:var(--color-text);font-weight:600}.action-menu__item-desc{color:var(--color-text-dim);font-size:.75rem}.action-menu__divider{height:1px;border-top:1px solid var(--color-border);margin:4px 0}.action-confirm{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#0009;z-index:200}.action-confirm__dialog{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:32px;max-width:480px;width:90%;box-shadow:0 24px 64px #000000b3;font-family:var(--font-body)}.action-confirm__title{font-family:var(--font-display);font-size:1.25rem;font-weight:700;margin:0 0 8px;color:var(--color-text)}.action-confirm__body{font-family:var(--font-body);font-size:.875rem;color:var(--color-text-dim);margin:0 0 24px}.action-confirm__field{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.action-confirm__label{font-size:.75rem;color:var(--color-text-dim);text-transform:uppercase;letter-spacing:.05em}.action-confirm__input{width:100%;padding:10px;background:var(--color-bg-raised);border:1px solid var(--color-border-strong);border-radius:var(--radius-sm);color:var(--color-text);font-family:ui-monospace,SF Mono,Menlo,Consolas,monospace;font-size:.875rem;outline:none}.action-confirm__input:focus{border-color:var(--color-accent)}.action-confirm__error{color:var(--color-red);font-size:.75rem;margin-top:4px}.action-confirm__actions{display:flex;gap:12px;justify-content:flex-end;margin-top:24px}.action-confirm__btn{padding:10px 20px;border-radius:var(--radius-md);font-size:.875rem;font-family:var(--font-body);border:1px solid var(--color-border-strong);background:transparent;color:var(--color-text);cursor:pointer;transition:background .12s ease,color .12s ease,border-color .12s ease}.action-confirm__btn:disabled{opacity:.6;cursor:not-allowed}.action-confirm__btn--primary{background:var(--color-accent);color:var(--color-bg);border-color:var(--color-accent)}.action-confirm__btn--danger{border-color:var(--color-red);color:var(--color-red);background:transparent}.action-confirm__btn--danger.action-confirm__btn--armed{background:var(--color-red);color:#fff}.action-confirm__ticket-link{color:var(--color-accent);text-decoration:underline}.action-confirm__status{font-size:.875rem;color:var(--color-text);display:flex;align-items:center;gap:8px}.action-confirm__status--success{color:var(--color-green)}.action-confirm__status--failure{color:var(--color-red)}.action-confirm__rollback{padding:8px 12px;background:var(--color-amber-bg);border-left:3px solid var(--color-amber);font-size:.8125rem;color:var(--color-text);margin-top:12px;border-radius:var(--radius-sm)}.action-confirm__spinner{width:12px;height:12px;border-radius:50%;border:2px solid var(--color-border-strong);border-top-color:var(--color-accent);display:inline-block;animation:action-spin .9s linear infinite}@keyframes action-spin{to{transform:rotate(360deg)}}.execution-pulse{pointer-events:none;position:absolute;width:60px;height:60px;border-radius:50%;transform:translate(-50%,-50%);z-index:50}.execution-pulse--submitting,.execution-pulse--polling{border:3px solid var(--color-amber);animation:pulse-ring 1.2s ease-out infinite}.execution-pulse--success{border:3px solid var(--color-green);animation:pulse-success .8s ease-out 3 forwards}.execution-pulse--failure{border:3px solid var(--color-red);animation:pulse-failure .8s ease-out infinite}.execution-pulse--rolled-back:after{content:"Auto-rollback complete";position:absolute;left:50%;top:100%;transform:translate(-50%,8px);background:var(--color-bg-raised);color:var(--color-text);padding:4px 8px;border-radius:var(--radius-sm);font-size:.6875rem;white-space:nowrap;border:1px solid var(--color-border)}@keyframes pulse-ring{0%{transform:translate(-50%,-50%) scale(.6);opacity:1}to{transform:translate(-50%,-50%) scale(1.6);opacity:0}}@keyframes pulse-success{0%{transform:translate(-50%,-50%) scale(.8);opacity:1}to{transform:translate(-50%,-50%) scale(1.5);opacity:0}}@keyframes pulse-failure{0%{transform:translate(-50%,-50%) scale(.7);opacity:1}to{transform:translate(-50%,-50%) scale(1.4);opacity:.2}}@media (prefers-reduced-motion: reduce){.execution-pulse--submitting,.execution-pulse--polling,.execution-pulse--success,.execution-pulse--failure,.action-confirm__spinner{animation:none}}.detail-panel{position:fixed;top:0;right:0;bottom:0;width:420px;max-width:90vw;display:flex;flex-direction:column;background:var(--color-bg-raised, #16181d);border-left:1px solid var(--color-border-strong, rgba(255, 255, 255, .14));box-shadow:-8px 0 32px #00000059;transform:translate(100%);transition:transform .25s ease;z-index:150;color:var(--color-text, #e6e6ea)}.detail-panel--open{transform:translate(0)}.detail-panel__header{display:flex;align-items:center;justify-content:space-between;padding:24px;border-bottom:1px solid var(--color-border, rgba(255, 255, 255, .08));flex-shrink:0}.detail-panel__title-group{display:flex;align-items:center;gap:12px;min-width:0}.detail-panel__title{font-family:Syne,system-ui,sans-serif;font-size:1.125rem;font-weight:700;margin:0;color:var(--color-text, #e6e6ea);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.detail-panel__status{display:inline-block;padding:2px 10px;border-radius:999px;font-size:.6875rem;text-transform:uppercase;letter-spacing:.08em;background:var(--color-grey-bg, rgba(120, 130, 150, .18));color:var(--color-grey, #8892a6)}.detail-panel__status--green{background:var(--color-green-bg, rgba(55, 200, 130, .16));color:var(--color-green, #37c882)}.detail-panel__status--amber{background:var(--color-amber-bg, rgba(240, 175, 60, .16));color:var(--color-amber, #f0af3c)}.detail-panel__status--red{background:var(--color-red-bg, rgba(235, 80, 85, .18));color:var(--color-red, #eb5055)}.detail-panel__status--grey{background:var(--color-grey-bg, rgba(120, 130, 150, .18));color:var(--color-grey, #8892a6)}.detail-panel__close{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;border:1px solid var(--color-border, rgba(255, 255, 255, .08));color:var(--color-text-dim, #9aa0ad);width:32px;height:32px;border-radius:6px;font-size:1.25rem;line-height:1;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:background .15s ease,color .15s ease}.detail-panel__close:hover,.detail-panel__close:focus-visible{background:var(--color-bg-raised-2, rgba(255, 255, 255, .06));color:var(--color-text, #e6e6ea);outline:none}.detail-panel__body{display:flex;flex-direction:column;flex:1;min-height:0}.detail-panel__tabs{display:flex;flex-direction:row;border-bottom:1px solid var(--color-border, rgba(255, 255, 255, .08));flex-shrink:0}.detail-panel__tab{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;border:none;border-bottom:2px solid transparent;padding:12px 16px;font-size:.8125rem;font-family:inherit;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-dim, #9aa0ad);cursor:pointer;transition:color .15s ease,border-color .15s ease}.detail-panel__tab:hover,.detail-panel__tab:focus-visible{color:var(--color-text, #e6e6ea);outline:none}.detail-panel__tab--active{color:var(--color-accent, #7ab8ff);border-bottom-color:var(--color-accent, #7ab8ff)}.detail-panel__content{padding:20px;overflow-y:auto;flex:1;min-height:0}.detail-panel__list{display:flex;flex-direction:column;gap:12px}.detail-panel__item{display:flex;flex-direction:column;gap:6px;padding:12px;background:var(--color-bg-raised-2, rgba(255, 255, 255, .04));border:1px solid var(--color-border, rgba(255, 255, 255, .08));border-radius:6px;font-size:.8125rem}.detail-panel__item-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.detail-panel__item-number{font-family:JetBrains Mono,ui-monospace,monospace;font-size:.75rem;color:var(--color-text-dim, #9aa0ad)}.detail-panel__item-title{color:var(--color-text, #e6e6ea);font-weight:500}.detail-panel__item-meta{font-size:.75rem;color:var(--color-text-dim, #9aa0ad)}.detail-panel__pill{display:inline-block;padding:2px 8px;border-radius:999px;font-size:.6875rem;text-transform:uppercase;letter-spacing:.08em;background:var(--color-grey-bg, rgba(120, 130, 150, .18));color:var(--color-grey, #8892a6)}.detail-panel__pill--p1{background:var(--color-red-bg, rgba(235, 80, 85, .18));color:var(--color-red, #eb5055)}.detail-panel__pill--p2{background:var(--color-amber-bg, rgba(240, 175, 60, .16));color:var(--color-amber, #f0af3c)}.detail-panel__pill--success{background:var(--color-green-bg, rgba(55, 200, 130, .16));color:var(--color-green, #37c882)}.detail-panel__pill--failure{background:var(--color-red-bg, rgba(235, 80, 85, .18));color:var(--color-red, #eb5055)}.detail-panel__pill--pending{background:var(--color-amber-bg, rgba(240, 175, 60, .16));color:var(--color-amber, #f0af3c)}.detail-panel__empty{text-align:center;padding:32px 12px;color:var(--color-text-dim, #9aa0ad);font-size:.8125rem}.detail-panel__vault-note{margin-top:16px;font-style:italic;font-size:.75rem;color:var(--color-text-dim, #9aa0ad);text-align:center}.detail-panel__skeleton{height:48px;border-radius:6px;background:linear-gradient(90deg,#ffffff0a,#ffffff14,#ffffff0a);background-size:200% 100%;animation:detail-panel-skeleton 1.4s ease-in-out infinite}.detail-panel__retry{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;border:1px solid var(--color-border, rgba(255, 255, 255, .08));color:var(--color-text, #e6e6ea);padding:8px 16px;border-radius:6px;cursor:pointer;font:inherit;margin:0 auto;display:block}@keyframes detail-panel-skeleton{0%{background-position:200% 0}to{background-position:-200% 0}}@media (max-width: 640px){.detail-panel{width:100vw;max-width:100vw}}@media (prefers-reduced-motion: reduce){.detail-panel{transition:none}.detail-panel__skeleton{animation:none}}.endpoints-page{min-height:100vh;display:flex;flex-direction:column;background:var(--color-bg);color:var(--color-text);font-family:var(--font-body);padding:var(--space-5) var(--space-5) var(--space-6)}.endpoints-header{display:flex;flex-direction:row;align-items:flex-end;justify-content:space-between;gap:var(--space-4);padding-bottom:var(--space-4);margin-bottom:var(--space-4);border-bottom:1px solid var(--color-border)}.endpoints-title{font-family:var(--font-display);font-size:2rem;font-weight:700;letter-spacing:-.01em;margin:0;color:var(--color-text)}.endpoints-subtitle{margin:var(--space-1) 0 0;font-size:.875rem;color:var(--color-text-dim)}.endpoints-meta{display:flex;flex-direction:row;gap:var(--space-4);font-size:.875rem;color:var(--color-text-dim);font-variant-numeric:tabular-nums}.endpoints-list{display:flex;flex-direction:column;gap:var(--space-2);padding:0}.endpoints-empty,.endpoints-loading,.endpoints-error{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-3);padding:var(--space-7) var(--space-4);color:var(--color-text-dim);text-align:center}.endpoints-error__retry{padding:8px 16px;background:var(--color-bg-raised);border:1px solid var(--color-border-strong);border-radius:var(--radius-md);color:var(--color-text);font-family:var(--font-body);cursor:pointer}.endpoint-row{display:flex;flex-direction:row;align-items:center;gap:var(--space-4);padding:var(--space-4) var(--space-5);background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:background .15s ease,transform .15s ease,border-color .15s ease}.endpoint-row:hover{background:var(--color-bg-raised);transform:translateY(-1px);border-color:var(--color-border-strong)}.endpoint-row:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.endpoint-row__main{display:flex;flex-direction:column;gap:2px;min-width:0}.endpoint-row__hostname{font-family:var(--font-display);font-size:1.125rem;font-weight:700;color:var(--color-text)}.endpoint-row__client{font-family:var(--font-body);font-size:.8125rem;color:var(--color-text-dim)}.endpoint-row__meta{display:flex;flex-direction:row;gap:var(--space-4);align-items:center;margin-left:auto;font-size:.8125rem;color:var(--color-text-dim);font-variant-numeric:tabular-nums}.endpoint-row__agent{padding:2px 8px;background:var(--color-bg-raised);border-radius:var(--radius-sm);color:var(--color-text-dim)}.endpoint-status{display:inline-block;padding:2px 10px;border-radius:999px;font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;font-weight:600}.endpoint-status--online{background:var(--color-green-bg);color:var(--color-green)}.endpoint-status--stale{background:var(--color-amber-bg);color:var(--color-amber)}.endpoint-status--offline{background:var(--color-grey-bg);color:var(--color-grey)}.endpoint-detail-panel{position:fixed;top:0;right:0;bottom:0;width:480px;max-width:90vw;background:var(--color-bg-elevated);border-left:1px solid var(--color-border-strong);transform:translate(100%);transition:transform .25s ease;z-index:150;display:flex;flex-direction:column}.endpoint-detail-panel--open{transform:translate(0)}.endpoint-detail-panel__header{display:flex;flex-direction:row;align-items:center;justify-content:space-between;padding:var(--space-5);border-bottom:1px solid var(--color-border)}.endpoint-detail-panel__title-group{display:flex;flex-direction:row;align-items:center;gap:var(--space-3);min-width:0}.endpoint-detail-panel__title{font-family:var(--font-display);font-size:1.25rem;font-weight:700;margin:0;color:var(--color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.endpoint-detail-panel__close{background:transparent;border:none;color:var(--color-text-dim);font-size:1.5rem;line-height:1;cursor:pointer;padding:4px 10px;border-radius:var(--radius-sm)}.endpoint-detail-panel__close:hover{background:var(--color-bg-raised);color:var(--color-text)}.endpoint-detail-panel__body{display:flex;flex-direction:column;flex:1;min-height:0}.endpoint-detail-panel__tabs{display:flex;flex-direction:row;border-bottom:1px solid var(--color-border)}.endpoint-detail-panel__tab{padding:var(--space-3) var(--space-4);background:transparent;border:none;border-bottom:2px solid transparent;color:var(--color-text-dim);text-transform:uppercase;font-size:.8125rem;letter-spacing:.08em;font-family:var(--font-body);cursor:pointer}.endpoint-detail-panel__tab:hover{color:var(--color-text)}.endpoint-detail-panel__tab--active{color:var(--color-accent);border-bottom-color:var(--color-accent)}.endpoint-detail-panel__content{padding:var(--space-5);overflow-y:auto;flex:1}.endpoint-detail-panel__skeleton{height:24px;background:var(--color-bg-raised);border-radius:var(--radius-sm);margin-bottom:var(--space-3);animation:endpoint-skeleton-pulse 1.4s ease-in-out infinite}@keyframes endpoint-skeleton-pulse{0%,to{opacity:.6}50%{opacity:1}}.endpoint-detail-panel__empty{color:var(--color-text-dim);padding:var(--space-4);text-align:center}.endpoint-detail-panel__retry{margin-top:var(--space-3);padding:8px 16px;background:var(--color-bg-raised);border:1px solid var(--color-border-strong);border-radius:var(--radius-md);color:var(--color-text);font-family:var(--font-body);cursor:pointer}.health-gauge{display:flex;flex-direction:column;align-items:center;gap:4px}.health-gauge__svg{width:120px;height:80px}.health-gauge__arc-bg{stroke:var(--color-border);fill:none;stroke-width:10}.health-gauge__arc-fill{fill:none;stroke-width:10;stroke-linecap:round;transition:stroke-dashoffset .4s ease}.health-gauge__arc--ok{stroke:var(--color-green)}.health-gauge__arc--warn{stroke:var(--color-amber)}.health-gauge__arc--crit{stroke:var(--color-red)}.health-gauge__value{font-family:var(--font-display);font-size:1.25rem;font-weight:700;color:var(--color-text)}.health-gauge__label{font-family:var(--font-body);font-size:.6875rem;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-dim)}.endpoint-health-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4);margin-bottom:var(--space-5)}.endpoint-health-text{font-family:var(--font-body);font-size:.8125rem;color:var(--color-text-dim);display:grid;grid-template-columns:auto 1fr;gap:var(--space-2) var(--space-4)}.endpoint-health-text>div:nth-child(odd){color:var(--color-text-muted);text-transform:uppercase;font-size:.6875rem;letter-spacing:.08em}.endpoint-health-text>div:nth-child(2n){color:var(--color-text)}.patch-status{padding:var(--space-4);background:var(--color-bg-raised);border:1px solid var(--color-border);border-radius:var(--radius-sm)}.patch-status__ok{color:var(--color-green);font-weight:600;font-size:1rem;margin-bottom:4px}.patch-status__pending{color:var(--color-amber);font-weight:600;font-size:1rem;margin-bottom:4px}.patch-status__meta{color:var(--color-text-dim);font-size:.8125rem}.command-dispatch{background:var(--color-bg-raised);padding:var(--space-4);border-radius:var(--radius-md);border:1px solid var(--color-border);margin-bottom:var(--space-4);display:flex;flex-direction:column;gap:var(--space-3)}.command-dispatch__row{display:flex;flex-direction:column;gap:var(--space-2)}.command-dispatch__label{font-size:.6875rem;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted);font-family:var(--font-body)}.command-dispatch__select,.command-dispatch__input{width:100%;padding:8px 12px;background:var(--color-bg);border:1px solid var(--color-border-strong);border-radius:var(--radius-sm);color:var(--color-text);font-family:var(--font-body);font-size:.875rem}.command-dispatch__select:focus-visible,.command-dispatch__input:focus-visible{outline:2px solid var(--color-accent);outline-offset:1px}.command-dispatch__description{margin:0;font-size:.8125rem;color:var(--color-text-dim)}.command-dispatch__error{color:var(--color-red);font-size:.8125rem;padding:var(--space-2) var(--space-3);background:var(--color-red-bg);border-radius:var(--radius-sm)}.command-dispatch__submit{padding:10px 20px;background:var(--color-accent);color:var(--color-bg);border:none;border-radius:var(--radius-md);font-family:var(--font-body);font-weight:600;cursor:pointer}.command-dispatch__submit:hover{filter:brightness(1.1)}.command-history{display:flex;flex-direction:column;gap:var(--space-2)}.command-history__empty{color:var(--color-text-dim);padding:var(--space-4);text-align:center}.command-history__item{display:flex;flex-direction:row;justify-content:space-between;align-items:center;gap:var(--space-3);padding:var(--space-3);background:var(--color-bg-raised);border:1px solid var(--color-border);border-radius:var(--radius-sm)}.command-history__action{font-family:var(--font-body);font-size:.875rem;font-weight:600;color:var(--color-text)}.command-history__meta{font-size:.75rem;color:var(--color-text-dim);margin-top:2px}.command-history__pill{padding:2px 10px;border-radius:999px;font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;font-weight:600;background:var(--color-bg)}.command-history__pill--queued{color:var(--color-amber)}.command-history__pill--running{color:var(--color-accent)}.command-history__pill--success{color:var(--color-green)}.command-history__pill--failure{color:var(--color-red)}.endpoint-confirm{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:200;padding:var(--space-4)}.endpoint-confirm__dialog{background:var(--color-bg-elevated);border:1px solid var(--color-border-strong);border-radius:var(--radius-lg);padding:var(--space-5);width:100%;max-width:460px;display:flex;flex-direction:column;gap:var(--space-3);box-shadow:var(--shadow-tile-hover)}.endpoint-confirm__title{font-family:var(--font-display);font-size:1.25rem;font-weight:700;margin:0;color:var(--color-text)}.endpoint-confirm__body{margin:0;color:var(--color-text-dim);font-size:.875rem}.endpoint-confirm__field{display:flex;flex-direction:column;gap:var(--space-2)}.endpoint-confirm__label{font-size:.6875rem;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted)}.endpoint-confirm__input{padding:8px 12px;background:var(--color-bg);border:1px solid var(--color-border-strong);border-radius:var(--radius-sm);color:var(--color-text);font-family:var(--font-body);font-size:.875rem}.endpoint-confirm__error{color:var(--color-red);font-size:.8125rem}.endpoint-confirm__preset{padding:8px 12px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);font-family:var(--font-body);font-size:.875rem;font-variant-numeric:tabular-nums}.endpoint-confirm__status{font-size:.875rem;color:var(--color-text-dim);display:flex;align-items:center;gap:var(--space-2)}.endpoint-confirm__status--success{color:var(--color-green)}.endpoint-confirm__status--failure{color:var(--color-red)}.endpoint-confirm__ticket-link{color:var(--color-accent);font-weight:600}.endpoint-confirm__rollback{font-size:.8125rem;color:var(--color-text-dim);padding:var(--space-2) var(--space-3);background:var(--color-bg-raised);border-radius:var(--radius-sm)}.endpoint-confirm__spinner{width:12px;height:12px;border-radius:999px;border:2px solid var(--color-border-strong);border-top-color:var(--color-accent);animation:endpoint-confirm-spin .8s linear infinite}@keyframes endpoint-confirm-spin{to{transform:rotate(360deg)}}.endpoint-confirm__actions{display:flex;flex-direction:row;justify-content:flex-end;gap:var(--space-2);margin-top:var(--space-2)}.endpoint-confirm__btn{padding:8px 16px;background:var(--color-bg-raised);border:1px solid var(--color-border-strong);border-radius:var(--radius-md);color:var(--color-text);font-family:var(--font-body);font-size:.875rem;cursor:pointer}.endpoint-confirm__btn:disabled{opacity:.6;cursor:not-allowed}.endpoint-confirm__btn--primary{background:var(--color-accent);color:var(--color-bg);border-color:var(--color-accent);font-weight:600}.endpoint-confirm__btn--danger{background:var(--color-red-bg);color:var(--color-red);border-color:var(--color-red);font-weight:600}.endpoint-confirm__btn--armed{box-shadow:0 0 0 3px var(--color-red-glow)}@media (max-width: 640px){.endpoint-detail-panel{width:100vw;max-width:100vw}.endpoint-health-grid{grid-template-columns:1fr}.endpoint-row{flex-wrap:wrap}.endpoint-row__meta{margin-left:0;gap:var(--space-3)}}@media (prefers-reduced-motion: reduce){.endpoint-detail-panel,.endpoint-row,.health-gauge__arc-fill{transition:none}.endpoint-confirm__spinner,.endpoint-detail-panel__skeleton{animation:none}}.patches-page{display:flex;flex-direction:column;min-height:100vh;background:var(--color-bg);color:var(--color-text);padding:var(--space-5);gap:var(--space-5)}.patches-header{display:flex;flex-direction:row;align-items:flex-end;justify-content:space-between;border-bottom:1px solid var(--color-border);padding-bottom:var(--space-4);gap:var(--space-4)}.patches-title{font-family:var(--font-display);font-size:2rem;font-weight:700;margin:0;color:var(--color-text)}.patches-subtitle{font-family:var(--font-body);font-size:.8125rem;color:var(--color-text-dim);margin:var(--space-1) 0 0 0}.patches-controls{display:flex;align-items:center;gap:var(--space-3)}.patches-empty{flex:1;display:flex;align-items:center;justify-content:center;color:var(--color-text-dim);font-family:var(--font-body);font-size:.9375rem;padding:var(--space-7)}.client-selector{display:flex;flex-direction:column;gap:var(--space-1)}.client-selector__label{font-family:var(--font-body);font-size:.6875rem;letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-dim)}.client-selector__select{background:var(--color-bg-raised);border:1px solid var(--color-border-strong);border-radius:var(--radius-sm);color:var(--color-text);padding:8px 12px;font-family:var(--font-body);font-size:.875rem;min-width:240px}.client-selector__select:focus{outline:2px solid var(--color-accent);outline-offset:1px}.client-selector__error{font-family:var(--font-body);font-size:.75rem;color:var(--color-red)}.compliance-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-5)}@media (max-width: 1100px){.compliance-cards{grid-template-columns:repeat(2,1fr)}}@media (max-width: 640px){.compliance-cards{grid-template-columns:1fr}}.compliance-card{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-5);display:flex;flex-direction:column;gap:var(--space-1)}.compliance-card__label{font-family:var(--font-body);font-size:.6875rem;letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-dim)}.compliance-card__value{font-family:var(--font-display);font-size:2.5rem;font-weight:700;line-height:1.1;color:var(--color-text);font-variant-numeric:tabular-nums}.compliance-card__sub{font-family:var(--font-body);font-size:.8125rem;color:var(--color-text-dim);margin-top:var(--space-1)}.compliance-card--critical .compliance-card__value{color:var(--color-red)}.compliance-card--important .compliance-card__value{color:var(--color-amber)}.patch-endpoint-list{display:flex;flex-direction:column;gap:var(--space-2)}.patch-endpoint-list--empty,.patch-endpoint-list--error{padding:var(--space-5);background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-dim);font-family:var(--font-body);font-size:.875rem;text-align:center}.patch-endpoint-list__skeleton{height:60px;border-radius:var(--radius-md);background:var(--color-bg-elevated);border:1px solid var(--color-border);animation:patches-pulse 1.4s ease-in-out infinite}@keyframes patches-pulse{0%,to{opacity:.6}50%{opacity:1}}.patch-endpoint-row{display:flex;flex-direction:row;align-items:center;gap:var(--space-4);background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-4) var(--space-5);cursor:pointer;transition:background .18s ease,transform .18s ease,border-color .18s ease}.patch-endpoint-row:hover,.patch-endpoint-row:focus-visible{background:var(--color-bg-raised);transform:translateY(-1px);border-color:var(--color-border-strong);outline:none}.patch-endpoint-row:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.patch-endpoint-row__main{display:flex;flex-direction:row;align-items:center;gap:var(--space-3);min-width:0}.patch-endpoint-row__hostname{font-family:var(--font-display);font-size:1.125rem;font-weight:700;color:var(--color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.patch-endpoint-row__meta{display:flex;flex-direction:row;gap:var(--space-4);margin-left:auto;align-items:center;font-family:var(--font-body);font-size:.8125rem;color:var(--color-text-dim);font-variant-numeric:tabular-nums}.patch-endpoint-row__critical--nonzero{color:var(--color-red);font-weight:700}.patch-endpoint-row__reboot-btn{background:transparent;border:1px solid var(--color-border-strong);color:var(--color-text);border-radius:var(--radius-sm);padding:6px 12px;font-family:var(--font-body);font-size:.75rem;cursor:pointer;transition:background .15s ease}.patch-endpoint-row__reboot-btn:hover{background:var(--color-bg-raised)}.ring-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:999px;font-family:var(--font-body);font-size:.6875rem;letter-spacing:.08em;text-transform:uppercase;font-variant-numeric:tabular-nums;border:1px solid transparent}.ring-badge--ring0{background:#c9a9611f;color:var(--color-accent);border-color:#c9a96159}.ring-badge--ring1{background:var(--color-amber-bg);color:var(--color-amber);border-color:#f59e0b59}.ring-badge--ring2{background:var(--color-grey-bg);color:var(--color-grey);border-color:#6a6a7459}.pending-patches-panel{position:fixed;top:0;right:0;bottom:0;width:520px;max-width:100vw;background:var(--color-bg-elevated);border-left:1px solid var(--color-border);z-index:150;display:flex;flex-direction:column;transform:translate(100%);transition:transform .25s ease;box-shadow:var(--shadow-tile-hover)}.pending-patches-panel--open{transform:translate(0)}@media (prefers-reduced-motion: reduce){.pending-patches-panel{transition:none}}.pending-patches-panel__header{display:flex;flex-direction:row;align-items:flex-start;justify-content:space-between;padding:var(--space-5);border-bottom:1px solid var(--color-border);gap:var(--space-4)}.pending-patches-panel__title{font-family:var(--font-display);font-size:1.25rem;font-weight:700;margin:0;color:var(--color-text)}.pending-patches-panel__subtitle{font-family:var(--font-body);font-size:.75rem;color:var(--color-text-dim);margin-top:var(--space-1);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:360px}.pending-patches-panel__close{background:transparent;border:none;color:var(--color-text);font-size:1.5rem;line-height:1;cursor:pointer;padding:var(--space-1) var(--space-2)}.pending-patches-panel__close:hover{color:var(--color-accent)}.pending-patches-panel__content{padding:var(--space-5);flex:1}.pending-patches-panel__skeleton{height:48px;border-radius:var(--radius-md);background:var(--color-bg-raised);margin-bottom:var(--space-3);animation:patches-pulse 1.4s ease-in-out infinite}.pending-patches-panel__summary{display:flex;flex-direction:row;gap:var(--space-3);padding:var(--space-3) var(--space-5);flex-wrap:wrap;border-bottom:1px solid var(--color-border)}.pending-patches-panel__summary-chip{display:inline-flex;align-items:center;padding:2px 8px;border-radius:999px;font-family:var(--font-body);font-size:.75rem;background:var(--color-bg-raised);color:var(--color-text);border:1px solid var(--color-border)}.pending-patches-panel__summary-chip--critical{color:var(--color-red);border-color:#ef444466;background:var(--color-red-bg)}.pending-patches-panel__summary-chip--important{color:var(--color-amber);border-color:#f59e0b66;background:var(--color-amber-bg)}.pending-patches-panel__summary-chip--reboot{color:var(--color-amber);border-color:#f59e0b66}.pending-patches-panel__list-header{padding:var(--space-3) var(--space-5);border-bottom:1px solid var(--color-border)}.pending-patches-panel__select-all{display:inline-flex;align-items:center;gap:var(--space-2);font-family:var(--font-body);font-size:.8125rem;color:var(--color-text-dim);cursor:pointer}.pending-patches-panel__list{overflow-y:auto;flex:1;padding:0 var(--space-5)}.pending-patches-panel__empty{padding:var(--space-5);color:var(--color-text-dim);font-family:var(--font-body);font-size:.875rem;text-align:center}.pending-patch-item{display:flex;flex-direction:row;align-items:center;padding:var(--space-3) 0;border-bottom:1px solid var(--color-border-strong);gap:var(--space-3);cursor:pointer}.pending-patch-item:last-child{border-bottom:none}.pending-patch-item__checkbox{margin-right:var(--space-3)}.pending-patch-item__body{flex:1;min-width:0}.pending-patch-item__kb{font-family:var(--font-display);font-size:.875rem;font-weight:700;color:var(--color-text)}.pending-patch-item__title{font-family:var(--font-body);font-size:.8125rem;color:var(--color-text-dim);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pending-patch-item__severity{font-family:var(--font-body);font-size:.75rem;padding:2px 8px;border-radius:999px;background:var(--color-grey-bg);color:var(--color-grey)}.pending-patch-item__severity--critical{color:var(--color-red);background:var(--color-red-bg)}.pending-patch-item__severity--important{color:var(--color-amber);background:var(--color-amber-bg)}.pending-patch-item__size{font-family:var(--font-body);font-size:.75rem;color:var(--color-text-dim);font-variant-numeric:tabular-nums;min-width:64px;text-align:right}.approve-bar{position:sticky;bottom:0;background:var(--color-bg-raised);padding:var(--space-4) var(--space-5);border-top:1px solid var(--color-border-strong);display:flex;flex-direction:row;align-items:center;justify-content:space-between;gap:var(--space-3)}.approve-bar__info{font-family:var(--font-body);font-size:.8125rem;color:var(--color-text-dim)}.approve-bar__actions{display:flex;flex-direction:row;gap:var(--space-2)}.approve-bar__clear{background:transparent;border:1px solid var(--color-border-strong);color:var(--color-text);border-radius:var(--radius-sm);padding:8px 14px;font-family:var(--font-body);font-size:.8125rem;cursor:pointer}.approve-bar__clear:disabled{opacity:.5;cursor:not-allowed}.approve-bar__button{padding:10px 20px;background:var(--color-accent);color:var(--color-bg);border-radius:var(--radius-md);font-family:var(--font-body);font-size:.875rem;font-weight:600;border:none;cursor:pointer}.approve-bar__button:disabled{opacity:.5;cursor:not-allowed}.pending-patches-panel__confirm{position:absolute;top:0;right:0;bottom:0;left:0;background:#000000a6;display:flex;align-items:center;justify-content:center;padding:var(--space-5);z-index:10}.pending-patches-panel__confirm-dialog{background:var(--color-bg-elevated);border:1px solid var(--color-border-strong);border-radius:var(--radius-lg);padding:var(--space-5);max-width:420px;width:100%}.pending-patches-panel__confirm-title{font-family:var(--font-display);font-size:1.125rem;margin:0 0 var(--space-3) 0;color:var(--color-text)}.pending-patches-panel__confirm-body{font-family:var(--font-body);font-size:.875rem;color:var(--color-text-dim);margin:0 0 var(--space-5) 0}.pending-patches-panel__confirm-actions{display:flex;flex-direction:row;justify-content:flex-end;gap:var(--space-3)}.pending-patches-panel__confirm-cancel{background:transparent;border:1px solid var(--color-border-strong);color:var(--color-text);border-radius:var(--radius-sm);padding:8px 16px;font-family:var(--font-body);font-size:.8125rem;cursor:pointer}.pending-patches-panel__confirm-ok{background:var(--color-accent);color:var(--color-bg);border:none;border-radius:var(--radius-md);padding:10px 20px;font-family:var(--font-body);font-size:.875rem;font-weight:600;cursor:pointer}.pending-patches-panel__status{padding:var(--space-3) var(--space-5);font-family:var(--font-body);font-size:.8125rem;border-top:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between;gap:var(--space-3)}.pending-patches-panel__status--success{color:var(--color-green);background:var(--color-green-bg)}.pending-patches-panel__status--failure{color:var(--color-red);background:var(--color-red-bg)}.pending-patches-panel__status-dismiss{background:transparent;border:1px solid currentColor;color:inherit;border-radius:var(--radius-sm);padding:4px 10px;font-size:.75rem;cursor:pointer}.reboot-modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;display:flex;align-items:center;justify-content:center;padding:var(--space-5)}.reboot-modal__overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#000000b3}.reboot-modal__dialog{position:relative;background:var(--color-bg-elevated);border:1px solid var(--color-border-strong);border-radius:var(--radius-lg);padding:var(--space-6);max-width:520px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-tile-hover)}.reboot-modal__header{margin-bottom:var(--space-5)}.reboot-modal__title{font-family:var(--font-display);font-size:1.25rem;font-weight:700;margin:0;color:var(--color-text)}.reboot-modal__subtitle{font-family:var(--font-body);font-size:.8125rem;color:var(--color-text-dim);margin-top:var(--space-1)}.reboot-modal__body{display:flex;flex-direction:column;gap:var(--space-4)}.reboot-modal__field{display:flex;flex-direction:column;gap:var(--space-2);border:none;padding:0;margin:0}.reboot-modal__legend{font-family:var(--font-body);font-size:.6875rem;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-dim);padding:0;margin-bottom:var(--space-1)}.reboot-modal__label{font-family:var(--font-body);font-size:.6875rem;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-dim)}.reboot-modal__radio{display:flex;flex-direction:row;align-items:center;gap:var(--space-2);font-family:var(--font-body);font-size:.875rem;color:var(--color-text);cursor:pointer}.reboot-modal__input{width:100%;padding:10px 12px;background:var(--color-bg-raised);border:1px solid var(--color-border-strong);border-radius:var(--radius-sm);color:var(--color-text);font-family:var(--font-body);font-size:.875rem}.reboot-modal__input:focus{outline:2px solid var(--color-accent);outline-offset:1px}.reboot-modal__textarea{width:100%;padding:10px 12px;min-height:80px;resize:vertical;background:var(--color-bg-raised);border:1px solid var(--color-border-strong);border-radius:var(--radius-sm);color:var(--color-text);font-family:var(--font-body);font-size:.875rem}.reboot-modal__textarea:focus{outline:2px solid var(--color-accent);outline-offset:1px}.reboot-modal__error{color:var(--color-red);font-family:var(--font-body);font-size:.8125rem}.reboot-modal__footer{display:flex;flex-direction:row;justify-content:flex-end;gap:var(--space-3);margin-top:var(--space-5)}.reboot-modal__cancel{background:transparent;border:1px solid var(--color-border-strong);color:var(--color-text);border-radius:var(--radius-sm);padding:10px 16px;font-family:var(--font-body);font-size:.875rem;cursor:pointer}.reboot-modal__submit{background:var(--color-accent);color:var(--color-bg);border:none;border-radius:var(--radius-md);padding:10px 20px;font-family:var(--font-body);font-size:.875rem;font-weight:600;cursor:pointer}.reboot-modal__submit:disabled{opacity:.5;cursor:not-allowed}.reboot-modal__submit--destructive{background:var(--color-red);color:var(--color-text);box-shadow:0 0 0 0 var(--color-red-glow)}.software-tab{display:flex;flex-direction:column;gap:var(--space-3);padding:var(--space-5)}.software-tab__header{display:flex;flex-direction:row;justify-content:space-between;font-family:var(--font-body);font-size:.8125rem;color:var(--color-text-dim)}.software-tab__skeleton{height:48px;border-radius:var(--radius-sm);background:var(--color-bg-raised);margin-bottom:var(--space-2);animation:patches-pulse 1.4s ease-in-out infinite}.software-tab__list{display:flex;flex-direction:column;gap:var(--space-2)}.software-tab__empty{padding:var(--space-5);color:var(--color-text-dim);font-family:var(--font-body);font-size:.8125rem;text-align:center}.software-row{display:flex;flex-direction:row;align-items:center;gap:var(--space-4);background:var(--color-bg-raised);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:var(--space-3)}.software-row__main{flex:1;min-width:0}.software-row__name{font-family:var(--font-display);font-size:.9375rem;font-weight:600;color:var(--color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.software-row__id{font-family:var(--font-body);font-size:.75rem;color:var(--color-text-dim);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.software-row__version{font-family:var(--font-body);font-size:.8125rem;color:var(--color-text);font-variant-numeric:tabular-nums}.software-row__version--outdated{color:var(--color-amber)}.software-row__action{display:flex;align-items:center;min-width:120px;justify-content:flex-end}.software-row__update{padding:6px 12px;font-family:var(--font-body);font-size:.75rem;background:var(--color-accent);color:var(--color-bg);border-radius:var(--radius-sm);border:none;cursor:pointer;font-weight:600}.software-row__update:hover{filter:brightness(1.05)}.software-row__status{font-family:var(--font-body);font-size:.75rem;display:inline-flex;gap:var(--space-2);align-items:center}.software-row__status--submitting{color:var(--color-text-dim)}.software-row__status--queued{color:var(--color-accent)}.software-row__status--failure{color:var(--color-red)}.software-row__status-dismiss,.software-row__status-retry{background:transparent;border:1px solid currentColor;color:inherit;border-radius:var(--radius-sm);padding:2px 8px;font-size:.6875rem;cursor:pointer}@media (prefers-reduced-motion: reduce){.patch-endpoint-row,.reboot-modal__submit,.software-row{transition:none}.patch-endpoint-list__skeleton,.pending-patches-panel__skeleton,.software-tab__skeleton{animation:none}}.scripts-page{display:flex;flex-direction:column;min-height:100vh;background:var(--color-bg);color:var(--color-text);font-family:var(--font-body)}.scripts-header{display:flex;justify-content:space-between;align-items:flex-start;padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--color-border);gap:var(--space-4)}.scripts-title{font-family:var(--font-display);font-size:2rem;font-weight:700;margin:0;color:var(--color-text)}.scripts-subtitle{margin:var(--space-1) 0 0;color:var(--color-text-dim);font-size:.875rem}.scripts-header__actions{display:flex;gap:var(--space-3);align-items:center}.scripts-header__new,.scripts-header__run{padding:var(--space-2) var(--space-4);border-radius:var(--radius-sm);border:1px solid var(--color-border-strong);background:var(--color-bg-raised);color:var(--color-text);cursor:pointer;font-family:var(--font-body);font-size:.875rem;transition:background .12s ease,transform .12s ease}.scripts-header__new:hover,.scripts-header__run:hover{background:var(--color-bg-elevated)}.scripts-header__run{background:var(--color-accent);border-color:var(--color-accent);color:var(--color-bg);font-weight:600}.scripts-header__run:disabled{opacity:.4;cursor:not-allowed}.scripts-layout{display:flex;flex:1 1 auto;min-height:0}.script-list-sidebar{width:320px;border-right:1px solid var(--color-border);overflow-y:auto;display:flex;flex-direction:column;flex-shrink:0}.script-list-sidebar__filters{padding:var(--space-4);border-bottom:1px solid var(--color-border);display:flex;flex-direction:column;gap:var(--space-2)}.script-list-sidebar__search{width:100%;padding:var(--space-2) var(--space-3);background:var(--color-bg-raised);border:1px solid var(--color-border-strong);border-radius:var(--radius-sm);color:var(--color-text);font-family:var(--font-body);font-size:.8125rem}.script-list-sidebar__search::placeholder{color:var(--color-text-muted)}.script-list-sidebar__row{display:flex;gap:var(--space-2)}.script-list-sidebar__select{flex:1;padding:var(--space-2);background:var(--color-bg-raised);border:1px solid var(--color-border-strong);border-radius:var(--radius-sm);color:var(--color-text);font-family:var(--font-body);font-size:.8125rem}.script-list-sidebar__list{flex:1;overflow-y:auto}.script-list-sidebar__status{padding:var(--space-4);color:var(--color-text-dim);font-size:.8125rem}.script-list-sidebar__status--error{color:var(--color-red)}.script-list-row{display:flex;flex-direction:column;gap:var(--space-1);padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border);cursor:pointer;transition:background .12s ease}.script-list-row:hover{background:var(--color-bg-raised)}.script-list-row:focus-visible{outline:2px solid var(--color-accent);outline-offset:-2px}.script-list-row--selected{background:var(--color-bg-raised);border-left:3px solid var(--color-accent)}.script-list-row__name{font-family:var(--font-display);font-size:.9375rem;font-weight:700}.script-list-row__desc{font-family:var(--font-body);font-size:.75rem;color:var(--color-text-dim)}.script-list-row__meta{display:flex;gap:var(--space-2);align-items:center;flex-wrap:wrap;margin-top:var(--space-1)}.script-list-row__platform{font-size:.6875rem;color:var(--color-text-dim);text-transform:uppercase;letter-spacing:.04em}.script-list-row__tags{display:flex;gap:4px}.script-list-row__tag{padding:1px 6px;font-size:.625rem;background:var(--color-bg-raised);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-dim)}.scripts-main{flex:1;padding:var(--space-5);overflow-y:auto;min-width:0}.scripts-empty{display:flex;align-items:center;justify-content:center;height:100%;color:var(--color-text-dim);font-size:.9375rem}.scripts-detail{display:flex;flex-direction:column;gap:var(--space-4)}.scripts-detail__name{font-family:var(--font-display);font-size:1.5rem;font-weight:700;letter-spacing:-.01em;color:var(--color-text);margin:0}.script-meta-form{display:flex;flex-direction:column;gap:var(--space-3)}.script-meta-form__field{display:flex;flex-direction:column;gap:var(--space-1);flex:1}.script-meta-form__label{font-size:.75rem;color:var(--color-text-dim);text-transform:uppercase;letter-spacing:.04em}.script-meta-form__input,.script-meta-form__textarea,.script-meta-form__select{padding:var(--space-2) var(--space-3);background:var(--color-bg-raised);border:1px solid var(--color-border-strong);border-radius:var(--radius-sm);color:var(--color-text);font-family:var(--font-body);font-size:.875rem}.script-meta-form__textarea{font-family:var(--font-body);resize:vertical}.script-meta-form__row{display:flex;gap:var(--space-3)}.script-meta-form__error{font-size:.75rem;color:var(--color-red)}.script-editor{min-height:320px;width:100%;padding:var(--space-3);background:var(--color-bg-raised);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);font-family:Consolas,Monaco,Courier New,monospace;font-size:.875rem;line-height:1.5;-moz-tab-size:2;tab-size:2;resize:vertical;white-space:pre;overflow:auto}.script-editor:focus{outline:2px solid var(--color-accent);outline-offset:0}.category-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:999px;font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.category-badge--diagnostic{background:var(--color-green-bg);color:var(--color-green)}.category-badge--remediation{background:var(--color-amber-bg);color:var(--color-amber)}.category-badge--maintenance{background:var(--color-grey-bg);color:var(--color-grey)}.category-badge__approval{font-size:.625rem;text-transform:uppercase;letter-spacing:.06em;margin-left:6px;opacity:.8}.run-dispatch{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:200;padding:var(--space-4)}.run-dispatch__dialog{background:var(--color-bg-elevated);border:1px solid var(--color-border-strong);border-radius:var(--radius-lg);padding:var(--space-6);max-width:640px;width:100%;max-height:90vh;overflow-y:auto;color:var(--color-text);box-shadow:var(--shadow-tile-hover)}.run-dispatch__header{margin-bottom:var(--space-4)}.run-dispatch__title{font-family:var(--font-display);font-size:1.25rem;font-weight:700;margin:0}.run-dispatch__sub{font-size:.8125rem;color:var(--color-text-dim);margin-top:var(--space-1)}.run-dispatch__actions{display:flex;justify-content:flex-end;gap:var(--space-3);margin-top:var(--space-4)}.run-dispatch__btn{padding:var(--space-2) var(--space-4);border-radius:var(--radius-sm);border:1px solid var(--color-border-strong);background:var(--color-bg-raised);color:var(--color-text);cursor:pointer;font-family:var(--font-body);font-size:.875rem}.run-dispatch__btn:hover:not(:disabled){background:var(--color-bg-elevated)}.run-dispatch__btn:disabled{opacity:.4;cursor:not-allowed}.run-dispatch__btn--primary{background:var(--color-accent);color:var(--color-bg);border-color:var(--color-accent);font-weight:600}.run-dispatch__btn--danger{background:var(--color-red-bg);color:var(--color-red);border-color:var(--color-red)}.run-dispatch__btn--armed{box-shadow:0 0 0 2px var(--color-red-glow)}.run-dispatch__status{padding:var(--space-3);margin-top:var(--space-3);border-radius:var(--radius-sm);background:var(--color-bg-raised);font-size:.875rem;display:flex;align-items:center;gap:var(--space-2)}.run-dispatch__status--success{color:var(--color-green);background:var(--color-green-bg)}.run-dispatch__status--failure{color:var(--color-red);background:var(--color-red-bg)}.run-dispatch__spinner{width:12px;height:12px;border:2px solid var(--color-border-strong);border-top-color:var(--color-accent);border-radius:50%;animation:scripts-spin .8s linear infinite;display:inline-block}@keyframes scripts-spin{to{transform:rotate(360deg)}}.run-dispatch__runs{margin-top:var(--space-3);display:flex;flex-direction:column;gap:var(--space-1);max-height:240px;overflow-y:auto}.run-dispatch__run-row{display:flex;justify-content:space-between;padding:var(--space-2) var(--space-3);background:var(--color-bg-raised);border-radius:var(--radius-sm);font-size:.8125rem}.run-dispatch__run-endpoint{color:var(--color-text-dim);font-family:Consolas,Monaco,Courier New,monospace;font-size:.75rem}.multi-endpoint-picker{display:flex;flex-direction:column;gap:var(--space-2);margin-top:var(--space-3)}.multi-endpoint-picker__filters{display:flex;gap:var(--space-2);flex-wrap:wrap}.multi-endpoint-picker__search,.multi-endpoint-picker__select{padding:var(--space-2) var(--space-3);background:var(--color-bg-raised);border:1px solid var(--color-border-strong);border-radius:var(--radius-sm);color:var(--color-text);font-family:var(--font-body);font-size:.8125rem}.multi-endpoint-picker__search{flex:1 1 200px}.multi-endpoint-picker__meta{font-size:.75rem;color:var(--color-text-dim)}.multi-endpoint-picker__list{max-height:320px;overflow-y:auto;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg)}.multi-endpoint-picker__status{padding:var(--space-3);font-size:.8125rem;color:var(--color-text-dim)}.multi-endpoint-picker__status--error{color:var(--color-red)}.picker-row{display:grid;grid-template-columns:auto 1fr 1fr 1fr auto;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-bottom:1px solid var(--color-border);font-size:.8125rem;cursor:pointer}.picker-row:hover{background:var(--color-bg-raised)}.picker-row--incompatible{opacity:.6;cursor:not-allowed}.picker-row__host{font-weight:600}.picker-row__client,.picker-row__os{color:var(--color-text-dim);font-size:.75rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.picker-row__incompatible{color:var(--color-red);font-size:.6875rem;text-transform:uppercase;letter-spacing:.04em}.run-history{display:flex;flex-direction:column;gap:var(--space-3);margin-top:var(--space-5)}.run-history__header{display:flex;justify-content:space-between;align-items:center}.run-history__title{margin:0;font-family:var(--font-display);font-size:1rem;font-weight:700}.run-history__loading{font-size:.75rem;color:var(--color-text-dim)}.run-history__empty,.run-history__error{padding:var(--space-3);font-size:.8125rem;color:var(--color-text-dim);background:var(--color-bg-raised);border-radius:var(--radius-sm)}.run-history__error{color:var(--color-red)}.run-history-list{display:flex;flex-direction:column;gap:var(--space-2)}.run-history-row{padding:var(--space-3);background:var(--color-bg-raised);border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;display:flex;flex-direction:column;gap:var(--space-1)}.run-history-row:hover{background:var(--color-bg-elevated)}.run-history-row--selected{border-color:var(--color-accent)}.run-history-row:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.run-history-row__main{display:flex;justify-content:space-between;align-items:center}.run-history-row__host{font-weight:600;font-size:.875rem}.run-history-row__meta{display:flex;gap:var(--space-3);font-size:.75rem;color:var(--color-text-dim)}.run-status{display:inline-flex;align-items:center;padding:2px 8px;border-radius:999px;font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.run-status--queued,.run-status--running{background:var(--color-grey-bg);color:var(--color-accent)}.run-status--success{background:var(--color-green-bg);color:var(--color-green)}.run-status--failure{background:var(--color-red-bg);color:var(--color-red)}.run-status--pending_approval{background:var(--color-amber-bg);color:var(--color-amber)}.run-status--cancelled{background:var(--color-grey-bg);color:var(--color-text-dim)}.output-viewer{background:var(--color-bg-raised);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:var(--space-4);font-family:Consolas,Monaco,Courier New,monospace;font-size:.8125rem;margin-top:var(--space-3);display:flex;flex-direction:column;gap:var(--space-2)}.output-viewer__meta{display:flex;gap:var(--space-4);font-size:.75rem;color:var(--color-text-dim)}.output-viewer__tabs{display:flex;border-bottom:1px solid var(--color-border)}.output-viewer__tab{padding:var(--space-2) var(--space-4);background:transparent;border:none;color:var(--color-text-dim);font-family:var(--font-body);font-size:.8125rem;cursor:pointer;border-bottom:2px solid transparent}.output-viewer__tab--active{color:var(--color-accent);border-bottom-color:var(--color-accent)}.output-viewer__body{max-height:400px;overflow-y:auto;white-space:pre-wrap;word-break:break-word;margin:0;color:var(--color-text)}.pending-approvals-banner{padding:var(--space-3) var(--space-6);background:var(--color-amber-bg);border-left:3px solid var(--color-amber);color:var(--color-text);font-size:.875rem}.script-create-form{display:flex;flex-direction:column;gap:var(--space-4)}.script-create-form__header{display:flex;justify-content:space-between}.script-create-form__title{font-family:var(--font-display);font-size:1.25rem;font-weight:700;margin:0}.script-create-form__error{color:var(--color-red);font-size:.8125rem;padding:var(--space-2) var(--space-3);background:var(--color-red-bg);border-radius:var(--radius-sm)}.script-create-form__actions{display:flex;justify-content:flex-end;gap:var(--space-3)}.script-create-form__btn{padding:var(--space-2) var(--space-4);border-radius:var(--radius-sm);border:1px solid var(--color-border-strong);background:var(--color-bg-raised);color:var(--color-text);cursor:pointer;font-family:var(--font-body);font-size:.875rem}.script-create-form__btn:disabled{opacity:.4;cursor:not-allowed}.script-create-form__btn--primary{background:var(--color-accent);color:var(--color-bg);border-color:var(--color-accent);font-weight:600}@media (max-width: 900px){.scripts-layout{flex-direction:column}.script-list-sidebar{width:100%;max-height:320px;border-right:none;border-bottom:1px solid var(--color-border)}.picker-row{grid-template-columns:auto 1fr;grid-template-areas:"check host" "check client" "check os" "check flag";gap:var(--space-1)}}@media (prefers-reduced-motion: reduce){.scripts-header__new,.scripts-header__run,.script-list-row,.run-history-row,.run-dispatch__status,.run-dispatch__spinner{transition:none;animation:none}}.services-tab{display:flex;flex-direction:column;gap:var(--space-3);padding:var(--space-5)}.services-tab__header{display:flex;justify-content:space-between;align-items:center;font-size:.8125rem;color:var(--color-text-dim)}.services-tab__search{width:100%;padding:var(--space-2) var(--space-3);background:var(--color-bg-raised);border:1px solid var(--color-border-strong);border-radius:var(--radius-sm);color:var(--color-text);font-family:var(--font-body);font-size:.8125rem}.services-tab__search::placeholder{color:var(--color-text-muted)}.services-tab__list{display:flex;flex-direction:column;gap:var(--space-2);max-height:540px;overflow-y:auto}.services-tab__empty{padding:var(--space-5);text-align:center;color:var(--color-text-dim);font-size:.8125rem;background:var(--color-bg-raised);border:1px dashed var(--color-border);border-radius:var(--radius-sm)}.service-row{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-4);padding:var(--space-3);background:var(--color-bg-raised);border:1px solid var(--color-border);border-radius:var(--radius-sm)}.service-row__info{display:flex;flex-direction:column;gap:var(--space-1);min-width:0;flex:1}.service-row__name{font-family:var(--font-display);font-size:.9375rem;font-weight:700;color:var(--color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.service-row__display{font-family:Consolas,Monaco,Courier New,monospace;font-size:.75rem;color:var(--color-text-dim);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.service-row__badges{display:flex;gap:var(--space-2);flex-wrap:wrap;margin-top:var(--space-1)}.service-row__status-pill{display:inline-flex;align-items:center;padding:2px 8px;border-radius:999px;font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.service-row__status-pill--running{background:var(--color-green-bg);color:var(--color-green)}.service-row__status-pill--stopped{background:var(--color-grey-bg);color:var(--color-grey)}.service-row__status-pill--paused,.service-row__status-pill--pending{background:var(--color-amber-bg);color:var(--color-amber)}.service-row__status-pill--unknown{background:var(--color-grey-bg);color:var(--color-grey)}.service-row__start-type{font-size:.6875rem;color:var(--color-text-dim);text-transform:uppercase;letter-spacing:.04em;padding:2px 6px;border:1px solid var(--color-border);border-radius:var(--radius-sm)}.service-row__monitor-chip{padding:2px 8px;font-size:.6875rem;background:var(--color-accent);color:var(--color-bg);border-radius:999px;text-transform:uppercase;letter-spacing:.04em}.service-row__actions{display:flex;gap:var(--space-1);align-items:center;flex-wrap:wrap;justify-content:flex-end}.service-row__btn{padding:4px 8px;font-size:.6875rem;border:1px solid var(--color-border-strong);border-radius:var(--radius-sm);background:transparent;color:var(--color-text);cursor:pointer;font-family:var(--font-body);transition:background .12s ease}.service-row__btn:hover:not(:disabled){background:var(--color-bg-elevated)}.service-row__btn:disabled{opacity:.4;cursor:not-allowed}.service-row__btn--destructive{color:var(--color-red);border-color:var(--color-red)}.service-row__select{padding:4px 6px;font-size:.6875rem;background:var(--color-bg);border:1px solid var(--color-border-strong);border-radius:var(--radius-sm);color:var(--color-text);font-family:var(--font-body)}.service-action-confirm,.service-monitor-modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:210;padding:var(--space-4)}.service-action-confirm__dialog,.service-monitor-modal__dialog{background:var(--color-bg-elevated);border:1px solid var(--color-border-strong);border-radius:var(--radius-lg);padding:var(--space-6);max-width:480px;width:100%;color:var(--color-text);box-shadow:var(--shadow-tile-hover)}.service-action-confirm__title,.service-monitor-modal__title{font-family:var(--font-display);font-size:1.125rem;font-weight:700;margin:0 0 var(--space-3) 0}.service-action-confirm__body{font-size:.875rem;color:var(--color-text-dim);margin:0 0 var(--space-4) 0}.service-action-confirm__status{padding:var(--space-3);margin:var(--space-3) 0;border-radius:var(--radius-sm);background:var(--color-bg-raised);font-size:.8125rem;display:flex;align-items:center;gap:var(--space-2)}.service-action-confirm__status--success{background:var(--color-green-bg);color:var(--color-green)}.service-action-confirm__status--failure{background:var(--color-red-bg);color:var(--color-red)}.service-action-confirm__spinner{width:12px;height:12px;border:2px solid var(--color-border-strong);border-top-color:var(--color-accent);border-radius:50%;animation:services-spin .8s linear infinite;display:inline-block}@keyframes services-spin{to{transform:rotate(360deg)}}.service-action-confirm__actions,.service-monitor-modal__actions{display:flex;justify-content:flex-end;gap:var(--space-3);margin-top:var(--space-3)}.service-action-confirm__btn,.service-monitor-modal__btn{padding:var(--space-2) var(--space-4);border-radius:var(--radius-sm);border:1px solid var(--color-border-strong);background:var(--color-bg-raised);color:var(--color-text);cursor:pointer;font-family:var(--font-body);font-size:.875rem}.service-action-confirm__btn:disabled,.service-monitor-modal__btn:disabled{opacity:.4;cursor:not-allowed}.service-action-confirm__btn--primary,.service-monitor-modal__btn--primary{background:var(--color-accent);color:var(--color-bg);border-color:var(--color-accent);font-weight:600}.service-action-confirm__btn--danger{background:var(--color-red-bg);color:var(--color-red);border-color:var(--color-red)}.service-action-confirm__btn--armed{box-shadow:0 0 0 2px var(--color-red-glow)}.service-monitor-modal__fieldset{border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:var(--space-3);margin:0 0 var(--space-3) 0;display:flex;gap:var(--space-4)}.service-monitor-modal__legend{font-size:.75rem;color:var(--color-text-dim);text-transform:uppercase;letter-spacing:.04em;padding:0 var(--space-2)}.service-monitor-modal__radio,.service-monitor-modal__checkbox{display:flex;align-items:center;gap:var(--space-2);font-size:.875rem;cursor:pointer}.service-monitor-modal__checkbox{margin-bottom:var(--space-3)}.service-monitor-modal__error{color:var(--color-red);font-size:.8125rem;padding:var(--space-2) var(--space-3);background:var(--color-red-bg);border-radius:var(--radius-sm);margin-top:var(--space-3)}@media (max-width: 900px){.service-row{flex-direction:column;align-items:stretch}.service-row__actions{justify-content:flex-start}}@media (prefers-reduced-motion: reduce){.service-row__btn,.service-action-confirm__status,.service-action-confirm__spinner{transition:none;animation:none}}.settings-page{display:flex;flex-direction:column;min-height:100vh;background:var(--color-bg);color:var(--color-text);font-family:var(--font-body)}.settings-header{display:flex;justify-content:space-between;align-items:flex-start;padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--color-border);gap:var(--space-4)}.settings-title{font-family:var(--font-display);font-size:2rem;font-weight:700;margin:0;color:var(--color-text)}.settings-subtitle{margin:var(--space-1) 0 0;color:var(--color-text-dim);font-size:.875rem}.settings-tabs{display:flex;flex-direction:row;gap:var(--space-1);padding:0 var(--space-6);border-bottom:1px solid var(--color-border);background:var(--color-bg)}.settings-tab{padding:var(--space-3) var(--space-4);background:transparent;border:none;border-bottom:2px solid transparent;color:var(--color-text-dim);font-family:var(--font-body);font-size:.8125rem;text-transform:uppercase;letter-spacing:.05em;cursor:pointer;transition:color .12s ease,border-color .12s ease}.settings-tab:hover{color:var(--color-text)}.settings-tab--active{color:var(--color-accent);border-bottom-color:var(--color-accent)}.settings-content{flex:1 1 auto;padding:var(--space-5) var(--space-6);overflow-y:auto}.settings-forbidden{padding:var(--space-6);text-align:center;color:var(--color-text-dim);border:1px dashed var(--color-border);border-radius:var(--radius-md)}.users-tab__counts{display:flex;flex-wrap:wrap;gap:var(--space-4);margin-bottom:var(--space-5)}.users-tab__count-card{min-width:120px;padding:var(--space-3) var(--space-4);background:var(--color-bg-raised);border:1px solid var(--color-border);border-radius:var(--radius-sm)}.users-tab__count-label{font-size:.6875rem;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-dim)}.users-tab__count-value{margin-top:var(--space-1);font-family:var(--font-display);font-size:1.5rem;font-weight:700;color:var(--color-text)}.users-tab__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-4);gap:var(--space-3)}.users-tab__heading{font-family:var(--font-display);font-size:1.125rem;font-weight:700;margin:0}.users-tab__invite-btn{padding:var(--space-2) var(--space-4);background:var(--color-accent);color:var(--color-bg);border:1px solid var(--color-accent);border-radius:var(--radius-sm);font-size:.875rem;font-family:var(--font-body);cursor:pointer;transition:transform .12s ease,background .12s ease}.users-tab__invite-btn:hover{transform:translateY(-1px)}.user-list{display:flex;flex-direction:column;gap:var(--space-2)}.user-list__placeholder{padding:var(--space-5);text-align:center;color:var(--color-text-dim);border:1px dashed var(--color-border);border-radius:var(--radius-md)}.user-list__placeholder--error{color:var(--color-red);border-color:var(--color-red)}.user-row{display:grid;grid-template-columns:40px minmax(180px,2fr) auto auto auto 1fr;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:border-color .12s ease,background .12s ease}.user-row:hover{border-color:var(--color-border-strong)}.user-row__avatar{width:32px;height:32px;border-radius:50%;background:var(--color-accent);color:var(--color-bg);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:700;font-size:.8125rem}.user-row__name{font-family:var(--font-display);font-size:.9375rem;font-weight:700;color:var(--color-text)}.user-row__email{font-family:var(--font-body);font-size:.75rem;color:var(--color-text-dim)}.user-row__last-active{font-size:.75rem;color:var(--color-text-dim);font-variant-numeric:tabular-nums}.user-row__actions{display:flex;gap:var(--space-2);margin-left:auto}.user-row__btn{padding:var(--space-1) var(--space-3);background:var(--color-bg-raised);border:1px solid var(--color-border-strong);color:var(--color-text);border-radius:var(--radius-sm);font-size:.75rem;font-family:var(--font-body);cursor:pointer;transition:background .12s ease,border-color .12s ease}.user-row__btn:hover:not(:disabled){background:var(--color-bg-elevated);border-color:var(--color-accent)}.user-row__btn:disabled{opacity:.5;cursor:not-allowed}.user-row__btn--danger{border-color:var(--color-red);color:var(--color-red)}.user-row__btn--danger:hover:not(:disabled){background:var(--color-red-bg);border-color:var(--color-red)}.user-role-pill{display:inline-block;padding:2px var(--space-2);border-radius:999px;background:var(--color-bg-raised);border:1px solid var(--color-border-strong);color:var(--color-text);font-size:.6875rem;text-transform:uppercase;letter-spacing:.06em}.user-role-pill--admin{border-color:var(--color-accent);color:var(--color-accent)}.user-role-pill--agent{border-color:var(--color-green);color:var(--color-green)}.user-role-pill--specialist{border-color:var(--color-amber);color:var(--color-amber)}.user-role-pill--support,.user-role-pill--viewer{border-color:var(--color-border-strong);color:var(--color-text-dim)}.user-status-badge{display:inline-block;padding:2px var(--space-2);border-radius:999px;font-size:.6875rem;text-transform:uppercase;letter-spacing:.06em;font-variant-numeric:tabular-nums}.user-status-badge--active{background:var(--color-green-bg);color:var(--color-green)}.user-status-badge--invited{background:var(--color-amber-bg);color:var(--color-amber)}.user-status-badge--suspended{background:var(--color-grey-bg);color:var(--color-grey)}.invite-user-modal,.edit-role-modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;display:flex;align-items:center;justify-content:center;z-index:150;padding:var(--space-4)}.invite-user-modal__dialog,.edit-role-modal__dialog{width:100%;max-width:460px;background:var(--color-bg-elevated);border:1px solid var(--color-border-strong);border-radius:var(--radius-md);box-shadow:var(--shadow-tile-hover);display:flex;flex-direction:column;animation:invite-dialog-in .16s ease-out}@keyframes invite-dialog-in{0%{transform:translateY(8px);opacity:0}to{transform:translateY(0);opacity:1}}.invite-user-modal__header,.edit-role-modal__header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--color-border)}.invite-user-modal__title,.edit-role-modal__title{font-family:var(--font-display);font-size:1.125rem;font-weight:700;margin:0;color:var(--color-text)}.invite-user-modal__close,.edit-role-modal__close{background:transparent;border:none;color:var(--color-text-dim);font-size:1.5rem;line-height:1;cursor:pointer;padding:0;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm)}.invite-user-modal__close:hover,.edit-role-modal__close:hover{color:var(--color-text);background:var(--color-bg-raised)}.invite-user-modal__form,.edit-role-modal__form{padding:var(--space-4) var(--space-5);display:flex;flex-direction:column;gap:var(--space-2)}.invite-user-modal__label,.edit-role-modal__label{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-dim);margin-top:var(--space-2)}.invite-user-modal__input,.invite-user-modal__select,.edit-role-modal__select{padding:var(--space-2) var(--space-3);background:var(--color-bg-raised);border:1px solid var(--color-border-strong);border-radius:var(--radius-sm);color:var(--color-text);font-family:var(--font-body);font-size:.875rem}.invite-user-modal__input:focus,.invite-user-modal__select:focus,.edit-role-modal__select:focus{outline:2px solid var(--color-accent);outline-offset:1px}.invite-user-modal__error,.edit-role-modal__error{padding:var(--space-2) var(--space-3);background:var(--color-red-bg);color:var(--color-red);border-radius:var(--radius-sm);font-size:.8125rem;margin-top:var(--space-2)}.edit-role-modal__warning{padding:var(--space-2) var(--space-3);background:var(--color-amber-bg);color:var(--color-amber);border-radius:var(--radius-sm);font-size:.8125rem;margin-top:var(--space-2)}.edit-role-modal__success{padding:var(--space-2) var(--space-3);background:var(--color-green-bg);color:var(--color-green);border-radius:var(--radius-sm);font-size:.8125rem;margin-top:var(--space-2)}.invite-user-modal__success{padding:var(--space-5);text-align:center;color:var(--color-text)}.invite-user-modal__actions,.edit-role-modal__actions{display:flex;gap:var(--space-2);justify-content:flex-end;margin-top:var(--space-4)}.invite-user-modal__btn,.edit-role-modal__btn{padding:var(--space-2) var(--space-4);background:var(--color-bg-raised);border:1px solid var(--color-border-strong);color:var(--color-text);border-radius:var(--radius-sm);font-family:var(--font-body);font-size:.875rem;cursor:pointer;transition:background .12s ease}.invite-user-modal__btn:hover:not(:disabled),.edit-role-modal__btn:hover:not(:disabled){background:var(--color-bg-elevated)}.invite-user-modal__btn:disabled,.edit-role-modal__btn:disabled{opacity:.5;cursor:not-allowed}.invite-user-modal__btn--primary,.edit-role-modal__btn--primary{background:var(--color-accent);border-color:var(--color-accent);color:var(--color-bg)}.invite-user-modal__btn--primary:hover:not(:disabled),.edit-role-modal__btn--primary:hover:not(:disabled){background:var(--color-accent);transform:translateY(-1px)}.coming-soon-tab{text-align:center;padding:var(--space-7) var(--space-4);color:var(--color-text-dim)}.coming-soon-tab__title{font-family:var(--font-display);font-size:1.5rem;font-weight:700;margin:0 0 var(--space-2);color:var(--color-text)}.coming-soon-tab__body{margin:0;font-size:.875rem}.accept-invitation-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--color-bg);color:var(--color-text);font-family:var(--font-body);padding:var(--space-4)}.accept-invitation-page__card{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-6);max-width:420px;width:100%;text-align:center}.accept-invitation-page__title{font-family:var(--font-display);font-size:1.5rem;font-weight:700;margin:0 0 var(--space-4)}.accept-invitation-page__status{font-size:.9375rem;color:var(--color-text-dim)}.accept-invitation-page__status--success{color:var(--color-green)}.accept-invitation-page__status--failure{color:var(--color-red)}@media (max-width: 720px){.settings-header,.settings-content{padding:var(--space-4)}.settings-tabs{padding:0 var(--space-4);overflow-x:auto;flex-wrap:nowrap;white-space:nowrap}.user-row{grid-template-columns:40px 1fr;grid-auto-flow:row;row-gap:var(--space-2)}.user-row__actions{grid-column:1 / -1;margin-left:0;flex-wrap:wrap}}@media (prefers-reduced-motion: reduce){.invite-user-modal__dialog,.edit-role-modal__dialog{animation:none}.users-tab__invite-btn:hover,.invite-user-modal__btn--primary:hover:not(:disabled),.edit-role-modal__btn--primary:hover:not(:disabled){transform:none}}.team-page{display:flex;flex-direction:column;min-height:100vh;background:var(--color-bg);color:var(--color-text);font-family:var(--font-body)}.team-header{display:flex;justify-content:space-between;align-items:flex-start;padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--color-border);gap:var(--space-4)}.team-title{font-family:var(--font-display);font-size:2rem;font-weight:700;margin:0;color:var(--color-text)}.team-subtitle{margin:var(--space-1) 0 0;color:var(--color-text-dim);font-size:.875rem}.team-tabs{display:flex;gap:var(--space-1);padding:0 var(--space-6);border-bottom:1px solid var(--color-border);background:var(--color-bg);overflow-x:auto}.team-tab{padding:var(--space-3) var(--space-4);background:transparent;border:none;border-bottom:2px solid transparent;color:var(--color-text-dim);font-family:var(--font-body);font-size:.8125rem;text-transform:uppercase;letter-spacing:.05em;cursor:pointer;transition:color .12s ease,border-color .12s ease;white-space:nowrap}.team-tab:hover{color:var(--color-text)}.team-tab--active{color:var(--color-accent);border-bottom-color:var(--color-accent)}.team-content{flex:1 1 auto;padding:var(--space-5) var(--space-6);overflow-y:auto}.roster-tab__header,.tasks-tab__header,.activity-tab__header,.time-report-tab__header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-3);margin-bottom:var(--space-4)}.roster-tab__title,.tasks-tab__title,.activity-tab__title,.time-report-tab__title{font-family:var(--font-display);font-size:1.25rem;font-weight:700;margin:0}.roster-tab__subtitle,.tasks-tab__subtitle,.activity-tab__subtitle,.time-report-tab__subtitle{margin:var(--space-1) 0 0;color:var(--color-text-dim);font-size:.8125rem}.roster-tab__refresh,.activity-tab__refresh,.time-report-tab__refresh,.tasks-tab__new-btn{padding:var(--space-2) var(--space-4);background:var(--color-bg-raised);border:1px solid var(--color-border-strong);color:var(--color-text);border-radius:var(--radius-sm);font-family:var(--font-body);font-size:.8125rem;cursor:pointer;transition:background .12s ease,border-color .12s ease}.roster-tab__refresh:hover:not(:disabled),.activity-tab__refresh:hover:not(:disabled),.time-report-tab__refresh:hover:not(:disabled),.tasks-tab__new-btn:hover{background:var(--color-bg-elevated);border-color:var(--color-accent)}.tasks-tab__new-btn{background:var(--color-accent);border-color:var(--color-accent);color:var(--color-bg)}.roster-tab__list{display:flex;flex-direction:column;gap:var(--space-2)}.roster-tab__placeholder,.tasks-tab__placeholder,.activity-tab__placeholder,.time-report-tab__placeholder{padding:var(--space-5);text-align:center;color:var(--color-text-dim);border:1px dashed var(--color-border);border-radius:var(--radius-md)}.roster-tab__placeholder--error,.tasks-tab__placeholder--error,.activity-tab__placeholder--error,.time-report-tab__placeholder--error{color:var(--color-red);border-color:var(--color-red)}.roster-member-row{display:grid;grid-template-columns:40px minmax(160px,2fr) auto auto 1fr auto auto;gap:var(--space-3);align-items:center;padding:var(--space-3) var(--space-4);background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md)}.roster-member-row__avatar{width:32px;height:32px;border-radius:50%;background:var(--color-accent);color:var(--color-bg);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:700;font-size:.8125rem}.roster-member-row__name{font-family:var(--font-display);font-size:.9375rem;font-weight:700;color:var(--color-text)}.roster-member-row__email{font-size:.75rem;color:var(--color-text-dim)}.roster-member-row__tz{font-size:.75rem;color:var(--color-text-dim);font-variant-numeric:tabular-nums}.roster-member-row__clocked{display:flex;align-items:center;gap:var(--space-2);font-size:.8125rem;color:var(--color-text)}.roster-member-row__dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.roster-member-row__dot--in{background:var(--color-green);box-shadow:0 0 6px var(--color-green-bg);animation:roster-pulse 2s ease-in-out infinite}.roster-member-row__dot--out{background:var(--color-grey)}@keyframes roster-pulse{0%,to{opacity:1}50%{opacity:.5}}.roster-member-row__hours,.roster-member-row__tasks{display:flex;flex-direction:column;align-items:flex-end}.roster-member-row__meta-label{font-size:.625rem;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-dim)}.roster-member-row__meta-value{font-family:var(--font-display);font-size:.875rem;font-weight:700;color:var(--color-text);font-variant-numeric:tabular-nums}.task-board{display:flex;gap:var(--space-4);overflow-x:auto;padding-bottom:var(--space-4)}.task-board__column{width:300px;min-width:300px;background:var(--color-bg-raised);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-3);display:flex;flex-direction:column;gap:var(--space-2)}.task-board__column-header{display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-2) var(--space-2);border-bottom:1px solid var(--color-border)}.task-board__column-title{font-family:var(--font-display);font-size:.875rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;margin:0;color:var(--color-text)}.task-board__column-count{font-size:.75rem;color:var(--color-text-dim);font-variant-numeric:tabular-nums}.task-board__column-body{display:flex;flex-direction:column;gap:var(--space-2);min-height:40px}.task-board__empty{padding:var(--space-4);text-align:center;color:var(--color-text-muted);font-size:.75rem}.task-card{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:var(--space-3);display:flex;flex-direction:column;gap:var(--space-2);transition:border-color .12s ease,transform .12s ease}.task-card:hover{border-color:var(--color-accent)}.task-card__title-btn{background:transparent;border:none;text-align:left;padding:0;cursor:pointer}.task-card__title{font-family:var(--font-display);font-size:.9375rem;font-weight:700;color:var(--color-text)}.task-card__description{margin:0;font-size:.8125rem;color:var(--color-text-dim);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.task-card__meta{display:flex;align-items:center;justify-content:space-between;font-size:.75rem;color:var(--color-text-dim)}.task-card__assignee{font-size:.75rem;color:var(--color-text)}.task-card__footer{display:flex;justify-content:space-between;align-items:center;gap:var(--space-2);padding-top:var(--space-2);border-top:1px solid var(--color-border)}.task-card__due{font-size:.6875rem;color:var(--color-text-dim)}.task-card__status-select{padding:2px var(--space-2);background:var(--color-bg-raised);border:1px solid var(--color-border-strong);color:var(--color-text);border-radius:var(--radius-sm);font-family:var(--font-body);font-size:.75rem;cursor:pointer}.task-priority-pill{display:inline-block;padding:2px var(--space-2);border-radius:999px;font-size:.6875rem;text-transform:uppercase;letter-spacing:.06em}.task-priority-pill--high{background:var(--color-red-bg);color:var(--color-red)}.task-priority-pill--normal{background:var(--color-amber-bg);color:var(--color-amber)}.task-priority-pill--low{background:var(--color-grey-bg);color:var(--color-grey)}.create-task-modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;display:flex;align-items:center;justify-content:center;z-index:150;padding:var(--space-4)}.create-task-modal__dialog{width:100%;max-width:520px;max-height:90vh;overflow-y:auto;background:var(--color-bg-elevated);border:1px solid var(--color-border-strong);border-radius:var(--radius-md);box-shadow:var(--shadow-tile-hover);animation:create-task-in .16s ease-out}@keyframes create-task-in{0%{transform:translateY(8px);opacity:0}to{transform:translateY(0);opacity:1}}.create-task-modal__header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--color-border)}.create-task-modal__title{font-family:var(--font-display);font-size:1.125rem;font-weight:700;margin:0;color:var(--color-text)}.create-task-modal__close{background:transparent;border:none;color:var(--color-text-dim);font-size:1.5rem;cursor:pointer;padding:0;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm)}.create-task-modal__close:hover{color:var(--color-text);background:var(--color-bg-raised)}.create-task-modal__form{padding:var(--space-4) var(--space-5);display:flex;flex-direction:column;gap:var(--space-2)}.create-task-modal__label{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-dim);margin-top:var(--space-2)}.create-task-modal__input,.create-task-modal__select,.create-task-modal__textarea{padding:var(--space-2) var(--space-3);background:var(--color-bg-raised);border:1px solid var(--color-border-strong);border-radius:var(--radius-sm);color:var(--color-text);font-family:var(--font-body);font-size:.875rem}.create-task-modal__textarea{resize:vertical;font-family:var(--font-body)}.create-task-modal__input:focus,.create-task-modal__select:focus,.create-task-modal__textarea:focus{outline:2px solid var(--color-accent);outline-offset:1px}.create-task-modal__error{padding:var(--space-2) var(--space-3);background:var(--color-red-bg);color:var(--color-red);border-radius:var(--radius-sm);font-size:.8125rem;margin-top:var(--space-2)}.create-task-modal__actions{display:flex;gap:var(--space-2);justify-content:flex-end;margin-top:var(--space-4)}.create-task-modal__btn{padding:var(--space-2) var(--space-4);background:var(--color-bg-raised);border:1px solid var(--color-border-strong);color:var(--color-text);border-radius:var(--radius-sm);font-family:var(--font-body);font-size:.875rem;cursor:pointer;transition:background .12s ease}.create-task-modal__btn:hover:not(:disabled){background:var(--color-bg-elevated)}.create-task-modal__btn:disabled{opacity:.5;cursor:not-allowed}.create-task-modal__btn--primary{background:var(--color-accent);border-color:var(--color-accent);color:var(--color-bg)}.activity-tab__list{display:flex;flex-direction:column}.activity-row{display:flex;gap:var(--space-3);align-items:baseline;padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border)}.activity-row:last-child{border-bottom:none}.activity-row__user{font-family:var(--font-display);font-size:.8125rem;font-weight:700;color:var(--color-text);flex-shrink:0}.activity-row__summary{flex:1 1 auto;font-family:var(--font-body);font-size:.8125rem;color:var(--color-text)}.activity-row__time{margin-left:auto;font-size:.75rem;color:var(--color-text-dim);font-variant-numeric:tabular-nums;flex-shrink:0}.time-report-tab__period{display:flex;flex-wrap:wrap;gap:var(--space-4);align-items:flex-end;margin-bottom:var(--space-4);padding:var(--space-3) var(--space-4);background:var(--color-bg-raised);border:1px solid var(--color-border);border-radius:var(--radius-md)}.time-report-tab__period-label{display:flex;flex-direction:column;gap:var(--space-1);font-size:.6875rem;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-dim)}.time-report-tab__select,.time-report-tab__input{padding:var(--space-2) var(--space-3);background:var(--color-bg-elevated);border:1px solid var(--color-border-strong);color:var(--color-text);border-radius:var(--radius-sm);font-family:var(--font-body);font-size:.875rem}.time-report-tab__total{margin-left:auto;font-size:.8125rem;color:var(--color-text-dim);font-variant-numeric:tabular-nums}.time-report-tab__total strong{color:var(--color-text);font-family:var(--font-display);font-weight:700}.time-report-table{width:100%;border-collapse:collapse;background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden;font-variant-numeric:tabular-nums}.time-report-table thead{background:var(--color-bg-raised)}.time-report-table th,.time-report-table td{padding:var(--space-3) var(--space-4);text-align:left;border-bottom:1px solid var(--color-border);font-size:.8125rem}.time-report-table th{font-family:var(--font-display);font-weight:700;text-transform:uppercase;letter-spacing:.05em;font-size:.6875rem;color:var(--color-text-dim)}.time-report-table tr:last-child td{border-bottom:none}.time-report-table__empty{text-align:center;color:var(--color-text-dim);padding:var(--space-5)}@media (max-width: 720px){.team-header,.team-content{padding:var(--space-4)}.team-tabs{padding:0 var(--space-4)}.roster-member-row{grid-template-columns:40px 1fr;grid-auto-flow:row;row-gap:var(--space-2)}.roster-member-row__tz,.roster-member-row__clocked,.roster-member-row__hours,.roster-member-row__tasks{grid-column:1 / -1;align-items:flex-start}}@media (prefers-reduced-motion: reduce){.create-task-modal__dialog,.roster-member-row__dot--in{animation:none}.task-card:hover{transform:none}}.clock-button{position:fixed;bottom:var(--space-4);right:var(--space-4);z-index:140;display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:var(--color-bg-elevated);border:1px solid var(--color-border-strong);border-radius:999px;color:var(--color-text);font-family:var(--font-body);font-size:.8125rem;cursor:pointer;box-shadow:var(--shadow-tile);transition:background .15s ease,border-color .15s ease,transform .15s ease}.clock-button:hover:not(:disabled){background:var(--color-bg-raised);border-color:var(--color-accent);transform:translateY(-1px)}.clock-button:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.clock-button:disabled{cursor:wait;opacity:.75}.clock-button--clocked-in{border-color:var(--color-green)}.clock-button--busy{opacity:.8}.clock-button__dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.clock-button__dot--in{background:var(--color-green);box-shadow:0 0 6px var(--color-green-bg);animation:clock-button-pulse 2s ease-in-out infinite}.clock-button__dot--out{background:var(--color-grey)}.clock-button__label{font-variant-numeric:tabular-nums;white-space:nowrap}.clock-button__error{color:var(--color-red);font-weight:700;margin-left:var(--space-1)}@keyframes clock-button-pulse{0%,to{opacity:1}50%{opacity:.55}}.team-online-badge{display:inline-flex;align-items:center;gap:var(--space-2);padding:2px var(--space-3);background:var(--color-green-bg);color:var(--color-green);font-size:.6875rem;text-transform:uppercase;letter-spacing:.06em;border-radius:999px;font-variant-numeric:tabular-nums}.team-online-badge__dot{width:6px;height:6px;border-radius:50%;background:var(--color-green);box-shadow:0 0 6px var(--color-green-bg)}@media (max-width: 720px){.clock-button{bottom:var(--space-2);right:var(--space-2);padding:var(--space-1) var(--space-3);font-size:.75rem}}@media (prefers-reduced-motion: reduce){.clock-button,.clock-button:hover:not(:disabled){transition:none;transform:none}.clock-button__dot--in{animation:none}}.netforge-status-pill{display:inline-block;padding:2px 10px;border-radius:999px;font-size:.6875rem;text-transform:uppercase;letter-spacing:.08em;font-weight:600;background:var(--color-grey-bg, rgba(120, 130, 150, .18));color:var(--color-grey, #8892a6)}.netforge-status--queued{background:var(--color-grey-bg, rgba(120, 130, 150, .18));color:var(--color-grey, #8892a6)}.netforge-status--dispatched{background:var(--color-amber-bg, rgba(240, 175, 60, .16));color:var(--color-amber, #f0af3c)}.netforge-status--success{background:var(--color-green-bg, rgba(55, 200, 130, .16));color:var(--color-green, #37c882)}.netforge-status--failed{background:var(--color-red-bg, rgba(235, 80, 85, .18));color:var(--color-red, #eb5055)}.netforge-status--rolled_back{background:var(--color-amber-bg, rgba(240, 175, 60, .16));color:var(--color-amber, #f0af3c)}.netforge-status--rollback_failed{background:var(--color-red-bg, rgba(235, 80, 85, .18));color:var(--color-red, #eb5055)}.netforge-job-panel{position:fixed;top:0;right:0;bottom:0;width:420px;max-width:90vw;display:flex;flex-direction:column;background:var(--color-bg-raised, #16181d);border-left:1px solid var(--color-border-strong, rgba(255, 255, 255, .14));box-shadow:-8px 0 32px #00000059;transform:translate(100%);transition:transform .25s ease;z-index:150;color:var(--color-text, #e6e6ea)}.netforge-job-panel--open{transform:translate(0)}@media (prefers-reduced-motion: reduce){.netforge-job-panel{transition:none}}.netforge-job-panel__header{display:flex;align-items:flex-start;justify-content:space-between;padding:24px;border-bottom:1px solid var(--color-border, rgba(255, 255, 255, .08));gap:12px}.netforge-job-panel__title{font-family:Syne,system-ui,sans-serif;font-size:1.125rem;font-weight:700;margin:0 0 6px}.netforge-job-panel__phase{display:flex;align-items:center;gap:8px}.netforge-job-panel__phase-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted, #97a0b0)}.netforge-job-panel__close{background:transparent;border:1px solid var(--color-border, rgba(255, 255, 255, .12));color:var(--color-text, #e6e6ea);padding:6px 12px;border-radius:6px;font-size:.75rem;cursor:pointer}.netforge-job-panel__close:hover{background:var(--color-bg-elevated, rgba(255, 255, 255, .06))}.netforge-job-panel__body{flex:1;overflow-y:auto;padding:20px 24px;display:flex;flex-direction:column;gap:14px}.netforge-job-panel__row{display:flex;flex-direction:column;gap:4px}.netforge-job-panel__label{font-size:.6875rem;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted, #97a0b0)}.netforge-job-panel__value{font-size:.875rem;font-family:JetBrains Mono,Fira Code,monospace;color:var(--color-text, #e6e6ea);word-break:break-all}.netforge-job-panel__ticket{color:var(--color-accent, #7aa2ff)}.netforge-job-panel__empty{color:var(--color-text-muted, #97a0b0);font-size:.875rem;margin:0}.netforge-job-panel__rollback{background:var(--color-amber-bg, rgba(240, 175, 60, .16));color:var(--color-amber, #f0af3c);padding:10px 14px;border-radius:6px;font-size:.8125rem}.netforge-job-panel__rollback-failed{background:var(--color-red-bg, rgba(235, 80, 85, .18));color:var(--color-red, #eb5055);padding:10px 14px;border-radius:6px;font-size:.8125rem;font-weight:600}.netforge-job-panel__error{background:var(--color-red-bg, rgba(235, 80, 85, .18));color:var(--color-red, #eb5055);padding:10px 14px;border-radius:6px;font-size:.8125rem}.netforge-job-panel__snapshots{display:flex;flex-direction:column;gap:6px;padding-top:8px;border-top:1px solid var(--color-border, rgba(255, 255, 255, .08))}.netforge-job-panel__snapshot-link{color:var(--color-accent, #7aa2ff);font-size:.8125rem;text-decoration:none}.netforge-job-panel__snapshot-link:hover{text-decoration:underline}.netforge-job-panel__footer{padding:16px 24px;border-top:1px solid var(--color-border, rgba(255, 255, 255, .08));display:flex;justify-content:flex-end}.netforge-job-panel__dismiss{background:var(--color-accent, #7aa2ff);color:#0b0d12;border:none;padding:8px 16px;border-radius:6px;font-weight:600;cursor:pointer}.netforge-confirm{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;display:flex;align-items:center;justify-content:center;z-index:300;padding:24px}.netforge-confirm__dialog{background:var(--color-bg-raised, #16181d);color:var(--color-text, #e6e6ea);border:1px solid var(--color-border-strong, rgba(255, 255, 255, .14));border-radius:10px;padding:24px;max-width:520px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 24px 64px #00000073}.netforge-confirm__title{font-family:Syne,system-ui,sans-serif;font-size:1.25rem;margin:0 0 12px}.netforge-confirm__body{font-size:.875rem;color:var(--color-text-muted, #97a0b0);margin:0 0 16px}.netforge-confirm__body code{font-family:JetBrains Mono,Fira Code,monospace;color:var(--color-text, #e6e6ea);background:var(--color-bg-elevated, rgba(255, 255, 255, .06));padding:1px 6px;border-radius:4px}.netforge-confirm__params{display:flex;flex-direction:column;gap:6px;margin:0 0 16px;padding:12px;background:var(--color-bg-elevated, rgba(255, 255, 255, .04));border-radius:6px}.netforge-confirm__param{display:flex;justify-content:space-between;font-size:.8125rem;gap:12px}.netforge-confirm__param dt{color:var(--color-text-muted, #97a0b0);text-transform:uppercase;font-size:.6875rem;letter-spacing:.06em}.netforge-confirm__param dd{margin:0;font-family:JetBrains Mono,Fira Code,monospace}.netforge-confirm__field{margin-bottom:16px}.netforge-confirm__label{display:block;font-size:.8125rem;color:var(--color-text-muted, #97a0b0);margin-bottom:6px}.netforge-confirm__input{width:100%;box-sizing:border-box;background:var(--color-bg, #0b0d12);color:var(--color-text, #e6e6ea);border:1px solid var(--color-border, rgba(255, 255, 255, .12));border-radius:6px;padding:9px 12px;font-size:.875rem;font-family:JetBrains Mono,Fira Code,monospace}.netforge-confirm__input:focus{outline:2px solid var(--color-accent, #7aa2ff);outline-offset:1px}.netforge-confirm__error{color:var(--color-red, #eb5055);font-size:.8125rem;margin-top:6px}.netforge-confirm__status{display:flex;align-items:center;gap:10px;font-size:.875rem;padding:12px 14px;border-radius:6px;background:var(--color-bg-elevated, rgba(255, 255, 255, .04));margin-bottom:12px}.netforge-confirm__status--success{background:var(--color-green-bg, rgba(55, 200, 130, .16));color:var(--color-green, #37c882)}.netforge-confirm__status--failure{background:var(--color-red-bg, rgba(235, 80, 85, .18));color:var(--color-red, #eb5055)}.netforge-confirm__pill{margin-left:auto}.netforge-confirm__ticket-line{font-size:.8125rem;color:var(--color-text-muted, #97a0b0);margin-bottom:8px}.netforge-confirm__snapshot-link{display:block;color:var(--color-accent, #7aa2ff);font-size:.8125rem;text-decoration:none;margin-top:6px}.netforge-confirm__snapshot-link:hover{text-decoration:underline}.netforge-confirm__rollback{font-size:.8125rem;padding:10px 14px;border-radius:6px;background:var(--color-amber-bg, rgba(240, 175, 60, .16));color:var(--color-amber, #f0af3c);margin-bottom:12px}.netforge-confirm__rollback--failed{background:var(--color-red-bg, rgba(235, 80, 85, .18));color:var(--color-red, #eb5055);font-weight:600}.netforge-confirm__spinner{width:14px;height:14px;border:2px solid rgba(255,255,255,.2);border-top-color:var(--color-accent, #7aa2ff);border-radius:50%;animation:netforge-spin .8s linear infinite;display:inline-block}@keyframes netforge-spin{to{transform:rotate(360deg)}}@media (prefers-reduced-motion: reduce){.netforge-confirm__spinner{animation:none}}.netforge-confirm__actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}.netforge-confirm__btn{background:transparent;color:var(--color-text, #e6e6ea);border:1px solid var(--color-border, rgba(255, 255, 255, .12));padding:9px 18px;border-radius:6px;font-size:.875rem;cursor:pointer;font-weight:500}.netforge-confirm__btn:hover:not(:disabled){background:var(--color-bg-elevated, rgba(255, 255, 255, .06))}.netforge-confirm__btn:disabled{opacity:.5;cursor:not-allowed}.netforge-confirm__btn--primary{background:var(--color-accent, #7aa2ff);color:#0b0d12;border-color:var(--color-accent, #7aa2ff);font-weight:600}.netforge-confirm__btn--primary:hover:not(:disabled){filter:brightness(1.1);background:var(--color-accent, #7aa2ff)}.netforge-confirm__btn--danger{background:var(--color-red, #eb5055);color:#fff;border-color:var(--color-red, #eb5055);font-weight:600}.netforge-confirm__btn--danger:hover:not(:disabled){filter:brightness(1.1)}.netforge-confirm__btn--armed{animation:netforge-arm-pulse 1s ease-in-out infinite}@keyframes netforge-arm-pulse{0%,to{box-shadow:0 0 #eb5055b3}50%{box-shadow:0 0 0 6px #eb505500}}@media (prefers-reduced-motion: reduce){.netforge-confirm__btn--armed{animation:none;box-shadow:0 0 0 2px #eb5055b3}}.device-config-history{display:flex;flex-direction:column;gap:14px;padding:16px;background:var(--color-bg-elevated, rgba(255, 255, 255, .03));border-radius:8px;border:1px solid var(--color-border, rgba(255, 255, 255, .08))}.device-config-history__header{display:flex;justify-content:space-between;align-items:center}.device-config-history__title{margin:0;font-size:.9375rem;font-weight:600}.device-config-history__refresh{background:transparent;border:1px solid var(--color-border, rgba(255, 255, 255, .12));color:var(--color-text, #e6e6ea);padding:5px 12px;border-radius:6px;font-size:.75rem;cursor:pointer}.device-config-history__loading,.device-config-history__empty{color:var(--color-text-muted, #97a0b0);font-size:.8125rem;text-align:center;padding:16px 0}.device-config-history__error{color:var(--color-red, #eb5055);font-size:.8125rem;padding:10px 12px;background:var(--color-red-bg, rgba(235, 80, 85, .12));border-radius:6px}.device-config-history__list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px;max-height:320px;overflow-y:auto}.device-config-history__item{display:flex;align-items:flex-start;gap:12px;padding:10px 12px;background:var(--color-bg-raised, #16181d);border:1px solid var(--color-border, rgba(255, 255, 255, .08));border-radius:6px}.device-config-history__item--selected{border-color:var(--color-accent, #7aa2ff);background:#7aa2ff0f}.device-config-history__check{padding-top:3px}.device-config-history__info{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.device-config-history__row{display:flex;justify-content:space-between;align-items:center;gap:8px}.device-config-history__action{font-weight:600;font-size:.875rem}.device-config-history__meta{display:flex;gap:12px;font-size:.75rem;color:var(--color-text-muted, #97a0b0)}.device-config-history__ticket{font-family:JetBrains Mono,Fira Code,monospace}.device-config-history__snapshots{display:flex;gap:10px;font-size:.75rem}.device-config-history__snapshot-link{color:var(--color-accent, #7aa2ff);text-decoration:none;text-transform:uppercase;letter-spacing:.06em}.device-config-history__actions{display:flex;justify-content:flex-end}.device-config-history__diff-btn{background:var(--color-accent, #7aa2ff);color:#0b0d12;border:none;padding:7px 16px;border-radius:6px;font-size:.8125rem;font-weight:600;cursor:pointer}.device-config-history__diff-btn:disabled{opacity:.45;cursor:not-allowed}.config-diff{font-family:JetBrains Mono,Fira Code,monospace;font-size:.75rem;background:var(--color-bg, #0b0d12);color:var(--color-text, #e6e6ea);border:1px solid var(--color-border, rgba(255, 255, 255, .1));border-radius:6px;padding:8px 0;max-height:480px;overflow:auto;margin:0;white-space:pre}.config-diff__line{display:flex;gap:6px;padding:1px 12px;line-height:1.45}.config-diff__line--add{background:#37c88224;color:#9be8bf}.config-diff__line--remove{background:#eb505524;color:#ffb0b3}.config-diff__line--equal{color:var(--color-text-muted, #97a0b0)}.config-diff__sigil{width:12px;flex-shrink:0;opacity:.8}.config-diff__text{flex:1}.integrations-tab{display:flex;flex-direction:column;gap:20px;padding:24px;color:var(--color-text, #e6e6ea)}.integrations-tab__header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px}.integrations-tab__title{font-family:Syne,system-ui,sans-serif;font-size:1.25rem;margin:0 0 4px}.integrations-tab__subtitle{margin:0;color:var(--color-text-muted, #97a0b0);font-size:.875rem;max-width:560px}.integrations-tab__refresh{background:transparent;border:1px solid var(--color-border, rgba(255, 255, 255, .12));color:var(--color-text, #e6e6ea);padding:7px 14px;border-radius:6px;font-size:.8125rem;cursor:pointer}.integrations-tab__refresh:hover{background:var(--color-bg-elevated, rgba(255, 255, 255, .06))}.integrations-tab__loading{color:var(--color-text-muted, #97a0b0);font-size:.875rem;padding:16px 0}.integrations-tab__error{background:var(--color-red-bg, rgba(235, 80, 85, .16));color:var(--color-red, #eb5055);padding:10px 14px;border-radius:6px;font-size:.875rem}.integrations-tab__grid{display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.integration-card{background:var(--color-bg-raised, #16181d);border:1px solid var(--color-border-strong, rgba(255, 255, 255, .12));border-radius:10px;padding:18px;display:flex;flex-direction:column;gap:14px}.integration-card[data-enabled=true]{border-color:var(--color-accent, #7aa2ff)}.integration-card__header{display:flex;justify-content:space-between;align-items:center;gap:12px}.integration-card__identity{display:flex;align-items:center;gap:10px;min-width:0}.integration-card__glyph{font-size:1.25rem;color:var(--color-accent, #7aa2ff)}.integration-card__name{margin:0;font-size:1rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.integration-card__toggle{display:flex;align-items:center;gap:6px;font-size:.75rem;color:var(--color-text-muted, #97a0b0);cursor:pointer}.integration-card__toggle input[type=checkbox]{cursor:pointer}.integration-card__toggle input[type=checkbox]:disabled{cursor:not-allowed}.integration-card__body{display:flex;flex-direction:column;gap:10px}.integration-card__status{display:flex;align-items:center;gap:10px}.integration-card__pill{display:inline-block;padding:2px 10px;border-radius:999px;font-size:.6875rem;text-transform:uppercase;letter-spacing:.06em;font-weight:600}.integration-card__pill--ok{background:var(--color-green-bg, rgba(55, 200, 130, .16));color:var(--color-green, #37c882)}.integration-card__pill--error{background:var(--color-red-bg, rgba(235, 80, 85, .18));color:var(--color-red, #eb5055)}.integration-card__pill--none{background:var(--color-grey-bg, rgba(120, 130, 150, .18));color:var(--color-grey, #8892a6)}.integration-card__meta{font-size:.75rem;color:var(--color-text-muted, #97a0b0)}.integration-card__stats{display:flex;gap:18px}.integration-card__stat{display:flex;flex-direction:column;gap:2px}.integration-card__stat-label{font-size:.6875rem;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted, #97a0b0)}.integration-card__stat-value{font-family:JetBrains Mono,Fira Code,monospace;font-size:.875rem}.integration-card__error{background:var(--color-red-bg, rgba(235, 80, 85, .14));color:var(--color-red, #eb5055);padding:8px 12px;border-radius:6px;font-size:.75rem}.integration-card__hint{color:var(--color-text-muted, #97a0b0);font-size:.75rem;font-style:italic}.integration-card__actions{display:flex;justify-content:flex-end;gap:8px;border-top:1px solid var(--color-border, rgba(255, 255, 255, .08));padding-top:12px}.integration-card__btn{background:transparent;border:1px solid var(--color-border, rgba(255, 255, 255, .12));color:var(--color-text, #e6e6ea);padding:6px 14px;border-radius:6px;font-size:.8125rem;cursor:pointer}.integration-card__btn:hover{background:var(--color-bg-elevated, rgba(255, 255, 255, .06))}.integration-sync-btn{background:var(--color-accent, #7aa2ff);color:#0b0d12;border:none;padding:6px 14px;border-radius:6px;font-size:.8125rem;font-weight:600;cursor:pointer}.integration-sync-btn:disabled{opacity:.5;cursor:not-allowed}.integration-sync-btn--success{background:var(--color-green, #37c882)}.integration-sync-btn--failure{background:var(--color-red, #eb5055);color:#fff}.integration-config-modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;display:flex;align-items:center;justify-content:center;z-index:300;padding:24px}.integration-config-modal__dialog{background:var(--color-bg-raised, #16181d);color:var(--color-text, #e6e6ea);border:1px solid var(--color-border-strong, rgba(255, 255, 255, .14));border-radius:10px;padding:24px;max-width:480px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 24px 64px #00000073}.integration-config-modal__title{font-family:Syne,system-ui,sans-serif;font-size:1.125rem;margin:0 0 16px}.integration-config-modal__body{display:flex;flex-direction:column;gap:14px}.integration-config-modal__field{display:flex;flex-direction:column;gap:6px}.integration-config-modal__label{font-size:.8125rem;color:var(--color-text-muted, #97a0b0);display:flex;align-items:center;gap:8px}.integration-config-modal__hint{font-size:.6875rem;font-style:italic;color:var(--color-text-muted, #97a0b0)}.integration-config-modal__input{background:var(--color-bg, #0b0d12);color:var(--color-text, #e6e6ea);border:1px solid var(--color-border, rgba(255, 255, 255, .12));border-radius:6px;padding:9px 12px;font-size:.875rem;font-family:inherit;box-sizing:border-box}.integration-config-modal__input:focus{outline:2px solid var(--color-accent, #7aa2ff);outline-offset:1px}.integration-config-modal__error{color:var(--color-red, #eb5055);font-size:.8125rem;padding:8px 12px;background:var(--color-red-bg, rgba(235, 80, 85, .12));border-radius:6px}.integration-config-modal__actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}.integration-config-modal__btn{background:transparent;color:var(--color-text, #e6e6ea);border:1px solid var(--color-border, rgba(255, 255, 255, .12));padding:9px 18px;border-radius:6px;font-size:.875rem;cursor:pointer;font-weight:500}.integration-config-modal__btn:hover:not(:disabled){background:var(--color-bg-elevated, rgba(255, 255, 255, .06))}.integration-config-modal__btn:disabled{opacity:.5;cursor:not-allowed}.integration-config-modal__btn--primary{background:var(--color-accent, #7aa2ff);color:#0b0d12;border-color:var(--color-accent, #7aa2ff);font-weight:600}.integration-config-modal__btn--primary:hover:not(:disabled){filter:brightness(1.1);background:var(--color-accent, #7aa2ff)}@media (prefers-reduced-motion: reduce){.integration-config-modal,.integration-card{transition:none}}:root{--brand-primary: #c9a961;--brand-secondary: #2a2a33}.brand-tab{display:flex;flex-direction:column;gap:1.5rem;padding:1rem 0}.brand-tab__header{display:flex;flex-direction:column;gap:.25rem}.brand-tab__title{font-size:1.4rem;font-weight:600;margin:0}.brand-tab__subtitle{margin:0;color:#888;font-size:.9rem}.brand-tab__form{display:flex;flex-direction:column;gap:1.25rem}.brand-tab__section{display:flex;flex-direction:column;gap:.75rem;padding:1rem;border:1px solid #2c2c33;border-radius:8px;background:#14141a}.brand-tab__section--colors{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.brand-tab__section-title{margin:0 0 .5rem;font-size:1rem;font-weight:600}.brand-tab__field{display:flex;flex-direction:column;gap:.35rem}.brand-tab__field-label{font-size:.85rem;color:#aaa}.brand-tab__field-input{font:inherit;padding:.5rem .75rem;border-radius:6px;border:1px solid #333;background:#0a0a10;color:#eee;width:100%;box-sizing:border-box}.brand-tab__field-help{margin:0;font-size:.78rem;color:#888}.brand-tab__color-picker{display:flex;flex-direction:column;gap:.4rem}.brand-tab__color-picker-label{font-size:.85rem;color:#aaa}.brand-tab__color-picker-row{display:flex;align-items:center;gap:.6rem}.brand-tab__color-picker-row input[type=color]{width:44px;height:32px;border:1px solid #333;border-radius:4px;background:transparent;padding:0}.brand-tab__color-picker-hex{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.85rem;color:#ccc}.brand-tab__preview{grid-column:1 / -1;display:flex;flex-direction:column;gap:.5rem;border:1px dashed #333;border-radius:6px;padding:.75rem;background:#0a0a10}.brand-tab__preview-bar{height:8px;border-radius:2px;transition:background .2s ease}.brand-tab__preview-card{padding:1rem;border-radius:6px;font-size:1.1rem;font-weight:600;transition:background .2s ease}.brand-tab__product-overrides{display:flex;flex-direction:column;gap:.5rem}.brand-tab__product-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.5rem}.brand-tab__product-row{display:flex;flex-direction:column;gap:.2rem}.brand-tab__product-key{font-size:.75rem;color:#888;font-family:ui-monospace,SFMono-Regular,Menlo,monospace}.brand-tab__logo-upload{display:flex;flex-direction:column;gap:.4rem}.brand-tab__logo-upload-preview{margin-top:.5rem;padding:.5rem;border:1px solid #2c2c33;border-radius:6px;background:#0a0a10;display:inline-block}.brand-tab__logo-upload-preview img{max-height:64px;max-width:240px;display:block}.brand-tab__footer{display:flex;align-items:center;gap:1rem}.brand-tab__submit{font:inherit;padding:.55rem 1.1rem;border-radius:6px;border:none;background:var(--brand-primary);color:#0a0a0a;font-weight:600;cursor:pointer;transition:filter .15s ease}.brand-tab__submit:hover:not(:disabled){filter:brightness(1.08)}.brand-tab__submit:disabled{cursor:not-allowed;filter:grayscale(.5)}.brand-tab__status{color:#6fbf6f;font-size:.85rem}.brand-tab__error{color:#e57373;font-size:.85rem}.modules-tab{display:flex;flex-direction:column;gap:1.25rem;padding:1rem 0}.modules-tab__header{display:flex;flex-direction:column;gap:.25rem}.modules-tab__title{font-size:1.4rem;font-weight:600;margin:0}.modules-tab__subtitle{margin:0;color:#888;font-size:.9rem}.modules-tab__form{display:flex;flex-direction:column;gap:1rem}.modules-tab__grid{display:grid;grid-template-columns:1fr;gap:.4rem;border:1px solid #2c2c33;border-radius:8px;overflow:hidden}.modules-tab__row{display:grid;grid-template-columns:1fr auto auto;align-items:center;gap:.75rem;padding:.55rem .85rem;background:#14141a;transition:background .15s ease}.modules-tab__row:not(:last-child){border-bottom:1px solid #1f1f25}.modules-tab__row--disabled{background:#0e0e13;color:#666}.modules-tab__row-name{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.88rem}.modules-tab__row-toggle{display:flex;align-items:center;gap:.5rem;cursor:pointer}.modules-tab__row-tier{font:inherit;padding:.35rem .5rem;border-radius:4px;border:1px solid #333;background:#0a0a10;color:#ddd}.entitlement-pill{display:inline-block;padding:.15rem .55rem;border-radius:999px;background:#1d1d24;color:#aaa;font-size:.72rem;text-transform:uppercase;letter-spacing:.04em}.modules-tab__row:not(.modules-tab__row--disabled) .entitlement-pill{background:var(--brand-primary);color:#0a0a0a}.modules-tab__footer{display:flex;align-items:center;gap:1rem}.modules-tab__submit{font:inherit;padding:.55rem 1.1rem;border-radius:6px;border:none;background:var(--brand-primary);color:#0a0a0a;font-weight:600;cursor:pointer;transition:filter .15s ease}.modules-tab__submit:hover:not(:disabled){filter:brightness(1.08)}.modules-tab__submit:disabled{cursor:not-allowed;filter:grayscale(.5)}.modules-tab__status{color:#6fbf6f;font-size:.85rem}.modules-tab__error{color:#e57373;font-size:.85rem}@media (prefers-reduced-motion: reduce){.brand-tab__preview-bar,.brand-tab__preview-card,.brand-tab__submit,.modules-tab__row,.modules-tab__submit{transition:none}}.vault-page{padding:24px 32px;color:#e5e5e5;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.vault-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;border-bottom:1px solid #2a2a2a;padding-bottom:16px}.vault-title{font-size:28px;margin:0 0 4px;color:#f5f5f5}.vault-subtitle{margin:0;font-size:13px;color:#888}.vault-meta{display:flex;align-items:center;gap:12px}.vault-countdown-badge{display:inline-block;padding:6px 12px;border-radius:999px;background:#1a3a2a;color:#8fe0a8;font-size:12px;font-family:SF Mono,Menlo,Consolas,monospace;border:1px solid #2c5b3f}.vault-countdown-badge--inactive{background:#1a1a1a;color:#666;border-color:#2a2a2a}.vault-countdown-badge--expiring{background:#3a2a1a;color:#ffb86c;border-color:#5b3f2c}.vault-countdown-badge--expired{background:#3a1a1a;color:#ff7575;border-color:#5b2c2c}.vault-list{display:flex;flex-direction:column;gap:8px}.vault-list--loading,.vault-list--empty,.vault-list--error{padding:24px;text-align:center;color:#666}.vault-list--error{color:#ff7575}.vault-entry-row{display:grid;grid-template-columns:2fr 1fr 1fr 1fr auto;align-items:center;gap:16px;padding:14px 16px;background:#161616;border:1px solid #262626;border-radius:6px}.vault-entry-row__label{font-weight:600;color:#f5f5f5}.vault-entry-row__type{font-size:12px;color:#888;text-transform:uppercase;letter-spacing:.5px}.vault-entry-row__rotated{font-size:12px;color:#888}.vault-entry-row__secret{font-family:SF Mono,Menlo,Consolas,monospace;color:#888;letter-spacing:4px}.vault-entry-row__reveal{background:#c9a961;color:#0a0a0a;border:none;padding:8px 16px;border-radius:4px;cursor:pointer;font-weight:600;font-size:13px}.vault-entry-row__reveal:hover:not(:disabled){background:#d8b970}.vault-entry-row__reveal:disabled{opacity:.6;cursor:not-allowed}.vault-entry-row__error{margin-left:8px;color:#ff7575;font-size:12px}.vault-stepup{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:200}.vault-stepup__dialog{background:#181818;border:1px solid #303030;border-radius:8px;padding:24px;min-width:380px;max-width:480px;color:#e5e5e5}.vault-stepup__title{margin:0 0 8px;font-size:18px;color:#f5f5f5}.vault-stepup__body{margin:0 0 16px;font-size:13px;color:#aaa}.vault-stepup__method-picker{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}.vault-stepup__method-btn{background:#232323;color:#d5d5d5;border:1px solid #353535;padding:8px 12px;border-radius:4px;cursor:pointer;font-size:12px}.vault-stepup__method-btn--active{background:#2a2a3a;color:#c9a961;border-color:#c9a961}.vault-stepup__field{margin-bottom:16px}.vault-stepup__label{display:block;font-size:12px;color:#888;margin-bottom:6px}.vault-stepup__code-input{width:100%;padding:12px 14px;background:#0e0e0e;border:1px solid #303030;color:#f5f5f5;font-family:SF Mono,Menlo,Consolas,monospace;font-size:18px;letter-spacing:6px;text-align:center;border-radius:4px}.vault-stepup__primary{width:100%;background:#c9a961;color:#0a0a0a;border:none;padding:10px 16px;border-radius:4px;cursor:pointer;font-weight:600;margin-top:8px}.vault-stepup__primary:disabled{opacity:.5;cursor:not-allowed}.vault-stepup__status{padding:8px 0;color:#aaa;font-size:13px}.vault-stepup__error{background:#2a1414;color:#ff7575;padding:10px 12px;border-radius:4px;margin-bottom:12px;font-size:13px}.vault-stepup__actions{display:flex;justify-content:flex-end;margin-top:16px}.vault-stepup__cancel{background:transparent;color:#888;border:1px solid #353535;padding:8px 14px;border-radius:4px;cursor:pointer;font-size:13px}.vault-reveal-modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:300}.vault-reveal-modal__dialog{background:#181818;border:1px solid #303030;border-radius:8px;padding:24px;min-width:420px;max-width:600px;color:#e5e5e5}.vault-reveal-modal__title{margin:0 0 16px;font-size:16px;color:#f5f5f5}.vault-reveal-modal__value{background:#0a0a0a;border:1px solid #303030;border-radius:4px;padding:14px;font-family:SF Mono,Menlo,Consolas,monospace;color:#c9a961;word-break:break-all;white-space:pre-wrap;-webkit-user-select:text;user-select:text;margin:0 0 12px}.vault-reveal-modal__hint{margin:0 0 16px;font-size:12px;color:#888}.vault-reveal-modal__actions{display:flex;justify-content:flex-end;gap:8px}.vault-reveal-modal__btn{background:#232323;color:#d5d5d5;border:1px solid #353535;padding:8px 14px;border-radius:4px;cursor:pointer;font-size:13px}.vault-reveal-modal__btn--primary{background:#c9a961;color:#0a0a0a;border-color:#c9a961;font-weight:600}.app-nav{position:fixed;top:12px;left:50%;transform:translate(-50%);display:flex;gap:4px;padding:6px 10px;background:#141414eb;border:1px solid #2a2a2a;border-radius:999px;z-index:40;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.app-nav__link{color:#aaa;text-decoration:none;font-size:12px;padding:6px 12px;border-radius:999px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.app-nav__link:hover{color:#e5e5e5;background:#1f1f1f}.app-nav__link--active{color:#b8d4ff;background:#2a3f5b}.compliance-page{padding:24px 32px;color:#e5e5e5;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.compliance-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;border-bottom:1px solid #2a2a2a;padding-bottom:16px}.compliance-title{font-size:28px;margin:0 0 4px;color:#f5f5f5}.compliance-subtitle{margin:0;font-size:13px;color:#888}.compliance-controls{display:flex;flex-wrap:wrap;gap:16px;align-items:flex-end;padding:16px;background:#141414;border:1px solid #2a2a2a;border-radius:8px;margin-bottom:20px}.compliance-field{display:flex;flex-direction:column;gap:6px;min-width:180px}.compliance-field label,.compliance-field-label{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:#888}.compliance-field select,.compliance-field input[type=date],.compliance-input{background:#1a1a1a;color:#e5e5e5;border:1px solid #2a2a2a;border-radius:4px;padding:8px 10px;font-size:13px;font-family:inherit;min-height:34px}.compliance-field select:focus,.compliance-field input:focus,.compliance-input:focus{outline:none;border-color:#4a9eff}.compliance-field--group{min-width:320px}.compliance-field--action{align-self:flex-end;min-width:0}.compliance-framework-tabs{display:inline-flex;gap:4px;background:#1a1a1a;border:1px solid #2a2a2a;border-radius:6px;padding:4px}.compliance-framework-tab{background:transparent;color:#aaa;border:none;padding:8px 14px;font-size:12px;border-radius:4px;cursor:pointer;font-family:inherit}.compliance-framework-tab:hover{color:#e5e5e5}.compliance-framework-tab--active{background:#2a3f5b;color:#b8d4ff}.compliance-btn{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:4px;border:1px solid #2a2a2a;background:#1a1a1a;color:#e5e5e5;font-size:13px;font-family:inherit;cursor:pointer;text-decoration:none;transition:border-color .12s ease,background .12s ease}.compliance-btn:hover:not(:disabled){border-color:#4a9eff}.compliance-btn:disabled{opacity:.5;cursor:not-allowed}.compliance-btn--primary{background:#2a3f5b;border-color:#3b5d87;color:#e5f0ff}.compliance-btn--primary:hover:not(:disabled){background:#34507a;border-color:#4a9eff}.compliance-btn--ghost{background:transparent}.compliance-btn--lg{padding:10px 20px;font-size:14px}.compliance-spinner{display:inline-block;width:12px;height:12px;border:2px solid #4a9eff;border-top-color:transparent;border-radius:50%;animation:compliance-spin .7s linear infinite}@keyframes compliance-spin{to{transform:rotate(360deg)}}.compliance-alert{padding:12px 16px;border-radius:4px;margin-bottom:16px;font-size:13px}.compliance-alert--error{background:#3a1a1a;color:#f99;border:1px solid #5b2c2c}.compliance-error{color:#f99;font-size:13px;margin:8px 0 0}.compliance-error-inline{color:#f99;font-size:12px;margin-left:8px}.compliance-success-inline{color:#8fe0a8;font-size:12px;margin-left:8px}.compliance-empty{color:#888;font-size:13px}.compliance-widget{margin:24px 0;padding:16px;background:#141414;border:1px solid #2a2a2a;border-radius:8px}.compliance-widget__header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:16px}.compliance-widget__header h2{font-size:16px;margin:0;color:#f5f5f5}.compliance-widget__client{color:#888;font-size:13px}.compliance-card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}@media (max-width: 900px){.compliance-card-grid{grid-template-columns:1fr}}.compliance-card{background:#1a1a1a;border:1px solid #2a2a2a;border-radius:6px;padding:16px;display:flex;flex-direction:column;gap:10px}.compliance-card--green{border-color:#2c5b3f}.compliance-card--yellow{border-color:#5b3f2c}.compliance-card--red{border-color:#5b2c2c}.compliance-card__header{display:flex;justify-content:space-between;align-items:center}.compliance-card__title{font-size:13px;margin:0;color:#ccc;text-transform:uppercase;letter-spacing:.5px}.compliance-card__disabled-chip{font-size:10px;color:#888;background:#1a1a1a;border:1px solid #2a2a2a;padding:2px 6px;border-radius:999px;text-transform:uppercase}.compliance-card__score{font-size:32px;font-weight:600;font-family:SF Mono,Menlo,Consolas,monospace}.compliance-card__score--green{color:#8fe0a8}.compliance-card__score--yellow{color:#ffb86c}.compliance-card__score--red{color:#ff7575}.compliance-card__score-suffix{font-size:13px;color:#888;font-weight:400;margin-left:4px}.compliance-card__meta{display:flex;gap:16px;margin:0;font-size:11px;color:#888}.compliance-card__meta div{display:flex;flex-direction:column}.compliance-card__meta dt{text-transform:uppercase;letter-spacing:.5px;margin-bottom:2px}.compliance-card__meta dd{color:#ccc;margin:0;font-family:SF Mono,Menlo,Consolas,monospace;font-size:12px}.compliance-card__actions{display:flex;gap:8px;margin-top:auto}.compliance-card--skeleton{min-height:160px;background:linear-gradient(90deg,#161616,#1f1f1f,#161616);background-size:200% 100%;animation:compliance-skeleton 1.5s ease-in-out infinite}.compliance-card__title-skel,.compliance-card__score-skel,.compliance-card__meta-skel{background:#222;border-radius:4px}.compliance-card__title-skel{height:14px;width:60%}.compliance-card__score-skel{height:32px;width:40%}.compliance-card__meta-skel{height:12px;width:80%}@keyframes compliance-skeleton{0%{background-position:100% 0}to{background-position:-100% 0}}.compliance-reports{margin-top:24px;background:#141414;border:1px solid #2a2a2a;border-radius:8px;padding:16px}.compliance-reports__header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:12px}.compliance-reports__header h2{font-size:16px;margin:0;color:#f5f5f5}.compliance-reports__meta{color:#888;font-size:12px}.compliance-reports__loading,.compliance-reports__empty{padding:32px;text-align:center;color:#888;font-size:13px}.compliance-reports__table{width:100%;border-collapse:collapse;font-size:13px}.compliance-reports__table th,.compliance-reports__table td{text-align:left;padding:10px 12px;border-bottom:1px solid #2a2a2a}.compliance-reports__table th{color:#888;text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:500}.compliance-reports__table tbody tr:hover{background:#181818}.compliance-score{display:inline-block;font-family:SF Mono,Menlo,Consolas,monospace;font-weight:600;padding:2px 10px;border-radius:999px}.compliance-score--green{background:#1a3a2a;color:#8fe0a8;border:1px solid #2c5b3f}.compliance-score--yellow{background:#3a2a1a;color:#ffb86c;border:1px solid #5b3f2c}.compliance-score--red{background:#3a1a1a;color:#ff7575;border:1px solid #5b2c2c}.compliance-status{display:inline-block;padding:2px 8px;border-radius:4px;font-size:11px;text-transform:uppercase;letter-spacing:.5px;background:#1a1a1a;color:#aaa;border:1px solid #2a2a2a}.compliance-status--ready{color:#8fe0a8;background:#1a3a2a;border-color:#2c5b3f}.compliance-status--generating,.compliance-status--pending{color:#b8d4ff;background:#1a2a3a;border-color:#2c3f5b}.compliance-status--failed{color:#ff7575;background:#3a1a1a;border-color:#5b2c2c}.compliance-settings-tab{display:flex;flex-direction:column;gap:16px}.compliance-settings-bulk{display:flex;align-items:center;gap:12px}.compliance-settings-table-wrap{overflow-x:auto;border:1px solid #2a2a2a;border-radius:6px}.compliance-settings-table{width:100%;border-collapse:collapse;font-size:13px;min-width:720px}.compliance-settings-table th,.compliance-settings-table td{padding:10px 12px;border-bottom:1px solid #2a2a2a;text-align:left;color:#e5e5e5}.compliance-settings-table thead th{color:#888;text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:500;background:#181818}.compliance-settings-row--highlight{background:#16211b}.compliance-settings-client{font-weight:500;color:#f5f5f5}.compliance-settings-check{text-align:center}.compliance-settings-check input[type=checkbox]{width:16px;height:16px;accent-color:#4a9eff}.compliance-settings-actions{white-space:nowrap}.compliance-settings-loading,.compliance-settings-error,.compliance-settings-empty{padding:24px;text-align:center;color:#888;font-size:13px}.compliance-settings-error{color:#f99}
