
:root{--red:#dc2626;--dark:#111827;--muted:#64748b;--line:#e5e7eb;--soft:#fff5f5;--green:#047857;--orange:#b45309}
*{box-sizing:border-box}html,body{max-width:100%;overflow-x:hidden}body{font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;background:#f8fafc;color:#111827}a{text-decoration:none}.tg-nav{background:#111827;color:#fff;border-bottom:1px solid rgba(255,255,255,.08)}.tg-nav-inner{max-width:1320px;margin:auto;padding:14px 18px;display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}.tg-brand{font-weight:950;color:#fff;font-size:20px;display:flex;align-items:center;gap:10px}.tg-brand img{width:38px;height:38px;object-fit:contain;background:#fff;border-radius:10px;padding:4px}.tg-nav-actions{display:flex;gap:8px;flex-wrap:wrap}.tg-nav-actions a,.tg-nav-actions button{border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.08);color:#fff;border-radius:12px;padding:9px 12px;font-weight:800}.tg-page{max-width:1320px;margin:auto;padding:28px 18px 70px}.tg-card{background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:0 12px 30px rgba(15,23,42,.06);overflow:hidden}.tg-card-head{padding:16px 18px;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap}.tg-card-head h3,.tg-card-head h4,.tg-card-head h5{margin:0;font-weight:950}.tg-card-body{padding:18px}.tg-grid{display:grid;gap:18px}.tg-grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}.tg-grid.three{grid-template-columns:repeat(3,minmax(0,1fr))}.tg-grid.four{grid-template-columns:repeat(4,minmax(0,1fr))}.metric{background:#fff;border:1px solid var(--line);border-radius:18px;padding:18px;box-shadow:0 12px 28px rgba(15,23,42,.05)}.metric small{color:var(--muted);font-weight:900;text-transform:uppercase;letter-spacing:.04em}.metric strong{display:block;font-size:30px;font-weight:950;letter-spacing:-.05em}.btn-red{border:none;background:linear-gradient(135deg,#ff5f66,#b91c1c);color:#fff;border-radius:12px;padding:10px 13px;font-weight:900}.btn-darkx{border:none;background:#111827;color:#fff;border-radius:12px;padding:10px 13px;font-weight:900}.btn-soft{border:1px solid var(--line);background:#fff;color:#111827;border-radius:12px;padding:10px 13px;font-weight:900}.btn-green{border:none;background:#047857;color:#fff;border-radius:12px;padding:10px 13px;font-weight:900}.btn-orange{border:none;background:#b45309;color:#fff;border-radius:12px;padding:10px 13px;font-weight:900}.form-control,.form-select{border-radius:12px;border:1px solid var(--line);min-height:44px}.badge-soft{border-radius:999px;padding:7px 10px;font-weight:900;background:#f1f5f9;color:#334155}.badge-green{background:#ecfdf5;color:#065f46}.badge-red{background:#fef2f2;color:#991b1b}.badge-orange{background:#fffbeb;color:#92400e}.badge-blue{background:#eff6ff;color:#1e3a8a}.alertbox{border-radius:16px;padding:14px 16px;border:1px solid var(--line);background:#fff}.alertbox.info{background:#eff6ff;color:#1e3a8a;border-color:#bfdbfe}.alertbox.warning{background:#fffbeb;color:#92400e;border-color:#fde68a}.alertbox.urgent,.alertbox.danger{background:#fef2f2;color:#991b1b;border-color:#fecaca}.alertbox.success{background:#ecfdf5;color:#065f46;border-color:#bbf7d0}.money-line{display:flex;justify-content:space-between;gap:12px;padding:6px 0;border-bottom:1px solid #f1f5f9}.money-line.total{font-size:20px;font-weight:950;color:#b91c1c;border-top:2px solid var(--line);margin-top:8px;padding-top:10px}.money-line.paid{font-weight:900;color:#047857}.money-line.due{font-weight:900;color:#b45309}.progress-steps{display:grid;grid-template-columns:repeat(6,1fr);gap:8px}.step{background:#f1f5f9;color:#64748b;border-radius:999px;padding:8px 10px;text-align:center;font-size:12px;font-weight:950}.step.done{background:#ecfdf5;color:#047857}.step.active{background:#fee2e2;color:#991b1b}.timeline{border-left:2px solid #dbe3ef;padding-left:18px}.timeline-item{position:relative;margin-bottom:16px}.timeline-item:before{content:"";position:absolute;left:-25px;top:5px;width:12px;height:12px;border-radius:50%;background:#dc2626;box-shadow:0 0 0 4px rgba(220,38,38,.12)}.chatbox{height:320px;overflow:auto;background:#f8fafc;border:1px solid var(--line);border-radius:14px;padding:12px;display:flex;flex-direction:column;gap:8px}.msg{max-width:80%;padding:10px 12px;border-radius:14px;background:#e5e7eb}.msg.admin{background:#0d6efd;color:#fff;align-self:flex-end;text-align:right}.msg.customer{background:#e5e7eb;color:#111827;align-self:flex-start}.msg small{display:block;opacity:.75;margin-top:3px}.table-wrap{overflow-x:auto}.table{min-width:780px}.popup-wrap{position:fixed;right:18px;top:18px;z-index:9999;display:flex;flex-direction:column;gap:10px;max-width:min(410px,calc(100vw - 36px))}.popup{background:#111827;color:#fff;border-radius:14px;padding:14px 16px;box-shadow:0 18px 45px rgba(15,23,42,.25);opacity:0;transform:translateY(-8px);transition:.2s}.popup.show{opacity:1;transform:translateY(0)}.popup.error{background:#7f1d1d}.popup.success{background:#064e3b}.item-row{display:grid;grid-template-columns:1fr 90px 120px 42px;gap:8px;align-items:center;border-bottom:1px solid #eef2f7;padding:8px 0}.simple-row{display:grid;grid-template-columns:1fr 42px;gap:8px;align-items:center;border-bottom:1px solid #eef2f7;padding:8px 0}.icon-btn{width:38px;height:38px;border:none;border-radius:10px;background:#ef4444;color:#fff}.filter-row{display:flex;gap:10px;flex-wrap:wrap}.filter-row button{border:1px solid var(--line);background:#fff;border-radius:999px;padding:8px 12px;font-weight:900}.filter-row button.active{background:#111827;color:#fff}.invoice-shell{max-width:980px;margin:26px auto;background:#fff;border-radius:24px;overflow:hidden;box-shadow:0 24px 80px rgba(15,23,42,.16)}.invoice-head{background:linear-gradient(135deg,#111827,#7f1d1d);color:#fff;padding:36px}.invoice-body{padding:34px}.paid-stamp,.due-stamp{display:inline-flex;border:3px solid currentColor;border-radius:12px;padding:8px 14px;font-weight:950;font-size:18px;transform:rotate(-2deg)}.paid-stamp{color:#047857}.due-stamp{color:#b45309}.print-actions{max-width:980px;margin:16px auto;display:flex;justify-content:flex-end;gap:8px;flex-wrap:wrap}@media(max-width:900px){.tg-grid.two,.tg-grid.three,.tg-grid.four{grid-template-columns:1fr}.progress-steps{grid-template-columns:repeat(2,1fr)}.item-row{grid-template-columns:1fr}.simple-row{grid-template-columns:1fr}.icon-btn{width:100%}.tg-nav-inner{align-items:stretch}.tg-nav-actions a,.tg-nav-actions button{flex:1 1 auto;text-align:center}.chatbox{height:280px}.msg{max-width:92%}.popup-wrap{left:12px;right:12px;top:12px;max-width:none}.print-actions{margin:10px}.print-actions .btn-soft,.print-actions .btn-darkx{width:100%;text-align:center}.invoice-shell{margin:10px;border-radius:18px}.invoice-head{padding:24px 18px}.invoice-body{padding:18px}.control-stack>*{width:100%}.filter-row{overflow-x:auto;flex-wrap:nowrap}.filter-row button{white-space:nowrap}.table{min-width:760px}}@media print{.tg-nav,.print-actions,.popup-wrap{display:none!important}body{background:#fff}.invoice-shell{box-shadow:none;margin:0;max-width:100%;border-radius:0}.invoice-head{print-color-adjust:exact;-webkit-print-color-adjust:exact}}
