@import "https://fonts.googleapis.com/css2?family=Sarabun:wght@300;400;500;600;700;800&family=Prompt:wght@400;600;700;800&display=swap";.react-grid-layout{transition:height .2s;position:relative}.react-grid-item{transition:left .2s,top .2s,width .2s,height .2s}.react-grid-item img{pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-grid-item.cssTransforms{transition-property:transform,width,height}.react-grid-item.resizing{z-index:1;will-change:width, height;transition:none}.react-grid-item.react-draggable-dragging{z-index:3;will-change:transform;transition:none}.react-grid-item.dropping{visibility:hidden}.react-grid-item.react-grid-placeholder{opacity:.2;z-index:2;-webkit-user-select:none;-moz-user-select:none;user-select:none;background:red;transition-duration:.1s}.react-grid-item.react-grid-placeholder.placeholder-resizing{transition:none}.react-grid-item>.react-resizable-handle{opacity:0;width:20px;height:20px;position:absolute}.react-grid-item:hover>.react-resizable-handle{opacity:1}.react-grid-item>.react-resizable-handle:after{content:"";border-bottom:2px solid #0006;border-right:2px solid #0006;width:5px;height:5px;position:absolute;bottom:3px;right:3px}.react-resizable-hide>.react-resizable-handle{display:none}.react-grid-item>.react-resizable-handle.react-resizable-handle-sw{cursor:sw-resize;bottom:0;left:0;transform:rotate(90deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-se{cursor:se-resize;bottom:0;right:0}.react-grid-item>.react-resizable-handle.react-resizable-handle-nw{cursor:nw-resize;top:0;left:0;transform:rotate(180deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-ne{cursor:ne-resize;top:0;right:0;transform:rotate(270deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-w,.react-grid-item>.react-resizable-handle.react-resizable-handle-e{cursor:ew-resize;margin-top:-10px;top:50%}.react-grid-item>.react-resizable-handle.react-resizable-handle-w{left:0;transform:rotate(135deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-e{right:0;transform:rotate(315deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-n,.react-grid-item>.react-resizable-handle.react-resizable-handle-s{cursor:ns-resize;margin-left:-10px;left:50%}.react-grid-item>.react-resizable-handle.react-resizable-handle-n{top:0;transform:rotate(225deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-s{bottom:0;transform:rotate(45deg)}.react-resizable{position:relative}.react-resizable-handle{box-sizing:border-box;background-image:url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCA2IDYiIHN0eWxlPSJiYWNrZ3JvdW5kLWNvbG9yOiNmZmZmZmYwMCIgeD0iMHB4IiB5PSIwcHgiIHdpZHRoPSI2cHgiIGhlaWdodD0iNnB4Ij48ZyBvcGFjaXR5PSIwLjMwMiI+PHBhdGggZD0iTSA2IDYgTCAwIDYgTCAwIDQuMiBMIDQgNC4yIEwgNC4yIDQuMiBMIDQuMiAwIEwgNiAwIEwgNiA2IEwgNiA2IFoiIGZpbGw9IiMwMDAwMDAiLz48L2c+PC9zdmc+);background-position:100% 100%;background-repeat:no-repeat;background-origin:content-box;width:20px;height:20px;padding:0 3px 3px 0;position:absolute}.react-resizable-handle-sw{cursor:sw-resize;bottom:0;left:0;transform:rotate(90deg)}.react-resizable-handle-se{cursor:se-resize;bottom:0;right:0}.react-resizable-handle-nw{cursor:nw-resize;top:0;left:0;transform:rotate(180deg)}.react-resizable-handle-ne{cursor:ne-resize;top:0;right:0;transform:rotate(270deg)}.react-resizable-handle-w,.react-resizable-handle-e{cursor:ew-resize;margin-top:-10px;top:50%}.react-resizable-handle-w{left:0;transform:rotate(135deg)}.react-resizable-handle-e{right:0;transform:rotate(315deg)}.react-resizable-handle-n,.react-resizable-handle-s{cursor:ns-resize;margin-left:-10px;left:50%}.react-resizable-handle-n{top:0;transform:rotate(225deg)}.react-resizable-handle-s{bottom:0;transform:rotate(45deg)}*{box-sizing:border-box;margin:0;padding:0}:root{--green:#22c55e;--green-dark:#16a34a;--green-deeper:#15803d;--green-light:#f0fdf4;--green-mid:#dcfce7;--navy:#1e3a5f;--red:#ef4444;--red-soft:#fef2f2;--orange:#f97316;--orange-soft:#fff7ed;--blue:#3b82f6;--blue-soft:#eff6ff;--bg:#fafbfc;--bg-soft:#f1f5f9;--surface:#fff;--surface-2:#f8fafc;--surface-3:#f1f5f9;--white:#fff;--overlay:#0f172a73;--text:#0f172a;--text-2:#1f2937;--text-light:#64748b;--text-muted:#94a3b8;--text-on-brand:#fff;--border:#e2e8f0;--border-strong:#cbd5e1;--border-soft:#eef2f7;--input-bg:#f8fafc;--input-border:#e2e8f0;--input-focus:var(--green);--input-focus-ring:#22c55e26;--placeholder:#94a3b8;--shadow-xs:0 1px 2px #0f172a0a;--shadow-sm:0 1px 3px #0f172a0f, 0 1px 2px #0f172a0a;--shadow-md:0 4px 12px #0f172a14;--shadow-lg:0 12px 32px #0f172a1f;--shadow-xl:0 24px 60px #0f172a2e;--sidebar-w:230px;--topbar-h:72px;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:20px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spin{animation:1s linear infinite spin}[data-theme=dark]{--green:#22c55e;--green-dark:#4ade80;--green-deeper:#22c55e;--green-light:#22c55e1f;--green-mid:#22c55e38;--navy:#93c5fd;--red:#f87171;--red-soft:#f871711f;--orange:#fb923c;--orange-soft:#fb923c1f;--blue:#60a5fa;--blue-soft:#60a5fa24;--bg:#0b1220;--bg-soft:#0f172a;--surface:#131c2f;--surface-2:#182236;--surface-3:#1e2a44;--white:#131c2f;--text-muted:#64748b;--input-bg:#182236;--input-border:#243049;--text:#e7eaf2;--text-2:#d6dbe6;--text-light:#94a3b8;--text-on-brand:#06210f;--border:#243049;--border-strong:#346;--border-soft:#1a2438;--input-focus:var(--green);--input-focus-ring:#22c55e40;--placeholder:#64748b;--shadow-xs:0 1px 2px #0006;--shadow-sm:0 1px 3px #00000073, 0 1px 2px #0006;--shadow-md:0 4px 12px #00000080;--shadow-lg:0 12px 32px #0000008c;--shadow-xl:0 24px 60px #0009;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}.desktop-only{display:block}.mobile-only{display:none}@media (max-width:768px){.desktop-only{display:none!important}.mobile-only{display:block!important}.mobile-only.av-menu-item{display:flex!important}}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;font-family:Sarabun,sans-serif;transition:background-color .3s,color .3s;overflow-x:hidden}::selection{background:var(--green-mid);color:var(--text)}::placeholder{color:var(--placeholder)}*{scrollbar-width:thin;scrollbar-color:var(--border-strong) transparent}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-strong);background-clip:content-box;border:2px solid #0000;border-radius:8px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted);background-clip:content-box}h1,h2,h3,.page-title,.modal-title,.auth-title,.landing-title{font-family:Prompt,sans-serif}.page{min-height:100vh;display:none}.page.active{flex-direction:column;display:flex}#landing{background:var(--bg)}.landing-nav{background:var(--surface);border-bottom:1px solid var(--border);z-index:10;-webkit-backdrop-filter:saturate(140%)blur(8px);backdrop-filter:saturate(140%)blur(8px);justify-content:space-between;align-items:center;padding:14px 40px;display:flex;position:-webkit-sticky;position:sticky;top:0}.logo{color:var(--navy);font-family:Prompt,sans-serif;font-size:20px;font-weight:700}.btn-signin{background:var(--green);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:9px 22px;font-family:Sarabun,sans-serif;font-size:14px;font-weight:600;transition:background .2s}.btn-signin:hover{background:var(--green-dark)}.landing-body{flex:1;grid-template-columns:1fr 1.2fr;align-items:start;gap:40px;width:100%;max-width:1200px;margin:0 auto;padding:50px 60px;display:grid}.landing-tag{color:var(--green-dark);letter-spacing:1px;margin-bottom:10px;font-size:12px;font-weight:700}.landing-title{color:var(--green);margin-bottom:14px;font-family:Prompt,sans-serif;font-size:52px;font-weight:800;line-height:1.1}.landing-sub{color:var(--text-light);margin-bottom:28px;font-size:15px}.landing-banner{color:#fff;background:linear-gradient(135deg,#1e3a5f,#16a34a);border-radius:16px;justify-content:center;align-items:center;height:220px;font-family:Prompt,sans-serif;font-size:28px;font-weight:800;display:flex;position:relative;overflow:hidden}.landing-banner:before{content:"🏢";opacity:.15;font-size:80px;position:absolute;right:20px}.landing-right{flex-direction:column;gap:20px;display:flex}.role-cards{grid-template-columns:1fr 1fr;gap:16px;display:grid}.role-card{background:var(--surface);box-shadow:var(--shadow-sm);cursor:pointer;border:2px solid #0000;border-radius:16px;padding:28px 24px;transition:transform .2s,box-shadow .2s,border-color .2s}.role-card:hover{border-color:var(--green);box-shadow:var(--shadow-md);transform:translateY(-2px)}.role-icon{border-radius:12px;justify-content:center;align-items:center;width:48px;height:48px;margin-bottom:16px;font-size:22px;display:flex}.role-icon.owner{background:#e8f4f8}.role-icon.tenant{background:#f0eeff}.role-name{color:var(--navy);margin-bottom:6px;font-family:Prompt,sans-serif;font-size:18px;font-weight:700}.role-desc{color:var(--text-light);margin-bottom:20px;font-size:13px}.role-enter{color:var(--navy);align-items:center;gap:6px;font-size:14px;font-weight:700;display:flex}.promo-banner{background:var(--green-deeper);color:#fff;border-radius:16px;align-items:center;gap:20px;padding:24px 28px;display:flex}.promo-btn{color:#fff;cursor:pointer;white-space:nowrap;background:#fff3;border:1px solid #fff6;border-radius:8px;padding:8px 18px;font-family:Sarabun,sans-serif;font-size:13px;font-weight:600}.promo-btn:hover{background:#ffffff59}.promo-text .promo-title{margin-bottom:4px;font-size:17px;font-weight:700}.promo-text .promo-sub{opacity:.8;font-size:13px}.landing-footer{background:var(--surface);border-top:1px solid var(--border);color:var(--text-light);justify-content:space-between;padding:18px 60px;font-size:13px;display:flex}.auth-page{background:var(--bg);flex-direction:column}.auth-nav{background:var(--surface);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:14px 40px;display:flex}.auth-nav-right{align-items:center;gap:20px;display:flex}.auth-nav-right a{color:var(--text-light);cursor:pointer;font-size:14px}.auth-body{flex:1;justify-content:center;align-items:flex-start;padding:32px 20px 60px;display:flex}@media (max-width:720px){.auth-body{padding:20px 12px 40px}}.auth-card{background:var(--surface);box-shadow:var(--shadow-lg);border:1px solid var(--border-soft);border-radius:20px;grid-template-columns:1fr 1fr;width:900px;max-width:100%;min-height:520px;display:grid;overflow:hidden}.auth-left-panel{background:linear-gradient(#1a3a5c 0%,#1e6040 100%);flex-direction:column;justify-content:flex-end;padding:40px;display:flex;position:relative;overflow:hidden}.auth-left-panel:before{content:"";opacity:.5;background:url("data:image/svg+xml,<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 400 500\"><rect width=\"400\" height=\"500\" fill=\"%231a3a5c\"/><rect x=\"80\" y=\"80\" width=\"240\" height=\"320\" rx=\"8\" fill=\"%23ffffff08\"/><rect x=\"100\" y=\"100\" width=\"55\" height=\"90\" rx=\"4\" fill=\"%23ffffff12\"/><rect x=\"165\" y=\"100\" width=\"55\" height=\"90\" rx=\"4\" fill=\"%23ffffff12\"/><rect x=\"230\" y=\"100\" width=\"55\" height=\"90\" rx=\"4\" fill=\"%23ffffff12\"/><rect x=\"100\" y=\"200\" width=\"55\" height=\"90\" rx=\"4\" fill=\"%23ffffff10\"/><rect x=\"165\" y=\"200\" width=\"55\" height=\"90\" rx=\"4\" fill=\"%23ffffff10\"/><rect x=\"230\" y=\"200\" width=\"55\" height=\"90\" rx=\"4\" fill=\"%23ffffff10\"/></svg>") 50%/cover;position:absolute;top:0;bottom:0;left:0;right:0}.auth-left-text{z-index:1;position:relative}.auth-left-text h2{color:#fff;margin-bottom:12px;font-family:Prompt,sans-serif;font-size:26px;font-weight:800;line-height:1.3}.auth-left-text p{color:#ffffffbf;font-size:14px;line-height:1.6}.auth-right-panel{flex-direction:column;justify-content:center;padding:48px 44px;display:flex}.auth-title{color:var(--green);margin-bottom:32px;font-family:Prompt,sans-serif;font-size:38px;font-weight:800}.form-group{margin-bottom:20px}.form-label{color:var(--text-light);letter-spacing:.8px;margin-bottom:8px;font-size:12px;font-weight:700;display:block}.form-input{background:var(--input-bg);border:1.5px solid var(--input-border);width:100%;color:var(--text);z-index:10;pointer-events:auto;border-radius:10px;outline:none;padding:12px 16px;font-family:Sarabun,sans-serif;font-size:14px;transition:border-color .2s;position:relative}.form-input:focus{border-color:var(--green)}.input-wrap{position:relative}.input-wrap input{background:var(--input-bg);border:1.5px solid var(--input-border);width:100%;color:var(--text);border-radius:10px;outline:none;padding:12px 16px 12px 42px;font-family:Sarabun,sans-serif;font-size:14px;transition:border-color .2s}.input-wrap input:focus{border-color:var(--green)}.input-icon{font-size:16px;position:absolute;top:50%;left:14px;transform:translateY(-50%)}.input-eye{cursor:pointer;font-size:16px;position:absolute;top:50%;right:14px;transform:translateY(-50%)}.form-row{grid-template-columns:1fr 1fr;gap:14px;display:grid}.btn-primary{background:var(--green-deeper);color:#fff;cursor:pointer;border:none;border-radius:10px;justify-content:center;align-items:center;gap:8px;width:100%;margin-top:8px;padding:14px;font-family:Sarabun,sans-serif;font-size:15px;font-weight:700;transition:background .2s;display:flex}.btn-primary:hover{background:var(--green-dark)}.auth-footer-link{text-align:center;color:var(--text-light);margin-top:24px;font-size:14px}.auth-footer-link a{color:var(--green-dark);cursor:pointer;font-weight:700;text-decoration:none}.auth-footer-link a:hover{text-decoration:underline}.form-hint{color:var(--text-light);margin-top:4px;font-size:12px}.role-selector{grid-template-columns:1fr 1fr;gap:12px;display:grid}.role-opt{border:2px solid var(--border);cursor:pointer;border-radius:10px;align-items:center;gap:10px;padding:14px;transition:all .2s;display:flex}.role-opt.selected{border-color:var(--green);background:var(--green-light)}.role-opt-icon{font-size:20px}.role-opt-info .role-opt-name{color:var(--navy);font-size:14px;font-weight:700}.role-opt-info .role-opt-desc{color:var(--text-light);font-size:12px}.auth-page-footer{color:var(--text-light);padding:16px 40px;font-size:13px}#dashboard{flex-direction:row;min-height:100vh}.sidebar{width:var(--sidebar-w);background:var(--surface);border-right:1px solid var(--border);flex-direction:column;height:100vh;display:flex;position:-webkit-sticky;position:sticky;top:0;overflow-y:auto}.sidebar-logo{height:var(--topbar-h);border-bottom:1px solid var(--border);cursor:pointer;box-sizing:border-box;align-items:center;gap:10px;padding:0 18px;transition:background .15s;display:flex}.sidebar-logo:hover{background:var(--surface-2)}.sidebar-logo-icon{flex-shrink:0;justify-content:center;align-items:center;display:flex}.sidebar-logo-icon img{object-fit:contain;width:40px;height:40px}[data-theme=dark] img[src$="/logo.png"]{filter:invert()}.sidebar-logo-text{color:var(--text);letter-spacing:-.5px;background:linear-gradient(135deg, var(--green) 0%, var(--green-dark) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-family:Prompt,sans-serif;font-size:22px;font-weight:800}.sidebar-logo-sub{color:var(--text-light);letter-spacing:.3px;margin-top:1px;font-family:Sarabun,sans-serif;font-size:10px;font-weight:600}.sidebar-nav{flex:1;padding:12px 0}.nav-item{cursor:pointer;color:var(--text);border-left:3px solid #0000;align-items:center;gap:12px;padding:12px 20px;font-size:14px;font-weight:500;transition:all .15s;display:flex}.mobile-toggle{cursor:pointer;width:40px;height:40px;color:var(--text);border-radius:10px;justify-content:center;align-items:center;margin-right:8px;display:none}.mobile-toggle:hover{background:var(--bg-soft)}@media (max-width:768px){.mobile-toggle{display:flex}}.nav-item:hover{background:var(--green-light);color:var(--green-dark)}.nav-item.active{background:var(--green-light);color:var(--green-dark);border-left-color:var(--green);font-weight:700}.nav-icon{text-align:center;width:22px;font-size:18px}.sidebar-bottom{border-top:1px solid var(--border);padding:12px 0}.dash-main{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.topbar{background:var(--surface);border-bottom:1px solid var(--border);height:var(--topbar-h);z-index:50;-webkit-backdrop-filter:saturate(140%)blur(8px);backdrop-filter:saturate(140%)blur(8px);justify-content:space-between;align-items:center;padding:0 28px;display:flex;position:-webkit-sticky;position:sticky;top:0}.topbar-tabs{align-items:center;display:flex}.topbar-tab{color:var(--text-light);cursor:pointer;border-bottom:2px solid #0000;padding:8px 18px;font-size:14px;font-weight:600}.topbar-tab.active{color:var(--text);border-bottom-color:var(--green)}.topbar-right{align-items:center;gap:16px;display:flex;position:relative}.topbar-icon{cursor:pointer;width:40px;height:40px;color:var(--text);border-radius:10px;justify-content:center;align-items:center;font-size:24px;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex}.topbar-icon:hover{background:var(--bg-soft);color:var(--green-dark);transform:translateY(-1px)}.topbar-icon:active{transform:translateY(0)scale(.95)}.material-symbols-outlined{font-variation-settings:"wght" 450, "opsz" 24}.avatar{background:linear-gradient(135deg, var(--navy), var(--green-dark));color:#fff;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-size:16px;transition:all .2s;display:flex;box-shadow:0 2px 8px #00000026}.avatar:hover{transform:scale(1.08)}.av-wrap{position:relative}.avatar-dropdown{background:var(--surface);box-shadow:var(--shadow-xl);border:1px solid var(--border-soft);z-index:200;opacity:0;pointer-events:none;border-radius:16px;width:230px;transition:all .2s cubic-bezier(.34,1.56,.64,1);position:absolute;top:46px;right:0;overflow:hidden;transform:translateY(-10px)scale(.97)}.avatar-dropdown.open{opacity:1;pointer-events:all;transform:translateY(0)scale(1)}.av-profile{border-bottom:1px solid var(--border);background:var(--green-light);align-items:center;gap:12px;padding:18px 16px;display:flex}.av-profile-pic{background:linear-gradient(135deg, var(--navy), var(--green-dark));color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:46px;height:46px;font-size:22px;display:flex}.av-profile-info .av-name{color:var(--text);font-size:14px;font-weight:700}.av-profile-info .av-role{color:var(--green-dark);margin-top:2px;font-size:12px;font-weight:600}.av-menu-item{color:var(--text);cursor:pointer;align-items:center;gap:10px;padding:12px 16px;font-size:14px;transition:background .15s;display:flex}.av-menu-item:hover{background:var(--surface-2)}.av-mi-icon{text-align:center;width:20px;font-size:17px}.av-divider{border-top:1px solid var(--border);margin:4px 0}.av-logout{font-weight:600;color:var(--red)!important}.av-logout:hover{background:var(--red-soft)!important}.dash-content{height:calc(100vh - var(--topbar-h));background:var(--bg);flex:1;padding:28px 32px;overflow-y:auto}.page-title{color:var(--text);margin-bottom:6px;font-family:Prompt,sans-serif;font-size:22px;font-weight:700}.page-sub{color:var(--text-light);margin-bottom:24px;font-size:13px}.stat-grid{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px;display:grid}.stat-card{background:var(--surface);border:1px solid var(--border-soft);box-shadow:var(--shadow-xs);border-radius:12px;align-items:center;gap:12px;padding:14px 16px;transition:transform .2s,box-shadow .2s,border-color .2s;display:flex}.stat-card:hover{box-shadow:var(--shadow-sm);border-color:var(--border);transform:translateY(-1px)}.sc-label{color:var(--text-light);letter-spacing:.3px;margin-bottom:0;font-size:11px;font-weight:600}.sc-value{color:var(--text);font-family:Prompt,sans-serif;font-size:20px;font-weight:700;line-height:1}.sc-sub{margin-left:4px;font-size:12px}.sc-green{color:var(--green-dark)}.sc-red{color:var(--red)}.sc-orange{color:var(--orange)}.card{background:var(--surface);border:1px solid var(--border-soft);border-radius:var(--radius-lg);box-shadow:var(--shadow-xs);overflow:hidden}.card-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:18px 22px;display:flex}.card-title{color:var(--text);font-size:15px;font-weight:700}.btn-sm{cursor:pointer;border:none;border-radius:8px;padding:7px 16px;font-family:Sarabun,sans-serif;font-size:13px;font-weight:600}.btn-sm-green{background:var(--green-light);color:var(--green-dark)}.btn-sm-green:hover{background:var(--green-mid)}.btn-sm-outline{background:var(--surface);color:var(--text);border:1.5px solid var(--border);transition:background .2s,border-color .2s}.btn-sm-outline:hover{background:var(--surface-2);border-color:var(--border-strong)}table{border-collapse:collapse;width:100%;min-width:600px}th{text-align:left;color:var(--text-light);letter-spacing:.5px;background:var(--surface-2);border-bottom:1px solid var(--border);padding:12px 22px;font-size:12px;font-weight:700}td{border-bottom:1px solid var(--border-soft);color:var(--text);padding:14px 22px;font-size:14px}tr:last-child td{border-bottom:none}tr:hover td{background:var(--surface-2)}.table-responsive{-webkit-overflow-scrolling:touch;overflow-x:auto}.badge{border-radius:20px;align-items:center;padding:3px 10px;font-size:12px;font-weight:600;display:inline-flex}.badge-green{background:var(--green-light);color:var(--green-dark)}.badge-red{background:var(--red-soft);color:var(--red)}.badge-orange{background:var(--orange-soft);color:var(--orange)}.badge-blue{background:var(--blue-soft);color:var(--blue)}.badge-gray{background:var(--surface-3);color:var(--text-light)}.room-grid{grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:10px;display:grid}.room-box{text-align:center;cursor:pointer;border:2px solid #0000;border-radius:10px;padding:14px 8px;transition:all .2s}.room-box:hover{transform:translateY(-2px)}.rm-occupied{background:var(--green-mid);border-color:var(--green)}.rm-occupied .rm-num{color:var(--green-dark);font-family:Prompt,sans-serif;font-size:16px;font-weight:700}.rm-occupied .rm-status{color:var(--green-dark);margin-top:3px;font-size:11px}.rm-empty{background:var(--surface-2);border-color:var(--border)}.rm-empty .rm-num{color:var(--text-light);font-family:Prompt,sans-serif;font-size:16px;font-weight:700}.rm-empty .rm-status{color:var(--text-light);margin-top:3px;font-size:11px}.rm-maintenance{background:var(--orange-soft);border-color:var(--orange)}.rm-maintenance .rm-num{color:var(--orange);font-family:Prompt,sans-serif;font-size:16px;font-weight:700}.rm-maintenance .rm-status{color:var(--orange);margin-top:3px;font-size:11px}.cal-grid{grid-template-columns:repeat(7,1fr);gap:2px;display:grid}.cal-day-name{text-align:center;color:var(--text-light);padding:8px 0;font-size:12px;font-weight:700}.cal-day{text-align:center;cursor:pointer;border-radius:8px;flex-direction:column;justify-content:center;align-items:center;min-height:36px;padding:8px 4px;font-size:13px;transition:background .15s;display:flex}.cal-day:hover{background:var(--surface-2)}.cal-day.today{background:var(--green);color:#fff;font-weight:700}.cal-day.other-month{color:var(--text-muted);opacity:.5}.meter-grid{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}.meter-bar{background:var(--border);border-radius:3px;height:6px;margin-bottom:8px;overflow:hidden}.meter-fill{border-radius:3px;height:100%}.two-col{grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px;display:grid}.profile-grid{grid-template-columns:280px 1fr;gap:20px;display:grid}.profile-card{background:var(--surface);border:1px solid var(--border-soft);box-shadow:var(--shadow-xs);text-align:center;border-radius:14px;padding:28px}.profile-avatar{background:linear-gradient(135deg, var(--navy), var(--green-dark));color:#fff;border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;margin:0 auto 16px;font-size:36px;display:flex}.profile-stats{grid-template-columns:1fr 1fr;gap:10px;margin-top:16px;display:grid}.profile-stat{background:var(--surface-2);border:1px solid var(--border-soft);border-radius:10px;padding:12px}.ps-val{color:var(--green-dark);font-family:Prompt,sans-serif;font-size:20px;font-weight:800}.ps-label{color:var(--text-light);font-size:11px}.edit-form{background:var(--surface);border:1px solid var(--border-soft);box-shadow:var(--shadow-xs);border-radius:14px;padding:28px}.ef-grid{grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px;display:grid}.ef-label{color:var(--text-light);letter-spacing:.5px;margin-bottom:6px;font-size:12px;font-weight:700}.ef-input{background:var(--input-bg);border:1.5px solid var(--input-border);z-index:10;pointer-events:auto;border-radius:10px;outline:none;width:100%;padding:11px 14px;font-family:Sarabun,sans-serif;font-size:14px;position:relative}.ef-input:focus{border-color:var(--green)}.setting-section{background:var(--surface);border:1px solid var(--border-soft);box-shadow:var(--shadow-xs);border-radius:14px;margin-bottom:16px;overflow:hidden}.setting-section-title{border-bottom:1px solid var(--border);color:var(--text-light);padding:16px 22px;font-size:14px;font-weight:700}.setting-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:16px;padding:16px 22px;display:flex}.setting-row:last-child{border-bottom:none}.sr-label{font-size:14px;font-weight:600}.sr-desc{color:var(--text-light);margin-top:2px;font-size:12px}.toggle{background:var(--border);cursor:pointer;border-radius:12px;flex-shrink:0;width:44px;height:24px;transition:background .2s;position:relative}.toggle.on{background:var(--green)}.toggle:after{content:"";background:#fff;border-radius:50%;width:18px;height:18px;transition:transform .2s;position:absolute;top:3px;left:3px;box-shadow:0 1px 4px #0003}.toggle.on:after{transform:translate(20px)}.parking-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:16px;margin-bottom:24px;display:grid}.parking-spot{text-align:center;cursor:pointer;background:var(--surface);box-shadow:var(--shadow-sm);border:2px solid #0000;border-radius:16px;flex-direction:column;justify-content:center;align-items:center;min-height:85px;padding:16px 12px;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex;position:relative}.parking-spot:after{content:"";background:#0000000d;border-radius:2px;height:3px;position:absolute;bottom:8px;left:20%;right:20%}.parking-spot:hover{box-shadow:var(--shadow-md);z-index:2;transform:translateY(-4px)scale(1.02)}.pk-taken{background:var(--orange-soft);border-color:var(--orange-light)}.pk-taken:after{background:var(--orange)}.pk-taken .pk-num{color:var(--orange-dark)}.pk-free{background:var(--green-light);border-color:var(--green-soft)}.pk-free:after{background:var(--green)}.pk-free .pk-num{color:var(--green-dark)}.pk-reserved{background:var(--blue-soft);border-color:var(--blue-light)}.pk-reserved:after{background:var(--blue)}.pk-reserved .pk-num{color:var(--blue-dark)}.pk-num{font-family:Prompt,sans-serif;font-size:15px;font-weight:800}.pk-info{margin-top:3px;font-size:11px}.market-grid{grid-template-columns:repeat(auto-fill,minmax(175px,1fr));gap:16px;padding:22px;display:grid}.market-item{background:var(--surface-2);border:2px solid var(--border-soft);cursor:pointer;border-radius:12px;padding:16px;transition:all .2s}.market-item:hover{border-color:var(--green);background:var(--green-light);transform:translateY(-2px)}.mi-img{margin-bottom:10px;font-size:36px}.mi-name{margin-bottom:4px;font-size:14px;font-weight:700}.mi-price{color:var(--green-dark);font-family:Prompt,sans-serif;font-size:16px;font-weight:800}.mi-seller{color:var(--text-light);margin-top:4px;font-size:12px}.notif-item{border-bottom:1px solid var(--border);align-items:flex-start;gap:14px;padding:16px 22px;display:flex}.notif-item:last-child{border-bottom:none}.ni-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px;margin-top:4px}.ni-title{margin-bottom:3px;font-size:14px;font-weight:600}.ni-desc{color:var(--text-light);font-size:13px}.ni-time{color:var(--text-light);white-space:nowrap;flex-shrink:0;margin-left:auto;font-size:12px}.parcel-item{border-bottom:1px solid var(--border);align-items:center;gap:14px;padding:14px 22px;display:flex}.parcel-item:last-child{border-bottom:none}.support-item{border-bottom:1px solid var(--border);cursor:pointer;align-items:center;gap:14px;padding:16px 22px;display:flex}.support-item:hover{background:var(--surface-2)}.support-item:last-child{border-bottom:none}.si-icon{border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:20px;display:flex}.si-title{font-size:14px;font-weight:700}.si-desc{color:var(--text-light);margin-top:2px;font-size:12px}.modal-overlay{background:var(--overlay);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:1000;justify-content:center;align-items:flex-start;padding:20px;animation:.2s modal-fade-bg;display:flex;position:fixed;top:0;bottom:0;left:0;right:0;overflow-y:auto}.modal-container{background:var(--surface);border:1px solid var(--border-soft);width:100%;max-width:520px;box-shadow:var(--shadow-xl);max-height:90vh;color:var(--text);border-radius:18px;flex-direction:column;margin:auto;animation:.25s cubic-bezier(.34,1.56,.64,1) modal-pop-in;display:flex}.modal-header{background:linear-gradient(135deg, var(--navy), var(--green-deeper));border-radius:18px 18px 0 0;flex-shrink:0;justify-content:space-between;align-items:center;padding:18px 24px;display:flex}.modal-title{color:#fff;font-family:Prompt,sans-serif;font-size:17px;font-weight:700}.modal-close{color:#fff;cursor:pointer;background:#ffffff26;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:20px;transition:background .2s;display:flex}.modal-close:hover{background:#ffffff4d}.modal-body{flex:1;padding:24px;overflow-y:auto}@keyframes modal-fade-bg{0%{opacity:0}to{opacity:1}}@keyframes modal-pop-in{0%{opacity:0;transform:scale(.92)translateY(10px)}to{opacity:1;transform:scale(1)translateY(0)}}.input{background:var(--input-bg);border:1.5px solid var(--input-border);width:100%;color:var(--text);z-index:10;pointer-events:auto;border-radius:10px;outline:none;padding:11px 14px;font-family:Sarabun,sans-serif;font-size:14px;transition:border-color .2s,box-shadow .2s;position:relative}.input:focus{border-color:var(--green);box-shadow:0 0 0 3px #22c55e1f}.input::placeholder{color:var(--placeholder)}.btn{cursor:pointer;border:none;border-radius:10px;align-items:center;gap:6px;padding:10px 22px;font-family:Sarabun,sans-serif;font-size:14px;font-weight:600;transition:all .2s;display:inline-flex}.btn-green{background:var(--green);color:#fff}.btn-green:hover{background:var(--green-dark);transform:translateY(-1px);box-shadow:0 4px 12px #22c55e4d}.btn-outline{background:var(--surface);color:var(--text);border:1.5px solid var(--border)}.btn-outline:hover{background:var(--surface-2);border-color:var(--border-strong)}.btn-sm-red{background:var(--red-soft);color:var(--red)}.btn-sm-red:hover{background:var(--red-soft);filter:brightness(.97)}.grid-2{grid-template-columns:1fr 1fr;gap:20px;display:grid}.grid-3{grid-template-columns:1fr 1fr 1fr;gap:20px;display:grid}.grid-4{grid-template-columns:1fr 1fr 1fr 1fr;gap:20px;display:grid}.flex-between{justify-content:space-between;align-items:center;gap:16px;display:flex}@media (max-width:768px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr!important;gap:12px!important}.flex-between{flex-direction:column;align-items:flex-start;gap:12px}.flex-between>*{width:100%}}.toast{background:var(--green-deeper);color:#fff;z-index:9999;border-radius:12px;padding:14px 22px;font-size:14px;font-weight:600;animation:.3s slideUp;position:fixed;bottom:30px;right:30px;box-shadow:0 8px 24px #0003}.sidebar-overlay{display:none}.mobile-toggle{cursor:pointer;color:var(--text);margin-right:12px;font-size:20px;display:none}@media (max-width:1024px){.stat-grid{grid-template-columns:repeat(2,1fr)}.two-col,.profile-grid{grid-template-columns:1fr}.meter-grid{grid-template-columns:1fr 1fr}.ef-grid{grid-template-columns:1fr}}@media (max-width:768px){:root{--sidebar-w:260px}.sidebar{z-index:1000;transition:transform .3s;position:fixed;transform:translate(-100%);box-shadow:10px 0 30px #0000001a}.sidebar.open{transform:translate(0)}.sidebar-overlay{background:var(--overlay);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:900;display:block;position:fixed;top:0;bottom:0;left:0;right:0}.mobile-toggle{display:block}.dash-content{padding:16px}.topbar{padding:0 16px}.topbar-prop-label,.topbar-switch-btn{display:none}.stat-grid{grid-template-columns:1fr 1fr;gap:10px}.sc-value{font-size:20px}.card-header{flex-direction:column;align-items:flex-start;gap:10px}.card-header .btn-sm{width:100%}.form-row{grid-template-columns:1fr!important;gap:12px!important}.ef-grid{grid-template-columns:1fr}.auth-card{grid-template-columns:1fr;width:100%;min-height:auto}.auth-left-panel{display:none}.auth-right-panel{padding:32px 20px}.landing-nav{padding:14px 20px}.landing-body{text-align:center;grid-template-columns:1fr;padding:30px 20px}.landing-title{font-size:36px}.role-cards{grid-template-columns:1fr}.table-responsive table{min-width:500px}.modal-overlay{align-items:stretch;padding:0}.modal-container{width:100%;max-width:100%;height:100vh;height:100dvh;max-height:100vh;border-radius:0;max-height:100dvh;margin:0}.modal-header{border-radius:0}.modal-body{padding:16px}}@media (max-width:480px){.stat-grid{grid-template-columns:1fr}.sc-value{font-size:22px}.page-title{font-size:18px}.toast{text-align:center;padding:12px;font-size:13px;bottom:16px;left:16px;right:16px}.hide-mobile{display:none}.topbar-tab{padding:8px 10px;font-size:13px}}.dropdown{display:inline-block;position:relative}.dropdown-content{background-color:var(--surface);border:1px solid var(--border-soft);min-width:180px;box-shadow:var(--shadow-lg);z-index:100;border-radius:8px;display:none;position:absolute;top:100%;left:0;overflow:hidden}.dropdown-content a{color:var(--text);cursor:pointer;padding:12px 16px;font-size:14px;text-decoration:none;display:block}.dropdown-content a:hover{background-color:var(--surface-2)}.dropdown:hover .dropdown-content{display:block}.btn-blue{background:var(--blue);color:#fff;border:none}.btn-blue:hover{background:#2563eb;transform:translateY(-1px);box-shadow:0 4px 12px #3b82f64d}.form-label-premium{color:var(--navy);margin-bottom:6px;font-family:Prompt,sans-serif;font-size:13px;font-weight:700;display:block}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (max-width:640px){.stat-grid{grid-template-columns:repeat(2,1fr)!important;gap:8px!important}.sc-value{font-size:18px!important}.card{border-radius:12px!important}.card-header{padding:14px 16px!important}.dash-content{padding:12px!important}}@media (max-width:400px){.stat-grid{grid-template-columns:1fr!important}}.theme-segment{background:var(--surface-2);border:1px solid var(--border);border-radius:999px;gap:2px;padding:4px;display:inline-flex}.theme-segment button{-webkit-appearance:none;-moz-appearance:none;appearance:none;color:var(--text-light);cursor:pointer;background:0 0;border:0;border-radius:999px;align-items:center;gap:6px;padding:8px 18px;font-family:Sarabun,sans-serif;font-size:13px;font-weight:600;transition:color .2s,background .2s,box-shadow .2s;display:inline-flex}.theme-segment button:hover{color:var(--text)}.theme-segment button.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-xs)}.theme-segment .material-symbols-outlined{font-size:18px}[data-theme=dark] img.invertable{filter:invert(.9)hue-rotate(180deg)}[data-theme=dark] [style*="background: white"],[data-theme=dark] [style*=background\:white],[data-theme=dark] [style*="background: #fff"],[data-theme=dark] [style*="background:#fff"],[data-theme=dark] [style*="background-color: white"],[data-theme=dark] [style*=background-color\:white]{background:var(--surface)!important}[data-theme=dark] [style*="background: #f1f5f9"],[data-theme=dark] [style*="background: #f8fafc"],[data-theme=dark] [style*="background: #f9fafb"],[data-theme=dark] [style*="background: #fafafa"],[data-theme=dark] [style*="background: #f3f4f6"]{background:var(--surface-2)!important}[data-theme=dark] [style*="color: #1e293b"],[data-theme=dark] [style*="color: #1f2937"],[data-theme=dark] [style*="color: #0f172a"]{color:var(--text)!important}[data-theme=dark] [style*="color: #64748b"],[data-theme=dark] [style*="color: #6b7280"]{color:var(--text-light)!important}[data-theme=dark] [style*="border: 1px solid #f1f5f9"],[data-theme=dark] [style*="border: 1px solid #e2e8f0"],[data-theme=dark] [style*="border: 2px solid #e2e8f0"],[data-theme=dark] [style*="border: 1px solid #e5e7eb"],[data-theme=dark] [style*="border: 1px solid #d1d5db"]{border-color:var(--border)!important}[data-theme=dark] [style*="background: #fefce8"],[data-theme=dark] [style*="background: #fef9c3"]{color:var(--text)!important;background:#eab3081f!important}[data-theme=dark] [style*="background: #fef2f2"],[data-theme=dark] [style*="background: #fee2e2"]{background:var(--red-soft)!important}[data-theme=dark] [style*="background: #fff7ed"],[data-theme=dark] [style*="background: #ffedd5"]{background:var(--orange-soft)!important}[data-theme=dark] [style*="background: #f0fdf4"],[data-theme=dark] [style*="background: #dcfce7"]{background:var(--green-light)!important}[data-theme=dark] [style*="background: #eff6ff"],[data-theme=dark] [style*="background: #dbeafe"]{background:var(--blue-soft)!important}[data-theme=dark] [style*="background: #e5e7eb"],[data-theme=dark] [style*="background: #d1d5db"]{background:var(--surface-3)!important}:focus-visible{outline:2px solid var(--green);outline-offset:2px;border-radius:6px}button:focus-visible{outline:2px solid var(--green);outline-offset:2px}a:focus-visible{outline:2px solid var(--green);outline-offset:2px}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}.meter-layout{grid-template-columns:240px 1fr;align-items:start;gap:18px;display:grid}.meter-sidebar{flex-direction:column;gap:14px;display:flex}.meter-card{background:var(--surface);border:1px solid var(--border-soft);box-shadow:var(--shadow-xs);border-radius:14px;padding:14px 16px}.meter-card-title{color:var(--text);margin-bottom:10px;font-family:Sarabun,sans-serif;font-size:12px;font-weight:700}.meter-rate-row{justify-content:space-between;align-items:center;padding:6px 0;font-size:13px;display:flex}.meter-main{background:var(--surface);border:1px solid var(--border-soft);box-shadow:var(--shadow-xs);border-radius:14px;overflow:hidden}.meter-toolbar{border-bottom:1px solid var(--border-soft);flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:14px;padding:14px 18px;display:flex}.meter-pill{border:1px solid var(--border);background:var(--surface);color:var(--text-light);cursor:pointer;border-radius:99px;min-width:36px;padding:6px 14px;font-family:Sarabun,sans-serif;font-size:13px;font-weight:700;transition:all .15s}.meter-pill:hover{border-color:var(--green);color:var(--green-dark)}.meter-pill.active{background:var(--blue);border-color:var(--blue);color:#fff}.meter-table-wrap{overflow-x:auto}.meter-table{border-collapse:collapse;width:100%;font-family:Sarabun,sans-serif}.meter-table thead th{color:var(--text-light);text-align:left;border-bottom:1px solid var(--border-soft);background:var(--surface);padding:12px 14px;font-size:12px;font-weight:700}.meter-table tbody td{border-bottom:1px solid var(--border-soft);color:var(--text);vertical-align:middle;padding:12px 14px;font-size:13px}.meter-table tbody tr:last-child td{border-bottom:none}.meter-table tbody tr:hover{background:var(--surface-2)}.meter-cell-faded{color:var(--text-light);font-weight:600}.meter-input{border:1px solid var(--border);background:var(--input-bg);width:88px;color:var(--text);border-radius:8px;outline:none;padding:7px 10px;font-family:Sarabun,sans-serif;font-size:13px;font-weight:600;transition:all .15s}.meter-input:focus{border-color:var(--green);box-shadow:0 0 0 3px var(--input-focus-ring)}.meter-status{border-radius:99px;padding:4px 14px;font-family:Sarabun,sans-serif;font-size:12px;font-weight:700;display:inline-block}.meter-status.done{background:var(--green-light);color:var(--green-dark)}.meter-status.pending{background:var(--orange-soft);color:var(--orange)}@media (max-width:900px){.contract-builder{grid-template-columns:1fr!important}.meter-layout{grid-template-columns:1fr}.meter-sidebar{flex-flow:wrap}.meter-sidebar .meter-card{flex:1;min-width:200px}.meter-input{width:72px}}@media (max-width:640px){.meter-sidebar{flex-direction:column}.meter-toolbar{flex-direction:column;align-items:stretch}.meter-toolbar .btn{justify-content:center;align-self:stretch!important}.meter-table thead th,.meter-table tbody td{padding:10px 8px;font-size:12px}.meter-input{width:64px;padding:6px 8px}}@media (max-width:992px){.responsive-table{border:0!important}.responsive-table thead{display:none}.responsive-table tr{background:var(--surface);box-shadow:var(--shadow-sm);margin-bottom:16px;padding:12px;display:block;border:1px solid var(--border)!important;border-radius:12px!important}.responsive-table td{text-align:right;justify-content:space-between;align-items:center;font-size:14px;display:flex;border-bottom:1px solid var(--border-soft)!important;padding:10px 4px!important}.responsive-table td:last-child{justify-content:center;gap:8px;border-bottom:0!important;padding-top:15px!important}.responsive-table td:before{content:attr(data-label);color:var(--text-light);text-align:left;text-transform:uppercase;margin-right:15px;font-size:12px;font-weight:700}.responsive-table td:last-child .btn-group{gap:8px;width:100%;display:flex}.responsive-table td:last-child button{flex:1}}
