@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/inter-cyrillic-ext-400-normal-BQZuk6qB.woff2)format("woff2"),url(/assets/inter-cyrillic-ext-400-normal-DQukG94-.woff)format("woff");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/inter-cyrillic-400-normal-obahsSVq.woff2)format("woff2"),url(/assets/inter-cyrillic-400-normal-HOLc17fK.woff)format("woff");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/inter-greek-ext-400-normal-DGGRlc-M.woff2)format("woff2"),url(/assets/inter-greek-ext-400-normal-KugGGMne.woff)format("woff");unicode-range:U+1F??}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/inter-greek-400-normal-B4URO6DV.woff2)format("woff2"),url(/assets/inter-greek-400-normal-q2sYcFCs.woff)format("woff");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/inter-vietnamese-400-normal-DMkecbls.woff2)format("woff2"),url(/assets/inter-vietnamese-400-normal-Bbgyi5SW.woff)format("woff");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/inter-latin-ext-400-normal-C1nco2VV.woff2)format("woff2"),url(/assets/inter-latin-ext-400-normal-77YHD8bZ.woff)format("woff");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/inter-latin-400-normal-C38fXH4l.woff2)format("woff2"),url(/assets/inter-latin-400-normal-CyCys3Eg.woff)format("woff");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/inter-cyrillic-ext-500-normal-B0yAr1jD.woff2)format("woff2"),url(/assets/inter-cyrillic-ext-500-normal-BmqWE9Dz.woff)format("woff");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/inter-cyrillic-500-normal-BasfLYem.woff2)format("woff2"),url(/assets/inter-cyrillic-500-normal-CxZf_p3X.woff)format("woff");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/inter-greek-ext-500-normal-C4iEst2y.woff2)format("woff2"),url(/assets/inter-greek-ext-500-normal-2j5mBUwD.woff)format("woff");unicode-range:U+1F??}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/inter-greek-500-normal-BIZE56-Y.woff2)format("woff2"),url(/assets/inter-greek-500-normal-Xzm54t5V.woff)format("woff");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/inter-vietnamese-500-normal-DOriooB6.woff2)format("woff2"),url(/assets/inter-vietnamese-500-normal-mJboJaSs.woff)format("woff");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/inter-latin-ext-500-normal-CV4jyFjo.woff2)format("woff2"),url(/assets/inter-latin-ext-500-normal-BxGbmqWO.woff)format("woff");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/inter-latin-500-normal-Cerq10X2.woff2)format("woff2"),url(/assets/inter-latin-500-normal-BL9OpVg8.woff)format("woff");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/inter-cyrillic-ext-600-normal-Dfes3d0z.woff2)format("woff2"),url(/assets/inter-cyrillic-ext-600-normal-Bcila6Z-.woff)format("woff");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/inter-cyrillic-600-normal-CWCymEST.woff2)format("woff2"),url(/assets/inter-cyrillic-600-normal-4D_pXhcN.woff)format("woff");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/inter-greek-ext-600-normal-DRtmH8MT.woff2)format("woff2"),url(/assets/inter-greek-ext-600-normal-B8X0CLgF.woff)format("woff");unicode-range:U+1F??}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/inter-greek-600-normal-plRanbMR.woff2)format("woff2"),url(/assets/inter-greek-600-normal-BZpKdvQh.woff)format("woff");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/inter-vietnamese-600-normal-Cc8MFFhd.woff2)format("woff2"),url(/assets/inter-vietnamese-600-normal-BuLX-rYi.woff)format("woff");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/inter-latin-ext-600-normal-D2bJ5OIk.woff2)format("woff2"),url(/assets/inter-latin-ext-600-normal-CIVaiw4L.woff)format("woff");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/inter-latin-600-normal-LgqL8muc.woff2)format("woff2"),url(/assets/inter-latin-600-normal-CiBQ2DWP.woff)format("woff");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/inter-cyrillic-ext-700-normal-BjwYoWNd.woff2)format("woff2"),url(/assets/inter-cyrillic-ext-700-normal-LO58E6JB.woff)format("woff");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/inter-cyrillic-700-normal-CjBOestx.woff2)format("woff2"),url(/assets/inter-cyrillic-700-normal-DrXBdSj3.woff)format("woff");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/inter-greek-ext-700-normal-qfdV9bQt.woff2)format("woff2"),url(/assets/inter-greek-ext-700-normal-BoQ6DsYi.woff)format("woff");unicode-range:U+1F??}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/inter-greek-700-normal-C3JjAnD8.woff2)format("woff2"),url(/assets/inter-greek-700-normal-BUv2fZ6O.woff)format("woff");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/inter-vietnamese-700-normal-DlLaEgI2.woff2)format("woff2"),url(/assets/inter-vietnamese-700-normal-BZaoP0fm.woff)format("woff");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/inter-latin-ext-700-normal-Ca8adRJv.woff2)format("woff2"),url(/assets/inter-latin-ext-700-normal-TidjK2hL.woff)format("woff");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/inter-latin-700-normal-Yt3aPRUw.woff2)format("woff2"),url(/assets/inter-latin-700-normal-BLAVimhd.woff)format("woff");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:800;src:url(/assets/inter-cyrillic-ext-800-normal-BZOjs1Xv.woff2)format("woff2"),url(/assets/inter-cyrillic-ext-800-normal-Ca-gJeZY.woff)format("woff");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:800;src:url(/assets/inter-cyrillic-800-normal-C7MGvYyJ.woff2)format("woff2"),url(/assets/inter-cyrillic-800-normal-CCHyn08d.woff)format("woff");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:800;src:url(/assets/inter-greek-ext-800-normal-B--PVpEC.woff2)format("woff2"),url(/assets/inter-greek-ext-800-normal-DUe57HfS.woff)format("woff");unicode-range:U+1F??}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:800;src:url(/assets/inter-greek-800-normal-CLIouy3y.woff2)format("woff2"),url(/assets/inter-greek-800-normal-BU00tryP.woff)format("woff");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:800;src:url(/assets/inter-vietnamese-800-normal-Cm7tD1pz.woff2)format("woff2"),url(/assets/inter-vietnamese-800-normal-DDlpr_Ee.woff)format("woff");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:800;src:url(/assets/inter-latin-ext-800-normal-DZJjya6U.woff2)format("woff2"),url(/assets/inter-latin-ext-800-normal-BOMpwxm3.woff)format("woff");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:800;src:url(/assets/inter-latin-800-normal-BYj_oED-.woff2)format("woff2"),url(/assets/inter-latin-800-normal-D1mf63XC.woff)format("woff");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}:root{--color-primary:#1e3a5f;--color-primary-light:#264d7a;--color-primary-dark:#152a44;--color-accent:#f59e0b;--color-accent-hover:#d97706;--color-green:#16a34a;--color-green-hover:#15803d;--color-green-bg:#f0fdf4;--color-bg:#f1f5f9;--color-bg-card:#fff;--color-border:#e2e8f0;--color-text:#1e293b;--color-text-muted:#64748b;--color-text-light:#94a3b8;--color-success:#10b981;--color-success-bg:#ecfdf5;--color-warning:#f59e0b;--color-warning-bg:#fffbeb;--color-danger:#ef4444;--color-danger-bg:#fef2f2;--color-info:#3b82f6;--color-info-bg:#eff6ff;--sidebar-width:260px;--sidebar-bg:linear-gradient(180deg, #071827 0%, #0d1f30 100%);--sidebar-text:#ffffffb8;--sidebar-text-active:#fff;--sidebar-active-bg:#ffffff1c;--sidebar-hover-bg:#ffffff12;--sidebar-muted:#8fa3b8;--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:32px;--space-2xl:48px;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:24px;--radius-full:9999px;--shadow-sm:0 1px 3px #00000014, 0 1px 2px #0000000f;--shadow-md:0 4px 6px #00000012, 0 2px 4px #0000000f;--shadow-lg:0 10px 15px #0000001a, 0 4px 6px #0000000d;--font-sans:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-mono:"SF Mono", SFMono-Regular, Consolas, monospace;--font-size-xs:11px;--font-size-sm:13px;--font-size-base:14px;--font-size-md:15px;--font-size-lg:18px;--font-size-xl:22px;--font-size-2xl:28px;--transition:.2s ease}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px}body{font-family:var(--font-sans);font-size:var(--font-size-base);color:var(--color-text);background:var(--color-bg);-webkit-font-smoothing:antialiased;line-height:1.5}a{color:inherit;text-decoration:none}button{cursor:pointer;background:0 0;border:none;font-family:inherit}input,select,textarea{font-family:inherit}.app-shell{min-height:100vh;display:flex}.main-content{margin-left:var(--sidebar-width);flex-direction:column;flex:1;min-height:100vh;display:flex}.page-body{padding:var(--space-xl);flex:1;width:100%;max-width:1280px}.sidebar{width:var(--sidebar-width);background:var(--sidebar-bg);z-index:100;flex-direction:column;height:100vh;display:flex;position:fixed;top:0;left:0;overflow:hidden auto}.sidebar-brand{border-bottom:1px solid #ffffff14;align-items:center;gap:12px;padding:24px 20px 20px;display:flex}.sidebar-brand-icon{background:var(--color-green);border-radius:var(--radius-md);color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-size:18px;font-weight:800;display:flex}.sidebar-brand-name{color:#fff;letter-spacing:-.3px;font-size:18px;font-weight:700}.sidebar-brand-tag{color:var(--color-green);letter-spacing:1px;text-transform:uppercase;font-size:10px;font-weight:600}.sidebar-section{padding:8px 0 0}.sidebar-section-toggle{cursor:pointer;color:#ffffff59;width:100%;font-family:var(--font-sans);background:0 0;border:none;justify-content:space-between;align-items:center;padding:6px 20px;display:flex}.sidebar-section-label{letter-spacing:1.2px;text-transform:uppercase;color:#ffffff59;font-size:10px;font-weight:700}.sidebar-section-arrow{flex-shrink:0;width:12px;height:12px;display:inline-block;position:relative}.sidebar-section-arrow:before,.sidebar-section-arrow:after{content:"";background:#ffffff59;border-radius:1px;width:5px;height:1.5px;transition:transform .2s;position:absolute;top:50%}.sidebar-section-arrow:before{left:1px;transform:translateY(-50%)rotate(45deg)}.sidebar-section-arrow:after{right:1px;transform:translateY(-50%)rotate(-45deg)}.sidebar-section-arrow.open:before{transform:translateY(-50%)rotate(-45deg)}.sidebar-section-arrow.open:after{transform:translateY(-50%)rotate(45deg)}.sidebar-section-items{max-height:0;padding:0 12px;transition:max-height .22s;overflow:hidden}.sidebar-section-items.open{max-height:600px;padding-bottom:6px}.sidebar-nav-item{border-radius:var(--radius-md);color:var(--sidebar-text);font-size:var(--font-size-sm);transition:var(--transition);align-items:center;gap:11px;margin-bottom:2px;padding:10px 12px;font-weight:500;display:flex;position:relative}.sidebar-nav-item:hover{background:var(--sidebar-hover-bg);color:#fff}.sidebar-nav-item.active{background:var(--sidebar-active-bg);color:var(--sidebar-text-active)}.sidebar-nav-item.active:before{content:"";background:var(--color-green);border-radius:0 2px 2px 0;width:3px;position:absolute;top:8px;bottom:8px;left:0}.sidebar-nav-icon{text-align:center;flex-shrink:0;width:18px;font-size:16px}.sidebar-badge{background:var(--color-accent);color:#fff;border-radius:var(--radius-full);margin-left:auto;padding:2px 6px;font-size:10px;font-weight:700;line-height:1.4}.sidebar-footer{border-top:1px solid #ffffff14;margin-top:auto;padding:16px 12px}.sidebar-user{border-radius:var(--radius-md);color:#ffffffbf;align-items:center;gap:10px;padding:10px;display:flex}.sidebar-avatar{background:var(--color-accent);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:13px;font-weight:700;display:flex}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-name{font-size:var(--font-size-sm);color:#fff;text-overflow:ellipsis;white-space:nowrap;font-weight:600;overflow:hidden}.sidebar-user-role{color:#ffffff73;text-transform:capitalize;font-size:11px}.sidebar-logout-btn{border-radius:var(--radius-sm);color:#fff6;transition:var(--transition);padding:6px;font-size:16px}.sidebar-logout-btn:hover{color:var(--color-danger);background:#ef44441a}.topbar{border-bottom:1px solid var(--color-border);height:64px;padding:0 var(--space-xl);z-index:50;background:#fff;justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.topbar-title{font-size:var(--font-size-lg);color:var(--color-text);font-weight:700;line-height:1}.topbar-title-group{flex-direction:column;gap:1px;display:flex}.topbar-workspace-name{letter-spacing:.8px;text-transform:uppercase;color:var(--color-text-muted);font-size:10px;font-weight:600}.topbar-menu-btn{border-radius:var(--radius-md);width:36px;height:36px;color:var(--color-text-muted);transition:var(--transition);flex-shrink:0;justify-content:center;align-items:center;display:none}.topbar-menu-btn:hover{background:var(--color-bg);color:var(--color-text)}.topbar-right{align-items:center;gap:var(--space-md);display:flex}.topbar-icon-btn{border-radius:var(--radius-md);width:36px;height:36px;color:var(--color-text-muted);transition:var(--transition);justify-content:center;align-items:center;font-size:18px;display:flex;position:relative}.topbar-icon-btn:hover{background:var(--color-bg);color:var(--color-text)}.notif-dot{background:var(--color-danger);border:2px solid #fff;border-radius:50%;width:8px;height:8px;position:absolute;top:7px;right:7px}.card{background:var(--color-bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--color-border)}.card-header{padding:var(--space-lg) var(--space-lg) var(--space-md);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;display:flex}.card-title{font-size:var(--font-size-md);color:var(--color-text);font-weight:700}.stat-grid{gap:var(--space-lg);margin-bottom:var(--space-xl);grid-template-columns:repeat(auto-fill,minmax(220px,1fr));display:grid}.stat-card{border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:var(--shadow-sm);border:1px solid var(--color-border);align-items:flex-start;gap:var(--space-md);transition:var(--transition);background:#fff;display:flex}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.stat-icon{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:22px;display:flex}.stat-icon.blue{color:#2563eb;background:#dbeafe}.stat-icon.green{color:#16a34a;background:#dcfce7}.stat-icon.amber{color:#d97706;background:#fef3c7}.stat-icon.red{color:#dc2626;background:#fee2e2}.stat-icon.purple{color:#7c3aed;background:#ede9fe}.stat-icon.teal{color:#0d9488;background:#ccfbf1}.stat-info{flex:1}.stat-value{font-size:var(--font-size-xl);color:var(--color-text);font-weight:800;line-height:1}.stat-label{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-top:4px}.stat-change{font-size:var(--font-size-xs);align-items:center;gap:3px;margin-top:6px;font-weight:600;display:flex}.stat-change.up{color:var(--color-success)}.stat-change.down{color:var(--color-danger)}.btn{border-radius:var(--radius-md);font-size:var(--font-size-sm);transition:var(--transition);white-space:nowrap;border:1px solid #0000;align-items:center;gap:7px;padding:9px 18px;font-weight:600;display:inline-flex}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover{background:var(--color-primary-light)}.btn-accent{background:var(--color-accent);color:#fff}.btn-accent:hover{background:var(--color-accent-hover)}.btn-outline{border-color:var(--color-border);color:var(--color-text);background:0 0}.btn-outline:hover{background:var(--color-bg)}.btn-danger{background:var(--color-danger-bg);color:var(--color-danger);border-color:#fecaca}.btn-sm{font-size:var(--font-size-xs);padding:6px 12px}.btn-lg{font-size:var(--font-size-md);padding:12px 24px}.btn-icon{padding:8px}.btn:disabled{opacity:.55;cursor:not-allowed}.table-wrapper{border-radius:var(--radius-lg);border:1px solid var(--color-border);overflow-x:auto}table{border-collapse:collapse;background:#fff;width:100%}thead{border-bottom:1px solid var(--color-border);background:#f8fafc}th{text-align:left;font-size:var(--font-size-xs);letter-spacing:.5px;text-transform:uppercase;color:var(--color-text-muted);padding:12px 16px;font-weight:700}td{font-size:var(--font-size-sm);color:var(--color-text);border-bottom:1px solid #f1f5f9;padding:14px 16px}tr:last-child td{border-bottom:none}tbody tr:hover td{background:#f8fafc}.badge{border-radius:var(--radius-full);font-size:var(--font-size-xs);align-items:center;gap:4px;padding:3px 9px;font-weight:600;display:inline-flex}.badge-success{background:var(--color-success-bg);color:#059669}.badge-warning{background:var(--color-warning-bg);color:#b45309}.badge-danger{background:var(--color-danger-bg);color:var(--color-danger)}.badge-info{background:var(--color-info-bg);color:#2563eb}.badge-neutral{color:var(--color-text-muted);background:#f1f5f9}.form-group{margin-bottom:var(--space-md)}.form-label{font-size:var(--font-size-sm);color:var(--color-text);margin-bottom:6px;font-weight:600;display:block}.form-control{border:1.5px solid var(--color-border);border-radius:var(--radius-md);width:100%;font-size:var(--font-size-sm);color:var(--color-text);transition:var(--transition);background:#fff;outline:none;padding:10px 14px}.form-control:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #1e3a5f14}.form-control::placeholder{color:var(--color-text-light)}select.form-control{cursor:pointer}.form-row{gap:var(--space-md);grid-template-columns:1fr 1fr;display:grid}.input-icon-wrapper{position:relative}.input-icon{color:var(--color-text-light);font-size:16px;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.input-icon-wrapper .form-control{padding-left:40px}.page-header{margin-bottom:var(--space-xl);justify-content:space-between;align-items:center;display:flex}.page-header h1{font-size:var(--font-size-xl);color:var(--color-text);font-weight:800;line-height:1}.page-header p{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-top:4px}.empty-state{padding:60px var(--space-xl);text-align:center;flex-direction:column;justify-content:center;align-items:center;display:flex}.empty-state-icon{margin-bottom:var(--space-md);opacity:.3;font-size:48px}.empty-state h3{font-size:var(--font-size-lg);color:var(--color-text);margin-bottom:var(--space-sm);font-weight:700}.empty-state p{font-size:var(--font-size-sm);color:var(--color-text-muted);max-width:320px;margin:0 auto var(--space-lg)}.modal-overlay{z-index:200;padding:var(--space-lg);background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{border-radius:var(--radius-xl);width:100%;max-width:520px;box-shadow:var(--shadow-lg);background:#fff;max-height:90vh;overflow-y:auto}.modal--sm{max-width:380px}.modal--md{max-width:560px}.modal--lg{max-width:780px}.modal-header{padding:var(--space-lg);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;display:flex}.modal-title{font-size:var(--font-size-lg);font-weight:700}.modal-close{border-radius:var(--radius-sm);width:32px;height:32px;color:var(--color-text-muted);transition:var(--transition);justify-content:center;align-items:center;font-size:20px;display:flex}.modal-close:hover{background:var(--color-bg);color:var(--color-text)}.modal-body{padding:var(--space-lg)}.modal-footer{padding:var(--space-md) var(--space-lg);border-top:1px solid var(--color-border);gap:var(--space-sm);justify-content:flex-end;display:flex}.auth-shell{min-height:100vh;padding:var(--space-lg);background:linear-gradient(135deg,#0f172a 0%,#1e3a5f 60%,#1e293b 100%);justify-content:center;align-items:center;display:flex}.auth-card{border-radius:var(--radius-xl);width:100%;max-width:440px;box-shadow:var(--shadow-lg);background:#fff;overflow:hidden}.auth-header{background:var(--color-primary);text-align:center;padding:32px}.auth-logo{background:var(--color-accent);border-radius:var(--radius-lg);color:#fff;width:56px;height:56px;margin-bottom:var(--space-md);justify-content:center;align-items:center;font-size:24px;font-weight:900;display:inline-flex}.auth-brand{color:#fff;letter-spacing:-.5px;font-size:24px;font-weight:800}.auth-subtitle{font-size:var(--font-size-sm);color:#fff9;margin-top:4px}.auth-body{padding:32px}.auth-footer{border-top:1px solid var(--color-border);text-align:center;font-size:var(--font-size-sm);color:var(--color-text-muted);background:#f8fafc;padding:16px 32px}.auth-footer a{color:var(--color-primary);font-weight:600}.auth-footer a:hover{text-decoration:underline}.btn-full{justify-content:center;width:100%;padding:13px}.alert{border-radius:var(--radius-md);font-size:var(--font-size-sm);margin-bottom:var(--space-md);align-items:center;gap:var(--space-sm);padding:12px 16px;display:flex}.alert-danger{background:var(--color-danger-bg);color:var(--color-danger)}.alert-success{background:var(--color-success-bg);color:#059669}.alert-warning{background:var(--color-warning-bg);color:#b45309}.spinner{border:2px solid #0000001a;border-top-color:currentColor;border-radius:50%;width:20px;height:20px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.page-loader{justify-content:center;align-items:center;gap:var(--space-md);height:200px;color:var(--color-text-muted);display:flex}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-sm{gap:var(--space-sm)}.gap-md{gap:var(--space-md)}.mt-md{margin-top:var(--space-md)}.mt-lg{margin-top:var(--space-lg)}.text-muted{color:var(--color-text-muted);font-size:var(--font-size-sm)}.fw-bold{font-weight:700}.divider{background:var(--color-border);height:1px;margin:var(--space-lg) 0}.property-grid{gap:var(--space-lg);grid-template-columns:repeat(auto-fill,minmax(300px,1fr));display:grid}.property-card{border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--color-border);transition:var(--transition);background:#fff;overflow:hidden}.property-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.property-card-header{padding:var(--space-lg);background:linear-gradient(135deg, var(--color-primary), var(--color-primary-light));color:#fff}.property-card-name{font-size:var(--font-size-lg);font-weight:700}.property-card-address{font-size:var(--font-size-sm);opacity:.75;align-items:center;gap:4px;margin-top:4px;display:flex}.property-card-body{padding:var(--space-lg)}.property-stats{gap:var(--space-sm);margin-bottom:var(--space-md);grid-template-columns:repeat(3,1fr);display:grid}.property-stat{text-align:center;padding:var(--space-sm);background:var(--color-bg);border-radius:var(--radius-sm)}.property-stat-value{font-size:var(--font-size-xl);color:var(--color-text);font-weight:800;line-height:1}.property-stat-label{font-size:var(--font-size-xs);color:var(--color-text-muted);margin-top:2px}.occupancy-bar{background:var(--color-border);height:6px;margin:var(--space-sm) 0;border-radius:3px;overflow:hidden}.occupancy-fill{background:linear-gradient(90deg, var(--color-success), #34d399);border-radius:3px;height:100%;transition:width .5s}.notice-item{padding:var(--space-md);border-radius:var(--radius-md);border:1px solid var(--color-border);margin-bottom:var(--space-sm);transition:var(--transition)}.notice-item:hover{border-color:var(--color-primary)}.notice-item.unread{border-left:3px solid var(--color-accent);background:#fffbeb}.sidebar-ws-strip{border-bottom:1px solid #ffffff12;justify-content:space-between;align-items:center;gap:8px;padding:10px 16px 12px;display:flex}.sidebar-ws-name{color:#ffffff8c;text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:12px;font-weight:600;overflow:hidden}.sidebar-nav-wrap{flex:1;padding-bottom:8px;overflow:hidden auto}.sidebar-nav-label{flex:1}.sub-badge{border-radius:var(--radius-full);letter-spacing:.3px;white-space:nowrap;align-items:center;padding:2px 8px;font-size:10px;font-weight:700;display:inline-flex}.sub-badge-expired,.sub-badge-inactive{color:#9ca3af;background:#6b728033}.sidebar-usage-wrap{border-top:1px solid #ffffff12;padding:12px 16px}.unit-usage-header{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.unit-usage-label{letter-spacing:.8px;text-transform:uppercase;color:var(--sidebar-muted);font-size:10px;font-weight:600}.unit-usage-count{color:#fff9;font-size:11px;font-weight:700}.unit-usage-track{background:#ffffff1a;border-radius:2px;height:4px;overflow:hidden}.unit-usage-fill{background:#34d399;border-radius:2px;height:100%;transition:width .4s}.unit-usage-fill.warning{background:#fbbf24}.unit-usage-fill.critical{background:#f87171}.unit-usage-alert{color:#f87171;margin-top:5px;font-size:10px;font-weight:600}.topbar-left{align-items:center;gap:12px;display:flex}.topbar-ws-info{align-items:center;gap:8px;display:flex}.topbar-unit-pill{background:var(--color-bg);border:1px solid var(--color-border);color:var(--color-text-muted);border-radius:var(--radius-full);padding:3px 10px;font-size:11px;font-weight:600}.sub-detail-list{flex-direction:column;gap:0;display:flex}.sub-detail-row{border-bottom:1px solid var(--color-border);font-size:var(--font-size-sm);justify-content:space-between;align-items:center;padding:10px 0;display:flex}.sub-detail-row dt{color:var(--color-text-muted);font-weight:500}.sub-detail-row dd{color:var(--color-text);font-weight:600}.doc-type-grid{gap:var(--space-md);margin-bottom:var(--space-lg);grid-template-columns:repeat(auto-fill,minmax(260px,1fr));display:grid}.doc-type-card{transition:var(--transition)}.doc-type-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}@media (width<=900px){.page-body{padding:var(--space-lg)}}@media (width<=768px){.sidebar{z-index:100;transition:transform .25s;transform:translate(-100%)}.sidebar--open{transform:translate(0)}.sidebar-overlay{display:block}.main-content{margin-left:0}.form-row{grid-template-columns:1fr}.stat-grid{grid-template-columns:1fr 1fr}.page-body{padding:var(--space-md)}.topbar{padding:0 var(--space-md)}.topbar-menu-btn{display:inline-flex}.topbar-ws-info{display:none}}.landing{min-height:100vh;color:var(--color-text);background:#fff}.landing-nav{z-index:100;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--color-border);background:#fffffff2;padding:0 24px;position:sticky;top:0}.landing-nav-inner{align-items:center;gap:32px;max-width:1140px;height:64px;margin:0 auto;display:flex}.landing-brand{flex-shrink:0;align-items:center;gap:10px;display:flex}.landing-brand-icon{background:var(--color-primary);color:#fff;border-radius:9px;justify-content:center;align-items:center;width:36px;height:36px;font-size:18px;font-weight:900;display:flex}.landing-brand-name{color:var(--color-primary);letter-spacing:-.5px;font-size:18px;font-weight:900}.landing-nav-links{flex:1;gap:24px;display:flex}.landing-nav-links a{color:var(--color-text-muted);font-size:14px;font-weight:500;transition:color .15s}.landing-nav-links a:hover{color:var(--color-primary)}.landing-nav-actions{align-items:center;gap:10px;display:flex}.landing-btn-outline{cursor:pointer;border:1.5px solid var(--color-border);color:var(--color-text);background:0 0;border-radius:8px;align-items:center;padding:8px 18px;font-size:14px;font-weight:600;transition:all .15s;display:inline-flex}.landing-btn-outline:hover{border-color:var(--color-primary);color:var(--color-primary)}.landing-btn-primary{cursor:pointer;background:var(--color-primary);color:#fff;border:none;border-radius:8px;align-items:center;padding:8px 20px;font-size:14px;font-weight:600;text-decoration:none;transition:opacity .15s;display:inline-flex}.landing-btn-primary:hover{opacity:.9}.landing-btn-ghost{color:#fff;cursor:pointer;background:#ffffff1f;border:1.5px solid #ffffff40;border-radius:10px;align-items:center;padding:10px 24px;font-size:15px;font-weight:600;text-decoration:none;transition:all .15s;display:inline-flex}.landing-btn-ghost:hover{background:#fff3}.landing-btn-lg{border-radius:12px;padding:14px 32px;font-size:16px}.landing-hero{background:linear-gradient(135deg,#1e3a5f 0%,#264d7a 60%,#1a3550 100%);padding:80px 24px 100px}.landing-hero-inner{text-align:center;max-width:780px;margin:0 auto}.landing-pill{color:#ffffffd9;letter-spacing:.3px;background:#ffffff1f;border-radius:20px;margin-bottom:24px;padding:6px 16px;font-size:13px;font-weight:600;display:inline-block}.landing-hero-title{color:#fff;letter-spacing:-1.5px;margin-bottom:20px;font-size:clamp(36px,5vw,56px);font-weight:900;line-height:1.1}.landing-hero-accent{color:var(--color-accent,#f59e0b)}.landing-hero-sub{color:#ffffffb3;margin-bottom:36px;max-width:600px;margin-inline:auto;font-size:18px;line-height:1.6}.landing-hero-cta{flex-wrap:wrap;justify-content:center;gap:14px;margin-bottom:56px;display:flex}.landing-hero-stats{justify-content:center;gap:48px;display:flex}.landing-stat{text-align:center}.landing-stat-val{color:#fff;font-size:28px;font-weight:900}.landing-stat-label{color:#ffffff8c;margin-top:2px;font-size:13px}.landing-section{background:#fff;padding:80px 24px}.landing-section-dark{background:#1e3a5f}.landing-section-inner{max-width:1140px;margin:0 auto}.landing-section-header{text-align:center;margin-bottom:52px}.landing-section-title{color:var(--color-primary);letter-spacing:-1px;margin-bottom:12px;font-size:36px;font-weight:900}.landing-section-sub{color:var(--color-text-muted);max-width:520px;margin:0 auto;font-size:17px;line-height:1.6}.landing-features-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;display:grid}.landing-feature-card{border:1px solid var(--color-border);background:#fff;border-radius:14px;padding:28px;transition:box-shadow .2s,transform .2s}.landing-feature-card:hover{transform:translateY(-2px);box-shadow:0 8px 32px #1e3a5f1a}.landing-feature-icon{margin-bottom:14px;font-size:32px}.landing-feature-title{color:var(--color-primary);margin-bottom:8px;font-size:17px;font-weight:700}.landing-feature-desc{color:var(--color-text-muted);font-size:14px;line-height:1.6}.landing-plans-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;display:grid}.landing-plan-card{background:#ffffff0f;border:1px solid #ffffff1f;border-radius:16px;padding:32px;position:relative}.landing-plan-highlight{border:2px solid var(--color-accent,#f59e0b);background:#fff;box-shadow:0 0 0 4px #f59e0b26}.landing-plan-badge{background:var(--color-accent,#f59e0b);color:#fff;border-radius:20px;padding:4px 14px;font-size:12px;font-weight:700;position:absolute;top:-12px;left:50%;transform:translate(-50%)}.landing-plan-name{color:#ffffffe6;margin-bottom:12px;font-size:18px;font-weight:800}.landing-plan-highlight .landing-plan-name{color:var(--color-primary)}.landing-plan-price{color:#fff;margin-bottom:4px;font-size:36px;font-weight:900}.landing-plan-highlight .landing-plan-price{color:var(--color-primary)}.landing-plan-period{opacity:.7;font-size:16px;font-weight:400}.landing-plan-units{color:#ffffff80;margin-bottom:20px;font-size:13px}.landing-plan-highlight .landing-plan-units{color:var(--color-text-muted)}.landing-plan-features{margin-bottom:28px;list-style:none}.landing-plan-features li{color:#ffffffbf;border-bottom:1px solid #ffffff0f;align-items:center;gap:8px;padding:6px 0;font-size:14px;display:flex}.landing-plan-highlight .landing-plan-features li{color:var(--color-text);border-bottom-color:var(--color-border)}.landing-check{color:var(--color-accent,#f59e0b);font-weight:700}.landing-plan-btn{text-align:center;color:#ffffffe6;background:#ffffff1a;border:1px solid #fff3;border-radius:10px;width:100%;padding:12px;font-size:15px;font-weight:700;text-decoration:none;transition:all .15s;display:block}.landing-plan-highlight .landing-plan-btn{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.landing-plan-btn:hover{opacity:.85}.landing-cta-section{background:var(--color-bg);text-align:center;padding:80px 24px}.landing-footer{background:#0f1e30;padding:32px 24px}.landing-footer .landing-nav-inner{height:auto;padding:0}@media (width<=640px){.landing-hero{padding:56px 20px 64px}.landing-hero-stats{gap:24px}.landing-nav-links{display:none}.landing-btn-lg{padding:12px 22px;font-size:14px}}.page-container{max-width:1100px}.page-title{font-size:var(--font-size-xl);color:var(--color-text);font-weight:800;line-height:1}.page-subtitle{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-top:4px}.tab-nav{border-bottom:2px solid var(--color-border);margin-bottom:var(--space-lg);flex-wrap:wrap;gap:4px;display:flex}.tab-btn{font-size:var(--font-size-sm);color:var(--color-text-muted);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-2px;padding:9px 16px;font-weight:600;transition:color .15s,border-color .15s}.tab-btn:hover{color:var(--color-text)}.tab-btn.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.form-input{border:1.5px solid var(--color-border);border-radius:var(--radius-md);width:100%;font-size:var(--font-size-sm);color:var(--color-text);background:#fff;outline:none;padding:10px 14px;transition:border-color .15s}.form-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #1e3a5f14}.form-input::placeholder{color:var(--color-text-light)}select.form-input{cursor:pointer}textarea.form-input{resize:vertical}.form-row-2{gap:var(--space-md);grid-template-columns:1fr 1fr;display:grid}@media (width<=580px){.form-row-2{grid-template-columns:1fr}}.form-actions{justify-content:flex-end;gap:var(--space-sm);padding-top:var(--space-md);border-top:1px solid var(--color-border);margin-top:var(--space-md);display:flex}.toggle-label{font-size:var(--font-size-sm);cursor:pointer;color:var(--color-text);align-items:center;gap:8px;font-weight:500;display:inline-flex}.toggle-label input[type=checkbox]{cursor:pointer;width:16px;height:16px}.loading-spinner{border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;width:32px;height:32px;margin:48px auto;animation:.7s linear infinite spin}.settings-card{border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:var(--space-lg);background:#fff}.btn-secondary{background:var(--color-bg);color:var(--color-text);border:1px solid var(--color-border)}.btn-secondary:hover:not(:disabled){background:#e9eff8;border-color:#c8d8ea}.alert-error{background:var(--color-danger-bg);color:var(--color-danger)}.btn-close-x{border-radius:var(--radius-sm);width:32px;height:32px;color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;font-size:20px;transition:background .15s;display:inline-flex}.btn-close-x:hover{background:var(--color-bg);color:var(--color-text)}.data-table{border-collapse:collapse;background:#fff;width:100%}.text-primary{color:var(--color-primary)!important}.text-danger{color:var(--color-danger)!important}.text-success{color:var(--color-success)!important}.empty-icon{margin-bottom:var(--space-md);opacity:.4;font-size:36px}.pagination-bar{justify-content:space-between;align-items:center;gap:var(--space-md);flex-wrap:wrap;padding:12px 0 4px;display:flex}.pagination-info{color:var(--color-text-muted);font-size:12px}.pagination-controls{flex-wrap:wrap;align-items:center;gap:3px;display:flex}.pagination-btn{border-radius:var(--radius-sm);border:1px solid var(--color-border);min-width:32px;height:32px;font-size:13px;font-family:var(--font-sans);color:var(--color-text);cursor:pointer;background:#fff;justify-content:center;align-items:center;padding:0 8px;transition:background .15s,border-color .15s;display:inline-flex}.pagination-btn:hover:not(:disabled){background:var(--color-bg);border-color:var(--color-primary);color:var(--color-primary)}.pagination-btn:disabled{opacity:.35;cursor:not-allowed}.pagination-btn.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary);font-weight:700}.pagination-ellipsis{color:var(--color-text-muted);padding:0 4px;font-size:13px}.export-group{flex-wrap:wrap;align-items:center;gap:4px;display:flex}.export-group .btn{white-space:nowrap}.ss-container{width:100%;position:relative}.ss-control{border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;-webkit-user-select:none;user-select:none;min-height:38px;font-family:var(--font-sans);background:#fff;justify-content:space-between;align-items:center;gap:6px;padding:0 10px;transition:border-color .15s;display:flex}.ss-control:hover{border-color:var(--color-primary)}.ss-search{font-size:var(--font-size-sm);font-family:var(--font-sans);background:0 0;border:none;outline:none;flex:1;padding:0}.ss-display{font-size:var(--font-size-sm);color:var(--color-text);text-overflow:ellipsis;white-space:nowrap;flex:1;line-height:1.4;overflow:hidden}.ss-chevron{color:var(--color-text-muted);flex-shrink:0}.ss-menu{border:1px solid var(--color-border);border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);z-index:900;background:#fff;max-height:220px;position:absolute;top:calc(100% + 2px);left:0;right:0;overflow:hidden auto}.ss-item{font-size:var(--font-size-sm);cursor:pointer;color:var(--color-text);font-family:var(--font-sans);padding:8px 12px}.ss-item.ss-selected{background:var(--color-primary-light,#eff6ff);color:var(--color-primary);font-weight:600}.ss-item.ss-muted{color:var(--color-text-muted);cursor:default}.ss-item.ss-muted:hover{background:0 0}.loc-fallback{flex-direction:column;gap:0;display:flex}.loc-hint{color:var(--color-text-muted);margin-top:4px;margin-bottom:var(--space-sm);font-size:12px}.billing-filters{flex-wrap:wrap;align-items:center}.billing-date-range{align-items:center;gap:6px;display:flex}.billing-date-range .form-control{width:140px}.billing-date-sep{color:var(--color-text-muted);white-space:nowrap;font-size:12px}.billing-arrears-toggle{font-size:var(--font-size-sm);color:var(--color-text);cursor:pointer;white-space:nowrap;align-items:center;gap:6px;display:flex}.billing-arrears-toggle input[type=checkbox]{cursor:pointer;width:16px;height:16px}.inv-table-wrap{border-radius:var(--radius);border:1px solid var(--color-border);background:#fff;overflow-x:auto}.inv-table th{text-align:left;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);background:var(--color-bg);border-bottom:1px solid var(--color-border);padding:10px 12px;font-size:11px;font-weight:600}.inv-table td{border-bottom:1px solid var(--color-border);vertical-align:middle;padding:10px 12px}.inv-number-chip{color:var(--color-primary);background:var(--color-primary-light,#eff6ff);border-radius:4px;padding:2px 8px;font-family:Courier New,monospace;font-size:12px;font-weight:600;display:inline-block}.inv-number-link{cursor:pointer;color:var(--color-primary);background:0 0;background:var(--color-primary-light,#eff6ff);border:none;border-radius:4px;padding:2px 8px;font-family:Courier New,monospace;font-size:12px;font-weight:600;text-decoration:underline}.inv-number-link:hover{opacity:.8}.inv-period{color:var(--color-text-muted);font-size:12px}.inv-tenant-code{color:var(--color-text-muted);font-size:11px}.inv-prop{font-weight:500}.inv-unit{color:var(--color-text-muted);font-size:11px}.inv-amount{font-variant-numeric:tabular-nums;text-align:right}.inv-paid{color:var(--color-success,#16a34a)}.inv-action-dd{display:inline-block;position:relative}.inv-action-trigger{align-items:center;gap:4px;padding:4px 10px;font-size:12px;display:flex}.inv-action-chevron{font-size:9px}.inv-action-menu{border:1px solid var(--color-border);border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);z-index:600;background:#fff;min-width:160px;padding:4px 0;position:absolute;top:calc(100% + 4px);right:0}.inv-action-item{text-align:left;width:100%;color:var(--color-text);cursor:pointer;font-size:13px;font-family:var(--font-sans);background:0 0;border:none;padding:8px 14px;display:block}.inv-action-item:hover{background:var(--color-bg)}.inv-action-danger{color:var(--color-danger,#dc2626)}.inv-action-restore{color:var(--color-success,#16a34a)}.inv-action-divider{background:var(--color-border);height:1px;margin:4px 0}.send-modal-invoice-info{margin-bottom:16px}.send-method-option{border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;align-items:flex-start;gap:10px;padding:12px 14px;transition:border-color .15s;display:flex}.send-method-label strong{color:var(--color-text);font-size:13px}.send-result-panel{flex-direction:column;gap:10px;padding:8px 0;display:flex}.send-result-title{color:var(--color-text);margin-bottom:4px;font-size:13px;font-weight:600}.send-result-row{border-radius:var(--radius-sm);align-items:flex-start;gap:8px;padding:10px 14px;font-size:13px;display:flex}.send-result-success{background:#f0fdf4;border:1px solid #bbf7d0}.send-result-failed{background:#fff5f5;border:1px solid #fecaca}.send-result-skipped{background:var(--color-bg);border:1px solid var(--color-border)}.send-result-icon{flex-shrink:0;font-weight:700}.send-result-label{flex-shrink:0;font-weight:600}.send-result-msg{color:var(--color-text-muted)}@media (width<=768px){.inv-list-desktop{display:none}.inv-list-mobile{display:block}.billing-date-range .form-control{width:120px}}.inv-detail-panel{font-size:14px}.inv-detail-header{justify-content:space-between;align-items:flex-start;margin-bottom:16px;display:flex}.inv-detail-section{margin-bottom:20px}.inv-detail-section-title{text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);border-bottom:1px solid var(--color-border);margin-bottom:8px;padding-bottom:4px;font-size:11px;font-weight:700}.inv-detail-row{border-bottom:1px solid var(--color-border);justify-content:space-between;padding:6px 0;display:flex}.inv-detail-row:last-child{border-bottom:none}.inv-detail-label{color:var(--color-text-muted);font-size:13px}.inv-detail-value{text-align:right;font-size:13px}.inv-detail-notes{color:var(--color-text-muted);margin:0;font-size:13px;line-height:1.5}.panel-doc-section{margin-top:20px}.issue-method-option{border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;align-items:flex-start;gap:10px;padding:10px 12px;display:flex}.issue-method-label{flex-direction:column;gap:2px;display:flex}.inv-form{flex-direction:column;gap:0;display:flex}.inv-form-section{margin-bottom:20px}.inv-form-section-title{text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);border-bottom:1px solid var(--color-border);margin-bottom:10px;padding-bottom:6px;font-size:11px;font-weight:700}.inv-form-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}@media (width<=600px){.inv-form-row{grid-template-columns:1fr}}.inv-form-tenant-info{color:var(--color-text-muted);background:var(--color-bg);border-radius:var(--radius-sm);flex-wrap:wrap;gap:12px;margin-top:8px;padding:8px 12px;font-size:12px;display:flex}.inv-form-total{text-align:right;color:var(--color-text);margin-top:8px;font-size:14px}.billing-tabs{border-bottom:2px solid var(--color-border);flex-wrap:wrap;gap:4px;margin-bottom:20px;display:flex}.billing-tab{color:var(--color-text-muted);cursor:pointer;font-size:13px;font-weight:500;font-family:var(--font-sans);background:0 0;border:none;border-bottom:2px solid #0000;align-items:center;gap:6px;margin-bottom:-2px;padding:10px 16px;display:flex}.billing-tab:hover:not(.active){color:var(--color-text)}.access-denied-wrap{background:var(--color-bg,#f8fafc);justify-content:center;align-items:center;min-height:100vh;padding:32px 16px;display:flex}.access-denied-card{border:1px solid var(--color-border,#e2e8f0);text-align:center;background:#fff;border-radius:16px;width:100%;max-width:420px;padding:48px 40px;box-shadow:0 4px 24px #0000000f}.access-denied-card--blocked{background:snow;border-color:#fecaca}.access-denied-icon-wrap{color:#64748b;background:#f1f5f9;border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;margin:0 auto 24px;display:flex}.access-denied-icon-wrap--blocked{color:#b91c1c;background:#fee2e2}.access-denied-title{color:var(--color-text,#0f172a);margin-bottom:12px;font-size:20px;font-weight:700}.access-denied-body{color:var(--color-text-muted,#64748b);margin-bottom:28px;font-size:14px;line-height:1.6}.pub-wrap{min-height:100vh;font-family:"Inter", var(--font-sans);background:#fff}.pub-inner{max-width:1160px;margin:0 auto;padding:0 24px}.pub-nav{z-index:200;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#fffffff7;border-bottom:1px solid #00000012;position:sticky;top:0}.pub-nav-inner{align-items:center;gap:32px;max-width:1160px;height:64px;margin:0 auto;padding:0 24px;display:flex}.pub-brand{flex-shrink:0;align-items:center;gap:10px;text-decoration:none;display:flex}.pub-brand-mark{color:#fff;letter-spacing:-.5px;background:linear-gradient(135deg,#1e3a5f,#3b82f6);border-radius:8px;justify-content:center;align-items:center;width:34px;height:34px;font-size:15px;font-weight:800;display:flex}.pub-brand-name{color:#1e3a5f;letter-spacing:-.3px;font-size:17px;font-weight:800}.pub-nav-links{flex:1;align-items:center;gap:24px;display:flex}.pub-nav-links a{color:#475569;font-size:14px;font-weight:500;text-decoration:none;transition:color .15s}.pub-nav-links a:hover,.pub-nav-links a.active{color:#1e3a5f}.pub-nav-actions{flex-shrink:0;align-items:center;gap:8px;display:flex}.pub-nav-mobile-btn{cursor:pointer;color:#475569;background:0 0;border:none;padding:6px;display:none}.pub-mobile-menu{background:#fff;border-top:1px solid #e2e8f0;flex-direction:column;gap:4px;padding:16px 24px;display:none}.pub-mobile-menu.open{display:flex}.pub-mobile-menu a{color:#1e293b;border-bottom:1px solid #f1f5f9;padding:11px 0;font-size:15px;font-weight:600;text-decoration:none}.pub-mobile-menu a:last-child{border-bottom:none}.pub-btn-ghost{color:#1e3a5f;cursor:pointer;font-size:14px;font-weight:600;font-family:"Inter", var(--font-sans);background:0 0;border:none;border-radius:7px;align-items:center;gap:6px;padding:8px 14px;text-decoration:none;transition:background .15s;display:inline-flex}.pub-btn-ghost:hover{background:#1e3a5f12}.pub-btn-outline{color:#1e3a5f;cursor:pointer;font-size:14px;font-weight:600;font-family:"Inter", var(--font-sans);background:0 0;border:1.5px solid #1e3a5f4d;border-radius:7px;align-items:center;gap:6px;padding:8px 16px;text-decoration:none;transition:all .15s;display:inline-flex}.pub-btn-outline:hover{color:#fff;background:#1e3a5f;border-color:#1e3a5f}.pub-btn-primary{color:#fff;cursor:pointer;font-size:14px;font-weight:700;font-family:"Inter", var(--font-sans);background:#1e3a5f;border:none;border-radius:7px;align-items:center;gap:6px;padding:9px 20px;text-decoration:none;transition:background .15s;display:inline-flex}.pub-btn-primary:hover{background:#264d7a}.pub-btn-primary-lg{color:#fff;cursor:pointer;font-size:15px;font-weight:700;font-family:"Inter", var(--font-sans);background:#1e3a5f;border:none;border-radius:8px;align-items:center;gap:8px;padding:13px 28px;text-decoration:none;transition:background .15s;display:inline-flex}.pub-btn-primary-lg:hover{background:#264d7a}.pub-btn-outline-lg{color:#fff;cursor:pointer;font-size:15px;font-weight:600;font-family:"Inter", var(--font-sans);background:0 0;border:1.5px solid #fff6;border-radius:8px;align-items:center;gap:8px;padding:12px 28px;text-decoration:none;transition:all .15s;display:inline-flex}.pub-btn-outline-lg:hover{background:#ffffff1f;border-color:#ffffffb3}.pub-btn-green-lg{color:#fff;cursor:pointer;font-size:15px;font-weight:700;font-family:"Inter", var(--font-sans);background:#10b981;border:none;border-radius:8px;align-items:center;gap:8px;padding:13px 28px;text-decoration:none;transition:background .15s;display:inline-flex}.pub-btn-green-lg:hover{background:#059669}.pub-hero{background:url(/images/home/hero-bomatrack-city-agent.png) 50%/cover no-repeat;padding:96px 24px 80px;position:relative;overflow:hidden}.pub-hero:before{content:"";background:linear-gradient(155deg,#071827f0 0%,#0d1f38e3 45%,#112240d1 100%);position:absolute;inset:0}.pub-hero:after{content:"";pointer-events:none;background:radial-gradient(70% 60% at 72% 38%,#3b82f624 0%,#0000 70%);position:absolute;inset:0}.pub-hero-inner{z-index:2;grid-template-columns:1fr 420px;align-items:center;gap:64px;max-width:1160px;margin:0 auto;display:grid;position:relative}.pub-hero-pill{color:#93c5fd;letter-spacing:.3px;background:#3b82f626;border:1px solid #3b82f64d;border-radius:999px;align-items:center;gap:7px;margin-bottom:20px;padding:5px 14px;font-size:12px;font-weight:600;display:inline-flex}.pub-hero-title{color:#fff;letter-spacing:-1.5px;margin-bottom:20px;font-size:50px;font-weight:800;line-height:1.08}.pub-hero-accent{color:#3b82f6}.pub-hero-sub{color:#ffffffa6;max-width:520px;margin-bottom:36px;font-size:17px;line-height:1.75}.pub-hero-cta{flex-wrap:wrap;gap:12px;margin-bottom:52px;display:flex}.pub-hero-stats{gap:36px;display:flex}.pub-hero-stat-val{color:#fff;font-size:26px;font-weight:800;line-height:1}.pub-hero-stat-label{color:#ffffff73;margin-top:4px;font-size:12px}.pub-hero-card{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff0f;border:1px solid #ffffff1a;border-radius:16px;padding:24px}.pub-hero-card-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.pub-hero-card-title{color:#fff6;letter-spacing:1px;text-transform:uppercase;font-size:11px;font-weight:700}.pub-hero-live-badge{color:#34d399;background:#10b98126;border:1px solid #10b9814d;border-radius:999px;align-items:center;gap:5px;padding:3px 10px;font-size:11px;font-weight:600;display:inline-flex}.pub-hero-live-dot{background:#34d399;border-radius:50%;width:6px;height:6px;animation:2s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.pub-hero-metric{border-bottom:1px solid #ffffff12;justify-content:space-between;align-items:center;padding:12px 0;display:flex}.pub-hero-metric:last-child{border-bottom:none}.pub-hero-metric-label{color:#ffffff80;font-size:13px}.pub-hero-metric-val{color:#fff;font-size:14px;font-weight:700}.pub-hero-metric-green{color:#34d399}.pub-hero-metric-amber{color:#fbbf24}.pub-hero-metric-blue{color:#60a5fa}.pub-hero-progress{margin-top:16px}.pub-hero-progress-bar-bg{background:#ffffff14;border-radius:3px;height:6px;margin-top:6px}.pub-hero-progress-bar{background:#3b82f6;border-radius:3px;height:6px}.pub-section{padding:80px 24px}.pub-section-light{background:#fff}.pub-section-gray{background:#f8fafc}.pub-section-dark{background:linear-gradient(155deg,#071827 0%,#0d1f38 100%)}.pub-section-inner{max-width:1160px;margin:0 auto}.pub-section-header{text-align:center;margin-bottom:56px}.pub-section-eyebrow{color:#3b82f6;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:10px;font-size:12px;font-weight:700}.pub-section-eyebrow-light{color:#60a5fa}.pub-section-title{color:#0f172a;letter-spacing:-.5px;margin-bottom:14px;font-size:36px;font-weight:800;line-height:1.15}.pub-section-title-light{color:#fff}.pub-section-sub{color:#64748b;max-width:580px;margin:0 auto;font-size:17px;line-height:1.75}.pub-section-sub-light{color:#ffffff94}.pub-trust-grid{grid-template-columns:repeat(4,1fr);gap:20px;display:grid}.pub-trust-card{text-align:center;background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:28px 20px;transition:all .2s}.pub-trust-card:hover{border-color:#3b82f6;transform:translateY(-2px);box-shadow:0 8px 24px #3b82f61a}.pub-trust-icon{color:#3b82f6;justify-content:center;margin-bottom:12px;display:flex}.pub-trust-val{color:#0f172a;font-size:32px;font-weight:800;line-height:1}.pub-trust-label{color:#64748b;margin-top:6px;font-size:13px;line-height:1.4}.pub-feature-grid{grid-template-columns:repeat(3,1fr);gap:24px;display:grid}.pub-feature-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:28px;transition:all .2s}.pub-feature-card:hover{border-color:#3b82f6;transform:translateY(-2px);box-shadow:0 6px 24px #3b82f61a}.pub-feature-icon{color:#3b82f6;background:#3b82f61a;border-radius:10px;justify-content:center;align-items:center;width:44px;height:44px;margin-bottom:16px;display:flex}.pub-feature-title{color:#0f172a;margin-bottom:8px;font-size:16px;font-weight:700}.pub-feature-desc{color:#64748b;font-size:14px;line-height:1.65}.pub-problem-grid{grid-template-columns:repeat(4,1fr);gap:16px;display:grid}.pub-problem-card{background:#ef44440a;border:1px solid #ef44441f;border-radius:10px;padding:20px;transition:border-color .2s}.pub-problem-card:hover{border-color:#ef44444d}.pub-problem-icon{color:#ef4444;margin-bottom:10px}.pub-problem-title{color:#0f172a;margin-bottom:6px;font-size:14px;font-weight:700}.pub-problem-desc{color:#64748b;font-size:13px;line-height:1.55}.pub-solution-grid{grid-template-columns:repeat(2,1fr);gap:24px;display:grid}.pub-solution-card{background:#ffffff0a;border:1px solid #ffffff1a;border-radius:14px;gap:20px;padding:28px;transition:border-color .2s;display:flex}.pub-solution-card:hover{border-color:#3b82f666}.pub-solution-icon{border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.pub-solution-title{color:#fff;margin-bottom:8px;font-size:17px;font-weight:700}.pub-solution-desc{color:#ffffff94;font-size:14px;line-height:1.65}.pub-solution-tags{flex-wrap:wrap;gap:6px;margin-top:12px;display:flex}.pub-solution-tag{color:#93c5fd;background:#3b82f626;border:1px solid #3b82f640;border-radius:999px;padding:3px 10px;font-size:11px;font-weight:600}.pub-testimonial-grid{grid-template-columns:repeat(2,1fr);gap:24px;display:grid}.pub-testimonial-card{background:#fff;border:1px solid #e2e8f0;border-radius:14px;padding:28px;transition:box-shadow .2s}.pub-testimonial-card:hover{box-shadow:0 8px 32px #1e3a5f1a}.pub-testimonial-stars{color:#f59e0b;gap:3px;margin-bottom:14px;display:flex}.pub-testimonial-quote{color:#334155;margin-bottom:20px;font-size:15px;font-style:italic;line-height:1.75}.pub-testimonial-author{align-items:center;gap:12px;display:flex}.pub-testimonial-avatar{color:#fff;background:linear-gradient(135deg,#1e3a5f,#3b82f6);border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;font-size:15px;font-weight:700;display:flex}.pub-testimonial-name{color:#0f172a;font-size:14px;font-weight:700}.pub-testimonial-role{color:#64748b;font-size:12px}.pub-testimonial-units{color:#10b981;margin-top:2px;font-size:11px;font-weight:600}.pub-pricing-grid{grid-template-columns:repeat(4,1fr);gap:20px;display:grid}.pub-pricing-card{background:#fff;border:1px solid #e2e8f0;border-radius:14px;flex-direction:column;padding:28px;transition:all .2s;display:flex;position:relative}.pub-pricing-card:hover{border-color:#3b82f6;box-shadow:0 8px 32px #3b82f61f}.pub-pricing-card-highlight{border-color:#1e3a5f;box-shadow:0 8px 32px #1e3a5f26}.pub-pricing-badge{color:#fff;white-space:nowrap;background:#f59e0b;border-radius:999px;padding:4px 16px;font-size:11px;font-weight:700;position:absolute;top:-13px;left:50%;transform:translate(-50%)}.pub-pricing-plan{color:#3b82f6;letter-spacing:.5px;text-transform:uppercase;margin-bottom:8px;font-size:13px;font-weight:700}.pub-pricing-price{color:#0f172a;margin-bottom:4px;font-size:36px;font-weight:800;line-height:1}.pub-pricing-price-sub{color:#64748b;font-size:14px;font-weight:400}.pub-pricing-desc{color:#64748b;min-height:40px;margin:12px 0 20px;font-size:13px}.pub-pricing-divider{background:#f1f5f9;height:1px;margin:0 0 16px}.pub-pricing-features{flex:1;margin-bottom:24px;list-style:none}.pub-pricing-features li{color:#475569;align-items:flex-start;gap:8px;padding:5px 0;font-size:13px;display:flex}.pub-pricing-check{color:#10b981;flex-shrink:0;margin-top:1px}.pub-pricing-btn{cursor:pointer;text-align:center;width:100%;font-size:14px;font-weight:700;font-family:"Inter", var(--font-sans);border-radius:8px;padding:11px;text-decoration:none;transition:all .15s;display:block}.pub-pricing-btn-primary{color:#fff;background:#1e3a5f;border:none}.pub-pricing-btn-primary:hover{background:#264d7a}.pub-pricing-btn-highlight{color:#fff;background:#3b82f6;border:none}.pub-pricing-btn-highlight:hover{background:#2563eb}.pub-pricing-btn-outline{color:#1e3a5f;background:0 0;border:1.5px solid #cbd5e1}.pub-pricing-btn-outline:hover{color:#fff;background:#1e3a5f;border-color:#1e3a5f}.pub-security-grid{grid-template-columns:repeat(3,1fr);gap:24px;display:grid}.pub-security-card{background:#ffffff0a;border:1px solid #ffffff17;border-radius:12px;gap:16px;padding:24px;transition:border-color .2s;display:flex}.pub-security-card:hover{border-color:#10b98159}.pub-security-icon{color:#34d399;background:#10b98126;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.pub-security-title{color:#fff;margin-bottom:6px;font-size:15px;font-weight:700}.pub-security-desc{color:#ffffff85;font-size:13px;line-height:1.6}.pub-avail-grid{grid-template-columns:repeat(4,1fr);gap:20px;display:grid}.pub-avail-card{text-align:center;background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:28px;transition:all .2s}.pub-avail-card:hover{border-color:#10b981;box-shadow:0 6px 20px #10b9811a}.pub-avail-icon{justify-content:center;margin-bottom:12px;display:flex}.pub-avail-title{color:#0f172a;margin-bottom:8px;font-size:15px;font-weight:700}.pub-avail-desc{color:#64748b;margin-bottom:12px;font-size:13px;line-height:1.6}.pub-avail-badge{color:#10b981;background:#10b9811a;border:1px solid #10b98133;border-radius:999px;align-items:center;gap:5px;padding:4px 12px;font-size:11px;font-weight:600;display:inline-flex}.pub-cta-section{text-align:center;background:linear-gradient(135deg,#071827 0%,#1e3a5f 100%);padding:96px 24px}.pub-cta-title{color:#fff;letter-spacing:-.8px;margin-bottom:16px;font-size:42px;font-weight:800;line-height:1.1}.pub-cta-sub{color:#ffffff9e;max-width:540px;margin-bottom:40px;margin-left:auto;margin-right:auto;font-size:17px;line-height:1.7}.pub-cta-actions{flex-wrap:wrap;justify-content:center;gap:14px;display:flex}.pub-footer{background:#060f1a;padding:64px 24px 32px}.pub-footer-inner{grid-template-columns:2.2fr 1fr 1fr 1fr 1fr;gap:40px;max-width:1160px;margin:0 auto 48px;display:grid}.pub-footer-brand-name{color:#fff;align-items:center;gap:10px;margin-bottom:10px;font-size:18px;font-weight:800;display:flex}.pub-footer-brand-desc{color:#ffffff73;max-width:240px;font-size:13px;line-height:1.7}.pub-footer-col-title{color:#ffffffb3;letter-spacing:1.2px;text-transform:uppercase;margin-bottom:16px;font-size:11px;font-weight:700}.pub-footer-links{flex-direction:column;gap:10px;list-style:none;display:flex}.pub-footer-links a{color:#ffffff73;font-size:13px;text-decoration:none;transition:color .15s}.pub-footer-links a:hover{color:#ffffffd9}.pub-footer-bottom{border-top:1px solid #ffffff12;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;max-width:1160px;margin:0 auto;padding-top:24px;display:flex}.pub-footer-copy{color:#ffffff47;font-size:12px}.pub-footer-legal{gap:20px;display:flex}.pub-footer-legal a{color:#ffffff59;font-size:12px;text-decoration:none;transition:color .15s}.pub-footer-legal a:hover{color:#ffffffa6}.pub-page-hero{text-align:center;background:linear-gradient(155deg,#071827 0%,#1e3a5f 100%);padding:72px 24px}.pub-page-hero-title{color:#fff;letter-spacing:-.5px;margin-bottom:14px;font-size:42px;font-weight:800}.pub-page-hero-sub{color:#ffffff9e;max-width:560px;margin:0 auto;font-size:17px;line-height:1.7}.pub-form-wrap{max-width:700px;margin:0 auto}.pub-form-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:40px}.pub-form-title{color:#0f172a;margin-bottom:6px;font-size:26px;font-weight:800}.pub-form-sub{color:#64748b;margin-bottom:28px;font-size:14px;line-height:1.65}.pub-form-grid{grid-template-columns:1fr 1fr;gap:16px;display:grid}.pub-form-group{margin-bottom:16px}.pub-form-group.full{grid-column:1/-1}.pub-form-label{color:#374151;margin-bottom:6px;font-size:13px;font-weight:600;display:block}.pub-form-input,.pub-form-select,.pub-form-textarea{width:100%;font-size:14px;font-family:"Inter", var(--font-sans);color:#0f172a;background:#fff;border:1.5px solid #e2e8f0;border-radius:8px;outline:none;padding:10px 14px;transition:border-color .15s}.pub-form-input:focus,.pub-form-select:focus,.pub-form-textarea:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.pub-form-textarea{resize:vertical;min-height:120px}.pub-form-submit{color:#fff;cursor:pointer;width:100%;font-size:15px;font-weight:700;font-family:"Inter", var(--font-sans);background:#1e3a5f;border:none;border-radius:8px;justify-content:center;align-items:center;gap:8px;margin-top:8px;padding:13px;transition:background .15s;display:flex}.pub-form-submit:hover{background:#264d7a}.pub-form-submit:disabled{opacity:.6;cursor:not-allowed}.pub-form-success{text-align:center;color:#059669;background:#10b98114;border:1px solid #10b98140;border-radius:10px;margin-bottom:20px;padding:16px 20px;font-size:15px;font-weight:600}.pub-form-error{color:#dc2626;background:#ef44440f;border:1px solid #ef444433;border-radius:8px;margin-bottom:16px;padding:12px 16px;font-size:13px}.pub-checkbox-row{align-items:flex-start;gap:10px;display:flex}.pub-checkbox-row input{accent-color:#1e3a5f;flex-shrink:0;margin-top:2px}.pub-checkbox-row label{color:#475569;font-size:13px;line-height:1.55}.pub-checkbox-row a{color:#3b82f6;text-decoration:underline}.pub-faq-list{max-width:760px;margin:0 auto}.pub-faq-group{margin-bottom:36px}.pub-faq-group-title{color:#3b82f6;letter-spacing:1.2px;text-transform:uppercase;margin-bottom:14px;font-size:12px;font-weight:700}.pub-faq-item{background:#fff;border:1px solid #e2e8f0;border-radius:10px;margin-bottom:8px;transition:border-color .15s;overflow:hidden}.pub-faq-item.open{border-color:#3b82f6}.pub-faq-q{text-align:left;color:#0f172a;cursor:pointer;width:100%;font-size:14px;font-weight:600;font-family:"Inter", var(--font-sans);background:0 0;border:none;justify-content:space-between;align-items:center;gap:12px;padding:18px 20px;display:flex}.pub-faq-chevron{color:#94a3b8;flex-shrink:0;transition:transform .2s}.pub-faq-item.open .pub-faq-chevron{color:#3b82f6;transform:rotate(180deg)}.pub-faq-a{color:#64748b;padding:0 20px 18px;font-size:14px;line-height:1.75}.pub-legal-wrap{max-width:800px;margin:0 auto;padding:60px 24px 80px}.pub-legal-eyebrow{color:#3b82f6;letter-spacing:1.2px;text-transform:uppercase;margin-bottom:8px;font-size:12px;font-weight:700}.pub-legal-title{color:#0f172a;letter-spacing:-.5px;margin-bottom:8px;font-size:38px;font-weight:800}.pub-legal-meta{color:#94a3b8;margin-bottom:20px;font-size:13px}.pub-legal-notice{color:#92400e;background:#f59e0b12;border:1px solid #f59e0b38;border-radius:8px;margin-bottom:36px;padding:12px 16px;font-size:13px;line-height:1.6}.pub-legal-body h2{color:#0f172a;border-top:1px solid #f1f5f9;margin:36px 0 12px;padding-top:8px;font-size:20px;font-weight:700}.pub-legal-body h3{color:#1e293b;margin:22px 0 8px;font-size:16px;font-weight:600}.pub-legal-body p{color:#475569;margin-bottom:14px;font-size:14.5px;line-height:1.8}.pub-legal-body ul,.pub-legal-body ol{color:#475569;margin-bottom:14px;padding-left:22px;font-size:14.5px}.pub-legal-body li{margin-bottom:7px;line-height:1.7}.pub-legal-body a{color:#3b82f6}.pub-values-grid{grid-template-columns:repeat(3,1fr);gap:24px;display:grid}.pub-value-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:28px}.pub-value-icon{margin-bottom:14px}.pub-value-title{color:#0f172a;margin-bottom:8px;font-size:16px;font-weight:700}.pub-value-desc{color:#64748b;font-size:14px;line-height:1.65}@media (width<=1024px){.pub-trust-grid{grid-template-columns:repeat(4,1fr)}.pub-pricing-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=900px){.pub-hero-inner{grid-template-columns:1fr}.pub-hero-title{font-size:38px}.pub-feature-grid,.pub-problem-grid{grid-template-columns:repeat(2,1fr)}.pub-solution-grid{grid-template-columns:1fr}.pub-security-grid{grid-template-columns:repeat(2,1fr)}.pub-footer-inner{grid-template-columns:1fr 1fr 1fr}.pub-form-grid{grid-template-columns:1fr}}@media (width<=768px){.pub-nav-links{display:none}.pub-nav-mobile-btn{display:flex}.pub-nav-actions .pub-btn-outline{display:none}.pub-hero{padding:64px 16px 52px}.pub-section{padding:56px 16px}.pub-trust-grid{grid-template-columns:repeat(2,1fr)}.pub-feature-grid,.pub-testimonial-grid,.pub-pricing-grid{grid-template-columns:1fr}.pub-avail-grid{grid-template-columns:repeat(2,1fr)}.pub-security-grid,.pub-values-grid{grid-template-columns:1fr}.pub-section-title,.pub-page-hero-title{font-size:28px}.pub-cta-title{font-size:30px}.pub-footer-inner{grid-template-columns:1fr 1fr;gap:28px}.pub-form-card{padding:24px}}@media (width<=480px){.pub-hero-stats{flex-wrap:wrap;gap:20px}.pub-problem-grid,.pub-avail-grid{grid-template-columns:1fr}.pub-trust-grid{grid-template-columns:1fr 1fr}.pub-footer-inner{grid-template-columns:1fr}.pub-cta-actions{flex-direction:column;align-items:center}.pub-hero-cta{flex-direction:column;align-items:flex-start}}.loc-dropdowns,.loc-fallback{width:100%}.loc-hint{color:var(--color-text-muted);margin-top:var(--space-sm);font-size:11px}.loc-hint-setup{padding:var(--space-sm) var(--space-md);background:var(--color-bg);border-radius:var(--radius-sm);border-left:3px solid var(--color-border);color:var(--color-text-muted);font-size:11px;line-height:1.5}.prop-gallery{width:100%}.prop-gallery-loading{color:var(--color-text-muted);text-align:center;padding:24px}.prop-gallery-empty{text-align:center;color:var(--color-text-muted);background:var(--color-bg);border-radius:var(--radius-md);border:1px dashed var(--color-border);padding:32px}.prop-gallery-empty p{margin-bottom:12px}.prop-gallery-grid{gap:var(--space-md);grid-template-columns:repeat(auto-fill,minmax(160px,1fr));display:grid}.prop-gallery-item{border-radius:var(--radius-md);border:2px solid var(--color-border);background:var(--color-bg);position:relative;overflow:hidden}.prop-gallery-item.is-cover{border-color:var(--color-primary)}.prop-gallery-img{object-fit:cover;cursor:zoom-in;width:100%;height:130px;display:block}.prop-gallery-cover-badge{background:var(--color-primary);color:#fff;border-radius:var(--radius-full);letter-spacing:.5px;text-transform:uppercase;padding:2px 6px;font-size:10px;font-weight:700;position:absolute;top:6px;left:6px}.prop-gallery-caption{color:var(--color-text-muted);white-space:nowrap;text-overflow:ellipsis;margin:0;padding:4px 8px;font-size:11px;overflow:hidden}.prop-gallery-actions{gap:8px;padding:4px 8px 6px;display:flex}.prop-gallery-actions .btn-link{font-size:11px}.prop-gallery-actions .btn-link-danger{color:var(--color-danger)!important}.prop-gallery-upload-cell{border:2px dashed var(--color-border);border-radius:var(--radius-md);justify-content:center;align-items:center;min-height:130px;display:flex}.prop-gallery-upload-btn{color:var(--color-primary);cursor:pointer;font-size:13px;font-weight:600;font-family:var(--font-sans);background:0 0;border:none;padding:16px}.prop-gallery-upload-btn:disabled{opacity:.6;cursor:wait}.prop-gallery-upload-btn:hover:not(:disabled){text-decoration:underline}.prop-lightbox{z-index:1000;cursor:zoom-out;background:#000000d1;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.prop-lightbox-img{object-fit:contain;border-radius:var(--radius-md);max-width:90vw;max-height:88vh}@media (width<=640px){.prop-gallery-grid{grid-template-columns:repeat(2,1fr)}}.stat-sub{font-size:var(--font-size-xs);color:var(--color-text-muted);margin-top:3px;font-weight:500}.ws-welcome-strip{margin-bottom:var(--space-xl);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;display:flex}.ws-welcome-name{font-size:var(--font-size-xl);color:var(--color-text);font-weight:800;line-height:1.2}.ws-welcome-date{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-top:2px;display:block}.ws-welcome-right{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.ws-welcome-bracket{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-full);font-size:var(--font-size-xs);color:var(--color-text-muted);padding:4px 12px;font-weight:600}.ws-welcome-renewal{font-size:var(--font-size-xs);color:var(--color-text-muted)}.ws-alert-list{margin-bottom:var(--space-xl);flex-direction:column;gap:8px;display:flex}.ws-alert-item{border-radius:var(--radius-md);border:1px solid #0000;align-items:flex-start;gap:12px;padding:12px 16px;display:flex}.ws-alert-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px;margin-top:5px}.ws-alert-title{font-size:var(--font-size-sm);margin-bottom:2px;font-weight:700}.ws-alert-msg{font-size:var(--font-size-sm);color:var(--color-text-muted)}.ws-panel-row{gap:var(--space-lg);margin-bottom:var(--space-lg);grid-template-columns:1fr 1fr;display:grid}@media (width<=900px){.ws-panel-row{grid-template-columns:1fr}}.ws-metric-panel .card-header{align-items:flex-start}.ws-metric-headline{font-size:var(--font-size-xl);color:var(--color-text);font-weight:800}.ws-progress-wrap{margin-bottom:var(--space-md)}.ws-progress-track{background:var(--color-border);border-radius:4px;height:8px;margin-bottom:6px;overflow:hidden}.ws-progress-fill{border-radius:4px;height:100%;transition:width .5s}.ws-progress-label{font-size:var(--font-size-xs);color:var(--color-text-muted);font-weight:500}.ws-metric-items{flex-direction:column;gap:0;display:flex}.ws-metric-item{border-bottom:1px solid var(--color-border);font-size:var(--font-size-sm);justify-content:space-between;align-items:center;padding:10px 0;display:flex}.ws-metric-item:last-child{border-bottom:none}.ws-metric-item-label{color:var(--color-text-muted)}.ws-metric-item-value{border-radius:var(--radius-full);font-weight:700;font-size:var(--font-size-xs);padding:2px 10px}.ws-sub-plan-row{margin-bottom:var(--space-md);padding-bottom:var(--space-md);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:baseline;display:flex}.ws-sub-plan-name{font-size:var(--font-size-md);color:var(--color-text);font-weight:700}.ws-sub-fee{font-size:var(--font-size-xl);color:var(--color-primary);font-weight:800}.ws-sub-period{font-size:var(--font-size-sm);color:var(--color-text-muted);font-weight:400}.ws-sub-details{flex-direction:column;gap:0;display:flex}.ws-sub-detail-row{border-bottom:1px solid var(--color-border);font-size:var(--font-size-sm);justify-content:space-between;align-items:center;padding:9px 0;display:flex}.ws-sub-detail-row:last-child{border-bottom:none}.ws-sub-detail-row dt{color:var(--color-text-muted);font-weight:500}.ws-sub-detail-row dd{color:var(--color-text);font-weight:600}.ws-sub-upgrade-notice{margin-top:var(--space-md);border-radius:var(--radius-md);font-size:var(--font-size-sm);color:#92400e;background:#fffbeb;border:1px solid #fde68a;align-items:flex-start;gap:8px;padding:10px 14px;display:flex}.ws-db-header{margin-bottom:var(--space-xl);padding-bottom:var(--space-lg);border-bottom:1px solid var(--color-border)}.ws-db-breadcrumb{letter-spacing:1.2px;text-transform:uppercase;color:var(--color-text-muted);margin-bottom:10px;font-size:10px;font-weight:700}.ws-db-breadcrumb-sep{opacity:.4;margin:0 6px}.ws-db-title-row{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.ws-db-title{color:var(--color-text);letter-spacing:-.4px;margin-bottom:6px;font-size:1.6rem;font-weight:800;line-height:1.2}.ws-db-sub-info{font-size:var(--font-size-sm);color:var(--color-text-muted);flex-wrap:wrap;align-items:center;gap:6px;display:flex}.ws-db-dot{opacity:.4}.ws-db-meta{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.ws-db-period-badge{border-radius:var(--radius-full);background:var(--color-bg);border:1px solid var(--color-border);color:var(--color-text-muted);padding:3px 10px;font-size:11px;font-weight:600}.ws-db-role-badge{border-radius:var(--radius-full);color:#166534;text-transform:uppercase;letter-spacing:.05em;background:#f0fdf4;border:1px solid #bbf7d0;padding:3px 10px;font-size:10px;font-weight:700}.ws-db-refresh-btn{border-radius:var(--radius-md);border:1px solid var(--color-border);font-size:var(--font-size-sm);color:var(--color-text);font-weight:600;font-family:var(--font-sans);cursor:pointer;transition:var(--transition);background:#fff;align-items:center;gap:6px;padding:7px 14px;display:inline-flex}.ws-db-refresh-btn:hover:not(:disabled){border-color:var(--color-green);color:var(--color-green)}.ws-db-refresh-btn:disabled{opacity:.5;cursor:not-allowed}.ws-quick-actions-card{border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-md) var(--space-lg);margin-bottom:var(--space-lg);background:#fff}.ws-quick-actions-label{letter-spacing:1.1px;text-transform:uppercase;color:var(--color-text-muted);margin-bottom:var(--space-sm);font-size:10px;font-weight:700}.ws-quick-actions-row{flex-wrap:wrap;gap:8px;display:flex}.ws-quick-btn{border-radius:var(--radius-md);border:1.5px solid var(--color-border);color:var(--color-text);transition:var(--transition);white-space:nowrap;background:#fff;flex-direction:row;align-items:center;gap:7px;padding:8px 16px;text-decoration:none;display:inline-flex}.ws-quick-btn:hover{border-color:var(--color-green);color:var(--color-green);background:#f0fdf4}.ws-quick-btn-primary{color:#fff;background:#111827;border-color:#111827}.ws-quick-btn-primary:hover{color:#fff;background:#1f2937;border-color:#1f2937}.ws-quick-btn-icon{flex-shrink:0;align-items:center;display:flex}.ws-quick-btn-label{font-size:var(--font-size-sm);font-weight:600;line-height:1.3}@media (width<=640px){.ws-quick-actions-row{gap:6px}.ws-quick-btn{font-size:var(--font-size-xs);padding:7px 12px}}.ws-empty-dashboard{max-width:700px;margin:0 auto}.ws-empty-dash-inner{text-align:center;border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);background:#fff;padding:60px 24px 40px}.ws-empty-dash-icon{margin-bottom:var(--space-lg);font-size:56px}.ws-empty-dash-title{font-size:var(--font-size-xl);color:var(--color-text);margin-bottom:var(--space-sm);font-weight:800}.ws-empty-dash-sub{font-size:var(--font-size-sm);color:var(--color-text-muted);max-width:480px;margin:0 auto;line-height:1.6}.dash-section-header{margin:var(--space-xl) 0 var(--space-sm);align-items:baseline;gap:12px;display:flex}.dash-section-title{font-size:var(--font-size-md);color:var(--color-text);font-weight:800}.dash-section-sub{font-size:var(--font-size-xs);color:var(--color-text-muted)}.dash-card{border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-lg);margin-bottom:var(--space-lg);background:#fff}.dash-live-row{margin-bottom:var(--space-lg)}.dash-live-col{border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-lg);background:#fff}.activity-feed{flex-direction:column;gap:0;display:flex}.activity-feed__empty{text-align:center;padding:32px 0}.activity-feed__empty-title{color:var(--color-text);margin-bottom:8px;font-weight:700}.activity-feed__empty-sub{font-size:var(--font-size-sm);color:var(--color-text-muted);max-width:420px;margin:0 auto;line-height:1.6}.activity-item{border-bottom:1px solid var(--color-border);gap:14px;padding:14px 0;display:flex}.activity-item:last-child{border-bottom:none}.activity-item__dot{background:var(--color-primary);border-radius:50%;flex-shrink:0;width:8px;height:8px;margin-top:6px}.activity-item__body{flex:1;min-width:0}.activity-item__top{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:3px;display:flex}.activity-item__title{font-size:var(--font-size-sm);color:var(--color-text);font-weight:700}.activity-item__desc{font-size:var(--font-size-xs);color:var(--color-text-muted);margin:0 0 4px}.activity-item__meta{font-size:var(--font-size-xs);color:var(--color-text-muted);gap:12px;display:flex}.activity-item__actor{opacity:.7}.activity-badge{border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.04em;padding:2px 8px;font-size:10px;font-weight:700}.activity-badge--green{color:#166534;background:#dcfce7}.activity-badge--blue{color:#1e40af;background:#dbeafe}.activity-badge--purple{color:#6b21a8;background:#f3e8ff}.activity-badge--amber{color:#92400e;background:#fef3c7}.activity-badge--red{color:#991b1b;background:#fee2e2}.activity-badge--teal{color:#134e4a;background:#ccfbf1}.activity-badge--gray{color:#475569;background:#f1f5f9}.lrp-list{flex-direction:column;gap:0;display:flex}.lrp-row{border-bottom:1px solid var(--color-border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:11px 0;display:flex}.lrp-row:last-child{border-bottom:none}.lrp-row__left{flex-direction:column;gap:2px;min-width:0;display:flex}.lrp-row__name{font-size:var(--font-size-sm);color:var(--color-text);font-weight:700}.lrp-row__unit{font-size:var(--font-size-xs);color:var(--color-text-muted)}.lrp-row__right{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.lrp-row__amount{font-size:var(--font-size-sm);color:var(--color-text);font-weight:700}.lrp-row__method,.lrp-row__time{font-size:var(--font-size-xs);color:var(--color-text-muted)}.ldp-grid{gap:var(--space-lg);margin-bottom:var(--space-lg);grid-template-columns:1fr 1fr;display:grid}@media (width<=900px){.ldp-grid{grid-template-columns:1fr}}.ldp-section{border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-md);background:#fff}.ldp-section__title{font-size:var(--font-size-sm);color:var(--color-text);margin-bottom:var(--space-sm);border-bottom:1px solid var(--color-border);padding-bottom:8px;font-weight:700}.ldp-section__empty{font-size:var(--font-size-xs);color:var(--color-text-muted);padding:10px 0}.ldp-row{border-bottom:1px solid var(--color-border);font-size:var(--font-size-xs);flex-wrap:wrap;align-items:center;gap:8px;padding:8px 0;display:flex}.ldp-row:last-child{border-bottom:none}.ldp-row__name{color:var(--color-text);text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-weight:600;overflow:hidden}.ldp-row__label{color:var(--color-text-muted)}.ldp-row__time{color:var(--color-text-muted);white-space:nowrap;margin-left:auto}.charts-grid{gap:var(--space-lg);margin-bottom:var(--space-xl);grid-template-columns:1fr 1fr;display:grid}@media (width<=1100px){.charts-grid{grid-template-columns:1fr}}.chart-card{border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-lg);background:#fff}.chart-card__title{font-size:var(--font-size-sm);color:var(--color-text);margin-bottom:var(--space-md);font-weight:700}.chart-card__body{width:100%}.chart-card__empty{text-align:center;font-size:var(--font-size-sm);color:var(--color-text-muted);padding:32px 0}.spinner--xs{vertical-align:middle;border-width:1.5px;width:10px;height:10px;display:inline-block}.issue-btn-group{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:12px;display:flex}.issue-method-options{flex-direction:column;gap:10px;display:flex}.issue-method-option{border:1.5px solid var(--color-border);border-radius:var(--radius);cursor:pointer;align-items:flex-start;gap:10px;padding:12px 14px;transition:border-color .15s;display:flex}.issue-method-option.selected{border-color:var(--color-primary);background:var(--color-primary-ghost,#4f46e50a)}.issue-method-option input[type=radio]{flex-shrink:0;margin-top:3px}.issue-method-label{font-size:var(--font-size-sm);flex-direction:column;gap:2px;display:flex}.issue-method-label strong{font-size:.875rem}.issue-method-label span{color:var(--color-text-muted);font-size:.8rem}.btn-xs{padding:3px 8px;font-size:.75rem}.btn-danger{border-color:var(--color-danger);color:var(--color-danger)}.btn-danger:hover{background:var(--color-danger);color:#fff}.prop-filters{gap:var(--space-sm);margin-bottom:var(--space-lg);flex-wrap:wrap;align-items:center;display:flex}.prop-filters .form-control{width:auto}.prop-filter-search{flex:1;min-width:220px}.prop-count-bar{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-bottom:8px}.prop-link{color:var(--color-primary);font-weight:600;font-size:var(--font-size-sm);cursor:pointer;text-align:left;background:0 0;border:none;padding:0}.prop-link:hover{text-decoration:underline}.prop-actions-dropdown{display:inline-block;position:relative}.prop-actions-menu{border:1px solid var(--color-border);border-radius:var(--radius-md);background:#fff;min-width:140px;padding:4px 0;box-shadow:0 4px 20px #0000001a}.prop-actions-item{text-align:left;width:100%;font-size:var(--font-size-sm);color:var(--color-text);cursor:pointer;white-space:nowrap;background:0 0;border:none;padding:8px 14px;font-family:inherit;transition:background .12s;display:block}.prop-actions-item:hover{background:var(--color-bg)}.prop-actions-item-danger{color:var(--color-danger,#dc2626)}.prop-actions-item-danger:hover{color:var(--color-danger,#dc2626);background:#fff5f5}.prop-actions-divider{background:var(--color-border);height:1px;margin:4px 0}.prop-list-desktop{display:block}.prop-list-mobile{display:none}@media (width<=820px){.prop-list-desktop{display:none}.prop-list-mobile{gap:var(--space-md);grid-template-columns:repeat(auto-fill,minmax(280px,1fr));display:grid}}.prop-card{border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-md);box-shadow:var(--shadow-sm);background:#fff;transition:box-shadow .15s}.prop-card:hover{box-shadow:var(--shadow-md,0 4px 12px #00000014)}.prop-card-top{justify-content:space-between;align-items:flex-start;gap:8px;display:flex}.prop-card-name{font-weight:700;font-size:var(--font-size-md);line-height:1.3}.prop-card-code{font-size:var(--font-size-xs);color:var(--color-text-muted);margin-top:2px}.prop-card-meta{flex-wrap:wrap;align-items:center;gap:8px;margin:10px 0;display:flex}.prop-card-loc{font-size:var(--font-size-xs);color:var(--color-text-muted)}.prop-card-stats{margin-bottom:var(--space-md);grid-template-columns:repeat(3,1fr);gap:8px;display:grid}.prop-card-stats>div{text-align:center;background:var(--color-bg);border-radius:var(--radius-sm);padding:8px 4px}.prop-card-stats strong{font-size:var(--font-size-md);font-weight:800;display:block}.prop-card-stats span{color:var(--color-text-muted);font-size:10px}.prop-card-actions{justify-content:flex-end;gap:6px;display:flex}.prop-pagination{margin-top:var(--space-lg);flex-wrap:wrap;justify-content:center;align-items:center;gap:4px;display:flex}.prop-pagination-btn{border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);font-size:var(--font-size-sm);cursor:pointer;background:#fff;min-width:38px;padding:6px 13px;font-family:inherit;transition:background .12s,border-color .12s,color .12s}.prop-pagination-btn:hover:not(:disabled){background:var(--color-bg);border-color:var(--color-primary);color:var(--color-primary)}.prop-pagination-btn.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff;font-weight:600}.prop-pagination-btn:disabled{opacity:.4;cursor:not-allowed}.prop-pagination-ellipsis{color:var(--color-text-muted);font-size:var(--font-size-sm);-webkit-user-select:none;user-select:none;padding:6px 2px}.prop-img-preview{border-radius:var(--radius-md);border:1px solid var(--color-border);max-width:320px;margin-top:10px;overflow:hidden}.prop-img-preview img{object-fit:cover;width:100%;max-height:180px;display:block}.prop-img-error{color:var(--color-danger,#dc2626);font-size:var(--font-size-sm);margin:4px 0 0}.prop-form-hint{font-size:var(--font-size-xs);color:var(--color-text-muted);margin:4px 0 0}.prop-form-section-label{font-size:var(--font-size-xs);letter-spacing:.6px;text-transform:uppercase;color:var(--color-text-muted);margin:var(--space-md) 0 var(--space-sm);border-bottom:1px solid var(--color-border);padding-bottom:4px;font-weight:700}.prop-form-section-label:first-child{margin-top:0}.prop-details-cover{border-radius:var(--radius-lg);width:100%;height:220px;margin-bottom:var(--space-md);border:1px solid var(--color-border);background:var(--color-bg);overflow:hidden}.prop-details-cover-img{object-fit:cover;width:100%;height:100%;display:block}.prop-details-cover-placeholder{background:linear-gradient(135deg,#f1f5f9 0%,#e8edf2 100%);justify-content:center;align-items:center;width:100%;height:100%;display:flex}.prop-details-cover-placeholder span{font-size:var(--font-size-sm);color:var(--color-text-muted);letter-spacing:.2px;font-weight:500}.prop-details-head{margin-bottom:var(--space-md);justify-content:space-between;align-items:flex-start;display:flex}.prop-details-name{font-size:var(--font-size-lg);font-weight:800;line-height:1.2}.prop-details-code{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-top:2px}.prop-detail-list{flex-direction:column;gap:0;display:flex}.prop-detail-row{border-bottom:1px solid var(--color-border);font-size:var(--font-size-sm);justify-content:space-between;gap:16px;padding:9px 0;display:flex}.prop-detail-row:last-child{border-bottom:none}.prop-detail-row dt{color:var(--color-text-muted);flex-shrink:0}.prop-detail-row dd{text-align:right;word-break:break-word;font-weight:600}.prop-details-desc{margin-top:var(--space-md)}.prop-img-gallery{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:8px;margin-top:8px;display:grid}.prop-img-gallery-item{border-radius:var(--radius-md);border:1px solid var(--color-border);aspect-ratio:4/3;background:var(--color-bg);position:relative;overflow:hidden}.prop-img-gallery-item img{object-fit:cover;width:100%;height:100%;display:block}.prop-img-cover-badge{background:var(--color-primary);color:#fff;border-radius:var(--radius-sm);pointer-events:none;padding:2px 6px;font-size:10px;font-weight:700;position:absolute;top:4px;left:4px}.prop-img-caption{color:#fff;text-overflow:ellipsis;white-space:nowrap;pointer-events:none;background:#00000080;padding:4px 6px;font-size:10px;position:absolute;bottom:0;left:0;right:0;overflow:hidden}.prop-future-grid{gap:var(--space-sm);margin-top:var(--space-lg);grid-template-columns:repeat(3,1fr);display:grid}.prop-future-card{border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-md);text-align:center;color:var(--color-text);transition:var(--transition);text-decoration:none;display:block}.prop-future-card:hover:not(.prop-future-disabled){border-color:var(--color-primary);box-shadow:var(--shadow-sm)}.prop-future-disabled{opacity:.5;cursor:default}.prop-future-title{font-weight:700;font-size:var(--font-size-sm);margin-bottom:4px}.prop-future-text{color:var(--color-text-muted);font-size:11px;line-height:1.4}.prop-details-foot{margin-top:var(--space-lg);justify-content:flex-end;display:flex}@media (width<=768px){.prop-future-grid{grid-template-columns:repeat(2,1fr)}.prop-details-cover{height:180px}}@media (width<=600px){.prop-filters{flex-direction:column;align-items:stretch}.prop-filters .form-control,.prop-filter-search{width:100%}.export-group{justify-content:flex-start;width:100%}.prop-future-grid{grid-template-columns:1fr}.prop-details-cover{height:150px}.prop-details-head{flex-direction:column;gap:8px}}@media (width<=480px){.prop-pagination-btn{min-width:32px;padding:5px 9px;font-size:12px}}.unit-card{border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);background:#fff;overflow:hidden}.unit-card-image{background:var(--color-bg);width:100%;height:140px;overflow:hidden}.unit-card-image img{object-fit:cover;width:100%;height:100%;display:block}.unit-card-top{justify-content:space-between;align-items:flex-start;gap:8px;display:flex}.unit-card-name{font-weight:700;font-size:var(--font-size-md)}.unit-card-code{font-size:var(--font-size-xs);color:var(--color-text-muted)}.unit-card-meta{flex-wrap:wrap;align-items:center;gap:8px;margin:10px 0;display:flex}.unit-card-prop{font-size:var(--font-size-xs);color:var(--color-text-muted)}.unit-card-rent{margin-bottom:var(--space-md);grid-template-columns:repeat(2,1fr);gap:8px;display:grid}.unit-card-rent>div{text-align:center;background:var(--color-bg);border-radius:var(--radius-sm);padding:8px 4px}.unit-card-rent strong{font-size:var(--font-size-sm);font-weight:800;display:block}.unit-card-rent span{color:var(--color-text-muted);font-size:10px}.unit-card-actions{justify-content:flex-end;gap:6px;display:flex}.unit-table-name-cell{align-items:center;gap:8px;display:flex}.unit-thumb{border-radius:var(--radius-sm);object-fit:cover;border:1px solid var(--color-border);flex-shrink:0;width:36px;height:36px}.unit-cat-badge{white-space:nowrap;border-radius:20px;align-items:center;gap:4px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-flex}.unit-cat-residential{color:#1d4ed8;background:#eff6ff;border:1px solid #bfdbfe}.unit-cat-commercial{color:#7c3aed;background:#faf5ff;border:1px solid #ddd6fe}.unit-vat-badge{border-radius:10px;padding:1px 5px;font-size:10px;font-weight:700}.unit-vat-enabled{color:#15803d;background:#f0fdf4;border:1px solid #bbf7d0}.unit-vat-disabled{color:#6b7280;background:#f9fafb;border:1px solid #e5e7eb}.tenant-summary-grid{gap:var(--space-md);margin-bottom:var(--space-lg);grid-template-columns:repeat(5,1fr);display:grid}@media (width<=1024px){.tenant-summary-grid{grid-template-columns:repeat(3,1fr)}}@media (width<=640px){.tenant-summary-grid{grid-template-columns:repeat(2,1fr)}}.tenant-summary-card{border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-md) var(--space-lg);box-shadow:var(--shadow-sm);background:#fff;flex-direction:column;gap:4px;display:flex}.tenant-summary-value{color:var(--color-text);font-size:28px;font-weight:800;line-height:1}.tenant-summary-label{font-size:var(--font-size-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px;font-weight:500}.tenant-card-active .tenant-summary-value{color:var(--color-success)}.tenant-card-pending .tenant-summary-value{color:var(--color-warning)}.tenant-card-moved-out .tenant-summary-value{color:var(--color-text-muted)}.tenant-card-archived .tenant-summary-value{color:#9ca3af}.tenant-badge{letter-spacing:.3px;white-space:nowrap;border-radius:99px;align-items:center;padding:2px 10px;font-size:11px;font-weight:600;display:inline-flex}.tenant-badge-active{color:#166534;background:#dcfce7}.tenant-badge-pending{color:#854d0e;background:#fef9c3}.tenant-badge-moved-out{color:#475569;background:#f1f5f9}.tenant-badge-suspended{color:#9a3412;background:#fde8d8}.tenant-badge-archived{color:#71717a;background:#f4f4f5}.tenant-table-wrap{border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);background:#fff;overflow-x:auto}.tenant-table{border-collapse:collapse;width:100%;font-size:var(--font-size-sm)}.tenant-table th{background:var(--color-bg);text-align:left;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-muted);border-bottom:1px solid var(--color-border);white-space:nowrap;padding:10px 14px;font-size:11px;font-weight:700}.tenant-table td{border-bottom:1px solid var(--color-border);vertical-align:middle;color:var(--color-text);padding:12px 14px}.tenant-table tr:last-child td{border-bottom:none}.tenant-table tr:hover td{background:var(--color-bg)}.tenant-table-name{font-weight:600}.tenant-table-email{color:var(--color-text-muted);margin-top:2px;font-size:11px}.tenant-table-unit{font-size:var(--font-size-sm);font-weight:500}.tenant-table-unit-sub{color:var(--color-text-muted);margin-top:2px;font-size:11px}.tenant-code-chip{background:var(--color-bg);border:1px solid var(--color-border);color:var(--color-text-muted);white-space:nowrap;border-radius:4px;padding:1px 8px;font-family:monospace;font-size:11px;font-weight:700;display:inline-block}.tenant-dep-paid{color:var(--color-success);font-weight:600}.tenant-dep-unpaid{color:var(--color-danger);font-weight:600}.tenant-table-actions{flex-wrap:nowrap;align-items:center;gap:6px;display:flex}.btn-link{cursor:pointer;color:var(--color-primary);white-space:nowrap;background:0 0;border:none;border-radius:3px;padding:2px 4px;font-size:12px;font-weight:600;transition:background .15s}.tenant-list-desktop{display:block}.tenant-list-mobile{display:none}@media (width<=900px){.tenant-list-desktop{display:none}.tenant-list-mobile{gap:var(--space-md);flex-direction:column;display:flex}}.tenant-card{border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-md);box-shadow:var(--shadow-sm);background:#fff}.tenant-card-top{justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:10px;display:flex}.tenant-card-name{font-weight:700;font-size:var(--font-size-md)}.tenant-card-code{font-size:var(--font-size-xs);color:var(--color-text-muted);margin-top:2px}.tenant-card-meta{flex-wrap:wrap;gap:6px;margin-bottom:12px;display:flex}.tenant-card-meta-item{background:var(--color-bg);border:1px solid var(--color-border);color:var(--color-text-muted);border-radius:4px;padding:2px 8px;font-size:11px}.tenant-card-rent{margin-bottom:var(--space-md);grid-template-columns:repeat(3,1fr);gap:8px;display:grid}.tenant-card-rent>div{text-align:center;background:var(--color-bg);border-radius:var(--radius-sm);padding:8px 4px}.tenant-card-rent strong{font-size:var(--font-size-sm);font-weight:800;display:block}.tenant-card-rent span{color:var(--color-text-muted);font-size:10px}.tenant-card-actions{flex-wrap:wrap;gap:6px;display:flex}.tenant-card-actions .btn{flex:1;justify-content:center;min-width:60px}.tenant-form{flex-direction:column;gap:0;display:flex}.tenant-form-section{padding:var(--space-md) 0;border-bottom:1px solid var(--color-border)}.tenant-form-section:last-child{border-bottom:none}.tenant-form-section-title{text-transform:uppercase;letter-spacing:.6px;color:var(--color-text-muted);margin-bottom:var(--space-md);font-size:11px;font-weight:700}.tenant-form-row{gap:var(--space-md);grid-template-columns:1fr 1fr;display:grid}@media (width<=600px){.tenant-form-row{grid-template-columns:1fr}}.tenant-form-checkbox{font-size:var(--font-size-sm);cursor:pointer;color:var(--color-text);align-items:center;gap:8px;font-weight:500;display:flex}.tenant-form-checkbox input{cursor:pointer;width:16px;height:16px}.tenant-form-no-units{color:var(--color-warning);font-size:var(--font-size-xs);margin-top:4px}.form-hint{color:var(--color-text-muted);margin-top:4px;font-size:11px}.tenant-detail-panel{flex-direction:column;gap:0;display:flex}.tenant-detail-header{padding-bottom:var(--space-md);border-bottom:1px solid var(--color-border);margin-bottom:var(--space-md);justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.tenant-detail-name{font-size:var(--font-size-lg);font-weight:700}.tenant-detail-code{font-size:var(--font-size-xs);color:var(--color-text-muted);margin-top:2px;font-family:monospace}.tenant-detail-section{padding:var(--space-md) 0;border-bottom:1px solid var(--color-border)}.tenant-detail-section:last-child{border-bottom:none}.tenant-detail-section-title{text-transform:uppercase;letter-spacing:.6px;color:var(--color-text-muted);margin-bottom:10px;font-size:11px;font-weight:700}.tenant-detail-row{font-size:var(--font-size-sm);justify-content:space-between;align-items:flex-start;gap:12px;padding:5px 0;display:flex}.tenant-detail-label{color:var(--color-text-muted);flex-shrink:0;min-width:130px;font-weight:500}.tenant-detail-value{color:var(--color-text);text-align:right;word-break:break-word}.tenant-detail-notes{font-size:var(--font-size-sm);color:var(--color-text);white-space:pre-wrap;background:var(--color-bg);border-radius:var(--radius-sm);padding:var(--space-sm) var(--space-md);border:1px solid var(--color-border);margin:0}.btn-warning{background:var(--color-warning,#f59e0b);color:#fff;border:1px solid #0000}.btn-warning:hover{opacity:.9}.tenant-col-check{width:36px;padding:0 8px}.tenant-table-code{color:var(--color-text-muted);margin-top:1px;font-size:11px}.tenant-table-unit-sub{color:var(--color-text-muted);font-size:11px}.row-selected td{background:#f0f6ff}.rent-status-badge{border-radius:var(--radius-full);padding:2px 8px;font-size:11px;font-weight:600;display:inline-block}.rent-badge-paid{color:#065f46;background:#ecfdf5}.rent-badge-overdue{color:#991b1b;background:#fef2f2}.rent-badge-unpaid{color:#92400e;background:#fffbeb}.balance-owed{color:var(--color-danger,#ef4444);font-weight:600}.balance-clear{color:var(--color-success,#10b981);font-weight:600}.text-muted{color:var(--color-text-muted)}.tenant-actions-menu{display:inline-block;position:relative}.btn-actions-trigger{font-size:12px;font-family:var(--font-sans);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);cursor:pointer;white-space:nowrap;background:#fff;align-items:center;gap:4px;padding:4px 10px;font-weight:500;display:inline-flex}.btn-actions-trigger:hover{background:var(--color-bg)}.tenant-actions-dropdown{border:1px solid var(--color-border);border-radius:var(--radius-md);min-width:180px;max-height:320px;box-shadow:var(--shadow-lg);z-index:2000;background:#fff;overflow:hidden auto}.tenant-actions-dropdown button{text-align:left;width:100%;font-size:13px;font-family:var(--font-sans);cursor:pointer;color:var(--color-text);background:0 0;border:none;padding:8px 14px;display:block}.tenant-actions-dropdown button:hover{background:var(--color-bg)}.tenant-actions-divider{background:var(--color-border);height:1px;margin:3px 0}.tenant-action-danger{color:var(--color-danger,#ef4444)!important}.tenant-action-restore{color:var(--color-success,#10b981)!important}.tenant-filter-bar{gap:var(--space-sm);margin-bottom:var(--space-md);flex-wrap:wrap;align-items:center;display:flex}.tenant-filter-bar .form-control{flex:140px;min-width:120px}.tenant-filter-bar .prop-filter-search{flex:2 200px}.tenant-export-group{flex-wrap:wrap;align-items:center;gap:4px;display:flex}.tenant-export-group .form-control-sm{min-width:130px;padding:4px 8px;font-size:12px}.tenant-last-pay-date{color:var(--color-text);white-space:nowrap;font-size:12px}.tenant-last-pay-amount{color:var(--color-success,#10b981);margin-top:1px;font-size:12px;font-weight:600}.tenant-last-pay-none{color:var(--color-text-muted);font-size:12px;font-style:italic}.tenant-bulk-bar{align-items:center;gap:var(--space-sm);border-radius:var(--radius-md);margin-bottom:var(--space-md);background:#eff6ff;border:1px solid #bfdbfe;flex-wrap:wrap;padding:8px 14px;display:flex}.tenant-bulk-count{color:#1d4ed8;margin-right:4px;font-size:13px;font-weight:600}.btn-danger{background:var(--color-danger,#ef4444);color:#fff;border:1px solid #0000}.btn-danger:hover{background:#dc2626}.btn-link-sm{color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;padding:0 4px;font-size:12px}.btn-link-sm:hover{color:var(--color-danger)}.btn-danger-outline{border-color:var(--color-danger)!important;color:var(--color-danger)!important}.page-header-actions{gap:var(--space-sm);flex-wrap:wrap;align-items:center;display:flex}.form-hint{color:var(--color-text-muted);margin-bottom:var(--space-sm);font-size:12px}@media (width<=1100px){.tenant-filter-bar .form-control{min-width:100px}.tenant-summary-grid{grid-template-columns:repeat(3,1fr)}}@media (width<=900px){.page-header{gap:var(--space-sm);flex-wrap:wrap}.page-header-actions{flex-wrap:wrap}.tenant-summary-grid{grid-template-columns:repeat(3,1fr)}.tenant-bulk-bar{gap:6px}}@media (width<=768px){.page-header{flex-direction:column;align-items:flex-start}.page-header-actions{width:100%}.tenant-filter-bar{flex-direction:column;align-items:stretch}.tenant-export-group{justify-content:flex-start}.tenant-bulk-bar{flex-direction:column;align-items:flex-start}.tenant-summary-grid{grid-template-columns:repeat(2,1fr)}}.ob-overlay{z-index:1000;background:#00000073;justify-content:center;align-items:flex-start;padding:32px 16px 48px;display:flex;position:fixed;inset:0;overflow-y:auto}.ob-wizard{background:#fff;border-radius:12px;flex-direction:column;width:100%;max-width:700px;display:flex;box-shadow:0 12px 48px #0000002e}.ob-header{border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;padding:20px 24px 16px;display:flex}.ob-title{color:#111827;font-size:17px;font-weight:700}.ob-close{cursor:pointer;color:#6b7280;background:0 0;border:none;border-radius:6px;align-items:center;padding:4px;display:flex}.ob-close:hover{color:#374151;background:#f3f4f6}.ob-progress{border-bottom:1px solid #e5e7eb;align-items:flex-start;gap:0;padding:16px 24px;display:flex}.ob-step{flex-direction:column;flex:1;align-items:center;gap:6px;display:flex;position:relative}.ob-step:not(:last-child):after{content:"";z-index:0;background:#e5e7eb;height:2px;position:absolute;top:13px;left:55%;right:-55%}.ob-step.done:after{background:#2563eb}.ob-step.active:after{background:#e5e7eb}.ob-step-num{color:#9ca3af;z-index:1;background:#e5e7eb;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:12px;font-weight:600;transition:background .2s,color .2s;display:flex;position:relative}.ob-step.active .ob-step-num{color:#fff;background:#2563eb}.ob-step.done .ob-step-num{color:#fff;background:#16a34a}.ob-step-label{color:#9ca3af;white-space:nowrap;font-size:10px;font-weight:500}.ob-step.active .ob-step-label{color:#2563eb;font-weight:700}.ob-step.done .ob-step-label{color:#16a34a}.ob-body{min-height:280px;padding:24px}.ob-footer{border-top:1px solid #e5e7eb;align-items:center;gap:10px;padding:16px 24px;display:flex}.wizard-section{margin-bottom:24px}.wizard-section:last-child{margin-bottom:0}.wizard-section-title{text-transform:uppercase;letter-spacing:.07em;color:#6b7280;border-bottom:1px solid #f3f4f6;margin-bottom:12px;padding-bottom:6px;font-size:11px;font-weight:700}.wizard-form-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}@media (width<=560px){.wizard-form-row{grid-template-columns:1fr}}.ob-freq-options{flex-direction:column;gap:8px;display:flex}.ob-freq-option{cursor:pointer;border:1.5px solid #e5e7eb;border-radius:8px;align-items:center;gap:10px;padding:10px 14px;transition:border-color .15s,background .15s;display:flex}.ob-freq-option:hover{border-color:#93c5fd}.ob-freq-option.selected{background:#eff6ff;border-color:#2563eb}.ob-freq-option input[type=radio]{accent-color:#2563eb;flex-shrink:0}.ob-freq-label{color:#111827;font-size:14px}.ob-custom-period{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;margin-top:12px;padding:14px 16px}.ob-payment-option{cursor:pointer;border:1.5px solid #e5e7eb;border-radius:8px;align-items:flex-start;gap:12px;margin-bottom:8px;padding:12px 14px;transition:border-color .15s,background .15s;display:flex}.ob-payment-option:hover{border-color:#93c5fd}.ob-payment-option.selected{background:#eff6ff;border-color:#2563eb}.ob-payment-option input[type=radio]{accent-color:#2563eb;flex-shrink:0;margin-top:2px}.ob-payment-option-label{color:#111827;font-size:14px;font-weight:600}.ob-payment-option-desc{color:#6b7280;margin-top:2px;font-size:12px}.ob-info-box{color:#1e40af;background:#eff6ff;border:1px solid #bfdbfe;border-radius:8px;padding:12px 16px;font-size:13px}.ob-billing-summary{border:1px solid #e5e7eb;border-radius:8px;font-size:13px;overflow:hidden}.ob-billing-row{color:#374151;border-bottom:1px solid #f3f4f6;justify-content:space-between;padding:8px 14px;display:flex}.ob-billing-total{color:#111827;background:#f9fafb;justify-content:space-between;padding:10px 14px;font-weight:600;display:flex}.ob-lease-card{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.ob-lease-title{color:#111827;font-size:14px;font-weight:600}.ob-lease-meta{color:#6b7280;margin-top:2px;font-size:12px}.ob-lease-badge{color:#16a34a;background:#dcfce7;border-radius:20px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-block}.ob-upload-result{color:#374151;background:#f0fdf4;border:1px solid #d1fae5;border-radius:6px;align-items:center;gap:8px;padding:8px 12px;font-size:13px;display:flex}.ob-upload-label{cursor:pointer;align-items:center;display:flex}.btn-link-danger{cursor:pointer;color:#dc2626;background:0 0;border:none;margin-left:8px;padding:0;font-size:12px}.btn-link-danger:hover{text-decoration:underline}.ob-review-section{margin-bottom:20px}.ob-review-section:last-child{margin-bottom:0}.ob-review-section-title{text-transform:uppercase;letter-spacing:.07em;color:#9ca3af;margin-bottom:8px;font-size:11px;font-weight:700}.ob-review-row{border-bottom:1px solid #f3f4f6;justify-content:space-between;align-items:flex-start;gap:16px;padding:7px 0;font-size:13px;display:flex}.ob-review-row:last-child{border-bottom:none}.ob-review-label{color:#6b7280;flex-shrink:0;min-width:140px}.ob-review-value{color:#111827;text-align:right;font-weight:500}.ob-pending-screen{text-align:center;padding:40px 16px}.ob-pending-spinner{margin:0 auto 20px}.ob-pending-title{color:#111827;margin-bottom:10px;font-size:16px;font-weight:700}.ob-pending-detail{color:#6b7280;margin-bottom:20px;font-size:14px;line-height:1.6}.ob-payment-link-box{color:#374151;word-break:break-all;text-align:left;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;margin-bottom:12px;padding:12px 16px;font-size:12px}.ob-success{text-align:center;padding:48px 24px}.ob-success-icon{background:#dcfce7;border-radius:50%;justify-content:center;align-items:center;width:60px;height:60px;margin:0 auto 20px;display:flex}.ob-success-title{color:#111827;margin-bottom:8px;font-size:20px;font-weight:700}.ob-success-detail{color:#6b7280;font-size:14px;line-height:1.6}.billing-summary-grid{gap:var(--space-md);margin-bottom:var(--space-lg);grid-template-columns:repeat(4,1fr);display:grid}@media (width<=1024px){.billing-summary-grid{grid-template-columns:repeat(3,1fr)}}@media (width<=640px){.billing-summary-grid{grid-template-columns:repeat(2,1fr)}}.billing-summary-card{border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-md) var(--space-lg);box-shadow:var(--shadow-sm);background:#fff;flex-direction:column;gap:4px;display:flex}.billing-summary-value{color:var(--color-text);word-break:break-all;font-size:22px;font-weight:800;line-height:1.1}.billing-summary-label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:500}.billing-card-expected .billing-summary-value{color:var(--color-primary)}.billing-card-collected .billing-summary-value{color:var(--color-success)}.billing-card-pending .billing-summary-value{color:var(--color-warning)}.billing-card-overdue .billing-summary-value{color:var(--color-danger)}.billing-header-actions{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.billing-tabs{border-bottom:2px solid var(--color-border);margin-bottom:var(--space-lg);gap:0;display:flex}.billing-tab{cursor:pointer;font-size:var(--font-size-sm);color:var(--color-text-muted);background:0 0;border:none;border-bottom:2px solid #0000;align-items:center;gap:6px;margin-bottom:-2px;padding:10px 20px;font-weight:600;transition:color .15s,border-color .15s;display:flex}.billing-tab:hover{color:var(--color-text)}.billing-tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.billing-tab-count{background:var(--color-primary);color:#fff;border-radius:99px;padding:1px 6px;font-size:10px;font-weight:700}.billing-period-selector{gap:8px;display:flex}.billing-period-selector .form-control{min-width:0}.billing-filters{flex-wrap:wrap}.inv-badge{letter-spacing:.3px;white-space:nowrap;border-radius:99px;align-items:center;padding:2px 10px;font-size:11px;font-weight:600;display:inline-flex}.inv-badge-draft{color:#475569;background:#f1f5f9}.inv-badge-issued{color:#1e40af;background:#dbeafe}.inv-badge-partial{color:#854d0e;background:#fef9c3}.inv-badge-paid{color:#166534;background:#dcfce7}.inv-badge-overdue{color:#991b1b;background:#fee2e2}.inv-badge-cancelled{color:#71717a;background:#f4f4f5}.inv-badge-archived{color:#9ca3af;background:#f4f4f5}.inv-table-wrap{border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);background:#fff;overflow:hidden}.inv-table{border-collapse:collapse;width:100%;font-size:var(--font-size-sm)}.inv-table th{background:var(--color-bg);text-align:left;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-muted);border-bottom:1px solid var(--color-border);white-space:nowrap;padding:10px 12px;font-size:11px;font-weight:700}.inv-table td{border-bottom:1px solid var(--color-border);vertical-align:middle;color:var(--color-text);padding:11px 12px}.inv-table tr:last-child td{border-bottom:none}.inv-table tr:hover td{background:#fafafa}.inv-row-overdue td{background:#fff8f8}.inv-row-overdue:hover td{background:#fef2f2}.inv-number-chip{background:var(--color-bg);border:1px solid var(--color-border);white-space:nowrap;border-radius:4px;padding:1px 8px;font-family:monospace;font-size:11px;font-weight:700;display:inline-block}.inv-period{color:var(--color-text-muted);white-space:nowrap;font-size:12px}.inv-tenant-name{font-weight:600}.inv-tenant-code{color:var(--color-text-muted);margin-top:2px;font-size:11px}.inv-prop{font-size:var(--font-size-sm)}.inv-unit{color:var(--color-text-muted);margin-top:2px;font-size:11px}.inv-amount{white-space:nowrap;font-variant-numeric:tabular-nums}.inv-paid{color:var(--color-success);font-weight:600}.inv-balance-due{color:var(--color-danger);font-weight:700}.inv-balance-zero{color:var(--color-success)}.inv-overdue-date{color:var(--color-danger);font-weight:600}.inv-table-actions{flex-wrap:nowrap;align-items:center;gap:4px;display:flex}.inv-list-desktop{display:block}.inv-list-mobile{display:none}@media (width<=960px){.inv-list-desktop{display:none}.inv-list-mobile{gap:var(--space-md);flex-direction:column;display:flex}}.inv-card{border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-md);box-shadow:var(--shadow-sm);background:#fff}.inv-card-overdue{border-left:3px solid var(--color-danger)}.inv-card-top{justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:8px;display:flex}.inv-card-period{color:var(--color-text-muted);margin-top:3px;font-size:11px}.inv-card-tenant{margin-bottom:4px;font-weight:600}.inv-card-meta{color:var(--color-text-muted);margin-bottom:12px;font-size:11px}.inv-card-amounts{margin-bottom:var(--space-md);grid-template-columns:repeat(3,1fr);gap:8px;display:grid}.inv-card-amounts>div{text-align:center;background:var(--color-bg);border-radius:var(--radius-sm);padding:8px 4px}.inv-card-amounts strong{font-size:var(--font-size-sm);font-weight:800;display:block}.inv-card-amounts span{color:var(--color-text-muted);font-size:10px}.inv-card-due{color:var(--color-text-muted);margin-bottom:12px;font-size:11px}.inv-card-actions{flex-wrap:wrap;gap:6px;display:flex}.inv-card-actions .btn{flex:1;justify-content:center;min-width:60px}.inv-form{flex-direction:column;display:flex}.inv-form-section{padding:var(--space-md) 0;border-bottom:1px solid var(--color-border)}.inv-form-section:last-child{border-bottom:none}.inv-form-section-title{text-transform:uppercase;letter-spacing:.6px;color:var(--color-text-muted);margin-bottom:var(--space-md);font-size:11px;font-weight:700}.inv-form-row{gap:var(--space-md);grid-template-columns:1fr 1fr;display:grid}@media (width<=600px){.inv-form-row{grid-template-columns:1fr}}.inv-form-tenant-info{color:var(--color-text-muted);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);margin-top:var(--space-sm);flex-wrap:wrap;gap:12px;padding:8px 12px;font-size:12px;display:flex}.inv-form-total{margin-top:var(--space-sm);font-size:var(--font-size-sm);color:var(--color-text-muted);background:var(--color-bg);border-radius:var(--radius-sm);border:1px solid var(--color-border);padding:8px 12px}.inv-form-total strong{color:var(--color-text);font-size:16px}.inv-detail-panel{flex-direction:column;display:flex}.inv-detail-header{padding-bottom:var(--space-md);border-bottom:1px solid var(--color-border);margin-bottom:var(--space-md);justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.inv-detail-period{color:var(--color-text-muted);margin-top:4px;font-size:11px}.inv-detail-section{padding:var(--space-md) 0;border-bottom:1px solid var(--color-border)}.inv-detail-section:last-child{border-bottom:none}.inv-detail-section-title{text-transform:uppercase;letter-spacing:.6px;color:var(--color-text-muted);margin-bottom:10px;font-size:11px;font-weight:700}.inv-detail-row{font-size:var(--font-size-sm);justify-content:space-between;gap:12px;padding:5px 0;display:flex}.inv-detail-label{color:var(--color-text-muted);flex-shrink:0;min-width:130px;font-weight:500}.inv-detail-value{color:var(--color-text);text-align:right}.inv-detail-notes{font-size:var(--font-size-sm);white-space:pre-wrap;background:var(--color-bg);border-radius:var(--radius-sm);border:1px solid var(--color-border);margin:0;padding:8px 12px}.gen-billing-result{text-align:center;padding:var(--space-md) 0}.gen-billing-result-period{margin-bottom:var(--space-lg);color:var(--color-text);font-size:18px;font-weight:700}.gen-billing-result-grid{gap:var(--space-md);grid-template-columns:repeat(3,1fr);display:grid}.gen-billing-result-item{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-md);flex-direction:column;align-items:center;gap:4px;display:flex}.gen-billing-result-item strong{color:var(--color-text);font-size:22px;font-weight:800}.gen-billing-result-item span{color:var(--color-text-muted);text-align:center;font-size:11px}.balances-table-wrap{border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);background:#fff;overflow:auto hidden}.balances-table{border-collapse:collapse;width:100%;font-size:var(--font-size-sm);min-width:700px}.balances-table th{background:var(--color-bg);text-align:left;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-muted);border-bottom:1px solid var(--color-border);white-space:nowrap;padding:10px 12px;font-size:11px;font-weight:700}.balances-table td{border-bottom:1px solid var(--color-border);vertical-align:middle;padding:11px 12px}.balances-table tr:last-child td{border-bottom:none}.balances-table tr:hover td{background:#fafafa}.balances-row-overdue td{background:#fff8f8}.balances-tenant-name{font-weight:600}.balances-tenant-code,.balances-unit{color:var(--color-text-muted);margin-top:2px;font-size:11px}.send-modal-invoice-info{background:var(--color-bg-light,#f8f9fa);border:1px solid var(--color-border);border-radius:8px;align-items:center;gap:8px;margin-bottom:16px;padding:10px 14px;font-size:13px;display:flex}.send-method-options{flex-direction:column;gap:8px;margin-top:4px;display:flex}.send-method-option{border:1.5px solid var(--color-border);cursor:pointer;border-radius:8px;align-items:flex-start;gap:10px;padding:12px 14px;transition:border-color .15s,background .15s;display:flex}.send-method-option:hover{border-color:var(--color-primary,#2563eb);background:#f0f6ff}.send-method-option.selected{border-color:var(--color-primary,#2563eb);background:#eff6ff}.send-method-option input[type=radio]{flex-shrink:0;margin-top:3px}.send-method-label{flex-direction:column;gap:2px;display:flex}.send-method-label strong{color:var(--color-text);font-size:13px;font-weight:600}.send-method-label span{color:var(--color-text-muted);font-size:12px}.send-result-panel{border:1px solid var(--color-border);border-radius:8px;margin-top:4px;overflow:hidden}.send-result-title{text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-muted);background:var(--color-bg-light,#f8f9fa);border-bottom:1px solid var(--color-border);padding:10px 14px;font-size:12px;font-weight:600}.send-result-row{border-bottom:1px solid var(--color-border);align-items:center;gap:10px;padding:10px 14px;font-size:13px;display:flex}.send-result-row:last-child{border-bottom:none}.send-result-icon{flex-shrink:0;width:18px;font-size:14px}.send-result-label{white-space:nowrap;min-width:40px;font-weight:600}.send-result-msg{color:var(--color-text-muted);font-size:12px}.send-result-success{background:#f0fdf4}.send-result-success .send-result-icon{color:#16a34a}.send-result-success .send-result-label{color:#15803d}.send-result-failed{background:#fef2f2}.send-result-failed .send-result-icon{color:#dc2626}.send-result-failed .send-result-label{color:#b91c1c}.send-result-skipped{background:#f8f9fa}.send-result-skipped .send-result-icon{color:#9ca3af}.send-result-skipped .send-result-label{color:#6b7280}.inv-actions-wrap{display:inline-block;position:relative}.inv-actions-dropdown{border:1px solid var(--color-border);border-radius:var(--radius-md,8px);background:#fff;min-width:170px;padding:4px 0;box-shadow:0 4px 16px #0000001f}.inv-actions-dropdown button{text-align:left;cursor:pointer;width:100%;font-size:var(--font-size-sm,13px);font-family:var(--font-sans,"Inter", sans-serif);color:var(--color-text);white-space:nowrap;background:0 0;border:none;padding:8px 14px;display:block}.inv-actions-dropdown button:hover{background:var(--color-bg,#f8fafc)}.inv-actions-divider{background:var(--color-border);height:1px;margin:4px 0}.inv-actions-dropdown .inv-action-danger{color:var(--color-danger,#dc2626)}.inv-actions-dropdown .inv-action-restore{color:var(--color-success,#16a34a)}.inv-number-link{border:1px solid var(--color-border);white-space:nowrap;cursor:pointer;color:var(--color-primary,#2563eb);background:0 0;border-radius:4px;padding:1px 8px;font-family:monospace;font-size:11px;font-weight:700}.inv-number-link:hover{background:var(--color-bg,#f8fafc)}.pay-summary-grid{gap:var(--space-md);margin-bottom:var(--space-lg);grid-template-columns:repeat(5,1fr);display:grid}@media (width<=1024px){.pay-summary-grid{grid-template-columns:repeat(3,1fr)}}@media (width<=640px){.pay-summary-grid{grid-template-columns:repeat(2,1fr)}}.pay-summary-card{border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-md) var(--space-lg);box-shadow:var(--shadow-sm);background:#fff;flex-direction:column;gap:4px;display:flex}.pay-summary-value{color:var(--color-text);word-break:break-all;font-size:24px;font-weight:800;line-height:1.1}.pay-summary-label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:500}.pay-card-confirmed .pay-summary-value{color:var(--color-success)}.pay-card-pending .pay-summary-value{color:var(--color-warning)}.pay-card-failed .pay-summary-value{color:var(--color-danger)}.pay-card-collected .pay-summary-value{color:var(--color-primary);font-size:20px}.pay-badge{letter-spacing:.3px;white-space:nowrap;border-radius:99px;align-items:center;padding:2px 10px;font-size:11px;font-weight:600;display:inline-flex}.pay-badge-pending{color:#854d0e;background:#fef9c3}.pay-badge-confirmed{color:#166534;background:#dcfce7}.pay-badge-failed{color:#991b1b;background:#fee2e2}.pay-badge-cancelled{color:#71717a;background:#f4f4f5}.pay-badge-archived{color:#9ca3af;background:#f4f4f5}.pay-table-responsive{overflow-x:auto}.pay-table-wrap{border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);background:#fff;min-width:800px;overflow:hidden}.pay-table{border-collapse:collapse;width:100%;font-size:var(--font-size-sm)}.pay-table th{background:var(--color-bg);text-align:left;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-muted);border-bottom:1px solid var(--color-border);white-space:nowrap;font-size:11px;font-weight:700;font-family:var(--font-sans,"Inter", sans-serif);padding:10px 12px}.pay-table td{border-bottom:1px solid var(--color-border);vertical-align:middle;color:var(--color-text);font-family:var(--font-sans,"Inter", sans-serif);padding:11px 12px}.pay-table tr:last-child td{border-bottom:none}.pay-table tr:hover td{background:#fafafa}.pay-number-chip{background:var(--color-bg);border:1px solid var(--color-border);white-space:nowrap;border-radius:4px;padding:1px 8px;font-family:monospace;font-size:11px;font-weight:700;display:inline-block}.pay-tenant-name{font-weight:600}.pay-tenant-sub{color:var(--color-text-muted);margin-top:2px;font-size:11px}.pay-amount{white-space:nowrap;font-weight:700}.pay-ref{color:var(--color-text-muted);font-family:monospace;font-size:12px}.pay-inv-chip{color:#1e40af;white-space:nowrap;background:#eff6ff;border:1px solid #bfdbfe;border-radius:4px;padding:1px 7px;font-size:11px;font-weight:600;display:inline-block}.pay-table-actions{flex-wrap:nowrap;align-items:center;gap:4px;display:flex}.pay-form{flex-direction:column;display:flex}.pay-form-section{padding:var(--space-md) 0;border-bottom:1px solid var(--color-border)}.pay-form-section:last-child{border-bottom:none}.pay-form-section-title{text-transform:uppercase;letter-spacing:.6px;color:var(--color-text-muted);margin-bottom:var(--space-md);font-size:11px;font-weight:700}.pay-form-row{gap:var(--space-md);grid-template-columns:1fr 1fr;display:grid}@media (width<=600px){.pay-form-row{grid-template-columns:1fr}}.pay-form-info{color:var(--color-text-muted);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);margin-top:var(--space-sm);flex-wrap:wrap;gap:16px;padding:8px 12px;font-size:12px;display:flex}.pay-form-inv-info{color:#1e40af;background:#eff6ff;border-color:#bfdbfe}.pay-form-inv-info strong{color:#1e3a8a}.pay-detail-panel{flex-direction:column;display:flex}.pay-detail-header{padding-bottom:var(--space-md);border-bottom:1px solid var(--color-border);margin-bottom:var(--space-md);justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.pay-detail-method{color:var(--color-text-muted);font-size:12px}.pay-detail-actions{margin-bottom:var(--space-md);flex-wrap:wrap;gap:8px;display:flex}.pay-detail-section{padding:var(--space-md) 0;border-bottom:1px solid var(--color-border)}.pay-detail-section:last-child{border-bottom:none}.pay-detail-section-title{text-transform:uppercase;letter-spacing:.6px;color:var(--color-text-muted);margin-bottom:10px;font-size:11px;font-weight:700}.pay-detail-row{font-size:var(--font-size-sm);justify-content:space-between;gap:12px;padding:5px 0;display:flex}.pay-detail-label{color:var(--color-text-muted);flex-shrink:0;min-width:130px;font-weight:500}.pay-detail-value{color:var(--color-text);text-align:right}.pay-detail-notes{font-size:var(--font-size-sm);white-space:pre-wrap;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);margin:0;padding:8px 12px}.ptype-manager{flex-direction:column;gap:12px;display:flex}.ptype-manager-header{justify-content:flex-end;display:flex}.ptype-manager-actions{gap:8px;display:flex}.ptype-form{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);flex-direction:column;gap:10px;padding:14px 16px;display:flex}.ptype-form-title{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:2px;font-weight:600}.ptype-form-actions{justify-content:flex-end;gap:8px;display:flex}.ptype-empty{text-align:center;color:var(--color-text-muted);flex-direction:column;align-items:center;gap:8px;padding:24px 0;display:flex}.ptype-empty p{margin:0}.ptype-empty-hint{font-size:var(--font-size-sm);max-width:420px}.ptype-list{flex-direction:column;gap:4px;display:flex}.ptype-row{border:1px solid var(--color-border);border-radius:var(--radius-sm);background:#fff;justify-content:space-between;align-items:center;padding:8px 12px;display:flex}.ptype-row-archived{opacity:.65}.ptype-row-info{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.ptype-row-actions{flex-shrink:0;gap:8px;display:flex}.ptype-name{font-size:var(--font-size-sm);font-weight:500}.ptype-name-muted{color:var(--color-text-muted)}.ptype-desc{color:var(--color-text-muted);font-size:.75rem}.ptype-category-badge{background:var(--color-primary-light,#eff6ff);color:var(--color-primary,#2563eb);border-radius:9999px;align-items:center;padding:2px 8px;font-size:.7rem;font-weight:500;display:inline-flex}.ptype-default-badge{color:#16a34a;background:#f0fdf4;border-radius:9999px;align-items:center;padding:2px 8px;font-size:.7rem;font-weight:500;display:inline-flex}.ptype-archived-section{margin-top:4px}.ptype-toggle-archived{font-size:var(--font-size-sm);color:var(--color-text-muted);cursor:pointer;margin-bottom:6px}.ptype-list-archived{margin-top:6px}.ptype-hint-rent{color:var(--color-warning,#d97706)!important}.actions-menu{border:1px solid var(--color-border);border-radius:var(--radius-md);min-width:160px;box-shadow:var(--shadow-lg);z-index:2000;background:#fff;position:fixed;overflow:hidden}.actions-menu-item{text-align:left;width:100%;font-size:13px;font-family:var(--font-sans);cursor:pointer;color:var(--color-text);background:0 0;border:none;padding:8px 14px;display:block}.actions-menu-item:hover{background:var(--color-bg)}.actions-menu-item--confirm{color:var(--color-success,#10b981)}.actions-menu-item--warn{color:var(--color-warning,#d97706)}.actions-menu-item--danger{color:var(--color-danger,#ef4444)}.actions-menu-item--restore{color:var(--color-success,#10b981)}.actions-menu-divider{background:var(--color-border);height:1px;margin:3px 0}.pay-date-range{flex-shrink:0;align-items:center;gap:6px;display:flex}.pay-date-range .form-control{width:140px}.pay-date-sep{color:var(--color-text-muted);white-space:nowrap;font-size:12px}.btn-actions-trigger{border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;width:30px;height:30px;color:var(--color-text-muted);background:0 0;justify-content:center;align-items:center;font-size:16px;line-height:1;transition:background .15s,border-color .15s;display:inline-flex}.btn-actions-trigger:hover{background:var(--color-bg);border-color:var(--color-text-muted)}.actions-menu-item--send{color:var(--color-primary,#2563eb)}.pay-receipt-send-wrap{flex-direction:column;gap:16px;display:flex}.pay-receipt-send-info{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);flex-direction:column;gap:6px;padding:12px 16px;display:flex}.pay-receipt-send-meta{color:var(--color-text-secondary);flex-wrap:wrap;gap:16px;font-size:13px;display:flex}.pay-receipt-method-options{flex-direction:column;gap:8px;display:flex}.pay-receipt-method-option{border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;align-items:flex-start;gap:12px;padding:12px 14px;transition:border-color .15s,background .15s;display:flex}.pay-receipt-method-option.selected{border-color:var(--color-primary,#2563eb);background:#eff6ff}.pay-receipt-method-option input[type=radio]{flex-shrink:0;margin-top:2px}.pay-receipt-method-label{flex-direction:column;gap:2px;display:flex}.pay-receipt-method-title{color:var(--color-text);font-size:14px;font-weight:600}.pay-receipt-method-desc{color:var(--color-text-muted);font-size:12px}.pay-receipt-result-panel{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);flex-direction:column;gap:8px;padding:14px 16px;display:flex}.pay-receipt-result-title{text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-muted);margin-bottom:4px;font-size:11px;font-weight:700}.pay-receipt-result-row{border-radius:var(--radius-sm);align-items:flex-start;gap:10px;padding:8px 10px;font-size:13px;display:flex}.pay-receipt-result-channel{flex-shrink:0;min-width:44px;font-weight:600}.pay-receipt-result-status{flex-shrink:0;min-width:52px;font-weight:600}.pay-receipt-result-msg{color:var(--color-text-secondary);flex:1}.pay-receipt-result-success{color:#166534;background:#f0fdf4}.pay-receipt-result-success .pay-receipt-result-status{color:#16a34a}.pay-receipt-result-failed{color:#7f1d1d;background:#fef2f2}.pay-receipt-result-failed .pay-receipt-result-status{color:#dc2626}.pay-receipt-result-skipped{color:#52525b;background:#f4f4f5}.pay-receipt-result-skipped .pay-receipt-result-status{color:#71717a}.pay-filters{flex-wrap:wrap}.pay-actions-wrap{display:inline-block;position:relative}.pay-number-link{cursor:pointer;color:var(--color-primary,#2563eb)}.pay-number-link:hover{background:#eff6ff}.pay-receipt-resend-notice{border-radius:var(--radius-sm,6px);color:#78350f;font-size:13px;font-family:var(--font-sans,"Inter", sans-serif);background:#fefce8;border:1px solid #fde68a;padding:9px 14px}.pay-desc-name{color:var(--color-text);font-size:13px;font-weight:600}.pay-desc-sub{color:var(--color-text-muted);margin-top:2px;font-size:11px}.pay-ref-chip{background:var(--color-bg);border:1px solid var(--color-border);white-space:nowrap;border-radius:4px;padding:1px 8px;font-family:monospace;font-size:11px;font-weight:700;display:inline-block}.pay-ref-sub{color:var(--color-text-muted);margin-top:2px;font-family:monospace;font-size:10px}.pay-datetime-cell{white-space:nowrap;color:var(--color-text);font-size:12px}.pay-col-amount{text-align:right!important}.pay-method-badge{white-space:nowrap;letter-spacing:.2px;border-radius:99px;padding:2px 9px;font-size:11px;font-weight:600;display:inline-block}.pay-method-mpesa{color:#92400e;background:#fffbeb;border:1px solid #fde68a}.pay-method-cash{color:#166534;background:#f0fdf4;border:1px solid #bbf7d0}.pay-method-bank{color:#1e40af;background:#eff6ff;border:1px solid #bfdbfe}.pay-method-card{color:#6b21a8;background:#faf5ff;border:1px solid #e9d5ff}.pay-method-cheque{color:#374151;background:#f9fafb;border:1px solid #e5e7eb}.pay-method-other{color:#52525b;background:#f4f4f5;border:1px solid #e4e4e7}.pay-table-wrap{min-width:700px}.pay-detail-amount-block{border-radius:var(--radius-md);margin-bottom:var(--space-md);text-align:center;background:#eff6ff;border:1px solid #bfdbfe;padding:14px 18px}.pay-detail-amount-value{color:#1e40af;font-size:24px;font-weight:800;font-family:var(--font-sans,"Inter", sans-serif)}.pay-detail-amount-label{color:#6b7280;text-transform:uppercase;letter-spacing:.5px;margin-top:2px;font-size:11px}.pay-breakdown-table{border-collapse:collapse;width:100%;margin-bottom:10px;font-size:13px}.pay-breakdown-label{color:var(--color-text);border-bottom:1px solid var(--color-border);padding:5px 0}.pay-breakdown-amount{text-align:right;color:var(--color-text);border-bottom:1px solid var(--color-border);white-space:nowrap;padding:5px 0;font-family:monospace;font-weight:600}.pay-breakdown-table tr:last-child .pay-breakdown-label,.pay-breakdown-table tr:last-child .pay-breakdown-amount{border-bottom:none}.pay-breakdown-totals{border:1px solid var(--color-border);border-radius:var(--radius-sm);overflow:hidden}.pay-breakdown-total-row{border-bottom:1px solid var(--color-border);justify-content:space-between;padding:7px 12px;font-size:13px;display:flex}.pay-breakdown-total-row:last-child{border-bottom:none}.pay-breakdown-paid{color:#166534;background:#f0fdf4;font-weight:700}.pay-breakdown-balance{color:#92400e;background:#fffbeb;font-weight:600}.pay-breakdown-fully-paid{color:#166534;background:#f0fdf4}.pay-breakdown-loading{color:var(--color-text-muted);padding:8px 0;font-size:12px}.pay-breakdown-error{color:var(--color-danger);padding:8px 0;font-size:12px}.stmt-modal-form{flex-direction:column;gap:16px;display:flex}.stmt-modal-hint{color:var(--color-text-muted);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:9px 12px;font-size:12px}.pay-cancelled-block{border-radius:var(--radius-md);margin-bottom:var(--space-md);background:#fafafa;border:1px solid #e4e4e7;padding:14px 16px}.pay-zero-applied{color:#71717a;font-family:monospace;font-weight:600}.pay-detail-amount-block--cancelled{background:#f4f4f5;border-color:#d4d4d8}.pay-detail-amount-block--cancelled .pay-detail-amount-value{color:#71717a}.ss-container{font-family:var(--font-sans,"Inter", sans-serif);position:relative}.ss-disabled{opacity:.55;pointer-events:none}.ss-control{border:1px solid var(--color-border,#e2e8f0);border-radius:var(--radius-sm,6px);cursor:pointer;background:#fff;justify-content:space-between;align-items:center;min-height:36px;padding:7px 10px;font-size:13px;display:flex}.ss-control.ss-open{border-color:var(--color-primary,#2563eb);box-shadow:0 0 0 2px #bfdbfe}.ss-search{background:0 0;border:none;outline:none;flex:1;font-family:inherit;font-size:13px}.ss-display{flex:1}.ss-placeholder{color:var(--color-text-muted,#9ca3af)}.ss-chevron{color:var(--color-text-muted,#9ca3af);flex-shrink:0;margin-left:6px}.ss-menu{border:1px solid var(--color-border,#e2e8f0);border-radius:var(--radius-md,8px);box-shadow:var(--shadow-lg,0 8px 24px #0000001f);z-index:1000;background:#fff;max-height:220px;position:absolute;top:calc(100% + 2px);left:0;right:0;overflow-y:auto}.ss-item{cursor:pointer;flex-direction:column;padding:8px 12px;font-size:13px;display:flex}.ss-item:hover{background:var(--color-bg,#f9fafb)}.ss-item.ss-selected{background:#eff6ff}.ss-item.ss-muted{color:var(--color-text-muted);cursor:default;font-style:italic}.ss-item-label{color:var(--color-text);font-weight:500}.ss-item-sub{color:var(--color-text-muted);margin-top:1px;font-size:11px}.ram-mode-tabs{border:1px solid var(--color-border);border-radius:var(--radius-md);margin-bottom:var(--space-lg);gap:0;display:flex;overflow:hidden}.ram-mode-tab{background:var(--color-bg);cursor:pointer;font-size:13px;font-weight:500;font-family:var(--font-sans,"Inter", sans-serif);color:var(--color-text-muted);border:none;flex:1;padding:9px 12px;transition:background .15s,color .15s}.ram-mode-tab+.ram-mode-tab{border-left:1px solid var(--color-border)}.ram-mode-tab--active{background:var(--color-primary,#2563eb);color:#fff}.ram-form{gap:var(--space-sm);flex-direction:column;display:flex}.ram-section-title{text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-muted);padding-top:var(--space-sm);border-top:1px solid var(--color-border);margin-top:4px;font-size:11px;font-weight:700}.ram-section-title:first-child{border-top:none;margin-top:0;padding-top:0}.ram-row{gap:var(--space-md);grid-template-columns:1fr 1fr;display:grid}@media (width<=560px){.ram-row{grid-template-columns:1fr}}.ram-inv-info{color:var(--color-text-muted);border-radius:var(--radius-sm);background:#eff6ff;border:1px solid #bfdbfe;margin-top:4px;padding:5px 10px;font-size:12px}.ram-actions{padding-top:var(--space-md);border-top:1px solid var(--color-border);margin-top:var(--space-sm);justify-content:flex-end;gap:8px;display:flex}.ram-pay-list{flex-direction:column;gap:6px;margin-bottom:8px;display:flex}.ram-pay-row{border:1px solid var(--color-border);border-radius:var(--radius-md);background:#fff;align-items:center;gap:12px;padding:10px 12px;display:flex}.ram-pay-row:hover{background:var(--color-bg)}.ram-pay-ref{color:var(--color-text);font-family:monospace;font-size:13px;font-weight:700}.ram-pay-meta{color:var(--color-text-muted);margin-top:2px;font-size:11px}.ram-pay-amount{white-space:nowrap;color:var(--color-text);margin-left:auto;font-size:14px;font-weight:700}.ram-loading,.ram-empty{text-align:center;color:var(--color-text-muted);padding:20px 0;font-size:13px}.ram-selected-pay{margin-bottom:var(--space-md)}.ram-pay-summary-card{border-radius:var(--radius-md);background:#eff6ff;border:1px solid #bfdbfe;flex-wrap:wrap;align-items:center;gap:14px;margin-bottom:6px;padding:10px 14px;font-size:13px;display:flex}.ram-pay-date-small{color:var(--color-text-muted);font-size:11px}.ram-change-btn{color:var(--color-primary,#2563eb);cursor:pointer;background:0 0;border:none;padding:0;font-family:inherit;font-size:12px}.ram-change-btn:hover{text-decoration:underline}.btn-link{cursor:pointer;color:var(--color-primary,#2563eb);background:0 0;border:none;padding:0;font-family:inherit;font-size:13px}.btn-link:hover{text-decoration:underline}.req{color:var(--color-danger,#ef4444)}.ram-tenant-card{border-radius:var(--radius-md);background:#f0fdf4;border:1px solid #bbf7d0;flex-direction:column;gap:3px;margin:4px 0 10px;padding:10px 14px;display:flex}.ram-tenant-name{color:var(--color-text,#111827);font-size:14px;font-weight:700}.ram-tenant-meta{color:var(--color-text-muted,#6b7280);font-size:12px}.ram-tenant-meta strong{color:var(--color-text,#111827)}.ram-tenant-meta code{color:#0369a1;background:#e0f2fe;border-radius:4px;padding:0 4px;font-size:11px}.ram-inv-info{color:var(--color-text-muted,#6b7280);margin-top:4px;font-size:12px}.ram-no-inv-note{color:#92400e;background:#fef9c3;border:1px solid #fde68a;border-radius:4px;margin-top:4px;padding:6px 10px;font-size:12px}.ram-mpesa-choice{margin-bottom:8px}.ram-mpesa-choice-grid{grid-template-columns:1fr 1fr;gap:12px;margin:12px 0;display:grid}@media (width<=520px){.ram-mpesa-choice-grid{grid-template-columns:1fr}}.ram-mpesa-choice-btn{background:var(--color-surface,#fff);border:2px solid var(--color-border,#e5e7eb);border-radius:var(--radius-md,8px);text-align:left;cursor:pointer;flex-direction:column;gap:6px;padding:16px 14px;transition:border-color .15s,box-shadow .15s;display:flex}.ram-mpesa-choice-btn:hover{border-color:var(--color-primary,#2563eb);box-shadow:0 0 0 3px #2563eb14}.ram-mpesa-choice-icon{font-size:22px;line-height:1}.ram-mpesa-choice-label{color:var(--color-text,#111827);font-size:14px;font-weight:700}.ram-mpesa-choice-desc{color:var(--color-text-muted,#6b7280);font-size:12px;line-height:1.4}.ram-hard-record-banner{border-radius:var(--radius-sm,6px);color:#92400e;background:#fef3c7;border:1px solid #fde68a;margin-bottom:12px;padding:6px 12px;font-size:13px}.ram-hard-record-banner .btn-link{color:#b45309;cursor:pointer;background:0 0;border:none;padding:0;font-weight:600;text-decoration:underline}.ram-mpesa-found-card{border-radius:var(--radius-md,8px);background:#f0fdf4;border:1px solid #bbf7d0;margin-bottom:16px;padding:12px 16px}.ram-mpesa-found-header{margin-bottom:8px}.ram-mpesa-found-badge{color:#15803d;letter-spacing:.02em;background:#dcfce7;border-radius:20px;padding:2px 10px;font-size:12px;font-weight:700;display:inline-block}.ram-mpesa-found-row{align-items:center;gap:12px;padding:3px 0;display:flex}.ram-mpesa-found-label{width:100px;color:var(--color-text-muted,#6b7280);flex-shrink:0;font-size:12px;font-weight:600}.ram-mpesa-found-value{color:var(--color-text,#111827);font-size:13px}.ram-mpesa-found-value code{font-family:monospace;font-size:13px}.ram-mpesa-found-amount{color:#15803d;font-weight:700}.ram-mpesa-found-status{color:#b45309;background:#fef3c7;border-radius:4px;padding:1px 6px;font-size:11px;font-weight:700}.ram-hint{color:var(--color-text-muted,#6b7280);margin-bottom:12px;font-size:13px;line-height:1.5}.doc-features-grid{gap:var(--space-md);margin-bottom:var(--space-lg);grid-template-columns:repeat(3,1fr);display:grid}@media (width<=900px){.doc-features-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=560px){.doc-features-grid{grid-template-columns:1fr}}.doc-feature-card{border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-md);box-shadow:var(--shadow-sm);background:#fff;align-items:flex-start;gap:14px;display:flex}.doc-feature-card-soon{opacity:.65;background:var(--color-bg)}.doc-feature-icon{flex-shrink:0;margin-top:2px;font-size:28px;line-height:1}.doc-feature-title{margin-bottom:4px;font-weight:700}.doc-feature-desc{color:var(--color-text-muted);font-size:12px;line-height:1.5}.doc-feature-actions{margin-top:10px}.doc-coming-soon{text-transform:uppercase;letter-spacing:.5px;background:var(--color-bg);border:1px solid var(--color-border);color:var(--color-text-muted);border-radius:4px;margin-top:8px;padding:2px 8px;font-size:10px;font-weight:700;display:inline-block}.doc-howto{padding:var(--space-lg);margin-bottom:var(--space-lg)}.doc-howto-title{margin-bottom:var(--space-md);color:var(--color-text);font-size:14px;font-weight:700}.doc-howto-grid{gap:var(--space-lg);grid-template-columns:repeat(3,1fr);display:grid}@media (width<=720px){.doc-howto-grid{grid-template-columns:1fr}}.doc-howto-item{align-items:flex-start;gap:12px;display:flex}.doc-howto-step{background:var(--color-primary);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:13px;font-weight:800;display:flex}.doc-howto-item strong{margin-bottom:4px;display:block}.doc-howto-item p{color:var(--color-text-muted);font-size:12px;line-height:1.5}.doc-quick-section{border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin-bottom:var(--space-lg);background:#fff;overflow:hidden}.doc-quick-title{text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-muted);background:var(--color-bg);border-bottom:1px solid var(--color-border);padding:12px 16px;font-size:11px;font-weight:700}.doc-quick-row{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;gap:12px;padding:11px 16px;display:flex}.doc-quick-row:last-child{border-bottom:none}.doc-quick-row:hover{background:var(--color-bg)}.doc-quick-info{flex-direction:column;gap:2px;min-width:0;display:flex}.doc-quick-num{white-space:nowrap;text-overflow:ellipsis;font-family:monospace;font-size:13px;font-weight:700;overflow:hidden}.doc-quick-sub{color:var(--color-text-muted);font-size:11px}.doc-actions{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.doc-actions-label{text-transform:uppercase;letter-spacing:.4px;color:var(--color-text-muted);margin-right:4px;font-size:11px;font-weight:600}.doc-actions-error{color:var(--color-danger);width:100%;font-size:11px;display:block}.doc-download-btn{color:var(--color-primary)}.doc-preview-frame-wrap{border-radius:var(--radius-sm);border:1px solid var(--color-border);background:#f8fafc;width:100%;height:70vh;min-height:400px;overflow:hidden}.doc-preview-frame{background:#fff;border:none;width:100%;height:100%}.doc-preview-loading{height:100%;color:var(--color-text-muted);font-size:var(--font-size-sm);justify-content:center;align-items:center;gap:12px;display:flex}.btn-xs{height:auto;padding:3px 9px;font-size:11px;line-height:1.4}.spinner-xs{vertical-align:middle;border:2px solid;border-top-color:#0000;border-radius:50%;width:10px;height:10px;margin-right:4px;animation:.7s linear infinite spin;display:inline-block}.doc-preview-footer{justify-content:flex-end;gap:8px;width:100%;display:flex}.form-grid-2col{gap:var(--space-md);grid-template-columns:1fr 1fr;display:grid}@media (width<=560px){.form-grid-2col{grid-template-columns:1fr}}.doc-template-grid{gap:var(--space-md);grid-template-columns:repeat(3,1fr);display:grid}@media (width<=900px){.doc-template-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=580px){.doc-template-grid{grid-template-columns:1fr}}.doc-template-card{border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-md);box-shadow:var(--shadow-sm);background:#fff}.doc-template-key{color:var(--color-text);margin-bottom:4px;font-size:13px;font-weight:700}.doc-template-name{color:var(--color-text-muted);margin-bottom:4px;font-size:11px}.doc-template-subject{color:var(--color-text-muted);white-space:nowrap;text-overflow:ellipsis;margin-bottom:10px;font-size:11px;overflow:hidden}.doc-template-footer{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.doc-lease-option{padding:var(--space-md);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md)}.doc-lease-option-label{margin-bottom:4px;font-size:14px;font-weight:700}.doc-lease-option-desc{color:var(--color-text-muted);font-size:13px}.panel-doc-section{padding:var(--space-md) 0;border-top:1px solid var(--color-border);margin-top:var(--space-sm)}.panel-doc-section-title{text-transform:uppercase;letter-spacing:.6px;color:var(--color-text-muted);margin-bottom:10px;font-size:11px;font-weight:700}.exp-summary-grid{gap:var(--space-md);margin-bottom:var(--space-lg);grid-template-columns:repeat(6,1fr);display:grid}@media (width<=1100px){.exp-summary-grid{grid-template-columns:repeat(3,1fr)}}@media (width<=640px){.exp-summary-grid{grid-template-columns:repeat(2,1fr)}}.exp-summary-card{border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-md) var(--space-md);box-shadow:var(--shadow-sm);background:#fff;flex-direction:column;gap:4px;display:flex}.exp-summary-value{color:var(--color-text);font-size:20px;font-weight:800;line-height:1.1}.exp-summary-label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:10px;font-weight:500}.exp-card-paid .exp-summary-value{color:var(--color-success)}.exp-card-pending .exp-summary-value{color:var(--color-warning)}.exp-card-total-paid .exp-summary-value{color:var(--color-primary);font-size:16px}.exp-card-total-pending .exp-summary-value{color:var(--color-warning);font-size:16px}.exp-badge{white-space:nowrap;border-radius:99px;align-items:center;padding:2px 10px;font-size:11px;font-weight:600;display:inline-flex}.exp-badge-pending{color:#854d0e;background:#fef9c3}.exp-badge-paid{color:#166534;background:#dcfce7}.exp-badge-cancelled{color:#71717a;background:#f4f4f5}.exp-badge-archived{color:#9ca3af;background:#f4f4f5}.exp-category-chip{color:#1e40af;background:#eff6ff;border:1px solid #bfdbfe;border-radius:4px;padding:1px 8px;font-size:11px;font-weight:600;display:inline-block}.exp-table-responsive{overflow-x:auto}.exp-table-wrap{border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);background:#fff;min-width:750px;overflow:hidden}.exp-table{border-collapse:collapse;width:100%;font-size:var(--font-size-sm)}.exp-table th{background:var(--color-bg);text-align:left;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-muted);border-bottom:1px solid var(--color-border);white-space:nowrap;font-size:11px;font-weight:700;font-family:var(--font-sans,"Inter", sans-serif);padding:10px 12px}.exp-table td{border-bottom:1px solid var(--color-border);vertical-align:middle;font-family:var(--font-sans,"Inter", sans-serif);padding:10px 12px}.exp-table tr:last-child td{border-bottom:none}.exp-table tr:hover td{background:#fafafa}.exp-number-chip{background:var(--color-bg);border:1px solid var(--color-border);white-space:nowrap;border-radius:4px;padding:1px 8px;font-family:monospace;font-size:11px;font-weight:700;display:inline-block}.exp-title{font-weight:600}.exp-ref{color:var(--color-text-muted);margin-top:2px;font-family:monospace;font-size:11px}.exp-unit{color:var(--color-text-muted);margin-top:2px;font-size:11px}.exp-amount{white-space:nowrap;font-weight:700}.exp-vendor{color:var(--color-text-muted);font-size:12px}.exp-table-actions{flex-wrap:nowrap;align-items:center;gap:4px;display:flex}.exp-actions-wrap{display:inline-block;position:relative}.exp-number-link{cursor:pointer;color:var(--color-primary,#2563eb);background:var(--color-bg);border:1px solid var(--color-border);white-space:nowrap;border-radius:4px;padding:1px 8px;font-family:monospace;font-size:11px;font-weight:700}.exp-number-link:hover{background:#eff6ff}.exp-export-bar{margin-bottom:var(--space-md);font-family:var(--font-sans,"Inter", sans-serif);align-items:center;gap:8px;display:flex}.exp-export-label{color:var(--color-text-muted);white-space:nowrap;font-size:12px;font-weight:600}.exp-form{flex-direction:column;display:flex}.exp-form-section{padding:var(--space-md) 0;border-bottom:1px solid var(--color-border)}.exp-form-section:last-child{border-bottom:none}.exp-form-section-title{text-transform:uppercase;letter-spacing:.6px;color:var(--color-text-muted);margin-bottom:var(--space-md);font-size:11px;font-weight:700}.exp-form-row{gap:var(--space-md);grid-template-columns:1fr 1fr;display:grid}@media (width<=600px){.exp-form-row{grid-template-columns:1fr}}.exp-detail-panel{flex-direction:column;display:flex}.exp-detail-header{padding-bottom:var(--space-md);border-bottom:1px solid var(--color-border);margin-bottom:var(--space-md);justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.exp-detail-actions{margin-bottom:var(--space-md);flex-wrap:wrap;gap:8px;display:flex}.exp-detail-section{padding:var(--space-md) 0;border-bottom:1px solid var(--color-border)}.exp-detail-section:last-child{border-bottom:none}.exp-detail-section-title{text-transform:uppercase;letter-spacing:.6px;color:var(--color-text-muted);margin-bottom:10px;font-size:11px;font-weight:700}.exp-detail-row{font-size:var(--font-size-sm);justify-content:space-between;gap:12px;padding:5px 0;display:flex}.exp-detail-label{color:var(--color-text-muted);flex-shrink:0;min-width:130px;font-weight:500}.exp-detail-value{color:var(--color-text);text-align:right}.exp-detail-notes{font-size:var(--font-size-sm);white-space:pre-wrap;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);margin:0;padding:8px 12px}.mnt-summary-grid{gap:var(--space-md);margin-bottom:var(--space-lg);grid-template-columns:repeat(7,1fr);display:grid}@media (width<=1200px){.mnt-summary-grid{grid-template-columns:repeat(4,1fr)}}@media (width<=800px){.mnt-summary-grid{grid-template-columns:repeat(2,1fr)}}.mnt-summary-card{border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-md);box-shadow:var(--shadow-sm);background:#fff;flex-direction:column;gap:4px;display:flex}.mnt-summary-value{color:var(--color-text);font-size:20px;font-weight:800;line-height:1.1}.mnt-summary-label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:10px;font-weight:500}.mnt-card-open .mnt-summary-value{color:var(--color-primary)}.mnt-card-inprogress .mnt-summary-value{color:var(--color-warning)}.mnt-card-resolved .mnt-summary-value{color:var(--color-success)}.mnt-card-urgent .mnt-summary-value{color:#ef4444}.mnt-card-cost .mnt-summary-value{color:var(--color-primary);font-size:15px}.mnt-badge{white-space:nowrap;border-radius:99px;align-items:center;padding:2px 10px;font-size:11px;font-weight:600;display:inline-flex}.mnt-badge-open{color:#1d4ed8;background:#eff6ff}.mnt-badge-inprogress{color:#854d0e;background:#fef9c3}.mnt-badge-resolved{color:#166534;background:#dcfce7}.mnt-badge-cancelled{color:#71717a;background:#f4f4f5}.mnt-badge-archived{color:#9ca3af;background:#f4f4f5}.mnt-priority{white-space:nowrap;text-transform:uppercase;border-radius:4px;align-items:center;padding:2px 8px;font-size:11px;font-weight:700;display:inline-flex}.mnt-pri-low{color:#15803d;background:#f0fdf4}.mnt-pri-medium{color:#1d4ed8;background:#eff6ff}.mnt-pri-high{color:#c2410c;background:#fff7ed}.mnt-pri-urgent{color:#b91c1c;background:#fef2f2;border:1px solid #fca5a5}.mnt-table-responsive{overflow-x:auto}.mnt-table-wrap{border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);background:#fff;min-width:900px;overflow:hidden}.mnt-table{border-collapse:collapse;width:100%;font-size:var(--font-size-sm)}.mnt-table th{background:var(--color-bg);text-align:left;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-muted);border-bottom:1px solid var(--color-border);white-space:nowrap;font-size:11px;font-weight:700;font-family:var(--font-sans,"Inter", sans-serif);padding:10px 12px}.mnt-table td{border-bottom:1px solid var(--color-border);vertical-align:middle;font-family:var(--font-sans,"Inter", sans-serif);padding:10px 12px}.mnt-table tr:last-child td{border-bottom:none}.mnt-table tr:hover td{background:#fafafa}.mnt-row-urgent td{border-left:3px solid #ef4444}.mnt-row-urgent:hover td{background:#fff5f5}.mnt-number-chip{background:var(--color-bg);border:1px solid var(--color-border);white-space:nowrap;border-radius:4px;padding:1px 8px;font-family:monospace;font-size:11px;font-weight:700;display:inline-block}.mnt-category-chip{color:#1e40af;background:#eff6ff;border:1px solid #bfdbfe;border-radius:4px;padding:1px 8px;font-size:11px;font-weight:600;display:inline-block}.mnt-title{font-weight:600}.mnt-assigned,.mnt-unit{color:var(--color-text-muted);margin-top:2px;font-size:11px}.mnt-table-actions{flex-wrap:nowrap;align-items:center;gap:4px;display:flex}.mnt-page-tabs{margin-bottom:var(--space-lg);border-bottom:2px solid var(--color-border);gap:4px;padding-bottom:0;display:flex}.mnt-page-tab{cursor:pointer;color:var(--color-text-muted);border-radius:var(--radius-sm) var(--radius-sm) 0 0;font-size:13px;font-weight:500;font-family:var(--font-sans,"Inter", sans-serif);background:0 0;border:none;border-bottom:2px solid #0000;align-items:center;gap:6px;margin-bottom:-2px;padding:8px 16px;transition:color .15s,border-color .15s;display:flex}.mnt-page-tab:hover{color:var(--color-text)}.mnt-page-tab-active{color:var(--color-primary);border-bottom-color:var(--color-primary);font-weight:700}.mnt-tab-count{background:var(--color-primary);color:#fff;border-radius:99px;justify-content:center;align-items:center;min-width:18px;height:18px;padding:0 5px;font-size:10px;font-weight:700;display:inline-flex}.mnt-archive-tabs{margin-bottom:var(--space-md);gap:4px;display:flex}.mnt-archive-tab{border:1px solid var(--color-border);cursor:pointer;color:var(--color-text-muted);border-radius:var(--radius-sm);font-size:12px;font-weight:500;font-family:var(--font-sans,"Inter", sans-serif);background:0 0;padding:5px 16px;transition:background .15s,color .15s,border-color .15s}.mnt-archive-tab:hover{background:var(--color-bg);color:var(--color-text)}.mnt-archive-tab-active{background:var(--color-primary);color:#fff;border-color:var(--color-primary);font-weight:600}.mnt-row-archived td{color:var(--color-text-muted);background:#fafafa!important}.mnt-req-hint{color:var(--color-primary);margin:6px 0 0;font-size:12px;font-style:italic}.pay-link-confirm{color:#059669}.tenant-link-warn{color:#d97706}.tenant-link-danger{color:#dc2626}.tenant-link-restore{color:#6366f1}.mnt-form{flex-direction:column;display:flex}.mnt-form-section{padding:var(--space-md) 0;border-bottom:1px solid var(--color-border)}.mnt-form-section:last-child{border-bottom:none}.mnt-form-section-title{text-transform:uppercase;letter-spacing:.6px;color:var(--color-text-muted);margin-bottom:var(--space-md);font-size:11px;font-weight:700}.mnt-form-row{gap:var(--space-md);grid-template-columns:1fr 1fr;display:grid}@media (width<=600px){.mnt-form-row{grid-template-columns:1fr}}.mnt-detail-panel{flex-direction:column;display:flex}.mnt-detail-header{padding-bottom:var(--space-md);border-bottom:1px solid var(--color-border);margin-bottom:var(--space-md);justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.mnt-detail-title{margin-top:6px;font-size:17px;font-weight:700}.mnt-detail-actions{margin-bottom:var(--space-md);flex-wrap:wrap;gap:8px;display:flex}.mnt-detail-section{padding:var(--space-md) 0;border-bottom:1px solid var(--color-border)}.mnt-detail-section:last-child{border-bottom:none}.mnt-detail-section-title{text-transform:uppercase;letter-spacing:.6px;color:var(--color-text-muted);margin-bottom:10px;font-size:11px;font-weight:700}.mnt-detail-row{font-size:var(--font-size-sm);justify-content:space-between;gap:12px;padding:5px 0;display:flex}.mnt-detail-label{color:var(--color-text-muted);flex-shrink:0;min-width:130px;font-weight:500}.mnt-detail-value{color:var(--color-text);text-align:right}.mnt-detail-notes{font-size:var(--font-size-sm);white-space:pre-wrap;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);margin:0;padding:8px 12px}.stf-summary-grid{gap:var(--space-md);margin-bottom:var(--space-lg);grid-template-columns:repeat(5,1fr);display:grid}@media (width<=900px){.stf-summary-grid{grid-template-columns:repeat(3,1fr)}}@media (width<=600px){.stf-summary-grid{grid-template-columns:repeat(2,1fr)}}.stf-summary-card{border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-md);box-shadow:var(--shadow-sm);background:#fff;flex-direction:column;gap:4px;display:flex}.stf-summary-value{color:var(--color-text);font-size:22px;font-weight:800;line-height:1.1}.stf-summary-label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:10px;font-weight:500}.stf-card-active .stf-summary-value{color:var(--color-success)}.stf-card-inactive .stf-summary-value{color:var(--color-warning)}.stf-card-invited .stf-summary-value{color:var(--color-primary)}.stf-card-archived .stf-summary-value{color:var(--color-text-muted)}.stf-badge{white-space:nowrap;border-radius:99px;align-items:center;padding:2px 10px;font-size:11px;font-weight:600;display:inline-flex}.stf-badge-active{color:#166534;background:#dcfce7}.stf-badge-inactive{color:#854d0e;background:#fef9c3}.stf-badge-invited{color:#1d4ed8;background:#eff6ff}.stf-badge-archived{color:#9ca3af;background:#f4f4f5}.stf-role{white-space:nowrap;border-radius:4px;align-items:center;padding:2px 9px;font-size:11px;font-weight:600;display:inline-flex}.stf-role-owner{color:#7e22ce;background:#fdf4ff;border:1px solid #e9d5ff}.stf-role-manager{color:#1d4ed8;background:#eff6ff;border:1px solid #bfdbfe}.stf-role-accountant{color:#15803d;background:#f0fdf4;border:1px solid #bbf7d0}.stf-role-caretaker{color:#c2410c;background:#fff7ed;border:1px solid #fed7aa}.stf-role-viewer{color:#52525b;background:#f4f4f5;border:1px solid #e4e4e7}.stf-table-responsive{overflow-x:auto}.stf-table-wrap{border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);background:#fff;min-width:860px;overflow:hidden}.stf-table{border-collapse:collapse;width:100%;font-size:var(--font-size-sm)}.stf-table th{background:var(--color-bg);text-align:left;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-muted);border-bottom:1px solid var(--color-border);white-space:nowrap;padding:10px 12px;font-size:11px;font-weight:700}.stf-table td{border-bottom:1px solid var(--color-border);vertical-align:middle;padding:10px 12px}.stf-table tr:last-child td{border-bottom:none}.stf-table tr:hover td{background:#fafafa}.stf-code-chip{background:var(--color-bg);border:1px solid var(--color-border);white-space:nowrap;border-radius:4px;padding:1px 8px;font-family:monospace;font-size:11px;font-weight:700;display:inline-block}.stf-avatar-row{align-items:center;gap:8px;display:flex}.stf-avatar{background:var(--color-primary);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-size:12px;font-weight:700;display:flex}.stf-name{font-weight:600}.stf-muted{color:var(--color-text-muted);font-size:12px}.stf-actions{flex-wrap:nowrap;align-items:center;gap:4px;display:flex}.stf-link-confirm{color:#059669}.stf-link-warn{color:#d97706}.stf-link-danger{color:#dc2626}.stf-link-restore{color:#6366f1}.stf-form{flex-direction:column;display:flex}.stf-form-section{padding:var(--space-md) 0;border-bottom:1px solid var(--color-border)}.stf-form-section:last-child{border-bottom:none}.stf-form-section-title{text-transform:uppercase;letter-spacing:.6px;color:var(--color-text-muted);margin-bottom:var(--space-md);font-size:11px;font-weight:700}.stf-form-row{gap:var(--space-md);grid-template-columns:1fr 1fr;display:grid}@media (width<=600px){.stf-form-row{grid-template-columns:1fr}}.stf-detail-panel{flex-direction:column;display:flex}.stf-detail-header{padding-bottom:var(--space-md);border-bottom:1px solid var(--color-border);margin-bottom:var(--space-md);justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.stf-detail-name{margin-top:6px;font-size:18px;font-weight:700}.stf-detail-actions{margin-bottom:var(--space-md);flex-wrap:wrap;gap:8px;display:flex}.stf-detail-section{padding:var(--space-md) 0;border-bottom:1px solid var(--color-border)}.stf-detail-section:last-child{border-bottom:none}.stf-detail-section-title{text-transform:uppercase;letter-spacing:.6px;color:var(--color-text-muted);margin-bottom:10px;font-size:11px;font-weight:700}.stf-detail-row{font-size:var(--font-size-sm);justify-content:space-between;gap:12px;padding:5px 0;display:flex}.stf-detail-label{color:var(--color-text-muted);flex-shrink:0;min-width:130px;font-weight:500}.stf-detail-value{color:var(--color-text);text-align:right}.stf-detail-notes{font-size:var(--font-size-sm);white-space:pre-wrap;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);margin:0;padding:8px 12px}.rpt-tabs{margin-bottom:var(--space-lg);border-bottom:2px solid var(--color-border);flex-wrap:wrap;gap:4px;padding-bottom:0;display:flex}.rpt-tab{cursor:pointer;color:var(--color-text-muted);border-radius:var(--radius-sm) var(--radius-sm) 0 0;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-2px;padding:8px 16px;font-size:13px;font-weight:500;transition:color .15s,border-color .15s}.rpt-tab:hover{color:var(--color-text)}.rpt-tab-active{color:var(--color-primary);border-bottom-color:var(--color-primary);font-weight:700}.rpt-filters{align-items:flex-end;gap:var(--space-sm);margin-bottom:var(--space-lg);padding:var(--space-md);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);background:#fff;flex-wrap:wrap;display:flex}.rpt-filter-date{flex-direction:column;gap:4px;display:flex}.rpt-filter-label{text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-muted);font-size:10px;font-weight:700}.rpt-clear-btn{align-self:flex-end}.rpt-export-group{flex-wrap:wrap;gap:6px;display:flex}.rpt-card-grid{gap:var(--space-md);margin-bottom:var(--space-lg);grid-template-columns:repeat(auto-fill,minmax(160px,1fr));display:grid}.rpt-card{border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-md);box-shadow:var(--shadow-sm);background:#fff}.rpt-card-value{color:var(--color-text);font-size:20px;font-weight:800;line-height:1.2}.rpt-card-label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px;margin-top:4px;font-size:10px;font-weight:500}.rpt-card-occupied .rpt-card-value{color:var(--color-primary)}.rpt-card-vacant .rpt-card-value{color:var(--color-warning)}.rpt-card-tenants .rpt-card-value{color:#7c3aed}.rpt-card-collected .rpt-card-value{color:var(--color-success)}.rpt-card-pending .rpt-card-value{color:var(--color-warning)}.rpt-card-expense .rpt-card-value{color:#dc2626}.rpt-card-warn .rpt-card-value{color:#d97706}.rpt-card-danger .rpt-card-value{color:#dc2626}.rpt-card-positive .rpt-card-value{color:var(--color-success)}.rpt-card-negative .rpt-card-value{color:#dc2626}.rpt-breakdown-row-pair{gap:var(--space-lg);margin-bottom:var(--space-lg);grid-template-columns:1fr 1fr;display:grid}@media (width<=700px){.rpt-breakdown-row-pair{grid-template-columns:1fr}}.rpt-breakdown{border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-md);box-shadow:var(--shadow-sm);margin-bottom:var(--space-lg);background:#fff}.rpt-breakdown-title{text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-muted);margin-bottom:10px;font-size:11px;font-weight:700}.rpt-breakdown-row{border-bottom:1px solid var(--color-border);font-size:var(--font-size-sm);justify-content:space-between;align-items:center;padding:6px 0;display:flex}.rpt-breakdown-row:last-child{border-bottom:none}.rpt-breakdown-key{color:var(--color-text-muted)}.rpt-breakdown-val{color:var(--color-text);font-weight:600}.rpt-table-section{margin-top:var(--space-lg)}.rpt-table-header{margin-bottom:var(--space-sm);justify-content:space-between;align-items:center;display:flex}.rpt-table-title{color:var(--color-text);font-size:14px;font-weight:700}.rpt-table-count{color:var(--color-text-muted);font-size:12px}.rpt-table-responsive{overflow-x:auto}.rpt-table-wrap{border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);background:#fff;min-width:600px;overflow:hidden}.rpt-table{border-collapse:collapse;width:100%;font-size:var(--font-size-sm)}.rpt-table th{background:var(--color-bg);text-align:left;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-muted);border-bottom:1px solid var(--color-border);white-space:nowrap;font-size:11px;font-weight:700;font-family:var(--font-sans,"Inter", sans-serif);padding:10px 12px}.rpt-table td{border-bottom:1px solid var(--color-border);vertical-align:middle;font-family:var(--font-sans,"Inter", sans-serif);padding:10px 12px}.rpt-table tr:last-child td{border-bottom:none}.rpt-table tr:hover td{background:#fafafa}.rpt-mono{background:var(--color-bg);border:1px solid var(--color-border);white-space:nowrap;border-radius:4px;padding:1px 7px;font-family:monospace;font-size:11px;font-weight:700}.rpt-danger{color:#dc2626;font-weight:600}.rpt-status{white-space:nowrap;text-transform:capitalize;color:#52525b;background:#f4f4f5;border-radius:99px;align-items:center;padding:2px 8px;font-size:11px;font-weight:600;display:inline-flex}.rpt-status-paid{color:#166534;background:#dcfce7}.rpt-status-partial{color:#854d0e;background:#fef9c3}.rpt-status-overdue{color:#991b1b;background:#fee2e2}.rpt-status-issued{color:#1d4ed8;background:#eff6ff}.rpt-status-active{color:#166534;background:#dcfce7}.rpt-status-pending{color:#854d0e;background:#fef9c3}.rpt-status-open{color:#1d4ed8;background:#eff6ff}.rpt-status-in_progress{color:#854d0e;background:#fef9c3}.rpt-status-resolved{color:#166534;background:#dcfce7}.rpt-status-moved_out{color:#71717a;background:#f4f4f5}.rpt-status-cancelled{color:#9ca3af;background:#f4f4f5}.rpt-priority{text-transform:uppercase;font-size:11px;font-weight:700}.rpt-pri-urgent{color:#b91c1c}.rpt-pri-high{color:#c2410c}.rpt-pri-medium{color:#1d4ed8}.rpt-pri-low{color:#15803d}.rpt-period-desc{color:var(--color-text-muted);margin-top:2px;font-size:13px}.rpt-period-label{color:var(--color-primary);font-weight:600}.rpt-card-progress{flex-direction:column;display:flex}.rpt-progress-bar{background:#e5e7eb;border-radius:99px;height:6px;margin:6px 0 4px;overflow:hidden}.rpt-progress-fill{border-radius:99px;height:100%;transition:width .4s}.rpt-charts-section{margin-bottom:var(--space-lg)}.rpt-chart-grid{gap:var(--space-md);grid-template-columns:repeat(auto-fill,minmax(320px,1fr));display:grid}.rpt-chart-panel{border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-md);box-shadow:var(--shadow-sm);background:#fff}.rpt-chart-panel-title{text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-muted);margin-bottom:var(--space-sm);font-size:11px;font-weight:700}.rpt-chart-empty{color:var(--color-text-muted);text-align:center;padding:40px 0;font-size:12px}.rpt-chart-body{padding-top:4px}@media print{.sidebar,.topbar,.page-header .rpt-export-group,.rpt-tabs,.rpt-filters,.btn{display:none!important}.main-content{margin-left:0!important;padding:0!important}.page-body{padding:0!important}.rpt-card-grid{grid-template-columns:repeat(4,1fr)}.rpt-table-wrap{min-width:unset}}.sub-top-grid{gap:var(--space-lg);margin-bottom:var(--space-lg);grid-template-columns:1fr 1fr;display:grid}@media (width<=800px){.sub-top-grid{grid-template-columns:1fr}}.sub-card{border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin-bottom:var(--space-lg);background:#fff;overflow:hidden}.sub-card-header{padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;display:flex}.sub-card-title{text-transform:uppercase;letter-spacing:.4px;color:var(--color-text-muted);font-size:13px;font-weight:700}.sub-card-body{padding:var(--space-lg)}.sub-badge{white-space:nowrap;border-radius:99px;align-items:center;padding:3px 10px;font-size:11px;font-weight:700;display:inline-flex}.sub-badge-active{color:#166534;background:#dcfce7}.sub-badge-trial{color:#1d4ed8;background:#eff6ff}.sub-badge-pastdue{color:#854d0e;background:#fef9c3}.sub-badge-suspended{color:#991b1b;background:#fee2e2}.sub-badge-cancelled{color:#9ca3af;background:#f4f4f5}.sub-plan-name{color:var(--color-primary);margin-bottom:2px;font-size:28px;font-weight:900}.sub-plan-type{color:var(--color-text-muted);margin-bottom:var(--space-md);font-size:12px}.sub-detail-list{margin-bottom:var(--space-md);flex-direction:column;gap:2px;display:flex}.sub-detail-row{border-bottom:1px solid var(--color-border);justify-content:space-between;padding:7px 0;font-size:13px;display:flex}.sub-detail-row:last-child{border-bottom:none}.sub-detail-label{color:var(--color-text-muted);font-weight:500}.sub-detail-value{text-align:right;font-weight:600}.sub-billing-badge{border-radius:4px;padding:1px 8px;font-size:11px;font-weight:600;display:inline-flex}.sub-billing-paid{color:#166534;background:#dcfce7}.sub-billing-unpaid{color:#991b1b;background:#fee2e2}.sub-billing-pending{color:#854d0e;background:#fef9c3}.sub-billing-failed{color:#7f1d1d;background:#fee2e2}.sub-custom-tag{color:#7e22ce;background:#fdf4ff;border:1px solid #e9d5ff;border-radius:4px;padding:1px 8px;font-size:11px;font-weight:700;display:inline-flex}.sub-recalc-btn{margin-top:4px}.sub-units-big{color:var(--color-primary);font-size:48px;font-weight:900;line-height:1}.sub-units-label{color:var(--color-text-muted);margin-bottom:var(--space-md);font-size:12px}.sub-bracket-info{margin-bottom:var(--space-md)}.sub-bracket-current{color:var(--color-text);font-size:16px;font-weight:700}.sub-bracket-next{color:var(--color-text-muted);margin-top:4px;font-size:12px}.sub-bracket-remaining{color:var(--color-warning);font-weight:600}.sub-usage-track{margin-top:var(--space-sm)}.sub-usage-bar-wrap{background:var(--color-border);border-radius:99px;height:10px;margin-bottom:6px;overflow:hidden}.sub-usage-bar-fill{border-radius:99px;height:100%;transition:width .4s}.sub-usage-bar-ok{background:var(--color-primary)}.sub-usage-bar-warn{background:var(--color-warning)}.sub-usage-bar-custom{background:#7e22ce}.sub-usage-pct{color:var(--color-text-muted);font-size:12px}.sub-warn-chip{color:#854d0e;background:#fef9c3;border-radius:4px;padding:2px 8px;font-size:10px;font-weight:700}.sub-custom-chip{color:#7e22ce;background:#fdf4ff;border-radius:4px;padding:2px 8px;font-size:10px;font-weight:700}.sub-custom-note{color:var(--color-text-muted);margin-top:var(--space-md);padding:var(--space-sm);border-radius:var(--radius-sm);background:#fdf4ff;border:1px solid #e9d5ff;font-size:13px}.sub-bracket-table-wrap{overflow-x:auto}.sub-bracket-table{border-collapse:collapse;width:100%;font-size:14px}.sub-bracket-table th{padding:10px var(--space-lg);text-align:left;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-muted);border-bottom:1px solid var(--color-border);background:var(--color-bg);font-size:11px;font-weight:700}.sub-bracket-table td{padding:12px var(--space-lg);border-bottom:1px solid var(--color-border)}.sub-bracket-table tr:last-child td{border-bottom:none}.sub-bracket-active-row td{color:var(--color-primary);background:#eff6ff;font-weight:700}.sub-bracket-fee{font-weight:700}.sub-current-chip{background:var(--color-primary);color:#fff;border-radius:99px;margin-left:10px;padding:1px 7px;font-size:10px;font-weight:700;display:inline-block}.sub-per-month-badge{background:var(--color-bg);border:1px solid var(--color-border);color:var(--color-text-muted);border-radius:4px;padding:2px 8px;font-size:11px;font-weight:600}.sub-pricing-note{padding:var(--space-sm) var(--space-lg);color:var(--color-text-muted);border-top:1px solid var(--color-border);font-size:12px}.sub-support-banner{align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);border-radius:var(--radius-lg);margin-bottom:var(--space-lg);background:#eff6ff;border:1px solid #bfdbfe;display:flex}.sub-support-icon{flex-shrink:0;font-size:28px}.sub-support-text{flex:1}.sub-support-title{margin-bottom:4px;font-weight:700}.sub-support-sub{color:var(--color-text-muted);font-size:13px}.sub-support-btn{white-space:nowrap;flex-shrink:0}.sub-history-empty{color:var(--color-text-muted);padding:var(--space-md) 0;font-size:13px}.sub-history-count{color:var(--color-text-muted);font-size:12px}.sub-history-table-wrap{overflow-x:auto}.sub-history-table{border-collapse:collapse;width:100%;font-size:13px}.sub-history-table th{padding:10px var(--space-lg);text-align:left;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-muted);border-bottom:1px solid var(--color-border);background:var(--color-bg);font-size:11px;font-weight:700}.sub-history-table td{padding:10px var(--space-lg);border-bottom:1px solid var(--color-border)}.sub-history-table tr:last-child td{border-bottom:none}.sub-history-ref{color:var(--color-text-muted);font-family:monospace;font-size:11px}.sub-history-status{text-transform:capitalize;border-radius:4px;padding:1px 8px;font-size:11px;font-weight:600;display:inline-flex}.sub-hist-paid{color:#166534;background:#dcfce7}.sub-hist-pending{color:#854d0e;background:#fef9c3}.sub-hist-failed{color:#991b1b;background:#fee2e2}.stg-page-form{max-width:780px}.stg-section{border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin-bottom:var(--space-lg);background:#fff;overflow:hidden}.stg-section-head{padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--color-border);background:var(--color-bg)}.stg-section-title{text-transform:uppercase;letter-spacing:.4px;color:var(--color-text);font-size:13px;font-weight:700}.stg-section-desc{color:var(--color-text-muted);margin-top:3px;font-size:12px}.stg-section-body{padding:var(--space-lg)}.stg-form{gap:var(--space-md);flex-direction:column;display:flex}.stg-form-row{gap:var(--space-md);grid-template-columns:1fr 1fr;display:grid}@media (width<=600px){.stg-form-row{grid-template-columns:1fr}}.form-hint{color:var(--color-text-muted);margin-top:4px;font-size:11px;display:block}.stg-color-row{align-items:center;gap:10px;display:flex}.stg-color-picker{border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;background:0 0;width:44px;height:38px;padding:2px}.stg-color-input{flex:1;font-family:monospace}.stg-logo-row{align-items:center;gap:var(--space-md);flex-wrap:wrap;margin-bottom:6px;display:flex}.stg-logo-preview-wrap{align-items:center;gap:10px;display:flex}.stg-logo-preview{object-fit:contain;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg);max-width:160px;height:56px;padding:4px}.stg-logo-placeholder{border:2px dashed var(--color-border);border-radius:var(--radius-sm);width:80px;height:56px;color:var(--color-text-muted);justify-content:center;align-items:center;font-size:11px;display:flex}.stg-logo-upload-btn{cursor:pointer;align-items:center;gap:6px;display:inline-flex}.stg-logo-del-btn{color:#dc2626;border-color:#fca5a5}.stg-due-day-input{max-width:100px}.stg-penalty-row{margin-bottom:4px}.stg-toggle-label{cursor:pointer;padding:var(--space-md);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);-webkit-user-select:none;user-select:none;align-items:center;gap:12px;display:flex}.stg-toggle-text{flex:1;font-size:14px;font-weight:500}.stg-toggle-input{display:none}.stg-toggle-switch{background:var(--color-border);border-radius:11px;flex-shrink:0;width:40px;height:22px;transition:background .2s;position:relative}.stg-toggle-switch:after{content:"";background:#fff;border-radius:50%;width:16px;height:16px;transition:transform .2s;position:absolute;top:3px;left:3px;box-shadow:0 1px 3px #0003}.stg-toggle-input:checked+.stg-toggle-switch{background:var(--color-primary)}.stg-toggle-input:checked+.stg-toggle-switch:after{transform:translate(18px)}.stg-security-panel{gap:var(--space-md);flex-direction:column;display:flex}.stg-security-item{padding:var(--space-md);border:1px solid var(--color-border);border-radius:var(--radius-sm)}.stg-security-label{margin-bottom:4px;font-size:14px;font-weight:600}.stg-security-desc{color:var(--color-text-muted);font-size:13px;line-height:1.5}.stg-security-future{background:var(--color-bg)}.stg-security-future .stg-security-label{color:var(--color-text-muted)}.stg-type-chips{flex-wrap:wrap;gap:6px;margin-bottom:4px;display:flex}.stg-type-chip{border:1.5px solid var(--color-border);background:var(--color-bg);color:var(--color-text-muted);cursor:pointer;border-radius:99px;padding:4px 12px;font-family:monospace;font-size:12px;font-weight:600;transition:all .15s}.stg-type-chip:hover{border-color:var(--color-primary);color:var(--color-primary)}.stg-type-chip.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.form-hint-inline{color:var(--color-text-muted);font-size:11px;font-weight:400}.stg-save-bar{padding-top:var(--space-md);border-top:1px solid var(--color-border);margin-top:var(--space-md);justify-content:flex-end;display:flex}.ntc-summary-grid{gap:var(--space-md);margin-bottom:var(--space-lg);grid-template-columns:repeat(7,1fr);display:grid}@media (width<=1100px){.ntc-summary-grid{grid-template-columns:repeat(4,1fr)}}@media (width<=640px){.ntc-summary-grid{grid-template-columns:repeat(2,1fr)}}.ntc-summary-card{border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-md);box-shadow:var(--shadow-sm);background:#fff;flex-direction:column;gap:4px;display:flex}.ntc-summary-value{color:var(--color-text);font-size:20px;font-weight:800;line-height:1.1}.ntc-summary-label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:10px;font-weight:500}.ntc-card-out .ntc-summary-value{color:var(--color-primary)}.ntc-card-int .ntc-summary-value{color:#7c3aed}.ntc-card-in .ntc-summary-value{color:#059669}.ntc-card-unread .ntc-summary-value{color:#dc2626}.ntc-card-announce .ntc-summary-value{color:var(--color-primary)}.ntc-card-urgent .ntc-summary-value{color:#ef4444}.ntc-unread-banner{border-radius:var(--radius-sm);margin-bottom:var(--space-md);color:#1e40af;background:#eff6ff;border:1px solid #bfdbfe;padding:10px 16px;font-size:13px}.ntc-dir-tabs{border-bottom:2px solid var(--color-border);margin-bottom:var(--space-md);flex-wrap:wrap;gap:4px;padding-bottom:0;display:flex}.ntc-dir-tab{cursor:pointer;color:var(--color-text-muted);border-radius:var(--radius-sm) var(--radius-sm) 0 0;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-2px;padding:8px 16px;font-size:13px;font-weight:500;position:relative}.ntc-dir-tab:hover{color:var(--color-text)}.ntc-dir-tab-active{color:var(--color-primary);border-bottom-color:var(--color-primary);font-weight:700}.ntc-unread-dot{color:#fff;background:#dc2626;border-radius:99px;justify-content:center;align-items:center;min-width:18px;height:18px;margin-left:6px;padding:0 4px;font-size:10px;font-weight:700;display:inline-flex}.ntc-table-responsive{overflow-x:auto}.ntc-table-wrap{border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);background:#fff;min-width:800px;overflow:hidden}.ntc-table{border-collapse:collapse;width:100%;font-size:var(--font-size-sm)}.ntc-table th{background:var(--color-bg);text-align:left;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-muted);border-bottom:1px solid var(--color-border);white-space:nowrap;padding:10px 12px;font-size:11px;font-weight:700}.ntc-table td{border-bottom:1px solid var(--color-border);vertical-align:middle;padding:10px 12px}.ntc-table tr:last-child td{border-bottom:none}.ntc-table tr:hover td{background:#fafafa}.ntc-row-unread td{background:#eff6ff!important}.ntc-row-unread:hover td{background:#e0efff!important}.ntc-dot-cell{width:20px;padding-right:0!important}.ntc-dot{border-radius:50%;width:8px;height:8px;display:inline-block}.ntc-dot-urgent{background:#ef4444}.ntc-dot-high{background:#f59e0b}.ntc-title{cursor:pointer;color:var(--color-text);font-weight:600}.ntc-title:hover{color:var(--color-primary)}.ntc-preview{color:var(--color-text-muted);margin-top:2px;font-size:11px}.ntc-muted{color:var(--color-text-muted);font-size:12px}.ntc-actions{flex-wrap:nowrap;align-items:center;gap:4px;display:flex}.ntc-link-confirm{color:#059669}.ntc-link-danger{color:#dc2626}.ntc-link-restore{color:#6366f1}.ntc-archive-tabs{margin-bottom:var(--space-md);gap:4px;display:flex}.ntc-archive-tab{border:1px solid var(--color-border);cursor:pointer;color:var(--color-text-muted);border-radius:var(--radius-sm);font-size:12px;font-weight:500;font-family:var(--font-sans,"Inter", sans-serif);background:0 0;padding:5px 16px;transition:background .15s,color .15s,border-color .15s}.ntc-archive-tab:hover{background:var(--color-bg);color:var(--color-text)}.ntc-archive-tab-active{background:var(--color-primary);color:#fff;border-color:var(--color-primary);font-weight:600}.ntc-row-archived td{color:var(--color-text-muted);background:#fafafa!important}.ntc-delivery-cell{flex-direction:column;gap:2px;display:flex}.ntc-delivery-method{color:var(--color-text);font-size:11px;font-weight:600}.ntc-delivery-sent{color:#166534;font-size:10px}.ntc-delivery-failed{color:#991b1b;font-size:10px}.ntc-delivery-skipped{color:#71717a;font-size:10px}.ntc-delivery-pending{color:#854d0e;font-size:10px}.ntc-delivery-options{flex-direction:column;gap:6px;margin-top:4px;display:flex}.ntc-delivery-option{border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;flex-direction:column;gap:2px;padding:8px 12px;transition:border-color .15s,background .15s;display:flex}.ntc-delivery-option:hover{border-color:var(--color-primary);background:#f8faff}.ntc-delivery-option-active{border-color:var(--color-primary);background:#eff6ff}.ntc-delivery-label{color:var(--color-text);font-size:13px;font-weight:600}.ntc-delivery-desc{color:var(--color-text-muted);font-size:11px}.ntc-delivery-note{color:var(--color-text-muted);border-radius:var(--radius-sm);background:#fffbeb;border:1px solid #fde68a;margin:6px 0 0;padding:6px 10px;font-size:11px}.ntc-badge{white-space:nowrap;border-radius:4px;align-items:center;padding:2px 9px;font-size:11px;font-weight:600;display:inline-flex}.ntc-badge-announce{color:#1d4ed8;background:#eff6ff}.ntc-badge-notice{color:#15803d;background:#f0fdf4}.ntc-badge-reminder{color:#854d0e;background:#fef9c3}.ntc-badge-warning{color:#991b1b;background:#fee2e2}.ntc-badge-maint{color:#c2410c;background:#fff7ed}.ntc-badge-payment{color:#166534;background:#f0fdf4}.ntc-badge-internal{color:#7e22ce;background:#fdf4ff}.ntc-badge-inbound{color:#0f766e;background:#f0fdfa}.ntc-badge-general{color:#52525b;background:#f4f4f5}.ntc-status-badge{white-space:nowrap;border-radius:99px;align-items:center;padding:2px 9px;font-size:11px;font-weight:600;display:inline-flex}.ntc-status-sent{color:#166534;background:#dcfce7}.ntc-status-draft{color:#854d0e;background:#fef9c3}.ntc-status-archived{color:#9ca3af;background:#f4f4f5}.ntc-status-read{color:#71717a;background:#f4f4f5}.ntc-status-unread{color:#1d4ed8;background:#eff6ff;font-weight:700}.ntc-pri-chip{border-radius:4px;padding:2px 8px;font-size:11px;font-weight:700;display:inline-flex}.ntc-pri-urgent{color:#991b1b;background:#fee2e2}.ntc-pri-high{color:#c2410c;background:#fff7ed}.ntc-form{flex-direction:column;display:flex}.ntc-form-section{padding:var(--space-md) 0;border-bottom:1px solid var(--color-border)}.ntc-form-section:last-child{border-bottom:none}.ntc-form-section-title{text-transform:uppercase;letter-spacing:.6px;color:var(--color-text-muted);margin-bottom:var(--space-md);font-size:11px;font-weight:700}.ntc-form-row{gap:var(--space-md);grid-template-columns:1fr 1fr;display:grid}@media (width<=600px){.ntc-form-row{grid-template-columns:1fr}}.ntc-detail-panel{flex-direction:column;display:flex}.ntc-detail-header{padding-bottom:var(--space-md);border-bottom:1px solid var(--color-border);margin-bottom:var(--space-md);justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.ntc-detail-title{font-size:17px;font-weight:700}.ntc-detail-actions{margin-bottom:var(--space-md);flex-wrap:wrap;gap:8px;display:flex}.ntc-detail-content{padding:var(--space-md) 0;border-bottom:1px solid var(--color-border);margin-bottom:var(--space-md)}.ntc-detail-section-title{text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-muted);margin-bottom:10px;font-size:11px;font-weight:700}.ntc-detail-body{white-space:pre-wrap;color:var(--color-text);margin:0;font-size:14px;line-height:1.6}.ntc-detail-section{padding:var(--space-md) 0;border-bottom:1px solid var(--color-border)}.ntc-detail-section:last-child{border-bottom:none}.ntc-detail-row{font-size:var(--font-size-sm);justify-content:space-between;gap:12px;padding:5px 0;display:flex}.ntc-detail-label{color:var(--color-text-muted);flex-shrink:0;min-width:100px;font-weight:500}.ntc-detail-value{color:var(--color-text);text-align:right}.cmm-header-actions{flex-wrap:wrap;gap:8px;display:flex}.cmm-unread-banner{border-radius:var(--radius-sm);margin-bottom:var(--space-md);color:#1e40af;background:#eff6ff;border:1px solid #bfdbfe;padding:10px 16px;font-size:13px}.cmm-summary-grid{gap:var(--space-md);margin-bottom:var(--space-lg);grid-template-columns:repeat(6,1fr);display:grid}@media (width<=1000px){.cmm-summary-grid{grid-template-columns:repeat(3,1fr)}}@media (width<=600px){.cmm-summary-grid{grid-template-columns:repeat(2,1fr)}}.cmm-summary-card{border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-md);box-shadow:var(--shadow-sm);background:#fff;flex-direction:column;gap:4px;display:flex}.cmm-summary-value{color:var(--color-text);font-size:22px;font-weight:800;line-height:1.1}.cmm-summary-label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:10px;font-weight:500}.cmm-card-sent .cmm-summary-value{color:var(--color-success)}.cmm-card-scheduled .cmm-summary-value{color:#7c3aed}.cmm-card-new .cmm-summary-value{color:var(--color-primary)}.cmm-card-urgent .cmm-summary-value{color:#ef4444}.cmm-card-resolved .cmm-summary-value{color:var(--color-success)}.cmm-tabs{border-bottom:2px solid var(--color-border);margin-bottom:var(--space-md);flex-wrap:wrap;gap:4px;padding-bottom:0;display:flex}.cmm-tab{cursor:pointer;color:var(--color-text-muted);border-radius:var(--radius-sm) var(--radius-sm) 0 0;font-size:13px;font-weight:500;font-family:var(--font-sans,"Inter", sans-serif);background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-2px;padding:8px 16px;position:relative}.cmm-tab:hover{color:var(--color-text)}.cmm-tab-active{color:var(--color-primary);border-bottom-color:var(--color-primary);font-weight:700}.cmm-tab-badge{color:#fff;background:#dc2626;border-radius:99px;justify-content:center;align-items:center;min-width:18px;height:18px;margin-left:6px;padding:0 4px;font-size:10px;font-weight:700;display:inline-flex}.cmm-badge{white-space:nowrap;border-radius:99px;align-items:center;padding:2px 10px;font-size:11px;font-weight:600;display:inline-flex}.cmm-badge-draft{color:#854d0e;background:#fef9c3}.cmm-badge-scheduled{color:#7e22ce;background:#fdf4ff}.cmm-badge-sent{color:#166534;background:#dcfce7}.cmm-badge-cancelled{color:#71717a;background:#f4f4f5}.cmm-badge-new{color:#1d4ed8;background:#eff6ff;font-weight:700}.cmm-badge-reviewing{color:#854d0e;background:#fef9c3}.cmm-badge-resolved{color:#166534;background:#dcfce7}.cmm-badge-closed{color:#52525b;background:#f4f4f5}.cmm-badge-archived{color:#9ca3af;background:#f4f4f5}.cmm-priority-chip{text-transform:uppercase;border-radius:4px;padding:2px 7px;font-size:11px;font-weight:700;display:inline-flex}.cmm-pri-urgent{color:#991b1b;background:#fee2e2}.cmm-pri-high{color:#c2410c;background:#fff7ed}.cmm-type-chip{color:#1e40af;background:#eff6ff;border:1px solid #bfdbfe;border-radius:4px;padding:1px 8px;font-size:11px;font-weight:600;display:inline-block}.cmm-table-responsive{overflow-x:auto}.cmm-table-wrap{border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);background:#fff;min-width:760px;overflow:hidden}.cmm-table{border-collapse:collapse;width:100%;font-size:var(--font-size-sm)}.cmm-table th{background:var(--color-bg);text-align:left;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-muted);border-bottom:1px solid var(--color-border);white-space:nowrap;font-size:11px;font-weight:700;font-family:var(--font-sans,"Inter", sans-serif);padding:10px 12px}.cmm-table td{border-bottom:1px solid var(--color-border);vertical-align:middle;font-family:var(--font-sans,"Inter", sans-serif);padding:10px 12px}.cmm-table tr:last-child td{border-bottom:none}.cmm-table tr:hover td{background:#fafafa}.cmm-row-new td{background:#eff6ff!important}.cmm-row-new:hover td{background:#e0efff!important}.cmm-title{cursor:pointer;font-weight:600}.cmm-title:hover{color:var(--color-primary)}.cmm-muted{color:var(--color-text-muted);font-size:12px}.cmm-sub-type{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.4px;margin-top:2px;font-size:10px}.cmm-actions{flex-wrap:nowrap;align-items:center;gap:4px;display:flex}.cmm-send-pill{white-space:nowrap;text-transform:uppercase;letter-spacing:.3px;border-radius:99px;align-items:center;padding:1px 8px;font-size:10px;font-weight:700;display:inline-flex}.cmm-send-sent{color:#166534;background:#dcfce7}.cmm-send-failed{color:#991b1b;background:#fee2e2}.cmm-send-skipped{color:#71717a;background:#f4f4f5}.cmm-send-pending{color:#854d0e;background:#fef9c3}.cmm-send-nil{color:var(--color-text-muted);font-size:12px}.btn-link{cursor:pointer;color:var(--color-primary);background:0 0;border:none;border-radius:4px;padding:2px 6px;font-size:12px;font-weight:500}.btn-link:hover{background:var(--color-bg)}.cmm-link-confirm{color:#059669}.cmm-link-warn{color:#d97706}.cmm-link-danger{color:#dc2626}.cmm-form{flex-direction:column;display:flex}.cmm-form-section{padding:var(--space-md) 0;border-bottom:1px solid var(--color-border);gap:var(--space-md);flex-direction:column;display:flex}.cmm-form-section:last-child{border-bottom:none}.cmm-form-section-title{text-transform:uppercase;letter-spacing:.6px;color:var(--color-text-muted);font-size:11px;font-weight:700}.cmm-form-row{gap:var(--space-md);grid-template-columns:1fr 1fr;display:grid}@media (width<=600px){.cmm-form-row{grid-template-columns:1fr}}.cmm-detail-panel{flex-direction:column;display:flex}.cmm-detail-header{padding-bottom:var(--space-md);border-bottom:1px solid var(--color-border);margin-bottom:var(--space-md);justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.cmm-detail-title{margin-top:6px;font-size:17px;font-weight:700}.cmm-detail-actions{margin-bottom:var(--space-md);flex-wrap:wrap;gap:8px;display:flex}.cmm-detail-body-section{padding:var(--space-md) 0;border-bottom:1px solid var(--color-border);margin-bottom:var(--space-md)}.cmm-detail-section{padding:var(--space-md) 0;border-bottom:1px solid var(--color-border)}.cmm-detail-section:last-child{border-bottom:none}.cmm-detail-section-title{text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-muted);margin-bottom:10px;font-size:11px;font-weight:700}.cmm-detail-body{white-space:pre-wrap;margin:0;font-size:14px;line-height:1.6}.cmm-detail-row{font-size:var(--font-size-sm);justify-content:space-between;gap:12px;padding:5px 0;display:flex}.cmm-detail-label{color:var(--color-text-muted);flex-shrink:0;min-width:110px;font-weight:500}.cmm-detail-value{color:var(--color-text);text-align:right}.cmm-delivery-hint{color:var(--color-text-muted);margin:0 0 8px;font-size:12px}.cmm-delivery-options{flex-direction:column;gap:6px;display:flex}.cmm-delivery-option{border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;font-family:var(--font-sans,"Inter", sans-serif);flex-direction:column;gap:2px;padding:8px 12px;transition:border-color .15s,background .15s;display:flex}.cmm-delivery-option:hover{border-color:var(--color-primary);background:#f8faff}.cmm-delivery-option-active{border-color:var(--color-primary);background:#eff6ff}.cmm-delivery-label{color:var(--color-text);font-size:13px;font-weight:600}.cmm-delivery-desc{color:var(--color-text-muted);font-size:11px}.cmm-delivery-note{color:var(--color-text-muted);border-radius:var(--radius-sm);background:#fffbeb;border:1px solid #fde68a;margin:6px 0 0;padding:6px 10px;font-size:11px}.cmm-delivery-cell{flex-direction:column;gap:2px;display:flex}.cmm-delivery-method{color:var(--color-text);font-size:11px;font-weight:600}.file-upload-field{flex-direction:column;gap:6px;display:flex}.file-upload-btn{align-self:flex-start}.file-upload-error{color:var(--color-danger,#e53e3e);font-size:.78rem}.file-section{border-top:1px solid var(--color-border,#e2e8f0);margin-top:20px;padding-top:16px}.file-section-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.file-section-title{text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted,#718096);font-size:.8rem;font-weight:700}.file-empty-state{text-align:center;color:var(--color-text-muted,#718096);padding:20px 0;font-size:.82rem;line-height:1.5}.file-empty-icon{margin-bottom:8px;font-size:1.6rem}.file-cat-chip{background:var(--color-bg-alt,#f7fafc);color:var(--color-text-muted,#718096);border:1px solid var(--color-border,#e2e8f0);border-radius:10px;padding:2px 8px;font-size:.72rem;font-weight:600;display:inline-block}.file-list{flex-direction:column;gap:8px;display:flex}.file-list-error{color:var(--color-danger,#e53e3e);margin-bottom:4px;font-size:.78rem}.file-list-item{border:1px solid var(--color-border,#e2e8f0);background:var(--color-bg-card,#fff);border-radius:8px;align-items:flex-start;gap:10px;padding:10px 12px;display:flex}.file-list-icon{flex-shrink:0;margin-top:1px;font-size:1.4rem}.file-list-meta{flex:1;min-width:0}.file-list-name{color:var(--color-text,#1a202c);white-space:nowrap;text-overflow:ellipsis;margin-bottom:4px;font-size:.85rem;font-weight:600;overflow:hidden}.file-list-sub{color:var(--color-text-muted,#718096);flex-wrap:wrap;align-items:center;gap:6px;font-size:.75rem;display:flex}.file-list-desc{color:var(--color-text-muted,#718096);margin-top:4px;font-size:.78rem;font-style:italic}.file-list-actions{flex-shrink:0;align-items:flex-start;gap:6px;display:flex}.btn-xs{border-radius:6px;padding:3px 10px;font-size:.75rem}.btn-ghost{color:var(--color-text-muted,#718096);cursor:pointer;background:0 0;border:1px solid #0000}.btn-ghost:hover{background:var(--color-bg-alt,#f7fafc);border-color:var(--color-border,#e2e8f0)}.fpg-container{width:100%}.fpg-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:10px;margin-top:8px;display:grid}.fpg-tile{border:1px solid var(--color-border,#e2e8f0);background:var(--color-bg-alt,#f7fafc);border-radius:8px;flex-direction:column;display:flex;overflow:hidden}.fpg-img-wrap{aspect-ratio:1;background:var(--color-border,#e2e8f0);justify-content:center;align-items:center;width:100%;display:flex;position:relative;overflow:hidden}.fpg-img{object-fit:cover;width:100%;height:100%;display:block}.fpg-loader{border:3px solid var(--color-border,#e2e8f0);border-top-color:var(--color-primary,#2b6cb0);border-radius:50%;width:24px;height:24px;animation:.8s linear infinite fpg-spin}@keyframes fpg-spin{to{transform:rotate(360deg)}}.fpg-img-error{color:var(--color-text-muted,#a0aec0);font-size:1.5rem}.fpg-tile-footer{background:var(--color-bg-card,#fff);border-top:1px solid var(--color-border,#e2e8f0);justify-content:space-between;align-items:center;padding:4px 6px;display:flex}.fpg-cat{padding:1px 6px;font-size:.66rem}.fpg-archive-btn{color:var(--color-danger,#e53e3e);padding:2px 6px;font-size:.9rem;line-height:1}.file-cat-tabs{flex-wrap:wrap;gap:6px;margin-bottom:10px;display:flex}.file-cat-tab{border:1px solid var(--color-border,#e2e8f0);cursor:pointer;color:var(--color-text-muted,#718096);background:0 0;border-radius:16px;padding:4px 12px;font-size:.78rem;transition:background .15s}.file-cat-tab.active,.file-cat-tab:hover{background:var(--color-primary,#2b6cb0);color:#fff;border-color:var(--color-primary,#2b6cb0)}.ta-status-badge{letter-spacing:.2px;text-transform:capitalize;border-radius:20px;padding:2px 10px;font-size:11px;font-weight:600;display:inline-block}.ta-row-muted td{opacity:.55}.ta-name{color:var(--color-text);font-size:13px;font-weight:500}.ta-job-title{color:var(--color-text-muted);margin-top:2px;font-size:11px}.ta-filters{flex-wrap:wrap;gap:10px;margin-bottom:16px;display:flex}.ta-search{flex:1;min-width:200px}.ta-filter-select{width:180px}.ta-dropdown{display:inline-block;position:relative}.ta-dropdown-caret{margin-left:6px;font-size:9px}.ta-dropdown-menu{background:var(--color-bg-card);border:1px solid var(--color-border);z-index:200;border-radius:8px;min-width:180px;position:absolute;top:calc(100% + 4px);right:0;overflow:hidden;box-shadow:0 8px 24px #0000001a}.ta-dropdown-menu button{text-align:left;width:100%;color:var(--color-text);cursor:pointer;background:0 0;border:none;padding:9px 14px;font-family:inherit;font-size:13px;transition:background .1s;display:block}.ta-dropdown-menu button:hover:not(:disabled){background:var(--color-bg)}.ta-dropdown-menu button.text-danger{color:#dc2626}.ta-dropdown-menu button:not(:last-child){border-bottom:1px solid var(--color-border)}.ta-invite-prompt{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:16px;padding:60px 24px;display:flex}.ta-invite-prompt-text{color:var(--color-text-muted);max-width:400px;font-size:14px}.wizard-steps{align-items:flex-start;gap:0;margin-bottom:24px;padding:0 4px;display:flex;overflow-x:auto}.wizard-step{flex-direction:column;flex:1;align-items:center;min-width:60px;display:flex;position:relative}.wizard-step-dot{background:var(--color-border);width:28px;height:28px;color:var(--color-text-muted);z-index:1;border-radius:50%;justify-content:center;align-items:center;font-size:12px;font-weight:600;transition:background .2s,color .2s;display:flex;position:relative}.wizard-step.active .wizard-step-dot{background:var(--color-primary);color:#fff}.wizard-step.done .wizard-step-dot{color:#fff;background:#16a34a}.wizard-step-label{color:var(--color-text-muted);text-align:center;white-space:nowrap;margin-top:6px;font-size:11px}.wizard-step.active .wizard-step-label{color:var(--color-primary);font-weight:600}.wizard-step.done .wizard-step-label{color:#16a34a}.wizard-step-line{background:var(--color-border);z-index:0;width:100%;height:2px;position:absolute;top:14px;left:50%}.wizard-step.done .wizard-step-line{background:#16a34a}.wizard-body{min-height:200px;padding:4px 0 16px}.wizard-step-desc{color:var(--color-text-muted);margin-bottom:16px;font-size:13px}.wizard-nav{border-top:1px solid var(--color-border);justify-content:space-between;margin-top:8px;padding-top:16px;display:flex}.wizard-success-icon{justify-content:center;margin-bottom:12px;display:flex}.wizard-success-text{color:var(--color-text);text-align:center;margin-bottom:12px;font-size:15px}.preset-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px;display:grid}.preset-card{background:var(--color-bg-card);border:2px solid var(--color-border);text-align:left;cursor:pointer;border-radius:8px;padding:14px 16px;font-family:inherit;transition:border-color .15s,box-shadow .15s}.preset-card:hover{border-color:var(--color-primary)}.preset-card--selected{border-color:var(--color-primary);background:var(--color-primary-light,#eff6ff);box-shadow:0 0 0 3px #2563eb1a}.preset-card-name{color:var(--color-text);margin-bottom:4px;font-size:13px;font-weight:600}.preset-card-desc{color:var(--color-text-muted);font-size:12px;line-height:1.4}.scope-options{flex-direction:column;gap:8px;display:flex}.scope-option{cursor:pointer;color:var(--color-text);align-items:center;gap:10px;font-size:13px;display:flex}.scope-option--block{border:1px solid var(--color-border);border-radius:8px;padding:12px 14px;transition:border-color .15s,background .15s}.scope-option--block:hover{border-color:var(--color-primary)}.scope-option--active{border-color:var(--color-primary);background:var(--color-primary-light,#eff6ff)}.scope-option-label{color:var(--color-text);font-size:13px;font-weight:500}.scope-option-desc{color:var(--color-text-muted);margin-top:2px;font-size:12px}.assign-list{border:1px solid var(--color-border);border-radius:8px;overflow:hidden}.assign-list-label{color:var(--color-text-muted);background:var(--color-bg);border-bottom:1px solid var(--color-border);padding:8px 12px;font-size:12px;font-weight:600}.assign-item{cursor:pointer;border-bottom:1px solid var(--color-border);color:var(--color-text);align-items:center;gap:10px;padding:9px 12px;font-size:13px;transition:background .1s;display:flex}.assign-item:last-child{border-bottom:none}.assign-item:hover{background:var(--color-bg)}.assign-item-sub{color:var(--color-text-muted);margin-left:auto;font-size:11px}.perm-summary-box{border:1px solid var(--color-border);background:var(--color-bg-card);border-radius:8px;padding:16px}.perm-summary-role{color:var(--color-text);margin-bottom:4px;font-size:15px;font-weight:600}.perm-summary-desc{color:var(--color-text-muted);margin-bottom:8px;font-size:13px}.perm-summary-codes{flex-wrap:wrap;gap:6px;display:flex}.perm-code-chip{color:#334155;background:#e2e8f0;border-radius:4px;padding:2px 8px;font-family:monospace;font-size:11px;display:inline-block}.perm-code-chip--sm{padding:1px 6px;font-size:10px}.confirm-summary{border:1px solid var(--color-border);border-radius:8px;overflow:hidden}.confirm-row{border-bottom:1px solid var(--color-border);padding:10px 14px;font-size:13px;display:flex}.confirm-row:last-child{border-bottom:none}.confirm-label{width:130px;color:var(--color-text-muted);flex-shrink:0;font-weight:500}.confirm-value{color:var(--color-text);font-weight:400}.access-modal-body{flex-direction:column;gap:14px;display:flex}.access-modal-warning{color:#7f1d1d;background:#fee2e2;border-left:4px solid #dc2626;border-radius:8px;padding:12px 14px;font-size:13px;line-height:1.55}.access-modal-warning--amber{color:#78350f;background:#fef3c7;border-left-color:#f59e0b}.access-modal-warning--red{color:#7f1d1d;background:#fee2e2;border-left-color:#dc2626}.access-modal-target{color:var(--color-text);margin:0;font-size:13px}.access-modal-text{color:var(--color-text);margin:0;font-size:13px;line-height:1.55}.perm-source{vertical-align:middle;border-radius:3px;margin-left:6px;padding:1px 6px;font-size:10px;font-weight:600;display:inline-block}.perm-source--added{color:#15803d;background:#dcfce7}.perm-source--removed{color:#b91c1c;background:#fee2e2}.perm-source--default{color:#475569;background:#e2e8f0}.perm-source--sensitive{color:#92400e;background:#fef3c7}.edit-access-perm-info{flex-wrap:wrap;flex:1;align-items:center;gap:4px;min-width:0;display:flex}.edit-access-perm-code{color:var(--color-text-muted);font-family:monospace;font-size:10px}.edit-access-perm-row--sensitive{background:#fffbeb}.change-summary{border:1px solid var(--color-border);border-radius:8px;margin-top:8px;overflow:hidden}.change-summary--none{color:var(--color-text-muted);border:1px solid var(--color-border);text-align:center;border-radius:8px;padding:12px 14px;font-size:13px}.change-summary-title{text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-muted);background:var(--color-bg);border-bottom:1px solid var(--color-border);padding:8px 14px;font-size:12px;font-weight:700}.change-row{border-bottom:1px solid var(--color-border);align-items:flex-start;gap:10px;padding:8px 14px;font-size:13px;display:flex}.change-row:last-child{border-bottom:none}.change-row--added .change-label{color:#15803d}.change-row--removed .change-label{color:#b91c1c}.change-label{width:180px;color:var(--color-text-muted);flex-shrink:0;font-size:12px;font-weight:600}.change-value{color:var(--color-text);font-size:13px}.change-codes{flex-wrap:wrap;gap:4px;display:flex}.perm-code-chip--sensitive{color:#92400e;background:#fef3c7}.ta-view-tabs{border-bottom:2px solid var(--color-border);gap:0;margin-bottom:16px;display:flex}.ta-view-tab{color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;align-items:center;gap:6px;margin-bottom:-2px;padding:7px 18px;font-family:inherit;font-size:13px;font-weight:500;display:flex}.ta-view-tab:hover{color:var(--color-text)}.ta-view-tab--active{color:var(--color-primary);border-bottom-color:var(--color-primary);font-weight:700}.ta-view-tab-count{background:var(--color-border);min-width:18px;height:18px;color:var(--color-text-muted);border-radius:99px;justify-content:center;align-items:center;padding:0 4px;font-size:10px;font-weight:700;display:inline-flex}.ta-view-tab--active .ta-view-tab-count{background:var(--color-primary);color:#fff}.ta-scope-chip{white-space:nowrap;border-radius:4px;padding:2px 9px;font-size:11px;font-weight:600;display:inline-block}.ta-scope-chip--all{color:#15803d;background:#f0fdf4;border:1px solid #bbf7d0}.ta-scope-chip--limited{color:#1d4ed8;background:#eff6ff;border:1px solid #bfdbfe}.edit-access-perms-label{color:var(--color-text);margin:16px 0 6px;font-size:13px;font-weight:600}.edit-access-legend{color:var(--color-text-muted);align-items:center;gap:4px;margin-bottom:12px;font-size:11px;display:flex}.legend-dot{border-radius:2px;width:10px;height:10px;display:inline-block}.legend-dot--grant{background:#16a34a}.legend-dot--deny{background:#dc2626}.legend-dot--none{background:#e2e8f0}.edit-access-modules{flex-direction:column;gap:10px;max-height:52vh;padding-right:4px;display:flex;overflow-y:auto}.edit-access-module{border:1px solid var(--color-border);border-radius:8px;overflow:hidden}.edit-access-module-header{background:var(--color-bg);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;gap:8px;padding:7px 12px;display:flex}.edit-access-module-name{text-transform:uppercase;letter-spacing:.6px;color:var(--color-text-muted);font-size:11px;font-weight:700}.edit-access-module-actions{flex-shrink:0;gap:2px;display:flex}.edit-access-perms-grid{flex-direction:column;display:flex}.edit-access-perm-row{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:7px 12px;font-size:13px;display:flex}.edit-access-perm-row:last-child{border-bottom:none}.edit-access-perm-name{color:var(--color-text);flex:1}.edit-access-perm-toggle{gap:2px;display:flex}.perm-toggle-btn{border:1px solid var(--color-border);background:var(--color-bg-card);width:24px;height:24px;color:var(--color-text-muted);cursor:pointer;border-radius:4px;font-family:inherit;font-size:11px;font-weight:600;transition:background .1s,color .1s,border-color .1s}.perm-toggle-btn:hover{background:var(--color-bg)}.perm-toggle-btn.active-grant{color:#15803d;background:#dcfce7;border-color:#16a34a}.perm-toggle-btn.active-deny{color:#b91c1c;background:#fee2e2;border-color:#dc2626}.perm-toggle-btn.active-default{color:#475569;background:#e2e8f0;border-color:#94a3b8}.preset-cards-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px;margin-top:16px;display:grid}.preset-detail-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:10px;flex-direction:column;gap:10px;padding:18px;transition:box-shadow .15s;display:flex}.preset-detail-card:hover{box-shadow:0 4px 14px #00000012}.preset-detail-card-header{justify-content:space-between;align-items:flex-start;gap:8px;display:flex}.preset-detail-name{color:var(--color-text);font-size:14px;font-weight:600}.preset-perm-count{color:#475569;white-space:nowrap;background:#e2e8f0;border-radius:10px;padding:2px 8px;font-size:11px}.preset-detail-card-desc{color:var(--color-text-muted);flex:1;font-size:13px;line-height:1.5}.preset-detail-card-actions{gap:8px;display:flex}.preset-detail-desc{color:var(--color-text-muted);margin-bottom:12px;font-size:13px;line-height:1.5}.preset-detail-count{color:var(--color-text-muted);margin-bottom:8px;font-size:12px;font-weight:600}.perm-matrix-table{font-size:12px}.perm-matrix-module-col{min-width:130px}.perm-matrix-action-col{text-align:center;min-width:60px}.perm-matrix-module-name{color:var(--color-text);font-weight:600}.perm-matrix-cell{text-align:center}.perm-matrix-dot{background:var(--color-primary);border-radius:50%;width:8px;height:8px;display:inline-block}.perm-matrix-empty{color:#cbd5e1}.perm-code-list{flex-wrap:wrap;gap:4px;display:flex}.activity-action-badge{white-space:nowrap;border-radius:4px;padding:2px 8px;font-family:monospace;font-size:11px}.section-header-sub{color:var(--color-text-muted);margin:0;font-size:12px;font-weight:400}.form-hint{color:var(--color-text-muted);margin:4px 0 0;font-size:11px}.roles-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;margin-top:16px;display:grid}.role-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:10px;flex-direction:column;gap:8px;padding:18px;transition:box-shadow .15s;display:flex}.role-card:hover{box-shadow:0 4px 12px #00000012}.role-card--system{border-left:3px solid var(--color-primary)}.role-card-name{color:var(--color-text);font-size:15px;font-weight:600}.role-card-desc{color:var(--color-text-muted);flex:1;font-size:13px;line-height:1.5}.role-card-actions{gap:8px;margin-top:8px;display:flex}.staff-types-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px;margin-top:16px;display:grid}.staff-type-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:10px;flex-direction:column;gap:8px;padding:16px;transition:box-shadow .15s;display:flex}.staff-type-card:hover{box-shadow:0 3px 10px #0000000f}.staff-type-card--inactive{opacity:.6}.staff-type-card-header{justify-content:space-between;align-items:flex-start;gap:8px;display:flex}.staff-type-name{color:var(--color-text);font-size:14px;font-weight:600}.staff-type-badges{flex-shrink:0;gap:5px;display:flex}.staff-type-desc{color:var(--color-text-muted);flex:1;font-size:12px;line-height:1.5}.staff-type-actions{gap:6px;margin-top:4px;display:flex}.rpm-container{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:10px;overflow:hidden}.rpm-header{border-bottom:1px solid var(--color-border);background:var(--color-bg);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.rpm-title{color:var(--color-text);margin:0;font-size:15px;font-weight:600}.rpm-modules{flex-direction:column;gap:14px;max-height:60vh;padding:16px 20px;display:flex;overflow-y:auto}.rpm-module-block{border:1px solid var(--color-border);border-radius:8px;overflow:hidden}.rpm-module-header{background:var(--color-bg);border-bottom:1px solid var(--color-border);padding:10px 14px}.rpm-module-toggle{cursor:pointer;color:var(--color-text);align-items:center;gap:8px;font-size:13px;font-weight:600;display:flex}.rpm-module-name{text-transform:uppercase;letter-spacing:.5px;font-size:11px}.rpm-perms-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:8px;padding:12px 14px;display:grid}.rpm-perm-item{color:var(--color-text);cursor:pointer;align-items:center;gap:6px;font-size:13px;display:flex}.rpm-perm-item input[type=checkbox]{cursor:pointer}.rpm-footer{border-top:1px solid var(--color-border);background:var(--color-bg);justify-content:flex-end;gap:10px;padding:14px 20px;display:flex}.activity-action-badge{color:#334155;background:#e2e8f0;border-radius:4px;padding:2px 8px;font-family:monospace;font-size:11px}.invite-success{text-align:center;padding:20px}.invite-success-icon{margin-bottom:12px;font-size:40px}.invite-link-label{color:var(--color-text-muted);text-align:left;margin:16px 0 6px;font-size:13px}.invite-link-box{gap:8px;margin-bottom:16px;display:flex}.section-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.section-header h3{color:var(--color-text);margin:0;font-size:15px;font-weight:600}.invite-info-box{color:#0c4a6e;background:#f0f9ff;border:1px solid #bae6fd;border-radius:8px;margin-bottom:16px;padding:14px 16px;font-size:14px}.invite-email{color:#0369a1;font-weight:500;margin-top:4px!important}.badge-xs{padding:2px 6px;font-size:10px}.badge-outline{border:1px solid var(--color-border);color:var(--color-text-muted);background:0 0}.table-cell-actions{align-items:center;gap:10px;display:flex}.btn-warning{color:#fff;background:#f59e0b;border:none}.btn-warning:hover:not(:disabled){background:#d97706}.btn-success{color:#fff;background:#16a34a;border:none}.btn-xs{cursor:pointer;border:1px solid var(--color-border);background:var(--color-bg-card);color:var(--color-text);border-radius:5px;padding:3px 10px;font-size:11px;font-weight:500}.btn-xs:hover:not(:disabled){background:var(--color-bg)}.vsm-chip-list{flex-wrap:wrap;gap:5px;margin-top:4px;display:flex}.vsm-chip{color:#334155;background:#e2e8f0;border-radius:4px;padding:2px 9px;font-size:11px;font-weight:500;display:inline-block}.vsm-chip--perm{color:#1d4ed8;background:#eff6ff}.vsm-chip--added{color:#15803d;background:#dcfce7}.vsm-chip--denied{color:#b91c1c;background:#fee2e2}.vsm-perm-groups{flex-direction:column;gap:10px;display:flex}.vsm-perm-group{border:1px solid var(--color-border);border-radius:6px;overflow:hidden}.vsm-perm-group-name{text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-muted);background:var(--color-bg);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:5px 10px;font-size:11px;font-weight:700;display:flex}.vsm-perm-count{background:var(--color-border);color:var(--color-text-muted);border-radius:99px;padding:0 5px;font-size:10px;font-weight:700}.table-cell-muted{color:var(--color-text-muted);font-size:12px}.ea-page-layout{grid-template-columns:300px 1fr;align-items:start;gap:20px;display:grid}.ea-sidebar{flex-direction:column;gap:14px;display:flex;position:sticky;top:24px}.ea-staff-card{text-align:center;flex-direction:column;align-items:center;padding:24px 16px 20px;display:flex}.ea-staff-avatar{background:var(--color-primary);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:52px;height:52px;margin-bottom:12px;font-size:20px;font-weight:700;display:flex}.ea-staff-name{color:var(--color-text);margin-bottom:4px;font-size:15px;font-weight:600}.ea-staff-detail{color:var(--color-text-muted);margin-top:2px;font-size:12px}.ea-card-label{text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-muted);margin-bottom:10px;font-size:11px;font-weight:700}.ea-main{flex-direction:column;gap:10px;display:flex}.ea-main-header{justify-content:space-between;align-items:center;margin-bottom:4px;display:flex}.ea-main-title{color:var(--color-text);font-size:13px;font-weight:600}.ea-perm-legend{color:var(--color-text-muted);align-items:center;gap:4px;font-size:11px;display:flex}.ea-leg{border-radius:2px;width:10px;height:10px;margin-left:8px;display:inline-block}.ea-leg--grant{background:#16a34a}.ea-leg--deny{background:#dc2626}.ea-leg--reset{background:#e2e8f0;border:1px solid #94a3b8}.ea-module-card{border:1px solid var(--color-border);background:var(--color-bg-card);border-radius:8px;overflow:hidden}.ea-module-header{background:var(--color-bg);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;gap:8px;padding:9px 14px;display:flex}.ea-module-name{text-transform:uppercase;letter-spacing:.6px;color:var(--color-text-muted);font-size:11px;font-weight:700}.ea-module-actions{flex-shrink:0;gap:2px;display:flex}.ea-perms-grid{flex-direction:column;display:flex}.ea-perm-row{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;gap:12px;padding:9px 14px;display:flex}.ea-perm-row:last-child{border-bottom:none}.ea-perm-row--sensitive{background:#fffbeb}.ea-perm-info{flex-wrap:wrap;flex:1;align-items:center;gap:6px;min-width:0;display:flex}.ea-perm-name{color:var(--color-text);font-size:13px;font-weight:500}.ea-perm-code{color:var(--color-text-muted);font-family:monospace;font-size:11px}.ea-badge{border-radius:3px;padding:1px 6px;font-size:10px;font-weight:600;display:inline-block}.ea-badge--grant{color:#15803d;background:#dcfce7}.ea-badge--deny{color:#b91c1c;background:#fee2e2}.ea-badge--owner{color:#92400e;background:#fef3c7}.ea-perm-toggle{flex-shrink:0;gap:3px;display:flex}.ea-toggle-btn{border:1px solid var(--color-border);background:var(--color-bg-card);width:28px;height:28px;color:var(--color-text-muted);cursor:pointer;border-radius:5px;font-family:inherit;font-size:12px;font-weight:600;transition:background .1s,border-color .1s}.ea-toggle-btn:hover:not(:disabled){background:var(--color-bg)}.ea-toggle-btn:disabled{opacity:.4;cursor:not-allowed}.ea-toggle-btn--grant{color:#15803d;background:#dcfce7;border-color:#16a34a}.ea-toggle-btn--deny{color:#b91c1c;background:#fee2e2;border-color:#dc2626}.ea-toggle-btn--default{color:#475569;background:#e2e8f0;border-color:#94a3b8}@media (width<=920px){.ea-page-layout{grid-template-columns:1fr}.ea-sidebar{position:static}}.ta-property-access{padding:4px 0}.ta-property-access-select{margin:20px 0 16px}.ta-staff-card{background:var(--color-bg);border:1px solid var(--color-border);border-radius:8px;margin-bottom:20px;padding:14px 18px}.ta-staff-card-name{color:var(--color-text);font-size:14px;font-weight:600}.ta-staff-card-meta{color:var(--color-text-muted);margin-top:3px;font-size:12px}.ta-staff-card-scope{color:var(--color-text-muted);margin-top:6px;font-size:12px}.ta-property-list-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.ta-property-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px;margin-bottom:20px;display:grid}.ta-property-card{border:1.5px solid var(--color-border);cursor:pointer;background:var(--color-bg-card);-webkit-user-select:none;user-select:none;border-radius:8px;align-items:flex-start;gap:10px;padding:12px 14px;transition:border-color .15s,background .15s;display:flex}.ta-property-card:hover{border-color:var(--color-primary)}.ta-property-card--selected{border-color:var(--color-primary);background:rgba(var(--color-primary-rgb,79, 70, 229), .06)}.ta-property-card input[type=checkbox]{accent-color:var(--color-primary);flex-shrink:0;margin-top:2px}.ta-property-card-name{color:var(--color-text);font-size:13px;font-weight:500}.ta-property-card-meta{color:var(--color-text-muted);margin-top:2px;font-size:11px}.ta-property-access-footer{border-top:1px solid var(--color-border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;padding-top:16px;display:flex}.ta-property-access-hint{color:var(--color-text-muted);flex:1;font-size:12px}.smtp-form .form-section{border:1px solid var(--color-border);background:var(--color-bg-card);border-radius:10px;margin-bottom:18px;padding:20px}.form-section-title{text-transform:uppercase;letter-spacing:.6px;color:var(--color-text-muted);margin:0 0 16px;font-size:12px;font-weight:700}.smtp-test-row{align-items:center;gap:10px;display:flex}.smtp-test-row .form-input{flex:1}.smtp-tabs{border-bottom:2px solid var(--color-border);gap:0;margin-bottom:20px;display:flex}.smtp-tab{color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-2px;padding:9px 18px;font-size:13px;font-weight:600;transition:color .15s,border-color .15s}.smtp-tab:hover{color:var(--color-text)}.smtp-tab--active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.templates-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;margin-top:16px;display:grid}.template-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:10px;flex-direction:column;gap:8px;padding:18px;transition:box-shadow .15s;display:flex}.template-card:hover{box-shadow:0 4px 12px #00000014}.template-card--inactive{opacity:.55}.template-card-key{color:var(--color-primary);letter-spacing:.2px;font-size:12px;font-weight:600}.template-card-name{color:var(--color-text);font-size:14px;font-weight:600}.template-card-subject{color:var(--color-text-muted);text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:12px;font-style:italic;overflow:hidden}.template-card-footer{justify-content:space-between;align-items:center;margin-top:8px;display:flex}.template-editor{padding:0}.template-tabs{gap:4px;margin-bottom:10px;display:flex}.template-textarea{resize:vertical;min-height:200px;font-family:Consolas,Monaco,monospace!important;font-size:12px!important}.template-var-chips{background:var(--color-bg);border:1px solid var(--color-border);border-radius:8px;flex-wrap:wrap;align-items:center;gap:6px;margin-bottom:12px;padding:10px 12px;display:flex}.var-chip{color:#334155;cursor:pointer;background:#e2e8f0;border:none;border-radius:4px;padding:3px 8px;font-family:monospace;font-size:11px;transition:background .1s}.var-chip:hover{background:var(--color-primary);color:#fff}.template-preview-panel{border:1px solid var(--color-border);border-radius:8px;margin-bottom:8px;overflow:hidden}.template-preview-subject{background:var(--color-bg);border-bottom:1px solid var(--color-border);color:var(--color-text);padding:10px 14px;font-size:13px}.template-preview-html{background:#fff;max-height:420px;padding:16px;font-size:14px;line-height:1.6;overflow-y:auto}.status-dot{font-size:12px;font-weight:500}.settings-info-banner{background:#eff6ff;border:1px solid #bfdbfe;border-radius:10px;align-items:flex-start;gap:12px;margin-bottom:20px;padding:14px 16px;display:flex}.info-icon{color:#2563eb;flex-shrink:0;margin-top:1px;font-size:18px}.settings-info-banner strong{color:#1e40af;margin-bottom:4px;font-size:14px;display:block}.settings-info-banner p{color:#3b82f6;margin:0;font-size:13px}.badge-green{color:#166534;background:#dcfce7;border:none}.badge-gray{color:#64748b;background:#f1f5f9;border:none}.badge-yellow{color:#854d0e;background:#fef9c3;border:none}.badge-red{color:#991b1b;background:#fee2e2;border:none}.staff-shell{background:var(--bg-main,#f8fafc);height:100vh;display:flex;overflow:hidden}.staff-sidebar{z-index:100;background:#071827;flex-direction:column;flex-shrink:0;width:240px;height:100vh;transition:transform .25s;display:flex;overflow-y:auto}.staff-sidebar-brand{border-bottom:1px solid #ffffff14;align-items:center;gap:10px;padding:20px 16px 14px;display:flex}.staff-sidebar-icon{color:#fff;background:#1e4a7a;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:16px;font-weight:700;display:flex}.staff-sidebar-name{color:#e2e8f0;font-size:13px;font-weight:700}.staff-sidebar-tag{color:#64748b;letter-spacing:1px;font-size:10px}.staff-ws-strip{background:#ffffff08;border-bottom:1px solid #ffffff0f;align-items:center;gap:10px;padding:12px 16px;display:flex}.staff-ws-avatar{color:#fff;background:#1e4a7a;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:13px;font-weight:600;display:flex}.staff-ws-fullname{color:#e2e8f0;white-space:nowrap;text-overflow:ellipsis;font-size:12px;font-weight:600;overflow:hidden}.staff-ws-role{color:#64748b;margin-top:1px;font-size:11px}.staff-sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:12px 8px;display:flex}.staff-nav-item{color:#94a3b8;border-radius:8px;align-items:center;gap:10px;padding:9px 12px;font-size:13px;text-decoration:none;transition:background .15s,color .15s;display:flex}.staff-nav-item:hover{color:#e2e8f0;background:#ffffff12}.staff-nav-item.active{color:#60a5fa;background:#1e4a7a80}.staff-nav-icon{text-align:center;flex-shrink:0;width:18px;font-size:14px}.staff-sidebar-footer{border-top:1px solid #ffffff0f;padding:12px 8px}.staff-logout-btn{color:#64748b;cursor:pointer;background:0 0;border:none;border-radius:8px;align-items:center;gap:8px;width:100%;padding:9px 12px;font-size:13px;transition:background .15s,color .15s;display:flex}.staff-logout-btn:hover{color:#f87171;background:#dc26261a}.staff-main{flex-direction:column;flex:1;display:flex;overflow:hidden}.staff-topbar{border-bottom:1px solid var(--color-border);background:var(--color-bg-card,white);flex-shrink:0;align-items:center;gap:12px;height:58px;padding:0 20px;display:flex}.staff-menu-toggle{cursor:pointer;color:var(--color-text-muted);background:0 0;border:none;padding:4px 6px;font-size:18px;display:none}.staff-topbar-title{color:var(--color-text);flex:1;font-size:15px;font-weight:600}.staff-topbar-right{color:var(--color-text-muted);font-size:13px}.staff-content{flex:1;padding:0;overflow-y:auto}.staff-welcome h2{color:var(--color-text);margin:0 0 4px;font-size:20px;font-weight:700}.staff-modules-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;margin-top:24px;display:grid}.staff-module-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:12px;flex-direction:column;gap:8px;padding:20px;transition:box-shadow .15s;display:flex}.staff-module-card:hover{box-shadow:0 4px 12px #00000014}.staff-module-icon{font-size:24px}.staff-module-title{color:var(--color-text);font-size:15px;font-weight:600}.staff-module-desc{color:var(--color-text-muted);flex:1;margin:0;font-size:13px}.staff-auth-shell{background:linear-gradient(135deg,#071827 0%,#0f3460 55%,#16213e 100%)}.staff-auth-header{background:linear-gradient(135deg,#0f3460 0%,#1a4a7a 100%)!important}.invite-info-box{background:#f0f7ff;border:1px solid #bfdbfe;border-radius:8px;margin-bottom:20px;padding:14px 16px;font-size:14px;line-height:1.6}.invite-info-box strong{color:#1e3a5f}.report-detail-view{flex-direction:column;gap:12px;display:flex}.review-info-row{align-items:center;gap:8px;font-size:14px;display:flex}.review-info-row span:first-child{color:var(--color-text-muted);min-width:80px}.review-description-box{background:var(--color-bg);border:1px solid var(--color-border);color:var(--color-text);border-radius:8px;padding:14px;font-size:14px;line-height:1.6}.status-badge{text-transform:capitalize;border-radius:4px;padding:3px 10px;font-size:12px;font-weight:500;display:inline-block}.profile-info-grid{flex-direction:column;gap:12px;display:flex}.profile-info-row{border-bottom:1px solid var(--color-border);gap:16px;padding-bottom:12px;font-size:14px;display:flex}.profile-info-label{color:var(--color-text-muted);min-width:110px;font-size:13px}.profile-info-value{color:var(--color-text);font-weight:500}.permissions-chips{flex-wrap:wrap;gap:6px;display:flex}.radio-group{gap:20px;display:flex}.radio-label{cursor:pointer;align-items:center;gap:6px;font-size:14px;display:flex}.approve-text{color:#16a34a;font-weight:500}.reject-text{color:#dc2626;font-weight:500}.required-star{color:#dc2626}.btn-success{color:#fff;cursor:pointer;background:#16a34a;border:none;border-radius:6px;padding:8px 16px;font-size:14px;font-weight:500;transition:background .15s}.btn-success:hover:not(:disabled){background:#15803d}.btn-success:disabled{opacity:.6;cursor:not-allowed}.btn-danger{color:#fff;cursor:pointer;background:#dc2626;border:none;border-radius:6px;padding:8px 16px;font-size:14px;font-weight:500;transition:background .15s}.btn-danger:hover:not(:disabled){background:#b91c1c}.btn-danger:disabled{opacity:.6;cursor:not-allowed}.staff-module-card{color:inherit;cursor:pointer;text-decoration:none}.search-bar-row{align-items:center;gap:12px;margin-bottom:16px;display:flex}.staff-property-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;margin-top:8px;display:grid}.staff-property-card{background:var(--color-bg-card,white);border:1px solid var(--color-border);border-radius:12px;flex-direction:column;gap:12px;padding:20px;display:flex}.staff-property-header{align-items:flex-start;gap:12px;display:flex}.staff-property-icon{flex-shrink:0;margin-top:2px;font-size:24px}.staff-property-name{color:var(--color-text);font-size:15px;font-weight:700}.staff-property-code{color:#94a3b8;margin-top:2px;font-size:11px}.staff-property-address{color:var(--color-text-muted);font-size:13px}.staff-property-stats{border-top:1px solid var(--color-border);border-bottom:1px solid var(--color-border);gap:16px;padding:12px 0;display:flex}.staff-prop-stat{flex-direction:column;flex:1;align-items:center;gap:2px;display:flex}.staff-prop-stat-value{color:var(--color-text);font-size:20px;font-weight:700}.staff-prop-stat-label{color:var(--color-text-muted);text-align:center;font-size:11px}.staff-property-meta{flex-wrap:wrap;gap:6px;display:flex}.notices-list{flex-direction:column;gap:10px;margin-top:8px;display:flex}.notice-card{background:var(--color-bg-card,white);border:1px solid var(--color-border);cursor:pointer;border-radius:10px;padding:16px;transition:box-shadow .15s}.notice-card:hover,.notice-card--open{border-color:var(--color-primary);box-shadow:0 4px 12px #00000014}.notice-card-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.notice-card-left{align-items:center;gap:6px;display:flex}.notice-type-chip{color:#475569;text-transform:uppercase;letter-spacing:.5px;background:#f1f5f9;border-radius:4px;padding:2px 8px;font-size:11px;font-weight:600}.notice-card-date{color:var(--color-text-muted);font-size:12px}.notice-card-title{color:var(--color-text);margin-bottom:4px;font-size:15px;font-weight:600}.notice-card-property{color:var(--color-text-muted);margin-bottom:4px;font-size:12px}.notice-card-body{border-top:1px solid var(--color-border);color:var(--color-text);white-space:pre-line;margin-top:12px;padding-top:12px;font-size:14px;line-height:1.6}.profile-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));align-items:start;gap:20px;display:grid}.access-modules-grid{flex-direction:column;gap:8px;display:flex}.access-module-chip{background:#f8fafc;border-radius:6px;align-items:baseline;gap:8px;padding:8px 12px;font-size:13px;display:flex}.access-module-name{color:var(--color-text);min-width:100px;font-weight:600}.access-module-actions{color:var(--color-text-muted);font-size:12px}.alert-info{color:#1d4ed8;background:#dbeafe}.card{background:var(--color-bg-card,white);border:1px solid var(--color-border);border-radius:12px;overflow:hidden}.card-header{border-bottom:1px solid var(--color-border);color:var(--color-text);background:#f8fafc;padding:14px 20px;font-size:14px;font-weight:600}.card-body{padding:20px}.sidebar-overlay{z-index:99;background:#00000080;display:none;position:fixed;inset:0}@media (width<=768px){.staff-sidebar{position:fixed;top:0;left:0;transform:translate(-100%)}.staff-sidebar.open{transform:translate(0);box-shadow:4px 0 20px #0000004d}.sidebar-overlay,.staff-menu-toggle{display:block}}:root{--cc-navy:#0c1628;--cc-navy-light:#172136;--cc-navy-muted:#263352;--cc-sidebar-text:#8da0bc;--cc-sidebar-hover:#ffffff0a;--cc-active-bg:#3b82f624;--cc-active-border:#3b82f6;--cc-active-text:#93c5fd;--cc-blue:#3b82f6;--cc-blue-light:#dbeafe;--cc-green:#10b981;--cc-green-light:#dcfce7;--cc-amber:#f59e0b;--cc-amber-light:#fef3c7;--cc-red:#ef4444;--cc-red-light:#fee2e2;--cc-purple:#6366f1;--cc-purple-light:#ede9fe;--cc-teal:#14b8a6;--cc-teal-light:#ccfbf1;--cc-cyan:#06b6d4;--cc-cyan-light:#cffafe;--cc-sidebar-width:252px;--cc-font:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--cc-topbar-h:60px;--cc-radius:12px;--cc-card-shadow:0 1px 3px #00000012, 0 1px 2px #0000000a;--cc-card-hover-shadow:0 8px 28px #0000001a, 0 2px 8px #0000000f;--cc-glow-blue:0 0 14px #3b82f647, 0 0 40px #3b82f61a;--cc-glow-green:0 0 14px #10b98147, 0 0 40px #10b9811a;--cc-glow-red:0 0 14px #ef444452, 0 0 40px #ef44441f;--cc-glow-amber:0 0 14px #f59e0b47, 0 0 40px #f59e0b14;--cc-glow-purple:0 0 14px #6366f147, 0 0 40px #6366f11a;--cc-glow-teal:0 0 14px #14b8a647, 0 0 40px #14b8a61a}@keyframes cc-fade-up{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}@keyframes cc-fade-in{0%{opacity:0}to{opacity:1}}@keyframes cc-shimmer{0%{background-position:-800px 0}to{background-position:800px 0}}@keyframes cc-pulse-green{0%,to{box-shadow:0 0 #10b98180,0 0 6px #10b98166}50%{box-shadow:0 0 0 5px #10b98100,0 0 14px #10b9814d}}@keyframes cc-pulse-red{0%,to{box-shadow:0 0 #ef444499,0 0 8px #ef444480}50%{box-shadow:0 0 0 6px #ef444400,0 0 18px #ef444466}}@keyframes cc-pulse-amber{0%,to{box-shadow:0 0 #f59e0b80,0 0 6px #f59e0b66}50%{box-shadow:0 0 0 5px #f59e0b00,0 0 14px #f59e0b4d}}@keyframes cc-neon-border-pulse{0%,to{opacity:.7}50%{opacity:1}}.cc-shell{min-height:100vh;font-family:var(--cc-font);background:#f0f4f8;display:flex}body,input,button,select,textarea{font-family:var(--cc-font)}.cc-sidebar{width:var(--cc-sidebar-width);z-index:200;scrollbar-width:thin;scrollbar-color:#ffffff12 transparent;background:linear-gradient(#0c1628 0%,#0a1220 100%);border-right:1px solid #ffffff0d;flex-direction:column;height:100vh;display:flex;position:fixed;top:0;left:0;overflow:hidden auto}.cc-sidebar::-webkit-scrollbar{width:3px}.cc-sidebar::-webkit-scrollbar-track{background:0 0}.cc-sidebar::-webkit-scrollbar-thumb{background:#ffffff14;border-radius:2px}.cc-brand{background:linear-gradient(135deg,#3b82f626 0%,#6366f10d 100%);border-bottom:1px solid #ffffff0d;flex-shrink:0;align-items:center;gap:10px;padding:18px 18px 16px;display:flex}.cc-brand-icon{color:#fff;background:linear-gradient(135deg,#3b82f6 0%,#6366f1 100%);border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:16px;font-weight:800;display:flex;box-shadow:0 0 0 2px #3b82f640,0 4px 14px #3b82f666,0 0 24px #3b82f62e}.cc-brand-text{flex-direction:column;gap:3px;min-width:0;display:flex}.cc-brand-name{color:#f1f5f9;letter-spacing:.5px;font-size:14.5px;font-weight:700;line-height:1.1}.cc-brand-tag{color:#60a5fa;letter-spacing:.9px;text-transform:uppercase;background:#3b82f626;border:1px solid #3b82f640;border-radius:4px;width:fit-content;padding:2px 6px;font-size:9.5px;font-weight:600}.cc-nav-body{scrollbar-width:none;flex:1;padding:6px 0 12px;overflow:hidden auto}.cc-nav-body::-webkit-scrollbar{display:none}.cc-nav-group{margin-bottom:1px}.cc-nav-group-header{cursor:pointer;-webkit-user-select:none;user-select:none;text-align:left;background:0 0;border:none;border-radius:0;justify-content:space-between;align-items:center;gap:6px;width:100%;padding:9px 16px 4px;transition:background .15s;display:flex}.cc-nav-group-header:hover{background:#ffffff05}.cc-nav-group-header.active-group .cc-nav-group-label{color:#60a5fa}.cc-nav-group-label{letter-spacing:.9px;text-transform:uppercase;color:#3d5270;flex:1;font-size:9.5px;font-weight:700;transition:color .15s}.cc-nav-group-chevron{color:#3d5270;flex-shrink:0;transition:transform .25s cubic-bezier(.4,0,.2,1),color .15s}.cc-nav-group-chevron.open{transform:rotate(180deg)}.cc-nav-group-items{overflow:hidden}.cc-nav-item{color:var(--cc-sidebar-text);cursor:pointer;white-space:nowrap;text-overflow:ellipsis;border-left:2px solid #0000;align-items:center;gap:9px;padding:7px 16px;font-size:13px;font-weight:450;line-height:1.4;text-decoration:none;transition:background .12s,color .12s,border-left-color .12s;display:flex;overflow:hidden}.cc-nav-item:hover{background:var(--cc-sidebar-hover);color:#cbd5e1;border-left-color:#3b82f64d}.cc-nav-item.active{border-left-color:var(--cc-active-border);color:var(--cc-active-text);background:linear-gradient(90deg,#3b82f62e 0%,#3b82f60a 100%);font-weight:600;box-shadow:inset 2px 0 10px #3b82f626}.cc-nav-item-icon{opacity:.75;flex-shrink:0;justify-content:center;align-items:center;width:16px;display:flex}.cc-nav-item.active .cc-nav-item-icon{opacity:1}.cc-nav-item-label{text-overflow:ellipsis;flex:1;overflow:hidden}.cc-sidebar-footer{background:#00000026;border-top:1px solid #ffffff0d;flex-shrink:0;padding:12px 14px}.cc-sidebar-user{align-items:center;gap:9px;display:flex}.cc-sidebar-avatar{color:#fff;background:linear-gradient(135deg,#3b82f6,#6366f1);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:12px;font-weight:700;display:flex;box-shadow:0 2px 8px #3b82f64d}.cc-sidebar-user-info{flex:1;min-width:0}.cc-sidebar-user-name{color:#e2e8f0;text-overflow:ellipsis;white-space:nowrap;font-size:12px;font-weight:600;overflow:hidden}.cc-sidebar-user-role{color:#4d6485;font-size:10.5px}.cc-sidebar-logout{color:#4d6485;cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;padding:5px;line-height:1;transition:color .15s,background .15s;display:flex}.cc-sidebar-logout:hover{color:#ef4444;background:#ef44441a}.cc-main{margin-left:var(--cc-sidebar-width);background-color:#eef2f7;background-image:linear-gradient(#3b82f606 1px,#0000 1px),linear-gradient(90deg,#3b82f606 1px,#0000 1px);background-position:0 0;background-repeat:repeat;background-size:36px 36px;background-attachment:scroll;background-origin:padding-box;background-clip:border-box;flex-direction:column;flex:1;min-height:100vh;display:flex}.cc-topbar{-webkit-backdrop-filter:blur(14px);height:var(--cc-topbar-h);z-index:100;background:#fffffff5;border-bottom:1px solid #3b82f614;flex-shrink:0;justify-content:space-between;align-items:center;padding:0 26px;display:flex;position:sticky;top:0;box-shadow:0 1px 8px #0000000d,0 0 0 1px #ffffffb3}.cc-topbar-left{flex-direction:column;justify-content:center;gap:2px;display:flex}.cc-topbar-title{color:#0f172a;letter-spacing:-.2px;font-size:17px;font-weight:700;line-height:1.2}.cc-topbar-subtitle{color:#64748b;font-size:12px;font-weight:400}.cc-topbar-right{align-items:center;gap:10px;display:flex}.cc-topbar-tag{letter-spacing:1px;text-transform:uppercase;color:var(--cc-blue);background:var(--cc-blue-light);border:1px solid #3b82f62e;border-radius:20px;padding:3px 10px;font-size:9.5px;font-weight:700}.cc-topbar-avatar{color:#fff;cursor:pointer;background:linear-gradient(135deg,#3b82f6,#6366f1);border:2px solid #3b82f633;border-radius:50%;justify-content:center;align-items:center;width:34px;height:34px;font-size:12px;font-weight:700;display:flex;box-shadow:0 2px 6px #3b82f633}.cc-privacy-btn{color:#64748b;cursor:pointer;background:0 0;border:1px solid #e2e8f0;border-radius:7px;align-items:center;padding:5px 9px;transition:border-color .15s,background .15s,color .15s;display:flex;position:relative}.cc-privacy-btn:hover{color:#16a34a;background:#f0fdf4;border-color:#86efac}.cc-privacy-tooltip{color:#f1f5f9;white-space:nowrap;z-index:999;pointer-events:none;font-size:11px;font-weight:500;font-family:var(--cc-font);background:#1e293b;border-radius:7px;padding:6px 12px;display:none;position:absolute;top:calc(100% + 8px);right:0;box-shadow:0 4px 12px #0003}.cc-privacy-btn:hover .cc-privacy-tooltip{display:block}.cc-page{flex:1;width:100%;max-width:1480px;padding:26px 28px}.cc-metric-grid{grid-template-columns:repeat(auto-fill,minmax(195px,1fr));gap:14px;margin-bottom:22px;display:grid}.cc-metric-card{border-radius:var(--cc-radius);box-shadow:var(--cc-card-shadow);cursor:default;background:#fff;border:1px solid #e2e8f0cc;flex-direction:column;gap:10px;padding:18px;transition:box-shadow .22s,transform .22s,border-color .22s;animation:.35s both cc-fade-up;display:flex;position:relative;overflow:hidden}.cc-metric-card:before{content:"";opacity:0;background:linear-gradient(90deg,#0000,#3b82f633,#0000);height:1px;transition:opacity .25s;position:absolute;top:0;left:0;right:0}.cc-metric-card:after{content:"";pointer-events:none;opacity:0;background:linear-gradient(135deg,#ffffff80 0%,#0000 60%);transition:opacity .25s;position:absolute;inset:0}.cc-metric-card:hover{box-shadow:var(--cc-card-hover-shadow);border-color:#3b82f626;transform:translateY(-2px)}.cc-metric-card:hover:before,.cc-metric-card:hover:after{opacity:1}.cc-metric-card[style*="3b82f6"]:hover{box-shadow:var(--cc-glow-blue), var(--cc-card-hover-shadow)}.cc-metric-card[style*="10b981"]:hover{box-shadow:var(--cc-glow-green), var(--cc-card-hover-shadow)}.cc-metric-card[style*=ef4444]:hover{box-shadow:var(--cc-glow-red), var(--cc-card-hover-shadow)}.cc-metric-card[style*=f59e0b]:hover{box-shadow:var(--cc-glow-amber), var(--cc-card-hover-shadow)}.cc-metric-card[style*="6366f1"]:hover{box-shadow:var(--cc-glow-purple), var(--cc-card-hover-shadow)}.cc-metric-card[style*="14b8a6"]:hover{box-shadow:var(--cc-glow-teal), var(--cc-card-hover-shadow)}.cc-metric-card.clickable{cursor:pointer}.cc-metric-grid .cc-metric-card:first-child{animation-delay:40ms}.cc-metric-grid .cc-metric-card:nth-child(2){animation-delay:70ms}.cc-metric-grid .cc-metric-card:nth-child(3){animation-delay:.1s}.cc-metric-grid .cc-metric-card:nth-child(4){animation-delay:.13s}.cc-metric-grid .cc-metric-card:nth-child(5){animation-delay:.16s}.cc-metric-grid .cc-metric-card:nth-child(6){animation-delay:.19s}.cc-metric-grid .cc-metric-card:nth-child(7){animation-delay:.22s}.cc-metric-grid .cc-metric-card:nth-child(8){animation-delay:.25s}.cc-metric-grid .cc-metric-card:nth-child(9){animation-delay:.28s}.cc-metric-grid .cc-metric-card:nth-child(10){animation-delay:.31s}.cc-metric-grid .cc-metric-card:nth-child(11){animation-delay:.34s}.cc-metric-grid .cc-metric-card:nth-child(12){animation-delay:.37s}.cc-metric-card .metric-header{justify-content:space-between;align-items:flex-start;display:flex}.cc-metric-card .metric-icon{border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;display:flex}.cc-metric-card .metric-trend{border-radius:20px;align-items:center;gap:3px;padding:3px 7px;font-size:11.5px;font-weight:600;display:flex}.cc-metric-card .metric-trend.up{color:#15803d;background:#dcfce7}.cc-metric-card .metric-trend.down{color:#dc2626;background:#fee2e2}.cc-metric-card .metric-value{color:#0f172a;letter-spacing:-.5px;font-size:26px;font-weight:800;line-height:1}.cc-metric-card .metric-label{color:#64748b;font-size:12.5px;font-weight:500;line-height:1.3}.cc-metric-card .metric-sub{color:#94a3b8;margin-top:2px;font-size:11px}.cc-section-card{border-radius:var(--cc-radius);background:#fff;border:1px solid #e2e8f0d9;margin-bottom:18px;transition:box-shadow .2s;animation:.3s both cc-fade-up;overflow:hidden;box-shadow:0 1px 4px #0000000f,0 1px 2px #0000000a}.cc-section-card:hover{box-shadow:0 4px 18px #00000014,0 1px 4px #0000000a}.cc-section-card.no-margin{margin-bottom:0}.cc-section-header{border-bottom:1px solid #f1f5f9;justify-content:space-between;align-items:center;gap:12px;padding:16px 20px 13px;display:flex}.cc-section-header-left{flex-direction:column;gap:2px;display:flex}.cc-section-title{color:#0f172a;font-size:14.5px;font-weight:700;line-height:1.2}.cc-section-subtitle{color:#64748b;font-size:12px;font-weight:400}.cc-section-body{padding:18px 20px}.cc-section-body.no-padding{padding:0}.cc-health-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:13px;display:grid}.cc-health-card{background:#fff;border:1px solid #f1f5f9;border-radius:10px;flex-direction:column;gap:9px;padding:15px;transition:box-shadow .2s,transform .2s;animation:.3s both cc-fade-up;display:flex;box-shadow:0 1px 2px #0000000a}.cc-health-card:hover{transform:translateY(-1px);box-shadow:0 4px 12px #00000014}.cc-health-card-header{justify-content:space-between;align-items:center;display:flex}.cc-health-icon{color:#64748b;align-items:center;display:flex}.cc-health-status{align-items:center;gap:5px;font-size:11px;font-weight:600;display:flex}.cc-health-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.cc-health-dot.healthy{background:var(--cc-green);animation:2.5s infinite cc-pulse-green;box-shadow:0 0 6px #10b98199}.cc-health-dot.warning{background:var(--cc-amber);animation:2.5s infinite cc-pulse-amber;box-shadow:0 0 6px #f59e0b99}.cc-health-dot.critical{background:var(--cc-red);animation:1.8s infinite cc-pulse-red;box-shadow:0 0 8px #ef4444b3}.cc-health-dot.unknown{background:#64748b}.cc-health-status.healthy{color:#15803d}.cc-health-status.warning{color:#92400e}.cc-health-status.critical{color:#dc2626}.cc-health-status.unknown{color:#64748b}.cc-health-label{color:#1e293b;font-size:12.5px;font-weight:600}.cc-health-value{color:#0f172a;font-size:20px;font-weight:800;line-height:1}.cc-health-detail{color:#94a3b8;font-size:11px}.cc-table-wrapper{border-radius:0 0 var(--cc-radius) var(--cc-radius);overflow-x:auto}.cc-table-wrapper table{border-collapse:collapse;width:100%;font-size:13px;font-family:var(--cc-font)}.cc-table-wrapper thead tr{background:#f8fafc;border-bottom:1px solid #e2e8f0}.cc-table-wrapper thead th{text-align:left;letter-spacing:.6px;text-transform:uppercase;color:#64748b;white-space:nowrap;z-index:1;background:#f8fafc;padding:10px 15px;font-size:10.5px;font-weight:700;position:sticky;top:0}.cc-table-wrapper tbody tr{border-bottom:1px solid #f1f5f9;transition:background .1s}.cc-table-wrapper tbody tr:last-child{border-bottom:none}.cc-table-wrapper tbody tr:hover{background:#f8fafc}.cc-table-wrapper tbody td{color:#1e293b;vertical-align:middle;padding:11px 15px}.cc-filter-bar{background:#fafbfc;border-bottom:1px solid #f1f5f9;flex-wrap:wrap;align-items:center;gap:10px;padding:14px 20px;display:flex}.cc-filter-search{background:#fff;border:1px solid #e2e8f0;border-radius:8px;flex:1;align-items:center;gap:8px;min-width:200px;max-width:300px;padding:6px 11px;transition:border-color .15s,box-shadow .15s;display:flex}.cc-filter-search:focus-within{border-color:var(--cc-blue);box-shadow:0 0 0 3px #3b82f61a}.cc-filter-search-icon{color:#94a3b8;flex-shrink:0;font-size:13px;display:flex}.cc-filter-search input{color:#1e293b;width:100%;font-size:13px;font-family:var(--cc-font);background:0 0;border:none;outline:none}.cc-filter-search input::placeholder{color:#94a3b8}.cc-filter-select{color:#374151;font-size:13px;font-family:var(--cc-font);cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:8px;outline:none;min-width:120px;padding:6px 10px;transition:border-color .15s}.cc-filter-select:focus{border-color:var(--cc-blue);box-shadow:0 0 0 3px #3b82f61a}.cc-badge{letter-spacing:.2px;white-space:nowrap;border-radius:20px;align-items:center;gap:4px;padding:2px 9px;font-size:11px;font-weight:600;line-height:1.5;display:inline-flex}.cc-badge-green{color:#059669;background:#10b9811a;border:1px solid #10b98147}.cc-badge-red{color:#dc2626;background:#ef44441a;border:1px solid #ef444447}.cc-badge-amber{color:#b45309;background:#f59e0b1a;border:1px solid #f59e0b47}.cc-badge-blue{color:#1d4ed8;background:#3b82f61a;border:1px solid #3b82f647}.cc-badge-purple{color:#4338ca;background:#6366f11a;border:1px solid #6366f147}.cc-badge-gray{color:#475569;background:#64748b14;border:1px solid #64748b33}.cc-badge-teal{color:#0f766e;background:#14b8a61a;border:1px solid #14b8a647}.cc-risk-low{color:#166534;background:#dcfce7;border:1px solid #bbf7d0}.cc-risk-medium{color:#92400e;background:#fef3c7;border:1px solid #fde68a}.cc-risk-high{color:#991b1b;background:#fee2e2;border:1px solid #fecaca}.cc-risk-critical{color:#7f1d1d;background:#fef2f2;border:1px solid #fca5a5;font-weight:700}.cc-tab-bar{scrollbar-width:none;background:#fff;border-bottom:1px solid #e2e8f0;flex-shrink:0;align-items:center;gap:2px;padding:0 20px;display:flex;overflow-x:auto}.cc-tab-bar::-webkit-scrollbar{display:none}.cc-tab{color:#64748b;cursor:pointer;white-space:nowrap;font-size:13px;font-weight:500;font-family:var(--cc-font);background:0 0;border:none;border-bottom:2px solid #0000;align-items:center;gap:6px;margin-bottom:-1px;padding:12px 14px 10px;transition:color .15s,border-color .15s;display:inline-flex}.cc-tab:hover{color:#334155}.cc-tab.active{color:var(--cc-blue);border-bottom-color:var(--cc-blue);font-weight:600}.cc-tab-count{color:#64748b;background:#f1f5f9;border-radius:10px;padding:1px 6px;font-size:10px;font-weight:700}.cc-tab.active .cc-tab-count{color:var(--cc-blue);background:#3b82f61f}.cc-placeholder-banner{color:#92400e;background:#fffbeb;border:1px solid #fde68a;border-radius:9px;align-items:center;gap:10px;margin-bottom:18px;padding:11px 15px;font-size:12.5px;font-weight:500;display:flex}.cc-placeholder-banner-icon{flex-shrink:0;align-items:center;display:flex}.cc-empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:10px;padding:52px 24px;display:flex}.cc-empty-state-icon{opacity:.35;justify-content:center;align-items:center;margin-bottom:4px;display:flex}.cc-empty-state-title{color:#1e293b;font-size:14.5px;font-weight:700}.cc-empty-state-message{color:#94a3b8;max-width:360px;font-size:13px;line-height:1.6}.cc-loading{background:linear-gradient(90deg,#f1f5f9 25%,#e2e8f0 50%,#f1f5f9 75%) 0 0/800px 100%;border-radius:6px;height:14px;animation:1.6s infinite cc-shimmer}.cc-loading-card{border-radius:var(--cc-radius);background:linear-gradient(90deg,#f1f5f9 25%,#e2e8f0 50%,#f1f5f9 75%) 0 0/800px 100%;height:96px;animation:1.6s infinite cc-shimmer}.cc-btn{font-size:13px;font-weight:600;font-family:var(--cc-font);cursor:pointer;white-space:nowrap;border:none;border-radius:8px;align-items:center;gap:6px;padding:7px 15px;line-height:1.4;text-decoration:none;transition:background .15s,box-shadow .15s,transform .1s;display:inline-flex}.cc-btn:disabled{opacity:.55;cursor:not-allowed;transform:none!important}.cc-btn:active:not(:disabled){transform:translateY(1px)}.cc-btn-primary{color:#fff;background:linear-gradient(135deg,#3b82f6 0%,#2563eb 100%);box-shadow:0 2px 8px #3b82f647}.cc-btn-primary:hover:not(:disabled){box-shadow:var(--cc-glow-blue);background:linear-gradient(135deg,#2563eb 0%,#1d4ed8 100%);transform:translateY(-1px)}.cc-btn-secondary{color:#374151;background:#f1f5f9;border:1px solid #e2e8f0}.cc-btn-secondary:hover:not(:disabled){background:#e2e8f0}.cc-btn-danger{color:#fff;background:#ef4444}.cc-btn-danger:hover:not(:disabled){background:#dc2626;box-shadow:0 4px 12px #ef444459}.cc-btn-success{color:#fff;background:#10b981}.cc-btn-success:hover:not(:disabled){background:#059669}.cc-btn-sm{border-radius:6px;padding:4px 10px;font-size:12px}.cc-action-btn{font-size:13px;font-weight:600;font-family:var(--cc-font);background:var(--cc-blue);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:8px;align-items:center;gap:6px;padding:6px 13px;line-height:1.4;text-decoration:none;transition:background .15s,box-shadow .15s,transform .1s;display:inline-flex}.cc-action-btn:hover{background:#2563eb;transform:translateY(-1px);box-shadow:0 3px 8px #3b82f64d}.cc-action-btn:active{transform:translateY(0)}.cc-action-btn-outline{color:var(--cc-blue);border:1px solid var(--cc-blue);background:0 0}.cc-action-btn-outline:hover{background:var(--cc-blue-light);box-shadow:none}.cc-action-btn-sm{padding:4px 10px;font-size:12px}.cc-action-btn-danger{background:var(--cc-red)}.cc-action-btn-danger:hover{background:#dc2626;box-shadow:0 3px 8px #ef44444d}.cc-action-btn-ghost{color:#64748b;background:0 0;border:1px solid #e2e8f0}.cc-action-btn-ghost:hover{color:#374151;box-shadow:none;background:#f8fafc}.cc-modal-overlay{z-index:1000;background:#0f172a8c;justify-content:center;align-items:center;padding:20px;animation:.15s cc-fade-in;display:flex;position:fixed;inset:0}.cc-modal-card{background:#fff;border-radius:14px;flex-direction:column;width:100%;max-width:520px;max-height:88vh;animation:.2s cc-fade-up;display:flex;overflow-y:auto;box-shadow:0 24px 64px #00000038}.cc-modal-header{border-bottom:1px solid #f1f5f9;justify-content:space-between;align-items:center;padding:18px 22px 14px;display:flex}.cc-modal-header h2{color:#0f172a;margin:0;font-size:15.5px;font-weight:700}.cc-modal-close{color:#94a3b8;cursor:pointer;background:0 0;border:none;border-radius:6px;align-items:center;padding:4px 6px;font-size:15px;line-height:1;transition:color .15s,background .15s;display:flex}.cc-modal-close:hover{color:#ef4444;background:#fee2e2}.cc-modal-body{flex-direction:column;flex:1;gap:11px;padding:18px 22px;display:flex}.cc-modal-row{border-bottom:1px solid #f8fafc;justify-content:space-between;align-items:center;padding:7px 0;font-size:13px;display:flex}.cc-modal-row span:first-child{color:#64748b;font-size:12px}.cc-modal-row span:last-child{color:#1e293b;text-align:right;font-weight:500}.cc-modal-footer{border-top:1px solid #f1f5f9;justify-content:flex-end;gap:10px;padding:14px 22px;display:flex}.cc-form-label{color:#374151;margin-bottom:4px;font-size:12px;font-weight:600;display:block}.cc-form-input{width:100%;font-size:13px;font-family:var(--cc-font);color:#1e293b;box-sizing:border-box;background:#fff;border:1px solid #e2e8f0;border-radius:8px;outline:none;margin-bottom:2px;padding:7px 11px;transition:border-color .15s,box-shadow .15s;display:block}.cc-form-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.cc-form-check{color:#374151;cursor:pointer;align-items:center;gap:8px;font-size:13px;display:flex}.cc-form-check input[type=checkbox]{cursor:pointer;width:15px;height:15px}.cc-form-group{flex-direction:column;gap:4px;display:flex}.cc-privacy-note,.cc-privacy-bar{color:#1e40af;background:#eff6ff;border:1px solid #bfdbfe;border-radius:9px;margin-bottom:18px;padding:10px 14px;font-size:12.5px}.cc-quick-links{grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:13px;display:grid}.cc-quick-link-card{border-radius:var(--cc-radius);text-align:center;background:#f8fafc;border:1px solid #e2e8f0cc;flex-direction:column;align-items:center;gap:7px;padding:18px 14px;text-decoration:none;transition:background .18s,box-shadow .18s,transform .18s,border-color .18s;display:flex}.cc-quick-link-card:hover{box-shadow:var(--cc-glow-blue), 0 4px 14px #0000000f;background:#eff6ffe6;border-color:#3b82f640;transform:translateY(-3px)}.cc-ql-icon{color:#3b82f6;align-items:center;display:flex}.cc-ql-label{color:#1e293b;font-size:13px;font-weight:700}.cc-ql-desc{color:#94a3b8;font-size:11px}.cc-page-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:22px;display:flex}.cc-page-title{color:#0f172a;letter-spacing:-.3px;font-size:20px;font-weight:800;line-height:1.2}.cc-page-subtitle{color:#64748b;margin-top:3px;font-size:13px}.cc-two-col{grid-template-columns:1fr 1fr;gap:18px;display:grid}.cc-three-col{grid-template-columns:1fr 1fr 1fr;gap:18px;display:grid}.cc-metric-grid-3{grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:18px;display:grid}.cc-metric-grid-4{grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:18px;display:grid}.cc-toggle-switch{width:38px;height:21px;display:inline-block;position:relative}.cc-toggle-switch input{opacity:0;width:0;height:0}.cc-toggle-slider{cursor:pointer;background:#e2e8f0;border-radius:21px;transition:background .2s;position:absolute;inset:0}.cc-toggle-slider:before{content:"";background:#fff;border-radius:50%;width:15px;height:15px;transition:transform .2s;position:absolute;bottom:3px;left:3px;box-shadow:0 1px 3px #0003}.cc-toggle-switch input:checked+.cc-toggle-slider{background:#3b82f6}.cc-toggle-switch input:checked+.cc-toggle-slider:before{transform:translate(17px)}.cc-status-banner{border:1px solid #0000;border-radius:9px;margin-bottom:18px;padding:11px 18px;font-size:13.5px;font-weight:600}.cc-storage-bar-wrap{padding:0 2px}.cc-storage-bar-track{background:#e2e8f0;border-radius:999px;height:10px;margin-bottom:7px;overflow:hidden}.cc-storage-bar-fill{border-radius:999px;height:100%;transition:width .5s}.cc-storage-bar-label{color:#64748b;font-size:12.5px}.cc-storage-stats{color:#374151;gap:24px;margin-top:11px;font-size:13px;display:flex}.cc-plans-grid{grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:18px;padding:18px 20px;display:grid}.cc-plan-card{background:#fff;border:1px solid #e2e8f0;border-radius:13px;flex-direction:column;transition:box-shadow .2s,transform .2s;display:flex;overflow:hidden}.cc-plan-card:hover{box-shadow:0 0 0 1px #3b82f64d, var(--cc-glow-blue), 0 8px 24px #00000014;transform:translateY(-3px)}.cc-plan-header{letter-spacing:-.3px;padding:18px 18px 3px;font-size:17px;font-weight:800}.cc-plan-price{color:#0f172a;padding:0 18px 4px;font-size:30px;font-weight:900;line-height:1.1}.cc-plan-price span{color:#94a3b8;font-size:13px;font-weight:400}.cc-plan-features{flex-direction:column;flex:1;gap:5px;margin:0;padding:10px 18px;list-style:none;display:flex}.cc-plan-features li{color:#374151;font-size:12.5px}.cc-plan-features li:before{content:"+ ";color:#10b981;font-weight:700}.cc-plan-footer{border-top:1px solid #f1f5f9;justify-content:space-between;align-items:center;padding:13px 18px;display:flex}.cc-gateway-grid{grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:14px;padding:4px 0;display:grid}.cc-gateway-card{border-radius:var(--cc-radius);background:#fff;border:1px solid #e2e8f0;flex-direction:column;gap:9px;padding:18px;transition:box-shadow .15s;display:flex}.cc-gateway-card:hover{box-shadow:0 4px 14px #00000012}.cc-gateway-name{color:#0f172a;font-size:15px;font-weight:700}.cc-gateway-stats{color:#374151;flex-direction:column;gap:4px;font-size:12.5px;display:flex}.cc-gateway-stats span{color:#0f172a;font-weight:600}.cc-reports-grid{grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:14px;padding:4px 0;display:grid}.cc-report-card{border-radius:var(--cc-radius);background:#fff;border:1px solid #e2e8f0;flex-direction:column;gap:9px;padding:18px;transition:box-shadow .15s;display:flex;position:relative}.cc-report-card:hover{box-shadow:0 4px 12px #00000012}.cc-report-name{color:#0f172a;font-size:14px;font-weight:700}.cc-report-desc{color:#64748b;flex:1;font-size:12.5px}.cc-report-actions{gap:8px;display:flex}.cc-coming-soon-badge{color:#94a3b8;letter-spacing:.4px;background:#f1f5f9;border-radius:999px;padding:2px 7px;font-size:9.5px;font-weight:600;position:absolute;top:11px;right:11px}.cc-retention-grid{grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:13px;padding:4px 0;display:grid}.cc-retention-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;flex-direction:column;gap:5px;padding:16px;display:flex}.cc-retention-type{color:#0f172a;font-size:13px;font-weight:700}.cc-retention-period{color:var(--cc-blue);text-shadow:0 0 12px #3b82f64d;font-size:20px;font-weight:800}.cc-retention-desc{color:#94a3b8;font-size:11px}.cc-flags-list{flex-direction:column;gap:10px;padding:4px 0;display:flex}.cc-flag-row{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;justify-content:space-between;align-items:center;gap:14px;padding:11px 14px;transition:background .12s;display:flex}.cc-flag-row:hover{background:#f1f5f9}.cc-flag-info{flex:1}.cc-flag-name{color:#0f172a;font-size:13.5px;font-weight:600}.cc-flag-desc{color:#64748b;margin-top:2px;font-size:12px}.cc-settings-form-preview{opacity:.6;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:13px;margin-top:14px;display:grid}.cc-chart-placeholder{text-align:center;color:#94a3b8;background:#f8fafc;border:2px dashed #e2e8f0;border-radius:10px;padding:44px 24px;font-size:13.5px}.cc-divider{background:#f1f5f9;height:1px;margin:14px 0}.cc-muted{color:#94a3b8;font-size:12px}.cc-sub-text{color:#94a3b8;font-size:11.5px}.cc-mono,.cc-text-mono{font-family:SF Mono,SFMono-Regular,Consolas,monospace;font-size:12px}.cc-link-btn{color:#3b82f6;font-size:13px;font-weight:600;text-decoration:none}.cc-link-btn:hover{text-decoration:underline}.cc-flex-between{justify-content:space-between;align-items:center;display:flex}.cc-flex-gap{align-items:center;gap:10px;display:flex}.cc-text-danger{color:#dc2626}.cc-bold{font-weight:700}.cc-placeholder-info{color:#94a3b8;padding:22px 0;font-size:13px}.cc-placeholder-info a{color:#3b82f6}.cc-refresh-indicator{color:#94a3b8;align-self:center;margin-left:auto;padding:0 4px;font-size:11.5px}.cc-health-detail-panel{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;flex-direction:column;gap:10px;padding:14px 18px;display:flex}.cc-health-detail-grid{color:#374151;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:8px;font-size:12.5px;display:grid}@media (width<=1200px){.cc-two-col,.cc-three-col{grid-template-columns:1fr}.cc-metric-grid-3,.cc-metric-grid-4{grid-template-columns:repeat(2,1fr)}}@media (width<=900px){.cc-metric-grid{grid-template-columns:repeat(auto-fill,minmax(155px,1fr))}.cc-page{padding:18px 14px}.cc-topbar{padding:0 16px}}@media (width<=768px){.cc-sidebar{transition:transform .25s;transform:translate(-100%)}.cc-sidebar.open{transform:translate(0)}.cc-main{margin-left:0}.cc-metric-grid-3,.cc-metric-grid-4{grid-template-columns:1fr}}@media (width<=640px){.cc-metric-grid{grid-template-columns:repeat(2,1fr)}}.cc-stat-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px;display:grid}.cc-stat-card{background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:14px 16px;box-shadow:0 1px 3px #0000000d}.cc-stat-label{color:#94a3b8;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;font-size:11px;font-weight:600}.cc-stat-value{color:#0f172a;align-items:center;font-size:14px;font-weight:600;display:flex}.cc-info-card{color:#334155;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:14px 16px;font-size:13px}.db-header{border-bottom:1px solid var(--color-border);flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:24px;padding-bottom:20px;display:flex}.db-breadcrumb{letter-spacing:1.5px;text-transform:uppercase;color:var(--color-text-muted);align-items:center;gap:6px;margin-bottom:8px;font-size:10px;font-weight:700;display:flex}.db-breadcrumb-sep{color:var(--color-border)}.db-title{color:var(--color-text);letter-spacing:-.6px;margin-bottom:8px;font-size:26px;font-weight:800;line-height:1}.db-meta{color:var(--color-text-muted);flex-wrap:wrap;align-items:center;gap:8px;font-size:12px;display:flex}.db-meta-sep{opacity:.4;background:currentColor;border-radius:50%;flex-shrink:0;width:3px;height:3px}.db-header-actions{flex-shrink:0;align-items:center;gap:8px;display:flex}.db-period-badge{border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-muted);font-size:11px;font-weight:600;font-family:var(--font-sans);background:#fff;padding:5px 12px}.db-refresh-btn{border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-muted);font-size:12px;font-weight:600;font-family:var(--font-sans);transition:var(--transition);cursor:pointer;background:#fff;align-items:center;gap:6px;padding:7px 14px;display:inline-flex}.db-refresh-btn:hover:not(:disabled){border-color:var(--color-green);color:var(--color-green)}.db-refresh-btn:disabled{opacity:.5;cursor:not-allowed}.db-actions-panel{border:1px solid var(--color-border);border-radius:var(--radius-lg);background:#fff;margin-bottom:16px;padding:14px 18px 16px}.db-actions-label{letter-spacing:1.2px;text-transform:uppercase;color:var(--color-text-muted);margin-bottom:10px;font-size:10px;font-weight:700}.db-actions-row{flex-wrap:wrap;gap:8px;display:flex}.db-action-btn{border-radius:var(--radius-md);font-size:13px;font-weight:600;font-family:var(--font-sans);transition:var(--transition);border:1px solid var(--color-border);color:var(--color-text);white-space:nowrap;background:#fff;align-items:center;gap:7px;padding:8px 16px;line-height:1;text-decoration:none;display:inline-flex}.db-action-btn:hover{background:#f8fafc;border-color:#b0bec5}.db-action-btn--primary{color:#fff;background:#0f172a;border-color:#0f172a}.db-action-btn--primary:hover{background:#1e293b;border-color:#1e293b}.db-alerts{flex-wrap:wrap;gap:10px;margin-bottom:16px;display:flex}.db-alert{border-radius:var(--radius-md);border:1px solid #0000;flex:1;align-items:flex-start;gap:10px;min-width:200px;max-width:380px;padding:10px 14px;display:flex}.db-alert--warning{color:#92400e;background:#fffbeb;border-color:#fde68a}.db-alert--danger{color:#991b1b;background:#fef2f2;border-color:#fecaca}.db-alert--info{color:#1e40af;background:#eff6ff;border-color:#bfdbfe}.db-alert-dot{border-radius:50%;flex-shrink:0;width:6px;height:6px;margin-top:5px}.db-alert--warning .db-alert-dot{background:#d97706}.db-alert--danger .db-alert-dot{background:#dc2626}.db-alert--info .db-alert-dot{background:#2563eb}.db-alert-title{margin-bottom:2px;font-size:12px;font-weight:700}.db-alert-msg{opacity:.85;font-size:11px;line-height:1.4}.db-metric-grid{grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:16px;display:grid}.db-metric{border:1px solid var(--color-border);border-radius:var(--radius-lg);background:#fff;padding:16px 16px 14px}.db-metric-icon{border-radius:7px;justify-content:center;align-items:center;width:30px;height:30px;margin-bottom:10px;display:flex}.db-metric-icon--blue{color:#2563eb;background:#dbeafe}.db-metric-icon--green{color:var(--color-green);background:#dcfce7}.db-metric-icon--amber{color:#d97706;background:#fef3c7}.db-metric-icon--red{color:#dc2626;background:#fee2e2}.db-metric-icon--purple{color:#7c3aed;background:#ede9fe}.db-metric-icon--teal{color:#0d9488;background:#ccfbf1}.db-metric-icon--slate{color:#475569;background:#f1f5f9}.db-metric-label{letter-spacing:1px;text-transform:uppercase;color:var(--color-text-muted);margin-bottom:4px;font-size:10px;font-weight:700}.db-metric-value{color:var(--color-text);letter-spacing:-.8px;font-size:26px;font-weight:800;line-height:1.1}.db-metric-value--green{color:var(--color-green)}.db-metric-value--amber{color:#d97706}.db-metric-value--red{color:#dc2626}.db-metric-sub{color:var(--color-text-muted);margin-top:3px;font-size:11px;line-height:1.3}.db-panels-row{grid-template-columns:1fr 1fr 1fr;gap:12px;margin-bottom:16px;display:grid}.db-panel{border:1px solid var(--color-border);border-radius:var(--radius-lg);background:#fff;overflow:hidden}.db-panel-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:11px 16px;display:flex}.db-panel-title{letter-spacing:1.2px;text-transform:uppercase;color:var(--color-text-muted);font-size:10px;font-weight:700}.db-panel-badge{border-radius:var(--radius-full);padding:2px 8px;font-size:10px;font-weight:700}.db-panel-body{padding:16px}.db-occ-rate{color:var(--color-green);letter-spacing:-2px;margin-bottom:4px;font-size:42px;font-weight:900;line-height:1}.db-occ-bar{background:var(--color-border);border-radius:3px;height:5px;margin:10px 0 12px;overflow:hidden}.db-occ-fill{background:var(--color-green);border-radius:3px;height:100%;transition:width .5s}.db-occ-stats{grid-template-columns:repeat(3,1fr);gap:6px;display:grid}.db-occ-stat{text-align:center;background:var(--color-bg);border-radius:6px;padding:8px 6px}.db-occ-stat-val{font-size:18px;font-weight:800;line-height:1}.db-occ-stat-lbl{color:var(--color-text-muted);margin-top:3px;font-size:10px}.db-coll-rate{letter-spacing:-2px;margin-bottom:4px;font-size:42px;font-weight:900;line-height:1}.db-coll-rows{margin-top:14px}.db-coll-row{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:9px 0;font-size:12px;display:flex}.db-coll-row:last-child{border-bottom:none}.db-coll-key{color:var(--color-text-muted)}.db-coll-val{color:var(--color-text);font-weight:700}.db-coll-val--green{color:var(--color-green)}.db-coll-val--amber{color:#d97706}.db-maint-rows{margin-top:4px}.db-maint-row{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:10px 0;font-size:12px;display:flex}.db-maint-row:last-child{border-bottom:none}.db-maint-key{color:var(--color-text-muted);align-items:center;gap:7px;display:flex}.db-maint-dot{border-radius:50%;flex-shrink:0;width:7px;height:7px}.db-maint-val{font-size:15px;font-weight:700}.db-payments-card{border:1px solid var(--color-border);border-radius:var(--radius-lg);background:#fff;margin-bottom:16px;overflow:hidden}.db-payments-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:11px 16px;display:flex}.db-payments-title{letter-spacing:1.2px;text-transform:uppercase;color:var(--color-text-muted);font-size:10px;font-weight:700}.db-table-wrap{overflow-x:auto}.db-table{border-collapse:collapse;width:100%;font-size:13px;font-family:var(--font-sans)}.db-table th{text-align:left;text-transform:uppercase;letter-spacing:.6px;color:var(--color-text-muted);border-bottom:1px solid var(--color-border);white-space:nowrap;background:#f8fafc;padding:10px 14px;font-size:10px;font-weight:700}.db-table td{color:var(--color-text);vertical-align:middle;border-bottom:1px solid #f1f5f9;padding:12px 14px}.db-table tr:last-child td{border-bottom:none}.db-table tbody tr:hover td{background:#f8fafc}.db-tenant-name{font-weight:600}.db-unit-badge{color:var(--color-text-muted);background:#f1f5f9;border-radius:4px;padding:2px 7px;font-family:Courier New,monospace;font-size:11px;display:inline-block}.db-prop-name{color:var(--color-text-muted);margin-top:2px;font-size:11px}.db-amount{font-variant-numeric:tabular-nums;font-weight:700}.db-method{color:var(--color-text-muted);text-transform:capitalize;font-size:11px}.db-status-badge{border-radius:var(--radius-full);white-space:nowrap;align-items:center;padding:2px 8px;font-size:10px;font-weight:700;display:inline-flex}.db-status--completed{color:#166534;background:#dcfce7}.db-status--pending{color:#92400e;background:#fef3c7}.db-status--failed{color:#991b1b;background:#fee2e2}.db-status--other{color:#475569;background:#f1f5f9}.db-date{color:var(--color-text-muted);white-space:nowrap;font-size:11px}.db-empty-payments{text-align:center;color:var(--color-text-muted);padding:40px;font-size:13px}@media (width<=1100px){.db-metric-grid{grid-template-columns:repeat(4,1fr)}}@media (width<=960px){.db-panels-row{grid-template-columns:1fr 1fr}}@media (width<=900px){.db-metric-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=640px){.db-panels-row{grid-template-columns:1fr}.db-alerts{flex-direction:column}.db-alert{max-width:100%}.db-action-btn{padding:7px 12px;font-size:12px}}@media (width<=480px){.db-metric-grid{grid-template-columns:1fr 1fr}.db-title{font-size:20px}}.investor-dashboard{flex-direction:column;gap:28px;display:flex}.investor-hero{border-radius:var(--radius-lg,16px);color:#fff;background:linear-gradient(135deg,#1e3a5f 0%,#0d2547 100%);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:20px 24px;display:flex}.investor-hero-title{letter-spacing:-.2px;margin:0 0 4px;font-size:18px;font-weight:700}.investor-hero-sub{color:#ffffffb8;margin:0;font-size:13px}.investor-hero-period{align-items:center;gap:8px;display:flex}.investor-period-label{color:#ffffffa6;font-size:12px}.investor-period-select{color:#fff;cursor:pointer;background:#ffffff1f;border:1px solid #ffffff40;border-radius:6px;padding:5px 10px;font-family:inherit;font-size:13px}.investor-period-select option{color:#1e293b;background:#fff}.investor-metric-grid{grid-template-columns:repeat(4,1fr);gap:16px;display:grid}@media (width<=1100px){.investor-metric-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=600px){.investor-metric-grid{grid-template-columns:1fr}}.investor-metric-card{border-radius:var(--radius-md,10px);background:#fff;border:1px solid #e2e8f0;flex-direction:column;gap:8px;padding:18px 20px;transition:box-shadow .15s;display:flex;position:relative;overflow:hidden}.investor-metric-card:hover{box-shadow:0 4px 16px #00000014}.investor-metric-card:before{content:"";background:var(--investor-card-accent,#e2e8f0);border-radius:3px 0 0 3px;width:3px;position:absolute;top:0;bottom:0;left:0}.investor-metric-card--blue:before{background:#1e3a5f}.investor-metric-card--green:before{background:#10b981}.investor-metric-card--amber:before{background:#f59e0b}.investor-metric-card--red:before{background:#ef4444}.investor-metric-card--teal:before{background:#0ea5e9}.investor-metric-card--gray:before{background:#94a3b8}.investor-metric-header{justify-content:space-between;align-items:center;display:flex}.investor-metric-label{text-transform:uppercase;letter-spacing:.5px;color:#64748b;font-size:11.5px;font-weight:600}.investor-metric-icon{color:#fff;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.investor-metric-icon--blue{background:#1e3a5f}.investor-metric-icon--green{background:#10b981}.investor-metric-icon--amber{background:#f59e0b}.investor-metric-icon--red{background:#ef4444}.investor-metric-icon--teal{background:#0ea5e9}.investor-metric-icon--gray{background:#94a3b8}.investor-metric-value{color:#1e293b;letter-spacing:-.5px;font-size:22px;font-weight:700;line-height:1.1}.investor-metric-sub{color:#94a3b8;font-size:11px}.investor-metric-sub--up{color:#10b981}.investor-metric-sub--down{color:#ef4444}.investor-section{flex-direction:column;gap:16px;display:flex}.investor-section-title{color:#1e293b;border-bottom:2px solid #f1f5f9;margin:0;padding-bottom:8px;font-size:14px;font-weight:700}.investor-charts-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}@media (width<=900px){.investor-charts-row{grid-template-columns:1fr}}.investor-chart-card{border-radius:var(--radius-md,10px);background:#fff;border:1px solid #e2e8f0;padding:20px}.investor-chart-title{color:#1e293b;margin:0 0 16px;font-size:13px;font-weight:600}.investor-table-card{border-radius:var(--radius-md,10px);background:#fff;border:1px solid #e2e8f0;overflow:hidden}.investor-table-header{border-bottom:1px solid #f1f5f9;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.investor-table-title{color:#1e293b;margin:0;font-size:13px;font-weight:700}.investor-table-wrap{overflow-x:auto}.investor-table{border-collapse:collapse;width:100%;font-size:13px}.investor-table th{text-align:left;text-transform:uppercase;letter-spacing:.5px;color:#64748b;white-space:nowrap;background:#f8fafc;border-bottom:1px solid #e2e8f0;padding:10px 14px;font-size:11px;font-weight:700}.investor-table td{color:#334155;vertical-align:middle;border-bottom:1px solid #f1f5f9;padding:12px 14px}.investor-table tr:last-child td{border-bottom:none}.investor-table tr:hover td{background:#f8fafc}.investor-table .prop-name{color:#1e293b;font-weight:600}.investor-occ-bar-wrap{align-items:center;gap:8px;min-width:100px;display:flex}.investor-occ-bar{background:#e2e8f0;border-radius:3px;flex:1;height:5px;overflow:hidden}.investor-occ-bar-fill{background:#10b981;border-radius:3px;height:100%;transition:width .4s}.investor-occ-bar-fill--low{background:#ef4444}.investor-occ-bar-fill--mid{background:#f59e0b}.investor-occ-bar-fill--good{background:#10b981}.investor-occ-pct{color:#475569;white-space:nowrap;font-size:12px;font-weight:600}.investor-action-wrap{position:relative}.investor-action-btn{color:#475569;cursor:pointer;white-space:nowrap;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:6px;padding:5px 12px;font-family:inherit;font-size:12px;font-weight:500;transition:background .12s}.investor-action-btn:hover{background:#e2e8f0}.investor-action-menu{z-index:100;background:#fff;border:1px solid #e2e8f0;border-radius:8px;min-width:160px;position:absolute;top:calc(100% + 4px);right:0;overflow:hidden;box-shadow:0 8px 24px #0000001a}.investor-action-item{text-align:left;color:#334155;cursor:pointer;background:0 0;border:none;width:100%;padding:9px 14px;font-family:inherit;font-size:13px;transition:background .1s;display:block}.investor-action-item:hover{color:#1e293b;background:#f8fafc}.investor-filter-row{flex-wrap:wrap;align-items:flex-end;gap:10px;display:flex}.investor-filter-group{flex-direction:column;gap:4px;display:flex}.investor-filter-label{color:#64748b;text-transform:uppercase;letter-spacing:.4px;font-size:11px;font-weight:600}.investor-filter-input,.investor-filter-select{color:#1e293b;background:#fff;border:1px solid #e2e8f0;border-radius:7px;min-width:130px;padding:7px 10px;font-family:inherit;font-size:13px}.investor-filter-input:focus,.investor-filter-select:focus{border-color:#1e3a5f;outline:none}.investor-summary-cards{grid-template-columns:repeat(4,1fr);gap:12px;display:grid}@media (width<=900px){.investor-summary-cards{grid-template-columns:repeat(2,1fr)}}.investor-summary-card{border-radius:var(--radius-md,10px);text-align:center;background:#fff;border:1px solid #e2e8f0;padding:16px 18px}.investor-summary-card-val{color:#1e293b;margin-bottom:4px;font-size:20px;font-weight:700}.investor-summary-card-lbl{color:#64748b;text-transform:uppercase;letter-spacing:.4px;font-size:11px;font-weight:600}.inv-badge--paid{color:#065f46;background:#d1fae5}.inv-badge--partial{color:#92400e;background:#fef3c7}.inv-badge--overdue{color:#991b1b;background:#fee2e2}.inv-badge--issued{color:#1e40af;background:#dbeafe}.inv-badge--draft{color:#475569;background:#f1f5f9}.inv-badge--cancelled{color:#94a3b8;background:#f1f5f9}.investor-prop-hero{border-radius:var(--radius-md,10px);background:#fff;border:1px solid #e2e8f0;flex-wrap:wrap;align-items:flex-start;gap:20px;padding:24px;display:flex}.investor-prop-image{object-fit:cover;background:#f1f5f9;border-radius:10px;flex-shrink:0;width:100px;height:80px}.investor-prop-image-placeholder{color:#94a3b8;background:linear-gradient(135deg,#e2e8f0 0%,#f8fafc 100%);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:100px;height:80px;font-size:24px;display:flex}.investor-prop-info{flex:1;min-width:180px}.investor-prop-name{color:#1e293b;margin:0 0 4px;font-size:20px;font-weight:700}.investor-prop-type{color:#64748b;text-transform:capitalize;margin:0 0 8px;font-size:12px}.investor-prop-addr{color:#475569;margin:0;font-size:13px}.investor-empty{text-align:center;color:#94a3b8;padding:48px 24px}.investor-empty-title{color:#475569;margin:0 0 6px;font-size:15px;font-weight:600}.investor-empty-body{margin:0;font-size:13px}.investor-back{color:#475569;align-items:center;gap:6px;margin-bottom:4px;font-size:13px;font-weight:500;text-decoration:none;display:inline-flex}.investor-back:hover{color:#1e3a5f}.zola-fab{z-index:9999;color:#fff;cursor:pointer;background:linear-gradient(135deg,#2563eb 0%,#1d4ed8 100%);border:none;border-radius:50px;align-items:center;gap:8px;padding:12px 18px;font-family:inherit;font-size:14px;font-weight:600;transition:transform .15s,box-shadow .15s;display:flex;position:fixed;bottom:28px;right:28px;box-shadow:0 4px 20px #2563eb66}.zola-fab:hover{transform:translateY(-2px);box-shadow:0 6px 24px #2563eb80}.zola-fab-dot{background:#4ade80;border-radius:50%;flex-shrink:0;width:8px;height:8px}.zola-panel{z-index:9998;background:#fff;border-radius:16px;flex-direction:column;width:360px;max-width:calc(100vw - 32px);animation:.2s zola-slide-up;display:flex;position:fixed;bottom:88px;right:28px;overflow:hidden;box-shadow:0 8px 40px #0000002e,0 2px 8px #00000014}@keyframes zola-slide-up{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.zola-header{color:#fff;background:linear-gradient(135deg,#2563eb 0%,#1d4ed8 100%);align-items:center;gap:10px;padding:14px 16px;display:flex}.zola-header-avatar{background:#fff3;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:16px;font-weight:700;display:flex}.zola-header-info{flex:1}.zola-header-name{font-size:14px;font-weight:700}.zola-header-status{opacity:.85;font-size:11px}.zola-close-btn{color:#fff;cursor:pointer;background:#ffffff26;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:16px;line-height:1;transition:background .15s;display:flex}.zola-close-btn:hover{background:#ffffff4d}.zola-messages{flex-direction:column;flex:1;gap:10px;min-height:180px;max-height:360px;padding:16px;display:flex;overflow-y:auto}.zola-bubble{word-break:break-word;border-radius:14px;max-width:88%;padding:9px 13px;font-size:13.5px;line-height:1.5}.zola-bubble--bot{color:#1e293b;background:#f1f5f9;border-bottom-left-radius:4px;align-self:flex-start}.zola-bubble--user{color:#fff;background:#2563eb;border-bottom-right-radius:4px;align-self:flex-end}.zola-bubble--typing{color:#64748b;background:#f1f5f9;align-self:flex-start;font-size:13px;font-style:italic}.zola-typing-dots{align-items:center;gap:3px;display:inline-flex}.zola-typing-dots span{background:#94a3b8;border-radius:50%;width:6px;height:6px;animation:1.2s ease-in-out infinite zola-dot-bounce}.zola-typing-dots span:nth-child(2){animation-delay:.2s}.zola-typing-dots span:nth-child(3){animation-delay:.4s}@keyframes zola-dot-bounce{0%,80%,to{opacity:.5;transform:scale(.8)}40%{opacity:1;transform:scale(1.1)}}.zola-error{color:#dc2626;text-align:center;background:#fef2f2;border-radius:8px;padding:8px 12px;font-size:12px}.zola-input-bar{background:#fafafa;border-top:1px solid #e5e7eb;align-items:flex-end;gap:8px;padding:12px 14px;display:flex}.zola-input{resize:none;background:#fff;border:1px solid #d1d5db;border-radius:20px;outline:none;flex:1;max-height:100px;padding:9px 14px;font-family:inherit;font-size:13.5px;transition:border-color .15s}.zola-input:focus{border-color:#2563eb}.zola-send-btn{color:#fff;cursor:pointer;background:#2563eb;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;transition:background .15s,transform .1s;display:flex}.zola-send-btn:hover:not(:disabled){background:#1d4ed8;transform:scale(1.05)}.zola-send-btn:disabled{cursor:not-allowed;background:#93c5fd}.zola-suggestions{background:#fafafa;border-top:1px solid #f1f5f9;flex-wrap:wrap;gap:6px;padding:8px 14px 10px;display:flex}.zola-chip{color:#1d4ed8;cursor:pointer;white-space:nowrap;background:#eff6ff;border:1px solid #bfdbfe;border-radius:20px;padding:5px 11px;font-family:inherit;font-size:12px;transition:background .15s,border-color .15s}.zola-chip:hover:not(:disabled){background:#dbeafe;border-color:#93c5fd}.zola-chip:disabled{opacity:.5;cursor:not-allowed}.zola-lead-card{background:#f8faff;border:1px solid #bfdbfe;border-radius:12px;align-self:flex-start;max-width:96%;margin:2px 0;padding:14px}.zola-lead-card-title{color:#1e293b;margin-bottom:2px;font-size:13.5px;font-weight:700}.zola-lead-card-sub{color:#64748b;margin-bottom:10px;font-size:12px}.zola-lead-form{flex-direction:column;gap:7px;display:flex}.zola-lead-input{background:#fff;border:1px solid #d1d5db;border-radius:8px;outline:none;padding:7px 10px;font-family:inherit;font-size:13px;transition:border-color .15s}.zola-lead-input:focus{border-color:#2563eb}.zola-lead-error{color:#dc2626;font-size:12px}.zola-lead-actions{gap:8px;margin-top:4px;display:flex}.zola-lead-submit{color:#fff;cursor:pointer;background:#2563eb;border:none;border-radius:8px;padding:7px 16px;font-family:inherit;font-size:13px;font-weight:600;transition:background .15s}.zola-lead-submit:hover:not(:disabled){background:#1d4ed8}.zola-lead-submit:disabled{cursor:not-allowed;background:#93c5fd}.zola-lead-dismiss{cursor:pointer;color:#64748b;background:0 0;border:1px solid #d1d5db;border-radius:8px;padding:7px 12px;font-family:inherit;font-size:13px;transition:border-color .15s}.zola-lead-dismiss:hover{border-color:#94a3b8}.zola-bubble-wrap{flex-direction:column;display:flex}.zola-bubble-wrap--user{align-items:flex-end}.zola-bubble-wrap--bot{align-items:flex-start}.zola-feedback-row{flex-wrap:wrap;align-items:center;gap:6px;margin-top:4px;display:flex}.zola-feedback-label{color:#94a3b8;font-size:11px}.zola-feedback-btn{cursor:pointer;color:#64748b;background:#fff;border:1px solid #e2e8f0;border-radius:20px;align-items:center;gap:3px;padding:3px 8px;font-family:inherit;font-size:11px;transition:background .12s,border-color .12s;display:inline-flex}.zola-feedback-btn--yes:hover{color:#065f46;background:#d1fae5;border-color:#6ee7b7}.zola-feedback-btn--no:hover{color:#991b1b;background:#fee2e2;border-color:#fca5a5}.zola-feedback-btn:disabled{opacity:.5;cursor:not-allowed}.zola-feedback-thanks{color:#64748b;margin-top:4px;font-size:11.5px;font-style:italic}@media (width<=480px){.zola-fab{padding:11px 14px;font-size:13px;bottom:16px;right:16px}.zola-panel{border-radius:14px;width:auto;max-width:none;bottom:72px;left:12px;right:12px}.zola-messages{max-height:280px}.zola-chip{padding:4px 9px;font-size:11.5px}}.invd-page{max-width:960px;padding:24px}.invd-back-btn{cursor:pointer;color:#6b7280;background:0 0;border:none;align-items:center;gap:6px;margin-bottom:20px;padding:0;font-size:13px;transition:color .15s;display:inline-flex}.invd-back-btn:hover{color:#111827}.invd-header{background:#fff;border:1px solid #e5e7eb;border-radius:10px;flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:20px;margin-bottom:20px;padding:20px 24px;display:flex}.invd-header-left{flex:1;min-width:200px}.invd-number{color:#111827;margin-bottom:6px;font-family:monospace;font-size:20px;font-weight:700}.invd-meta{color:#6b7280;margin-top:4px;font-size:12px}.invd-badges{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.invd-actions{flex-wrap:wrap;align-items:flex-start;gap:8px;display:flex}.invd-info-grid{grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px;display:grid}@media (width<=600px){.invd-info-grid{grid-template-columns:1fr}}.invd-card{background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:16px 20px}.invd-card-title{text-transform:uppercase;letter-spacing:.05em;color:#9ca3af;margin-bottom:10px;font-size:11px;font-weight:600}.invd-card-row{justify-content:space-between;padding:3px 0;font-size:13px;display:flex}.invd-card-label{color:#6b7280}.invd-card-value{color:#111827;font-weight:500}.invd-section{background:#fff;border:1px solid #e5e7eb;border-radius:10px;margin-bottom:20px;overflow:hidden}.invd-section-header{color:#111827;border-bottom:1px solid #f3f4f6;justify-content:space-between;align-items:center;padding:12px 20px;font-size:13px;font-weight:600;display:flex}.invd-section-body{padding:0}.invd-table{border-collapse:collapse;width:100%;font-size:13px}.invd-table th{text-align:left;text-transform:uppercase;letter-spacing:.04em;color:#6b7280;white-space:nowrap;background:#f9fafb;border-bottom:1px solid #e5e7eb;padding:8px 14px;font-size:11px;font-weight:600}.invd-table td{vertical-align:middle;color:#111827;border-bottom:1px solid #f3f4f6;padding:10px 14px}.invd-table tr:last-child td{border-bottom:none}.invd-table .num{text-align:right;font-variant-numeric:tabular-nums}.invd-totals{border-top:1px solid #f3f4f6;flex-direction:column;align-items:flex-end;gap:6px;padding:16px 20px;display:flex}.invd-total-row{justify-content:flex-end;gap:24px;min-width:280px;font-size:13px;display:flex}.invd-total-label{color:#6b7280;text-align:right;flex:1}.invd-total-val{color:#111827;font-variant-numeric:tabular-nums;text-align:right;min-width:110px}.invd-total-row--grand .invd-total-label,.invd-total-row--grand .invd-total-val{color:#111827;font-size:15px;font-weight:700}.invd-total-row--balance .invd-total-val{color:#dc2626;font-weight:700}.invd-total-row--balance.invd-settled .invd-total-val{color:#16a34a}.invd-total-divider{background:#e5e7eb;width:280px;height:1px;margin:4px 0}.invd-tax-chip{color:#0369a1;background:#f0f9ff;border-radius:4px;padding:1px 6px;font-family:monospace;font-size:10px;font-weight:600;display:inline-block}.invd-cancel-form{margin-top:12px}.invd-cancel-warning{color:#991b1b;background:#fef2f2;border:1px solid #fecaca;border-radius:6px;margin-bottom:14px;padding:10px 14px;font-size:13px}.invd-empty{text-align:center;color:#9ca3af;padding:24px;font-size:13px}.invd-loading{text-align:center;color:#6b7280;padding:60px;font-size:14px}.invd-badge{border-radius:12px;padding:3px 10px;font-size:11px;font-weight:600;display:inline-block}.invd-badge--draft{color:#374151;background:#f3f4f6}.invd-badge--issued{color:#1e40af;background:#dbeafe}.invd-badge--partial{color:#92400e;background:#fef3c7}.invd-badge--paid{color:#15803d;background:#dcfce7}.invd-badge--overdue{color:#991b1b;background:#fee2e2}.invd-badge--cancelled{color:#92400e;background:#fef3c7}.invd-badge--archived{color:#9ca3af;background:#f3f4f6}.invd-badge--etims-ns{color:#6b7280;background:#f3f4f6}.invd-badge--etims-ok{color:#15803d;background:#dcfce7}.invd-badge--etims-err{color:#dc2626;background:#fee2e2}.cn-section .invd-section-header{background:#fffbeb;border-bottom-color:#fde68a}.cn-credited-badge{color:#991b1b;background:#fee2e2;border-radius:10px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-block}.cn-create-btn{padding:4px 12px;font-size:12px}.cn-effective-bar{color:#374151;background:#fefce8;border-bottom:1px solid #fde68a;flex-wrap:wrap;align-items:center;gap:8px;padding:10px 20px;font-size:12px;display:flex}.cn-sep{color:#9ca3af;font-weight:700}.cn-num-link{cursor:pointer;color:#2563eb;background:0 0;border:none;padding:0;font-family:monospace;font-size:12px;font-weight:600;text-decoration:underline}.cn-num-link:hover{color:#1d4ed8}.cn-badge{white-space:nowrap;border-radius:10px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-block}.cn-badge--draft{color:#374151;background:#f3f4f6}.cn-badge--issued{color:#15803d;background:#dcfce7}.cn-badge--cancelled{color:#991b1b;background:#fee2e2}.cn-modal-warning{color:#92400e;background:#fffbeb;border:1px solid #fde68a;border-radius:6px;margin-bottom:14px;padding:10px 14px;font-size:12px;line-height:1.5}.cn-type-row{flex-wrap:wrap;gap:8px;display:flex}.cn-type-btn{cursor:pointer;color:#374151;background:#fff;border:1px solid #d1d5db;border-radius:6px;padding:5px 14px;font-size:12px;transition:all .12s}.cn-type-btn:hover{border-color:#6b7280}.cn-type-btn--active{color:#1d4ed8;background:#eff6ff;border-color:#2563eb;font-weight:600}.cn-lines-table{border-collapse:collapse;width:100%;margin-bottom:4px;font-size:12px}.cn-lines-table th{text-align:left;text-transform:uppercase;letter-spacing:.04em;color:#6b7280;background:#f9fafb;border-bottom:1px solid #e5e7eb;padding:4px 6px;font-size:10px;font-weight:600}.cn-lines-table td{vertical-align:middle;border-bottom:1px solid #f3f4f6;padding:4px}.cn-num-input{text-align:right;width:70px}.cn-remove-line{cursor:pointer;color:#dc2626;background:0 0;border:none;padding:0 4px;font-size:16px;line-height:1}.cn-remove-line:hover{color:#991b1b}.cn-preview-box{background:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;margin-top:12px;padding:12px 16px}.cn-preview-row{color:#374151;justify-content:space-between;padding:3px 0;font-size:12px;display:flex}.cn-preview-row--total{font-weight:600}.cn-preview-divider{background:#e5e7eb;height:1px;margin:6px 0}.cn-preview-row--balance{color:#111827;font-size:13px;font-weight:700}.cnd-page{max-width:840px;padding:24px}.cnd-back-btn{cursor:pointer;color:#6b7280;background:0 0;border:none;align-items:center;gap:6px;margin-bottom:20px;padding:0;font-size:13px;transition:color .15s;display:inline-flex}.cnd-back-btn:hover{color:#111827}.cnd-header{background:#fff;border:1px solid #e5e7eb;border-radius:10px;flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:20px;margin-bottom:20px;padding:20px 24px;display:flex}.cnd-number{color:#111827;margin-bottom:6px;font-family:monospace;font-size:18px;font-weight:700}.cnd-meta{color:#6b7280;margin-top:4px;font-size:12px}.cnd-badges{flex-wrap:wrap;gap:8px;margin-top:10px;display:flex}.cnd-actions{flex-wrap:wrap;align-items:flex-start;gap:8px;display:flex}.cnd-info-grid{grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px;display:grid}@media (width<=600px){.cnd-info-grid{grid-template-columns:1fr}}.cnd-card{background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:16px 20px}.cnd-card-title{text-transform:uppercase;letter-spacing:.05em;color:#9ca3af;margin-bottom:10px;font-size:11px;font-weight:600}.cnd-card-row{justify-content:space-between;padding:3px 0;font-size:13px;display:flex}.cnd-card-label{color:#6b7280}.cnd-card-value{color:#111827;font-weight:500}.cnd-section{background:#fff;border:1px solid #e5e7eb;border-radius:10px;margin-bottom:20px;overflow:hidden}.cnd-section-header{color:#111827;border-bottom:1px solid #f3f4f6;justify-content:space-between;align-items:center;padding:12px 20px;font-size:13px;font-weight:600;display:flex}.cnd-totals{border-top:1px solid #f3f4f6;flex-direction:column;align-items:flex-end;gap:6px;padding:16px 20px;display:flex}.cnd-total-row{justify-content:flex-end;gap:24px;min-width:260px;font-size:13px;display:flex}.cnd-total-label{color:#6b7280;text-align:right;flex:1}.cnd-total-val{color:#111827;font-variant-numeric:tabular-nums;text-align:right;min-width:100px}.cnd-total-row--grand .cnd-total-label,.cnd-total-row--grand .cnd-total-val{color:#dc2626;font-size:15px;font-weight:700}.cnd-total-divider{background:#e5e7eb;width:260px;height:1px;margin:4px 0}.cnd-loading{text-align:center;color:#6b7280;padding:60px;font-size:14px}.cnd-inv-link{color:#2563eb;cursor:pointer;font-family:monospace;text-decoration:underline}.tsp-page{max-width:1100px;padding:24px}.tsp-back-btn{cursor:pointer;color:#6b7280;background:0 0;border:none;align-items:center;gap:6px;margin-bottom:16px;padding:0;font-size:13px;transition:color .15s;display:inline-flex}.tsp-back-btn:hover{color:#111827}.tsp-page-title{color:#111827;margin-bottom:4px;font-size:20px;font-weight:700}.tsp-page-sub{color:#6b7280;margin-bottom:20px;font-size:13px}.tsp-period-card{background:#fff;border:1px solid #e5e7eb;border-radius:10px;margin-bottom:20px;padding:16px 20px}.tsp-period-row{flex-wrap:wrap;align-items:flex-end;gap:12px;display:flex}.tsp-field-group{flex-direction:column;gap:4px;display:flex}.tsp-field-label{color:#6b7280;text-transform:uppercase;letter-spacing:.04em;font-size:11px;font-weight:600}.tsp-field-input{color:#374151;background:#fff;border:1px solid #d1d5db;border-radius:6px;min-width:150px;height:36px;padding:0 10px;font-size:13px}.tsp-field-input:focus{border-color:#2563eb;outline:none;box-shadow:0 0 0 2px #2563eb1f}.tsp-load-btn{height:36px}.tsp-inline-error{color:#dc2626;background:#fef2f2;border:1px solid #fecaca;border-radius:6px;margin-top:10px;padding:6px 10px;font-size:12px}.tsp-tenant-card{background:#fff;border:1px solid #e5e7eb;border-radius:10px;flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:16px;padding:16px 20px;display:flex}.tsp-tenant-name{color:#111827;margin-bottom:3px;font-size:16px;font-weight:700}.tsp-tenant-sub{color:#6b7280;margin-bottom:2px;font-size:12px}.tsp-tenant-code{color:#374151;background:#f3f4f6;border-radius:4px;margin-top:4px;padding:2px 7px;font-family:monospace;font-size:11px;display:inline-block}.tsp-period-label{color:#6b7280;white-space:nowrap;background:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;padding:6px 12px;font-size:12px}.tsp-summary-row{grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px;display:grid}@media (width<=700px){.tsp-summary-row{grid-template-columns:repeat(2,1fr)}}.tsp-sum-card{text-align:center;background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:14px 16px}.tsp-sum-label{text-transform:uppercase;letter-spacing:.05em;color:#9ca3af;margin-bottom:6px;font-size:10px;font-weight:600}.tsp-sum-value{color:#111827;font-size:17px;font-weight:700}.tsp-sum-value--green{color:#16a34a}.tsp-sum-value--amber{color:#d97706}.tsp-sum-value--red{color:#dc2626}.tsp-table-card{background:#fff;border:1px solid #e5e7eb;border-radius:10px;margin-bottom:20px;overflow:hidden}.tsp-table-header{color:#111827;border-bottom:1px solid #f3f4f6;justify-content:space-between;align-items:center;padding:12px 20px;font-size:13px;font-weight:600;display:flex}.tsp-table-count{color:#6b7280;font-size:12px;font-weight:400}.tsp-empty{text-align:center;color:#9ca3af;padding:40px 24px;font-size:13px}.tsp-table-wrap{overflow-x:auto}.tsp-table{border-collapse:collapse;width:100%;font-size:13px}.tsp-table th{text-align:left;text-transform:uppercase;letter-spacing:.05em;color:#9ca3af;white-space:nowrap;background:#f9fafb;border-bottom:1px solid #e5e7eb;padding:10px 12px;font-size:10px;font-weight:700}.tsp-table th.num{text-align:right}.tsp-table td{color:#374151;vertical-align:middle;border-bottom:1px solid #f9fafb;padding:10px 12px}.tsp-table td.num{text-align:right;font-variant-numeric:tabular-nums;white-space:nowrap}.tsp-table tr:last-child td{border-bottom:none}.tsp-table tr:hover td{background:#fafafa}.tsp-ref{color:#374151;font-family:monospace;font-size:12px}.tsp-date{white-space:nowrap;color:#6b7280;font-size:12px}.tsp-amount{font-weight:600}.tsp-amount--ok{color:#16a34a}.tsp-amount--dim{color:#9ca3af}.tsp-badge{white-space:nowrap;border-radius:99px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-block}.tsp-badge--completed{color:#166534;background:#dcfce7}.tsp-badge--pending{color:#854d0e;background:#fef9c3}.tsp-badge--cancelled,.tsp-badge--failed{color:#991b1b;background:#fee2e2}.tsp-badge--reversed,.tsp-badge--default{color:#6b7280;background:#f3f4f6}.tsp-actions{flex-wrap:wrap;gap:6px;display:flex}.tsp-action-btn{color:#374151;cursor:pointer;background:0 0;border:1px solid #d1d5db;border-radius:5px;padding:3px 10px;font-size:12px;transition:background .12s}.tsp-action-btn:hover{background:#f3f4f6}.tsp-action-btn--receipt{color:#2563eb;border-color:#bfdbfe}.tsp-action-btn--receipt:hover{background:#eff6ff}.tsp-modal-overlay{z-index:1200;background:#00000059;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.tsp-modal{background:#fff;border-radius:10px;width:100%;max-width:440px;overflow:hidden;box-shadow:0 20px 60px #0000002e}.tsp-modal-header{border-bottom:1px solid #f3f4f6;justify-content:space-between;align-items:center;padding:14px 20px;display:flex}.tsp-modal-title{color:#111827;font-size:14px;font-weight:700}.tsp-modal-close{cursor:pointer;color:#6b7280;background:0 0;border:none;padding:0;font-size:20px;line-height:1}.tsp-modal-close:hover{color:#111827}.tsp-modal-body{max-height:70vh;padding:16px 20px;overflow-y:auto}.tsp-detail-row{border-bottom:1px solid #f9fafb;grid-template-columns:130px 1fr;gap:4px 10px;padding:6px 0;font-size:13px;display:grid}.tsp-detail-row:last-child{border-bottom:none}.tsp-detail-label{color:#6b7280}.tsp-detail-value{color:#111827;word-break:break-all;font-weight:500}.finance-tabs{scrollbar-width:none;border-bottom:2px solid #e5e7eb;flex-shrink:0;gap:0;margin-bottom:24px;display:flex;overflow-x:auto}.finance-tabs::-webkit-scrollbar{display:none}.finance-tab{color:#6b7280;cursor:pointer;white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-2px;padding:10px 20px;font-family:inherit;font-size:14px;font-weight:500;transition:color .15s,border-color .15s}.finance-tab:hover{color:#374151}.finance-tab.active{color:#2563eb;border-bottom-color:#2563eb;font-weight:600}.finance-overview-cards{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px;margin-bottom:28px;display:grid}.finance-ov-card{background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:16px 18px}.finance-ov-card-label{text-transform:uppercase;letter-spacing:.07em;color:#9ca3af;margin-bottom:6px;font-size:11px;font-weight:600}.finance-ov-card-value{color:#111827;font-size:20px;font-weight:700;line-height:1.2}.finance-ov-card-value.green{color:#16a34a}.finance-ov-card-value.red{color:#dc2626}.finance-ov-card-value.amber{color:#d97706}.finance-ov-section{margin-bottom:28px}.finance-ov-section-title{color:#374151;border-bottom:1px solid #f3f4f6;margin-bottom:10px;padding-bottom:8px;font-size:13px;font-weight:700}.finance-ov-table{border-collapse:collapse;width:100%;font-size:13px}.finance-ov-table th{text-align:left;color:#9ca3af;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;background:#fafafa;border-bottom:1px solid #f3f4f6;padding:8px 12px;font-size:11px;font-weight:600}.finance-ov-table td{color:#374151;vertical-align:middle;border-bottom:1px solid #f9fafb;padding:9px 12px}.finance-ov-table tr:last-child td{border-bottom:none}.finance-ov-table tr:hover td{background:#f9fafb}@media (width<=640px){.finance-overview-cards{grid-template-columns:1fr 1fr}.finance-ov-table th,.finance-ov-table td{padding:7px 8px}}.sa-cards{grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:14px;margin-bottom:24px;display:grid}.sa-card{background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:16px 18px}.sa-card-label{color:#6b7280;font-size:12px;font-weight:600}.sa-card-value{color:#0f172a;margin-top:6px;font-size:26px;font-weight:700}.sa-panel{background:#fff;border:1px solid #e5e7eb;border-radius:10px;margin-bottom:20px;padding:18px}.sa-panel-title{color:#111827;margin:0 0 12px;font-size:14px;font-weight:700}.sa-filters{flex-wrap:wrap;gap:10px;margin-bottom:16px;display:flex}.sa-filters input,.sa-filters select{border:1px solid #d1d5db;border-radius:7px;min-width:150px;padding:8px 10px;font-size:13px}.sa-table{border-collapse:collapse;width:100%;font-size:13px}.sa-table th{text-align:left;color:#475569;white-space:nowrap;background:#f8fafc;border-bottom:1px solid #e5e7eb;padding:10px 12px;font-weight:600}.sa-table td{color:#1f2937;vertical-align:middle;border-bottom:1px solid #f1f5f9;padding:10px 12px}.sa-table tr:hover td{background:#fafbfc}.sa-badge{text-transform:capitalize;border-radius:999px;padding:2px 9px;font-size:11px;font-weight:700;display:inline-block}.sa-badge-green{color:#166534;background:#dcfce7}.sa-badge-amber{color:#92400e;background:#fef3c7}.sa-badge-red{color:#991b1b;background:#fee2e2}.sa-badge-blue{color:#1e40af;background:#dbeafe}.sa-badge-gray{color:#475569;background:#f1f5f9}.sa-btn{cursor:pointer;border:1px solid #0000;border-radius:7px;padding:7px 13px;font-size:12.5px;font-weight:600}.sa-btn:disabled{opacity:.6;cursor:not-allowed}.sa-btn-primary{color:#fff;background:#2563eb}.sa-btn-secondary{color:#374151;background:#fff;border-color:#d1d5db}.sa-btn-danger{color:#fff;background:#dc2626}.sa-btn-success{color:#fff;background:#16a34a}.sa-btn-xs{padding:4px 9px;font-size:11.5px}.sa-pagination{color:#475569;align-items:center;gap:10px;margin-top:14px;font-size:13px;display:flex}.sa-row{border-bottom:1px solid #f1f5f9;justify-content:space-between;gap:12px;padding:7px 0;font-size:13px;display:flex}.sa-row span:first-child{color:#6b7280}.sa-row span:last-child{color:#111827;text-align:right;font-weight:600}.sa-actions-bar{flex-wrap:wrap;gap:8px;margin-bottom:16px;display:flex}.sa-grid2{grid-template-columns:1fr 1fr;gap:18px;display:grid}@media (width<=760px){.sa-grid2{grid-template-columns:1fr}}.sa-modal-overlay{z-index:1000;background:#0f172a80;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.sa-modal{background:#fff;border-radius:12px;width:100%;max-width:460px;max-height:90vh;padding:22px;overflow:auto}.sa-modal h3{color:#0f172a;margin:0 0 14px;font-size:16px}.sa-field{margin-bottom:12px}.sa-field label{color:#374151;margin-bottom:5px;font-size:12.5px;font-weight:600;display:block}.sa-field input,.sa-field select,.sa-field textarea{box-sizing:border-box;border:1px solid #d1d5db;border-radius:7px;width:100%;padding:8px 10px;font-size:13px}.sa-msg{border-radius:7px;margin-bottom:12px;padding:9px 12px;font-size:12.5px}.sa-msg-ok{color:#065f46;background:#ecfdf5;border:1px solid #a7f3d0}.sa-msg-err{color:#991b1b;background:#fef2f2;border:1px solid #fecaca}.sa-link-btn{color:#2563eb;cursor:pointer;background:0 0;border:none;padding:0;font-size:13px;font-weight:600}.sa-tabs{border-bottom:2px solid #e5e7eb;gap:0;margin-bottom:20px;display:flex}.sa-tab{color:#6b7280;cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-2px;padding:9px 20px;font-size:13px;font-weight:600}.sa-tab:hover{color:#374151}.sa-tab.active{color:#2563eb;border-bottom-color:#2563eb}.sa-page-header{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:20px;display:flex}.sa-page-header-left h2{color:#0f172a;margin:0 0 4px;font-size:20px;font-weight:700}.sa-page-header-left p{color:#6b7280;margin:0;font-size:13px}.sa-page-header-right{flex-shrink:0;align-items:center;gap:8px;display:flex}.sa-dropdown{display:inline-block;position:relative}.sa-dropdown-menu{z-index:200;background:#fff;border:1px solid #e5e7eb;border-radius:8px;min-width:160px;padding:4px 0;position:absolute;top:calc(100% + 4px);right:0;box-shadow:0 4px 16px #0000001a}.sa-dropdown-item{text-align:left;color:#374151;cursor:pointer;background:0 0;border:none;width:100%;padding:8px 14px;font-size:13px;font-weight:500;display:block}.sa-dropdown-item:hover{color:#111827;background:#f8fafc}.sa-dropdown-item.danger{color:#dc2626}.sa-dropdown-item.danger:hover{background:#fef2f2}.sa-dropdown-divider{background:#f1f5f9;height:1px;margin:4px 0}.sa-banner{border-radius:8px;align-items:center;gap:8px;margin-bottom:16px;padding:10px 14px;font-size:13px;display:flex}.sa-banner-ok{color:#065f46;background:#ecfdf5;border:1px solid #a7f3d0}.sa-banner-err{color:#991b1b;background:#fef2f2;border:1px solid #fecaca}.pis-page{max-width:820px}.pis-card{background:#fff;border:1px solid #e5e7eb;border-radius:10px;margin-bottom:24px;padding:24px}.pis-card-head{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:6px;display:flex}.pis-title{letter-spacing:.04em;color:#111827;text-transform:uppercase;font-size:14px;font-weight:700}.pis-sub{color:#6b7280;margin:0 0 16px;font-size:12.5px}.pis-sub--sm{text-transform:uppercase;letter-spacing:.04em;color:#9ca3af;margin:14px 0 6px;font-size:11.5px;font-weight:600}.pis-instructions{color:#374151;white-space:pre-line;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;margin-bottom:18px;padding:12px 14px;font-size:12.5px;line-height:1.6}.pis-instructions strong{color:#111827}.pis-row{margin-bottom:14px}.pis-row label{color:#374151;margin-bottom:5px;font-size:12.5px;font-weight:600;display:block}.pis-row input,.pis-row select{box-sizing:border-box;color:#111827;background:#fff;border:1px solid #d1d5db;border-radius:7px;width:100%;padding:9px 11px;font-size:13px}.pis-row input:focus,.pis-row select:focus{border-color:#2563eb;outline:none}.pis-hint{color:#6b7280;margin-top:4px;font-size:11.5px}.pis-saved{color:#047857;margin-top:4px;font-size:11.5px}.pis-c2b-health{margin-top:8px;margin-bottom:4px}.pis-c2b-health-ok,.pis-c2b-health-warn{flex-wrap:wrap;align-items:baseline;gap:5px;font-size:11.5px;display:flex}.pis-c2b-health-ok{color:#065f46}.pis-c2b-health-warn{color:#92400e;background:#fef3c7;border-radius:6px;padding:6px 8px;line-height:1.45}.pis-c2b-dot{border-radius:50%;flex-shrink:0;width:7px;height:7px;margin-top:2px;display:inline-block}.pis-c2b-dot--ok{background:#059669}.pis-c2b-dot--warn{background:#d97706}.pis-c2b-receipt,.pis-c2b-amt{color:#374151}.pis-c2b-tag{border-radius:4px;margin-left:2px;padding:1px 5px;font-size:10px;font-weight:600}.pis-c2b-tag--ok{color:#065f46;background:#d1fae5}.pis-c2b-tag--warn{color:#92400e;background:#fef3c7}.pis-section-label{color:#374151;text-transform:uppercase;letter-spacing:.03em;margin:20px 0 10px;font-size:12px;font-weight:700}.pis-grid2{grid-template-columns:1fr 1fr;gap:14px;display:grid}@media (width<=620px){.pis-grid2{grid-template-columns:1fr}}.pis-actions{flex-wrap:wrap;gap:10px;margin-top:18px;display:flex}.pis-btn{cursor:pointer;border:1px solid #0000;border-radius:7px;padding:9px 16px;font-size:13px;font-weight:600}.pis-btn:disabled{opacity:.6;cursor:not-allowed}.pis-btn-primary{color:#fff;background:#2563eb}.pis-btn-secondary{color:#374151;background:#fff;border-color:#d1d5db}.pis-msg{border-radius:7px;margin-bottom:14px;padding:10px 12px;font-size:12.5px}.pis-msg-ok{color:#065f46;background:#ecfdf5;border:1px solid #a7f3d0}.pis-msg-err{color:#991b1b;background:#fef2f2;border:1px solid #fecaca}.pis-msg-info{color:#1e40af;background:#eff6ff;border:1px solid #bfdbfe}.pis-field-err{color:#dc2626;margin-top:3px;font-size:11.5px}.pis-input-err{box-shadow:0 0 0 2px #fee2e2;border-color:#dc2626!important}.pis-callbacks{margin-top:20px}.pis-url-row{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:8px;display:flex}.pis-url-label{color:#374151;min-width:130px;font-size:12px;font-weight:600}.pis-url-value{color:#111827;word-break:break-all;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:6px;flex:1;min-width:220px;padding:6px 8px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12px}.pis-copy-btn{cursor:pointer;color:#374151;background:#fff;border:1px solid #d1d5db;border-radius:6px;padding:6px 10px;font-size:11.5px}.pis-card-title-row{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.pis-card-badges{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.pis-card-meta{margin-top:4px}.pis-meta-text{color:#6b7280;font-size:12px}.pis-meta-muted{color:#9ca3af}.pis-collapse-btn{cursor:pointer;color:#374151;background:#f9fafb;border:1px solid #d1d5db;border-radius:7px;margin-top:10px;padding:7px 14px;font-size:12.5px;font-weight:600}.pis-collapse-btn:hover{background:#f3f4f6}.pis-form-wrap{padding-top:6px}.pis-form-body{padding-top:4px}.pis-divider{border:none;border-top:1px solid #e5e7eb;margin:16px 0}.pis-card--loading{color:#6b7280;font-size:13px}.pis-env-badge{text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;border-radius:999px;padding:2px 8px;font-size:11px;font-weight:700;display:inline-block}.pis-env-badge--sandbox{color:#0369a1;background:#e0f2fe}.pis-env-badge--prod{color:#92400e;background:#fef3c7}.pis-test-badge{white-space:nowrap;border-radius:999px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-block}.pis-test-ok{color:#166534;background:#dcfce7}.pis-test-fail{color:#991b1b;background:#fee2e2}.pis-test-info{color:#374151;background:#f3f4f6}.pis-test-none{color:#9ca3af;background:#f3f4f6}.pis-msg-warn{color:#92400e;background:#fef3c7;border:1px solid #fcd34d}.pis-radio-group{flex-wrap:wrap;gap:24px;margin-top:4px;display:flex}.pis-radio-opt{color:#374151;cursor:pointer;align-items:center;gap:6px;font-size:13px;font-weight:500;display:flex}.pis-radio-opt input[type=radio]{cursor:pointer;margin:0}.pis-hint--block{margin:0 0 12px;display:block}.pis-stk-test{margin-top:20px}.pis-stk-row{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.pis-stk-phone{color:#111827;border:1px solid #d1d5db;border-radius:7px;flex:1;min-width:180px;padding:9px 11px;font-size:13px}.pis-stk-phone:focus{border-color:#2563eb;outline:none}.pis-card--provider{border-left:4px solid var(--pis-accent,#2563eb);padding:0;overflow:hidden}.pis-card-provider-header{align-items:flex-start;gap:18px;padding:20px 24px;display:flex}.pis-card-logo-box{flex-shrink:0;width:96px;padding-top:2px}.pis-provider-logo{border-radius:6px;width:100%;height:auto;display:block}.pis-card-provider-info{flex:1;min-width:0}.pis-card-desc{color:#6b7280;margin:5px 0 8px;font-size:12.5px;line-height:1.5}.pis-card-meta-row{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.pis-card--provider .pis-form-wrap{padding:0 24px 24px}.pis-callback-notice{background:#fffbeb;border:1px solid #fcd34d;border-radius:10px;margin-bottom:24px;padding:18px 20px}.pis-callback-notice-title{color:#92400e;margin-bottom:8px;font-size:13.5px;font-weight:700}.pis-callback-notice-warn{color:#b45309;margin-bottom:5px;font-size:12.5px}.pis-callback-notice-desc{color:#78350f;margin:8px 0 0;font-size:12.5px;line-height:1.65}.pis-callback-notice-placeholder{display:none}.pis-row--inline{flex-direction:column;display:flex}.pis-toggle-label{cursor:pointer;color:#111827;-webkit-user-select:none;user-select:none;align-items:center;gap:8px;font-size:13px;font-weight:500;display:inline-flex}.pis-toggle-label input[type=checkbox]{cursor:pointer;accent-color:#2563eb;flex-shrink:0;width:16px;height:16px}.pis-status{text-transform:capitalize;white-space:nowrap;border-radius:999px;padding:3px 10px;font-size:11.5px;font-weight:700;display:inline-block}.pis-status--not_configured{color:#6b7280;background:#f3f4f6}.pis-status--incomplete{color:#92400e;background:#fef3c7}.pis-status--ready_for_sandbox{color:#1e40af;background:#dbeafe}.pis-status--ready_for_production{color:#166534;background:#dcfce7}.pis-status--callback_registered{color:#065f46;background:#d1fae5}.pis-status--error{color:#991b1b;background:#fee2e2}.recon-summary-bar{gap:var(--space-md);margin-bottom:var(--space-lg);flex-wrap:wrap;display:flex}.recon-summary-card{border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-md) var(--space-lg);box-shadow:var(--shadow-sm);background:#fff;flex-direction:column;flex:1;gap:4px;min-width:140px;display:flex}.recon-summary-value{color:var(--color-text);font-size:22px;font-weight:800;line-height:1.1}.recon-summary-label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:500}.recon-card-pending .recon-summary-value{color:var(--color-warning)}.recon-card-matched .recon-summary-value{color:var(--color-success)}.recon-card-escalated .recon-summary-value{color:var(--color-danger)}.recon-card-ignored .recon-summary-value{color:#6b7280}.recon-filters{gap:var(--space-sm);margin-bottom:var(--space-md);flex-wrap:wrap;align-items:flex-end;display:flex}.recon-filter-group{flex-direction:column;gap:4px;display:flex}.recon-filter-group label{text-transform:uppercase;letter-spacing:.4px;color:var(--color-text-muted);font-size:11px;font-weight:600}.recon-filters input,.recon-filters select{border:1px solid var(--color-border);border-radius:var(--radius-md);height:36px;color:var(--color-text);background:#fff;min-width:140px;padding:0 10px;font-size:13px}.recon-filters input:focus,.recon-filters select:focus{border-color:var(--color-primary);outline:none}.recon-table-wrap{border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);background:#fff;overflow:hidden}.recon-table-responsive{overflow-x:auto}.recon-table{border-collapse:collapse;width:100%;font-size:13px}.recon-table th{background:var(--color-bg-subtle,#f9fafb);border-bottom:1px solid var(--color-border);text-align:left;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;padding:10px 14px;font-size:11px;font-weight:700}.recon-table td{border-bottom:1px solid var(--color-border-subtle,#f3f4f6);vertical-align:middle;padding:12px 14px}.recon-table tr:last-child td{border-bottom:none}.recon-table tr:hover td{background:var(--color-bg-hover,#f9fafb)}.recon-amount{font-variant-numeric:tabular-nums;font-weight:700}.recon-badge{letter-spacing:.3px;white-space:nowrap;border-radius:99px;align-items:center;padding:2px 10px;font-size:11px;font-weight:600;display:inline-flex}.recon-badge-pending{color:#854d0e;background:#fef9c3}.recon-badge-matched{color:#166534;background:#dcfce7}.recon-badge-ignored{color:#71717a;background:#f4f4f5}.recon-badge-escalated{color:#991b1b;background:#fee2e2}.recon-badge-reversed{color:#5b21b6;background:#ede9fe}.recon-badge-alloc-suspense{color:#9a3412;background:#fff7ed}.recon-badge-alloc-unallocated{color:#854d0e;background:#fef9c3}.recon-badge-alloc-allocated{color:#166534;background:#dcfce7}.recon-badge-alloc-partial{color:#1e40af;background:#dbeafe}.recon-actions{flex-wrap:wrap;gap:6px;display:flex}.recon-btn{border-radius:var(--radius-md);cursor:pointer;white-space:nowrap;border:1px solid #0000;align-items:center;gap:4px;padding:5px 11px;font-size:12px;font-weight:600;transition:opacity .15s;display:inline-flex}.recon-btn:disabled{opacity:.5;cursor:not-allowed}.recon-btn:hover:not(:disabled){opacity:.85}.recon-btn-primary{background:var(--color-primary);color:#fff}.recon-btn-success{background:var(--color-success);color:#fff}.recon-btn-warning{color:#fff;background:#d97706}.recon-btn-danger{background:var(--color-danger);color:#fff}.recon-btn-ghost{color:var(--color-text);border-color:var(--color-border);background:#f4f4f5}.recon-btn-outline{color:var(--color-primary);border-color:var(--color-primary);background:0 0}.recon-drawer-overlay{z-index:200;background:#00000059;justify-content:flex-end;display:flex;position:fixed;inset:0}.recon-drawer{background:#fff;flex-direction:column;width:min(560px,100vw);height:100vh;display:flex;overflow-y:auto;box-shadow:-4px 0 24px #0000001f}.recon-drawer-header{border-bottom:1px solid var(--color-border);z-index:1;background:#fff;justify-content:space-between;align-items:center;padding:18px 24px;display:flex;position:sticky;top:0}.recon-drawer-header h3{color:var(--color-text);margin:0;font-size:16px;font-weight:700}.recon-drawer-close{cursor:pointer;color:var(--color-text-muted);background:0 0;border:none;padding:4px;font-size:20px;line-height:1}.recon-drawer-close:hover{color:var(--color-text)}.recon-drawer-body{flex-direction:column;flex:1;gap:24px;padding:24px;display:flex}.recon-info-grid{grid-template-columns:1fr 1fr;gap:12px;display:grid}.recon-info-item{flex-direction:column;gap:3px;display:flex}.recon-info-label{text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-muted);font-size:10px;font-weight:700}.recon-info-value{color:var(--color-text);font-size:14px;font-weight:500}.recon-suggestions-list{flex-direction:column;gap:10px;display:flex}.recon-suggestion-card{border:1px solid var(--color-border);border-radius:var(--radius-md);background:#fff;flex-direction:column;gap:6px;padding:12px 14px;display:flex}.recon-suggestion-card:hover{border-color:var(--color-primary)}.recon-suggestion-top{justify-content:space-between;align-items:center;gap:8px;display:flex}.recon-suggestion-name{color:var(--color-text);font-size:14px;font-weight:600}.recon-confidence{text-transform:uppercase;letter-spacing:.5px;border-radius:99px;padding:2px 8px;font-size:10px;font-weight:700}.recon-confidence-high{color:#166534;background:#dcfce7}.recon-confidence-medium{color:#854d0e;background:#fef9c3}.recon-confidence-low{color:#71717a;background:#f4f4f5}.recon-suggestion-meta{color:var(--color-text-muted);font-size:12px}.recon-suggestion-reason{color:var(--color-text-muted);border-top:1px solid var(--color-border-subtle,#f3f4f6);padding-top:6px;font-size:12px;font-style:italic}.recon-suggestion-actions{flex-wrap:wrap;gap:6px;padding-top:6px;display:flex}.recon-section-title{text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-muted);margin-bottom:10px;font-size:12px;font-weight:700}.recon-form-row{flex-direction:column;gap:5px;margin-bottom:12px;display:flex}.recon-form-row label{color:var(--color-text);font-size:12px;font-weight:600}.recon-form-row input,.recon-form-row select,.recon-form-row textarea{border:1px solid var(--color-border);border-radius:var(--radius-md);width:100%;color:var(--color-text);box-sizing:border-box;background:#fff;padding:8px 10px;font-size:13px}.recon-form-row textarea{resize:vertical;min-height:72px}.recon-form-row input:focus,.recon-form-row select:focus,.recon-form-row textarea:focus{border-color:var(--color-primary);outline:none}.recon-form-error{color:var(--color-danger);margin-top:4px;font-size:12px}.recon-form-actions{justify-content:flex-end;gap:8px;margin-top:4px;display:flex}.recon-drawer-tabs{border-bottom:2px solid var(--color-border);gap:0;display:flex;overflow-x:auto}.recon-drawer-tab{color:var(--color-text-muted);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-2px;padding:8px 16px;font-size:13px;font-weight:600}.recon-drawer-tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.recon-empty{text-align:center;color:var(--color-text-muted);padding:48px 24px;font-size:14px}.recon-empty-icon{opacity:.4;margin-bottom:12px;font-size:40px}@media (width<=768px){.recon-info-grid{grid-template-columns:1fr}.recon-drawer{width:100vw}.recon-filters{flex-direction:column}.recon-filters input,.recon-filters select{min-width:unset;width:100%}}.fc-page{flex-direction:column;gap:24px;max-width:1100px;display:flex}.fc-notice-banner{background:#eff6ff;border:1px solid #bfdbfe;border-radius:8px;align-items:flex-start;gap:12px;padding:14px 16px;display:flex}.fc-notice-icon{color:#fff;background:#2563eb;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;margin-top:1px;font-size:13px;font-weight:700;display:flex}.fc-notice-text{color:#1e3a5f;font-size:13.5px;line-height:1.5}.fc-section{background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:24px}.fc-section-header{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:20px;display:flex}.fc-section-title{color:#111827;margin:0 0 4px;font-size:15px;font-weight:600}.fc-section-sub{color:#6b7280;margin:0;font-size:13px}.fc-warning-block{color:#92400e;background:#fffbeb;border:1px solid #fcd34d;border-radius:6px;margin-bottom:20px;padding:10px 14px;font-size:13px}.fc-warning-inline{color:#92400e;background:#fffbeb;border-left:3px solid #f59e0b;border-radius:0 4px 4px 0;margin-bottom:12px;padding:8px 12px;font-size:12.5px}.fc-error{color:#b91c1c;background:#fef2f2;border:1px solid #fecaca;border-radius:6px;margin-bottom:16px;padding:10px 14px;font-size:13px}.fc-form-grid{flex-direction:column;gap:16px;display:flex}.fc-field{flex-direction:column;gap:4px;display:flex}.fc-field label{color:#374151;font-size:13px;font-weight:500}.fc-field input,.fc-field select,.fc-field textarea{color:#111827;background:#fff;border:1px solid #d1d5db;border-radius:6px;outline:none;padding:8px 10px;font-size:13.5px;transition:border-color .15s}.fc-field input:focus,.fc-field select:focus,.fc-field textarea:focus{border-color:#2563eb}.fc-field-hint{color:#9ca3af;font-size:12px}.fc-row-2{grid-template-columns:1fr 1fr;gap:16px;display:grid}.fc-check-row{color:#374151;align-items:center;gap:8px;font-size:13px;display:flex}.fc-check-row input[type=checkbox]{cursor:pointer;width:15px;height:15px}.fc-save-row{justify-content:flex-end;display:flex}.fc-toggle-row{border-bottom:1px solid #f3f4f6;justify-content:space-between;align-items:flex-start;gap:16px;padding:12px 0;display:flex}.fc-toggle-row:last-of-type{border-bottom:none}.fc-toggle-label{color:#111827;margin-bottom:2px;font-size:13.5px;font-weight:500}.fc-toggle-hint{color:#6b7280;font-size:12px}.fc-switch{cursor:pointer;flex-shrink:0;width:42px;height:24px;display:inline-block;position:relative}.fc-switch input{opacity:0;width:0;height:0}.fc-switch-slider{background:#d1d5db;border-radius:24px;transition:background .2s;position:absolute;inset:0}.fc-switch-slider:before{content:"";background:#fff;border-radius:50%;width:18px;height:18px;transition:transform .2s;position:absolute;bottom:3px;left:3px}.fc-switch input:checked+.fc-switch-slider{background:#2563eb}.fc-switch input:checked+.fc-switch-slider:before{transform:translate(18px)}.fc-divider{background:#f3f4f6;height:1px;margin:20px 0}.fc-auto-actions{flex-direction:column;gap:20px;display:flex}.fc-auto-action-group{justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.fc-confirm-box{background:#fef3c7;border:1px solid #fcd34d;border-radius:8px;padding:16px}.fc-confirm-box p{color:#92400e;margin:0 0 12px;font-size:13.5px}.fc-confirm-actions{justify-content:flex-end;gap:8px;display:flex}.fc-preview-result,.fc-run-result{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:14px}.fc-preview-stats,.fc-run-stats{flex-wrap:wrap;gap:8px;margin-bottom:12px;display:flex}.fc-stat-pill{border-radius:20px;padding:3px 10px;font-size:12px;font-weight:600}.fc-stat-green{color:#065f46;background:#d1fae5}.fc-stat-gray{color:#374151;background:#f3f4f6}.fc-stat-red{color:#991b1b;background:#fee2e2}.fc-error-list{color:#b91c1c;margin:8px 0 0;padding-left:16px;font-size:12.5px}.fc-table{border-collapse:collapse;width:100%;font-size:13.5px}.fc-table th{text-align:left;color:#6b7280;text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid #e5e7eb;padding:8px 10px;font-size:12px;font-weight:600}.fc-table td{color:#374151;vertical-align:middle;border-bottom:1px solid #f3f4f6;padding:10px}.fc-table tr:last-child td{border-bottom:none}.fc-table-sm th,.fc-table-sm td{padding:6px 8px;font-size:12.5px}.fc-row-inactive td{opacity:.5}.fc-prov-name{color:#111827;font-weight:500}.fc-prov-code{color:#9ca3af;font-size:11.5px}.fc-env-badge{text-transform:uppercase;border-radius:20px;padding:2px 8px;font-size:11px;font-weight:600}.fc-env-sandbox{color:#0369a1;background:#e0f2fe}.fc-env-production{color:#92400e;background:#fef3c7}.fc-badge{border-radius:20px;padding:2px 8px;font-size:11px;font-weight:600}.fc-badge-default{color:#1d4ed8;background:#dbeafe}.fc-badge-active{color:#065f46;background:#d1fae5}.fc-badge-inactive{color:#6b7280;background:#f3f4f6}.fc-badge-warn{color:#92400e;background:#fef3c7}.fc-action-row{flex-wrap:wrap;justify-content:flex-end;gap:6px;display:flex}.fc-integrity-result{margin-top:16px}.fc-integrity-stats{flex-wrap:wrap;gap:12px;margin-bottom:20px;display:flex}.fc-integrity-stat{text-align:center;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;flex:1;min-width:100px;padding:12px 16px}.fc-stat-clean{background:#ecfdf5;border-color:#a7f3d0}.fc-stat-warn{background:#fffbeb;border-color:#fcd34d}.fc-stat-error{background:#fef2f2;border-color:#fca5a5}.fc-integrity-num{color:#111827;font-size:24px;font-weight:700}.fc-integrity-label{color:#6b7280;margin-top:2px;font-size:12px}.fc-integrity-clean{color:#065f46;background:#ecfdf5;border:1px solid #a7f3d0;border-radius:8px;padding:14px 18px;font-size:13.5px;font-weight:500}.fc-integrity-group{border:1px solid #fee2e2;border-radius:8px;margin-bottom:16px;overflow:hidden}.fc-integrity-group-header{color:#991b1b;background:#fff1f2;justify-content:space-between;align-items:center;padding:10px 14px;font-size:13px;font-weight:500;display:flex}.fc-integrity-group .fc-table{border:none;border-radius:0}.fc-overflow-note{color:#6b7280;border-top:1px solid #f3f4f6;padding:8px 14px;font-size:12px}.fc-btn-primary{color:#fff;cursor:pointer;background:#2563eb;border:none;border-radius:6px;padding:8px 18px;font-size:13.5px;font-weight:500;transition:background .15s}.fc-btn-primary:hover:not(:disabled){background:#1d4ed8}.fc-btn-primary:disabled{opacity:.5;cursor:not-allowed}.fc-btn-outline{color:#2563eb;cursor:pointer;background:0 0;border:1px solid #2563eb;border-radius:6px;padding:7px 16px;font-size:13.5px;font-weight:500;transition:background .15s}.fc-btn-outline:hover:not(:disabled){background:#eff6ff}.fc-btn-outline:disabled{opacity:.5;cursor:not-allowed}.fc-btn-ghost{color:#6b7280;cursor:pointer;background:0 0;border:1px solid #d1d5db;border-radius:6px;padding:7px 16px;font-size:13.5px;transition:background .15s}.fc-btn-ghost:hover{background:#f9fafb}.fc-btn-sm{color:#374151;cursor:pointer;background:0 0;border:1px solid #d1d5db;border-radius:5px;padding:5px 12px;font-size:12px;transition:background .15s}.fc-btn-sm:hover{background:#f9fafb}.fc-btn-sm:disabled{opacity:.4;cursor:not-allowed}.fc-btn-danger{color:#b91c1c;border-color:#fca5a5}.fc-btn-danger:hover{background:#fef2f2}.fc-modal-overlay{z-index:2000;background:#0006;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.fc-modal{background:#fff;border-radius:10px;width:100%;max-width:520px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0003}.fc-modal-header{border-bottom:1px solid #f3f4f6;justify-content:space-between;align-items:center;padding:18px 20px 14px;display:flex}.fc-modal-header h3{color:#111827;margin:0;font-size:15px;font-weight:600}.fc-modal-close{color:#9ca3af;cursor:pointer;background:0 0;border:none;border-radius:4px;padding:2px 6px;font-size:18px;line-height:1}.fc-modal-close:hover{color:#374151;background:#f3f4f6}.fc-modal-body{flex-direction:column;gap:14px;padding:20px;display:flex}.fc-modal-footer{justify-content:flex-end;gap:8px;margin-top:4px;display:flex}.fc-empty{text-align:center;color:#9ca3af;padding:40px 20px;font-size:13.5px}.fc-loading{text-align:center;color:#9ca3af;padding:32px 20px;font-size:13.5px}@media (width<=640px){.fc-row-2{grid-template-columns:1fr}.fc-section-header{flex-direction:column;align-items:stretch}.fc-auto-action-group,.fc-integrity-stats{flex-direction:column}}.pcb-page{flex-direction:column;gap:20px;max-width:1200px;display:flex}.pcb-filters{background:#fff;border:1px solid #e5e7eb;border-radius:10px;flex-wrap:wrap;align-items:flex-end;gap:10px;padding:16px;display:flex}.pcb-filter-group{flex-direction:column;gap:4px;min-width:140px;display:flex}.pcb-filter-group label{color:#6b7280;font-size:12px;font-weight:500}.pcb-filter-group input,.pcb-filter-group select{color:#111827;background:#fff;border:1px solid #d1d5db;border-radius:6px;outline:none;padding:7px 10px;font-size:13px}.pcb-filter-group input:focus,.pcb-filter-group select:focus{border-color:#2563eb}.pcb-filter-actions{align-self:flex-end;gap:8px;margin-left:auto;display:flex}.pcb-stats{flex-wrap:wrap;gap:12px;display:flex}.pcb-stat{text-align:center;background:#fff;border:1px solid #e5e7eb;border-radius:8px;flex:1;min-width:100px;padding:12px 16px}.pcb-stat-num{color:#111827;font-size:22px;font-weight:700}.pcb-stat-label{color:#6b7280;margin-top:2px;font-size:12px}.pcb-stat-processed{background:#ecfdf5;border-color:#a7f3d0}.pcb-stat-manual{background:#fffbeb;border-color:#fcd34d}.pcb-stat-failed{background:#fef2f2;border-color:#fca5a5}.pcb-stat-duplicate{background:#f5f3ff;border-color:#c4b5fd}.pcb-card{background:#fff;border:1px solid #e5e7eb;border-radius:10px;overflow:hidden}.pcb-table{border-collapse:collapse;width:100%;font-size:13px}.pcb-table th{text-align:left;color:#6b7280;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;background:#f9fafb;border-bottom:1px solid #e5e7eb;padding:10px 14px;font-size:11.5px;font-weight:600}.pcb-table td{color:#374151;vertical-align:middle;border-bottom:1px solid #f3f4f6;padding:11px 14px}.pcb-table tr:last-child td{border-bottom:none}.pcb-table tr:hover td{background:#f9fafb}.pcb-txref{color:#374151;font-family:monospace;font-size:12px}.pcb-txref-none{color:#9ca3af;font-size:12px;font-style:italic}.pcb-badge{text-transform:capitalize;white-space:nowrap;border-radius:20px;padding:2px 9px;font-size:11px;font-weight:600;display:inline-block}.pcb-badge-received{color:#0369a1;background:#e0f2fe}.pcb-badge-processing{color:#1d4ed8;background:#dbeafe}.pcb-badge-processed{color:#065f46;background:#d1fae5}.pcb-badge-duplicate{color:#6d28d9;background:#ede9fe}.pcb-badge-failed{color:#991b1b;background:#fee2e2}.pcb-badge-ignored{color:#6b7280;background:#f3f4f6}.pcb-badge-manual_review{color:#92400e;background:#fef3c7}.pcb-provider{color:#374151;white-space:nowrap;background:#f3f4f6;border-radius:4px;padding:2px 8px;font-size:11.5px;font-weight:600}.pcb-provider-mpesa_stk,.pcb-provider-mpesa_c2b,.pcb-provider-mpesa{color:#166534;background:#dcfce7}.pcb-provider-pesapal{color:#1d4ed8;background:#dbeafe}.pcb-row-actions{justify-content:flex-end;gap:6px;display:flex}.pcb-btn-primary{color:#fff;cursor:pointer;background:#2563eb;border:none;border-radius:6px;padding:7px 16px;font-size:13px;font-weight:500;transition:background .15s}.pcb-btn-primary:hover:not(:disabled){background:#1d4ed8}.pcb-btn-primary:disabled{opacity:.45;cursor:not-allowed}.pcb-btn-outline{color:#2563eb;cursor:pointer;background:0 0;border:1px solid #2563eb;border-radius:6px;padding:6px 14px;font-size:13px;transition:background .15s}.pcb-btn-outline:hover{background:#eff6ff}.pcb-btn-sm{color:#374151;cursor:pointer;background:0 0;border:1px solid #d1d5db;border-radius:5px;padding:4px 11px;font-size:12px;transition:background .15s}.pcb-btn-sm:hover{background:#f9fafb}.pcb-btn-sm:disabled{opacity:.4;cursor:not-allowed}.pcb-btn-warn{color:#92400e;border-color:#fcd34d}.pcb-btn-warn:hover{background:#fffbeb}.pcb-pagination{color:#6b7280;border-top:1px solid #f3f4f6;justify-content:space-between;align-items:center;padding:12px 16px;font-size:13px;display:flex}.pcb-pagination-controls{gap:6px;display:flex}.pcb-empty{text-align:center;color:#9ca3af;padding:48px 20px;font-size:13.5px}.pcb-loading{text-align:center;color:#9ca3af;padding:32px 20px;font-size:13px}.pcb-detail-overlay{z-index:2000;background:#00000059;justify-content:flex-end;display:flex;position:fixed;inset:0}.pcb-detail-panel{background:#fff;flex-direction:column;width:100%;max-width:520px;height:100%;display:flex;overflow-y:auto;box-shadow:-4px 0 24px #0000001f}.pcb-detail-header{z-index:1;background:#fff;border-bottom:1px solid #f3f4f6;justify-content:space-between;align-items:center;padding:18px 20px 14px;display:flex;position:sticky;top:0}.pcb-detail-header h3{color:#111827;margin:0;font-size:15px;font-weight:600}.pcb-detail-close{color:#9ca3af;cursor:pointer;background:0 0;border:none;border-radius:4px;padding:2px 6px;font-size:18px;line-height:1}.pcb-detail-close:hover{color:#374151;background:#f3f4f6}.pcb-detail-body{flex-direction:column;flex:1;gap:16px;padding:20px;display:flex}.pcb-detail-section{border:1px solid #f3f4f6;border-radius:8px;overflow:hidden}.pcb-detail-section-title{color:#6b7280;text-transform:uppercase;letter-spacing:.04em;background:#f9fafb;border-bottom:1px solid #f3f4f6;padding:8px 12px;font-size:12px;font-weight:600}.pcb-detail-row{border-bottom:1px solid #f9fafb;padding:8px 12px;font-size:13px;display:flex}.pcb-detail-row:last-child{border-bottom:none}.pcb-detail-key{color:#6b7280;flex-shrink:0;width:140px;font-size:12.5px;font-weight:500}.pcb-detail-val{color:#111827;word-break:break-all;font-size:13px}.pcb-detail-val-mono{color:#374151;font-family:monospace;font-size:12px}.pcb-detail-error{color:#b91c1c;white-space:pre-wrap;word-break:break-all;background:#fef2f2;border:1px solid #fecaca;border-radius:6px;padding:10px 14px;font-size:12.5px}.pcb-detail-actions{border-top:1px solid #f3f4f6;justify-content:flex-end;gap:8px;padding:16px 20px;display:flex}.pcb-error{color:#b91c1c;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;padding:12px 16px;font-size:13px}@media (width<=768px){.pcb-filters{flex-direction:column}.pcb-filter-actions{margin-left:0}.pcb-stats{flex-wrap:wrap}.pcb-stat{min-width:120px}.pcb-detail-panel{max-width:100%}}.cs-page{max-width:1200px;padding:28px 32px}.cs-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:24px;display:flex}.cs-title{color:#111827;margin:0;font-size:20px;font-weight:700}.cs-subtitle{color:#6b7280;margin:2px 0 0;font-size:13px}.cs-filters{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:20px;display:flex}.cs-filters select,.cs-filters input{color:#374151;background:#fff;border:1px solid #d1d5db;border-radius:6px;min-width:140px;padding:7px 10px;font-size:13px}.cs-filters select:focus,.cs-filters input:focus{border-color:#6366f1;outline:none}.cs-table-wrap{background:#fff;border:1px solid #e5e7eb;border-radius:10px;overflow:hidden}.cs-table{border-collapse:collapse;width:100%;font-size:13px}.cs-table thead tr{background:#f9fafb}.cs-table th{text-align:left;color:#6b7280;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;border-bottom:1px solid #e5e7eb;padding:11px 14px;font-size:12px;font-weight:600}.cs-table td{color:#374151;vertical-align:middle;border-bottom:1px solid #f3f4f6;padding:11px 14px}.cs-table tbody tr:last-child td{border-bottom:none}.cs-table tbody tr:hover{cursor:pointer;background:#f9fafb}.cs-ref{color:#1e40af;background:#eff6ff;border:1px solid #bfdbfe;border-radius:4px;padding:2px 6px;font-family:monospace;font-size:12px}.cs-amount{color:#111827;font-weight:600}.cs-muted{color:#9ca3af;font-size:12px}.cs-badge{text-transform:capitalize;white-space:nowrap;border-radius:12px;padding:3px 8px;font-size:11px;font-weight:600;display:inline-block}.cs-badge-pending{color:#854d0e;background:#fef9c3}.cs-badge-submitted{color:#1e40af;background:#dbeafe}.cs-badge-completed{color:#166534;background:#dcfce7}.cs-badge-failed{color:#991b1b;background:#fee2e2}.cs-badge-expired,.cs-badge-cancelled{color:#6b7280;background:#f3f4f6}.cs-badge-manual_review{color:#92400e;background:#fef3c7}.cs-via{color:#6b7280;white-space:nowrap;background:#f3f4f6;border-radius:10px;padding:2px 6px;font-size:11px}.cs-layout{align-items:flex-start;gap:20px;display:flex}.cs-table-col{flex:1;min-width:0}.cs-detail-col{background:#fff;border:1px solid #e5e7eb;border-radius:10px;flex-shrink:0;width:360px;padding:20px;position:sticky;top:24px}.cs-detail-title{color:#111827;justify-content:space-between;align-items:center;margin:0 0 16px;font-size:14px;font-weight:700;display:flex}.cs-close-btn{color:#9ca3af;cursor:pointer;background:0 0;border:none;padding:0;font-size:18px;line-height:1}.cs-close-btn:hover{color:#374151}.cs-detail-row{border-bottom:1px solid #f3f4f6;gap:8px;padding:7px 0;font-size:13px;display:flex}.cs-detail-row:last-child{border-bottom:none}.cs-detail-key{color:#6b7280;flex:0 0 130px;font-size:12px;font-weight:500}.cs-detail-val{color:#111827;word-break:break-all;flex:1}.cs-detail-val-mono{color:#1e40af;font-family:monospace;font-size:11px}.cs-detail-actions{flex-wrap:wrap;gap:8px;margin-top:16px;display:flex}.cs-pagination{color:#6b7280;background:#f9fafb;border-top:1px solid #e5e7eb;justify-content:space-between;align-items:center;padding:12px 16px;font-size:13px;display:flex}.cs-page-btns{gap:6px;display:flex}.cs-page-btns button{cursor:pointer;color:#374151;background:#fff;border:1px solid #d1d5db;border-radius:6px;padding:4px 12px;font-size:13px}.cs-page-btns button:disabled{opacity:.45;cursor:not-allowed}.cs-page-btns button:not(:disabled):hover{background:#f3f4f6}.cs-empty{text-align:center;color:#9ca3af;padding:48px 24px}.cs-empty-icon{margin-bottom:10px;font-size:32px}.cs-empty h3{color:#374151;margin:0 0 4px;font-size:15px}.cs-empty p{margin:0;font-size:13px}.cs-loading,.cs-error{text-align:center;color:#6b7280;padding:40px 24px;font-size:14px}.cs-error{color:#dc2626}.cs-btn{cursor:pointer;border:none;border-radius:6px;padding:6px 14px;font-size:13px;font-weight:500;transition:opacity .15s}.cs-btn:hover{opacity:.85}.cs-btn-primary{color:#fff;background:#4f46e5}.cs-btn-secondary{color:#374151;background:#f3f4f6;border:1px solid #d1d5db}.cs-btn-danger{color:#991b1b;background:#fee2e2;border:1px solid #fca5a5}.cs-btn-sm{padding:4px 10px;font-size:12px}.sp-loader{background:#f8fafc;justify-content:center;align-items:center;min-height:100vh;display:flex}.sp-page{background:#f8fafc;min-height:100vh;padding:48px 24px 80px;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.sp-header{text-align:center;max-width:620px;margin:0 auto 48px}.sp-logo{letter-spacing:.14em;color:#3b82f6;text-transform:uppercase;margin-bottom:20px;font-size:13px;font-weight:800}.sp-title{color:#0f172a;margin-bottom:12px;font-size:32px;font-weight:700;line-height:1.25}.sp-subtitle{color:#64748b;font-size:15px;line-height:1.6}.sp-error{color:#b91c1c;text-align:center;background:#fee2e2;border:1px solid #fecaca;border-radius:8px;max-width:900px;margin:0 auto 24px;padding:12px 16px;font-size:14px}.sp-plans{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:24px;max-width:1100px;margin:0 auto 40px;display:grid}.sp-card{background:#fff;border:1px solid #e2e8f0;border-radius:14px;flex-direction:column;padding:28px 24px 24px;transition:box-shadow .2s,transform .2s;display:flex;position:relative}.sp-card:hover{transform:translateY(-2px);box-shadow:0 8px 32px #0000001a}.sp-card--popular{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f62e,0 4px 20px #3b82f61f}.sp-card--enterprise{background:linear-gradient(135deg,#fafafa 0%,#f5f3ff 100%);border-color:#6366f1}.sp-popular-badge{color:#fff;letter-spacing:.06em;text-transform:uppercase;background:#3b82f6;border-radius:20px;padding:4px 14px;font-size:11px;font-weight:700;position:absolute;top:-12px;left:50%;transform:translate(-50%)}.sp-card-header{margin-bottom:16px}.sp-plan-name{color:#0f172a;margin-bottom:4px;font-size:20px;font-weight:700}.sp-unit-label{color:#64748b;margin-bottom:12px;font-size:13px}.sp-price{color:#0f172a;font-size:26px;font-weight:800;line-height:1.1}.sp-trial-note{color:#10b981;margin-top:6px;font-size:12px;font-weight:600}.sp-plan-desc{color:#64748b;margin-bottom:16px;font-size:13px;line-height:1.5}.sp-features{flex:1;margin:0 0 24px;padding:0;list-style:none}.sp-feature-item{color:#374151;align-items:flex-start;gap:8px;padding:5px 0;font-size:13.5px;line-height:1.4;display:flex}.sp-feature-check{color:#10b981;flex-shrink:0;margin-top:1px;font-size:13px;font-weight:700}.sp-btn{cursor:pointer;color:#0f172a;background:#fff;border:1.5px solid #e2e8f0;border-radius:8px;width:100%;margin-top:auto;padding:12px 20px;font-size:14px;font-weight:600;transition:background .15s,border-color .15s,color .15s}.sp-btn:hover:not(:disabled){background:#f1f5f9;border-color:#cbd5e1}.sp-btn--primary{color:#fff;background:#3b82f6;border-color:#3b82f6}.sp-btn--primary:hover:not(:disabled){background:#2563eb;border-color:#2563eb}.sp-btn:disabled{opacity:.6;cursor:not-allowed}.sp-note{text-align:center;color:#94a3b8;max-width:620px;margin:0 auto;font-size:13px;line-height:1.6}.sub-lifecycle-page{max-width:1400px;margin:0 auto;padding:24px}.sub-lifecycle-page h1{color:#111827;margin:0 0 4px;font-size:22px;font-weight:700}.sub-lifecycle-page .page-subtitle{color:#6b7280;margin-bottom:24px;font-size:13px}.sub-toolbar{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:20px;display:flex}.sub-toolbar input,.sub-toolbar select{background:#fff;border:1px solid #d1d5db;border-radius:6px;min-width:160px;padding:8px 12px;font-size:13px}.sub-toolbar input:focus,.sub-toolbar select:focus{border-color:#6366f1;outline:none;box-shadow:0 0 0 3px #6366f11a}.btn-process-expiries{color:#fff;cursor:pointer;background:#f59e0b;border:none;border-radius:6px;margin-left:auto;padding:8px 16px;font-size:13px;font-weight:600}.btn-process-expiries:hover{background:#d97706}.btn-process-expiries:disabled{opacity:.6;cursor:not-allowed}.sub-table-wrap{background:#fff;border:1px solid #e5e7eb;border-radius:10px;overflow:hidden}.sub-table{border-collapse:collapse;width:100%;font-size:13px}.sub-table th{text-align:left;color:#374151;white-space:nowrap;background:#f9fafb;border-bottom:1px solid #e5e7eb;padding:10px 14px;font-weight:600}.sub-table td{color:#374151;vertical-align:middle;border-bottom:1px solid #f3f4f6;padding:10px 14px}.sub-table tr:last-child td{border-bottom:none}.sub-table tr:hover td{background:#f9fafb}.status-badge{text-transform:uppercase;letter-spacing:.03em;border-radius:12px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-block}.status-trialing{color:#1d4ed8;background:#dbeafe}.status-active{color:#065f46;background:#d1fae5}.status-past_due{color:#92400e;background:#fef3c7}.status-suspended{color:#991b1b;background:#fee2e2}.status-cancelled{color:#6b7280;background:#f3f4f6}.status-expired{color:#9d174d;background:#fce7f3}.status-pending_plan{color:#3730a3;background:#e0e7ff}.sub-actions{flex-wrap:wrap;gap:6px;display:flex}.btn-action{cursor:pointer;color:#374151;background:#fff;border:1px solid #d1d5db;border-radius:5px;padding:4px 10px;font-size:12px;transition:all .15s}.btn-action:hover{background:#f3f4f6}.btn-action.btn-danger{color:#dc2626;border-color:#fca5a5}.btn-action.btn-danger:hover{background:#fee2e2}.btn-action.btn-success{color:#065f46;border-color:#6ee7b7}.btn-action.btn-success:hover{background:#d1fae5}.btn-action.btn-warn{color:#92400e;border-color:#fcd34d}.btn-action.btn-warn:hover{background:#fef3c7}.sub-pagination{color:#6b7280;border-top:1px solid #e5e7eb;justify-content:space-between;align-items:center;padding:14px 16px;font-size:13px;display:flex}.sub-pagination-btns{gap:8px;display:flex}.sub-pagination-btns button{cursor:pointer;background:#fff;border:1px solid #d1d5db;border-radius:6px;padding:6px 14px;font-size:13px}.sub-pagination-btns button:disabled{opacity:.5;cursor:not-allowed}.sub-pagination-btns button:hover:not(:disabled){background:#f3f4f6}.policy-card{background:#fff;border:1px solid #e5e7eb;border-radius:10px;margin-top:28px;padding:24px}.policy-card h2{color:#111827;margin:0 0 6px;font-size:16px;font-weight:700}.policy-card .policy-desc{color:#6b7280;margin-bottom:20px;font-size:12px}.policy-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px;display:grid}.policy-field label{color:#374151;margin-bottom:5px;font-size:12px;font-weight:600;display:block}.policy-field input,.policy-field select{box-sizing:border-box;background:#fff;border:1px solid #d1d5db;border-radius:6px;width:100%;padding:8px 10px;font-size:13px}.policy-field input:focus,.policy-field select:focus{border-color:#6366f1;outline:none}.policy-field input[type=checkbox]{width:auto;margin-right:6px}.policy-save-row{align-items:center;gap:12px;margin-top:20px;display:flex}.btn-save-policy{color:#fff;cursor:pointer;background:#6366f1;border:none;border-radius:6px;padding:9px 20px;font-size:13px;font-weight:600}.btn-save-policy:hover{background:#4f46e5}.btn-save-policy:disabled{opacity:.6;cursor:not-allowed}.policy-save-msg{color:#059669;font-size:13px}.modal-overlay{z-index:1000;background:#00000073;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-box{background:#fff;border-radius:10px;width:480px;max-width:96vw;padding:24px}.modal-box h3{color:#111827;margin:0 0 12px;font-size:16px;font-weight:700}.modal-box textarea{resize:vertical;box-sizing:border-box;border:1px solid #d1d5db;border-radius:6px;width:100%;min-height:90px;padding:9px 12px;font-size:13px}.modal-box textarea:focus{border-color:#6366f1;outline:none}.modal-actions{justify-content:flex-end;gap:10px;margin-top:16px;display:flex}.btn-modal-cancel{cursor:pointer;background:#fff;border:1px solid #d1d5db;border-radius:6px;padding:8px 16px;font-size:13px}.btn-modal-confirm{color:#fff;cursor:pointer;background:#dc2626;border:none;border-radius:6px;padding:8px 16px;font-size:13px;font-weight:600}.btn-modal-confirm:disabled{opacity:.6;cursor:not-allowed}.btn-modal-confirm:hover:not(:disabled){background:#b91c1c}.expiry-result{color:#065f46;background:#ecfdf5;border:1px solid #6ee7b7;border-radius:8px;margin-bottom:16px;padding:14px 18px;font-size:13px}.expiry-result strong{margin-bottom:4px;display:block}.ws-sub-page{max-width:900px;margin:0 auto;padding:24px}.ws-sub-page h1{color:#111827;margin:0 0 4px;font-size:22px;font-weight:700}.ws-sub-page .page-subtitle{color:#6b7280;margin-bottom:24px;font-size:13px}.restriction-banner{border-radius:8px;margin-bottom:20px;padding:12px 16px;font-size:13px;font-weight:500}.restriction-banner.warning{color:#92400e;background:#fef3c7;border:1px solid #fcd34d}.restriction-banner.error{color:#991b1b;background:#fee2e2;border:1px solid #fca5a5}.sub-plan-card{background:#fff;border:1px solid #e5e7eb;border-radius:10px;margin-bottom:20px;padding:20px 24px}.sub-plan-card .plan-header{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.sub-plan-card .plan-name{color:#111827;font-size:18px;font-weight:700}.sub-plan-card .plan-price{color:#6b7280;font-size:14px}.trial-countdown{background:#eff6ff;border:1px solid #bfdbfe;border-radius:8px;justify-content:space-between;align-items:center;margin-bottom:18px;padding:14px 18px;display:flex}.trial-countdown .trial-label{color:#1e40af;font-size:13px}.trial-countdown .trial-days{color:#1d4ed8;font-size:24px;font-weight:700}.trial-countdown.trial-urgent{background:#fef3c7;border-color:#fcd34d}.trial-countdown.trial-urgent .trial-label{color:#92400e}.trial-countdown.trial-urgent .trial-days{color:#d97706}.usage-section h2{color:#111827;margin-bottom:14px;font-size:15px;font-weight:700}.usage-row{margin-bottom:14px}.usage-row-header{color:#374151;justify-content:space-between;margin-bottom:5px;font-size:13px;display:flex}.usage-bar-bg{background:#e5e7eb;border-radius:4px;height:8px;overflow:hidden}.usage-bar-fill{background:#6366f1;border-radius:4px;height:100%;transition:width .3s}.usage-bar-fill.near-limit{background:#f59e0b}.usage-bar-fill.at-limit{background:#ef4444}.avail-plans-section h2{color:#111827;margin-bottom:14px;font-size:15px;font-weight:700}.avail-plans-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;margin-bottom:20px;display:grid}.avail-plan-card{cursor:pointer;border:1px solid #e5e7eb;border-radius:9px;padding:16px;transition:border-color .15s,box-shadow .15s}.avail-plan-card:hover{border-color:#6366f1}.avail-plan-card.selected{border-color:#6366f1;box-shadow:0 0 0 2px #6366f126}.avail-plan-card.current{background:#f5f3ff;border-color:#a5b4fc}.avail-plan-card .plan-card-name{color:#111827;margin-bottom:4px;font-size:15px;font-weight:700}.avail-plan-card .plan-card-price{color:#6b7280;margin-bottom:8px;font-size:13px}.avail-plan-card .plan-card-limits{color:#4b5563;font-size:12px}.btn-change-plan{color:#fff;cursor:pointer;background:#6366f1;border:none;border-radius:6px;padding:9px 20px;font-size:13px;font-weight:600}.btn-change-plan:hover{background:#4f46e5}.btn-change-plan:disabled{opacity:.6;cursor:not-allowed}.plan-change-msg{border-radius:7px;margin-top:10px;padding:10px 14px;font-size:13px}.plan-change-msg.success{color:#065f46;background:#d1fae5}.plan-change-msg.error{color:#991b1b;background:#fee2e2}.billing-page{max-width:1100px;padding:28px 32px}.billing-page h1{color:#111827;margin:0 0 4px;font-size:22px;font-weight:700}.page-subtitle{color:#6b7280;margin:0 0 24px;font-size:13px}.billing-card{background:#fff;border:1px solid #e5e7eb;border-radius:10px;margin-bottom:22px;padding:22px 24px}.billing-card h2{color:#111827;margin:0 0 16px;font-size:15px;font-weight:600}.current-invoice-card{flex-direction:column;gap:8px;display:flex}.inv-row{border-bottom:1px solid #f3f4f6;justify-content:space-between;align-items:center;padding:5px 0;font-size:13px;display:flex}.inv-row:last-child{border-bottom:none}.inv-label{color:#6b7280}.inv-value{color:#111827;font-weight:600}.inv-amount-large{color:#111827;font-size:24px;font-weight:700}.pay-badge{letter-spacing:.3px;text-transform:uppercase;border-radius:12px;padding:2px 10px;font-size:11px;font-weight:600;display:inline-block}.pay-badge.unpaid{color:#854d0e;background:#fef9c3}.pay-badge.partially_paid{color:#9a3412;background:#fff7ed}.pay-badge.paid{color:#14532d;background:#dcfce7}.pay-badge.overdue{color:#991b1b;background:#fee2e2}.inv-badge.draft{color:#374151;background:#f3f4f6}.inv-badge.issued{color:#1e40af;background:#eff6ff}.inv-badge.cancelled{color:#991b1b;background:#fee2e2}.inv-badge{text-transform:uppercase;border-radius:12px;padding:2px 10px;font-size:11px;font-weight:600;display:inline-block}.provider-cards{flex-wrap:wrap;gap:14px;display:flex}.provider-card{cursor:pointer;border:1px solid #e5e7eb;border-radius:8px;flex:1;min-width:200px;padding:16px;transition:border-color .15s,box-shadow .15s}.provider-card:hover{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.provider-card.selected{background:#f5f3ff;border-color:#6366f1}.provider-name{color:#111827;margin-bottom:4px;font-size:14px;font-weight:600}.provider-label{color:#6b7280;font-size:12px}.mpesa-instructions{background:#f0fdf4;border:1px solid #86efac;border-radius:8px;margin-top:14px;padding:16px 20px}.mpesa-instructions h3{color:#14532d;margin:0 0 10px;font-size:14px;font-weight:600}.mpesa-step{color:#166534;margin:4px 0;padding-left:12px;font-size:13px}.mpesa-ref-box{color:#111827;background:#fff;border:1px solid #bbf7d0;border-radius:6px;align-items:center;gap:10px;margin-top:10px;padding:10px 14px;font-family:monospace;font-size:14px;font-weight:700;display:flex}.billing-table{border-collapse:collapse;width:100%;font-size:13px}.billing-table th{text-align:left;color:#6b7280;text-transform:uppercase;letter-spacing:.4px;border-bottom:2px solid #f3f4f6;padding:8px 12px;font-size:11px;font-weight:600}.billing-table td{color:#374151;border-bottom:1px solid #f9fafb;padding:10px 12px}.billing-table tr:hover td{background:#fafafa}.billing-table td.mono{font-family:monospace;font-size:12px}.btn-primary{color:#fff;cursor:pointer;background:#6366f1;border:none;border-radius:7px;padding:9px 20px;font-size:13px;font-weight:600;transition:background .15s}.btn-primary:hover:not(:disabled){background:#4f46e5}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{color:#374151;cursor:pointer;background:#fff;border:1px solid #d1d5db;border-radius:7px;padding:8px 16px;font-size:13px;font-weight:500}.btn-danger{color:#dc2626;cursor:pointer;background:#fff;border:1px solid #fca5a5;border-radius:7px;padding:8px 16px;font-size:13px;font-weight:600}.btn-success{color:#fff;cursor:pointer;background:#16a34a;border:none;border-radius:7px;padding:9px 20px;font-size:13px;font-weight:600}.billing-filters{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:16px;display:flex}.billing-filters select,.billing-filters input{color:#374151;background:#fff;border:1px solid #d1d5db;border-radius:6px;padding:7px 11px;font-size:13px}.billing-pagination{color:#6b7280;justify-content:flex-end;align-items:center;gap:8px;margin-top:14px;font-size:13px;display:flex}.billing-pagination button{cursor:pointer;background:#fff;border:1px solid #d1d5db;border-radius:5px;padding:5px 12px;font-size:13px}.billing-pagination button:disabled{opacity:.4;cursor:not-allowed}.billing-modal-overlay{z-index:1000;background:#00000073;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.billing-modal{background:#fff;border-radius:12px;width:440px;max-width:96vw;padding:28px 30px;box-shadow:0 20px 60px #0000002e}.billing-modal h3{color:#111827;margin:0 0 16px;font-size:16px;font-weight:700}.billing-modal label{color:#374151;margin-bottom:5px;font-size:12px;font-weight:600;display:block}.billing-modal input,.billing-modal textarea{box-sizing:border-box;border:1px solid #d1d5db;border-radius:6px;width:100%;margin-bottom:12px;padding:8px 11px;font-size:13px}.billing-modal textarea{resize:vertical;min-height:70px}.billing-modal-actions{justify-content:flex-end;gap:10px;margin-top:4px;display:flex}.billing-msg{border-radius:6px;margin-top:10px;padding:9px 14px;font-size:13px}.billing-msg.success{color:#14532d;background:#dcfce7;border:1px solid #86efac}.billing-msg.error{color:#991b1b;background:#fee2e2;border:1px solid #fca5a5}.billing-msg.info{color:#1e40af;background:#eff6ff;border:1px solid #bfdbfe}.billing-tabs{border-bottom:2px solid #e5e7eb;gap:0;margin-bottom:20px;display:flex}.billing-tab{color:#6b7280;cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-2px;padding:9px 18px;font-size:13px;font-weight:500}.billing-tab.active{color:#6366f1;border-bottom-color:#6366f1;font-weight:600}.billing-empty{text-align:center;color:#9ca3af;padding:36px 0;font-size:13px}.cb-badge{text-transform:uppercase;border-radius:10px;padding:2px 8px;font-size:10px;font-weight:600;display:inline-block}.cb-badge.processed{color:#14532d;background:#dcfce7}.cb-badge.received{color:#1e40af;background:#eff6ff}.cb-badge.duplicate{color:#374151;background:#f3f4f6}.cb-badge.failed{color:#991b1b;background:#fee2e2}.cb-badge.manual_review{color:#92400e;background:#fef3c7}.cb-badge.ignored{color:#9ca3af;background:#f3f4f6}
