@import url('https://fonts.googleapis.com/css2?family=Roboto:wght@400;500;700;900&display=swap');
:root {
  --brand-blue: #0b60d0;
  --brand-red: #d92945;
  --brand-white: #ffffff;
  --ink: #122033;
  --muted: #6c7a92;
  --bg: #f4f7fb;
  --card: rgba(255,255,255,0.95);
  --border: rgba(11, 96, 208, 0.10);
  --success: #0f9d58;
  --warning: #f29900;
  --danger: #d93025;
  --shadow: 0 18px 40px rgba(12, 42, 94, 0.10);
  --gradient: linear-gradient(135deg, #0b60d0 0%, #4ab0ff 38%, #ffffff 55%, #ff9bb0 75%, #d92945 100%);
}
* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; font-family: "Roboto", Arial, Helvetica, sans-serif; color: var(--ink); background: var(--bg); }
body { line-height: 1.45; }
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
button, input, select, textarea { font: inherit; }
.mt-1 { margin-top: 8px; }
.mt-2 { margin-top: 12px; }
.mt-3 { margin-top: 20px; }
.text-muted { color: var(--muted); }
.w-100 { width: 100%; }
.small { font-size: 13px; }
body.login-body {
  min-height: 100vh;
  background:
    radial-gradient(circle at top left, rgba(74,176,255,0.60), transparent 28%),
    radial-gradient(circle at bottom right, rgba(217,41,69,0.25), transparent 28%),
    #eef5ff;
}
.login-wrap { min-height: 100vh; display: grid; grid-template-columns: 1.15fr 0.85fr; }
.login-side {
  padding: 56px; color: #fff;
  background: linear-gradient(135deg, rgba(11,96,208,0.96), rgba(217,41,69,0.88));
  display: flex; flex-direction: column; justify-content: space-between;
}
.login-side h1 { font-size: 42px; line-height: 1.1; margin: 0 0 12px; }
.login-side p { color: rgba(255,255,255,0.92); max-width: 560px; font-size: 16px; }
.login-badges { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 26px; }
.badge-pill { background: rgba(255,255,255,0.12); border: 1px solid rgba(255,255,255,0.18); padding: 10px 14px; border-radius: 999px; font-size: 14px; }
.login-card-wrap { display: grid; place-items: center; padding: 32px; }
.login-card {
  width: 100%; max-width: 440px; background: rgba(255,255,255,0.96);
  border: 1px solid rgba(255,255,255,0.65); border-radius: 28px; box-shadow: var(--shadow); padding: 28px;
}
.login-card h2 { margin: 0 0 8px; font-size: 28px; }
.login-card .meta { color: var(--muted); margin-bottom: 20px; }
.app-shell { min-height: 100vh; display: grid; grid-template-columns: 280px 1fr; }
.sidebar {
  background: linear-gradient(180deg, #0d2d66 0%, #0b60d0 48%, #d92945 100%);
  color: #fff; padding: 20px; position: sticky; top: 0; height: 100vh;
}
.brand { display: flex; align-items: center; gap: 14px; padding: 12px 10px 22px; border-bottom: 1px solid rgba(255,255,255,0.18); margin-bottom: 18px; }
.brand-mark {
  width: 52px; height: 52px; border-radius: 18px;
  background: linear-gradient(135deg, #ffffff, rgba(255,255,255,0.2));
  color: var(--brand-blue); display: grid; place-items: center; font-weight: 800; font-size: 20px;
}
.brand-title { font-size: 18px; font-weight: 800; line-height: 1.2; }
.brand-sub { font-size: 12px; color: rgba(255,255,255,0.78); margin-top: 4px; }
.nav-group { display: grid; gap: 8px; }
.nav-link {
  padding: 14px 16px; border-radius: 18px; display: flex; align-items: center; justify-content: space-between;
  color: rgba(255,255,255,0.90); transition: 0.2s ease; border: 1px solid rgba(255,255,255,0.06);
}
.nav-link:hover, .nav-link.active { background: rgba(255,255,255,0.15); color: #fff; transform: translateX(3px); }
.sidebar-footer {
  position: absolute; bottom: 22px; left: 20px; right: 20px;
  background: rgba(255,255,255,0.12); border-radius: 20px; padding: 16px; border: 1px solid rgba(255,255,255,0.12);
}
.sidebar-footer small { color: rgba(255,255,255,0.76); }
.main { padding: 24px; }
.topbar {
  display: flex; justify-content: space-between; align-items: center; gap: 16px;
  padding: 18px 22px; border-radius: 28px; background: var(--gradient); box-shadow: var(--shadow); margin-bottom: 22px;
}
.topbar h1 { margin: 0; font-size: 28px; }
.topbar p { margin: 4px 0 0; color: #3c4862; }
.topbar .user-box { background: rgba(255,255,255,0.74); padding: 14px 18px; border-radius: 18px; min-width: 220px; text-align: right; }
.alerts { display: grid; gap: 10px; margin-bottom: 18px; }
.alert { padding: 14px 16px; border-radius: 16px; border: 1px solid transparent; background: #fff; }
.alert-success { border-color: rgba(15,157,88,0.20); color: #0f6e41; }
.alert-info { border-color: rgba(11,96,208,0.15); color: #0b60d0; }
.alert-danger { border-color: rgba(217,48,37,0.18); color: #a32018; }
.alert-warning { border-color: rgba(242,153,0,0.20); color: #9b6300; }
.grid { display: grid; gap: 18px; }
.grid-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.grid-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.grid-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.card { background: var(--card); border: 1px solid var(--border); border-radius: 26px; padding: 20px; box-shadow: var(--shadow); }
.card-title { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 14px; }
.card-title h2, .card-title h3 { margin: 0; }
.card-title p { margin: 4px 0 0; color: var(--muted); }
.metric-card { padding: 22px; position: relative; overflow: hidden; }
.metric-card:after { content: ""; position: absolute; inset: auto -15% -40% auto; width: 120px; height: 120px; border-radius: 50%; background: linear-gradient(135deg, rgba(11,96,208,0.12), rgba(217,41,69,0.08)); }
.metric-label { color: var(--muted); font-size: 14px; }
.metric-value { font-size: 34px; font-weight: 800; margin: 8px 0 0; }
.metric-sub { font-size: 13px; color: var(--muted); }
.kv-list, .report-list { display: grid; gap: 12px; }
.kv-item, .report-item { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 14px 16px; border-radius: 18px; background: rgba(11,96,208,0.04); }
.empty { padding: 16px; border-radius: 18px; background: rgba(11,96,208,0.04); color: var(--muted); text-align: center; }
.table-wrap { overflow: auto; }
.table { width: 100%; border-collapse: collapse; min-width: 980px; }
.table th, .table td { padding: 14px 12px; text-align: left; border-bottom: 1px solid rgba(11,96,208,0.08); vertical-align: top; }
.table th { font-size: 13px; color: var(--muted); font-weight: 700; }
.table td strong { display: inline-block; margin-bottom: 4px; }
.table tr:hover td { background: rgba(11,96,208,0.015); }
.toolbar, .actions { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.toolbar form { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.form-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 16px; }
.form-group { display: grid; gap: 8px; }
.form-group.full { grid-column: 1 / -1; }
label { font-size: 14px; font-weight: 700; }
input, select, textarea { width: 100%; border-radius: 16px; border: 1px solid rgba(11,96,208,0.15); background: #fff; padding: 12px 14px; outline: none; }
textarea { min-height: 112px; resize: vertical; }
input:focus, select:focus, textarea:focus { border-color: rgba(11,96,208,0.42); box-shadow: 0 0 0 4px rgba(11,96,208,0.08); }
.btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; padding: 12px 16px; border-radius: 14px; border: 0; cursor: pointer; font-weight: 700; transition: 0.2s ease; }
.btn:hover { transform: translateY(-1px); }
.btn-primary { background: linear-gradient(135deg, var(--brand-blue), #4ab0ff); color: #fff; }
.btn-danger { background: linear-gradient(135deg, #d92945, #ff7a90); color: #fff; }
.btn-light { background: #fff; color: var(--ink); border: 1px solid rgba(11,96,208,0.1); }
.btn-success { background: linear-gradient(135deg, #0f9d58, #43c37d); color: #fff; }
.btn-ghost { background: rgba(11,96,208,0.06); color: var(--brand-blue); }
.btn-sm { padding: 10px 12px; font-size: 13px; }
.pill { display: inline-flex; align-items: center; justify-content: center; padding: 8px 10px; border-radius: 999px; font-size: 12px; font-weight: 700; white-space: nowrap; }
.pill.blue { background: rgba(11,96,208,0.10); color: #0b60d0; }
.pill.red { background: rgba(217,41,69,0.12); color: #bf1335; }
.pill.green { background: rgba(15,157,88,0.12); color: #0f8a4e; }
.pill.orange { background: rgba(242,153,0,0.13); color: #ac6b00; }
.pill.gray { background: rgba(108,122,146,0.12); color: #52627b; }
.property-card { display: grid; grid-template-columns: 160px 1fr; gap: 14px; padding: 14px; border-radius: 22px; background: rgba(11,96,208,0.04); }
.property-card img { height: 124px; width: 100%; object-fit: cover; border-radius: 18px; background: #eaf0f7; }
.property-card h3 { margin: 8px 0 4px; }
.hero-tip { padding: 16px 18px; border-radius: 18px; background: rgba(11,96,208,0.05); border: 1px dashed rgba(11,96,208,0.14); }
@media (max-width: 1200px) { .grid-4 { grid-template-columns: repeat(2, minmax(0, 1fr)); } .grid-3 { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (max-width: 980px) {
  .app-shell { grid-template-columns: 1fr; }
  .sidebar { position: relative; height: auto; }
  .sidebar-footer { position: static; margin-top: 18px; }
  .login-wrap { grid-template-columns: 1fr; }
}
@media (max-width: 760px) {
  .main { padding: 16px; }
  .grid-4, .grid-3, .grid-2, .form-grid { grid-template-columns: 1fr; }
  .topbar { flex-direction: column; align-items: flex-start; }
  .topbar .user-box { width: 100%; text-align: left; min-width: 0; }
  .property-card { grid-template-columns: 1fr; }
}
.form-grid-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.inline-check { display: inline-flex; align-items: center; gap: 8px; padding: 8px 12px; background: rgba(11,96,208,0.04); border-radius: 12px; }
.inline-check input { width: auto; }
code { background: rgba(11,96,208,0.06); padding: 3px 6px; border-radius: 8px; }
@media (max-width: 760px) {
  .form-grid-3 { grid-template-columns: 1fr; }
}


.stat-grid { display:grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap: 16px; }
.stat-box { background: rgba(11,96,208,0.05); border: 1px solid rgba(11,96,208,0.08); border-radius: 18px; padding: 16px; }
.stat-box .number { font-size: 30px; font-weight: 800; margin-top: 4px; }
.multiselect-box { min-height: 220px; }
.payment-option-row { border: 1px solid rgba(11,96,208,0.10); background: rgba(11,96,208,0.03); border-radius: 20px; padding: 16px; margin-bottom: 14px; }
.summary-inline { display:flex; gap: 8px; flex-wrap: wrap; }
.mini-note { font-size: 12px; color: var(--muted); }
.program-option-list { display:grid; gap: 8px; }
.program-option-item { padding: 10px 12px; border-radius: 14px; background: rgba(11,96,208,0.05); }
.price-stack strong { display:block; }
@media (max-width: 760px) { .stat-grid { grid-template-columns: 1fr; } }

.nav-group { margin-bottom: 140px; }
.form-grid-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.adjustment-row, .payment-option-row { border: 1px solid rgba(11,96,208,0.10); background: rgba(11,96,208,0.03); border-radius: 20px; padding: 16px; margin-bottom: 14px; }
.adjustment-list { display:grid; gap: 10px; }
.adjustment-item { padding: 12px 14px; border-radius: 14px; background: rgba(217,41,69,0.04); border: 1px solid rgba(217,41,69,0.08); }
.adjustment-item .head, .option-summary .head { display:flex; align-items:center; justify-content:space-between; gap:10px; margin-bottom:6px; }
.option-summary-list { display:grid; gap: 12px; }
.option-summary { padding: 14px; border-radius: 16px; background: rgba(11,96,208,0.04); border: 1px solid rgba(11,96,208,0.08); }
.option-summary .meta-line { display:flex; gap:10px; flex-wrap:wrap; margin-top:6px; }
.quick-grid { display:grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap:16px; }
.selector-list { display:grid; gap:10px; max-height:280px; overflow:auto; padding:4px; }
.selector-item { display:flex; align-items:flex-start; gap:10px; padding:12px; border-radius:14px; background: rgba(11,96,208,0.04); border: 1px solid rgba(11,96,208,0.08); }
.selector-item input { width:auto; margin-top:3px; }
.selector-item small { display:block; color: var(--muted); margin-top:2px; }
.helper-box { padding: 12px 14px; border-radius: 14px; background: rgba(11,96,208,0.05); border: 1px dashed rgba(11,96,208,0.14); }
.cart-group { margin-top: 20px; }
.cart-group-head { display:flex; align-items:center; justify-content:space-between; gap:12px; margin-bottom:12px; }
.cart-grid { display:grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap:16px; }
.cart-card { background:#fff; border:1px solid rgba(11,96,208,0.1); border-radius:20px; padding:16px; box-shadow: 0 10px 24px rgba(12,42,94,0.06); }
.cart-card .top { display:flex; justify-content:space-between; gap:12px; align-items:flex-start; }
.cart-card .title { font-size:18px; font-weight:800; margin-bottom:3px; }
.cart-card .price-main { font-size:24px; font-weight:800; margin-top:10px; }
.cart-card .line { display:flex; gap:10px; flex-wrap:wrap; margin-top:8px; }
.tag { display:inline-flex; align-items:center; gap:6px; padding:8px 10px; border-radius:999px; background: rgba(11,96,208,0.06); color: var(--brand-blue); font-size:12px; font-weight:700; }
.tag.red { background: rgba(217,41,69,0.08); color: var(--brand-red); }
.tag.green { background: rgba(15,157,88,0.10); color: var(--success); }
.tag.orange { background: rgba(242,153,0,0.12); color: var(--warning); }
.card-split { display:grid; grid-template-columns: 1.2fr 0.8fr; gap:16px; }
.tiny-list { display:grid; gap:8px; }
.tiny-item { padding:10px 12px; border-radius:12px; background: rgba(11,96,208,0.04); }
.option-mini-list { display:grid; gap:8px; margin-top:12px; }
.option-mini { padding:10px 12px; border-radius:14px; background: rgba(11,96,208,0.04); }
.table .wide-cell { min-width: 240px; }
@media (max-width: 980px) {
  .cart-grid, .quick-grid, .card-split, .form-grid-4 { grid-template-columns: 1fr; }
}

.cart-legend { display:flex; gap:10px; flex-wrap:wrap; }
.legend-item { display:inline-flex; align-items:center; gap:8px; padding:8px 12px; border-radius:999px; font-size:12px; font-weight:700; border:1px solid transparent; }
.legend-item.available { background: rgba(15,157,88,0.10); color: #0a7a43; border-color: rgba(15,157,88,0.15); }
.legend-item.booked { background: rgba(242,153,0,0.14); color: #b46900; border-color: rgba(242,153,0,0.16); }
.legend-item.deposit { background: rgba(11,96,208,0.10); color: var(--brand-blue); border-color: rgba(11,96,208,0.14); }
.legend-item.sold { background: rgba(217,41,69,0.10); color: var(--brand-red); border-color: rgba(217,41,69,0.14); }
.legend-item.off { background: rgba(104,117,140,0.12); color: #526174; border-color: rgba(104,117,140,0.16); }
.cart-group.table-mode { background:#fff; border:1px solid rgba(11,96,208,0.08); border-radius:20px; padding:16px; box-shadow: 0 10px 24px rgba(12,42,94,0.05); }
.cart-group-head.table-mode { margin-bottom:14px; }
.sales-cart-table-wrap { overflow:auto; border-radius:18px; }
.sales-cart-table tbody tr { transition: all .2s ease; }
.sales-cart-table tbody tr:hover { transform: translateY(-1px); box-shadow: inset 0 0 0 9999px rgba(11,96,208,0.02); }
.sales-cart-table tbody tr.cart-row-status-available td:first-child { border-left: 4px solid #0f9d58; }
.sales-cart-table tbody tr.cart-row-status-booked td:first-child { border-left: 4px solid #f29900; }
.sales-cart-table tbody tr.cart-row-status-deposit td:first-child { border-left: 4px solid #0b60d0; }
.sales-cart-table tbody tr.cart-row-status-sold td:first-child { border-left: 4px solid #d92945; }
.sales-cart-table tbody tr.cart-row-status-off td:first-child { border-left: 4px solid #7f8ea3; }
.sales-cart-table tbody tr.cart-row-status-available { background: rgba(15,157,88,0.04); }
.sales-cart-table tbody tr.cart-row-status-booked { background: rgba(242,153,0,0.05); }
.sales-cart-table tbody tr.cart-row-status-deposit { background: rgba(11,96,208,0.04); }
.sales-cart-table tbody tr.cart-row-status-sold { background: rgba(217,41,69,0.04); }
.sales-cart-table tbody tr.cart-row-status-off { background: rgba(104,117,140,0.05); }
.sales-cart-table td, .sales-cart-table th { vertical-align: middle; }
@media (max-width: 980px) {
  .cart-group-head.table-mode { align-items:flex-start; }
}

.tag.yellow { background: rgba(245, 199, 0, 0.16); color: #8b6900; }
.inventory-card .toolbar form { align-items: center; }
.inventory-program-banner { display:flex; align-items:center; justify-content:space-between; gap:12px; padding:14px 16px; border-radius:18px; background: linear-gradient(135deg, rgba(11,96,208,0.08), rgba(217,41,69,0.06)); border:1px solid rgba(11,96,208,0.08); }
.inventory-row-block { margin-top: 22px; border: 1px solid rgba(11,96,208,0.08); border-radius: 20px; background: #fff; padding: 16px; box-shadow: 0 10px 24px rgba(12,42,94,0.05); }
.inventory-row-head { display:flex; align-items:flex-start; justify-content:space-between; gap:12px; margin-bottom:14px; }
.inventory-row-head h3 { margin:0; font-size: 24px; letter-spacing: 0.5px; }
.inventory-summary-inline { justify-content:flex-end; }
.inventory-grid-wrap { overflow-x:auto; }
.inventory-grid-table { width:100%; border-collapse: collapse; table-layout: fixed; min-width: 980px; background:#fff; border:1px solid rgba(12,42,94,0.10); }
.inventory-grid-table td { padding:0; border:1px solid rgba(12,42,94,0.12); height:84px; vertical-align:top; }
.inventory-cell { position:relative; }
.inventory-cell-link { display:flex; flex-direction:column; align-items:flex-start; justify-content:space-between; min-height:84px; padding:8px 8px 6px; text-decoration:none; color:inherit; }
.inventory-cell-number { display:block; font-size:24px; line-height:1; font-weight:800; }
.inventory-cell-status { display:block; margin-top:6px; font-size:12px; line-height:1.2; font-weight:700; text-transform: lowercase; }
.inventory-cell.status-available { background:#08a34a; color:#ffffff; }
.inventory-cell.status-booked { background:#ff9800; color:#1e1e1e; }
.inventory-cell.status-deposit { background:#f3ea00; color:#111111; }
.inventory-cell.status-sold { background:#ff2b2b; color:#ffffff; }
.inventory-cell.status-off { background:#d9d9d9; color:#333333; }
.inventory-cell.status-default { background:#eef3f9; color:#1f2d3d; }
.inventory-cell-empty { background:#ffffff; }
.inventory-cell-link:hover { filter: brightness(0.97); }
.inventory-cell.status-available .inventory-cell-link:hover,
.inventory-cell.status-sold .inventory-cell-link:hover { filter: brightness(0.93); }
@media (max-width: 991px) {
  .inventory-row-head, .inventory-program-banner { flex-direction: column; align-items:flex-start; }
  .inventory-grid-table { min-width: 760px; }
  .inventory-grid-table td { height:72px; }
  .inventory-cell-link { min-height:72px; }
  .inventory-cell-number { font-size:20px; }
}

.inventory-cell-button {
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  justify-content:space-between;
  width:100%;
  min-height:84px;
  padding:8px 8px 6px;
  border:0;
  background:transparent;
  color:inherit;
  text-align:left;
  cursor:pointer;
}
.inventory-cell-button:hover { filter: brightness(0.97); }
.inventory-cell.status-available .inventory-cell-button:hover,
.inventory-cell.status-sold .inventory-cell-button:hover { filter: brightness(0.93); }

body.modal-open { overflow:hidden; }
.status-modal {
  position:fixed;
  inset:0;
  display:none;
  align-items:center;
  justify-content:center;
  z-index:9999;
  padding:24px;
}
.status-modal.active { display:flex; }
.status-modal-backdrop {
  position:absolute;
  inset:0;
  background:rgba(8, 18, 34, 0.48);
  backdrop-filter: blur(2px);
}
.status-modal-card {
  position:relative;
  z-index:1;
  width:100%;
  max-width:520px;
  background:#fff;
  border-radius:24px;
  border:1px solid rgba(11,96,208,0.10);
  box-shadow:0 30px 80px rgba(12,42,94,0.22);
  padding:22px;
}
.status-modal-head {
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:14px;
  margin-bottom:16px;
}
.status-modal-head h3 {
  margin:0;
  font-size:24px;
}
.status-modal-close {
  width:40px;
  height:40px;
  border-radius:999px;
  border:1px solid rgba(11,96,208,0.10);
  background:#fff;
  color:#26354a;
  font-size:24px;
  line-height:1;
  cursor:pointer;
}
.status-modal-info {
  border-radius:18px;
  background:linear-gradient(135deg, rgba(11,96,208,0.07), rgba(217,41,69,0.06));
  border:1px solid rgba(11,96,208,0.08);
  padding:14px 16px;
}
.status-modal-lot {
  font-size:22px;
  font-weight:800;
  line-height:1.1;
}
.status-modal-title {
  margin-top:6px;
  color:#30415b;
  font-weight:700;
}
.status-modal-actions {
  display:flex;
  justify-content:flex-end;
  gap:10px;
  flex-wrap:wrap;
}
@media (max-width: 640px) {
  .status-modal { padding:14px; }
  .status-modal-card { padding:18px; border-radius:20px; }
  .status-modal-head h3 { font-size:20px; }
  .status-modal-lot { font-size:19px; }
}

.inventory-cell-price {
  display:block;
  margin-top:6px;
  font-size:13px;
  line-height:1.2;
  font-weight:700;
}
.inventory-cell.status-booked .inventory-cell-price,
.inventory-cell.status-deposit .inventory-cell-price,
.inventory-cell.status-off .inventory-cell-price {
  color: rgba(0,0,0,0.78);
}
.inventory-cell.status-available .inventory-cell-price,
.inventory-cell.status-sold .inventory-cell-price {
  color: rgba(255,255,255,0.96);
}
.mb-2 { margin-bottom: 12px; }
.no-print { }
.print-settings-grid textarea { min-height: 88px; }
.project-report-sheet { padding: 26px; }
.print-header-grid { display:grid; grid-template-columns: 1fr 1fr; gap: 24px; align-items:start; }
.print-header-block.right { text-align:right; }
.print-header-line { font-size: 15px; line-height: 1.35; font-weight: 700; }
.print-header-line.upper { text-transform: uppercase; }
.print-header-line.center { text-align:center; }
.print-title-wrap { text-align:center; margin: 24px 0 18px; }
.print-report-title { font-size: 28px; font-weight: 800; text-transform: uppercase; letter-spacing: 0.5px; }
.print-report-subtitle { margin-top: 8px; font-size: 16px; color: #33445d; font-weight: 700; }
.print-filter-line { margin-top: 10px; color: #5a6a81; font-size: 13px; }
.report-summary-band { display:grid; grid-template-columns: repeat(6, minmax(0, 1fr)); gap: 10px; margin-bottom: 18px; }
.summary-chip { border:1px solid rgba(11,96,208,0.08); background: rgba(11,96,208,0.04); border-radius: 16px; padding: 12px; text-align:center; }
.summary-chip span { display:block; font-size: 12px; color: #5f7088; text-transform: uppercase; }
.summary-chip strong { display:block; margin-top: 6px; font-size: 18px; }
.project-report-group { margin-top: 20px; }
.project-report-group-title { font-size: 18px; font-weight: 800; margin: 0 0 10px; padding: 10px 14px; border-radius: 14px; background: linear-gradient(135deg, rgba(11,96,208,0.08), rgba(217,41,69,0.05)); }
.project-report-table { min-width: 1280px; }
.project-report-table thead th { background: linear-gradient(135deg, var(--brand-blue), #4ab0ff); color: #ffffff; border-bottom-color: rgba(11,96,208,0.22); text-align:center; font-size: 12px; }
.project-report-table tbody td { text-align:center; }
.project-report-table tbody td:first-child { text-align:left; }
.print-footer-note { margin-top: 20px; padding-top: 10px; border-top: 1px dashed rgba(11,96,208,0.14); color: #4d5c74; font-size: 13px; }
.project-report-sheet[data-paper-size="A4"] { max-width: 1123px; }
.project-report-sheet[data-paper-size="A3"] { max-width: 1600px; }
.project-report-sheet[data-orientation="portrait"] .project-report-table { min-width: 0; }
@media (max-width: 1100px) {
  .report-summary-band { grid-template-columns: repeat(3, minmax(0,1fr)); }
}
@media (max-width: 760px) {
  .print-header-grid, .report-summary-band { grid-template-columns: 1fr; }
  .print-header-block.right { text-align:left; }
  .print-header-line.center { text-align:left; }
}
@media print {
  html, body { background: #fff !important; }
  .sidebar, .topbar, .sidebar-footer, .no-print, .alerts, .btn { display: none !important; }
  .app-shell, .main { display: block !important; padding: 0 !important; margin: 0 !important; }
  .card { box-shadow: none !important; border: 0 !important; background: #fff !important; border-radius: 0 !important; }
  .project-report-sheet { padding: 0 !important; max-width: none !important; }
  .table-wrap { overflow: visible !important; }
  .project-report-table { min-width: 0 !important; width: 100% !important; }
  .project-report-table th, .project-report-table td { font-size: 11px; padding: 8px 6px; }
  .project-report-group { page-break-inside: avoid; }
  a[href]:after { content: '' !important; }
}


/* --- Project report v2 / Roboto --- */
button, input, select, textarea, table, th, td, .btn, .nav-link, .brand-title, .brand-sub {
  font-family: "Roboto", Arial, Helvetica, sans-serif;
}
.print-preview-body {
  background: #eef2f8;
}
.print-preview-layout {
  display: grid;
  grid-template-columns: 360px minmax(0, 1fr);
  gap: 18px;
  padding: 18px;
  align-items: start;
}
.print-preview-sidebar {
  position: sticky;
  top: 18px;
}
.print-preview-main {
  min-width: 0;
}
.report-summary-band-4 {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}
.project-report-table-screen {
  min-width: 1380px;
}
.project-report-table th,
.project-report-table td {
  white-space: nowrap;
}
.project-report-table td.project-cell-name {
  white-space: normal;
  min-width: 280px;
}
.project-group-summary-row td {
  background: #e9e9e9 !important;
  font-weight: 700;
  font-style: italic;
}
.project-group-summary-row td:nth-child(2) {
  text-align: left;
}
.project-report-table tbody tr td:nth-child(3),
.project-report-table tbody tr td:nth-child(6),
.project-report-table tbody tr td:nth-child(7),
.project-report-table tbody tr td:nth-child(10) {
  color: #d60000;
}
.project-report-table tbody tr td:nth-child(11),
.project-report-table tbody tr td:nth-child(12),
.project-report-table tbody tr td:nth-child(13) {
  color: #000;
}
.project-report-table tbody tr.highlight-remain td:nth-child(10),
.project-report-table tbody tr.highlight-remain td:nth-child(11),
.project-report-table tbody tr.highlight-remain td:nth-child(12),
.project-report-table tbody tr.highlight-remain td:nth-child(13) {
  background: #fff46b;
}
.print-sheet.project-report-sheet {
  padding: 20px;
}
.print-sheet .table-wrap {
  overflow: visible;
}
.print-sheet .project-report-table {
  min-width: 0;
  width: 100%;
}
.print-sheet .project-report-table th,
.print-sheet .project-report-table td {
  font-size: 12px;
  padding: 7px 6px;
}
@media (max-width: 1200px) {
  .print-preview-layout {
    grid-template-columns: 1fr;
  }
  .print-preview-sidebar {
    position: static;
  }
}
@media (max-width: 760px) {
  .report-summary-band-4 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media print {
  .print-preview-layout {
    display: block !important;
    padding: 0 !important;
  }
  .print-preview-main {
    width: 100% !important;
  }
  .print-preview-body {
    background: #fff !important;
  }
}


/* ===== Responsive + mobile enhancements merged back safely ===== */
:root{
  --app-shell-gap: 20px;
  --app-sidebar-width: 220px;
  --app-sidebar-width-mobile: 280px;
}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body,button,input,select,textarea,table{font-family:Roboto,Arial,Helvetica,sans-serif !important;}
img,svg,video,canvas{max-width:100%;height:auto;}
button,input,select,textarea{max-width:100%;}
.table-wrap,.project-report-scroll,.table-responsive,.dataTables_wrapper{max-width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;}
.table,.project-report-table{width:100%;}
.card,.metric-card,.toolbar,.hero-tip{max-width:100%;}
.card-title{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap;}
.card-title .actions,.actions,.toolbar,.project-link-stack,.note-modal-actions{display:flex;flex-wrap:wrap;gap:10px;}
.form-group{min-width:0;}
.form-group input,.form-group select,.form-group textarea{width:100%;max-width:100%;}
.btn{white-space:nowrap;}
.project-report-table th,.project-report-table td{vertical-align:middle;}
.project-report-table td{background-clip:padding-box;}
.mobile-nav-toggle,.mobile-nav-backdrop{display:none;}

@media (max-width: 1200px){
  .card{padding:18px !important;}
}

@media (max-width: 1024px){
  body{overflow-x:hidden;}
  .mobile-nav-toggle{
    display:flex;align-items:center;justify-content:center;
    position:fixed;top:12px;left:12px;z-index:1400;
    width:44px;height:44px;border:none;border-radius:14px;
    background:linear-gradient(135deg,#0b60d0,#d92945);color:#fff;
    box-shadow:0 12px 24px rgba(11,96,208,.28);font-size:20px;font-weight:700;cursor:pointer;
  }
  .mobile-nav-backdrop{
    position:fixed;inset:0;background:rgba(8,17,40,.38);z-index:1290;
  }
  body.sidebar-open .mobile-nav-backdrop{display:block;}
  .sidebar,.app-sidebar,aside.sidebar,aside.app-sidebar,nav.sidebar,nav.app-sidebar{
    position:fixed !important;left:0;top:0;bottom:0;z-index:1300;
    width:var(--app-sidebar-width-mobile) !important;max-width:84vw;
    transform:translateX(-105%);transition:transform .22s ease;overflow-y:auto;
  }
  body.sidebar-open .sidebar,
  body.sidebar-open .app-sidebar,
  body.sidebar-open aside.sidebar,
  body.sidebar-open aside.app-sidebar,
  body.sidebar-open nav.sidebar,
  body.sidebar-open nav.app-sidebar{transform:translateX(0);}

  .main-content,.content-wrapper,.app-content,.page-content,.app-main,main{
    width:100% !important;max-width:100% !important;margin-left:0 !important;
  }
  .container,.container-fluid,.page-content,.app-content,.content-wrapper,.app-main,main{
    padding-left:14px !important;padding-right:14px !important;
  }
  .card{border-radius:18px !important;}
  .hero-tip,.toolbar,.card-title,.project-link-stack{gap:8px;}
  .btn{padding:10px 12px !important;font-size:13px !important;}
  .table,.project-report-table{font-size:13px;}
  .project-report-table th,.project-report-table td{padding:8px 8px !important;}
}

@media (max-width: 768px){
  :root{--app-shell-gap:14px;}
  .container,.container-fluid,.page-content,.app-content,.content-wrapper,.app-main,main{
    padding-left:12px !important;padding-right:12px !important;
  }
  .card-title h2{font-size:24px !important;line-height:1.25;}
  .card-title p,.hero-tip,.project-helper-line{font-size:13px !important;line-height:1.5;}
  .actions,.toolbar,.project-link-stack,.note-modal-actions{gap:8px;}
  .actions .btn,.toolbar .btn,.project-link-stack .btn{flex:0 0 auto;}
  .projects-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr)) !important;gap:10px !important;}
  .projects-summary-grid>.metric-card{min-height:108px !important;}
  .metric-label{font-size:12px !important;}
  .metric-sub{font-size:11px !important;line-height:1.4;}
  .metric-value{font-size:30px !important;line-height:1.15;}
  .project-report-scroll{padding-bottom:12px !important;}
  .project-report-table{font-size:12px !important;}
  .project-report-table th{font-size:11px !important;line-height:1.25 !important;}
  .project-report-table td{font-size:12px !important;}
  .note-chip{min-width:150px !important;max-width:220px !important;padding:9px 10px !important;}
  .note-modal textarea{font-size:14px !important;}
}

@media (max-width: 560px){
  .projects-summary-grid{grid-template-columns:1fr !important;}
  .card{padding:14px !important;}
  .card-title{gap:12px;}
  .card-title .actions,.actions,.toolbar,.project-link-stack{gap:6px;}
  .btn{width:auto;max-width:100%;}
  .actions .btn,.toolbar .btn,.project-link-stack .btn{font-size:12px !important;padding:9px 11px !important;}
  .project-report-table{font-size:11px !important;}
  .project-report-table th,.project-report-table td{padding:7px 7px !important;}
  .note-chip{min-width:138px !important;max-width:180px !important;}
}


/* ===== Compact menu + project table tune v8 ===== */
:root{
  --app-sidebar-width: 236px;
  --app-sidebar-width-mobile: 272px;
}
.app-shell{grid-template-columns:236px 1fr;}
.sidebar{
  width:236px;
  padding:16px 16px 18px;
}
.brand{
  gap:12px;
  padding:8px 6px 18px;
  margin-bottom:14px;
}
.brand-mark{
  width:48px;
  height:48px;
  border-radius:16px;
  font-size:18px;
}
.brand-title{font-size:16px;}
.brand-sub{font-size:11px;}
.nav-group{gap:6px;}
.nav-link{
  padding:11px 13px;
  min-height:46px;
  border-radius:16px;
  font-size:14px;
}
.sidebar-footer{
  left:16px;
  right:16px;
  bottom:16px;
  padding:14px;
  border-radius:18px;
}
.sidebar-footer .btn,
.sidebar-footer .btn-sm{
  padding:10px 12px;
  font-size:13px;
  border-radius:12px;
}
.main{padding:18px;}
.topbar{padding:16px 18px; margin-bottom:18px; border-radius:24px;}
.card{padding:18px; border-radius:22px;}
.metric-card{padding:16px 18px;}
.metric-value{font-size:28px;}
.metric-label{font-size:13px;}
.metric-sub{font-size:12px;}
.btn{padding:10px 14px; border-radius:12px;}
.btn-sm{padding:8px 11px; font-size:12px; border-radius:12px;}
.project-link-stack{gap:6px !important;}
.project-link-stack .btn,
.actions .btn,
.toolbar .btn{padding:8px 11px !important; font-size:12px !important; border-radius:12px !important;}
.note-chip{min-width:150px !important; padding:8px 10px !important; border-radius:12px !important;}
.project-report-scroll{padding-bottom:6px !important;}
.project-report-table.project-report-table-screen{min-width:1320px !important;}
.project-report-table thead th,
.project-report-table tbody td{padding:10px 10px !important;}
.project-report-table thead th{font-size:11px !important; line-height:1.25 !important;}
.project-report-table tbody td{font-size:13px !important;}
.project-report-table th:nth-child(2),
.project-report-table td:nth-child(2){
  width:180px;
  min-width:180px !important;
  max-width:180px;
}
.project-report-table td.project-cell-name,
.project-report-table tbody td:nth-child(2){
  white-space:normal !important;
  word-break:break-word;
  line-height:1.35;
}
.project-note-col,
.project-report-table.project-report-table-screen td:last-child{
  min-width:170px !important;
  width:170px;
}
.projects-summary-grid{gap:12px !important;}
.projects-summary-grid > .metric-card{min-height:112px !important;}
.sidebar-collapse-toggle{
  position:fixed;
  top:16px;
  left:252px;
  z-index:1350;
  width:36px;
  height:36px;
  border:none;
  border-radius:12px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:linear-gradient(135deg,#0b60d0,#7f58d6);
  color:#fff;
  box-shadow:0 12px 24px rgba(11,96,208,.24);
  cursor:pointer;
  transition:all .2s ease;
}
.sidebar-collapse-toggle:hover{transform:translateY(-1px);}
body.sidebar-collapsed .app-shell{grid-template-columns:84px 1fr;}
body.sidebar-collapsed .sidebar{width:84px; padding:16px 12px; overflow:hidden;}
body.sidebar-collapsed .brand{justify-content:center; padding-bottom:14px;}
body.sidebar-collapsed .brand-copy,
body.sidebar-collapsed .nav-link span:first-child,
body.sidebar-collapsed .sidebar-footer > div,
body.sidebar-collapsed .sidebar-footer small,
body.sidebar-collapsed .sidebar-footer .btn{display:none !important;}
body.sidebar-collapsed .nav-link{justify-content:center; padding:11px 10px;}
body.sidebar-collapsed .nav-link::after{display:none;}
body.sidebar-collapsed .sidebar-footer{padding:10px; min-height:52px;}
body.sidebar-collapsed .sidebar-collapse-toggle{left:100px;}
body.sidebar-collapsed .main{padding-left:16px;}
@media (max-width: 1200px){
  .project-report-table.project-report-table-screen{min-width:1260px !important;}
  .project-report-table th:nth-child(2),
  .project-report-table td:nth-child(2){width:165px; min-width:165px !important; max-width:165px;}
}
@media (max-width: 1024px){
  .sidebar-collapse-toggle{display:none !important;}
  .sidebar{width:var(--app-sidebar-width-mobile) !important;}
  .nav-link{min-height:44px; font-size:14px;}
  .project-report-table.project-report-table-screen{min-width:1200px !important;}
  .project-report-table th:nth-child(2),
  .project-report-table td:nth-child(2){width:160px; min-width:160px !important; max-width:160px;}
}
@media (max-width: 768px){
  .main{padding:14px;}
  .card{padding:14px; border-radius:18px;}
  .projects-summary-grid>.metric-card{min-height:96px !important;}
  .metric-value{font-size:24px !important;}
  .project-link-stack .btn,
  .actions .btn,
  .toolbar .btn{padding:7px 10px !important; font-size:12px !important;}
  .project-report-table.project-report-table-screen{min-width:1120px !important;}
  .project-report-table thead th,
  .project-report-table tbody td{padding:8px 8px !important;}
}
@media (max-width: 560px){
  .sidebar{padding:14px 12px 16px;}
  .brand{margin-bottom:12px;}
  .brand-mark{width:44px; height:44px; font-size:17px;}
  .nav-link{padding:10px 12px; min-height:42px; border-radius:14px;}
  .sidebar-footer{left:12px; right:12px; bottom:12px; padding:12px;}
  .project-report-table.project-report-table-screen{min-width:1060px !important;}
  .project-report-table th:nth-child(2),
  .project-report-table td:nth-child(2){width:150px; min-width:150px !important; max-width:150px;}
  .project-note-col,
  .project-report-table.project-report-table-screen td:last-child{min-width:150px !important; width:150px;}
}


/* ===== Final compact tune v9 ===== */
.mobile-nav-toggle,
.sidebar-collapse-toggle,
.mobile-nav-backdrop{display:none !important;}
body.sidebar-open,
body.sidebar-collapsed{overflow-x:hidden;}
.app-shell,
body.sidebar-collapsed .app-shell{grid-template-columns:244px minmax(0,1fr) !important;}
.sidebar,
body.sidebar-collapsed .sidebar{
  width:244px !important;
  padding:16px 16px 18px !important;
  overflow:visible !important;
}
body.sidebar-collapsed .brand,
.brand{justify-content:flex-start !important;}
body.sidebar-collapsed .brand-copy,
body.sidebar-collapsed .nav-link span:first-child,
body.sidebar-collapsed .sidebar-footer > div,
body.sidebar-collapsed .sidebar-footer small,
body.sidebar-collapsed .sidebar-footer .btn{display:initial !important;}
body.sidebar-collapsed .nav-link{justify-content:space-between !important; padding:11px 14px !important;}
body.sidebar-collapsed .sidebar-footer{padding:14px !important; min-height:auto !important;}
.main{min-width:0; padding:18px !important;}
.nav-group{margin-bottom:126px;}
.nav-link{min-height:44px; padding:11px 14px !important; border-radius:15px !important; font-size:14px !important;}
.brand-title{font-size:15px !important;}
.brand-sub{font-size:11px !important;}
.sidebar-footer{left:16px !important; right:16px !important; bottom:16px !important; border-radius:18px !important;}
.sidebar-footer .btn{border-radius:12px !important;}
.project-report-scroll{
  width:100%;
  overflow:auto;
  -webkit-overflow-scrolling:touch;
  padding-bottom:0 !important;
}
.project-report-table.project-report-table-screen{
  width:100% !important;
  min-width:1360px !important;
  max-width:none !important;
  table-layout:auto !important;
}
.project-report-table thead th,
.project-report-table tbody td{
  padding:10px 12px !important;
}
.project-report-table thead th:nth-child(1),
.project-report-table tbody td:nth-child(1){
  width:56px;
  min-width:56px !important;
  max-width:56px;
  text-align:center;
}
.project-report-table thead th:nth-child(2),
.project-report-table tbody td:nth-child(2),
.project-cell-name{
  width:210px;
  min-width:210px !important;
  max-width:210px;
  white-space:normal !important;
  word-break:break-word;
  line-height:1.35;
  text-align:center;
}
.project-report-table thead th:last-child,
.project-report-table tbody td:last-child,
.project-note-col{
  width:190px;
  min-width:190px !important;
  max-width:190px;
}
.project-group-summary-row td{
  background:#f7f9fd;
  vertical-align:top !important;
}
.project-group-summary-row .project-cell-name{
  width:266px;
  min-width:266px !important;
  max-width:266px;
}
.project-link-stack{
  display:flex !important;
  flex-wrap:wrap;
  gap:8px !important;
  margin-top:8px !important;
}
.project-link-stack .btn,
.actions .btn,
.toolbar .btn{
  padding:7px 10px !important;
  font-size:12px !important;
  border-radius:12px !important;
}
.project-helper-line{
  margin-top:6px;
  font-size:13px !important;
  line-height:1.45;
}
.projects-summary-grid{grid-template-columns:repeat(4,minmax(0,1fr)) !important; gap:12px !important;}
.projects-summary-grid > .metric-card{min-height:102px !important; padding:14px 16px !important;}
.metric-value{font-size:26px !important;}
.metric-label{font-size:13px !important;}
.metric-sub{font-size:12px !important;}
.note-chip{min-width:150px !important; max-width:190px !important; width:100%;}
@media (max-width: 1200px){
  .project-report-table.project-report-table-screen{min-width:1280px !important;}
}
@media (max-width: 1024px){
  .app-shell{grid-template-columns:224px minmax(0,1fr) !important;}
  .sidebar{width:224px !important;}
  .projects-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr)) !important;}
  .project-report-table.project-report-table-screen{min-width:1220px !important;}
}
@media (max-width: 768px){
  .app-shell{grid-template-columns:1fr !important;}
  .sidebar{position:relative !important; width:100% !important; max-width:none !important; transform:none !important; height:auto !important; padding:14px 12px 16px !important;}
  .nav-group{margin-bottom:14px;}
  .sidebar-footer{position:static !important; left:auto !important; right:auto !important; bottom:auto !important; margin-top:12px;}
  .main{padding:12px !important;}
  .projects-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr)) !important;}
  .projects-summary-grid > .metric-card{min-height:94px !important;}
  .metric-value{font-size:22px !important;}
  .project-report-table.project-report-table-screen{min-width:1100px !important;}
  .project-report-table thead th,
  .project-report-table tbody td{padding:8px 8px !important;}
  .project-report-table thead th:nth-child(2),
  .project-report-table tbody td:nth-child(2),
  .project-cell-name{width:180px; min-width:180px !important; max-width:180px;}
  .project-group-summary-row .project-cell-name{width:230px; min-width:230px !important; max-width:230px;}
}
@media (max-width: 560px){
  .projects-summary-grid{grid-template-columns:1fr !important;}
  .brand-mark{width:42px !important; height:42px !important;}
  .brand-title{font-size:14px !important;}
  .nav-link{min-height:40px; padding:10px 12px !important;}
  .project-report-table.project-report-table-screen{min-width:1040px !important;}
}

/* Bỏ tô vàng cột còn lại chưa cấp giấy */
.project-report-table tbody tr.highlight-remain td:nth-child(10),
.project-report-table tbody tr.highlight-remain td:nth-child(11),
.project-report-table tbody tr.highlight-remain td:nth-child(12),
.project-report-table tbody tr.highlight-remain td:nth-child(13) {
  background: transparent !important;
}


/* === Final mobile optimization v20 === */
@media (max-width: 980px) {
  .sidebar { padding: 16px; position: relative; height: auto; }
  .nav-group { gap: 6px; margin-bottom: 18px; }
  .nav-link { padding: 12px 14px; border-radius: 16px; }
  .topbar { padding: 16px; border-radius: 22px; }
  .card { padding: 16px; border-radius: 22px; }
  .card-title { flex-direction: column; align-items: flex-start; }
  .toolbar, .actions { width: 100%; }
  .table-wrap, .only-row-table-wrap, .project-report-wrap { -webkit-overflow-scrolling: touch; }
}
@media (max-width: 640px) {
  html, body { font-size: 15px; }
  .main { padding: 12px; }
  .brand { gap: 10px; padding: 8px 6px 16px; margin-bottom: 14px; }
  .brand-mark { width: 44px; height: 44px; border-radius: 14px; font-size: 18px; }
  .brand-title { font-size: 17px; }
  .brand-sub { font-size: 11px; }
  .nav-link { font-size: 15px; padding: 11px 13px; }
  .sidebar-footer { position: static; margin-top: 16px; padding: 14px; }
  .topbar h1 { font-size: 24px; }
  .topbar p { font-size: 14px; }
  .metric-value { font-size: 28px; }
  .btn { padding: 11px 14px; }
  .btn-sm { padding: 9px 11px; }
  .form-actions, .only-row-filter .form-group { width: 100%; }
  .only-row-title-line .actions, .card-title .actions, .toolbar { width: 100%; }
  .only-row-title-line .actions .btn, .card-title .actions .btn, .toolbar .btn { flex: 1 1 calc(50% - 8px); }
  .table th, .table td { padding: 10px 8px; }
}
