:root{--bg: #f0f4f8;--white: #ffffff;--sidebar: #1a2e4a;--sidebar-hover: #243d61;--sidebar-active: #1e56a0;--accent: #1e56a0;--accent-hover: #174186;--text: #0f1923;--text-muted: #4a5568;--text-dim: #718096;--border: #d1dce8;--green: #15803d;--green-bg: #dcfce7;--red: #b91c1c;--red-bg: #fee2e2;--orange: #c2410c;--orange-bg: #ffedd5;--shadow: 0 2px 8px rgba(0,0,0,.08);--shadow-lg: 0 8px 24px rgba(0,0,0,.12);--radius: 12px}*{margin:0;padding:0;box-sizing:border-box}body{background:var(--bg);color:var(--text);font-family:Inter,sans-serif;font-size:16px}.auth-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a2e4a,#1e56a0);padding:20px}.auth-card{background:#fff;border-radius:20px;padding:40px;width:100%;max-width:440px;box-shadow:var(--shadow-lg)}.auth-logo{text-align:center;margin-bottom:28px}.auth-logo-name{font-size:28px;font-weight:800;color:var(--accent)}.auth-logo-sub{font-size:14px;color:var(--text-muted);margin-top:4px}.auth-title{font-size:22px;font-weight:800;margin-bottom:6px}.auth-sub{font-size:14px;color:var(--text-muted);margin-bottom:24px}.auth-form{display:flex;flex-direction:column;gap:16px}.form-group{display:flex;flex-direction:column;gap:6px}.form-label{font-size:14px;font-weight:700;color:var(--text-muted)}.form-input{border:2px solid var(--border);border-radius:10px;padding:12px 14px;font-size:15px;font-family:Inter,sans-serif;color:var(--text);outline:none;transition:border-color .15s;background:#f8fafc;width:100%}.form-input:focus{border-color:var(--accent);background:#fff}.form-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.auth-btn{background:var(--accent);color:#fff;border:none;border-radius:10px;padding:14px;font-size:16px;font-weight:700;cursor:pointer;font-family:Inter,sans-serif;transition:background .15s;width:100%;margin-top:4px}.auth-btn:hover{background:var(--accent-hover)}.auth-btn:disabled{opacity:.6;cursor:not-allowed}.auth-link{text-align:center;font-size:14px;color:var(--text-muted);margin-top:16px}.auth-link a{color:var(--accent);font-weight:700;text-decoration:none}.auth-error{background:var(--red-bg);color:var(--red);border:2px solid #fca5a5;border-radius:10px;padding:12px 14px;font-size:14px;font-weight:600}.ref-box{background:linear-gradient(135deg,#1a2e4a,#1e56a0);border-radius:14px;padding:24px;text-align:center;margin:20px 0}.ref-label{font-size:13px;color:#fff9;font-weight:600;letter-spacing:.08em;text-transform:uppercase}.ref-code{font-size:32px;font-weight:800;color:#fff;font-family:JetBrains Mono,monospace;letter-spacing:.12em;margin:8px 0}.ref-copy{font-size:13px;color:#ffffff80}.pending-wrap{min-height:100vh;background:var(--bg);display:flex;align-items:center;justify-content:center;padding:20px}.pending-card{background:#fff;border-radius:20px;padding:36px;width:100%;max-width:520px;box-shadow:var(--shadow-lg);text-align:center}.pending-icon{font-size:56px;margin-bottom:16px}.pending-title{font-size:24px;font-weight:800;margin-bottom:8px}.pending-sub{font-size:15px;color:var(--text-muted);margin-bottom:24px;line-height:1.6}.steps{text-align:left;background:#f8fafc;border-radius:12px;padding:20px 24px;margin:20px 0}.step{display:flex;gap:14px;align-items:flex-start;padding:10px 0;border-bottom:1px solid var(--border)}.step:last-child{border-bottom:none}.step-num{width:28px;height:28px;border-radius:50%;background:var(--accent);color:#fff;font-size:13px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px}.step-text{font-size:14px;font-weight:600;color:var(--text);line-height:1.5}.step-text span{color:var(--accent);font-family:JetBrains Mono,monospace;font-weight:800}.momo-number{font-size:26px;font-weight:800;color:var(--accent);font-family:JetBrains Mono,monospace;background:#f0f6ff;border-radius:10px;padding:14px 20px;display:inline-block;margin:10px 0;border:2px solid var(--border)}.setup-wrap{min-height:100vh;background:var(--bg);display:flex;align-items:center;justify-content:center;padding:20px}.setup-card{background:#fff;border-radius:20px;padding:40px;width:100%;max-width:500px;box-shadow:var(--shadow-lg)}.app-layout{display:flex;min-height:100vh}.sidebar{width:260px;min-height:100vh;background:var(--sidebar);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100}.logo-area{padding:28px 24px 22px;border-bottom:1px solid rgba(255,255,255,.1)}.logo-name{font-size:22px;font-weight:800;color:#fff}.logo-prop{font-size:13px;color:#ffffff80;margin-top:4px;font-weight:500}.nav{padding:20px 0;flex:1}.nav-btn{display:flex;align-items:center;gap:14px;padding:16px 24px;cursor:pointer;color:#ffffffa6;font-size:16px;font-weight:600;transition:all .15s;border:none;border-left:4px solid transparent;background:none;width:100%;text-align:left;font-family:Inter,sans-serif}.nav-btn:hover{background:var(--sidebar-hover);color:#fff}.nav-btn.active{background:var(--sidebar-active);color:#fff;border-left-color:#60a5fa}.nav-icon{font-size:22px;width:28px;text-align:center;flex-shrink:0}.sidebar-bottom{padding:20px 24px;border-top:1px solid rgba(255,255,255,.1)}.prop-box{background:#ffffff14;border-radius:10px;padding:14px 16px}.prop-stat-row{display:flex;gap:16px;margin-top:10px}.prop-stat{font-size:13px;color:#ffffff80}.prop-stat strong{font-size:18px;color:#fff;font-family:JetBrains Mono,monospace;display:block}.logout-btn{background:none;border:none;color:#fff6;font-size:13px;font-weight:600;cursor:pointer;padding:12px 0 0;font-family:Inter,sans-serif;text-align:left}.logout-btn:hover{color:#fff}.main{margin-left:260px;flex:1;display:flex;flex-direction:column;min-height:100vh}.topbar{background:var(--white);border-bottom:2px solid var(--border);padding:0 32px;height:72px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:50;box-shadow:var(--shadow)}.page-title{font-size:22px;font-weight:800;color:var(--text)}.topbar-right{display:flex;gap:12px;align-items:center}.btn{padding:12px 22px;border-radius:10px;font-size:15px;font-weight:700;cursor:pointer;border:none;font-family:Inter,sans-serif;transition:all .15s;display:inline-flex;align-items:center;gap:8px}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover)}.btn-outline{background:#fff;color:var(--text-muted);border:2px solid var(--border)}.btn-outline:hover{border-color:var(--accent);color:var(--accent)}.btn-green{background:var(--green);color:#fff}.btn-green:hover{background:#166534}.btn-red{background:var(--red);color:#fff}.btn-red:hover{background:#991b1b}.btn-sm{padding:9px 16px;font-size:14px}.btn:disabled{opacity:.6;cursor:not-allowed}.content{padding:28px 32px}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:28px}.stat-card{background:var(--white);border-radius:var(--radius);padding:22px 24px;box-shadow:var(--shadow);border:2px solid var(--border)}.stat-icon{font-size:28px;margin-bottom:10px}.stat-label{font-size:13px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px}.stat-value{font-size:26px;font-weight:800;color:var(--text);font-family:JetBrains Mono,monospace;line-height:1}.stat-value.blue{color:var(--accent)}.stat-value.green{color:var(--green)}.stat-value.red{color:var(--red)}.stat-sub{font-size:13px;color:var(--text-dim);margin-top:8px;font-weight:500}.sec-title{font-size:19px;font-weight:800;color:var(--text);margin-bottom:16px}.card{background:var(--white);border-radius:var(--radius);border:2px solid var(--border);box-shadow:var(--shadow);overflow:hidden;margin-bottom:24px}.card-head{padding:18px 24px;border-bottom:2px solid var(--border);display:flex;align-items:center;justify-content:space-between;background:#f8fafc}.card-title{font-size:17px;font-weight:700}.card-meta{font-size:14px;color:var(--text-muted);font-weight:600}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse}thead th{padding:13px 18px;text-align:left;font-size:13px;font-weight:700;color:var(--text-muted);background:#f8fafc;border-bottom:2px solid var(--border);white-space:nowrap;text-transform:uppercase;letter-spacing:.05em}tbody tr{border-bottom:2px solid var(--border);cursor:pointer;transition:background .1s}tbody tr:last-child{border-bottom:none}tbody tr:hover{background:#f0f6ff}td{padding:16px 18px;font-size:15px;color:var(--text);white-space:nowrap}.flat-badge{width:44px;height:44px;border-radius:10px;background:#e8f0fb;color:var(--accent);font-weight:800;font-size:16px;display:flex;align-items:center;justify-content:center;font-family:JetBrains Mono,monospace}.tenant-name{font-weight:700;font-size:15px}.tenant-phone{font-size:13px;color:var(--text-dim);font-family:JetBrains Mono,monospace;margin-top:3px}.mono{font-family:JetBrains Mono,monospace;font-weight:600}.col-green{color:var(--green)}.col-red{color:var(--red)}.col-blue{color:var(--accent)}.pill{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:99px;font-size:13px;font-weight:700}.pill-green{background:var(--green-bg);color:var(--green)}.pill-red{background:var(--red-bg);color:var(--red)}.pill-orange{background:var(--orange-bg);color:var(--orange)}.pill-grey{background:#f1f5f9;color:var(--text-dim)}.pill-dot{width:7px;height:7px;border-radius:50%;background:currentColor}.action-row{display:flex;gap:6px}.icon-btn{width:38px;height:38px;border-radius:8px;border:2px solid var(--border);background:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;color:var(--text-muted);transition:all .15s}.icon-btn:hover{background:#f0f6ff;border-color:var(--accent);color:var(--accent)}.icon-btn.danger:hover{background:var(--red-bg);border-color:var(--red);color:var(--red)}.bill-settings{background:var(--white);border:2px solid var(--border);border-radius:var(--radius);padding:24px 28px;margin-bottom:24px;box-shadow:var(--shadow)}.bill-input-label{font-size:14px;font-weight:700;color:var(--text-muted);margin-bottom:8px}.bill-input{width:100%;border:2px solid var(--border);border-radius:10px;padding:12px 16px;font-size:18px;font-weight:700;font-family:JetBrains Mono,monospace;color:var(--text);outline:none;transition:border-color .15s;background:#f8fafc}.bill-input:focus{border-color:var(--accent);background:#fff}.bill-split-info{font-size:13px;color:var(--text-dim);margin-top:6px;font-weight:500}.split-result{font-size:15px;font-weight:800;color:var(--accent);font-family:JetBrains Mono,monospace}.month-tabs{display:flex;gap:10px;margin-bottom:20px;flex-wrap:wrap}.month-tab{padding:12px 22px;border-radius:10px;font-size:15px;font-weight:700;cursor:pointer;border:2px solid var(--border);background:#fff;color:var(--text-muted);transition:all .15s;font-family:Inter,sans-serif}.month-tab.active{background:var(--accent);color:#fff;border-color:var(--accent)}.month-tab:hover:not(.active){border-color:var(--accent);color:var(--accent)}.month-header{display:grid;grid-template-columns:220px repeat(12,1fr) 130px;gap:6px;padding:10px 24px;background:#f8fafc;border-bottom:2px solid var(--border)}.month-header div{font-size:12px;font-weight:700;color:var(--text-muted);text-align:center;text-transform:uppercase}.month-header div:first-child{text-align:left}.month-header div:last-child{text-align:right}.bill-row-grid{display:grid;grid-template-columns:220px repeat(12,1fr) 130px;gap:6px;align-items:center;padding:14px 24px;border-bottom:2px solid var(--border);transition:background .1s}.bill-row-grid:last-child{border-bottom:none}.bill-row-grid:hover{background:#f8fafc}.bill-tenant-name{font-size:15px;font-weight:700}.bill-tenant-flat{font-size:12px;color:var(--text-dim);font-family:JetBrains Mono,monospace;margin-top:2px}.month-cell{height:36px;border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:700;cursor:pointer;transition:all .15s;border:2px solid transparent}.month-cell.paid{background:var(--green-bg);color:var(--green);border-color:#86efac}.month-cell.unpaid{background:var(--red-bg);color:var(--red);border-color:#fca5a5}.month-cell.future{background:#f1f5f9;color:#cbd5e1;cursor:default;font-size:18px}.month-cell:hover:not(.future){transform:scale(1.12);box-shadow:0 2px 8px #00000026}.owed-label{text-align:right;font-family:JetBrains Mono,monospace;font-size:15px;font-weight:700}.overdue-big{display:flex;flex-direction:column;gap:12px}.overdue-item{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:var(--red-bg);border:2px solid #fca5a5;border-radius:10px}.overdue-item-name{font-size:16px;font-weight:700}.overdue-item-flat{font-size:14px;color:var(--red);font-family:JetBrains Mono,monospace;font-weight:600}.overdue-item-amt{font-size:20px;font-weight:800;color:var(--red);font-family:JetBrains Mono,monospace}.clear-box{text-align:center;padding:28px;font-size:18px;font-weight:700;color:var(--green)}.two-col{display:grid;grid-template-columns:1fr 1fr;gap:20px}.progress-item{margin-bottom:18px}.progress-label{display:flex;justify-content:space-between;font-size:15px;font-weight:600;margin-bottom:8px}.progress-label span:last-child{color:var(--accent);font-family:JetBrains Mono,monospace}.progress-track{height:12px;background:#e2e8f0;border-radius:6px;overflow:hidden}.progress-fill{height:100%;border-radius:6px;background:var(--accent)}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f192a99;z-index:200;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal{background:var(--white);border-radius:16px;width:620px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg)}.modal-head{padding:22px 28px;border-bottom:2px solid var(--border);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;background:var(--white);z-index:10}.modal-title{font-size:20px;font-weight:800}.modal-close{width:40px;height:40px;border-radius:10px;border:2px solid var(--border);background:#fff;cursor:pointer;font-size:18px;color:var(--text-muted);display:flex;align-items:center;justify-content:center;transition:all .15s}.modal-close:hover{background:var(--red-bg);border-color:var(--red);color:var(--red)}.modal-body{padding:24px 28px}.modal-foot{padding:18px 28px;border-top:2px solid var(--border);display:flex;justify-content:flex-end;gap:12px;position:sticky;bottom:0;background:var(--white)}.form-section{margin-bottom:24px}.form-sec-title{font-size:14px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;margin-bottom:14px;padding-bottom:10px;border-bottom:2px solid var(--border)}.form-grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px}.pay-big-input{width:100%;border:3px solid var(--accent);border-radius:12px;padding:16px 20px;font-size:28px;font-weight:800;font-family:JetBrains Mono,monospace;color:var(--text);outline:none;text-align:center;margin:16px 0}.toast{position:fixed;bottom:28px;right:28px;z-index:400;color:#fff;border-radius:10px;padding:14px 22px;font-size:16px;font-weight:700;display:flex;align-items:center;gap:10px;box-shadow:var(--shadow-lg);animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(80px);opacity:0}to{transform:translateY(0);opacity:1}}.toast.success{background:var(--green)}.toast.error{background:var(--red)}.toast.info{background:var(--accent)}.admin-wrap{min-height:100vh;background:var(--bg)}.admin-topbar{background:var(--sidebar);color:#fff;padding:0 32px;height:68px;display:flex;align-items:center;justify-content:space-between}.admin-logo{font-size:20px;font-weight:800}.admin-content{padding:28px 32px;max-width:1100px;margin:0 auto}.status-pill{display:inline-flex;align-items:center;gap:5px;padding:4px 12px;border-radius:99px;font-size:12px;font-weight:700}.status-active{background:var(--green-bg);color:var(--green)}.status-pending{background:var(--orange-bg);color:var(--orange)}.status-suspended{background:var(--red-bg);color:var(--red)}.tip-wrap{position:relative;display:inline-flex}.tip-wrap .tip-text{visibility:hidden;opacity:0;position:absolute;bottom:calc(100% + 10px);left:50%;transform:translate(-50%);background:#1a2e4a;color:#fff;padding:8px 14px;border-radius:8px;font-size:13px;font-weight:600;white-space:nowrap;z-index:500;pointer-events:none;transition:opacity .15s;box-shadow:var(--shadow-lg)}.tip-wrap .tip-text:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:#1a2e4a}.tip-wrap:hover .tip-text{visibility:visible;opacity:1}.pro-badge{display:inline-flex;align-items:center;gap:4px;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;font-size:11px;font-weight:800;padding:2px 8px;border-radius:99px;letter-spacing:.05em}.plan-card{border:2px solid var(--border);border-radius:14px;padding:20px 22px;cursor:pointer;transition:all .15s;background:#fff;position:relative}.plan-card:hover{border-color:var(--accent)}.plan-card.selected{border-color:var(--accent);background:#f0f6ff}.plan-card .save-tag{position:absolute;top:-11px;right:14px;background:var(--green);color:#fff;font-size:11px;font-weight:800;padding:3px 10px;border-radius:99px}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#f1f5f9}::-webkit-scrollbar-thumb{background:#94a3b8;border-radius:4px}@media (max-width: 768px){.sidebar{width:100%;height:auto;min-height:auto;position:fixed;top:auto;bottom:0;left:0;right:0;flex-direction:row;z-index:200;box-shadow:0 -3px 12px #00000026}.logo-area,.sidebar-bottom{display:none}.nav{display:flex;flex-direction:row;padding:0;flex:1}.nav-btn{flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:8px 4px 6px;font-size:11px;font-weight:700;border-left:none!important;border-top:3px solid transparent;flex:1;text-align:center}.nav-btn.active{border-left:none!important;border-top:3px solid #60a5fa}.nav-icon{font-size:20px;width:auto}.main{margin-left:0;padding-bottom:76px}.topbar{padding:0 16px;height:58px}.page-title{font-size:17px}.topbar-right .btn-outline{display:none}.btn{padding:10px 16px;font-size:14px}.btn-sm{padding:8px 12px;font-size:13px}.content{padding:14px}.stats-grid{grid-template-columns:1fr 1fr;gap:10px;margin-bottom:16px}.stat-card{padding:14px}.stat-icon{font-size:20px;margin-bottom:5px}.stat-label{font-size:11px}.stat-value{font-size:20px}.stat-sub{font-size:11px;margin-top:5px}.sec-title{font-size:16px;margin-bottom:10px}.two-col{grid-template-columns:1fr}.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}td,thead th{padding:11px 10px;font-size:13px}.bill-settings{padding:14px}.bill-input{font-size:16px;padding:11px 12px}.month-tabs{flex-wrap:nowrap;overflow-x:auto;padding-bottom:4px;-webkit-overflow-scrolling:touch}.month-tab{flex-shrink:0;padding:10px 14px;font-size:14px}.card-head{padding:12px 14px;flex-direction:column;align-items:flex-start;gap:3px}.month-header,.bill-row-grid{display:flex;overflow-x:auto;-webkit-overflow-scrolling:touch;gap:4px;padding:8px 12px;min-width:0}.month-header{align-items:center;background:#f8fafc;border-bottom:2px solid var(--border)}.month-header>div{flex-shrink:0;width:36px;text-align:center;font-size:11px}.month-header>div:first-child{width:120px;text-align:left}.month-header>div:last-child{width:80px;text-align:right}.bill-row-grid{align-items:center;border-bottom:2px solid var(--border)}.bill-row-grid>div:first-child{flex-shrink:0;width:120px}.bill-row-grid>.month-cell{flex-shrink:0;width:36px}.bill-row-grid>.owed-label{flex-shrink:0;width:80px}.month-cell{height:32px;font-size:13px;border-radius:6px}.modal{width:96vw!important;max-height:88vh}.modal-body,.modal-head{padding:14px 16px}.modal-foot{padding:12px 16px}.form-grid2{grid-template-columns:1fr;gap:12px}.overdue-item{flex-direction:column;gap:6px;align-items:flex-start}.pay-big-input{font-size:22px;padding:12px 16px}.action-row{gap:4px}.icon-btn{width:34px;height:34px;font-size:14px}.flat-badge{width:38px;height:38px;font-size:14px}.admin-content{padding:16px}.admin-topbar{padding:0 16px}}
