:root{--bg:#f4f7fb;--surface:#fff;--surface-soft:#f8fafc;--line:#dbe4ef;--line-strong:#b8c5d6;--text:#172033;--muted:#607087;--muted-2:#8794a8;--brand:#2563eb;--brand-dark:#1d4ed8;--green:#16a34a;--red:#dc2626;--orange:#f97316;--teal:#0f766e;--purple:#7c3aed;--shadow:0 16px 36px #17203314}*{box-sizing:border-box}html{background:var(--bg);min-width:320px}body{color:var(--text);background:var(--bg);letter-spacing:0;margin:0;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:15px}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}button{cursor:pointer}input,select,textarea{border:1px solid var(--line);width:100%;min-height:40px;color:var(--text);background:#fff;border-radius:8px;outline:none;padding:9px 11px}textarea{resize:vertical;min-height:92px}input:focus,select:focus,textarea:focus{border-color:var(--brand);box-shadow:0 0 0 3px #2563eb24}.app-shell{min-height:100vh;padding-top:124px}.topbar{z-index:10000;border-bottom:1px solid var(--line);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff5;gap:10px;padding:10px 22px 12px;display:grid;position:fixed;top:0;left:0;right:0;box-shadow:0 12px 26px #1720331a}.topbar-main{justify-content:space-between;align-items:center;gap:16px;min-width:0;display:flex}.brand{align-items:center;gap:10px;min-width:0;display:inline-flex}.brand strong,.brand small{display:block}.brand strong{font-size:16px}.brand small{color:var(--muted);font-size:12px}.brand-mark{color:#fff;background:var(--brand);border-radius:8px;justify-content:center;align-items:center;width:38px;height:38px;display:inline-flex;box-shadow:0 8px 18px #2563eb38}.brand-mark.large{width:52px;height:52px}.main-menu{background:#172033;border:1px solid #263449;border-radius:8px;flex-wrap:wrap;justify-content:flex-start;align-items:center;gap:8px;min-width:0;padding:8px;display:flex;overflow:visible}.menu-link,.profile-button,.ghost-button,.primary-button,.icon-button{white-space:nowrap;border:1px solid #0000;border-radius:8px;justify-content:center;align-items:center;gap:8px;min-height:40px;display:inline-flex}.menu-link{color:var(--text);background:#fff;border-color:#ffffff24;flex:none;padding:9px 11px;font-weight:750}.menu-link:hover{color:var(--text);background:#eaf1ff;border-color:#2563eb80}.account-actions{justify-content:flex-end;align-items:center;gap:8px;min-width:0;display:flex}.profile-button{border-color:var(--line);background:#fff;min-width:0;padding:5px 8px}.profile-copy{text-align:left;min-width:0;display:block}.profile-copy strong,.profile-copy small{text-overflow:ellipsis;max-width:150px;display:block;overflow:hidden}.profile-copy small{color:var(--muted);font-size:12px}.avatar{color:#fff;text-align:center;border:2px solid #fff;border-radius:50%;flex:none;place-content:center;align-items:center;width:30px;height:30px;font-size:14px;font-weight:800;display:inline-flex}.avatar.small{border-width:1px;width:25px;height:25px;font-size:10px}.avatar-stack{align-items:center;display:inline-flex}.avatar-stack .avatar+.avatar{margin-left:-7px}.icon-button{border-color:var(--line);background:#fff;width:42px;padding:0;position:relative}.icon-button svg+svg{position:absolute;bottom:6px;right:6px}.icon-button.danger{color:var(--red)}.icon-button:hover,.profile-button:hover{border-color:var(--line-strong);background:var(--surface-soft)}.app-main{padding:22px}.login-page{background:linear-gradient(90deg, #2563eb14, #0f766e12), var(--bg);place-items:center;min-height:100vh;padding:24px;display:grid}.login-panel{border:1px solid var(--line);width:min(920px,100%);box-shadow:var(--shadow);background:#fff;border-radius:8px;grid-template-columns:minmax(280px,1fr) minmax(320px,420px);gap:0;display:grid;overflow:hidden}.login-copy{color:#fff;background:#172033;padding:42px}.login-copy h1{margin:22px 0 10px;font-size:34px;line-height:1.1}.login-copy p{color:#cbd5e1;max-width:420px;margin:0;line-height:1.6}.login-badges{flex-wrap:wrap;gap:8px;margin-top:28px;display:flex}.login-badges span{color:#e2e8f0;border:1px solid #fff3;border-radius:8px;align-items:center;gap:7px;padding:8px 10px;display:inline-flex}.login-form{align-content:center;gap:18px;padding:42px;display:grid}.login-form label,.admin-form label,.quick-task-form label,.region-device-row label,.date-range label{color:var(--muted);gap:7px;font-size:13px;display:grid}.field-with-icon,.search-field,.select-control,.inline-select{border:1px solid var(--line);min-height:40px;color:var(--muted);background:#fff;border-radius:8px;align-items:center;gap:8px;padding:0 10px;display:flex}.field-with-icon input,.search-field input,.select-control select,.inline-select select{box-shadow:none;background:0 0;border:0;min-height:38px;padding-inline:0}.form-error{color:var(--red);margin:0;font-weight:700}.primary-button{border:1px solid var(--brand);background:var(--brand);color:#fff;padding:9px 14px;font-weight:750}.primary-button:hover{background:var(--brand-dark)}.primary-button:disabled{cursor:wait;opacity:.7}.ghost-button{border-color:var(--line);color:var(--text);background:#fff;padding:8px 11px}.ghost-button:hover{border-color:var(--line-strong);background:var(--surface-soft)}.ghost-button.danger{color:var(--red);border-color:#dc262638}.page-error{margin-bottom:14px}.page-header{justify-content:space-between;align-items:flex-start;gap:20px;margin-bottom:18px;display:flex}.page-header.compact{margin-bottom:14px}.page-header h1{margin:4px 0 7px;font-size:30px;line-height:1.16}.page-header p{color:var(--muted);margin:0}.eyebrow{color:var(--brand);text-transform:uppercase;margin:0;font-size:12px;font-weight:800}.metric-strip{flex-wrap:wrap;justify-content:flex-end;gap:8px;display:flex}.metric{border:1px solid var(--line);background:#fff;border-radius:8px;grid-template-columns:auto 1fr;align-items:center;gap:2px 8px;min-width:112px;padding:10px 12px;display:grid}.metric span{font-size:20px;font-weight:850}.metric small{color:var(--muted);grid-column:1/-1}.filter-bar,.tag-filter,.table-toolbar,.tag-create-form{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.filter-bar{margin-bottom:10px}.sync-message{color:var(--muted);font-size:12px;font-weight:800}.sync-message.error{color:var(--red)}.tag-filter{margin-bottom:14px}.tag-create-form{border-top:1px solid var(--line);margin-top:12px;padding-top:12px}.search-field{flex:260px;min-width:260px}.select-control{min-width:210px}.compact-filter-control{flex:0 190px;min-width:150px}.tag-toggle{border:1px solid var(--line);min-height:34px;color:var(--muted);background:#fff;border-radius:8px;align-items:center;gap:6px;padding:6px 9px;display:inline-flex}.tag-toggle.active{color:var(--brand-dark);background:#2563eb1a;border-color:#2563eb61;font-weight:750}.tag-toggle.compact{min-height:30px;font-size:12px}.dashboard-grid{grid-template-columns:minmax(0,4fr) minmax(320px,1fr);align-items:stretch;gap:16px;display:grid}.map-surface,.surface,.task-rail{border:1px solid var(--line);background:var(--surface);border-radius:8px;box-shadow:0 10px 24px #1720330d}.map-surface{min-height:650px;overflow:hidden}.map-canvas{background:#eef4f7;width:100%;height:100%;min-height:650px;position:relative;overflow:hidden}.google-map-canvas{z-index:0;background:#eef4f7;width:100%;height:100%;position:absolute;inset:0}.google-map-canvas .gm-style{font-family:inherit}.static-map-image,.static-map-fallback{z-index:0;width:100%;height:100%;position:absolute;inset:0}.static-map-image{filter:saturate(.96)contrast(1.02);-webkit-user-select:none;user-select:none;pointer-events:none;background-position:50%;background-repeat:no-repeat;background-size:cover}.static-map-fallback{color:#17203338;letter-spacing:0;pointer-events:none;background:linear-gradient(90deg,#ffffffa3 1px,#0000 1px) 0 0/46px 46px,linear-gradient(0deg,#ffffffa3 1px,#0000 1px) 0 0/46px 46px,linear-gradient(135deg,#dbeafe,#e2e8f0 42%,#dcfce7);place-items:center;font-size:74px;font-weight:950;display:grid}.map-mode-badge{z-index:4;max-width:min(420px,100% - 28px);color:var(--text);pointer-events:none;background:#ffffffeb;border:1px solid #1720332e;border-radius:8px;align-items:center;gap:7px;padding:8px 10px;font-size:12px;font-weight:800;display:inline-flex;position:absolute;top:14px;left:14px;box-shadow:0 8px 18px #1720331a}.map-status-legend{z-index:4;max-width:min(340px,100% - 28px);color:var(--text);background:#fffffff0;border:1px solid #1720332e;border-radius:8px;flex-wrap:wrap;gap:8px;padding:8px 10px;font-size:12px;font-weight:800;display:inline-flex;position:absolute;top:14px;right:14px;box-shadow:0 8px 18px #1720331a}.map-status-legend span{align-items:center;gap:6px;display:inline-flex}.map-status-legend .status-dot{width:8px;height:8px;box-shadow:none}.map-load-state{z-index:2;color:var(--muted);text-align:center;background:#eef4f7;place-items:center;font-size:14px;font-weight:800;display:grid;position:absolute;inset:0}.map-road{fill:none;stroke:#ffffffeb;stroke-width:18px;stroke-linecap:round;filter:drop-shadow(0 1px #17203314)}.map-road.thin{stroke-width:10px}.map-label{fill:#17203373;font-size:24px;font-weight:800}.map-marker-overlay{z-index:3;pointer-events:auto;will-change:transform;width:0;height:0;position:absolute;top:0;left:0}.map-marker-overlay:has(.device-marker.selected){z-index:8}.map-marker-overlay:has(.device-marker.editing){z-index:9}.device-marker{z-index:3;text-align:center;justify-items:center;width:92px;display:grid;position:absolute;transform:translate(-50%,-50%)}.map-marker-overlay .device-marker{position:relative}.device-marker.selected{z-index:8}.device-marker.editing{z-index:9;cursor:grab}.device-marker.editing:active{cursor:grabbing}.pin-shell{color:#fff;cursor:pointer;border:1px solid #fff;border-radius:6px;align-items:center;gap:3px;max-width:84px;min-height:22px;padding:3px 4px;font-size:10px;line-height:1.1;display:inline-flex;box-shadow:0 5px 10px #17203324}button.pin-shell{font:inherit}.pin-shell svg{flex:none;width:12px;height:12px}.device-marker.selected .pin-shell{outline:2px solid #2563eb47}.device-marker.editing .pin-shell{outline:3px solid #f9731657}.device-marker.online .pin-shell{background:var(--green)}.device-marker.offline .pin-shell{background:var(--red)}.device-marker.error .pin-shell{background:var(--orange)}.device-code{font-weight:850}.device-code:hover{text-decoration:underline}.device-name{max-width:92px;color:var(--text);background:#ffffffe0;border-radius:6px;margin-top:2px;padding:1px 4px;font-size:11px;font-weight:700;line-height:1.2;box-shadow:0 2px 6px #17203314}.assignment-ring{border:1px solid var(--line);background:#ffffffeb;border-radius:999px;padding:2px;display:inline-flex;position:absolute;bottom:50px;left:50%;transform:translate(-50%);box-shadow:0 8px 18px #1720331f}.assignment-ring .avatar{border:1px solid #fff;width:21px;height:21px;padding:0;font-size:10px}.assignment-ring .avatar+.avatar{margin-left:-4px}.assignment-popover{z-index:10;border:1px solid var(--line);width:260px;box-shadow:var(--shadow);text-align:left;background:#fff;border-radius:8px;padding:12px;position:absolute;bottom:102px;left:50%;transform:translate(-50%)}.device-popover{z-index:12;border:1px solid var(--line);width:270px;box-shadow:var(--shadow);text-align:left;background:#fff;border-radius:8px;padding:12px;position:absolute;top:72px;left:50%;transform:translate(-50%)}.device-popover>button{color:var(--muted);background:0 0;border:0;font-size:20px;position:absolute;top:6px;right:8px}.device-popover strong,.device-popover span,.device-popover small{padding-right:22px;display:block}.device-popover span{color:var(--muted);margin-top:3px;font-weight:700}.device-popover .device-region{color:var(--text);font-weight:850}.device-popover small{color:var(--brand-dark);margin-top:8px;font-weight:850}.device-popover p{color:#c2410c;margin:10px 0 0;font-size:12px;font-weight:800}.popover-actions{flex-wrap:wrap;gap:8px;margin-top:12px;display:flex}.popover-actions a,.popover-actions button{border:1px solid var(--line);min-height:34px;color:var(--text);background:#fff;border-radius:8px;align-items:center;gap:6px;padding:7px 9px;font-weight:850;display:inline-flex}.popover-actions a:hover,.popover-actions button:hover{background:#2563eb14;border-color:#2563eb59}.assignment-popover button{color:var(--muted);background:0 0;border:0;font-size:20px;position:absolute;top:6px;right:8px}.assignment-popover strong,.assignment-popover span{padding-right:22px;display:block}.assignment-popover span{color:var(--brand-dark);margin-top:3px;font-weight:750}.assignment-popover p{color:var(--muted);margin:8px 0 0;line-height:1.45}.task-rail{flex-direction:column;max-height:650px;padding:14px;display:flex;overflow:hidden}.rail-header,.section-title,.task-card-top,.timeline-head{justify-content:space-between;align-items:center;gap:12px;display:flex}.rail-header h2,.section-title h2{margin:0;font-size:18px}.count-pill,.status-pill,.priority-label,.visibility-pill{border-radius:8px;align-items:center;gap:5px;padding:5px 8px;font-size:12px;font-weight:800;display:inline-flex}.count-pill{background:var(--surface-soft);color:var(--text)}.quick-task-form,.admin-form{gap:10px;display:grid}.quick-task-form{border-bottom:1px solid var(--line);margin-top:14px;padding-bottom:14px}.form-row{grid-template-columns:1fr 1fr;gap:10px;display:grid}.assignee-picker{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;display:grid}.avatar-choice{border:1px solid var(--line);color:var(--muted);background:#fff;border-radius:8px;justify-items:center;gap:4px;padding:8px 4px;display:grid}.avatar-choice span{color:#fff;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:10px;font-weight:850;display:inline-flex}.avatar-choice.active{border-color:var(--brand);color:var(--brand-dark);background:#2563eb14}.task-list{gap:10px;margin-top:14px;padding-right:3px;display:grid;overflow:auto}.compact-list{max-height:none;overflow:visible}.task-card{border:1px solid var(--line);border-inline-start:4px solid var(--brand);background:#fff;border-radius:8px;padding:12px}.task-card h3{margin:9px 0 6px;font-size:15px;line-height:1.25}.task-card p{color:var(--muted);margin:0;line-height:1.45}.task-card footer{color:var(--muted);flex-wrap:wrap;gap:10px;margin-top:10px;font-size:12px;display:flex}.task-card footer a,.rail-link,.inline-link,.table-title-link{color:var(--brand-dark);font-weight:800}.task-card footer a:hover,.rail-link:hover,.inline-link:hover,.table-title-link:hover{text-decoration:underline}.rail-link{border:1px solid var(--line);background:#fff;border-radius:8px;justify-content:center;margin-top:12px;padding:9px 10px;display:inline-flex}.task-card footer span,.task-table-row>span,.event-row,.asset-row span{align-items:center;gap:6px;display:inline-flex}.status-pill.planned,.status-pill.open{color:var(--brand-dark);background:#2563eb1a}.status-pill.in_progress,.status-pill.planned.timeline{color:#c2410c;background:#f973161f}.status-pill.blocked{color:var(--red);background:#dc26261c}.status-pill.done,.status-pill.resolved{color:var(--green);background:#16a34a1f}.priority-urgent{background:#fff7f7}.priority-high{background:#fffaf0}.priority-normal,.priority-low{background:#fff}.content-grid{gap:16px;display:grid}.content-grid.two{grid-template-columns:repeat(2,minmax(0,1fr));margin-bottom:16px}.content-grid.three{grid-template-columns:repeat(3,minmax(0,1fr));margin-bottom:16px}.content-grid.four{grid-template-columns:repeat(4,minmax(0,1fr));margin-bottom:16px}.surface{padding:16px}.surface h2{margin:0}.stat-surface{gap:7px;display:grid}.stat-surface svg{color:var(--brand)}.stat-surface span{color:var(--muted)}.stat-surface strong{font-size:22px}.back-link{color:var(--muted);align-items:center;gap:5px;margin-bottom:10px;font-weight:700;display:inline-flex}.device-status-card{color:#fff;border-radius:8px;justify-items:start;gap:5px;min-width:170px;padding:14px;display:grid}.device-status-card.online{background:var(--green)}.device-status-card.offline{background:var(--red)}.device-status-card.error{background:var(--orange)}.device-status-card small{color:#ffffffd1}.details-list,.inline-meta{gap:12px;margin:12px 0 0;display:grid}.details-list div,.inline-meta div{gap:4px;display:grid}.details-list dt,.inline-meta dt{color:var(--muted);font-size:12px}.details-list dd,.inline-meta dd{margin:0;font-weight:750}.chip-cloud{flex-wrap:wrap;gap:8px;margin-top:12px;display:flex}.chip{border:1px solid var(--line);background:var(--surface-soft);color:var(--text);border-radius:8px;padding:7px 9px;font-size:12px;font-weight:750}.device-asset-list,.event-list,.rank-list,.summary-bars,.permission-user-list,.region-device-list{gap:10px;margin-top:14px;display:grid}.asset-row,.event-row{border:1px solid var(--line);background:var(--surface-soft);border-radius:8px;justify-content:space-between;gap:12px;padding:10px}.asset-row small,.muted{color:var(--muted)}.timeline{gap:14px;margin-top:14px;display:grid;position:relative}.timeline-item{grid-template-columns:20px minmax(0,1fr);gap:10px;display:grid;position:relative}.timeline-dot{background:var(--brand);border-radius:50%;width:12px;height:12px;margin-top:7px;box-shadow:0 0 0 4px #2563eb1f}.timeline-item.resolved .timeline-dot{background:var(--green);box-shadow:0 0 0 4px #16a34a1f}.timeline-item.open .timeline-dot{background:var(--red);box-shadow:0 0 0 4px #dc26261f}.timeline-item h3{margin:0;font-size:16px}.timeline-item p{color:var(--muted);margin:7px 0;line-height:1.5}.inline-meta{grid-template-columns:repeat(3,minmax(0,1fr))}.empty-state{color:var(--green);align-items:center;gap:8px;font-weight:800;display:flex}.task-admin-grid{grid-template-columns:minmax(300px,.55fr) minmax(0,1.45fr)}.task-admin-list,.permission-matrix-panel{min-width:0;overflow:hidden}.task-table{gap:8px;margin-top:14px;display:grid}.task-table-head,.task-table-row{grid-template-columns:minmax(180px,.85fr) minmax(240px,1.2fr) minmax(100px,.45fr) minmax(150px,.6fr) minmax(110px,.45fr) auto;align-items:center;gap:10px;display:grid}.task-table-head{color:var(--muted);padding:0 10px;font-size:12px;font-weight:850}.task-table-row{border:1px solid var(--line);background:#fff;border-radius:8px;padding:10px}.task-table-row.editing{grid-template-columns:1fr;align-items:stretch}.task-table-row strong{margin-bottom:5px;display:block}.task-device-cell{gap:6px;display:grid}.task-summary-cell{min-width:0;display:block}.clickable-cell{border-radius:8px;margin:-6px;padding:6px}.clickable-cell:hover{background:#2563eb12}.task-device-cell strong{color:var(--text);margin:0;font-size:16px;font-weight:900;line-height:1.2}.device-code-inline{width:fit-content;color:var(--brand-dark);background:#2563eb1a;border-radius:8px;align-items:center;gap:6px;padding:6px 8px;font-size:12px;font-weight:850;display:inline-flex}.task-table-row p{color:var(--muted);margin:0 0 6px;line-height:1.35}.priority-label.urgent{color:var(--red);background:#dc26261a}.priority-label.high{color:#c2410c;background:#f973161f}.priority-label.normal,.priority-label.low{background:var(--surface-soft);color:var(--muted)}.inline-select{min-width:150px}.inline-select select:disabled{cursor:not-allowed;color:var(--muted)}.task-edit-grid{grid-template-columns:repeat(3,minmax(150px,1fr));gap:10px;display:grid}.task-edit-grid label,.task-assignee-edit{color:var(--muted);gap:7px;font-size:13px;display:grid}.task-edit-issue,.task-assignee-edit{grid-column:span 3}.task-row-actions{justify-content:flex-end}.region-grid{grid-template-columns:minmax(300px,.42fr) minmax(0,1fr);align-items:start}.permissions-grid,.user-admin-grid{grid-template-columns:minmax(280px,.45fr) minmax(0,1.55fr)}.device-create-form{align-self:start}.region-left-column{align-self:start;gap:16px;display:grid}.summary-bar{gap:8px;display:grid}.summary-bar div{justify-content:space-between;gap:10px;display:flex}progress{background:var(--surface-soft);border:0;border-radius:999px;width:100%;height:9px;overflow:hidden}progress::-webkit-progress-bar{background:var(--surface-soft)}progress::-webkit-progress-value{background:var(--brand)}.region-device-row{border:1px solid var(--line);background:#fff;border-radius:8px;grid-template-columns:minmax(160px,.55fr) minmax(150px,.45fr) minmax(180px,.75fr) minmax(130px,.35fr) auto;align-items:start;gap:12px;padding:12px;display:grid}.region-device-row.editing{grid-template-columns:1fr}.user-admin-list{min-width:0}.user-table{gap:10px;margin-top:14px;display:grid}.compact-user-table{margin-top:14px}.user-row{border:1px solid var(--line);background:#fff;border-radius:8px;grid-template-columns:42px minmax(180px,1fr) minmax(140px,.5fr) minmax(100px,.35fr) auto;align-items:center;gap:12px;padding:10px;display:grid}.user-row.editing{grid-template-columns:42px minmax(0,1fr) auto}.edit-grid{grid-template-columns:repeat(3,minmax(120px,1fr));gap:8px;display:grid}.user-row strong,.user-row span{display:block}.user-row div span{color:var(--muted);align-items:center;gap:6px;margin-top:4px;font-size:13px;display:inline-flex}.role-pill{width:fit-content;color:var(--brand-dark);background:#2563eb1a;border-radius:8px;align-items:center;gap:6px;padding:7px 9px;font-size:12px;font-weight:850;display:inline-flex}.region-device-row>div:first-child{gap:4px;display:grid}.region-device-row>div:first-child strong{font-size:16px;font-weight:850;line-height:1.2}.region-device-row>div:first-child span{color:var(--muted);font-size:12px}.row-tags{flex-wrap:wrap;gap:6px;display:flex}.row-actions{flex-wrap:wrap;justify-content:flex-end;gap:6px;display:inline-flex}.device-exclusion-cell{justify-items:start;gap:4px;display:grid}.device-exclusion-cell small{color:var(--muted);font-size:11px;font-weight:750}.device-exclusion-toggle{border:1px solid var(--line);min-height:32px;color:var(--green);background:#fff;border-radius:8px;align-items:center;gap:6px;padding:5px 8px;font-size:12px;font-weight:850;display:inline-flex}.device-exclusion-toggle.active{color:var(--red);background:#dc262614;border-color:#dc26263d}.device-exclusion-toggle:disabled{cursor:not-allowed;opacity:.65}.region-admin-form{grid-template-columns:44px minmax(0,1fr);gap:8px;margin-top:14px;display:grid}.region-admin-form input:first-child{grid-column:1/-1}.region-admin-list{gap:8px;margin-top:14px;display:grid}.region-admin-row{border:1px solid var(--line);background:#fff;border-radius:8px;grid-template-columns:14px minmax(0,1fr) 30px;align-items:center;gap:8px;padding:8px;display:grid}.region-admin-row:has(input){grid-template-columns:minmax(0,1fr) 40px 30px}.region-admin-row strong,.region-admin-row small{display:block}.region-admin-row small{color:var(--muted);font-size:11px}.region-admin-row strong{font-size:13px;line-height:1.2}.region-swatch,.role-icon{border-radius:50%;justify-content:center;align-items:center;width:14px;height:14px;display:inline-flex}.role-icon{width:22px;height:22px;color:var(--brand-dark);background:#2563eb1a;border-radius:8px}.region-admin-row .row-actions{grid-template-columns:1fr;justify-items:end;display:grid}.region-admin-row .icon-button{width:28px;min-height:28px}.region-admin-row .icon-button svg{width:14px;height:14px}.permission-user{border:1px solid var(--line);text-align:left;background:#fff;border-radius:8px;align-items:center;gap:10px;width:100%;padding:10px;display:flex}.permission-user.active{border-color:var(--brand);background:#2563eb14}.permission-user strong,.permission-user small{display:block}.permission-user small{color:var(--muted)}.permission-matrix{gap:8px;margin-top:14px;display:grid;overflow-x:auto}.permission-row{border:1px solid var(--line);background:#fff;border-radius:8px;grid-template-columns:minmax(120px,1fr) repeat(4,minmax(90px,.5fr)) minmax(120px,.65fr);align-items:center;gap:8px;min-width:720px;padding:10px;display:grid}.permission-row.head{background:var(--surface-soft);color:var(--muted);border-color:#0000;font-size:12px;font-weight:850}.permission-toggle{border:1px solid var(--line);width:52px;min-height:34px;color:var(--muted-2);background:#fff;border-radius:8px;justify-content:center;align-items:center;display:inline-flex}.permission-toggle.enabled{color:var(--green);background:#16a34a17;border-color:#16a34a40}.permission-toggle:disabled{cursor:not-allowed;opacity:.6}.visibility-pill.visible{color:var(--green);background:#16a34a1a}.visibility-pill.hidden{color:var(--muted);background:#6070871c}.date-range{flex-wrap:wrap;justify-content:flex-end;gap:10px;display:flex}.date-range label{border:1px solid var(--line);background:#fff;border-radius:8px;grid-template-columns:auto auto minmax(0,1fr);align-items:center;min-width:180px;padding:6px 8px}.date-range input{min-height:32px;box-shadow:none;border:0;padding:0}.rank-panel{min-height:300px}.rank-row{border:1px solid var(--line);background:#fff;border-radius:8px;gap:8px;padding:10px;display:grid}.rank-row strong,.rank-row span{display:block}.rank-row span{color:var(--muted);margin-top:3px}.rank-bar{background:var(--surface-soft);border-radius:999px;height:9px;position:relative;overflow:hidden}.rank-bar:after{width:var(--bar-width);content:"";background:var(--brand);border-radius:inherit;position:absolute;inset:0 auto 0 0}.ghost-button:disabled{cursor:not-allowed;opacity:.62}.offline-filter-bar{margin-bottom:16px}.date-control,.threshold-control{border:1px solid var(--line);min-height:42px;color:var(--muted);background:#fff;border-radius:8px;grid-template-columns:auto auto minmax(130px,1fr);align-items:center;gap:8px;padding:6px 9px;font-size:13px;display:grid}.date-control input,.threshold-control input{min-height:30px;box-shadow:none;border:0;padding:0}.threshold-control{max-width:220px}.offline-record-grid{grid-template-columns:minmax(280px,.72fr) minmax(0,1.45fr) minmax(260px,.72fr)}.offline-device-panel,.offline-snapshot-panel,.offline-rank-panel{min-width:0}.offline-device-panel .search-field{min-width:0;margin-top:14px}.offline-device-panel .offline-sort-control{min-width:0;margin-top:10px}.offline-device-panel .offline-sort-control select{width:100%}.offline-monitor-actions{flex-wrap:wrap;gap:8px;margin-top:12px;display:flex}.offline-device-list,.offline-snapshot-list{gap:10px;margin-top:14px;display:grid}.offline-device-list{max-height:620px;padding-right:3px;overflow:auto}.offline-device-option{border:1px solid var(--line);width:100%;color:var(--text);text-align:left;background:#fff;border-radius:8px;grid-template-columns:auto minmax(0,1fr) auto auto;align-items:center;gap:9px;padding:10px;display:grid}.offline-device-option:hover,.offline-device-option.selected{background:#2563eb12;border-color:#2563eb6b}.offline-device-option strong,.offline-device-option small{text-overflow:ellipsis;display:block;overflow:hidden}.offline-device-option small{color:var(--muted);margin-top:2px}.monitor-pill{width:25px;height:25px;color:var(--brand-dark);background:#2563eb1a;border-radius:8px;justify-content:center;align-items:center;display:inline-flex}.status-dot{background:var(--muted-2);border-radius:50%;width:11px;height:11px;box-shadow:0 0 0 4px #6070871a}.status-dot.online{background:var(--green);box-shadow:0 0 0 4px #16a34a1f}.status-dot.offline{background:var(--red);box-shadow:0 0 0 4px #dc26261f}.status-dot.error{background:var(--orange);box-shadow:0 0 0 4px #f9731624}.offline-snapshot-day{border:1px solid var(--line);background:#fff;border-radius:8px;padding:12px}.offline-snapshot-day header{justify-content:space-between;align-items:center;gap:12px;margin-bottom:10px;display:flex}.offline-snapshot-day header strong,.offline-snapshot-day header span{display:block}.offline-snapshot-day header span{color:var(--muted);margin-top:2px;font-size:12px;font-weight:750}.snapshot-device-cloud{grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:8px;display:grid}.snapshot-device-chip{border:1px solid var(--line);background:var(--surface-soft);width:100%;min-width:0;color:var(--text);border-radius:8px;grid-template-columns:auto auto;align-items:center;gap:1px 6px;padding:7px 9px;display:inline-grid}.snapshot-device-chip svg{color:var(--red);grid-row:1/3}.snapshot-device-chip strong,.snapshot-device-chip small{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.snapshot-device-chip strong{font-size:12px}.snapshot-device-chip small{color:var(--muted);font-size:11px;font-weight:800}.snapshot-device-chip.critical,.rank-row.critical{background:#fff7f7;border-color:#dc262652}.snapshot-device-chip.critical strong,.rank-row.critical strong{color:var(--red)}.snapshot-device-chip.alerting,.offline-device-option.alerting{animation:1.15s infinite offline-alert-pulse}.offline-device-option.alerting{border-color:#dc262657}@keyframes offline-alert-pulse{0%,to{box-shadow:0 0 #dc262600}50%{box-shadow:0 0 0 4px #dc26262e}}@media (max-width:1180px){.app-shell{padding-top:156px}.topbar{padding:10px 14px 12px}.account-actions{justify-content:flex-start}.dashboard-grid,.task-admin-grid,.region-grid,.offline-record-grid,.user-admin-grid,.permissions-grid,.content-grid.two,.content-grid.three,.content-grid.four{grid-template-columns:1fr}.task-rail{max-height:none}.task-table{overflow-x:auto}.task-table-head,.task-table-row{min-width:980px}}@media (max-width:760px){.app-shell{padding-top:190px}.app-main{padding:14px}.topbar-main{align-items:flex-start}.profile-copy{display:none}.page-header{display:grid}.page-header h1{font-size:24px}.metric-strip,.date-range{justify-content:flex-start}.login-panel{grid-template-columns:1fr}.login-copy,.login-form{padding:28px}.filter-bar,.tag-filter,.table-toolbar{display:grid}.search-field,.select-control{min-width:0}.map-surface,.map-canvas{min-height:560px}.device-marker{width:84px}.pin-shell{max-width:78px;min-height:21px;padding:3px 4px;font-size:8px}.device-name{max-width:84px;font-size:8px}.assignment-popover{width:220px}.map-status-legend{top:56px;left:14px;right:auto}.form-row,.assignee-picker,.inline-meta,.task-edit-grid{grid-template-columns:1fr}.task-edit-issue,.task-assignee-edit{grid-column:auto}.region-device-row{grid-template-columns:1fr}.user-row{grid-template-columns:38px 1fr}.user-row.editing,.edit-grid,.region-admin-form,.region-admin-row{grid-template-columns:1fr}.region-admin-row:has(input){grid-template-columns:1fr}.row-actions{justify-content:flex-start}}
