/* Keeper UI kit — local layer on top of design tokens */
.app{display:grid;grid-template-columns:var(--sidebar-current-w,var(--sidebar-w)) 1fr;min-height:100vh;background:var(--bg-page);font-family:var(--font-sans);color:var(--fg);transition:grid-template-columns 220ms var(--ease-out)}
.sidebar{background:var(--bg-sidebar);color:#fff;padding:18px 12px;display:flex;flex-direction:column;gap:6px;position:sticky;top:0;height:100vh}
.brand{display:flex;align-items:center;gap:10px;padding:4px 8px 16px;border-bottom:1px solid var(--border-sidebar);margin-bottom:8px}
.brand-mark{width:28px;height:28px;border-radius:6px;background:#FFB300;display:flex;align-items:center;justify-content:center;font-size:18px}
.brand-name{font:700 17px/1 Inter;letter-spacing:-.01em}
.org{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;background:var(--bg-sidebar-hover);border-radius:8px;margin-bottom:6px;cursor:pointer;font-size:12px;color:#C2CCD8}
.org b{color:#fff;font-weight:600;font-size:13px;display:block}
.section{font:600 10px Inter;text-transform:uppercase;letter-spacing:.05em;color:#707F8D;padding:14px 10px 4px}
.nav-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:6px;font:500 13px Inter;color:#C2CCD8;cursor:pointer;border:none;background:transparent;width:100%;text-align:left;transition:background 120ms}
.nav-item i{font-size:16px}
.nav-item:hover{background:var(--bg-sidebar-hover);color:#fff}
.nav-item.active{background:#FFB300;color:#1D1C1D;font-weight:600}
.nav-item .badge{margin-left:auto;background:#E5342B;color:#fff;border-radius:999px;font:700 10px Inter;padding:2px 6px;line-height:1}
.nav-item.active .badge{background:#1D1C1D;color:#fff}
.sidebar-foot{margin-top:auto;border-top:1px solid var(--border-sidebar);padding-top:10px;display:flex;flex-direction:column;gap:2px}
.user{display:flex;align-items:center;gap:8px;padding:8px;border-radius:6px;font-size:12px;color:#C2CCD8}
.user .av{width:28px;height:28px;border-radius:50%;background:#FFB300;color:#1D1C1D;display:flex;align-items:center;justify-content:center;font:700 11px Inter}
.user b{color:#fff;font-weight:600;font-size:13px;display:block}

.main{display:flex;flex-direction:column;min-width:0}
.topbar{height:var(--topbar-h);background:#fff;border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 24px;gap:14px;position:sticky;top:0;z-index:5}
.crumbs{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--fg-muted)}
.crumbs b{color:var(--fg-strong);font-weight:600}
.crumbs i{font-size:12px}
.search{flex:1;max-width:360px;margin-left:auto;position:relative}
.search input{width:100%;height:32px;border:1px solid var(--border);border-radius:8px;padding:0 12px 0 32px;font:400 13px Inter;background:var(--n-100)}
.search i{position:absolute;left:10px;top:8px;color:var(--fg-muted)}
.icon-btn{width:34px;height:34px;border:1px solid var(--border);border-radius:8px;background:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--fg);position:relative}
.icon-btn .pulse{position:absolute;top:6px;right:6px;width:8px;height:8px;border-radius:50%;background:#E5342B;border:2px solid #fff}
.page{padding:24px;display:flex;flex-direction:column;gap:20px;min-width:0}
.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:14px}
.page-title{font:700 26px/1.15 Inter;letter-spacing:-.015em;color:var(--fg-strong)}
.page-sub{font-size:13px;color:var(--fg-muted);margin-top:4px}
.actions{display:flex;gap:8px}

.card{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:var(--sp-4)}
.card--flat{box-shadow:none}
.card h3.card-title{font:600 14px Inter;color:var(--fg-strong);margin:0 0 12px;display:flex;align-items:center;justify-content:space-between}
.card-title a{font:500 12px Inter;color:var(--fg-muted)}

.btn{display:inline-flex;align-items:center;gap:6px;height:36px;padding:0 14px;border-radius:var(--radius-md);font:var(--fw-semi) var(--fs-sm) var(--font-sans);cursor:pointer;border:1px solid transparent;transition:all var(--dur-fast);white-space:nowrap;text-decoration:none;user-select:none}
.btn:focus-visible{outline:none;box-shadow:var(--shadow-focus)}
/* Primary */
.btn--primary{background:var(--keeper-honey);color:var(--fg-on-honey)}
.btn--primary:hover{background:var(--keeper-honey-deep)}
.btn--primary:active{background:var(--keeper-honey-deep);filter:brightness(.93)}
.btn--primary:disabled,.btn--primary[disabled]{background:var(--n-200);color:var(--fg-disabled);cursor:not-allowed;pointer-events:none}
/* Secondary */
.btn--secondary{background:var(--bg-canvas);color:var(--fg);border-color:var(--border)}
.btn--secondary:hover{background:var(--n-100);border-color:var(--border-strong)}
.btn--secondary:active{background:var(--n-150);border-color:var(--border-strong)}
.btn--secondary:disabled,.btn--secondary[disabled]{background:var(--n-50);color:var(--fg-disabled);border-color:var(--border-subtle);cursor:not-allowed;pointer-events:none}
/* Dark */
.btn--dark{background:var(--keeper-ink);color:var(--fg-on-dark)}
.btn--dark:hover{background:var(--keeper-ink-3)}
.btn--dark:active{background:var(--keeper-ink-2);filter:brightness(.9)}
.btn--dark:disabled,.btn--dark[disabled]{background:var(--n-200);color:var(--fg-disabled);cursor:not-allowed;pointer-events:none}
/* Ghost */
.btn--ghost{background:transparent;color:var(--fg)}
.btn--ghost:hover{background:var(--n-100)}
.btn--ghost:active{background:var(--n-150)}
.btn--ghost:disabled,.btn--ghost[disabled]{color:var(--fg-disabled);cursor:not-allowed;pointer-events:none}
/* Danger */
.btn--danger{background:var(--status-critical);color:var(--fg-on-dark)}
.btn--danger:hover{background:#c92d24}
.btn--danger:active{background:#b02820}
.btn--danger:disabled,.btn--danger[disabled]{background:var(--n-200);color:var(--fg-disabled);cursor:not-allowed;pointer-events:none}
/* Size modifier */
.btn--sm{height:30px;padding:0 var(--sp-3);font-size:var(--fs-xs);border-radius:var(--radius-sm)}

table{width:100%;border-collapse:collapse;font-size:var(--fs-sm)}
th{font:var(--fw-semi) var(--fs-micro)/var(--lh-micro) var(--font-sans);text-transform:uppercase;letter-spacing:.04em;color:var(--fg-muted);text-align:left;padding:10px 12px;border-bottom:1px solid var(--border);background:var(--n-50);position:sticky;top:0;z-index:1}
td{padding:12px;border-bottom:1px solid var(--border-subtle);font-variant-numeric:tabular-nums;color:var(--fg)}
tbody tr:nth-child(even) td{background:var(--n-50)}
tbody tr{cursor:pointer}
tbody tr:hover td{background:var(--bg-hover)}
.id-mono{font-family:var(--font-mono);font-size:var(--fs-xs);color:var(--fg-muted)}

.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.kpi{background:#fff;border:1px solid var(--border);border-radius:12px;padding:16px;cursor:pointer;transition:box-shadow 120ms}
.kpi:hover{box-shadow:var(--shadow-md)}
.kpi-lbl{font-size:11px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--fg-muted);display:flex;justify-content:space-between;align-items:center}
.kpi-lbl i{color:var(--fg-muted);font-size:14px}
.kpi-val{font:700 28px Inter;font-variant-numeric:tabular-nums;letter-spacing:-.02em;color:var(--fg-strong);margin-top:6px;display:flex;gap:6px;align-items:baseline}
.kpi-unit{font:500 14px Inter;color:var(--fg-muted)}
.kpi-delta{font-size:12px;font-weight:600;margin-top:4px;color:var(--fg-muted)}
.kpi-delta.up{color:#26972B}.kpi-delta.dn{color:#E5342B}
.spark{margin-top:10px;height:32px;border-radius:6px;overflow:hidden}

.tri{display:inline-block;width:0;height:0;border-left:11px solid transparent;border-right:11px solid transparent;flex-shrink:0;position:relative}
.tri-thr{border-bottom:18px solid #7FB539}
.tri-act{border-bottom:18px solid #E8B84A}
.tri-att{border-bottom:18px solid #FF7A00}
.tri-cri{border-bottom:18px solid #E5342B}
.tri-off{border-bottom:18px solid #C2CCD8}
.tri.lg{border-left-width:18px;border-right-width:18px}
.tri.lg.tri-thr{border-bottom-width:30px}
.tri.lg.tri-act{border-bottom-width:30px}
.tri.lg.tri-att{border-bottom-width:30px}
.tri.lg.tri-cri{border-bottom-width:30px}
.tri.lg.tri-off{border-bottom-width:30px}

.sched{display:grid;grid-template-columns:48px repeat(7,1fr);gap:2px}
.sched .h{font:600 11px Inter;color:var(--fg-muted);display:flex;align-items:center;justify-content:center;text-transform:uppercase}
.sched .cell{height:30px;display:flex;align-items:center;justify-content:center;font:600 10px Inter;border-radius:3px;cursor:pointer}
.sched .open{background:#7FB539;color:#1D1C1D}
.sched .close{background:#FF7A00;color:#fff}
.sched .empty{background:var(--n-100);color:var(--n-300)}

.alert-row{border-radius:8px;padding:12px 14px;display:grid;grid-template-columns:32px 1fr auto auto;gap:12px;align-items:center;background:#fff;border:1px solid var(--border);border-left-width:3px;cursor:pointer;transition:background 120ms}
.alert-row:hover{background:var(--n-50)}
.alert-row + .alert-row{margin-top:8px}
.alert-row.crit,.alert-row[data-sev="critical"]{border-left-color:var(--status-critical);background:var(--status-critical-tint)}
.alert-row.warn,.alert-row[data-sev="warn"]{border-left-color:var(--status-alert);background:var(--status-alert-tint)}
.alert-row.info,.alert-row[data-sev="info"]{border-left-color:var(--status-info);background:var(--status-info-tint)}
.alert-row .ic{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:18px}
.alert-row.crit .ic,.alert-row[data-sev="critical"] .ic{background:var(--status-critical-soft);color:var(--status-critical-fg)}
.alert-row.warn .ic,.alert-row[data-sev="warn"] .ic{background:var(--status-alert-soft);color:var(--status-alert-fg)}
.alert-row.info .ic,.alert-row[data-sev="info"] .ic{background:var(--status-info-soft);color:var(--status-info-fg)}
.alert-title{font:600 14px Inter;color:var(--fg-strong)}
.alert-sub{font-size:12px;color:var(--fg-muted);margin-top:2px}
.alert-time{font-size:12px;color:var(--fg-muted);font-variant-numeric:tabular-nums}

/* Greenhouse schematic floorplan */
.gh-canvas{position:relative;width:1006px;max-width:100%;height:480px;background:repeating-linear-gradient(90deg,rgba(38,151,43,.04) 0 22px,transparent 22px 24px),#fff;border:1px solid var(--border);border-radius:12px;overflow:hidden}
.gh-hull{position:absolute;left:18px;top:18px;right:18px;bottom:18px;border:2px solid #242D36;border-radius:8px;background:rgba(255,255,255,.6);pointer-events:none}
.gh-zone{position:absolute;border:1.5px solid #B6C2D0;border-radius:6px;background:rgba(248,250,252,.65);overflow:hidden;cursor:pointer;transition:transform 120ms,box-shadow 120ms}
.gh-zone:hover{transform:translateY(-1px);box-shadow:0 4px 10px rgba(36,45,54,.12)}
.gh-zone-lbl{position:absolute;top:6px;left:8px;font:700 10px Inter;color:#242D36;letter-spacing:.05em;text-transform:uppercase;background:#fff;padding:2px 6px;border-radius:4px;border:1px solid var(--border);z-index:2;display:inline-flex;align-items:center;gap:6px}
.gh-zone-state.tri{border-left-width:5px;border-right-width:5px}
.gh-zone-state.tri.tri-thr{border-bottom:8px solid #7FB539}
.gh-zone-state.tri.tri-act{border-bottom:8px solid #E8B84A}
.gh-zone-state.tri.tri-att{border-bottom:8px solid #FF7A00}
.gh-zone-state.tri.tri-cri{border-bottom:8px solid #E5342B}
.gh-zone-state.tri.tri-off{border-bottom:8px solid #C2CCD8}
.gh-zone-meta{position:absolute;bottom:6px;right:8px;font:500 10px Inter;color:var(--fg-muted);font-variant-numeric:tabular-nums;z-index:2}
.gh-rows{position:absolute;left:8px;right:8px;top:30px;bottom:26px;display:flex;justify-content:space-between;gap:1px}
.gh-row{flex:1;background:linear-gradient(180deg,#D8EFD9 0%,#BFE2C0 50%,#D8EFD9 100%);border-radius:2px;position:relative;max-width:8px}
.gh-row::before{content:"";position:absolute;top:0;bottom:0;left:50%;width:1px;background:rgba(38,151,43,.35)}

.gh-corridor{position:absolute;left:20px;right:20px;top:208px;height:18px;background:repeating-linear-gradient(45deg,#EEF1F5 0 5px,#fff 5px 10px);border-top:1px dashed #C2CCD8;border-bottom:1px dashed #C2CCD8;z-index:1}
.gh-door{position:absolute;left:14px;top:214px;width:10px;height:18px;background:#FFB300;border:2px solid #242D36;border-radius:1px;z-index:3}
.gh-door::after{content:"вход";position:absolute;left:14px;top:3px;font:700 9px Inter;color:#242D36;white-space:nowrap;text-transform:uppercase;letter-spacing:.05em}

.gh-gw{position:absolute;left:480px;top:214px;width:28px;height:28px;background:#1D1C1D;border-radius:50%;border:3px solid #FFB300;display:flex;align-items:center;justify-content:center;color:#FFB300;font:700 12px Inter;z-index:4}
.gh-gw::after{content:"GW-01";position:absolute;top:32px;left:50%;transform:translateX(-50%);font:700 10px Inter;color:#1D1C1D;background:#fff;padding:2px 6px;border-radius:3px;border:1px solid var(--border);white-space:nowrap}
.gh-pulse{position:absolute;left:480px;top:214px;width:28px;height:28px;border-radius:50%;border:2px solid #FFB300;animation:gh-p 1.6s ease-out infinite;z-index:3;pointer-events:none}
@keyframes gh-p{0%{transform:scale(1);opacity:.7}100%{transform:scale(2.4);opacity:0}}

.gh-hive{position:absolute;cursor:pointer;transition:transform 120ms;z-index:5}
.gh-hive:hover{transform:scale(1.2)}
.gh-hive .num{position:absolute;top:5px;left:50%;transform:translateX(-50%);font:700 9px Inter;color:#1D1C1D;white-space:nowrap}
.gh-hive.selected{filter:drop-shadow(0 0 0 3px #007BFB) drop-shadow(0 1px 2px rgba(0,0,0,.2))}
.gh-hive.tri{border-left-width:13px;border-right-width:13px}
.gh-hive.tri.tri-thr{border-bottom:22px solid #7FB539}
.gh-hive.tri.tri-act{border-bottom:22px solid #E8B84A}
.gh-hive.tri.tri-att{border-bottom:22px solid #FF7A00}
.gh-hive.tri.tri-cri{border-bottom:22px solid #E5342B}
.gh-hive.tri.tri-off{border-bottom:22px solid #C2CCD8}
.gh-device{position:absolute;transform:translate(-50%,-50%);width:16px;height:16px;border-radius:50%;background:#fff;border:2px solid currentColor;display:grid;place-items:center;z-index:6;pointer-events:auto;cursor:pointer;box-shadow:0 1px 3px rgba(36,45,54,.2)}
.gh-device:hover{transform:translate(-50%,-50%) scale(1.15)}
.gh-device i{font-size:8px;line-height:1;color:currentColor}
.gh-device.tri-thr{color:#7FB539}
.gh-device.tri-act{color:#E8B84A}
.gh-device.tri-att{color:#FF7A00}
.gh-device.tri-cri{color:#E5342B}
.gh-device.tri-off{color:#C2CCD8}

.gh-fix{position:absolute;display:flex;align-items:center;gap:5px;font:600 10px Inter;color:#fff;padding:4px 8px;border-radius:5px;line-height:1;z-index:4;cursor:pointer;transition:transform 120ms,box-shadow 120ms}
.gh-fix:hover{transform:translateY(-1px);box-shadow:0 4px 10px rgba(29,28,29,.18)}
.gh-fix.active{box-shadow:0 0 0 2px #fff,0 0 0 4px #007BFB}
.gh-fix::before{content:"";width:6px;height:6px;border-radius:50%;background:#7FB539;box-shadow:0 0 0 2px rgba(127,181,57,.3)}
.gh-fix.warn::before{background:#FF7A00;box-shadow:0 0 0 2px rgba(255,122,0,.3)}
.gh-fix--tds{background:#007BFB}
.gh-fix--irr{background:#26972B}
.gh-fix--cam{background:#6B7785}

.gh-compass{position:absolute;right:30px;top:30px;width:38px;height:38px;border-radius:50%;background:#fff;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font:700 11px Inter;color:#242D36;z-index:4}
.gh-compass::before{content:"";position:absolute;top:4px;left:50%;transform:translateX(-50%);border-left:5px solid transparent;border-right:5px solid transparent;border-bottom:8px solid #E5342B}
.gh-compass span{margin-top:8px}

.gh-scale{position:absolute;left:34px;bottom:30px;display:flex;flex-direction:column;align-items:flex-start;gap:3px;font:600 10px Inter;color:var(--fg-muted);z-index:4}
.gh-scale .bar{display:flex;height:6px;border:1px solid #242D36}
.gh-scale .bar i{display:block;width:30px;height:100%}
.gh-scale .bar i:nth-child(odd){background:#242D36}
.gh-scale .bar i:nth-child(even){background:#fff}

/* fixture popover */
.gh-pop{position:absolute;background:#1D1C1D;color:#fff;border-radius:8px;padding:12px 14px;width:240px;font:500 11px Inter;line-height:1.45;z-index:30;box-shadow:0 10px 24px rgba(29,28,29,.28);animation:gh-popin 140ms cubic-bezier(.2,.7,.2,1.2) both}
@keyframes gh-popin{from{opacity:0;transform:translateY(4px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}
.gh-pop::after{content:"";position:absolute;top:-6px;left:18px;border-left:6px solid transparent;border-right:6px solid transparent;border-bottom:6px solid #1D1C1D}
.gh-pop h4{margin:0 0 4px;font:700 12px Inter;color:#fff;display:flex;justify-content:space-between;align-items:center;gap:8px}
.gh-pop h4 small{font:500 10px Inter;color:#9AA5B3}
.gh-pop .id{font:500 10px ui-monospace,Menlo,monospace;color:#9AA5B3;margin-bottom:8px}
.gh-pop dl{display:grid;grid-template-columns:auto 1fr;gap:4px 12px;margin:0 0 8px}
.gh-pop dt{color:#9AA5B3;font-weight:500;font-size:10px;text-transform:uppercase;letter-spacing:.04em;align-self:center}
.gh-pop dd{margin:0;color:#fff;font-variant-numeric:tabular-nums;font-weight:600;text-align:right}
.gh-pop dd.ok{color:#9CD962}.gh-pop dd.warn{color:#FFB300}.gh-pop dd.crit{color:#FF6760}
.gh-pop .gh-status{background:#FF7A00;color:#fff;font:700 9px Inter;text-transform:uppercase;letter-spacing:.04em;padding:3px 6px;border-radius:3px;margin-bottom:8px;display:inline-block}
.gh-pop .gh-actions{display:flex;gap:6px;border-top:1px solid var(--border-sidebar);padding-top:8px;margin-top:6px}
.gh-pop button{flex:1;background:var(--bg-sidebar-hover);border:none;color:#fff;font:600 10px Inter;padding:6px 8px;border-radius:5px;cursor:pointer;text-align:center}
.gh-pop button:hover{background:#4A5663}
.gh-pop button.primary{background:#FFB300;color:#1D1C1D}
.gh-pop button.primary:hover{background:#FAC20B}

.legend{display:flex;gap:14px;font-size:11px;color:var(--fg-muted);align-items:center}
.legend .d{width:10px;height:10px;border-radius:50%;display:inline-block;margin-right:5px;vertical-align:-1px}

.detail-panel{position:fixed;top:0;right:0;width:420px;height:100vh;background:#fff;border-left:1px solid var(--border);box-shadow:var(--shadow-lg);z-index:20;display:flex;flex-direction:column;animation:slide 200ms var(--ease-out)}
@keyframes slide{from{transform:translateX(100%)}to{transform:translateX(0)}}
.detail-head{padding:18px 20px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:flex-start;gap:12px}
.detail-body{flex:1;overflow:auto;padding:18px 20px;display:flex;flex-direction:column;gap:18px}
.metric-row{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.metric{padding:10px 12px;background:var(--n-50);border-radius:8px}
.metric-lbl{font-size:11px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--fg-muted)}
.metric-val{font:700 18px Inter;font-variant-numeric:tabular-nums;color:var(--fg-strong);margin-top:4px}
.metric-val small{font:500 12px Inter;color:var(--fg-muted)}

.history{font-size:12px;display:flex;flex-direction:column;gap:8px}
.history .h-row{display:grid;grid-template-columns:80px 1fr;gap:10px;padding:8px 0;border-bottom:1px solid var(--n-150)}
.history time{color:var(--fg-muted);font-variant-numeric:tabular-nums}

.toggle-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--n-150)}
.toggle-row b{font:600 13px Inter;color:var(--fg-strong);display:block}
.toggle-row span{font-size:12px;color:var(--fg-muted)}
.switch{width:38px;height:22px;border-radius:999px;background:var(--n-300);position:relative;cursor:pointer;transition:background 120ms}
.switch::after{content:"";position:absolute;left:2px;top:2px;width:18px;height:18px;border-radius:50%;background:#fff;transition:left 120ms}
.switch.on{background:#26972B}
.switch.on::after{left:18px}

.empty-state{padding:40px;text-align:center;color:var(--fg-muted);font-size:13px}

.tab-bar{display:flex;border-bottom:1px solid var(--border);gap:4px;margin-bottom:16px}
.tab{padding:10px 14px;font:600 13px Inter;color:var(--fg-muted);cursor:pointer;border:none;background:none;border-bottom:2px solid transparent;margin-bottom:-1px}
.tab.active{color:var(--fg-strong);border-bottom-color:#FFB300}
.tab:hover{color:var(--fg-strong)}
