:root{font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;--bg:#0e0e10;--glass:#ffffff0d;--glass-hover:#ffffff14;--glass-border:#ffffff17;--glass-strong:#ffffff29;--text:#d8dce8;--text-muted:#a0a8bead;--text-strong:#f0f2f8;--g-slate:linear-gradient(135deg, #3a4a5c 0%, #2a3a4e 100%);--g-steel:linear-gradient(135deg, #2e4a5a 0%, #1e3a4a 100%);--g-teal:linear-gradient(135deg, #1a4a44 0%, #1a5c52 100%);--g-ember:linear-gradient(135deg, #4a3020 0%, #5a3a28 100%);--g-rose:linear-gradient(135deg, #4a2a2a 0%, #5a3030 100%);--g-moss:linear-gradient(135deg, #2a3a24 0%, #344a2c 100%);--accent-blue:#5a8ab0;--accent-teal:#3a9080;--accent-amber:#9a7840;--accent-rose:#8a5050;--glow-slate:0 6px 20px #3a4a5c66;--glow-steel:0 6px 20px #2e4a5a61;--glow-teal:0 6px 20px #1a4a4461;--glow-ember:0 6px 20px #4a30205c;--surface:#ffffff0d;--surface-soft:#ffffff08;--line:#ffffff17;--muted:#a0a8bead;--primary:#5a8ab0;--primary-strong:#7aa8cc;--accent:#3a9080;--warn:#9a7840;--danger:#8a5050;--shadow:0 16px 44px #0000007a, 0 0 0 1px #ffffff0a;font-family:Sarabun,system-ui,sans-serif}*,:before,:after{box-sizing:border-box}body{background:var(--bg);min-width:320px;min-height:100vh;color:var(--text);background-image:radial-gradient(at 20% 0,#32466438 0%,#0000 55%),radial-gradient(at 85% 12%,#1e37502e 0%,#0000 55%),radial-gradient(at 5% 90%,#19463c24 0%,#0000 55%),radial-gradient(at 90% 85%,#3c281e1f 0%,#0000 55%);background-attachment:fixed;margin:0;overflow-x:hidden}body:before{content:"";pointer-events:none;z-index:0;background:radial-gradient(circle,#3250781a 0%,#0000 70%);border-radius:50%;width:360px;height:360px;animation:11s ease-in-out infinite drift;position:fixed;top:-100px;right:-80px}body:after{content:"";pointer-events:none;z-index:0;background:radial-gradient(circle,#19504617 0%,#0000 70%);border-radius:50%;width:300px;height:300px;animation:14s ease-in-out infinite reverse drift;position:fixed;bottom:80px;left:-80px}@keyframes drift{0%,to{transform:translate(0)scale(1)}33%{transform:translate(24px,-24px)scale(1.03)}66%{transform:translate(-14px,16px)scale(.98)}}a{color:inherit;text-decoration:none}button,input{font:inherit}.app-shell{z-index:1;max-width:760px;min-height:100vh;margin:0 auto;padding:20px 14px 96px;position:relative}.desktop-sidebar{display:none}.app-main{min-width:0}.topbar{justify-content:space-between;align-items:flex-start;gap:12px;padding:14px 4px 26px;display:flex}.topbar h1,.hero-panel h2,.section-title h2,.section-title h3{margin:0;font-family:Kanit,Sarabun,system-ui,sans-serif}.topbar h1{background:linear-gradient(135deg,#f0f2f8 0%,#9ab8d0 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:27px;font-weight:800;line-height:1.15}.eyebrow{color:#5a8ab0;text-transform:uppercase;letter-spacing:2.5px;margin:0 0 5px;font-size:10.5px;font-weight:800}.readonly-pill,.count-pill,.status-ok,.status-warn{white-space:nowrap;letter-spacing:.5px;border-radius:100px;justify-content:center;align-items:center;min-height:28px;padding:4px 13px;font-size:11px;font-weight:800;display:inline-flex}.readonly-pill{color:#7aa8cc;background:#5a8ab01f;border:1px solid #5a8ab03d}.count-pill{color:#5aaa96;background:#3a90801f;border:1px solid #3a90803d}.status-ok{color:#5aaa96;background:#28826e1f;border:1px solid #28826e3d}.status-warn{color:#aa9060;background:#9a78401f;border:1px solid #9a78403d}.page-frame{display:block}.stack{gap:14px;display:grid}.worklist-page{gap:10px;display:grid}.cycle-strip{border:1px solid var(--line);background:var(--glass);box-shadow:var(--shadow);border-radius:14px;justify-content:space-between;align-items:flex-start;gap:12px;padding:12px;display:flex}.cycle-strip h2{color:var(--text-strong);margin:0;font-family:Kanit,sans-serif;font-size:20px;line-height:1.2}.cycle-strip span,.compact-warning{color:var(--muted);font-size:12px;font-weight:800}.compact-warning{background:#9a784014;border:1px solid #9a784047;border-radius:12px;padding:10px 12px}.work-summary{grid-template-columns:.9fr .9fr 1.35fr;gap:8px;display:grid}.work-summary>div{border:1px solid var(--line);background:var(--glass);border-radius:12px;min-height:64px;padding:10px}.work-summary span{color:var(--muted);font-size:11px;font-weight:900;display:block}.work-summary strong{color:var(--text-strong);margin-top:6px;font-family:Kanit,sans-serif;font-size:18px;line-height:1.08;display:block}.quick-task-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;display:grid}.quick-task{border:1px solid var(--line);background:var(--glass);min-height:68px;box-shadow:var(--shadow);border-radius:14px;align-content:center;gap:5px;padding:12px;display:grid}.quick-task:first-child{background:var(--g-teal);border-color:#3a90803d}.quick-task strong{color:var(--text-strong);font-family:Kanit,sans-serif;font-size:15px;line-height:1.15}.quick-task span{color:var(--muted);font-size:11px;font-weight:900}.filter-tabs{grid-template-columns:repeat(4,minmax(0,1fr));gap:6px;padding:4px 0;display:grid}.filter-tabs button{border:1px solid var(--line);background:var(--glass);min-height:38px;color:var(--muted);border-radius:10px;font-size:12px;font-weight:900}.filter-tabs button.active{background:var(--g-slate);color:#e0e8f0;border-color:#5a8ab059}.room-worklist{gap:8px;display:grid}.room-row{border:1px solid var(--line);background:var(--glass);box-shadow:var(--shadow);border-radius:14px;gap:9px;padding:12px;display:grid}.room-row.ready{border-color:#3a90803d}.room-row.blocked{border-color:#9a784047}.room-row.paid,.room-row.vacant{opacity:.78}.room-row-top,.room-row-middle,.room-row-bottom{justify-content:space-between;gap:10px;display:flex}.room-row-top{align-items:flex-start}.room-row-top strong,.room-row-middle strong{color:var(--text-strong);font-family:Kanit,sans-serif;display:block}.room-row-top span,.room-row-middle span,.room-row-bottom span{color:var(--muted);font-size:12px;font-weight:800;line-height:1.35}.room-row-middle{align-items:baseline}.room-row-middle strong{color:var(--primary-strong);white-space:nowrap;font-size:20px}.room-row-bottom{align-items:center}.room-row-bottom em{min-height:28px;color:var(--text-strong);background:#ffffff12;border-radius:8px;flex:none;padding:5px 9px;font-size:11px;font-style:normal;font-weight:900}.desktop-only-layout{display:none}.desktop-dashboard{gap:16px}.desktop-page-head,.panel-heading{justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.desktop-page-head{border:1px solid var(--line);background:var(--glass);box-shadow:var(--shadow);border-radius:18px;padding:18px}.desktop-page-head h2,.panel-heading h3{color:var(--text-strong);margin:0;font-family:Kanit,sans-serif}.desktop-page-head h2{font-size:26px}.desktop-page-head span{color:var(--muted);margin-top:5px;font-size:13px;font-weight:800;display:block}.desktop-stat-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;display:grid}.desktop-stat{border:1px solid var(--line);background:var(--glass);min-height:104px;box-shadow:var(--shadow);border-radius:16px;padding:16px}.desktop-stat span{color:var(--muted);font-size:12px;font-weight:900}.desktop-stat strong{color:var(--primary-strong);margin-top:12px;font-family:Kanit,sans-serif;font-size:24px;line-height:1.1;display:block}.desktop-stat.danger strong{color:#d48c8c}.desktop-content-grid{grid-template-columns:minmax(0,1fr) 330px;gap:16px;display:grid}.desktop-table-panel,.desktop-side-panel{border:1px solid var(--line);background:var(--glass);min-width:0;box-shadow:var(--shadow);border-radius:18px;padding:16px}.room-table{gap:8px;margin-top:14px;display:grid}.room-table-head,.room-table-row{grid-template-columns:72px minmax(120px,1fr) minmax(150px,1.1fr) 130px minmax(170px,1.2fr);align-items:center;gap:12px;display:grid}.room-table-head{color:var(--muted);text-transform:uppercase;padding:0 12px 4px;font-size:11px;font-weight:900}.room-table-row{border:1px solid var(--line);background:#ffffff09;border-radius:12px;min-height:66px;padding:10px 12px}.room-table-row.ready{border-color:#3a90803d}.room-table-row.blocked{border-color:#9a784047}.room-table-row.paid,.room-table-row.vacant{opacity:.78}.room-table-row span{color:var(--muted);font-size:12px;font-weight:800;line-height:1.4}.room-table-row strong{color:var(--text-strong);font-family:Kanit,sans-serif;font-size:14px}.desktop-issue-list{gap:10px;margin-top:14px;display:grid}.desktop-issue{border:1px solid var(--line);background:#ffffff09;border-radius:13px;padding:13px}.desktop-issue.warning{border-color:#9a784047}.desktop-issue.danger{border-color:#8a50504d}.desktop-issue strong{color:var(--text-strong);font-size:13px;display:block}.desktop-issue p,.desktop-issue span{color:var(--muted);margin:6px 0 0;font-size:12px;font-weight:800;line-height:1.45;display:block}.shape-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.shape-card{border:1px solid var(--line);background:var(--glass);min-width:0;box-shadow:var(--shadow);border-radius:14px;padding:13px}.shape-card-head{justify-content:space-between;gap:10px;display:flex}.shape-card-head strong{color:var(--text-strong);font-family:Kanit,sans-serif}.shape-card-head span,.shape-field em{color:var(--muted);font-size:11px;font-style:normal;font-weight:800}.shape-field-list{gap:7px;margin-top:10px;display:grid}.shape-field{border-top:1px solid #ffffff0d;justify-content:space-between;gap:8px;padding:7px 0;display:flex}.shape-field span{min-width:0;color:var(--primary-strong);text-overflow:ellipsis;font-size:12px;font-weight:900;overflow:hidden}.coverage-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;display:grid}.coverage-card{border:1px solid var(--line);min-width:0;box-shadow:var(--shadow);background:#ffffff0a;border-radius:14px;padding:14px}.coverage-card.warning{border-color:#9a784047}.coverage-card-head{justify-content:space-between;align-items:center;gap:10px;display:flex}.coverage-card-head span{color:var(--muted);font-size:12px;font-weight:900}.coverage-card-head strong{color:var(--text-strong);font-family:Kanit,sans-serif;font-size:20px}.coverage-card p{color:var(--primary-strong);overflow-wrap:anywhere;margin:10px 0 0;font-size:12px;font-weight:800;line-height:1.5}.migration-preview-card{border:1px solid var(--line);box-shadow:var(--shadow);background:#ffffff0b;border-radius:16px;padding:16px}.migration-preview-card .section-title{margin-bottom:12px}.preview-warning-list{flex-wrap:wrap;gap:8px;margin-bottom:12px;display:flex}.preview-warning-list span{color:#e8c88f;background:#9a78401a;border:1px solid #9a78404d;border-radius:999px;padding:7px 10px;font-size:11px;font-weight:900}.preview-entity-grid{grid-template-columns:repeat(5,minmax(0,1fr));gap:10px;display:grid}.preview-entity{background:#00000029;border:1px solid #ffffff12;border-radius:14px;min-width:0;padding:12px}.preview-entity>strong{color:var(--text-strong);font-family:Kanit,sans-serif;font-size:14px;display:block}.preview-field-list{gap:7px;margin-top:10px;display:grid}.preview-field{gap:2px;display:grid}.preview-field span{color:var(--muted);font-size:10px;font-weight:900}.preview-field em{color:var(--primary-strong);overflow-wrap:anywhere;font-size:12px;font-style:normal;font-weight:900}@media (width<=540px){.shape-grid,.coverage-grid,.preview-entity-grid,.meter-summary-totals{grid-template-columns:1fr}.arrears-total-panel,.arrears-lines,.tenant-profile-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.meter-summary-row{grid-template-columns:1fr auto}.meter-summary-row>div{grid-column:1/-1}.backup-import-panel{grid-template-columns:1fr}}.hero-panel{-webkit-backdrop-filter:blur(20px);box-shadow:var(--shadow);background:#ffffff0a;border:1px solid #ffffff17;border-radius:20px;padding:24px 22px;position:relative;overflow:hidden}.hero-panel:before{content:"";opacity:.6;background:linear-gradient(90deg,#3a4a5c,#5a8ab0,#3a9080,#5a8ab0,#3a4a5c) 0 0/250% 100%;height:2px;animation:6s linear infinite shimmer;position:absolute;top:0;left:0;right:0}.hero-panel:after{content:"";pointer-events:none;background:radial-gradient(circle,#3c5a821a 0%,#0000 70%);border-radius:50%;width:180px;height:180px;position:absolute;top:-60px;right:-60px}@keyframes shimmer{0%{background-position:0 0}to{background-position:250% 0}}.hero-panel h2{background:linear-gradient(135deg,#f0f2f8 0%,#9ab8d0 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-family:Kanit,sans-serif;font-size:24px;font-weight:800;line-height:1.28}.hero-panel p{color:var(--text-muted);margin:10px 0 0;font-size:13.5px;font-weight:600;line-height:1.65}.source-row{flex-wrap:wrap;align-items:center;gap:8px;margin-top:14px;display:flex}.warning-text{font-weight:700;color:#aa9060!important}.notice-panel{background:var(--glass);border:1px solid var(--glass-border);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);color:var(--text-muted);border-radius:18px;padding:16px 18px;font-size:13px;font-weight:700;line-height:1.65}.backup-import-panel{border:1px solid var(--glass-border);background:var(--glass);box-shadow:var(--shadow);border-radius:14px;grid-template-columns:minmax(0,1fr) auto auto;align-items:center;gap:12px;padding:13px;display:grid}.backup-import-panel strong{color:var(--text-strong);font-family:Kanit,sans-serif;font-size:15px;display:block}.backup-import-panel p{color:var(--text-muted);margin:4px 0 0;font-size:12px;font-weight:800;line-height:1.4}.file-button{background:var(--g-slate);color:#e0e8f0;cursor:pointer;white-space:nowrap;border:1px solid #5a8ab03d;border-radius:8px;justify-content:center;align-items:center;min-height:34px;padding:6px 11px;font-size:12px;font-weight:900;display:inline-flex}.file-button input{display:none}.small-button{border:1px solid var(--glass-strong);background:var(--glass);color:#7aa8cc;cursor:pointer;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:100px;min-height:32px;padding:5px 16px;font-size:12px;font-weight:800;transition:all .22s}.small-button:hover:not(:disabled){background:#5a8ab024;border-color:#5a8ab0;box-shadow:0 0 14px #5a8ab02e}.small-button:disabled{opacity:.45;cursor:default}.metric-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.audit-panel{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;display:grid}.audit-total-grid,.detail-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.room-hero-card{border:1px solid var(--line);background:var(--glass);box-shadow:var(--shadow);border-radius:16px;justify-content:space-between;align-items:flex-start;gap:12px;padding:16px;display:flex}.room-hero-card strong{color:var(--text-strong);margin-top:4px;font-family:Kanit,sans-serif;font-size:22px;line-height:1.18;display:block}.room-hero-card p{color:var(--muted);margin:6px 0 0;font-size:13px;font-weight:800;line-height:1.45}.audit-total{border:1px solid var(--line);background:var(--glass);min-height:82px;box-shadow:var(--shadow);border-radius:14px;padding:13px}.audit-total span{color:var(--muted);font-size:12px;font-weight:900;display:block}.audit-total strong{color:var(--primary-strong);margin-top:8px;font-family:Kanit,sans-serif;font-size:20px;line-height:1.15;display:block}.audit-total.danger strong{color:#d48c8c}.audit-room-list{gap:10px;display:grid}.audit-room-row{border:1px solid var(--line);background:var(--glass);box-shadow:var(--shadow);border-radius:14px;justify-content:space-between;align-items:flex-start;gap:12px;padding:13px;display:flex}.audit-room-row.ready{border-color:#3a90803d}.audit-room-row.blocked{border-color:#9a784047}.audit-room-row.paid,.audit-room-row.vacant{opacity:.72}.audit-room-main{min-width:0}.audit-room-main strong,.audit-room-money strong{color:var(--text-strong);font-family:Kanit,sans-serif;font-size:15px;display:block}.audit-room-main p{color:var(--muted);margin:5px 0 0;font-size:12px;font-weight:800;line-height:1.45}.audit-room-money{text-align:right;flex:none}.audit-room-money span{color:var(--muted);white-space:nowrap;margin-top:4px;font-size:11px;font-weight:800;display:block}.audit-panel>div{border:1px solid var(--line);background:var(--glass);min-height:70px;box-shadow:var(--shadow);border-radius:8px;padding:12px}.audit-panel span,.issue-item p{color:var(--muted);font-size:12px;font-weight:800;line-height:1.45}.audit-panel strong{color:var(--primary-strong);margin-top:6px;font-size:24px;line-height:1;display:block}.issue-list{gap:10px;display:grid}.issue-item{border:1px solid var(--line);background:var(--glass);box-shadow:var(--shadow);border-radius:8px;justify-content:space-between;gap:12px;padding:12px;display:flex}.issue-item strong{color:var(--text-strong);font-size:14px;display:block}.issue-item p{margin:5px 0 0}.issue-item>span{max-width:42%;color:var(--primary-strong);text-align:right;font-size:12px;font-weight:900;line-height:1.35}.issue-item.warning{border-color:#9a784042}.issue-item.danger{border-color:#8a50504d}.metric-card,.work-item,.room-card{background:unset;border:unset;border-radius:unset;box-shadow:unset}.metric-card{border-radius:18px;align-content:space-between;min-height:100px;padding:18px 16px;text-decoration:none;transition:transform .22s,filter .22s;display:grid;position:relative;overflow:hidden}.metric-card:first-child{background:var(--g-slate);box-shadow:var(--glow-slate)}.metric-card:nth-child(2){background:var(--g-teal);box-shadow:var(--glow-teal)}.metric-card:nth-child(3){background:var(--g-rose);box-shadow:var(--glow-ember)}.metric-card:nth-child(4){background:var(--g-ember);box-shadow:var(--glow-ember)}.metric-card:before{content:"";pointer-events:none;background:linear-gradient(#ffffff14 0%,#0000 100%);height:50%;position:absolute;top:0;left:0;right:0}.metric-card:hover{filter:brightness(1.12);transform:translateY(-3px)scale(1.018)}.metric-card span{color:#ffffffa6;text-transform:uppercase;letter-spacing:.8px;font-size:11px;font-weight:800;position:relative}.metric-card strong{color:#fff;text-shadow:0 1px 6px #0000004d;font-family:Kanit,sans-serif;font-size:25px;font-weight:900;line-height:1.1;position:relative}.section-title{justify-content:space-between;align-items:center;gap:12px;padding:8px 4px 2px;display:flex}.section-title h2,.section-title h3{background:linear-gradient(135deg,#e8ecf4 0%,#9ab8d0 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-family:Kanit,sans-serif;font-size:20px;font-weight:800}.work-list{gap:10px;display:grid}.work-item{background:var(--glass);border:1px solid var(--glass-border);-webkit-backdrop-filter:blur(16px);min-height:unset;border-radius:16px;justify-content:space-between;align-items:center;gap:14px;padding:17px 18px 17px 22px;text-decoration:none;transition:all .25s;display:flex;position:relative;overflow:hidden}.work-item:before{content:"";border-radius:3px 0 0 3px;width:3px;position:absolute;top:0;bottom:0;left:0}.work-item:first-child:before{background:linear-gradient(#5a8ab0,#3a9080)}.work-item:nth-child(2):before{background:linear-gradient(#3a9080,#2a7060)}.work-item:nth-child(3):before{background:linear-gradient(#8a5050,#6a3838)}.work-item:hover{background:var(--glass-hover);border-color:var(--glass-strong);transform:translate(4px)}.work-item strong{color:var(--text-strong);font-family:Kanit,sans-serif;font-size:15.5px;font-weight:700;display:block}.work-item p{color:var(--text-muted);margin:5px 0 0;font-size:12.5px;font-weight:600;line-height:1.5}.work-item>span{border-radius:13px;flex-shrink:0;place-items:center;min-width:44px;min-height:44px;font-family:Kanit,sans-serif;font-size:18px;font-weight:900;display:grid}.work-item:first-child>span{color:#7aa8cc;background:#5a8ab029}.work-item:nth-child(2)>span{color:#5aaa96;background:#3a908029}.work-item:nth-child(3)>span{color:#aa7070;background:#8a505029}.room-card{background:var(--glass);border:1px solid var(--glass-border);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-radius:16px;padding:17px;transition:all .22s}.room-card:hover{background:var(--glass-hover);border-color:var(--glass-strong)}.room-card.attention{background:#9a78400d;border-color:#9a784047}.room-card.room-card-danger{border-color:#8a50504d}.primary-action.action-danger{background:linear-gradient(135deg,#5a2020,#8a3030)}.room-card-head{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.room-card-head strong{color:var(--text-strong);margin-top:2px;font-family:Kanit,sans-serif;font-size:17px;font-weight:700;display:block}.room-number{color:var(--text-muted);text-transform:uppercase;letter-spacing:1.2px;font-size:11px;font-weight:800}.amount-due{color:#aa7070;white-space:nowrap;font-family:Kanit,sans-serif;font-weight:900}.meter-pair,.bill-lines,.tenant-details{gap:8px;margin-top:12px;display:grid}.meter-input-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:12px;display:grid}.meter-input-grid label{gap:6px;display:grid}.meter-input-grid label span{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:800}.meter-input-grid input{border:1px solid var(--glass-border);background:var(--glass);width:100%;min-height:48px;color:var(--text-strong);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:13px;padding:8px 13px;font-family:Kanit,sans-serif;font-size:19px;font-weight:900;transition:border-color .2s,box-shadow .2s}.meter-input-grid input:focus{border-color:#5a8ab0;outline:none;box-shadow:0 0 0 3px #5a8ab02e}.meter-input-grid input[readonly]{color:var(--text-muted);background:#ffffff05}.meter-pair{grid-template-columns:repeat(2,minmax(0,1fr))}.meter-workspace{max-width:860px}.arrears-workspace{max-width:940px}.line-workspace{max-width:960px}.tenant-workspace{max-width:940px}.arrears-total-panel{grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;display:grid}.arrears-total-panel .audit-total{min-height:76px}.arrears-focus-card{border-color:#8a505047}.payment-focus-card{border-color:#3a90803d}.line-focus-card{border-color:#5a8ab03d}.tenant-focus-card{border-color:#5a8ab033}.tenant-profile-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-top:14px;display:grid}.tenant-profile-grid>div{background:#00000024;border:1px solid #ffffff12;border-radius:13px;min-width:0;padding:12px}.tenant-profile-grid span{color:var(--text-muted);font-size:11px;font-weight:900;display:block}.tenant-profile-grid strong{color:var(--text-strong);overflow-wrap:anywhere;margin-top:4px;font-family:Kanit,sans-serif;font-size:15px;display:block}.line-message-preview{margin-top:14px}.payment-amount-hero{background:#3a908014;border:1px solid #3a908038;border-radius:14px;margin-top:14px;padding:16px}.payment-amount-hero span{color:var(--text-muted);font-size:11px;font-weight:900}.payment-amount-hero strong{color:var(--text-strong);margin-top:4px;font-family:Kanit,sans-serif;font-size:32px;line-height:1.05;display:block}.payment-amount-hero p{color:var(--muted);margin:8px 0 0;font-size:12px;font-weight:800}.arrears-lines{grid-template-columns:repeat(4,minmax(0,1fr))}.meter-room-strip{scroll-snap-type:x proximity;gap:8px;padding:2px 0 8px;display:flex;overflow-x:auto}.meter-room-chip{border:1px solid var(--glass-border);background:var(--glass);min-width:68px;min-height:58px;color:var(--muted);cursor:pointer;scroll-snap-align:start;border-radius:14px;place-items:center;gap:2px;padding:8px 10px;display:grid}.meter-room-chip strong{color:var(--text-strong);font-family:Kanit,sans-serif;font-size:18px;line-height:1}.meter-room-chip span{color:var(--text-muted);font-size:10px;font-weight:900}.meter-room-chip.active{background:var(--g-teal);box-shadow:var(--glow-teal);border-color:#3a908052}.meter-room-chip.attention:not(.active){border-color:#9a784047}.meter-focus-card{padding-bottom:18px}.meter-entry-grid input:not([readonly]){font-size:24px}.meter-action-bar{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin-top:14px;display:grid}.meter-draft-footer{margin-top:14px}.meter-summary-panel{border:1px solid var(--glass-border);background:var(--glass);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-radius:16px;padding:16px}.meter-summary-panel.empty{gap:8px;display:grid}.meter-summary-panel.empty strong{color:var(--text-strong);margin-top:4px;font-family:Kanit,sans-serif;font-size:17px;display:block}.meter-summary-panel.empty p{color:var(--text-muted);margin:0;font-size:12px;font-weight:800;line-height:1.5}.meter-summary-totals{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin-top:12px;display:grid}.meter-summary-totals>div{background:#00000029;border:1px solid #ffffff12;border-radius:13px;min-width:0;padding:12px}.meter-summary-totals span,.meter-summary-row span{color:var(--text-muted);font-size:11px;font-weight:900}.meter-summary-totals strong,.meter-summary-row strong{color:var(--text-strong);margin-top:3px;font-family:Kanit,sans-serif;font-size:15px;display:block}.meter-summary-list{gap:8px;margin-top:12px;display:grid}.meter-summary-row{background:#0000001f;border:1px solid #ffffff12;border-radius:13px;grid-template-columns:minmax(0,1.1fr) minmax(0,1fr) auto;align-items:center;gap:8px;padding:10px;display:grid}.meter-summary-row>button:first-child{text-align:left;cursor:pointer;background:0 0;border:0;min-width:0;padding:0}.meter-summary-row>div{min-width:0}.meter-summary-row>div span{margin-right:8px;display:inline-block}.meter-summary-panel .primary-action{margin-top:12px}.meter-box{background:var(--glass);border:1px solid var(--glass-border);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:14px;min-height:88px;padding:14px}.meter-box span,.meter-box small,.bill-lines span,.tenant-details span{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:800;display:block}.meter-box strong{color:var(--text-strong);margin:10px 0 3px;font-family:Kanit,sans-serif;font-size:22px;font-weight:900;display:block}.bill-lines,.tenant-details{grid-template-columns:repeat(2,minmax(0,1fr))}.bill-lines span,.tenant-details span{background:var(--glass);border:1px solid var(--glass-border);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px;padding:12px}.message-preview{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#5a8ab012;border:1px solid #5a8ab029;border-radius:16px;margin-top:14px;padding:16px}.message-preview strong{color:#7aa8cc;font-family:Kanit,sans-serif;font-weight:700;display:block}.message-preview p{color:var(--text-muted);margin:8px 0 0;font-size:13px;font-weight:600;line-height:1.6}.reason-row{border:1px solid var(--line);background:var(--glass);color:var(--text-muted);border-radius:13px;margin-top:10px;padding:11px 13px;font-size:12px;font-weight:900;line-height:1.45}.billing-ready{border-color:#3a90803d}.billing-blocked{border-color:#9a784047}.billing-paid{opacity:.78}.billing-vacant{opacity:.64}.primary-action{background:var(--g-slate);color:#e0e8f0;cursor:pointer;width:100%;min-height:50px;box-shadow:var(--glow-slate);border:1px solid #5a8ab038;border-radius:14px;margin-top:14px;font-family:Kanit,sans-serif;font-size:15px;font-weight:900;transition:transform .2s,filter .2s}.primary-action:hover:not(:disabled){filter:brightness(1.15);transform:translateY(-2px)}.primary-action:disabled{color:var(--text-muted);box-shadow:none;cursor:default;background:#ffffff0f;border-color:#0000}.draft-footer{color:#5aaa96;background:#286e6014;border:1px solid #286e6033;border-radius:13px;justify-content:space-between;gap:10px;margin-top:12px;padding:13px 16px;font-size:13px;font-weight:800;display:flex}.bottom-nav{-webkit-backdrop-filter:blur(28px);z-index:100;background:#0a0a0ce0;border:1px solid #ffffff14;border-radius:24px;grid-template-columns:repeat(4,1fr);gap:4px;width:min(736px,100% - 24px);padding:8px;display:grid;position:fixed;bottom:14px;left:50%;transform:translate(-50%);box-shadow:0 20px 50px #00000085,0 0 0 1px #ffffff0a}.nav-item{min-height:52px;color:var(--text-muted);letter-spacing:.2px;border-radius:16px;place-items:center;gap:3px;font-size:10px;font-weight:800;text-decoration:none;transition:all .25s;display:grid}.nav-item span{font-size:19px;line-height:1;transition:transform .25s}.nav-item:hover:not(.active){color:var(--text);background:#ffffff0f}.nav-item:hover:not(.active) span{transform:translateY(-2px)}.nav-item.active{background:var(--g-slate);color:#d8e8f4;box-shadow:var(--glow-slate);border:1px solid #5a8ab033}.nav-item.active span{transform:scale(1.1)}a.nav-item[href=\/meters].active{background:var(--g-teal);box-shadow:var(--glow-teal);color:#c8f0e8;border-color:#3a908038}a.nav-item[href=\/arrears].active{background:var(--g-rose);box-shadow:var(--glow-ember);color:#f0d8d8;border-color:#8a505038}a.nav-item[href=\/audit].active,a.nav-item[href=\/billing].active{background:var(--g-steel);box-shadow:var(--glow-steel);color:#c8e0f0;border-color:#2e4a5a38}a.nav-item[href=\/payments].active{background:var(--g-ember);box-shadow:var(--glow-ember);color:#f0e0c8;border-color:#5a3a2838}a.nav-item[href=\/tenants].active{background:var(--g-moss);box-shadow:var(--glow-teal);color:#d0e8c8;border-color:#344a2c38}@keyframes fadeInUp{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}.stack>*{animation:.36s both fadeInUp}.stack>:first-child{animation-delay:40ms}.stack>:nth-child(2){animation-delay:90ms}.stack>:nth-child(3){animation-delay:.14s}.stack>:nth-child(4){animation-delay:.19s}.stack>:nth-child(5){animation-delay:.24s}.stack>:nth-child(6){animation-delay:.29s}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#ffffff1f;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#ffffff38}@media (width>=680px){.app-shell{padding-top:32px}.topbar h1{font-size:32px}.metric-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}@media (width>=960px){.app-shell{grid-template-columns:250px minmax(0,1fr);gap:22px;max-width:1440px;padding:22px;display:grid}.desktop-sidebar{border:1px solid var(--line);height:calc(100vh - 44px);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(22px);backdrop-filter:blur(22px);background:#0a0a0cb8;border-radius:20px;flex-direction:column;gap:18px;padding:18px;display:flex;position:sticky;top:22px}.sidebar-brand strong{color:var(--text-strong);font-family:Kanit,sans-serif;font-size:22px;line-height:1.15;display:block}.sidebar-brand span{color:var(--muted);margin-top:8px;font-size:12px;font-weight:800;display:block}.sidebar-nav{gap:8px;display:grid}.sidebar-link{min-height:44px;color:var(--muted);border:1px solid #0000;border-radius:12px;grid-template-columns:28px 1fr;align-items:center;gap:10px;padding:9px 11px;font-size:13px;font-weight:900;display:grid}.sidebar-link.active{background:var(--g-slate);color:#e0e8f0;box-shadow:var(--glow-slate);border-color:#5a8ab03d}.app-main{min-width:0}.topbar,.bottom-nav,.mobile-only-layout{display:none}.desktop-only-layout{display:grid}}.portal-page{background:#f2f4f6;justify-content:center;align-items:flex-start;min-height:100dvh;padding:20px 16px 48px;display:flex}.portal-card{background:#fff;border-radius:20px;width:100%;max-width:480px;overflow:hidden;box-shadow:0 12px 40px #00000024}.portal-header{color:#fff;background:#1a8870;padding:22px 22px 18px}.portal-header.paid{background:#1a8870}.portal-shop{opacity:.78;margin:0 0 6px;font-size:12px}.portal-header h1{margin:0 0 4px;font-family:Kanit,sans-serif;font-size:22px;font-weight:900}.portal-room-label{opacity:.88;margin:0;font-size:14px}.portal-amount-section{border-bottom:1px solid #f0f0f0;padding:18px 22px 12px}.portal-month{color:#888;margin:0 0 4px;font-size:13px}.portal-amount{margin-bottom:4px;font-family:Kanit,sans-serif;font-size:36px;font-weight:900;line-height:1}.portal-amount.due{color:#1a1a2e}.portal-amount.paid{color:#1a8870}.portal-amount-sub{color:#888;margin:0;font-size:13px}.portal-breakdown{border-bottom:1px solid #f0f0f0;flex-direction:column;gap:8px;padding:16px 22px;display:flex}.portal-bill-row{justify-content:space-between;align-items:center;font-size:14px;display:flex}.portal-bill-row span{color:#555}.portal-bill-row em{color:#222;font-style:normal;font-weight:700}.portal-total-row{border-top:1px solid #e8e8e8;justify-content:space-between;align-items:center;margin-top:4px;padding-top:10px;font-size:15px;display:flex}.portal-total-row span{color:#333;font-weight:600}.portal-total-row strong{color:#1a1a2e;font-size:18px;font-weight:900}.portal-bank{background:#f8faf9;border-bottom:1px solid #f0f0f0;padding:14px 22px}.portal-bank p{color:#555;margin:0 0 4px;font-size:13px}.portal-bank p:last-child{margin:0}.portal-slip-section{flex-direction:column;gap:10px;padding:18px 22px 22px;display:flex}.portal-slip-label{color:#333;margin:0;font-size:14px;font-weight:700}.portal-upload-btn{color:#fff;cursor:pointer;background:#1a8870;border:none;border-radius:12px;width:100%;padding:14px;font-family:Sarabun,sans-serif;font-size:15px;font-weight:700;transition:filter .2s}.portal-upload-btn:hover:not(:disabled){filter:brightness(1.1)}.portal-upload-btn:disabled{cursor:not-allowed;background:#ccc}.portal-upload-ok{color:#1a6050;text-align:center;background:#e8f8f2;border-radius:12px;padding:14px;font-size:14px;font-weight:600}.portal-upload-error{color:#c0392b;margin:0;font-size:13px}.portal-loading,.portal-error{text-align:center;color:#555;margin-top:80px}.portal-error strong{color:#333;margin-bottom:8px;font-size:18px;display:block}.portal-avatar{object-fit:cover;border:2px solid #fff9;border-radius:50%;width:56px;height:56px;margin-bottom:8px}.portal-switch-room{color:#fff;cursor:pointer;background:#fff3;border:1px solid #fff6;border-radius:20px;margin-top:10px;padding:4px 16px;font-size:13px}.portal-switch-room:hover{background:#ffffff4d}.portal-room-select{flex-direction:column;gap:12px;padding:20px;display:flex}.portal-room-btn{cursor:pointer;text-align:left;background:#fff;border:1px solid #e0e0e0;border-radius:12px;align-items:center;gap:12px;padding:16px 18px;transition:background .15s;display:flex}.portal-room-btn:hover{background:#f5f5f5}.portal-room-btn-num{color:#1a1a2e;min-width:60px;font-size:17px;font-weight:700}.portal-room-btn-name{color:#555;flex:1;font-size:15px}.portal-room-btn-status{font-size:13px;font-weight:600}.portal-room-btn-status.paid{color:#1a8870}.portal-room-btn-status.due{color:#c0392b}.pair-done-body{text-align:center;color:#333;padding:24px 20px;line-height:1.6}.pair-done-body strong{color:#1a1a2e}.pair-note{color:#777;margin-top:10px;font-size:14px}.pair-profile-section{padding:20px 20px 0}.pair-profile-card{background:#f7f7f7;border-radius:12px;align-items:center;gap:14px;padding:14px 16px;display:flex}.pair-avatar{object-fit:cover;border:2px solid #ddd;border-radius:50%;flex-shrink:0;width:52px;height:52px}.pair-avatar-placeholder{background:#ccc;border-radius:50%;flex-shrink:0;width:52px;height:52px}.pair-profile-info{flex-direction:column;gap:4px;display:flex}.pair-profile-info strong{color:#1a1a2e;font-size:16px}.pair-profile-info span{color:#777;font-size:13px}.pair-steps{flex-direction:column;gap:12px;padding:20px;display:flex}.pair-step{color:#444;align-items:flex-start;gap:12px;font-size:14px;display:flex}.pair-step-num{color:#fff;background:#1a8870;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;font-size:13px;font-weight:700;display:flex}.pair-actions{padding:0 20px 20px}.pair-actions .portal-upload-btn{background:linear-gradient(135deg,#1a8870,#1fa885);width:100%}.pair-qr-section{flex-direction:column;align-items:center;gap:10px;padding:12px 16px 16px;display:flex}.pair-qr-section canvas{border-radius:8px}.pair-qr-label{color:var(--text-muted);text-align:center;font-size:13px}.login-page{justify-content:center;align-items:center;min-height:100vh;padding:24px 16px;display:flex}.login-card{border:1px solid var(--glass-border);background:var(--glass);-webkit-backdrop-filter:blur(24px);width:100%;max-width:400px;box-shadow:var(--shadow);border-radius:24px;padding:36px 32px}.login-header{text-align:center;margin-bottom:28px}.login-header h1{background:linear-gradient(135deg,#f0f2f8 0%,#9ab8d0 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin:4px 0 8px;font-family:Kanit,Sarabun,system-ui,sans-serif;font-size:26px;font-weight:800}.login-subtitle{color:var(--text-muted);margin:0;font-size:13px}.login-form{flex-direction:column;gap:16px;display:flex}.field-group{flex-direction:column;gap:6px;display:flex}.field-label{color:var(--text-muted);letter-spacing:.5px;font-size:12px;font-weight:800}.field-input{border:1px solid var(--glass-border);width:100%;color:var(--text-strong);background:#ffffff0f;border-radius:12px;outline:none;padding:11px 14px;font-size:15px;transition:border-color .15s,background .15s}.field-input:focus{border-color:var(--accent-blue);background:#ffffff17}.field-input:disabled{opacity:.5;cursor:not-allowed}.field-input::placeholder{color:var(--text-muted);opacity:.6}.login-error{color:#e8a0a0;background:#8a50501f;border:1px solid #8a505066;border-radius:10px;padding:10px 14px;font-size:13px;font-weight:700}.btn-primary{color:#f0f2f8;cursor:pointer;background:linear-gradient(135deg,#3a6a90,#2a5a7a);border:none;border-radius:12px;padding:12px 20px;font-size:15px;font-weight:800;transition:opacity .15s,transform .1s}.btn-primary:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.login-submit{margin-top:4px}.auth-loading{min-height:100vh;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:16px;font-size:14px;display:flex}.auth-loading-spinner{border:3px solid #5a8ab033;border-top-color:var(--accent-blue);border-radius:50%;width:36px;height:36px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.sidebar-footer{border-top:1px solid var(--glass-border);flex-direction:column;gap:8px;margin-top:auto;padding-top:12px;display:flex}.sidebar-user{color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;margin-top:2px;font-size:11px;font-weight:700;display:block;overflow:hidden}.btn-logout{border:1px solid var(--glass-border);color:var(--text-muted);cursor:pointer;text-align:left;background:0 0;border-radius:10px;padding:9px 14px;font-size:12px;font-weight:800;transition:background .15s,color .15s}.btn-logout:hover{color:#e8a0a0;background:#8a50501f;border-color:#8a50504d}.btn-logout-sm{border:1px solid var(--glass-border);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:8px;padding:6px 12px;font-size:11px;font-weight:800;transition:background .15s}.btn-logout-sm:hover{color:#e8a0a0;background:#8a50501a}.topbar-right{flex-shrink:0;align-items:center;gap:8px;display:flex}.topbar-user{color:var(--text-muted);font-size:12px;font-weight:700}.worker-pill{border-radius:999px;padding:4px 10px;font-size:10px;font-weight:900}.worker-pill.warn{color:#e8c88f;background:#9a78401f;border:1px solid #9a784059}.worker-warning{color:#e8c88f;cursor:help;background:#9a78401a;border:1px solid #9a78404d;border-radius:8px;padding:7px 10px;font-size:11px;font-weight:800}.migrate-panel{background:#5a8ab00f;border:1px solid #5a8ab040;border-radius:16px;flex-direction:column;gap:12px;padding:18px;display:flex}.migrate-panel>div>strong{color:var(--text-strong);font-family:Kanit,sans-serif;font-size:15px;display:block}.migrate-panel>div>p{color:var(--text-muted);margin:4px 0 0;font-size:12px;line-height:1.5}.migrate-result{border-radius:10px;padding:10px 14px;font-size:13px;font-weight:700}.migrate-result.ok{color:#7acfc0;background:#3a90801a;border:1px solid #3a908059}.migrate-result.error{color:#e8a0a0;background:#8a50501a;border:1px solid #8a505059}.edit-form{border-top:1px solid var(--glass-border);flex-direction:column;gap:12px;margin-top:14px;padding-top:14px;display:flex}.edit-form label{grid-template-columns:110px 1fr;align-items:center;gap:10px;display:grid}.edit-form label.label-stack{grid-template-columns:unset;flex-direction:column;align-items:stretch;gap:6px;display:flex}.edit-form label span{color:var(--text-muted);font-size:12px;font-weight:800}.edit-form input{border:1px solid var(--glass-border);min-height:38px;color:var(--text);background:#ffffff0d;border-radius:10px;padding:0 12px;font-family:inherit;font-size:14px;font-weight:700}.edit-form input:focus{background:#5a8ab012;border-color:#5a8ab08c;outline:none}.edit-form select,.edit-form textarea{background:var(--glass);border:1px solid var(--glass-border);min-height:38px;color:var(--text);box-sizing:border-box;border-radius:10px;width:100%;padding:8px 12px;font-family:inherit;font-size:14px;font-weight:700}.edit-form textarea{resize:vertical;line-height:1.6}.edit-form select:focus,.edit-form textarea:focus{background:#5a8ab012;border-color:#5a8ab08c;outline:none}.edit-form select option{background:var(--bg);color:var(--text)}.audit-total.warning strong{color:#c8a040}[data-theme=light] .audit-total.warning strong{color:#8a6010}.payment-input-group{background:#3a90800f;border:1px solid #3a90802e;border-radius:14px;flex-direction:column;gap:12px;margin-top:14px;padding:14px;display:flex}.payment-input-group label{grid-template-columns:120px 1fr;align-items:center;gap:10px;display:grid}.payment-input-group label span{color:var(--text-muted);font-size:12px;font-weight:800}.payment-input-group input{border:1px solid var(--glass-border);min-height:38px;color:var(--text);background:#ffffff0d;border-radius:10px;padding:0 12px;font-family:inherit;font-size:14px;font-weight:700}.payment-input-group input:focus{border-color:#3a90808c;outline:none}.payment-input-group .primary-action{margin-top:4px}.payment-history-list{flex-direction:column;gap:8px;margin-top:14px;display:flex}.payment-history-list .eyebrow{letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);margin:0 0 4px;font-size:11px;font-weight:900}.payment-history-row{border:1px solid var(--glass-border);background:#ffffff0a;border-radius:10px;justify-content:space-between;align-items:center;gap:10px;padding:10px 12px;display:flex}.payment-history-row>div{flex:1;align-items:center;gap:10px;min-width:0;display:flex}.payment-history-row strong{color:#7acfc0;white-space:nowrap;font-size:15px;font-weight:900}.payment-history-row span{color:var(--text-muted);font-size:12px}.payment-history-row em{color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;font-size:12px;font-style:normal;overflow:hidden}.small-button.danger{color:#e8a0a0;border-color:#8a505066}.small-button.danger:hover:not(:disabled){background:#8a505024}.small-button.active{background:var(--g-teal);color:#c8f0e8;border-color:#3a908066}.photo-upload-area{flex-direction:column;gap:8px;margin-top:10px;display:flex}.photo-preview-wrap{align-items:flex-start;gap:8px;display:flex}.photo-preview{object-fit:cover;border:1px solid var(--glass-border);border-radius:10px;width:80px;height:80px}.photo-info{color:var(--text-muted);align-self:center;font-size:11px;font-weight:700}.photo-upload-btn{cursor:pointer;align-self:flex-start}.photo-upload-btn.uploading{opacity:.6;cursor:default}.repair-list{flex-direction:column;gap:14px;display:flex}.repair-card.status-open{border-color:#8a505059}.repair-card.status-in_progress{border-color:#5a8a5059}.repair-card.status-done{border-color:#3a908059}.repair-photo{object-fit:cover;border:1px solid var(--glass-border);border-radius:12px;width:100%;max-height:200px;margin-top:10px}.repair-meta{color:var(--text-muted);gap:10px;margin-top:8px;font-size:12px;font-weight:700;display:flex}.line-type-tabs{flex-wrap:wrap;gap:8px;margin-top:14px;display:flex}.line-message-preview{color:#c8f0e8;white-space:pre-wrap;word-break:break-word;background:#0000004d;border:1px solid #3a908038;border-radius:12px;margin-top:12px;padding:14px;font-family:Sarabun,Kanit,system-ui,sans-serif;font-size:13px;font-weight:600;line-height:1.7}.flex-card-preview{color:#1a1a1a;background:#fff;border:1px solid #ffffff1f;border-radius:16px;margin-top:14px;overflow:hidden;box-shadow:0 8px 24px #00000052}.flex-card-header{flex-direction:column;gap:4px;padding:18px 20px 14px;display:flex}.flex-card-header strong{color:#fff;font-family:Kanit,sans-serif;font-size:18px;font-weight:900}.flex-card-header span{color:#ffffffd1;font-size:13px}.flex-card-body{padding:18px 20px 20px}.flex-card-month{color:#888;margin:0 0 4px;font-size:13px}.flex-card-amount{margin:0;font-family:Kanit,sans-serif;font-size:30px;font-weight:900;line-height:1.1}.flex-card-sep{border:none;border-top:1px solid #e8e8e8;margin:12px 0}.flex-card-rows{flex-direction:column;gap:5px;display:flex}.flex-card-row{justify-content:space-between;align-items:center;font-size:13px;display:flex}.flex-card-row span{color:#666}.flex-card-row strong{font-size:13px;font-weight:700}.btn-theme-toggle{border:1px solid var(--glass-border);color:var(--text-muted);cursor:pointer;text-align:left;background:0 0;border-radius:10px;padding:9px 14px;font-size:12px;font-weight:800;transition:background .15s,color .15s}.btn-theme-toggle:hover{background:var(--glass-hover);color:var(--text-strong)}.btn-theme-toggle-sm{border:1px solid var(--glass-border);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:8px;padding:5px 9px;font-size:14px;line-height:1;transition:background .15s}.btn-theme-toggle-sm:hover{background:var(--glass-hover)}[data-theme=light]{--bg:#eef0f5;--glass:#ffffffbf;--glass-hover:#ffffffeb;--glass-border:#00000017;--glass-strong:#00000024;--text:#2c3040;--text-muted:#3c465fad;--text-strong:#18202e;--g-slate:linear-gradient(135deg, #c8d8e8 0%, #b8cce0 100%);--g-steel:linear-gradient(135deg, #bcd0de 0%, #aac4d4 100%);--g-teal:linear-gradient(135deg, #bce0d8 0%, #a8d4cc 100%);--g-ember:linear-gradient(135deg, #e8d4bc 0%, #dcc8b0 100%);--g-rose:linear-gradient(135deg, #e0c8c8 0%, #d4bcbc 100%);--g-moss:linear-gradient(135deg, #c8d8bc 0%, #bcccb0 100%);--glow-slate:0 4px 14px #5a82aa38;--glow-teal:0 4px 14px #28826e2e;--glow-ember:0 4px 14px #a0643229;--glow-steel:0 4px 14px #3c64822e;--accent-blue:#3a6a90;--accent-teal:#2a8070;--surface:#0000000a;--surface-soft:#00000005;--line:#00000017;--muted:#3c465fa6;--primary:#3a6a90;--primary-strong:#2a5a80;--shadow:0 4px 16px #0000001a, 0 0 0 1px #0000000d}[data-theme=light] body{background:var(--bg);background-image:radial-gradient(at 20% 0,#8cb4dc3d 0%,#0000 55%),radial-gradient(at 85% 12%,#64a0c82e 0%,#0000 55%),radial-gradient(at 5% 90%,#50b4a024 0%,#0000 55%),radial-gradient(at 90% 85%,#c896641a 0%,#0000 55%)}[data-theme=light] body:before{background:radial-gradient(circle,#78aad21f 0%,#0000 70%)}[data-theme=light] body:after{background:radial-gradient(circle,#50b4a01a 0%,#0000 70%)}[data-theme=light] ::-webkit-scrollbar-thumb{background:#00000026}[data-theme=light] ::-webkit-scrollbar-thumb:hover{background:#00000040}[data-theme=light] .topbar h1{background:linear-gradient(135deg,#1a2030 0%,#3a6a90 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}[data-theme=light] .section-title h2,[data-theme=light] .section-title h3,[data-theme=light] .hero-panel h2{background:linear-gradient(135deg,#18202e 0%,#3a5a80 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}[data-theme=light] .eyebrow{color:#3a6a90}[data-theme=light] .bottom-nav{background:#f0f2f8eb;border-color:#00000017;box-shadow:0 8px 24px #0000001f,0 0 0 1px #0000000d}[data-theme=light] .nav-item.active{color:#18303e;box-shadow:none;background:linear-gradient(135deg,#c8d8e8,#b8cce0);border-color:#3a6a9040}[data-theme=light] .desktop-sidebar{background:#f0f2f8e0;border-color:#00000014;box-shadow:0 4px 16px #00000014}[data-theme=light] .sidebar-brand strong{color:var(--text-strong)}[data-theme=light] .sidebar-link.active{color:#18303e;background:linear-gradient(135deg,#c8d8e8,#b8cce0);border-color:#3a6a9038}[data-theme=light] .room-table-row{background:#fff9}[data-theme=light] .tenant-profile-grid>div{background:#0000000a;border-color:#00000012}[data-theme=light] .meter-summary-row,[data-theme=light] .meter-summary-totals>div{background:#fff9;border-color:#00000012}[data-theme=light] .preview-entity{background:#ffffff80;border-color:#00000012}[data-theme=light] .desktop-issue{background:#fff9}[data-theme=light] .desktop-table-panel,[data-theme=light] .desktop-side-panel,[data-theme=light] .desktop-page-head{background:#ffffffb3}[data-theme=light] .line-message-preview{color:#2a4840;background:#ffffffb3;border-color:#28826e40}[data-theme=light] .audit-total strong{color:var(--primary-strong)}[data-theme=light] .payment-history-row strong{color:#2a8070}[data-theme=light] .draft-footer{color:#2a8070;background:#286e600f;border-color:#286e6029}[data-theme=light] .hero-panel{background:#ffffffa6;border-color:#00000017}[data-theme=light] .small-button{color:#3a6a90}[data-theme=light] .room-row-middle strong{color:#2a5a80}[data-theme=light] .migrate-result.ok{color:#1a7060;background:#28826e14;border-color:#28826e40}[data-theme=light] .migrate-result.error{color:#8a2020;background:#8a505014;border-color:#8a505040}[data-theme=light] .migrate-panel{background:#3a6a900f;border-color:#3a6a902e}[data-theme=light] .status-ok{color:#1a7060;background:#28826e1a;border-color:#28826e38}[data-theme=light] .status-warn{color:#7a5820;background:#9a78401a;border-color:#9a784038}[data-theme=light] .count-pill{color:#1a7060;background:#28826e1a;border-color:#28826e38}[data-theme=light] .readonly-pill{color:#3a5a80;background:#3a6a901a;border-color:#3a6a9038}[data-theme=light] .desktop-stat strong{color:var(--primary-strong)}[data-theme=light] .desktop-stat.danger strong,[data-theme=light] .audit-total.danger strong{color:#8a3030}
