:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;--font-weight-regular:400;--font-weight-medium:500;--font-weight-semibold:600;--color-background:#f7f8f3;--color-surface:#fff;--color-surface-muted:#edf3ee;--color-surface-strong:#fbfcf7;--color-text:#122019;--color-text-muted:#5b6b62;--color-border:#dfe7dd;--color-border-strong:#cbd8ca;--color-drawer:#082219;--color-drawer-surface:#0f3426;--color-drawer-text:#f7fbf3;--color-drawer-muted:#abc0b2;--color-drawer-border:#245140;--color-brand-mark:#003f2d;--color-primary:#003f2d;--color-primary-text:#fff;--color-primary-hover:#062f23;--color-primary-soft:#dcecdf;--color-accent:#0fbd2d;--color-accent-warm:#c99b37;--color-success:#229d45;--color-warning:#ad6b1d;--color-danger:#b42318;--color-focus:#0fbd2d;--color-link:#075f49;--shadow-soft:0 1px 2px #003f2d0f, 0 18px 42px #003f2d1a;--shadow-crisp:0 1px 0 #153f2c14;--shadow-lifted:0 1px 2px #003f2d14, 0 22px 50px #003f2d24;--radius-sm:.375rem;--radius-md:.5rem;--radius-lg:.625rem;--radius-pill:999px;--duration-fast:.14s;--duration-medium:.22s;--ease-smooth:cubic-bezier(.2, .8, .2, 1);color:var(--color-text);background:var(--color-background);font-family:Proxima Nova,ProximaNova,proxima-nova,Avenir Next,Avenir,Helvetica Neue,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5}@media (prefers-color-scheme:dark){:root:not([data-theme]){--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--color-background:#0e1511;--color-surface:#151f19;--color-surface-muted:#1f2b23;--color-surface-strong:#111a15;--color-text:#edf5ed;--color-text-muted:#b0beb4;--color-border:#2d3b32;--color-border-strong:#45574a;--color-drawer:#07120d;--color-drawer-surface:#10251a;--color-drawer-text:#f3f8ef;--color-drawer-muted:#a7b8a8;--color-drawer-border:#294634;--color-brand-mark:#0fbd2d;--color-primary:#86d98f;--color-primary-text:#0b130e;--color-primary-hover:#a1e2a9;--color-primary-soft:#223b29;--color-accent:#58d86b;--color-accent-warm:#f0c264;--color-success:#62c96f;--color-warning:#f2b84b;--color-danger:#ff8a80;--color-focus:#7fd28a;--color-link:#91d99a;--shadow-soft:0 1px 2px #00000047, 0 12px 30px #0000004d;--shadow-lifted:0 1px 2px #00000052, 0 22px 48px #00000061}}:root[data-theme=dark]{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--color-background:#0e1511;--color-surface:#151f19;--color-surface-muted:#1f2b23;--color-surface-strong:#111a15;--color-text:#edf5ed;--color-text-muted:#b0beb4;--color-border:#2d3b32;--color-border-strong:#45574a;--color-drawer:#07120d;--color-drawer-surface:#10251a;--color-drawer-text:#f3f8ef;--color-drawer-muted:#a7b8a8;--color-drawer-border:#294634;--color-brand-mark:#0fbd2d;--color-primary:#86d98f;--color-primary-text:#0b130e;--color-primary-hover:#a1e2a9;--color-primary-soft:#223b29;--color-accent:#58d86b;--color-accent-warm:#f0c264;--color-success:#62c96f;--color-warning:#f2b84b;--color-danger:#ff8a80;--color-focus:#7fd28a;--color-link:#91d99a;--shadow-soft:0 1px 2px #00000047, 0 12px 30px #0000004d;--shadow-lifted:0 1px 2px #00000052, 0 22px 48px #00000061}:root[data-theme=light]{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light}*{box-sizing:border-box}body{background:linear-gradient(145deg, color-mix(in srgb, var(--color-accent-warm), transparent 94%), transparent 22rem), linear-gradient(180deg, var(--color-surface-strong), var(--color-background) 18rem), var(--color-background);flex-direction:column;min-height:100vh;margin:0;display:flex}main{width:100%;max-width:82rem;margin:0 auto;padding:2rem}h1{color:var(--color-text);font-size:3.1rem;font-weight:var(--font-weight-semibold);letter-spacing:0;margin-top:0;line-height:1}h2,h3,strong,b{font-weight:var(--font-weight-semibold)}a{color:var(--color-link)}button{cursor:pointer;border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text);border-radius:var(--radius-md);font:inherit;font-weight:var(--font-weight-semibold);box-shadow:var(--shadow-crisp);transition:background var(--duration-fast) var(--ease-smooth), border-color var(--duration-fast) var(--ease-smooth), box-shadow var(--duration-fast) var(--ease-smooth), color var(--duration-fast) var(--ease-smooth), transform var(--duration-fast) var(--ease-smooth);padding:.5rem 1rem}button:hover{background:var(--color-surface-muted);transform:translateY(-1px)}button:active{transform:translateY(0)}button:disabled{cursor:not-allowed;opacity:.55}button:disabled:hover{transform:none}button.primary{background:var(--color-primary);color:var(--color-primary-text);border-color:var(--color-primary);box-shadow:0 10px 22px color-mix(in srgb, var(--color-primary), transparent 78%)}button.primary:hover{background:var(--color-primary-hover);box-shadow:0 14px 30px color-mix(in srgb, var(--color-primary), transparent 74%)}button.success{color:var(--color-primary-text);background:var(--color-success);border-color:var(--color-success)}button.success:hover{background:color-mix(in srgb, var(--color-success), #000 12%)}button.danger{color:#fff;background:var(--color-danger);border-color:var(--color-danger)}button.danger:hover{background:color-mix(in srgb, var(--color-danger), #000 12%)}input,select,textarea{font:inherit;color:var(--color-text);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:background var(--duration-fast) var(--ease-smooth), border-color var(--duration-fast) var(--ease-smooth), box-shadow var(--duration-fast) var(--ease-smooth);padding:.625rem .75rem;box-shadow:inset 0 1px #ffffff6b}input[type=file]{padding:.45rem}input[type=file]::file-selector-button{color:var(--color-text);background:var(--color-surface-muted);border:1px solid var(--color-border);border-radius:var(--radius-sm);font:inherit;margin-right:.75rem;padding:.45rem .7rem;font-weight:600}input:focus-visible,select:focus-visible,textarea:focus-visible,button:focus-visible,a:focus-visible{outline:3px solid color-mix(in srgb, var(--color-focus), transparent 55%);outline-offset:2px}input:focus-visible,select:focus-visible,textarea:focus-visible{border-color:color-mix(in srgb, var(--color-focus), var(--color-border) 35%);box-shadow:0 0 0 4px color-mix(in srgb, var(--color-focus), transparent 84%)}code,pre{background:var(--color-surface-muted);border-radius:.25rem;padding:.1rem .3rem;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace}pre{padding:.75rem 1rem;overflow-x:auto}.app-shell{min-height:100vh;transition:grid-template-columns var(--duration-medium) var(--ease-smooth);grid-template-columns:17.5rem minmax(0,1fr);display:grid}.app-shell.drawer-collapsed{grid-template-columns:5.25rem minmax(0,1fr)}.app-drawer{z-index:10;height:100vh;color:var(--color-drawer-text);background:linear-gradient(180deg, color-mix(in srgb, var(--color-drawer-surface), #fff 3%), var(--color-drawer) 16rem), var(--color-drawer);border-right:1px solid var(--color-drawer-border);flex-direction:column;align-self:start;gap:1.5rem;padding:1rem .875rem;display:flex;position:sticky;top:0;overflow-y:auto;box-shadow:16px 0 46px #08221929}.drawer-header{grid-template-columns:minmax(0,1fr) auto auto;align-items:center;gap:.5rem;min-width:0;display:grid}.brand-link{min-width:0;color:var(--color-drawer-text);align-items:center;gap:.65rem;font-size:1.15rem;font-weight:600;text-decoration:none;display:inline-flex}.brand-name{text-overflow:ellipsis;overflow:hidden}.brand-mark{border:1px solid color-mix(in srgb, var(--color-drawer-border), #fff 18%);border-radius:var(--radius-lg);background:#fff;width:2.35rem;height:2.35rem;padding:.3rem;display:block;box-shadow:inset 0 -1px #003f2d1f,0 10px 24px #0000002e}.drawer-utility-links{align-items:center;gap:.25rem;display:flex}.drawer-icon-link{width:2.25rem;height:2.25rem;color:var(--color-drawer-muted);border-radius:var(--radius-lg);transition:background var(--duration-fast) var(--ease-smooth), border-color var(--duration-fast) var(--ease-smooth), color var(--duration-fast) var(--ease-smooth), transform var(--duration-fast) var(--ease-smooth);background:0 0;border:1px solid #0000;place-items:center;font-size:1.2rem;line-height:1;text-decoration:none;display:grid}.drawer-icon-link.account-icon span{clip-path:polygon(50% 0,72% 8%,82% 27%,72% 44%,62% 50%,84% 62%,100% 100%,0 100%,16% 62%,38% 50%,28% 44%,18% 27%,28% 8%);background:radial-gradient(circle at 50% 22%,currentColor 0 .28rem,#0000 .29rem),radial-gradient(at 50% 100%,currentColor 0 .58rem,#0000 .59rem);width:1.1rem;height:1.15rem;display:block}.drawer-icon-link:hover,.drawer-icon-link.active{color:var(--color-drawer-text);background:color-mix(in srgb, var(--color-drawer-surface), #fff 6%);border-color:var(--color-drawer-border);transform:translateY(-1px)}.drawer-toggle{width:2rem;height:2rem;color:var(--color-drawer-text);background:var(--color-drawer-surface);border-color:var(--color-drawer-border);flex:none;place-items:center;padding:0;font-size:1.15rem;line-height:1;display:grid}.app-nav{align-items:stretch;gap:.625rem;min-width:0;display:grid}.nav-section{gap:.35rem;display:grid}.nav-section-toggle{text-align:left;width:100%;min-height:2.75rem;box-shadow:none;transition:background var(--duration-fast) var(--ease-smooth), color var(--duration-fast) var(--ease-smooth);background:0 0;border-color:#0000;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:.5rem;padding:.45rem .625rem;display:grid}.nav-section-toggle:hover{background:color-mix(in srgb, var(--color-drawer-surface), transparent 35%);transform:none}.nav-section-toggle[aria-expanded=false] .nav-section-caret{transform:rotate(-90deg)}.nav-section-text{gap:.1rem;min-width:0;display:grid}.nav-section-title{color:var(--color-drawer-text);letter-spacing:0;text-transform:uppercase;margin:0;font-size:.78rem;font-weight:600}.nav-section-description{color:var(--color-drawer-muted);text-overflow:ellipsis;white-space:nowrap;font-size:.76rem;overflow:hidden}.nav-section-caret{color:var(--color-drawer-muted);transition:transform .14s}.nav-section-items{gap:.25rem;display:grid}.nav-section-compact-items{display:none}.nav-link-standalone{margin-block:.125rem}.nav-link.nav-link-overview{min-height:2.75rem;color:var(--color-drawer-text);letter-spacing:0;text-transform:uppercase;font-size:.78rem;font-weight:600}.nav-link{color:var(--color-drawer-muted);border-radius:var(--radius-lg);transition:background var(--duration-fast) var(--ease-smooth), border-color var(--duration-fast) var(--ease-smooth), box-shadow var(--duration-fast) var(--ease-smooth), color var(--duration-fast) var(--ease-smooth), transform var(--duration-fast) var(--ease-smooth);border:1px solid #0000;align-items:center;padding:.62rem .75rem;font-size:.95rem;font-weight:600;line-height:1.2;text-decoration:none;display:flex}.nav-link-label{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.nav-link:hover{color:var(--color-drawer-text);background:color-mix(in srgb, var(--color-drawer-surface), transparent 20%);transform:translate(2px)}.nav-link.active{color:var(--color-drawer-text);background:color-mix(in srgb, var(--color-drawer-surface), #fff 7%);border-color:color-mix(in srgb, var(--color-drawer-border), #fff 18%);box-shadow:inset 3px 0 0 var(--color-accent), 0 10px 22px #00000014}.nav-link.urgent{color:var(--color-drawer-text);border-color:color-mix(in srgb, var(--color-accent), transparent 54%);background:color-mix(in srgb, var(--color-accent), transparent 88%)}.nav-link.urgent.active,.nav-link.urgent:hover{color:var(--color-drawer-text);background:color-mix(in srgb, var(--color-accent), var(--color-drawer-surface) 82%);border-color:color-mix(in srgb, var(--color-accent), transparent 36%)}.drawer-collapsed .app-drawer{align-items:stretch;padding-inline:.75rem}.drawer-collapsed .brand-link{justify-content:center}.drawer-collapsed .brand-name,.drawer-collapsed .drawer-utility-links,.drawer-collapsed .app-nav{display:none}.drawer-collapsed .drawer-header{grid-template-columns:1fr;justify-items:center}.drawer-collapsed .drawer-toggle{width:2rem}.app-actions{border-top:1px solid var(--color-drawer-border);flex-wrap:wrap;align-items:center;gap:.625rem;min-width:0;margin-top:auto;padding-top:1rem;display:flex}.app-actions>div{flex-wrap:wrap;min-width:0}.app-actions select{max-width:12rem;color:var(--color-drawer-text);background:var(--color-drawer-surface);border-color:var(--color-drawer-border)}.app-actions label{color:var(--color-drawer-muted)}.app-actions .button-link,.app-actions button{color:var(--color-drawer-text);background:var(--color-drawer-surface);border-color:var(--color-drawer-border)}.app-actions .button-link:hover,.app-actions button:hover{background:color-mix(in srgb, var(--color-drawer-surface), #fff 8%)}.theme-toggle{min-width:6.5rem;padding-inline:.75rem}.app-content{min-width:0;padding:1.5rem}.auth-page{background:linear-gradient(135deg, color-mix(in srgb, var(--color-accent), transparent 92%), transparent 24rem), linear-gradient(180deg, var(--color-surface-strong), var(--color-background));align-items:center;width:100%;max-width:none;min-height:100vh;padding:2rem;display:grid}.auth-shell{grid-template-columns:minmax(0,1.05fr) minmax(23rem,28rem);align-items:stretch;gap:1rem;width:min(100%,68rem);margin:0 auto;display:grid}.auth-brand-card,.auth-panel{border:1px solid var(--color-border-strong);border-radius:var(--radius-lg);box-shadow:var(--shadow-lifted)}.auth-brand-card{min-height:37rem;color:var(--color-drawer-text);background:linear-gradient(150deg, color-mix(in srgb, var(--color-accent), transparent 74%), transparent 28rem), linear-gradient(180deg, #073223, #061811);place-items:center;padding:3rem;display:grid;position:relative;overflow:hidden}.auth-brand-card:before{content:"";border-radius:var(--radius-lg);pointer-events:none;border:1px solid #ffffff14;position:absolute;inset:1rem}.auth-brand-lockup{z-index:1;justify-items:start;gap:1.35rem;width:min(100%,27rem);display:grid;position:relative}.auth-brand-wordmark{border-radius:var(--radius-lg);background:#fff;width:min(15rem,72%);height:auto;padding:.85rem 1rem;display:block;box-shadow:0 18px 44px #0003}.auth-brand-lockup p{color:#f7fbf3db;max-width:24rem;margin:0;font-size:clamp(1.35rem,2.2vw,2rem);font-weight:600;line-height:1.16}.auth-panel{background:var(--color-surface);align-content:center;gap:1.25rem;min-height:37rem;padding:2.25rem;display:grid}.auth-panel-header{gap:.5rem;display:grid}.auth-panel-mark{border:1px solid var(--color-border);border-radius:var(--radius-lg);width:3rem;height:3rem;box-shadow:var(--shadow-crisp);background:#fff;padding:.35rem}.auth-eyebrow{color:var(--color-primary);letter-spacing:.08em;text-transform:uppercase;font-size:.78rem;font-weight:600}.auth-panel h1{margin:0;font-size:2.45rem}.auth-panel p{color:var(--color-text-muted);margin:0}.auth-form{gap:.625rem;margin-top:.25rem;display:flex}.auth-form input{min-height:3rem}.auth-form-stack{gap:.95rem;display:grid}.auth-form-stack label{color:var(--color-text-muted);gap:.4rem;font-size:.9rem;font-weight:600;display:grid}.auth-form-stack button{width:100%;min-height:3rem;margin-top:.25rem}.auth-actions{flex-wrap:wrap;justify-content:center;gap:.75rem;margin-top:.1rem;display:flex}.auth-actions button{color:var(--color-primary);cursor:pointer;font:inherit;box-shadow:none;background:0 0;border:0;padding:.25rem .125rem;font-weight:600}.auth-actions button:hover{color:var(--color-primary-hover);background:0 0;transform:none}.form-error,.form-notice{border-radius:var(--radius-md);margin:0;padding:.7rem .8rem;font-size:.92rem}.form-error{color:var(--color-danger);background:color-mix(in srgb, var(--color-danger), transparent 91%);border:1px solid color-mix(in srgb, var(--color-danger), transparent 62%)}.form-notice{color:var(--color-text-muted);background:var(--color-surface-muted);border:1px solid var(--color-border)}@media (prefers-reduced-motion:no-preference){@keyframes surface-enter{0%{opacity:0;transform:translateY(.5rem)}to{opacity:1;transform:translateY(0)}}.auth-brand-card,.auth-panel{animation:surface-enter var(--duration-medium) var(--ease-smooth) both}.auth-panel{animation-delay:55ms}}.button-link{min-height:2.5rem;color:var(--color-text);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-crisp);transition:background var(--duration-fast) var(--ease-smooth), border-color var(--duration-fast) var(--ease-smooth), box-shadow var(--duration-fast) var(--ease-smooth), color var(--duration-fast) var(--ease-smooth), transform var(--duration-fast) var(--ease-smooth);justify-content:center;align-items:center;padding:.5rem 1rem;font-weight:600;text-decoration:none;display:inline-flex}.button-link:hover{background:var(--color-surface-muted);transform:translateY(-1px)}.button-link.primary{color:var(--color-primary-text);background:var(--color-primary);border-color:var(--color-primary)}.page-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:flex-start;gap:1.5rem;margin-bottom:1.5rem;padding:.25rem 0 1.25rem;display:flex}.page-header h1{margin-bottom:.25rem}.page-header p{max-width:44rem;color:var(--color-text-muted);margin:0;font-size:1rem}.page-header-actions{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.page-actions{flex-wrap:wrap;justify-content:flex-end;gap:.5rem;display:flex}.section-stack{gap:.75rem;display:grid}.section-stack>h2,.section-stack>h3{margin:0}.section-grid{grid-template-columns:repeat(auto-fit,minmax(16rem,1fr));gap:1rem;display:grid}.project-board{grid-template-columns:repeat(auto-fit,minmax(18rem,1fr))}.utility-chart-grid{grid-template-columns:repeat(auto-fit,minmax(19rem,1fr))}.outdoor-zone-grid{grid-template-columns:repeat(auto-fit,minmax(18rem,1fr))}.metric-strip{grid-template-columns:repeat(auto-fit,minmax(14rem,1fr));gap:.875rem;display:grid}.metric-card{background:var(--color-surface);border:1px solid var(--color-border-strong);border-radius:var(--radius-lg);box-shadow:var(--shadow-crisp);transition:border-color var(--duration-fast) var(--ease-smooth), box-shadow var(--duration-fast) var(--ease-smooth), transform var(--duration-fast) var(--ease-smooth);gap:.25rem;padding:1rem 1.125rem;display:grid}.metric-card:hover{border-color:color-mix(in srgb, var(--color-primary), var(--color-border) 64%);box-shadow:var(--shadow-soft);transform:translateY(-1px)}.metric-card span{color:var(--color-text-muted);letter-spacing:0;text-transform:uppercase;font-size:.82rem;font-weight:600}.metric-card strong{color:var(--color-text);font-size:1.6rem;line-height:1.1}.alert{border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-surface);box-shadow:var(--shadow-crisp);padding:.75rem 1rem}.alert.danger{color:var(--color-danger);border-color:color-mix(in srgb, var(--color-danger), var(--color-border) 55%)}.alert.success{color:var(--color-success);border-color:color-mix(in srgb, var(--color-success), var(--color-border) 55%)}.home-page{gap:1.25rem;display:grid}.summary-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:.875rem;display:grid}.summary-card{min-height:6.75rem;color:var(--color-text);background:var(--color-surface);border:1px solid var(--color-border-strong);border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);transition:background var(--duration-fast) var(--ease-smooth), border-color var(--duration-fast) var(--ease-smooth), box-shadow var(--duration-fast) var(--ease-smooth), transform var(--duration-fast) var(--ease-smooth);gap:.25rem;padding:1rem;text-decoration:none;display:grid;position:relative;overflow:hidden}.summary-card:before{content:"";background:var(--color-primary);height:.22rem;position:absolute;inset:0}.summary-card:first-child:before{background:var(--color-accent-warm)}.summary-card:nth-child(2):before{background:var(--color-accent)}.summary-card:nth-child(3):before{background:#2f9fb0}.summary-card:hover{background:var(--color-surface-strong);border-color:color-mix(in srgb, var(--color-primary), var(--color-border) 55%);box-shadow:var(--shadow-lifted);transform:translateY(-2px)}.summary-card span{color:var(--color-text-muted);font-size:.875rem}.summary-card strong{color:var(--color-primary);align-self:end;font-size:2.25rem;line-height:1}.dashboard-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem;display:grid}.dashboard-panel{min-height:13rem;color:var(--color-text);background:var(--color-surface);border:1px solid var(--color-border-strong);border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);transition:background var(--duration-fast) var(--ease-smooth), border-color var(--duration-fast) var(--ease-smooth), box-shadow var(--duration-fast) var(--ease-smooth), transform var(--duration-fast) var(--ease-smooth);align-content:start;gap:.75rem;padding:1.125rem;text-decoration:none;display:grid;position:relative;overflow:hidden}.dashboard-panel:after{content:"";border-radius:var(--radius-pill) var(--radius-pill) 0 0;background:color-mix(in srgb, var(--color-primary), transparent 75%);opacity:0;height:.2rem;transition:opacity var(--duration-fast) var(--ease-smooth), transform var(--duration-fast) var(--ease-smooth);position:absolute;inset:auto 1rem 0;transform:translateY(.2rem)}.dashboard-panel:hover{background:var(--color-surface-strong);border-color:color-mix(in srgb, var(--color-primary), var(--color-border) 55%);box-shadow:var(--shadow-lifted);transform:translateY(-2px)}.dashboard-panel:hover:after{opacity:1;transform:translateY(0)}.dashboard-panel-header{justify-content:space-between;align-items:baseline;gap:1rem;display:flex}.dashboard-panel-header h2{margin:0;font-size:1.05rem}.dashboard-list{gap:.625rem;display:grid}.dashboard-row{justify-content:space-between;align-items:center;gap:.75rem;padding-block:.125rem;display:flex}.dashboard-row div{min-width:0;display:grid}.dashboard-row strong,.dashboard-row span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.dashboard-row>div>span{color:var(--color-text-muted);font-size:.875rem}.status-dot{border-radius:var(--radius-pill);background:var(--color-border);flex:none;width:.625rem;height:.625rem}.status-dot.danger{background:var(--color-danger)}.status-dot.success{background:var(--color-success)}.status-dot.warning{background:var(--color-warning)}.empty-dashboard-state{color:var(--color-text-muted);margin:0}.quick-links-panel{min-height:auto}.quick-link-list{gap:.5rem;display:grid}.quick-link-list a{min-height:2.5rem;color:var(--color-text);background:var(--color-surface-muted);border-radius:var(--radius-lg);transition:background var(--duration-fast) var(--ease-smooth), border-color var(--duration-fast) var(--ease-smooth), color var(--duration-fast) var(--ease-smooth), transform var(--duration-fast) var(--ease-smooth);border:1px solid #0000;align-items:center;padding-inline:.75rem;font-weight:600;text-decoration:none;display:flex}.quick-link-list a:hover{color:var(--color-primary);border-color:var(--color-border);background:var(--color-surface);transform:translate(2px)}.settings-page{gap:1rem;display:grid}.utility-summary-grid{grid-template-columns:repeat(auto-fit,minmax(12rem,1fr));gap:1rem;margin-bottom:1rem;display:grid}.utility-summary-card{color:var(--color-text);background:var(--color-surface);border:1px solid var(--color-border-strong);border-radius:var(--radius-lg);box-shadow:var(--shadow-crisp);transition:border-color var(--duration-fast) var(--ease-smooth), box-shadow var(--duration-fast) var(--ease-smooth), transform var(--duration-fast) var(--ease-smooth);gap:.5rem;padding:.875rem;display:grid}.utility-summary-card:hover{border-color:color-mix(in srgb, var(--color-primary), var(--color-border) 62%);box-shadow:var(--shadow-soft);transform:translateY(-1px)}.utility-summary-card h3{margin-top:0}.utility-summary-card p{margin:0}.utility-empty-reading{color:var(--color-text-muted);margin:0}.utility-chart{margin:0}.utility-chart svg{width:100%;max-width:32.5rem;height:auto;color:var(--color-text-muted);background:var(--color-surface);border:1px solid var(--color-border-strong);border-radius:var(--radius-lg);box-shadow:var(--shadow-crisp);display:block}.utility-chart-axis{stroke:var(--color-border-strong)}.utility-chart-line{stroke:var(--color-text-muted)}.utility-chart-empty{color:var(--color-text-muted);margin:0}.account-page{gap:1rem;display:grid}.account-controls{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.account-controls>div{flex-wrap:wrap}.account-facts{grid-template-columns:1fr}.settings-section{background:var(--color-surface);border:1px solid var(--color-border-strong);border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);grid-template-columns:minmax(0,1fr) minmax(18rem,24rem);align-items:start;gap:1rem;padding:1.125rem;display:grid}.settings-section h2{margin:0 0 .25rem;font-size:1rem}.settings-section p{color:var(--color-text-muted);margin:0}.segmented-field{border:0;gap:.5rem;min-width:0;margin:0;padding:0;display:grid}.segmented-field legend{color:var(--color-text-muted);padding:0;font-size:.875rem;font-weight:600}.segmented-control{background:var(--color-surface-muted);border:1px solid var(--color-border);border-radius:var(--radius-lg);grid-template-columns:repeat(3,minmax(0,1fr));gap:.25rem;padding:.25rem;display:grid}.segmented-option{min-width:0}.segmented-option input{opacity:0;pointer-events:none;position:absolute}.segmented-option span{min-height:2.25rem;color:var(--color-text-muted);border-radius:var(--radius-md);place-items:center;padding-inline:.625rem;font-weight:600;display:grid}.segmented-option input:checked+span{color:var(--color-primary);background:var(--color-surface);box-shadow:var(--shadow-soft)}.segmented-option input:focus-visible+span{outline:3px solid color-mix(in srgb, var(--color-focus), transparent 55%);outline-offset:2px}.list-page{gap:1rem;display:grid}.search-panel{background:var(--color-surface);border:1px solid var(--color-border-strong);border-radius:var(--radius-lg);max-width:42rem;box-shadow:var(--shadow-soft);gap:.5rem;padding:1rem 1.125rem;display:grid}.search-panel label,.page-toolbar label{color:var(--color-text-muted);font-size:.875rem;font-weight:600}.search-panel input{min-height:2.75rem;font-size:1.05rem}.page-toolbar,.inline-form{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.page-toolbar{margin-top:-.25rem}.inline-form>input,.inline-form>select{min-width:10rem}.inline-form .input-narrow{width:5.75rem;min-width:5.75rem}.inline-form .input-medium{width:8rem;min-width:8rem}.inline-form .input-grow{flex:14rem;min-width:12rem}.form-actions{flex-wrap:wrap;gap:.5rem;display:flex}.inline-check{color:var(--color-text-muted);align-items:center;gap:.45rem;font-size:.9rem;font-weight:600;display:inline-flex}.inline-check input{width:1rem;height:1rem}.data-table-wrap{overflow-x:auto}.data-table{border-spacing:0;border-collapse:separate;background:var(--color-surface);border:1px solid var(--color-border-strong);border-radius:var(--radius-lg);width:100%;box-shadow:var(--shadow-crisp);overflow:hidden}.data-table th,.data-table td{text-align:left;border-bottom:1px solid var(--color-border);padding:.7rem .875rem}.data-table th{color:var(--color-text-muted);background:var(--color-surface-muted);letter-spacing:0;text-transform:uppercase;font-size:.8rem;font-weight:600}.data-table tr:last-child td{border-bottom:0}.record-list{gap:.75rem;margin:0;padding:0;list-style:none;display:grid}.record-row{background:var(--color-surface);border:1px solid var(--color-border-strong);border-radius:var(--radius-lg);min-height:4.75rem;box-shadow:var(--shadow-crisp);transition:background var(--duration-fast) var(--ease-smooth), border-color var(--duration-fast) var(--ease-smooth), box-shadow var(--duration-fast) var(--ease-smooth), transform var(--duration-fast) var(--ease-smooth);justify-content:space-between;align-items:center;gap:1rem;padding:1rem 1.125rem;display:flex}.record-row:hover{border-color:color-mix(in srgb, var(--color-primary), var(--color-border) 64%);background:var(--color-surface-strong);box-shadow:var(--shadow-soft);transform:translateY(-1px)}.record-row.compact{min-height:0;padding:.75rem .875rem}.record-main{gap:.35rem;min-width:0;display:grid}.record-title{width:fit-content;color:var(--color-text);transition:color var(--duration-fast) var(--ease-smooth);font-weight:600;text-decoration:none}.record-title:hover{color:var(--color-primary)}.record-meta{flex-wrap:wrap;gap:.375rem;display:flex}.meta-chip{min-height:1.625rem;color:var(--color-text-muted);background:color-mix(in srgb, var(--color-surface-muted), var(--color-surface) 30%);border:1px solid color-mix(in srgb, var(--color-border), transparent 20%);border-radius:var(--radius-pill);align-items:center;padding:.15rem .55rem;font-size:.825rem;line-height:1.1;text-decoration:none;display:inline-flex;box-shadow:inset 0 1px #ffffff5c}.meta-chip.overdue,.meta-chip.expired{color:var(--color-danger);background:color-mix(in srgb, var(--color-danger), transparent 88%);border-color:color-mix(in srgb, var(--color-danger), transparent 55%)}.meta-chip.due,.meta-chip.due.soon,.meta-chip.expiring{color:var(--color-warning);background:color-mix(in srgb, var(--color-warning), transparent 88%);border-color:color-mix(in srgb, var(--color-warning), transparent 55%)}.meta-chip.active,.meta-chip.later,.meta-chip.completed{color:var(--color-success);background:color-mix(in srgb, var(--color-success), transparent 88%);border-color:color-mix(in srgb, var(--color-success), transparent 55%)}a.meta-chip:hover{color:var(--color-primary)}.record-actions{flex-wrap:wrap;flex:none;justify-content:flex-end;gap:.5rem;display:flex}.record-edit-form{flex:1}.record-notes,.empty-state{color:var(--color-text-muted);margin:0}.status-group-list{gap:1rem;display:grid}.status-group{gap:.625rem;display:grid}.status-group h2{color:var(--color-text-muted);letter-spacing:0;text-transform:uppercase;margin:0;font-size:.85rem}.section-heading{justify-content:space-between;align-items:center;gap:1rem;margin-top:2rem;margin-bottom:.75rem;display:flex}.section-heading:first-of-type{margin-top:0}.detail-section .section-heading,.field-card .section-heading,.task-library-heading{margin-block:0}.section-heading h2,.section-heading h3{margin:0}.section-heading p{color:var(--color-text-muted);margin:.25rem 0 0}.completed-panel{gap:.75rem;padding-top:.25rem;display:grid}.completed-panel summary{cursor:pointer;width:fit-content;color:var(--color-text-muted);font-weight:600}.completed-panel[open] summary{color:var(--color-text)}.field-page{gap:1rem;display:grid}.emergency-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:.875rem;display:grid}.field-card{background:var(--color-surface);border:1px solid var(--color-border-strong);border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);gap:.5rem;padding:1.125rem;display:grid}.field-card.priority{border-color:color-mix(in srgb, var(--color-primary), var(--color-border) 55%)}.field-card-wide{grid-column:1/-1}.field-card h2,.field-label{color:var(--color-text-muted);letter-spacing:0;text-transform:uppercase;margin:0;font-size:.85rem;font-weight:600}.field-card p{margin:0;font-size:1.35rem;font-weight:600}.field-card .section-heading p,.field-card .empty-state,.field-card .record-notes{font-size:.95rem;font-weight:500}.code-list{gap:.375rem;margin:0;padding:0;font-size:1.15rem;list-style:none;display:grid}.field-edit-form{max-width:36rem}.scanner-video{aspect-ratio:4/3;border:1px solid var(--color-border);border-radius:var(--radius-lg);background:#000;width:min(100%,34rem)}.breaker-slot{width:3rem;height:3rem;color:var(--color-primary);background:var(--color-primary-soft);border:1px solid var(--color-border);border-radius:var(--radius-lg);flex:none;place-items:center;font-weight:600;display:grid}.breaker-panel-card{align-content:start}.breaker-box-field{border:0;gap:.625rem;margin:0;padding:0;display:grid}.breaker-box-field legend{color:var(--color-text-muted);padding:0;font-size:.875rem;font-weight:600}.breaker-box{background:linear-gradient(90deg, transparent calc(50% - 1px), var(--color-border-strong) calc(50% - 1px), var(--color-border-strong) calc(50% + 1px), transparent calc(50% + 1px)), var(--color-surface-muted);border:1px solid var(--color-border-strong);border-radius:var(--radius-lg);grid-template-columns:repeat(2,minmax(0,1fr));gap:.35rem .5rem;padding:.875rem;display:grid}.breaker-box button{min-height:2.1rem;color:var(--color-text);background:var(--color-surface);border-color:var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-crisp);grid-template-columns:2rem minmax(0,1fr);place-items:center start;padding:.25rem .5rem;display:grid}.breaker-box button:nth-child(odd){border-top-right-radius:.25rem;border-bottom-right-radius:.25rem}.breaker-box button:nth-child(2n){border-top-left-radius:.25rem;border-bottom-left-radius:.25rem}.breaker-box button span{font-weight:600}.breaker-box button small{color:var(--color-text-muted);text-transform:uppercase;font-size:.7rem;font-weight:600}.breaker-box button.selected{color:var(--color-primary);background:var(--color-primary-soft);border-color:color-mix(in srgb, var(--color-primary), var(--color-border) 30%)}.breaker-box button:disabled{color:var(--color-text-muted);background:color-mix(in srgb, var(--color-surface-muted), var(--color-surface) 50%);opacity:.78}.detail-page{gap:1rem;display:grid}.back-link{width:fit-content;color:var(--color-text-muted);text-decoration:none}.back-link:hover{color:var(--color-primary)}.detail-header{justify-content:space-between;align-items:flex-start;gap:1rem;display:flex}.detail-header h1,.detail-header h2{margin-bottom:.25rem}.detail-header p{color:var(--color-text-muted);margin:0}.detail-section{background:var(--color-surface);border:1px solid var(--color-border-strong);border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);gap:.75rem;padding:1.125rem;display:grid}.detail-section h2{margin:0;font-size:1rem}.detail-section h3,.detail-section h4{margin:0}.room-record-section{position:relative;overflow:hidden}.room-record-section:before{content:"";background:var(--color-primary);width:.28rem;position:absolute;inset:0 auto 0 0}.room-record-section-fixtures:before{background:var(--color-warning)}.room-record-section-appliances:before{background:var(--color-success)}.room-record-list{gap:0;margin:0;padding:0;list-style:none;display:grid}.room-record-row{border-bottom:1px solid var(--color-border);padding:.75rem 0}.room-record-row:last-child{border-bottom:0}.plain-record-row{justify-content:space-between;align-items:center;gap:1rem;display:flex}.fact-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:.875rem;margin:0;display:grid}.fact-grid div{gap:.25rem;display:grid}.fact-grid dt{color:var(--color-text-muted);letter-spacing:0;text-transform:uppercase;font-size:.8rem;font-weight:600}.fact-grid dd{margin:0;font-size:1.05rem}.qr-output{overflow-wrap:anywhere;margin:0}.modal-backdrop{z-index:30;background:#0000006b;place-items:center;padding:1rem;display:grid;position:fixed;inset:0}.modal-panel{background:var(--color-surface);border:1px solid var(--color-border-strong);border-radius:var(--radius-lg);width:min(100%,42rem);max-height:min(42rem,100vh - 2rem);box-shadow:var(--shadow-soft);gap:1rem;padding:1.125rem;display:grid;overflow-y:auto}.modal-header{justify-content:space-between;align-items:flex-start;gap:1rem;display:flex}.modal-header h2{margin:0;font-size:1.15rem}.modal-form{gap:.75rem;display:grid}.modal-mode-switch{background:var(--color-surface-muted);border:1px solid var(--color-border);border-radius:var(--radius-lg);grid-template-columns:repeat(2,minmax(0,1fr));gap:.25rem;padding:.25rem;display:grid}.modal-mode-switch button{background:0 0;border-color:#0000}.modal-mode-switch button.active{color:var(--color-primary);background:var(--color-surface);border-color:var(--color-border);box-shadow:var(--shadow-soft)}.modal-form label{color:var(--color-text-muted);gap:.35rem;font-size:.875rem;font-weight:600;display:grid}.modal-actions{flex-wrap:wrap;justify-content:flex-end;gap:.5rem;margin-top:.25rem;display:flex}.confirm-message{color:var(--color-text-muted);margin:0}.task-library{gap:1rem;display:grid}.task-library-section{padding:1rem}.task-library-heading{align-items:flex-start}.library-start-date{max-width:14rem;color:var(--color-text-muted);gap:.35rem;font-size:.875rem;font-weight:600;display:grid}.library-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:.875rem;display:grid}.library-card{min-height:11rem;color:var(--color-text);text-align:left;background:var(--color-surface);border:1px solid var(--color-border-strong);border-radius:var(--radius-lg);box-shadow:var(--shadow-crisp);cursor:pointer;align-content:start;gap:.875rem;padding:1rem;display:grid}.library-card:hover,.library-card:focus-visible{border-color:var(--color-primary);box-shadow:var(--shadow-soft);transform:translateY(-1px)}.library-card h3{margin:0 0 .25rem}.library-card-heading{justify-content:space-between;align-items:flex-start;gap:.75rem;display:flex}.library-card p,.library-card dd{color:var(--color-text-muted);margin:0}.library-card-title{font-size:1rem;font-weight:600;line-height:1.2}.library-card-summary{color:var(--color-text-muted);line-height:1.45}.library-modal{gap:1rem;display:grid}.library-modal>p{color:var(--color-text-muted);margin:0}.library-notes{gap:.625rem;margin:0;display:grid}.library-notes div{gap:.15rem;display:grid}.library-notes dt{color:var(--color-text);font-weight:600}.library-task-list{gap:.45rem;margin:.375rem 0 0;padding-left:1.25rem;display:grid}.library-task-list li{padding-left:.125rem}.library-task-list span,.library-task-list small{display:block}.library-task-list small{color:var(--color-text-muted);margin-top:.1rem}.library-details{background:var(--color-surface-muted);border:1px solid var(--color-border);border-radius:var(--radius-md);gap:.75rem;padding:.75rem;display:grid}.library-details summary{cursor:pointer;width:fit-content;font-weight:600}.library-detail-list{gap:.75rem;margin-top:.75rem;display:grid}.library-task-detail{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);gap:.5rem;padding:.75rem;display:grid}.library-task-detail p,.library-detail-note{color:var(--color-text-muted);margin:0}.library-task-select{color:var(--color-text);align-items:flex-start;gap:.5rem;font-weight:600;display:flex}.library-task-select input{margin-top:.2rem}.library-steps{color:var(--color-text-muted);gap:.25rem;margin:0;padding-left:1.25rem;display:grid}.library-references{gap:.25rem;display:grid}.library-references a{overflow-wrap:anywhere;color:var(--color-primary);font-size:.9rem;font-weight:600;text-decoration:none}.library-references a:hover{text-decoration:underline}@media (width<=52rem){.library-grid{grid-template-columns:1fr}.auth-page{padding:1rem}.auth-shell{grid-template-columns:1fr;gap:.75rem}.auth-brand-card{min-height:auto;padding:1.25rem}.auth-brand-card:before{display:none}.auth-brand-lockup{text-align:center;justify-items:center;gap:.75rem}.auth-brand-wordmark{width:10rem;padding:.55rem .7rem}.auth-brand-lockup p{max-width:18rem;font-size:1rem}.auth-panel{min-height:auto;padding:1.5rem}.auth-panel h1{font-size:2rem}.app-shell,.app-shell.drawer-collapsed{grid-template-columns:1fr}.app-drawer,.drawer-collapsed .app-drawer{border-right:0;border-bottom:1px solid var(--color-border);align-items:stretch;height:auto;padding:1rem;position:static}.drawer-toggle{display:none}.drawer-collapsed .brand-link{justify-content:flex-start}.drawer-collapsed .drawer-header{grid-template-columns:minmax(0,1fr) auto;justify-items:stretch}.drawer-collapsed .brand-name{display:initial}.drawer-collapsed .drawer-utility-links{display:flex}.drawer-collapsed .app-nav{display:grid}.app-nav{grid-template-columns:repeat(2,minmax(0,1fr))}.nav-section{align-content:start}.app-content{padding:1rem}.auth-form,.page-header{flex-direction:column}h1{font-size:2.35rem;line-height:1}.detail-header{flex-direction:column}.page-actions{justify-content:flex-start}.summary-grid,.dashboard-grid,.emergency-grid,.fact-grid,.settings-section{grid-template-columns:1fr}.record-row{flex-direction:column;align-items:stretch}.record-actions{justify-content:flex-start}.inline-form>input,.inline-form>select{flex:12rem;min-width:0}}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}button:hover,.button-link:hover,.drawer-icon-link:hover,.nav-link:hover,.summary-card:hover,.dashboard-panel:hover,.quick-link-list a:hover,.utility-summary-card:hover,.metric-card:hover,.record-row:hover{transform:none}}
