.spinner{display:inline-block;border-style:solid;border-color:#1a936f40;border-top-color:#1a936f;border-radius:50%;animation:spinner-spin .8s linear infinite}@keyframes spinner-spin{to{transform:rotate(360deg)}}.sidebar{position:fixed;inset:0 auto 0 0;width:240px;z-index:200;display:flex;flex-direction:column;background:#fff;border-right:1px solid #e2e8f0;padding:1rem 0 .5rem;transform:translate(-100%);transition:transform .2s cubic-bezier(.4,0,.2,1),width .2s cubic-bezier(.4,0,.2,1);scrollbar-width:thin;scrollbar-color:#cbd5e1 transparent}.sidebar::-webkit-scrollbar{width:8px;height:8px}.sidebar::-webkit-scrollbar-track{background:transparent}.sidebar::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:9999px}.sidebar::-webkit-scrollbar-thumb:hover{background:#94a3b8}.sidebar{overflow-y:auto;overflow-x:hidden}@media(min-width:768px){.sidebar{transform:translate(0);position:sticky;top:0;height:100vh;flex-shrink:0}}.sidebar--mobile-open{transform:translate(0);box-shadow:0 24px 56px #0f172a2e,0 8px 16px #0f172a14}@media(min-width:768px){.sidebar--collapsed{width:64px}}.sidebar__backdrop{position:fixed;inset:0;background:#0f172a73;z-index:199;opacity:0;pointer-events:none;transition:opacity .14s cubic-bezier(.2,.8,.2,1)}.sidebar__backdrop--open{opacity:1;pointer-events:auto}@media(min-width:768px){.sidebar__backdrop{display:none}}.sidebar__brand{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem 1.5rem;min-height:56px}.sidebar__logo{width:32px;height:32px;flex-shrink:0;border-radius:8px;background:linear-gradient(135deg,#1a936f,#105658);box-shadow:0 4px 12px #1a936f4d}.sidebar__title{font-weight:600;font-size:1rem;color:#0f172a;letter-spacing:-.01em;flex:1;white-space:nowrap;overflow:hidden}.sidebar__close-mobile{display:inline-flex;width:44px;height:44px;align-items:center;justify-content:center;border-radius:8px;background:transparent;border:none;color:#64748b;cursor:pointer;transition:background .14s cubic-bezier(.2,.8,.2,1);margin-right:-.25rem}.sidebar__close-mobile:hover{background:#f1f5f9;color:#0f172a}@media(min-width:768px){.sidebar__close-mobile{display:none}}.sidebar__nav{display:flex;flex-direction:column;gap:2px;padding:0 .5rem;flex:1}.sidebar__link{display:flex;align-items:center;gap:.5rem;padding:.625rem 1rem;min-height:44px;border-radius:8px;color:#334155;font-size:.875rem;font-weight:500;text-decoration:none;transition:background .14s cubic-bezier(.2,.8,.2,1),color .14s cubic-bezier(.2,.8,.2,1)}.sidebar__link:hover{background:#f1f5f9;color:#0f172a}.sidebar__link--active{background:#1a936f1a;color:#1a936f;box-shadow:inset 3px 0 #1a936f}.sidebar__link-label{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar__collapse{display:none}@media(min-width:768px){.sidebar__collapse{display:flex;align-items:center;gap:.5rem;margin:.5rem .5rem 0;padding:.5rem 1rem;border-radius:8px;background:transparent;border:none;color:#64748b;font-size:.8125rem;cursor:pointer;transition:background .14s cubic-bezier(.2,.8,.2,1),color .14s cubic-bezier(.2,.8,.2,1)}.sidebar__collapse:hover{background:#f1f5f9;color:#0f172a}.sidebar__collapse svg{transition:transform .2s cubic-bezier(.4,0,.2,1)}}.sidebar--collapsed .sidebar__title,.sidebar--collapsed .sidebar__link-label{opacity:0;width:0;pointer-events:none}.sidebar--collapsed .sidebar__brand{justify-content:center;padding-inline:.5rem}.sidebar--collapsed .sidebar__link,.sidebar--collapsed .sidebar__collapse{justify-content:center;padding-inline:0}.sidebar--collapsed .sidebar__collapse svg{transform:rotate(180deg)}.topbar{position:sticky;top:0;z-index:50;height:56px;background:#fff;border-bottom:1px solid #e2e8f0;display:flex;align-items:center;justify-content:space-between;padding:0 1rem;gap:.5rem;backdrop-filter:saturate(180%) blur(8px);-webkit-backdrop-filter:saturate(180%) blur(8px)}@media(min-width:768px){.topbar{padding:0 1.5rem}}.topbar__left{display:flex;align-items:center;gap:.5rem;min-width:0}.topbar__menu-btn{display:inline-flex;width:44px;height:44px;margin-left:-.5rem;align-items:center;justify-content:center;border-radius:8px;background:transparent;border:none;color:#334155;cursor:pointer;transition:background-color .14s cubic-bezier(.2,.8,.2,1),border-color .14s cubic-bezier(.2,.8,.2,1),color .14s cubic-bezier(.2,.8,.2,1),box-shadow .2s cubic-bezier(.2,.8,.2,1),transform .14s cubic-bezier(.2,.8,.2,1);outline:none}.topbar__menu-btn:focus-visible{box-shadow:0 0 0 2px #f8fafc,0 0 0 4px #1a936f73}.topbar__menu-btn:hover{background:#f1f5f9;color:#0f172a}@media(min-width:1024px){.topbar__menu-btn{display:none}}.topbar__right{display:flex;align-items:center;gap:.5rem}@media(min-width:768px){.topbar__right{gap:1rem}}.topbar__icon-btn{width:36px;height:36px;border-radius:8px;background:transparent;border:none;color:#334155;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:background-color .14s cubic-bezier(.2,.8,.2,1),border-color .14s cubic-bezier(.2,.8,.2,1),color .14s cubic-bezier(.2,.8,.2,1),box-shadow .2s cubic-bezier(.2,.8,.2,1),transform .14s cubic-bezier(.2,.8,.2,1);outline:none}.topbar__icon-btn:focus-visible{box-shadow:0 0 0 2px #f8fafc,0 0 0 4px #1a936f73}.topbar__icon-btn:hover{background:#f1f5f9;color:#0f172a}.topbar__user{display:none;flex-direction:column;align-items:flex-end;line-height:1.15;min-width:0}@media(min-width:768px){.topbar__user{display:flex}}.topbar__user-name{font-size:.8125rem;font-weight:600;color:#0f172a;max-width:22ch;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.topbar__user-email{font-size:.75rem;color:#94a3b8;max-width:28ch;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.app-shell{display:flex;min-height:100vh;min-height:100dvh;background:#f8fafc;color:#0f172a;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif}.app-shell__main{flex:1;display:flex;flex-direction:column;min-width:0}.app-shell__content{flex:1;padding:1rem;overflow-x:hidden;overflow-y:auto;scrollbar-width:thin;scrollbar-color:#cbd5e1 transparent}.app-shell__content::-webkit-scrollbar{width:8px;height:8px}.app-shell__content::-webkit-scrollbar-track{background:transparent}.app-shell__content::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:9999px}.app-shell__content::-webkit-scrollbar-thumb:hover{background:#94a3b8}@media(min-width:640px){.app-shell__content{padding:1.5rem}}@media(min-width:1024px){.app-shell__content{padding:2rem}}.app-shell__content>*{max-width:1440px;margin-inline:auto}.gradient-orbs{position:absolute;inset:0;pointer-events:none}.gradient-orbs__orb{position:absolute;inset:0}.gradient-orbs__orb--primary{background:radial-gradient(ellipse at 20% 20%,rgba(26,147,111,.15) 0%,transparent 50%)}.gradient-orbs__orb--accent{background:radial-gradient(ellipse at 80% 80%,rgba(34,211,238,.1) 0%,transparent 50%)}.gradient-orbs__orb--deep{background:radial-gradient(ellipse at 50% 50%,rgba(16,86,88,.2) 0%,transparent 70%)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;border-radius:8px;font-weight:500;border:1px solid transparent;cursor:pointer;transition:background .12s ease,border-color .12s ease,color .12s ease,transform 80ms ease;outline:none}.btn:focus-visible{box-shadow:0 0 0 2px #f8fafc,0 0 0 4px #1a936f73}.btn:active:not(:disabled){transform:translateY(1px)}.btn:disabled{opacity:.6;cursor:not-allowed}.btn--sm{padding:.375rem .75rem;font-size:.8125rem}.btn--md{padding:.5rem 1rem;font-size:.875rem}.btn--lg{padding:.75rem 1.25rem;font-size:1rem}.btn--primary{background:linear-gradient(135deg,#1a936f,#105658);color:#fff}.btn--primary:hover:not(:disabled){background:linear-gradient(135deg,#4ade80,#1a936f)}.btn--secondary{background:#fff;border-color:#e2e8f0;color:#0f172a}.btn--secondary:hover:not(:disabled){background:#f8fafc}.btn--ghost{background:transparent;color:#475569}.btn--ghost:hover:not(:disabled){background:#f1f5f9;color:#0f172a}.btn--danger{background:#ef4444;color:#fff}.btn--danger:hover:not(:disabled){background:#ed2d2d}.input-field{display:flex;flex-direction:column;gap:.25rem}.input-field__label{font-size:.8125rem;font-weight:500;color:#334155}.input-field__input{width:100%;padding:.5rem .75rem;border-radius:8px;border:1px solid #cbd5e1;background:#fff;font-size:.875rem;color:#0f172a;transition:border-color .12s ease,box-shadow .12s ease}.input-field__input:focus{outline:none;border-color:#1a936f;box-shadow:0 0 0 3px #1a936f26}.input-field__input--error{border-color:#ef4444}.input-field__input--error:focus{box-shadow:0 0 0 3px #ef444426}.input-field__hint{font-size:.75rem;color:#94a3b8}.input-field__error{font-size:.75rem;color:#ef4444}.login-form{width:100%;padding:2rem;display:flex;flex-direction:column;gap:1rem}.login-form__heading{color:#f8fafc;font-size:1.25rem;font-weight:600;margin:0 0 .5rem}.login-form .input-field__label{color:#94a3b8}.login-form .input-field__input{background:#ffffff0f;border-color:#ffffff1f;color:#f8fafc}.login-form .input-field__input::-moz-placeholder{color:#ffffff4d}.login-form .input-field__input::placeholder{color:#ffffff4d}.login-form .input-field__input:focus{border-color:#1a936f;box-shadow:0 0 0 3px #1a936f40}.login-form__error{background:#ef44441f;color:#f47c7c;padding:.5rem 1rem;border-radius:8px;font-size:.8125rem;border:1px solid rgba(239,68,68,.3)}.login-page{min-height:100vh;position:relative;background:#0a0f1a;display:flex;align-items:center;justify-content:center;padding:1.5rem;overflow:hidden}.login-page__grid-overlay{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);background-size:50px 50px;pointer-events:none}.login-page__container{position:relative;z-index:1;width:100%;max-width:420px;display:flex;flex-direction:column;align-items:center;gap:2rem}.login-page__brand{display:flex;flex-direction:column;align-items:center;gap:.5rem}.login-page__logo{width:56px;height:56px;border-radius:12px;background:linear-gradient(135deg,#1a936f,#105658);box-shadow:0 0 32px #1a936f66}.login-page__title{background:linear-gradient(135deg,#fff,#94a3b8);-webkit-background-clip:text;background-clip:text;color:transparent;font-size:2rem;font-weight:700;margin:0;letter-spacing:-.02em}.login-page__tagline{color:#94a3b8;font-size:.875rem;margin:0}.login-page__footer{color:#94a3b8;font-size:.75rem;margin-top:1rem}.kpi-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:1rem 1.5rem;display:flex;flex-direction:column;gap:.25rem;min-height:96px;transition:box-shadow .16s ease,border-color .16s ease}.kpi-card:hover{border-color:#cbd5e1;box-shadow:0 1px 3px #0f172a0f}.kpi-card__header{display:flex;align-items:center;justify-content:space-between}.kpi-card__label{font-size:.75rem;font-weight:500;color:#94a3b8;text-transform:uppercase;letter-spacing:.04em}.kpi-card__icon{color:#94a3b8;display:inline-flex}.kpi-card__value{font-size:1.75rem;font-weight:600;color:#0f172a;line-height:1.1}.kpi-card__hint{font-size:.75rem;color:#94a3b8}.kpi-card--success .kpi-card__value{color:#22c55e}.kpi-card--warning .kpi-card__value{color:#f59e0b}.kpi-card--danger .kpi-card__value{color:#ef4444}.kpi-strip{display:grid;grid-template-columns:1fr;gap:1rem}@media(min-width:640px){.kpi-strip{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){.kpi-strip{grid-template-columns:repeat(4,1fr)}}.alert-row{display:grid;grid-template-columns:24px 52px 1fr;gap:.5rem;padding:.5rem 1rem;border-bottom:1px solid #f1f5f9;align-items:flex-start}.alert-row:last-child{border-bottom:none}.alert-row__icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;flex-shrink:0}.alert-row__time{font-size:.75rem;color:#94a3b8;font-variant-numeric:tabular-nums;padding-top:4px}.alert-row__body{min-width:0}.alert-row__label{font-size:.875rem;font-weight:500;color:#0f172a;line-height:1.3}.alert-row__meta{font-size:.75rem;color:#94a3b8;margin-top:2px}.alert-row--critical .alert-row__icon{background:#ef44441f;color:#ef4444}.alert-row--warning .alert-row__icon{background:#f59e0b24;color:#d97706}.alert-row--info .alert-row__icon{background:#1a936f1f;color:#1a936f}.alerts-feed{background:#fff;border:1px solid #e2e8f0;border-radius:12px;display:flex;flex-direction:column;min-height:360px}.alerts-feed__header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;border-bottom:1px solid #f1f5f9}.alerts-feed__title{margin:0;font-size:.95rem;font-weight:600;color:#0f172a}.alerts-feed__count{font-size:.75rem;color:#94a3b8;background:#f1f5f9;padding:2px 8px;border-radius:999px;font-variant-numeric:tabular-nums}.alerts-feed__list{flex:1;overflow-y:auto;max-height:420px}.alerts-feed__empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem;padding:3rem;color:#94a3b8;text-align:center}.alerts-feed__empty p{margin:0;font-weight:500;color:#475569}.alerts-feed__empty span{font-size:.8125rem}.alerts-feed__view-all{padding:.5rem 1.5rem;text-align:center;border-top:1px solid #f1f5f9;color:#1a936f;text-decoration:none;font-size:.8125rem;font-weight:500}.alerts-feed__view-all:hover{background:#f8fafc}.snap-tile{background:#fff;border:1px solid #e2e8f0;border-radius:8px;overflow:hidden;display:flex;flex-direction:column;transition:border-color .16s ease,transform .16s ease}.snap-tile:hover{border-color:#1a936f;transform:translateY(-1px)}.snap-tile__media{position:relative;width:100%;aspect-ratio:16/9;background:#0f172a;overflow:hidden}.snap-tile__img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block}.snap-tile__fallback{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#ffffff80;gap:.25rem;font-size:.75rem}.snap-tile__live-btn{position:absolute;bottom:.5rem;right:.5rem;background:#0000008c;color:#fff;border:none;border-radius:999px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .12s ease}.snap-tile__live-btn:hover{background:#1a936f}.snap-tile__footer{padding:.5rem 1rem;display:flex;align-items:center;gap:.5rem;border-top:1px solid #f1f5f9}.snap-tile__status{width:8px;height:8px;border-radius:50%;background:#cbd5e1;flex-shrink:0}.snap-tile__status[data-on=true]{background:#22c55e;box-shadow:0 0 0 3px #22c55e2e}.snap-tile__name{font-size:.8125rem;font-weight:500;color:#0f172a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.snaps-grid{background:#fff;border:1px solid #e2e8f0;border-radius:12px;display:flex;flex-direction:column;min-height:360px}.snaps-grid__header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;border-bottom:1px solid #f1f5f9}.snaps-grid__title{margin:0;font-size:.95rem;font-weight:600;color:#0f172a}.snaps-grid__view-all{color:#1a936f;text-decoration:none;font-size:.8125rem;font-weight:500}.snaps-grid__view-all:hover{text-decoration:underline}.snaps-grid__tiles{padding:1rem;display:grid;grid-template-columns:1fr;gap:1rem}@media(min-width:640px){.snaps-grid__tiles{grid-template-columns:repeat(2,1fr)}}.snaps-grid__empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem;padding:3rem;color:#94a3b8;text-align:center}.snaps-grid__empty p{margin:0;font-weight:500;color:#475569}.snaps-grid__empty span{font-size:.8125rem}.timeline-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:1rem 1.5rem}.timeline-card__header{margin-bottom:.25rem}.timeline-card__title{margin:0;font-size:.95rem;font-weight:600;color:#0f172a}.dashboard-page{display:flex;flex-direction:column;gap:1.5rem}.dashboard-page__header{display:flex;flex-direction:column;gap:.25rem}.dashboard-page__heading{font-size:1.5rem;font-weight:600;color:#0f172a;margin:0;letter-spacing:-.01em}.dashboard-page__sub{color:#94a3b8;margin:0;font-size:.875rem}.dashboard-page__main{display:grid;grid-template-columns:1fr;gap:1.5rem}@media(min-width:1024px){.dashboard-page__main{grid-template-columns:1fr 1fr}}.status-dot{display:inline-flex;align-items:center;gap:.25rem}.status-dot__bead{width:8px;height:8px;border-radius:50%;background:#cbd5e1;flex-shrink:0}.status-dot__label{font-size:.8125rem;color:#475569}.status-dot--connected .status-dot__bead{background:#22c55e;box-shadow:0 0 0 3px #22c55e2e}.status-dot--connecting .status-dot__bead{background:#f59e0b;box-shadow:0 0 0 3px #f59e0b2e;animation:pulse 1.4s ease-in-out infinite}.status-dot--offline .status-dot__bead{background:#94a3b8}.status-dot--revoked .status-dot__bead,.status-dot--error .status-dot__bead{background:#ef4444;box-shadow:0 0 0 3px #ef44442e}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.2);opacity:.7}}.devices-grid{width:100%;min-height:480px;height:calc(100vh - 280px);border:1px solid #e2e8f0;border-radius:12px;overflow:hidden;background:#fff;--ag-grid-size: 6px;--ag-header-background-color: #f8fafc;--ag-header-foreground-color: #475569;--ag-row-hover-color: #f1f5f9;--ag-selected-row-background-color: rgba(26, 147, 111, .08);--ag-border-color: #e2e8f0;--ag-secondary-border-color: #f1f5f9;--ag-font-family: inherit;--ag-font-size: 14px;--ag-row-border-color: #f1f5f9}.devices-grid .ag-row{cursor:pointer}.devices-grid__cell{display:flex;align-items:center}.devices-grid__header-cell{font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.04em}.devices-grid__os-chip{background:#f1f5f9;color:#334155;border-radius:999px;padding:2px 8px;font-size:.75rem;font-weight:500;text-transform:capitalize}.drawer{position:fixed;top:0;bottom:0;background:#fff;display:flex;flex-direction:column;box-shadow:-8px 0 32px #0f172a1f;z-index:200;animation:drawer-in-right .22s ease}.drawer__backdrop{position:fixed;inset:0;background:#0f172a59;z-index:200;animation:drawer-fade .14s ease}.drawer--right{right:0}.drawer--left{left:0;box-shadow:8px 0 32px #0f172a1f;animation-name:drawer-in-left}.drawer__header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;border-bottom:1px solid #f1f5f9;flex-shrink:0}.drawer__title{margin:0;font-size:1rem;font-weight:600;color:#0f172a}.drawer__close{background:transparent;border:none;color:#475569;cursor:pointer;padding:6px;border-radius:8px;display:flex}.drawer__close:hover{background:#f1f5f9;color:#0f172a}.drawer__body{padding:1.5rem;overflow-y:auto;flex:1}.drawer__footer{padding:1rem 1.5rem;border-top:1px solid #f1f5f9;display:flex;justify-content:flex-end;gap:.5rem;flex-shrink:0}@keyframes drawer-in-right{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes drawer-in-left{0%{transform:translate(-100%)}to{transform:translate(0)}}@keyframes drawer-fade{0%{opacity:0}to{opacity:1}}.device-drawer{display:flex;flex-direction:column;gap:1.5rem}.device-drawer__head{display:flex;flex-direction:column;gap:.25rem}.device-drawer__name{margin:0;font-size:1.125rem;font-weight:600;color:#0f172a}.device-drawer__meta{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin:0}.device-drawer__meta>div{display:flex;flex-direction:column;gap:2px}.device-drawer__meta--full{grid-column:1/-1}.device-drawer__meta dt{font-size:.7rem;font-weight:500;color:#94a3b8;text-transform:uppercase;letter-spacing:.04em}.device-drawer__meta dd{margin:0;font-size:.875rem;color:#0f172a}.device-drawer__chip{background:#f1f5f9;color:#334155;border-radius:999px;padding:2px 8px;font-size:.75rem;font-weight:500;text-transform:capitalize;align-self:flex-start;width:-moz-fit-content;width:fit-content}.device-drawer__mono{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.75rem;word-break:break-all}.device-drawer__open{width:100%}.device-drawer__actions{display:flex;flex-direction:column;gap:.5rem;border-top:1px solid #f1f5f9;padding-top:1rem}.device-drawer__confirm{display:flex;align-items:center;gap:.5rem;background:#ef44440f;border:1px solid rgba(239,68,68,.2);border-radius:8px;padding:.5rem}.device-drawer__confirm span{flex:1;font-size:.8125rem;color:#ef4444}.modal{background:#fff;border-radius:16px;box-shadow:0 24px 64px #0f172a2e;display:flex;flex-direction:column;max-height:calc(100vh - 64px);width:100%;animation:modal-in .18s ease}.modal__backdrop{position:fixed;inset:0;background:#0f172a8c;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:300;display:flex;align-items:center;justify-content:center;padding:1.5rem;animation:modal-fade .14s ease}.modal--sm{max-width:420px}.modal--md{max-width:560px}.modal--lg{max-width:800px}.modal--xl{max-width:1080px}.modal__header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;border-bottom:1px solid #f1f5f9}.modal__title{margin:0;font-size:1rem;font-weight:600;color:#0f172a}.modal__close{background:transparent;border:none;color:#475569;cursor:pointer;padding:6px;border-radius:8px;display:flex}.modal__close:hover{background:#f1f5f9;color:#0f172a}.modal__body{padding:1.5rem;overflow-y:auto;flex:1}.modal__footer{padding:1rem 1.5rem;border-top:1px solid #f1f5f9;display:flex;justify-content:flex-end;gap:.5rem}@keyframes modal-in{0%{opacity:0;transform:translateY(10px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes modal-fade{0%{opacity:0}to{opacity:1}}.connect-modal{display:flex;flex-direction:column;gap:1.5rem}.connect-modal__intro{margin:0;color:#475569;font-size:.875rem;line-height:1.5}.connect-modal__downloads{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.connect-modal__dl{display:flex;align-items:center;gap:.5rem;padding:1rem;border:1px solid #e2e8f0;border-radius:8px;text-decoration:none;color:#0f172a;transition:border-color .12s ease,background .12s ease}.connect-modal__dl>svg:first-child{color:#1a936f}.connect-modal__dl>div{flex:1}.connect-modal__dl>svg:last-child{color:#94a3b8}.connect-modal__dl:hover{border-color:#1a936f;background:#1a936f08}.connect-modal__dl-title{font-weight:600;font-size:.9rem}.connect-modal__dl-sub{font-size:.75rem;color:#94a3b8}.connect-modal__steps{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem;background:#f8fafc;border-radius:8px;padding:1rem}.connect-modal__step{display:flex;align-items:flex-start;gap:.5rem;font-size:.875rem;color:#334155;line-height:1.4}.connect-modal__step-num{flex-shrink:0;width:22px;height:22px;background:#1a936f;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:600}.connect-modal__step-text{flex:1}.connect-modal__copy{border:1px solid #e2e8f0;background:#fff;color:#475569;font-size:.7rem;padding:2px 8px;border-radius:4px;cursor:pointer;transition:background .12s ease;display:inline-flex;align-items:center}.connect-modal__copy:hover{background:#f1f5f9}.connect-modal__footer-note{font-size:.75rem;color:#94a3b8;text-align:center}.connect-modal__actions{display:flex;justify-content:flex-end;padding-top:1rem;border-top:1px solid #f1f5f9;margin-top:1rem}.devices-page{display:flex;flex-direction:column;gap:1.5rem}.devices-page__header{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.devices-page__heading{font-size:1.5rem;font-weight:600;color:#0f172a;margin:0;letter-spacing:-.01em}.devices-page__sub{color:#94a3b8;margin:.25rem 0 0;font-size:.875rem}.devices-page__toolbar{display:flex;align-items:center;gap:.5rem}.devices-page__error{background:#ef44440f;color:#ef4444;border:1px solid rgba(239,68,68,.2);border-radius:8px;padding:.5rem 1rem;font-size:.8125rem}.devices-page__loading{display:flex;align-items:center;justify-content:center;min-height:240px}.devices-page__empty{background:#fff;border:1px dashed #cbd5e1;border-radius:12px;padding:3rem;text-align:center;display:flex;flex-direction:column;align-items:center;gap:1rem}.devices-page__empty p{margin:0;color:#94a3b8;font-size:.95rem}.event-chips{display:flex;flex-direction:column;gap:4px}.event-chips--empty{color:#94a3b8;font-size:.75rem;padding:4px 0}.event-chips__chip{display:flex;align-items:center;gap:6px;padding:4px 8px;border-radius:4px;font-size:.75rem;overflow:hidden}.event-chips__time{font-variant-numeric:tabular-nums;color:#475569;flex-shrink:0}.event-chips__label{color:#0f172a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.event-chips__chip--critical{background:#ef444414;color:#ef4444}.event-chips__chip--critical .event-chips__time,.event-chips__chip--critical .event-chips__label{color:inherit}.event-chips__chip--warning{background:#f59e0b1a;color:#b45309}.event-chips__chip--warning .event-chips__time,.event-chips__chip--warning .event-chips__label{color:inherit}.event-chips__chip--info{background:#1a936f14;color:#1a936f}.event-chips__chip--info .event-chips__time,.event-chips__chip--info .event-chips__label{color:inherit}.camera-tile{background:#fff;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden;display:flex;flex-direction:column;transition:border-color .16s ease,box-shadow .16s ease,transform .16s ease}.camera-tile:hover{border-color:#1a936f;box-shadow:0 6px 24px #0f172a14;transform:translateY(-2px)}.camera-tile__media{position:relative;width:100%;aspect-ratio:16/9;background:#0f172a;overflow:hidden}.camera-tile__img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block}.camera-tile__fallback{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#ffffff73;gap:.25rem;font-size:.75rem}.camera-tile__bboxes{position:absolute;inset:0;pointer-events:none;animation:ai-flash 2s ease-out forwards}.camera-tile__bbox{position:absolute;border:2px solid #f59e0b;border-radius:4px;box-shadow:0 0 0 1px #0009}.camera-tile__bbox-label{position:absolute;top:-22px;left:-2px;background:#f59e0b;color:#1f1003;font-size:.65rem;font-weight:600;padding:2px 6px;border-radius:3px;text-transform:uppercase;letter-spacing:.04em}.camera-tile__disabled-banner{position:absolute;bottom:0;left:0;right:0;background:#0f172ab3;color:#fff;text-align:center;font-size:.7rem;padding:4px}.camera-tile__body{padding:.5rem 1rem 1rem;display:flex;flex-direction:column;gap:.5rem}.camera-tile__head{display:flex;align-items:center;gap:.5rem}.camera-tile__status{width:8px;height:8px;border-radius:50%;background:#cbd5e1;flex-shrink:0}.camera-tile__status[data-on=true]{background:#22c55e;box-shadow:0 0 0 3px #22c55e2e}.camera-tile__name{margin:0;font-size:.9rem;font-weight:600;color:#0f172a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.camera-tile__actions{display:flex;align-items:center;gap:.5rem}.camera-tile__actions .btn{flex:1}.camera-tile__icon-btn{width:32px;height:32px;border-radius:8px;background:#f8fafc;border:1px solid #e2e8f0;color:#475569;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .12s ease,border-color .12s ease}.camera-tile__icon-btn:hover{background:#f1f5f9;border-color:#1a936f;color:#1a936f}@keyframes ai-flash{0%{opacity:1}85%{opacity:1}to{opacity:0}}.tiles-grid{display:grid;grid-template-columns:1fr;gap:1.5rem}@media(min-width:640px){.tiles-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){.tiles-grid{grid-template-columns:repeat(3,1fr)}}@media(min-width:1280px){.tiles-grid{grid-template-columns:repeat(4,1fr)}}.tiles-grid__state{background:#fff;border:1px dashed #cbd5e1;border-radius:12px;padding:3rem;text-align:center;color:#94a3b8;font-size:.875rem}.tiles-grid__state--empty{display:flex;flex-direction:column;align-items:center;gap:.25rem}.tiles-grid__state--empty p{margin:0;font-weight:500;color:#475569}.tiles-grid__state--empty span{font-size:.8125rem}.live-modal{display:flex;flex-direction:column;gap:1rem}.live-modal__player{position:relative;width:100%;aspect-ratio:16/9;background:#000;border-radius:8px;overflow:hidden}.live-modal__video{width:100%;height:100%;-o-object-fit:contain;object-fit:contain;display:block;background:#000}.live-modal__overlay{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;color:#ffffffd9;background:#00000073;font-size:.875rem}.live-modal__overlay--error{color:#f58686;background:#0000008c}.live-modal__badge{position:absolute;top:.5rem;left:.5rem;display:flex;align-items:center;gap:6px;background:#ef4444eb;color:#fff;font-size:.7rem;font-weight:700;letter-spacing:.06em;padding:4px 10px;border-radius:999px}.live-modal__dot{width:8px;height:8px;border-radius:50%;background:#fff;animation:live-pulse 1.4s ease-in-out infinite}.live-modal__footer{display:flex;align-items:center;justify-content:space-between;gap:1rem}.live-modal__timer{display:flex;align-items:center;gap:6px;color:#94a3b8;font-size:.8125rem;font-variant-numeric:tabular-nums}.live-modal__actions{display:flex;gap:.5rem}@keyframes live-pulse{0%,to{opacity:1}50%{opacity:.3}}.device-detail{display:flex;flex-direction:column;gap:1.5rem}.device-detail__header{display:flex;flex-direction:column;gap:.5rem}.device-detail__back{display:inline-flex;align-items:center;gap:4px;color:#94a3b8;text-decoration:none;font-size:.8125rem;font-weight:500;width:-moz-fit-content;width:fit-content;padding:4px 8px;margin-left:-8px;border-radius:4px}.device-detail__back:hover{color:#1a936f;background:#1a936f0f}.device-detail__meta{display:flex;flex-direction:column;gap:.25rem}.device-detail__title-row{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.device-detail__name{margin:0;font-size:1.5rem;font-weight:600;color:#0f172a;letter-spacing:-.01em}.device-detail__stats{display:flex;gap:6px;color:#94a3b8;font-size:.8125rem}.device-detail__missing{display:flex;align-items:center;gap:1rem;color:#94a3b8}.not-found{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;text-align:center;gap:.5rem}.not-found__code{font-size:4rem;font-weight:700;color:#1a936f;line-height:1}.not-found__title{font-size:1.25rem;font-weight:600;color:#0f172a;margin:0}.not-found__sub{color:#94a3b8;margin:0 0 1rem}.not-found__link{color:#1a936f;text-decoration:none;font-weight:500;border:1px solid #1a936f;padding:.5rem 1rem;border-radius:8px;transition:background .12s ease}.not-found__link:hover{background:#1a936f14}*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,JetBrains Mono,Menlo,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}*,*:before,*:after{box-sizing:border-box}html,body,#root{height:100%}html{-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;font-size:.875rem;line-height:1.5;color:#0f172a;background:#f8fafc;overscroll-behavior-y:none}h1,h2,h3,h4,h5,h6{margin:0;font-weight:600;line-height:1.15;letter-spacing:-.01em;color:#0f172a}h1{font-size:1.5rem;letter-spacing:-.02em}h2{font-size:1.25rem}h3{font-size:1.125rem}h4{font-size:1rem}h5{font-size:.875rem}h6{font-size:.8125rem;text-transform:uppercase;letter-spacing:.04em;color:#64748b}p{margin:0;line-height:1.5}a{color:#1a936f;text-decoration:none;transition:color .14s cubic-bezier(.2,.8,.2,1)}a:hover{color:#105658}button,input,select,textarea{font:inherit;color:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed}img,picture,svg,video,canvas{display:block;max-width:100%}::-moz-selection{background:#1a936f38;color:#0f172a}::selection{background:#1a936f38;color:#0f172a}:focus{outline:none}:focus-visible{outline:2px solid #1a936f;outline-offset:2px;border-radius:4px}html{scrollbar-width:thin;scrollbar-color:#cbd5e1 transparent}html::-webkit-scrollbar{width:8px;height:8px}html::-webkit-scrollbar-track{background:transparent}html::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:9999px}html::-webkit-scrollbar-thumb:hover{background:#94a3b8}body{scrollbar-width:thin;scrollbar-color:#cbd5e1 transparent}body::-webkit-scrollbar{width:8px;height:8px}body::-webkit-scrollbar-track{background:transparent}body::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:9999px}body::-webkit-scrollbar-thumb:hover{background:#94a3b8}.glass-card{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:16px}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.mt-1{margin-top:.25rem}.flex{display:flex}.grid{display:grid}.hidden{display:none}.h-full{height:100%}.w-full{width:100%}.items-center{align-items:center}.justify-center{justify-content:center}.text-2xl{font-size:1.5rem;line-height:1.25;letter-spacing:-.01em}.text-sm{font-size:.8125rem;line-height:1.45}.font-semibold{font-weight:600}.text-slate-500{--tw-text-opacity: 1;color:rgb(100 116 139 / var(--tw-text-opacity, 1))}.text-slate-900{--tw-text-opacity: 1;color:rgb(15 23 42 / var(--tw-text-opacity, 1))}.shadow{--tw-shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--tw-shadow-colored: 0 1px 3px 0 var(--tw-shadow-color), 0 1px 2px -1px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}
