:root{--primary:#6366f1;--primary-light:#818cf8;--primary-dark:#4f46e5;--primary-bg:#eef2ff;--pink:#f472b6;--pink-bg:#fdf2f8;--blue:#3b82f6;--blue-bg:#eff6ff;--green:#10b981;--green-bg:#ecfdf5;--orange:#f59e0b;--orange-bg:#fffbeb;--red:#ef4444;--red-bg:#fef2f2;--text-primary:#111827;--text-secondary:#6b7280;--text-muted:#9ca3af;--bg-app:#f8f9fc;--bg-card:#fff;--border:#e5e7eb;--border-light:#f3f4f6;--sidebar-w:240px;--radius:12px;--radius-sm:8px;--shadow-sm:0 1px 3px #0000000f, 0 1px 2px #0000000a;--shadow:0 4px 16px #00000014;--shadow-lg:0 12px 40px #0000001f;--font:"Inter", "Plus Jakarta Sans", sans-serif}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font);background:var(--bg-app);color:var(--text-primary);min-height:100vh;font-size:14px;line-height:1.6}#app{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-w);border-right:1px solid var(--border);z-index:100;box-shadow:var(--shadow-sm);background:#fff;flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-brand{border-bottom:1px solid var(--border-light);align-items:center;gap:10px;padding:1.25rem 1rem;display:flex}.sidebar-logo{object-fit:cover;border-radius:10px;width:40px;height:40px}.sidebar-brand-text{flex-direction:column;line-height:1.2;display:flex}.brand-name{color:var(--text-primary);font-size:.95rem;font-weight:700}.brand-sub{color:var(--primary);letter-spacing:.04em;text-transform:uppercase;font-size:.72rem;font-weight:500}.sidebar-nav{flex-direction:column;flex:1;gap:4px;padding:1rem .75rem;display:flex}.nav-item{border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;align-items:center;gap:10px;padding:.65rem .9rem;font-size:.875rem;font-weight:500;text-decoration:none;transition:all .18s;display:flex}.nav-item:hover{background:var(--primary-bg);color:var(--primary)}.nav-item.active{background:var(--primary);color:#fff;box-shadow:0 4px 12px #6366f14d}.nav-icon{text-align:center;width:20px;font-size:1rem}.sidebar-footer{border-top:1px solid var(--border-light);padding:1rem}.sidebar-footer-text{color:var(--text-muted);text-align:center;font-size:.7rem}.main-content{margin-left:var(--sidebar-w);flex:1;min-height:100vh;padding:2rem}.page{display:none}.page.active{display:block}.page-header{justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.75rem;display:flex}.page-title{color:var(--text-primary);letter-spacing:-.02em;font-size:1.6rem;font-weight:700}.page-subtitle{color:var(--text-secondary);margin-top:2px;font-size:.85rem}.header-actions{flex-wrap:wrap;gap:8px;display:flex}.btn{cursor:pointer;white-space:nowrap;border:none;border-radius:8px;align-items:center;gap:6px;padding:.55rem 1.1rem;font-size:.875rem;font-weight:500;text-decoration:none;transition:all .18s;display:inline-flex}.btn-primary{background:var(--primary);color:#fff;box-shadow:0 2px 8px #6366f140}.btn-primary:hover{background:var(--primary-dark);transform:translateY(-1px);box-shadow:0 4px 16px #6366f159}.btn-outline{color:var(--text-secondary);border:1px solid var(--border);background:#fff}.btn-outline:hover{background:var(--primary-bg);color:var(--primary);border-color:var(--primary-light)}.btn-danger{background:var(--red-bg);color:var(--red);border:1px solid #fecaca}.btn-danger:hover{background:var(--red);color:#fff}.btn-add-row{background:var(--primary-bg);color:var(--primary);border:1.5px dashed var(--primary-light);cursor:pointer;border-radius:8px;width:100%;margin-top:.75rem;padding:.5rem 1rem;font-weight:500;transition:all .18s}.btn-add-row:hover{background:var(--primary);color:#fff;border-color:var(--primary)}.btn-sm{padding:.4rem .8rem;font-size:.8rem}.btn-icon{padding:.5rem .85rem}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1.75rem;display:grid}.stat-card{border-radius:var(--radius);box-shadow:var(--shadow-sm);border:1px solid var(--border);background:#fff;align-items:center;gap:1rem;padding:1.25rem 1.5rem;transition:transform .2s,box-shadow .2s;display:flex}.stat-card:hover{box-shadow:var(--shadow);transform:translateY(-2px)}.stat-icon{border-radius:12px;justify-content:center;align-items:center;width:48px;height:48px;font-size:1.3rem;display:flex}.stat-blue .stat-icon{background:var(--blue-bg)}.stat-green .stat-icon{background:var(--green-bg)}.stat-orange .stat-icon{background:var(--orange-bg)}.stat-pink .stat-icon{background:var(--pink-bg)}.stat-value{color:var(--text-primary);letter-spacing:-.02em;font-size:1.5rem;font-weight:700}.stat-label{color:var(--text-secondary);margin-top:2px;font-size:.78rem}.section-card{border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow-sm);background:#fff;overflow:hidden}.section-card-header{border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;padding:1.1rem 1.5rem;display:flex}.section-title{color:var(--text-primary);font-size:.95rem;font-weight:600}.empty-state{text-align:center;color:var(--text-muted);padding:3rem 1.5rem}.empty-icon{opacity:.6;margin-bottom:.75rem;font-size:2.5rem}.empty-state p{margin-bottom:1rem}.invoice-table-wrapper{overflow-x:auto}.inv-table{border-collapse:collapse;width:100%;font-size:.875rem}.inv-table thead tr{border-bottom:1px solid var(--border)}.inv-table th{text-align:left;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);padding:.8rem 1.25rem;font-size:.75rem;font-weight:600}.inv-table tbody tr{border-bottom:1px solid var(--border-light);cursor:pointer;transition:background .15s}.inv-table tbody tr:hover{background:#f9fafb}.inv-table td{color:var(--text-primary);padding:.85rem 1.25rem}.badge{letter-spacing:.03em;text-transform:uppercase;border-radius:999px;padding:.22rem .65rem;font-size:.72rem;font-weight:600;display:inline-block}.badge-paid{background:var(--green-bg);color:var(--green);border:1px solid #a7f3d0}.badge-partial{background:var(--orange-bg);color:var(--orange);border:1px solid #fde68a}.badge-unpaid{background:var(--red-bg);color:var(--red);border:1px solid #fecaca}.filter-bar{flex-wrap:wrap;gap:.75rem;margin-bottom:1rem;display:flex}.search-input{border:1px solid var(--border);min-width:240px;font-size:.875rem;font-family:var(--font);color:var(--text-primary);background:#fff;border-radius:8px;flex:1;padding:.6rem 1rem;transition:border .18s}.search-input:focus{border-color:var(--primary-light);outline:none;box-shadow:0 0 0 3px #6366f11a}.filter-select{border:1px solid var(--border);font-size:.875rem;font-family:var(--font);color:var(--text-primary);cursor:pointer;background:#fff;border-radius:8px;padding:.6rem .9rem}.invoice-form{flex-direction:column;gap:1.25rem;display:flex}.form-section{border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow-sm);background:#fff;padding:1.5rem}.form-section-title{color:var(--text-primary);align-items:center;gap:.65rem;margin-bottom:1.25rem;font-size:.95rem;font-weight:600;display:flex}.section-badge{background:var(--primary);color:#fff;border-radius:6px;justify-content:center;align-items:center;width:24px;height:24px;font-size:.75rem;font-weight:700;display:flex}.form-grid-3{grid-template-columns:repeat(3,1fr);gap:1rem;display:grid}.form-group{flex-direction:column;gap:.4rem;display:flex}.form-group-full{grid-column:1/-1}.form-group label{color:var(--text-secondary);font-size:.78rem;font-weight:500}.form-input{border:1px solid var(--border);font-size:.875rem;font-family:var(--font);color:var(--text-primary);background:#fff;border-radius:8px;width:100%;padding:.55rem .85rem;transition:border .18s,box-shadow .18s}.form-input:focus{border-color:var(--primary-light);outline:none;box-shadow:0 0 0 3px #6366f11a}.form-input::placeholder{color:var(--text-muted)}.form-textarea{border:1px solid var(--border);font-size:.875rem;font-family:var(--font);color:var(--text-primary);resize:vertical;background:#fff;border-radius:8px;width:100%;min-height:100px;padding:.7rem .9rem;transition:border .18s}.form-textarea:focus{border-color:var(--primary-light);outline:none;box-shadow:0 0 0 3px #6366f11a}.letterhead-preview{border:1px solid var(--border);border-radius:10px;margin-bottom:1.25rem;position:relative;overflow:hidden}.letterhead-img{object-fit:contain;background:#fff;width:100%;max-height:120px;display:block}.letterhead-overlay{background:0 0;justify-content:center;align-items:center;transition:background .2s;display:flex;position:absolute;inset:0}.letterhead-preview:hover .letterhead-overlay{background:#00000026}.upload-overlay-btn{color:var(--text-primary);cursor:pointer;opacity:0;background:#ffffffe6;border-radius:8px;align-items:center;gap:4px;padding:.4rem .9rem;font-size:.8rem;font-weight:500;transition:opacity .2s;display:flex}.letterhead-preview:hover .upload-overlay-btn{opacity:1}.items-table-wrapper{margin:0 -.5rem;overflow-x:auto}.items-table{border-collapse:collapse;width:100%;font-size:.875rem}.items-table th{background:var(--bg-app);text-align:left;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);border-bottom:1px solid var(--border);padding:.65rem .75rem;font-size:.72rem;font-weight:600}.items-table td{border-bottom:1px solid var(--border-light);padding:.5rem}.items-table td input{width:100%;font-size:.875rem;font-family:var(--font);color:var(--text-primary);background:0 0;border:1px solid #0000;border-radius:6px;padding:.45rem .6rem;transition:border .15s,background .15s}.items-table td input:focus{border-color:var(--primary-light);background:var(--primary-bg);outline:none}.items-table td input::placeholder{color:var(--text-muted)}.col-sno{text-align:center;width:52px}.col-service{width:auto}.col-qty{width:80px}.col-rate{width:130px}.col-action{text-align:center;width:44px}.sno-cell{text-align:center;color:var(--text-muted);padding:.45rem 0;font-size:.8rem;font-weight:600;display:block}.btn-remove-row{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;width:28px;height:28px;font-size:1.1rem;transition:all .15s;display:flex}.btn-remove-row:hover{background:var(--red-bg);color:var(--red)}.toggle-row{align-items:center;gap:.75rem;display:flex}.toggle-label{color:var(--text-primary);font-size:.875rem;font-weight:500}.toggle-switch{width:42px;height:24px;display:inline-block;position:relative}.toggle-input{opacity:0;width:0;height:0}.toggle-slider{cursor:pointer;background:#d1d5db;border-radius:999px;transition:background .25s;position:absolute;inset:0}.toggle-slider:before{content:"";background:#fff;border-radius:50%;width:18px;height:18px;transition:transform .25s;position:absolute;bottom:3px;left:3px;box-shadow:0 1px 3px #0003}.toggle-input:checked+.toggle-slider{background:var(--primary)}.toggle-input:checked+.toggle-slider:before{transform:translate(18px)}.gst-options{background:var(--primary-bg);border-radius:8px;flex-wrap:wrap;align-items:flex-end;gap:.75rem;margin-top:.75rem;padding:1rem;display:flex}.gst-options.hidden{display:none}.radio-group{flex-wrap:wrap;align-items:center;gap:1rem;display:flex}.radio-option{color:var(--text-secondary);cursor:pointer;align-items:center;gap:5px;font-size:.85rem;display:flex}.radio-option input{accent-color:var(--primary)}.pricing-layout{grid-template-columns:1fr 1fr;gap:1.5rem;display:grid}.pricing-breakdown{background:var(--bg-app);border:1px solid var(--border);border-radius:10px;padding:1.25rem}.pricing-row{color:var(--text-secondary);justify-content:space-between;align-items:center;padding:.45rem 0;font-size:.875rem;display:flex}.pricing-divider{border:none;border-top:1px solid var(--border);margin:.5rem 0}.pricing-total{color:var(--text-primary);font-size:1.1rem;font-weight:700}.text-orange{color:var(--orange)}.text-red{color:var(--red)}.invoice-preview-card{padding:0}.invoice-print-area{padding:2rem}.inv-letterhead{object-fit:contain;width:100%;max-height:140px;margin-bottom:.5rem;display:block}.inv-divider{border:none;border-top:2px solid var(--primary);margin:.5rem 0 1.5rem}.inv-two-col{grid-template-columns:1fr 1fr;gap:2rem;margin-bottom:1.5rem;display:grid}.inv-info-block h3{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:.5rem;font-size:.72rem;font-weight:600}.inv-info-block p{color:var(--text-primary);font-size:.875rem;line-height:1.8}.inv-info-block .client-name{font-size:1rem;font-weight:700}.inv-meta{gap:2rem;margin-bottom:1.5rem;display:flex}.inv-meta-item label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:2px;font-size:.72rem;display:block}.inv-meta-item span{font-size:.9rem;font-weight:600}.inv-items-table{border-collapse:collapse;width:100%;margin-bottom:1.5rem;font-size:.875rem}.inv-items-table th{background:var(--primary);color:#fff;text-align:left;text-transform:uppercase;letter-spacing:.05em;padding:.7rem 1rem;font-size:.75rem}.inv-items-table td{border-bottom:1px solid var(--border-light);padding:.7rem 1rem}.inv-items-table tbody tr:nth-child(2n){background:var(--bg-app)}.inv-totals{justify-content:flex-end;margin-bottom:1.5rem;display:flex}.inv-totals-box{min-width:280px}.inv-total-row{justify-content:space-between;padding:.4rem 0;font-size:.875rem;display:flex}.inv-grand-total{background:var(--primary);color:#fff;border-radius:8px;justify-content:space-between;margin-top:.5rem;padding:.75rem 1rem;font-size:1rem;font-weight:700;display:flex}.inv-notes{background:var(--bg-app);border-radius:8px;margin-bottom:1.5rem;padding:1rem 1.25rem}.inv-notes h3{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:.5rem;font-size:.72rem}.inv-notes p{color:var(--text-secondary);white-space:pre-wrap;font-size:.875rem}.inv-signature{border-top:1px solid var(--border);justify-content:flex-end;padding-top:1rem;display:flex}.sig-box{text-align:center}.sig-line{border-top:1px solid var(--text-primary);width:160px;margin-top:2.5rem;margin-bottom:.35rem}.sig-label{color:var(--text-muted);font-size:.75rem}.payment-summary{border-bottom:1px solid var(--border-light);grid-template-columns:repeat(4,1fr);gap:1rem;padding:1.25rem 1.5rem;display:grid}.ps-label{color:var(--text-muted);margin-bottom:4px;font-size:.75rem;font-weight:500}.ps-value{color:var(--text-primary);font-size:1.2rem;font-weight:700}.payment-form-wrapper{border-bottom:1px solid var(--border-light);padding:1.25rem 1.5rem}.payment-form-wrapper.hidden{display:none}.payment-form{background:var(--bg-app);border:1px solid var(--border);border-radius:10px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;padding:1.25rem;display:grid}.payment-form-actions{grid-column:1/-1;gap:.75rem;display:flex}.payment-history{padding:1.25rem 1.5rem}.payment-item{background:var(--bg-app);border:1px solid var(--border);border-radius:8px;justify-content:space-between;align-items:center;margin-bottom:.6rem;padding:.85rem 1rem;transition:box-shadow .15s;display:flex}.payment-item:hover{box-shadow:var(--shadow-sm)}.pay-item-left{flex-direction:column;gap:2px;display:flex}.pay-item-mode{color:var(--primary);text-transform:uppercase;letter-spacing:.04em;background:var(--primary-bg);border-radius:4px;margin-bottom:2px;padding:.15rem .6rem;font-size:.75rem;font-weight:600;display:inline-block}.pay-item-ref{color:var(--text-muted);font-size:.78rem}.pay-item-date{color:var(--text-secondary);font-size:.8rem}.pay-item-amount{color:var(--green);font-size:1rem;font-weight:700}.btn-delete-payment{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px 8px;font-size:.9rem;transition:all .15s}.btn-delete-payment:hover{background:var(--red-bg);color:var(--red)}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#00000073;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal-overlay.hidden{display:none}.modal-container{border-radius:var(--radius);width:100%;max-width:860px;max-height:90vh;box-shadow:var(--shadow-lg);background:#fff;flex-direction:column;display:flex;overflow:hidden}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:1.1rem 1.5rem;display:flex}.modal-header h2{font-size:1rem;font-weight:600}.modal-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:4px 8px;font-size:1.1rem;transition:all .15s}.modal-close:hover{background:var(--red-bg);color:var(--red)}.modal-body{flex:1;padding:1.5rem;overflow-y:auto}.modal-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;display:flex}#toast-container{z-index:9999;flex-direction:column;gap:.5rem;display:flex;position:fixed;bottom:1.5rem;right:1.5rem}.toast{background:var(--text-primary);color:#fff;box-shadow:var(--shadow-lg);border-radius:8px;align-items:center;gap:8px;padding:.75rem 1.25rem;font-size:.875rem;animation:.3s slideUp;display:flex}.toast-success{background:var(--green)}.toast-error{background:var(--red)}.toast-info{background:var(--primary)}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}.hidden{display:none!important}.receipt-print-area{max-width:480px;margin:0 auto;padding:2rem}.receipt-title{text-align:center;letter-spacing:.1em;text-transform:uppercase;color:var(--primary);margin-bottom:.25rem;font-size:1.4rem;font-weight:800}.receipt-subtitle{text-align:center;color:var(--text-muted);margin-bottom:1.5rem;font-size:.8rem}.receipt-box{background:var(--primary-bg);border:2px solid var(--primary);border-radius:12px;padding:1.5rem}.receipt-amount{text-align:center;color:var(--primary);margin:.5rem 0 1rem;font-size:2rem;font-weight:800}.receipt-row{border-bottom:1px dashed var(--border);justify-content:space-between;padding:.35rem 0;font-size:.875rem;display:flex}.receipt-row:last-child{border:none}.inv2-body{font-family:var(--font);color:var(--text-primary);padding:2rem 2rem 1.5rem;font-size:.875rem}.inv2-header-cols{justify-content:space-between;align-items:flex-start;gap:2rem;margin-bottom:.75rem;display:flex}.inv2-col{flex:1}.inv2-col-right{text-align:right}.inv2-col-title{color:var(--text-primary);letter-spacing:.01em;margin-bottom:.4rem;font-size:.8rem;font-weight:700}.inv2-col-content{color:var(--text-secondary);font-size:.8rem;line-height:1.75}.inv2-dash{border:none;border-top:1.5px dashed #b0b0b0;margin:.65rem 0}.inv2-dash-light{border:none;border-top:1px dashed #d8d8d8;margin:.35rem 0}.inv2-table{border-collapse:collapse;width:100%;margin:.25rem 0;font-size:.86rem}.inv2-table thead tr{border-top:1.5px dashed #b0b0b0;border-bottom:1.5px dashed #b0b0b0}.inv2-table th{color:var(--text-primary);padding:.5rem .6rem;font-size:.78rem;font-weight:700}.inv2-th-sno{text-align:center;width:9%}.inv2-th-left{text-align:left}.inv2-th-qty{text-align:center;width:10%}.inv2-th-price{text-align:right;width:15%}.inv2-th-amount{text-align:right;width:16%}.inv2-table tbody tr{border-bottom:1px dashed #e4e4e4}.inv2-table tbody tr:last-child{border-bottom:none}.inv2-table td{vertical-align:top;padding:.45rem .6rem}.inv2-td-sno{text-align:center;color:var(--text-secondary)}.inv2-td-left{text-align:left}.inv2-td-qty{text-align:center;color:var(--text-secondary)}.inv2-td-price{text-align:right;color:var(--text-secondary);font-weight:500}.inv2-td-amount{text-align:right;font-weight:600}.inv2-item-desc{color:var(--text-muted);margin-top:2px;font-size:.75rem;font-weight:400;display:block}.inv2-price-table{border-collapse:collapse;width:100%;margin:.1rem 0}.inv2-price-label{color:var(--text-secondary);text-align:left;width:62%;padding:.32rem .6rem .32rem 1.5rem;font-size:.875rem}.inv2-price-amount{text-align:right;letter-spacing:.01em;width:38%;padding:.32rem .25rem;font-size:.9rem;font-weight:600}.inv2-total-label{color:var(--text-primary);font-size:.9rem;font-weight:700}.inv2-total-amount{color:var(--primary);font-size:1rem;font-weight:800}.inv2-notes-title{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:.3rem;font-size:.72rem;font-weight:700}.inv2-notes-content{color:var(--text-secondary);white-space:pre-wrap;font-size:.82rem;line-height:1.6}.inv2-signature{justify-content:flex-end;padding-top:.5rem;display:flex}.btn-tbl-action{border:1px solid var(--border);background:var(--bg-card);font-size:.75rem;font-family:var(--font);cursor:pointer;color:var(--text-secondary);border-radius:6px;align-items:center;gap:3px;margin:0 2px;padding:3px 10px;font-weight:500;transition:all .15s;display:inline-flex}.btn-tbl-view:hover{background:var(--primary-bg);color:var(--primary);border-color:var(--primary-light)}.btn-tbl-edit:hover{color:#d97706;background:#fffbeb;border-color:#fcd34d}label.toggle-switch,.toggle-switch{cursor:pointer}@media (width<=1024px){:root{--sidebar-w:200px}.stats-grid{grid-template-columns:repeat(2,1fr);gap:.75rem}.form-grid-3{grid-template-columns:repeat(2,1fr)}.pricing-layout{grid-template-columns:1fr}.main-content{padding:1.25rem}.page-header{gap:.75rem}.header-actions{flex-wrap:wrap;gap:.5rem}.header-actions .btn{flex:1;min-width:100px}}@media (width<=768px){.sidebar{width:56px;overflow:hidden}.sidebar-brand{justify-content:center;padding:.75rem 0}.sidebar-logo{width:32px;height:32px}.sidebar-brand-text,.sidebar-footer-text{display:none}.nav-item{justify-content:center;gap:0;padding:.85rem 0}.nav-item span:last-child{display:none}.nav-item .nav-icon{font-size:1.1rem}.main-content{margin-left:56px;padding:.875rem}.page-header{flex-direction:column;align-items:flex-start;gap:.75rem;padding-bottom:.75rem}.page-header>div:first-child{width:100%}.header-actions{flex-wrap:wrap;gap:.5rem;width:100%;display:flex}.header-actions .btn{flex:calc(50% - .25rem);min-width:0;font-size:.8rem}.stats-grid{grid-template-columns:repeat(2,1fr);gap:.6rem}.stat-card{padding:.875rem}.stat-value{font-size:1.3rem}.form-grid-3{grid-template-columns:1fr;gap:.75rem}.form-group-full{grid-column:span 1}.section-card{padding:1rem}.form-section{margin-bottom:.75rem;padding:1rem}.items-table-wrapper{-webkit-overflow-scrolling:touch;overflow-x:auto}.items-table{min-width:520px}.pricing-layout{grid-template-columns:1fr;gap:1rem}.pricing-right{margin-top:.5rem}.pricing-breakdown{max-width:100%}.gst-options{flex-direction:column;align-items:flex-start}.payment-summary{grid-template-columns:repeat(2,1fr);gap:.6rem}.invoice-table-wrapper{overflow-x:auto}.invoice-table{min-width:600px}#page-detail .page-header{flex-direction:column;align-items:flex-start}#page-detail .header-actions .btn{padding:.4rem .7rem;font-size:.78rem}.invoice-preview-card{padding:.5rem;overflow-x:auto}.invoice-preview-card>div{min-width:480px}.filter-bar{flex-direction:column;gap:.6rem}.search-input,.filter-select{width:100%}.modal-container{width:96%;max-height:90vh;padding:1rem}.modal-footer{flex-wrap:wrap;gap:.5rem}.modal-footer .btn{flex:1}#page-detail .page-header>div:first-child{flex-wrap:wrap;gap:.5rem}.btn{padding:.45rem .9rem;font-size:.82rem}.btn-sm{padding:.3rem .6rem;font-size:.75rem}}@media (width<=480px){.main-content{padding:.625rem}.stats-grid{grid-template-columns:1fr 1fr;gap:.5rem}.stat-card{padding:.75rem .6rem}.stat-value{font-size:1.1rem}.stat-label{font-size:.7rem}.page-title{font-size:1.1rem}.page-subtitle{font-size:.75rem}.header-actions .btn{flex:100%}.invoice-preview-card>div{min-width:440px}.payment-summary{grid-template-columns:1fr 1fr}.ps-value{font-size:.95rem}.section-badge{width:22px;height:22px;font-size:.7rem}.form-section-title{font-size:.85rem}}.auth-page{background:var(--bg-app);justify-content:center;align-items:center;min-height:100vh;display:flex}.auth-card{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;width:100%;max-width:420px;padding:2.5rem;box-shadow:0 8px 32px #00000014}.auth-logo{text-align:center;margin-bottom:1rem}.auth-title{text-align:center;color:var(--text-primary);margin:0 0 .25rem;font-size:1.5rem;font-weight:700}.auth-subtitle{text-align:center;color:var(--text-muted);margin:0 0 1.5rem;font-size:.875rem}.auth-form{flex-direction:column;gap:1rem;display:flex}.auth-footer{text-align:center;color:var(--text-muted);margin-top:1rem;font-size:.875rem}.auth-footer a{color:var(--primary);font-weight:500;text-decoration:none}.alert{border-radius:8px;margin-bottom:.5rem;padding:.75rem 1rem;font-size:.875rem}.alert-error{color:#dc2626;background:#fef2f2;border:1px solid #fecaca}.w-full{justify-content:center;width:100%}.text-green{color:var(--green)}.app-loading{min-height:100vh;color:var(--text-muted);justify-content:center;align-items:center;font-size:1.1rem;display:flex}.btn-logout{color:var(--text-muted);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:6px;width:100%;margin-top:.5rem;padding:.4rem .75rem;font-size:.8rem;transition:all .15s}.btn-logout:hover{background:var(--red-bg);color:var(--red)}.toast{border-radius:10px;padding:.75rem 1.25rem;font-size:.875rem;font-weight:500;box-shadow:0 4px 16px #0000001f}.toast-success{color:#fff;background:#10b981}
