@import "https://fonts.googleapis.com/css2?family=Noto+Sans+Sinhala:wght@300;400;500;600;700&family=Outfit:wght@300;400;500;600;700&display=swap";:root{--primary:#10b77f;--primary-hover:#0d9668;--primary-light:#ecfdf8;--secondary:#f43e63;--secondary-hover:#f21843;--secondary-light:#fef1f3;--neutral:#65758b;--neutral-light:#f1f5f9;--bg-gradient:linear-gradient(135deg, #f8fafc 0%, #eef1f6 100%);--card-bg:#ffffffd9;--card-border:#ffffff80;--text-dark:#0f1729;--text-muted:#65758b;--border-color:#e1e7ef;--radius-sm:8px;--radius-md:14px;--radius-lg:20px;--shadow-sm:0 2px 8px #0000000a;--shadow-md:0 8px 30px #0000000f;--shadow-lg:0 12px 40px #0000001a;--transition:all .25s cubic-bezier(.4, 0, .2, 1);--sidebar-width:260px;--font-family:"Outfit", "Noto Sans Sinhala", system-ui, -apple-system, sans-serif}*{box-sizing:border-box;font-family:var(--font-family);-webkit-font-smoothing:antialiased;margin:0;padding:0}body{background:var(--bg-gradient);color:var(--text-dark);min-height:100vh;overflow-x:hidden}button,input,select,textarea{font-family:var(--font-family)}.app-container{width:100vw;min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-right:1px solid var(--border-color);z-index:100;height:100vh;transition:var(--transition);background:#ffffffe6;flex-direction:column;padding:24px 16px;display:flex;position:fixed;top:0;left:0}.brand-section{border-bottom:1px solid var(--border-color);align-items:center;gap:12px;margin-bottom:24px;padding-bottom:24px;display:flex}.brand-logo{background:var(--primary);border-radius:var(--radius-sm);color:#fff;justify-content:center;align-items:center;width:42px;height:42px;font-size:20px;font-weight:700;display:flex;box-shadow:0 4px 12px #10b9814d}.brand-name{color:var(--primary);font-size:17px;font-weight:700;line-height:1.2}.brand-subtitle{color:var(--text-muted);font-size:11px;font-weight:500}.nav-menu{flex-direction:column;flex-grow:1;gap:6px;padding-right:4px;list-style:none;display:flex;overflow-y:auto}.nav-menu::-webkit-scrollbar{width:4px}.nav-menu::-webkit-scrollbar-thumb{background:#0000001a;border-radius:2px}.nav-item{color:var(--text-dark);border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);align-items:center;gap:12px;padding:12px 16px;font-size:14px;font-weight:500;text-decoration:none;display:flex}.nav-item svg{width:18px;height:18px;stroke:var(--text-muted);transition:var(--transition)}.nav-item:hover{background:var(--neutral-light);color:var(--primary)}.nav-item:hover svg{stroke:var(--primary)}.nav-item.active{background:var(--primary);color:#fff;box-shadow:0 4px 15px #10b98133}.nav-item.active svg{stroke:#fff}.user-badge{border-top:1px solid var(--border-color);flex-direction:column;gap:8px;margin-top:16px;padding-top:16px;display:flex}.user-info{align-items:center;gap:10px;display:flex}.user-avatar{background:var(--neutral-light);width:36px;height:36px;color:var(--text-dark);border:2px solid var(--primary);border-radius:50%;justify-content:center;align-items:center;font-weight:600;display:flex}.user-details{flex-direction:column;display:flex}.user-name{color:var(--text-dark);white-space:nowrap;text-overflow:ellipsis;max-width:150px;font-size:13px;font-weight:600;overflow:hidden}.user-role{color:var(--text-muted);text-transform:uppercase;font-size:11px;font-weight:500}.logout-btn{border:1px solid var(--border-color);border-radius:var(--radius-sm);width:100%;color:var(--secondary);cursor:pointer;transition:var(--transition);background:0 0;justify-content:center;align-items:center;gap:8px;padding:10px;font-size:13px;font-weight:600;display:flex}.logout-btn:hover{background:var(--secondary-light);border-color:var(--secondary)}.main-content{margin-left:var(--sidebar-width);min-height:100vh;transition:var(--transition);flex-grow:1;padding:40px}.mobile-header{border-bottom:1px solid var(--border-color);z-index:99;background:#fff;padding:16px 20px;display:none;position:sticky;top:0}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:30px;display:flex}.page-title-group{flex-direction:column;gap:4px;display:flex}.page-title{color:var(--text-dark);font-size:28px;font-weight:700;position:relative}.page-subtitle{color:var(--text-muted);font-size:14px}.card{background:var(--card-bg);-webkit-backdrop-filter:blur(16px);border:1px solid var(--card-border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);transition:var(--transition);margin-bottom:24px;padding:24px}.card:hover{box-shadow:var(--shadow-md)}.card-title{color:var(--text-dark);border-bottom:1px solid var(--border-color);align-items:center;gap:8px;margin-bottom:18px;padding-bottom:10px;font-size:17px;font-weight:600;display:flex}.metrics-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;margin-bottom:24px;display:grid}.metric-card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);transition:var(--transition);justify-content:space-between;align-items:center;padding:20px;display:flex}.metric-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.metric-card.primary{border-left:5px solid var(--primary)}.metric-card.secondary{border-left:5px solid var(--secondary)}.metric-card.neutral{border-left:5px solid var(--neutral)}.metric-info{flex-direction:column;gap:6px;display:flex}.metric-label{color:var(--text-muted);font-size:13px;font-weight:600}.metric-value{color:var(--text-dark);font-size:24px;font-weight:700}.metric-icon-box{border-radius:12px;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.metric-card.primary .metric-icon-box{background:var(--primary-light);color:var(--primary)}.metric-card.secondary .metric-icon-box{background:var(--secondary-light);color:var(--secondary)}.metric-card.neutral .metric-icon-box{background:var(--neutral-light);color:var(--neutral)}.btn{border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);border:none;justify-content:center;align-items:center;gap:8px;padding:10px 20px;font-size:14px;font-weight:600;text-decoration:none;display:inline-flex}.btn-primary{background:var(--primary);color:#fff;box-shadow:0 4px 12px #10b98133}.btn-primary:hover{background:var(--primary-hover);box-shadow:0 6px 16px #10b9814d}.btn-secondary{background:var(--secondary);color:#fff;box-shadow:0 4px 12px #f43f5e33}.btn-secondary:hover{background:var(--secondary-hover);box-shadow:0 6px 16px #f43f5e4d}.btn-neutral{border:1px solid var(--border-color);color:var(--text-dark);background:#fff}.btn-neutral:hover{background:var(--neutral-light)}.btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:none!important;transform:none!important}.form-group{flex-direction:column;gap:6px;margin-bottom:16px;display:flex}.form-label{color:var(--text-dark);font-size:13px;font-weight:600}.form-control{border:1px solid var(--border-color);border-radius:var(--radius-sm);width:100%;color:var(--text-dark);transition:var(--transition);background:#fff;outline:none;padding:10px 14px;font-size:14px}.form-control:focus{border-color:var(--primary);box-shadow:0 0 0 3px #10b9811f}.form-control::placeholder{color:#a0aec0}.form-row{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:8px;display:grid}.filter-bar{border:1px solid var(--border-color);border-radius:var(--radius-md);background:#fff;grid-template-columns:repeat(auto-fit,minmax(180px,1fr)) auto;align-items:flex-end;gap:14px;margin-bottom:24px;padding:16px;display:grid}.table-container{border-radius:var(--radius-sm);border:1px solid var(--border-color);background:#fff;width:100%;overflow-x:auto}.table{border-collapse:collapse;text-align:left;width:100%;font-size:14px}.table th{background:var(--neutral-light);color:var(--text-dark);border-bottom:2px solid var(--border-color);white-space:nowrap;padding:14px 16px;font-size:13px;font-weight:600}.table td{border-bottom:1px solid var(--border-color);color:var(--text-dark);vertical-align:middle;padding:14px 16px}.table tbody tr:last-child td{border-bottom:none}.table tbody tr:hover{background:var(--primary-light)}.badge{border-radius:50px;align-items:center;padding:4px 10px;font-size:11px;font-weight:600;display:inline-flex}.badge-active{background:var(--primary-light);color:var(--primary)}.badge-inactive,.badge-cancelled,.badge-unpaid{background:var(--secondary-light);color:var(--secondary)}.badge-partial{color:#d97706;background:#fef3c7}.badge-paid{background:var(--primary-light);color:var(--primary)}.bill-section-title{color:var(--text-dark);justify-content:space-between;align-items:center;margin-top:24px;margin-bottom:12px;font-size:15px;font-weight:600;display:flex}.bill-summary-grid{background:var(--neutral-light);border-radius:var(--radius-sm);border:1px solid var(--border-color);grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-top:24px;padding:18px;display:grid}.summary-item{flex-direction:column;gap:4px;display:flex}.summary-label{color:var(--text-muted);font-size:12px;font-weight:600}.summary-value{color:var(--text-dark);font-size:16px;font-weight:700}.summary-value.highlight-green{color:var(--primary);font-size:18px}.summary-value.highlight-red{color:var(--secondary);font-size:18px}.billing-table-input{border:1px solid var(--border-color);border-radius:6px;outline:none;width:100%;padding:6px 10px;font-size:14px}.billing-table-input:focus{border-color:var(--primary)}.billing-remove-row-btn{color:var(--secondary);cursor:pointer;transition:var(--transition);background:0 0;border:none;justify-content:center;align-items:center;display:flex}.billing-remove-row-btn:hover{transform:scale(1.15)}.modal-overlay{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:200;background:#0f172a66;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal-content{border-radius:var(--radius-md);box-shadow:var(--shadow-lg);background:#fff;width:100%;max-width:600px;max-height:90vh;animation:.3s cubic-bezier(.16,1,.3,1) modalReveal;overflow-y:auto}.modal-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:18px 24px;display:flex}.modal-header-title{color:var(--text-dark);font-size:16px;font-weight:600}.modal-close-btn{cursor:pointer;color:var(--text-muted);background:0 0;border:none}.modal-body{padding:24px}.modal-footer{border-top:1px solid var(--border-color);justify-content:flex-end;gap:12px;padding:16px 24px;display:flex}@keyframes modalReveal{0%{opacity:0;transform:translateY(15px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}@media (width<=768px){.desktop-only-view{display:none!important}.mobile-only-view{display:block!important}}@media (width>=769px){.desktop-only-view{display:block!important}.mobile-only-view{display:none!important}}.blocking-password-overlay{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:1000;background:#0f172ad9;justify-content:center;align-items:center;width:100vw;height:100vh;padding:20px;display:flex;position:fixed;top:0;left:0}.blocking-card{border-radius:var(--radius-md);width:100%;max-width:500px;box-shadow:var(--shadow-lg);border:2px solid var(--secondary);background:#fff;padding:30px}.blocking-title{color:var(--secondary);align-items:center;gap:10px;margin-bottom:10px;font-size:20px;font-weight:700;display:flex}.blocking-desc{color:var(--text-dark);margin-bottom:20px;font-size:14px;line-height:1.5}@media (width<=1024px){:root{--sidebar-width:220px}}@media (width<=768px){body{-webkit-overflow-scrolling:touch;overflow-x:hidden}.app-container{flex-direction:column}.sidebar{display:none!important}.main-content{margin-left:0!important;padding:12px 12px 150px!important}.mobile-header{box-shadow:var(--shadow-sm);z-index:100;background:#fff;justify-content:space-between;align-items:center;padding:12px 16px;display:flex;position:sticky;top:0}.logout-btn-header{white-space:nowrap;padding:6px 10px!important;font-size:11px!important}.page-header{gap:8px;margin-bottom:14px}.page-title{line-height:1.2;font-size:20px!important}.page-subtitle{font-size:12px}.card{border-radius:var(--radius-sm);margin-bottom:12px;padding:14px!important}.card-title{font-size:15px}.filter-bar{gap:10px;padding:12px;grid-template-columns:1fr!important}.form-row{gap:10px;margin-bottom:0;grid-template-columns:1fr!important}.form-group{margin-bottom:12px}.form-control{min-height:48px;padding:12px 14px!important;font-size:16px!important}select.form-control{min-height:48px}textarea.form-control{min-height:80px}.form-label{font-size:13px}.btn{white-space:nowrap;min-height:46px;padding:12px 16px!important;font-size:14px!important}.btn-block-mobile{width:100%!important}.metrics-grid{gap:10px;grid-template-columns:1fr 1fr!important}.metric-card{padding:14px}.metric-value{font-size:18px}.metric-label{font-size:12px}.metric-icon-box{width:36px;height:36px}.bill-summary-grid{gap:10px;padding:12px;grid-template-columns:1fr 1fr!important}.summary-label{font-size:11px}.summary-value{font-size:14px}.summary-value.highlight-green,.summary-value.highlight-red{font-size:16px}.table-container{-webkit-overflow-scrolling:touch;border-radius:var(--radius-sm);overflow-x:auto}.table th,.table td{white-space:nowrap;padding:10px 12px;font-size:13px}.table-container.responsive-mobile-cards{background:0 0;border:none;overflow-x:visible}.table-container.responsive-mobile-cards .table{display:block}.table-container.responsive-mobile-cards .table thead{display:none}.table-container.responsive-mobile-cards .table tbody{flex-direction:column;gap:12px;display:flex}.table-container.responsive-mobile-cards .table tr{border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);background:#fff;padding:14px;display:block}.table-container.responsive-mobile-cards .table tr:hover{box-shadow:var(--shadow-md);background:#fff}.table-container.responsive-mobile-cards .table td{white-space:normal;border-bottom:1px solid #f1f5f9;justify-content:space-between;align-items:flex-start;gap:8px;padding:7px 0;font-size:13px;display:flex}.table-container.responsive-mobile-cards .table td:last-child{border-bottom:none;padding-bottom:0}.table-container.responsive-mobile-cards .table td:before{content:attr(data-label);color:var(--text-muted);flex-shrink:0;min-width:90px;font-size:12px;font-weight:600}.table-container.responsive-mobile-cards .table td:last-child{flex-wrap:wrap;justify-content:flex-end;gap:6px}.table-container.responsive-mobile-cards .table td:last-child:before{display:none}.modal-overlay{align-items:flex-end;padding:0}.modal-content{border-radius:20px 20px 0 0;max-height:88vh;width:100%!important;max-width:100%!important}.modal-header,.modal-body{padding:14px 16px}.modal-footer{flex-direction:column-reverse;gap:8px;padding:12px 16px}.modal-footer .btn{width:100%}.daily-bill-tabs{flex-wrap:wrap;gap:6px;display:flex}.daily-bill-tabs .btn{flex:1;min-width:140px;padding:10px 12px!important;font-size:12px!important}.bill-success-card{max-width:100%!important;padding:20px!important}.success-badge-circle{width:50px;height:50px;margin-bottom:14px;font-size:26px}.mobile-sticky-save-bar{gap:10px;padding:10px 14px}.sticky-bill-label{font-size:10px}.sticky-bill-amount{font-size:16px}.mobile-bottom-nav{height:62px;padding-bottom:env(safe-area-inset-bottom,0px);display:flex}.bottom-nav-item{padding:6px 0}.bottom-nav-item .nav-icon{font-size:20px}.bottom-nav-item .nav-label{font-size:10px}.drawer-grid{grid-template-columns:repeat(3,1fr);gap:10px;padding:16px}.drawer-grid-item{min-height:72px;padding:12px 8px}.drawer-item-icon{font-size:20px}.drawer-item-label{font-size:10px;font-weight:600}.blocking-card{max-width:calc(100% - 24px);margin:12px;padding:20px}.blocking-title{font-size:16px}.badge{white-space:nowrap;padding:3px 8px;font-size:10px}.page-header,.form-group,.card,.filter-bar{max-width:100%;overflow:hidden}.billing-table-input{min-height:42px;font-size:16px!important}.bill-section-title{margin-top:16px;margin-bottom:8px;font-size:13px}}@media (width<=375px){.main-content{padding:10px 10px 150px!important}.page-title{font-size:18px!important}.metrics-grid,.bill-summary-grid{grid-template-columns:1fr!important}.btn{padding:11px 12px!important;font-size:13px!important}.card{padding:12px!important}.form-control{font-size:16px!important}.drawer-grid{grid-template-columns:repeat(3,1fr);gap:8px;padding:12px}.drawer-item-label{font-size:9px}}.mobile-bottom-nav{-webkit-backdrop-filter:blur(12px);border-top:1px solid var(--border-color);z-index:500;background:#fffffff2;justify-content:space-around;align-items:center;height:62px;display:none;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -4px 20px #0000000d}@media (width<=768px){.mobile-bottom-nav{display:flex}}.bottom-nav-item{color:var(--text-muted);cursor:pointer;transition:var(--transition);font-family:var(--font-family);background:0 0;border:none;outline:none;flex-direction:column;flex:1;justify-content:center;align-items:center;padding:6px 0;display:flex}.bottom-nav-item .nav-icon{filter:grayscale(.2);margin-bottom:2px;font-size:18px}.bottom-nav-item .nav-label{letter-spacing:.2px;font-size:10px;font-weight:600}.bottom-nav-item.active{color:var(--primary)}.bottom-nav-item.active .nav-icon{filter:none;transform:scale(1.1)}.more-drawer{z-index:600;background:#fff;border-top-left-radius:24px;border-top-right-radius:24px;flex-direction:column;transition:transform .3s cubic-bezier(.16,1,.3,1);display:flex;position:fixed;bottom:0;left:0;right:0;transform:translateY(100%);box-shadow:0 -10px 40px #0f172a26}.more-drawer.open{transform:translateY(0)}.drawer-handle{cursor:pointer;background:#cbd5e1;border-radius:10px;width:48px;height:5px;margin:12px auto 6px}.drawer-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:10px 24px;display:flex}.drawer-header h4{color:var(--text-dark);font-size:15px;font-weight:700}.close-drawer-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;font-size:18px}.drawer-grid{grid-template-columns:repeat(3,1fr);gap:12px;padding:20px;display:grid}.drawer-grid-item{background:var(--neutral-light);border-radius:var(--radius-sm);border:1px solid var(--border-color);cursor:pointer;transition:var(--transition);flex-direction:column;justify-content:center;align-items:center;padding:14px 8px;display:flex}.drawer-grid-item:active{transform:scale(.95)}.drawer-grid-item.active{background:var(--primary-light);border-color:var(--primary);color:var(--primary)}.drawer-item-icon{margin-bottom:4px;font-size:22px}.drawer-item-label{text-align:center;font-size:11px;font-weight:700}.drawer-backdrop{-webkit-backdrop-filter:blur(4px);z-index:550;background:#0f172a66;animation:.2s ease-out fadeIn;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.mobile-sticky-save-bar{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-top:1px solid var(--border-color);z-index:450;background:#ffffffe6;justify-content:space-between;align-items:center;padding:12px 20px;display:flex;position:fixed;bottom:62px;left:0;right:0;box-shadow:0 -4px 15px #0000000a}@media (width>=769px){.mobile-sticky-save-bar{display:none!important}}.sticky-bill-info{flex-direction:column;display:flex}.sticky-bill-label{color:var(--text-muted);font-size:11px;font-weight:600}.sticky-bill-amount{color:var(--primary);font-size:18px;font-weight:800}.bill-success-card{border-radius:var(--radius-md);width:100%;max-width:450px;box-shadow:var(--shadow-lg);text-align:center;background:#fff;padding:30px}.success-badge-circle{background:var(--primary-light);width:64px;height:64px;color:var(--primary);border-radius:50%;justify-content:center;align-items:center;margin:0 auto 20px;font-size:32px;display:flex;box-shadow:0 4px 15px #10b98126}
