@import"https://fonts.googleapis.com/css2?family=DM+Serif+Display:ital@0;1&family=DM+Sans:opsz,wght@9..40,300;9..40,400;9..40,500;9..40,600;9..40,700&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root,[data-theme=light]{--forest: #1a3a2a;--forest2: #2d5a3d;--leaf: #4a8c5c;--mint: #7fbf8e;--sage: #b8d4be;--cream: #f5f0e8;--warm: #ede8dc;--amber: #d4a853;--ember: #c05c2a;--sky: #4a90a4;--snow: #ffffff;--ink: #1a2419;--ink2: #3a4a3a;--muted: #7a8c7a;--border: rgba(26,58,42,.12);--shadow: 0 2px 12px rgba(26,58,42,.08);--shadow-lg:0 8px 32px rgba(26,58,42,.14);font-family:DM Sans,sans-serif;font-size:16px}[data-theme=dark]{--forest: #4a9e6a;--forest2: #5aaa78;--leaf: #6dbd85;--mint: #90d4a0;--sage: #4a6a52;--cream: #161e17;--warm: #1e2820;--amber: #e8bb5a;--ember: #e06830;--sky: #5ec4dc;--snow: #232f25;--ink: #e8f0e8;--ink2: #b8ccb8;--muted: #8ab09a;--border: rgba(90,170,112,.18);--shadow: 0 2px 12px rgba(0,0,0,.3);--shadow-lg:0 8px 32px rgba(0,0,0,.45)}[data-theme=dark] body{background:var(--cream);color:var(--ink)}body{background:var(--cream);color:var(--ink);min-height:100vh}.loading-screen{height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;background:linear-gradient(135deg,var(--forest),var(--forest2))}.loading-leaf{font-size:48px;animation:pulse 1.5s ease-in-out infinite}.loading-text{font-family:"DM Serif Display",serif;font-style:italic;font-size:18px;color:#ffffffb3}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.95)}}.app{display:flex;min-height:100vh}.sidebar{width:256px;flex-shrink:0;background:var(--forest);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100}.main-area{flex:1;margin-left:256px;display:flex;flex-direction:column;min-height:100vh;align-items:center}.page-content{padding:2rem;max-width:1080px;width:100%}.sidebar-logo{padding:1.75rem 1.5rem 1.25rem;border-bottom:1px solid rgba(255,255,255,.07)}.logo-icon{width:42px;height:42px;border-radius:11px;background:linear-gradient(135deg,var(--leaf),var(--forest2));border:1px solid rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center;margin-bottom:10px;font-size:20px;box-shadow:0 4px 14px #00000040}.logo-title{font-family:"DM Serif Display",serif;font-size:16px;color:#fff;line-height:1.2}.logo-sub{font-size:11px;color:#ffffff61;margin-top:3px}.logo-condo{font-size:12px;color:var(--mint);margin-top:6px;font-weight:600}.nav-section{padding:.875rem .75rem .5rem}.nav-label{font-size:10px;font-weight:600;color:#ffffff47;text-transform:uppercase;letter-spacing:.1em;padding:0 .75rem .4rem}.nav-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:9px;font-size:15px;color:#ffffff9e;cursor:pointer;border:none;background:none;width:100%;text-align:left;transition:all .13s;font-family:DM Sans,sans-serif;font-weight:500}.nav-item:hover{background:#ffffff12;color:#ffffffe6}.nav-item.active{background:#7fbf8e2e;color:var(--mint);font-weight:600}.nav-icon{width:18px;text-align:center;font-size:15px;flex-shrink:0}.nav-divider{height:1px;background:#ffffff0f;margin:.4rem 1.25rem}.sidebar-footer{margin-top:auto;padding:1rem 1.25rem;border-top:1px solid rgba(255,255,255,.07);display:flex;align-items:center;gap:10px}.avatar{width:32px;height:32px;border-radius:50%;background:#7fbf8e33;border:1px solid rgba(127,191,142,.3);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:var(--mint);flex-shrink:0}.avatar-name{font-size:13px;color:#ffffffd1;font-weight:500}.avatar-role{font-size:11px;color:#ffffff52}.logout-btn{margin-left:auto;background:none;border:none;color:#ffffff47;cursor:pointer;font-size:18px;padding:2px 4px;border-radius:5px;transition:color .13s;line-height:1}.logout-btn:hover{color:#ffffffb3}.topbar{background:var(--snow);border-bottom:1px solid var(--border);padding:0 2rem;height:60px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:50;box-shadow:0 1px 0 var(--border);flex-shrink:0;width:100%;align-self:stretch}.topbar-title{font-family:"DM Serif Display",serif;font-size:20px;color:var(--ink)}.topbar-left{display:flex;align-items:center;gap:12px}.btn{font-size:14px;padding:9px 18px;border-radius:9px;border:1.5px solid var(--border);background:var(--snow);color:var(--ink2);cursor:pointer;font-weight:500;transition:all .13s;font-family:DM Sans,sans-serif;box-shadow:0 1px 3px #0000000d}.btn:hover{background:var(--warm);border-color:var(--sage)}.btn-primary{background:var(--forest);color:#fff;border-color:var(--forest);font-weight:600;box-shadow:0 2px 8px #1a3a2a38}.btn-primary:hover{background:var(--forest2)}.btn-danger{background:#c0392b;color:#fff;border-color:#c0392b}.btn-danger:hover{background:#a93226}.btn-sm{font-size:12px;padding:5px 12px;border-radius:7px}.btn:disabled{opacity:.5;cursor:not-allowed}.card{background:var(--snow);border-radius:14px;padding:1.5rem;border:1px solid var(--border);box-shadow:var(--shadow);margin-bottom:1rem;overflow:hidden}.card-title{font-family:"DM Serif Display",serif;font-size:17px;color:var(--ink);margin-bottom:1.25rem}.stat-grid{display:grid;gap:1rem;margin-bottom:1rem}.stat-grid-5{grid-template-columns:repeat(5,1fr)}.stat-grid-4{grid-template-columns:repeat(4,1fr)}.stat-grid-3{grid-template-columns:repeat(3,1fr)}.stat-grid-2{grid-template-columns:repeat(2,1fr)}.stat-card{background:var(--snow);border-radius:14px;padding:1.25rem 1.5rem;border:1px solid var(--border);box-shadow:var(--shadow);position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;border-radius:14px 14px 0 0}.stat-card.c-forest:before{background:var(--forest)}.stat-card.c-leaf:before{background:var(--leaf)}.stat-card.c-amber:before{background:var(--amber)}.stat-card.c-sky:before{background:var(--sky)}.stat-card.c-ember:before{background:var(--ember)}.stat-card.c-mint:before{background:var(--mint)}.stat-label{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:7px}.stat-value{font-family:"DM Serif Display",serif;font-size:26px;color:var(--ink);line-height:1.1}.stat-sub{font-size:12px;color:var(--muted);margin-top:4px}.stat-from{font-size:11px;color:var(--mint);margin-top:5px;font-weight:500}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:14px}thead th{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);padding:9px 12px;text-align:left;border-bottom:1px solid var(--border)}tbody tr{border-bottom:1px solid rgba(26,58,42,.05);transition:background .1s}tbody tr:last-child{border-bottom:none}tbody tr:hover{background:#1a3a2a06}td{padding:10px 12px;color:var(--ink2)}.td-num{text-align:right;font-variant-numeric:tabular-nums}.td-bold{font-weight:700;color:var(--forest)}.form-group{display:flex;flex-direction:column;gap:5px;margin-bottom:1rem}.form-group label{font-size:12px;font-weight:600;color:var(--ink2);letter-spacing:.02em}.form-group input,.form-group select,.form-group textarea{padding:10px 12px;border-radius:9px;border:1.5px solid var(--border);background:var(--snow);font-size:14px;color:var(--ink);font-family:DM Sans,sans-serif;transition:border-color .14s,box-shadow .14s;outline:none}.form-group input:focus,.form-group select:focus{border-color:var(--leaf);box-shadow:0 0 0 3px #4a8c5c1a}.form-group input:disabled{opacity:.55;background:var(--warm)}.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.section-sep{border:none;border-top:1px solid var(--border);margin:1.25rem 0}.form-hint{font-size:11px;color:var(--muted)}.form-hint.err{color:#c0392b}.notice{padding:11px 15px;border-radius:10px;font-size:14px;margin-bottom:1rem;line-height:1.5}.notice-green{background:#4a8c5c1a;border-left:3px solid var(--leaf);color:var(--forest2)}.notice-amber{background:#d4a8531a;border-left:3px solid var(--amber);color:#7a5010}.notice-blue{background:#4a90a41a;border-left:3px solid var(--sky);color:#1a4a58}.notice-red{background:#c0392b1a;border-left:3px solid #c0392b;color:#7a1a0a}.error-msg{font-size:13px;color:#c0392b;background:#c0392b12;padding:10px 14px;border-radius:8px;margin-bottom:.75rem;border-left:3px solid #c0392b}.badge{font-size:11px;padding:3px 9px;border-radius:20px;font-weight:600;display:inline-block}.badge-green{background:#4a8c5c21;color:var(--forest2)}.badge-amber{background:#d4a85326;color:#6a4a05}.badge-blue{background:#4a90a421;color:#1a4a58}.badge-red{background:#c0392b1a;color:#7a1a0a}.bim-pill{font-size:12px;padding:3px 10px;border-radius:20px;font-weight:600}.bim-cold{background:#4a90a421;color:#1a4a58}.bim-warm{background:#d4a8531f;color:#7a5010}.bar-wrap{margin-bottom:1rem}.bar-label-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px;font-size:14px}.bar-track{height:7px;background:var(--warm);border-radius:4px;overflow:hidden}.bar-fill{height:100%;border-radius:4px;transition:width .7s cubic-bezier(.4,0,.2,1)}.kwh-chips{display:flex;gap:6px;margin-top:5px}.kwh-chip{font-size:11px;padding:2px 8px;border-radius:12px;font-weight:500}.chip-forest{background:#1a3a2a14;color:var(--forest)}.chip-sky{background:#4a90a41a;color:#1a4a58}.two-col{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.reading-card{background:var(--snow);border:1px solid var(--border);border-radius:14px;padding:1.25rem 1.5rem;margin-bottom:.75rem;box-shadow:var(--shadow)}.reading-card-header{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:.5rem;margin-bottom:.75rem}.reading-card-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.anno-tabs{display:flex;gap:6px;margin-bottom:1.5rem;flex-wrap:wrap}.anno-tab{padding:7px 16px;border-radius:8px;border:1.5px solid var(--border);background:var(--snow);font-size:14px;color:var(--ink2);cursor:pointer;font-family:DM Sans,sans-serif;font-weight:500;transition:all .13s}.anno-tab:hover{border-color:var(--sage);background:var(--warm)}.anno-tab.active{background:var(--forest);color:#fff;border-color:var(--forest);font-weight:600}.filter-row{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:1rem;align-items:center}.filter-chip{padding:5px 14px;border-radius:20px;border:1px solid var(--border);background:var(--snow);font-size:13px;color:var(--ink2);cursor:pointer;font-family:DM Sans,sans-serif;font-weight:500;transition:all .13s}.filter-chip:hover{border-color:var(--sage)}.filter-chip.af{background:var(--forest);color:#fff;border-color:var(--forest)}.filter-chip.as{background:var(--sky);color:#fff;border-color:var(--sky)}.filter-chip.al{background:var(--leaf);color:#fff;border-color:var(--leaf)}.filter-sep{width:1px;height:20px;background:var(--border);margin:0 4px}.trend-row{display:flex;align-items:center;gap:14px;margin-bottom:14px}.trend-anno{font-weight:700;font-size:15px;min-width:44px;color:var(--forest)}.trend-bar-wrap{flex:1;height:8px;background:var(--warm);border-radius:4px;overflow:hidden}.trend-bar{height:100%;background:linear-gradient(90deg,var(--leaf),var(--forest));border-radius:4px}[data-theme=dark] .trend-bar{background:linear-gradient(90deg,#6dbd85,#4a9e6a)}[data-theme=dark] .bim-cold{background:#5ec4dc2e;color:#9de0f0}[data-theme=dark] .bim-warm{background:#e8bb5a2e;color:#f0ce70}[data-theme=dark] .badge-green{background:#6dbd8533;color:#90d4a0}[data-theme=dark] .badge-amber{background:#e8bb5a33;color:#f0ce70}[data-theme=dark] .badge-blue{background:#5ec4dc33;color:#9de0f0}[data-theme=dark] .badge-red{background:#e0683033;color:#f09070}[data-theme=dark] .notice-amber{color:#f0ce70}[data-theme=dark] .notice-green{color:#90d4a0}[data-theme=dark] .notice-blue{color:#9de0f0}[data-theme=dark] .chip-forest{background:#6dbd8526;color:var(--leaf)}[data-theme=dark] .chip-sky{background:#5ec4dc26;color:var(--sky)}[data-theme=dark] .bar-track{background:#ffffff14}[data-theme=dark] .readonly-banner{background:#5ec4dc1a;color:#9de0f0;border-color:#5ec4dc40}[data-theme=dark] .filter-chip.as{background:var(--amber);color:#1a1a00}[data-theme=dark] tbody tr:hover td{background:#6dbd850f}[data-theme=dark] .modal-box{background:#1e2820;border:1px solid rgba(109,189,133,.2)}[data-theme=dark] .modal-overlay{background:#000000a6}[data-theme=dark] .form-hint.err{color:#f09090}[data-theme=dark] .error-msg{background:#e068301f;color:#f09070;border-color:#e068304d}.trend-val{font-weight:700;font-size:15px;min-width:90px;text-align:right}.trend-delta{font-size:12px;font-weight:600;min-width:55px;text-align:right}.delta-up{color:#c0392b}.delta-dn{color:var(--leaf)}.ios-list{background:var(--snow);border:1px solid var(--border);border-radius:14px;overflow:hidden;box-shadow:var(--shadow);margin-bottom:1rem}.ios-list-row{display:flex;align-items:center;gap:12px;padding:13px 16px;border-bottom:1px solid var(--border);transition:background .1s}.ios-list-row:last-child{border-bottom:none}.ios-list-row:hover{background:#1a3a2a05}.ios-list-icon{width:34px;height:34px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0}.ios-list-label{flex:1;font-size:14px;font-weight:500;color:var(--ink2)}.ios-list-value{font-size:14px;color:var(--muted)}.form-group input[type=number]{font-variant-numeric:tabular-nums;min-width:0;font-size:15px}.form-group input{min-width:0}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{opacity:.5}.preview-box{background:#4a8c5c14;border:1px solid rgba(74,140,92,.2);border-radius:10px;padding:1rem 1.25rem;margin-bottom:1rem}.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--forest) 0%,var(--forest2) 55%,var(--leaf) 100%);padding:2rem}.login-card{background:var(--snow);border-radius:20px;padding:2.5rem;width:100%;max-width:400px;box-shadow:0 20px 60px #00000047}.login-logo{text-align:center;margin-bottom:2rem}.login-icon{width:54px;height:54px;border-radius:15px;background:linear-gradient(135deg,var(--forest),var(--leaf));display:flex;align-items:center;justify-content:center;margin:0 auto 12px;font-size:24px;box-shadow:0 8px 20px #1a3a2a59}.login-title{font-family:"DM Serif Display",serif;font-size:24px;color:var(--ink);margin-bottom:4px}.login-sub{font-size:13px;color:var(--muted)}.divider{display:flex;align-items:center;gap:12px;margin:1.25rem 0;color:var(--muted);font-size:13px}.divider:before,.divider:after{content:"";flex:1;height:1px;background:var(--border)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:200;padding:1rem}.modal-box{background:var(--snow);border-radius:16px;padding:2rem;width:100%;max-width:440px;box-shadow:var(--shadow-lg)}.modal-title{font-family:"DM Serif Display",serif;font-size:19px;color:var(--ink);margin-bottom:8px}.modal-sub{font-size:14px;color:var(--muted);margin-bottom:1.5rem;line-height:1.6}.modal-actions{display:flex;gap:10px;justify-content:flex-end}.loading{display:flex;align-items:center;justify-content:center;padding:4rem;font-family:"DM Serif Display",serif;font-style:italic;color:var(--muted);font-size:16px}.readonly-banner{background:#d4a8531a;border:1px solid rgba(212,168,83,.3);border-radius:10px;padding:10px 16px;font-size:13px;color:#7a5010;margin-bottom:1rem;display:flex;align-items:center;gap:8px}.page-content>.card,.page-content>div[style*=maxWidth],.page-content>div[style*=max-width]{margin-left:auto;margin-right:auto}.hamburger{display:none;background:none;border:none;cursor:pointer;padding:6px;border-radius:8px;color:var(--ink);font-size:22px;line-height:1;transition:background .13s}.hamburger:hover{background:var(--warm)}.hamburger-float{position:fixed;top:12px;left:12px;z-index:101;background:var(--snow);border:1px solid var(--border)!important;border-radius:8px;box-shadow:var(--shadow);padding:8px 10px;color:var(--ink)}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:99;animation:fadeIn .2s ease}.sidebar-overlay.open{display:block}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media (max-width: 900px){.stat-grid-5,.stat-grid-4,.stat-grid-3{grid-template-columns:1fr 1fr}.two-col{grid-template-columns:1fr}}@media (max-width: 640px){.sidebar{transform:translate(-100%);transition:transform .25s cubic-bezier(.4,0,.2,1);z-index:100;width:280px}.sidebar.open{transform:translate(0);box-shadow:4px 0 24px #0000004d}.main-area{margin-left:0}.hamburger-float{display:flex;align-items:center;justify-content:center}.topbar{padding:0 1rem 0 3.5rem;height:54px}.topbar-title{font-size:17px}.stat-grid-4,.stat-grid-3,.stat-grid-2,.form-row-2{grid-template-columns:1fr}.page-content{padding:.875rem}.stat-card{padding:1rem 1.125rem}.stat-value{font-size:22px}.card{padding:1.125rem}.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}table{min-width:480px}td,thead th{padding:9px 10px;font-size:13px}.anno-tabs{overflow-x:auto;flex-wrap:nowrap;padding-bottom:4px}.anno-tab{white-space:nowrap;flex-shrink:0}.filter-row{overflow-x:auto;flex-wrap:nowrap;padding-bottom:4px}.filter-chip{white-space:nowrap;flex-shrink:0}.login-wrap{padding:2rem 1rem 1rem;align-items:flex-start}.login-card{padding:1.75rem 1.25rem;border-radius:16px}.login-title{font-size:20px}.form-tenants-grid{grid-template-columns:1fr 1fr!important}.reading-card{padding:1rem}.reading-card-header{flex-direction:column;align-items:flex-start}.reading-card-actions{width:100%;justify-content:flex-end}.modal-box{padding:1.5rem}.modal-overlay{align-items:flex-end;padding:0}.modal-box{border-radius:20px 20px 0 0;max-width:100%;width:100%;animation:slideUp .25s cubic-bezier(.4,0,.2,1)}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.ios-list-row{padding:12px 14px}.avatar-name{font-size:12px}.avatar-role{font-size:10px}}@media (max-height: 500px) and (max-width: 900px){.login-wrap{align-items:flex-start;padding:1rem}.login-logo{margin-bottom:1rem}.login-icon{width:40px;height:40px;font-size:18px;margin-bottom:8px}.login-title{font-size:18px}.login-sub{display:none}.login-card{padding:1.25rem}.form-group{margin-bottom:.625rem}.sidebar{width:240px}.topbar{height:48px}.page-content{padding:.75rem}.stat-grid-4{grid-template-columns:repeat(4,1fr)}.stat-grid-3{grid-template-columns:repeat(3,1fr)}.stat-value{font-size:18px}}
