:root{
  --bg:#f5f7fb;
  --card:#ffffff;
  --ink:#1f2937;
  --muted:#6b7280;
  --line:#e5e7eb;
  --brand:#2563eb;
  --brand-soft:#dbeafe;
  --good:#166534;
  --good-bg:#dcfce7;
  --warn:#92400e;
  --warn-bg:#fef3c7;
  --bad:#991b1b;
  --bad-bg:#fee2e2;
}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--ink);font-family:Arial,Helvetica,sans-serif}
a{text-decoration:none;color:inherit}
.wrap{max-width:760px;margin:0 auto;padding:12px}
.topbar{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:12px}
.brand{font-size:24px;font-weight:700}
.sub{font-size:12px;color:var(--muted)}
.card{background:var(--card);border:1px solid var(--line);border-radius:18px;padding:14px;box-shadow:0 6px 18px rgba(0,0,0,.04);margin-bottom:12px}
.month-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.month-pill{display:block;text-align:center;padding:10px 8px;border-radius:12px;border:1px solid var(--line);background:#fff;font-size:14px}
.month-pill.active{background:var(--brand);color:#fff;border-color:var(--brand)}
.flex{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.right{margin-left:auto}
.badge{display:inline-block;padding:5px 9px;border-radius:999px;font-size:12px;border:1px solid var(--line);background:#fff}
.stat-no{color:var(--bad);background:var(--bad-bg);border-color:#fecaca}
.stat-partial{color:var(--warn);background:var(--warn-bg);border-color:#fde68a}
.stat-full{color:var(--good);background:var(--good-bg);border-color:#bbf7d0}
.stat-none{color:var(--muted);background:#f3f4f6}
.small{font-size:12px;color:var(--muted)}
.client-card{display:block}
.client-head{display:flex;gap:8px;align-items:start}
.client-name{font-weight:700;font-size:16px}
.money{font-weight:700}
.row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-top:10px}
.k{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}
.v{font-size:14px;font-weight:700}
.actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}
.btn,.input,select,textarea{border-radius:12px;border:1px solid var(--line);font-size:14px}
.btn{padding:10px 12px;background:#fff;cursor:pointer}
.btn.primary{background:var(--brand);border-color:var(--brand);color:#fff}
.btn.danger{background:#fff5f5;color:var(--bad);border-color:#fecaca}
.btn.warn{background:#fffbeb;color:var(--warn);border-color:#fde68a}
.input,select,textarea{width:100%;padding:10px 12px;background:#fff}
textarea{min-height:90px;resize:vertical}
form.stack{display:grid;gap:10px}
details{margin-top:10px;border:1px dashed var(--line);padding:10px;border-radius:12px;background:#fcfcfd}
summary{cursor:pointer;font-weight:700}
.note{padding:10px;border:1px solid var(--line);border-radius:12px;margin-top:8px;background:#fff}
.note-date{font-size:12px;color:var(--muted);margin-bottom:4px}
.tableish{display:grid;gap:8px}
.alert{padding:10px 12px;border-radius:12px;margin-bottom:12px;font-size:14px}
.alert.ok{background:#ecfdf5;color:#065f46;border:1px solid #a7f3d0}
.alert.err{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}
.section-title{font-weight:700;font-size:18px;margin-bottom:8px}
.header-link{color:var(--brand);font-weight:700}
.meta{display:grid;grid-template-columns:1fr 1fr;gap:8px}
@media (max-width:560px){
  .month-grid{grid-template-columns:repeat(3,1fr)}
  .row,.meta{grid-template-columns:1fr 1fr}
}


/* Patch V2 extra styles */
.period-nav{display:flex;align-items:center;justify-content:space-between;gap:10px}
.row-4{grid-template-columns:repeat(4,minmax(0,1fr))}
.wrapflex{display:flex;flex-wrap:wrap}
.inline-filter select, select, .input, textarea{width:100%;padding:10px;border:1px solid #d0d7de;border-radius:10px;background:#fff}
.inline-filter{margin-left:auto}
.carry{margin-top:8px;color:#8a4b00}
.print-area{background:#fff}
@media print{
  .btn, details, .topbar .sub a {display:none !important;}
  body{background:#fff}
}





@import url('patch_v4.css');

.compact-actions{margin-top:8px}
.invoice-wrap{max-width:230mm}
.invoice-sheet{width:210mm;min-height:297mm;margin:0 auto;background:#fff;border:1px solid #cfd7e5;border-radius:8px;padding:14mm;box-shadow:0 8px 24px rgba(0,0,0,.05)}
.invoice-toolbar{display:flex;justify-content:flex-end;margin-bottom:8mm}
.invoice-header{display:grid;grid-template-columns:1.2fr .9fr;gap:14mm;align-items:start;padding-bottom:8mm;border-bottom:2px solid #d8e0ed}
.invoice-brand{font-size:28px;font-weight:800;letter-spacing:.01em;color:#1c2d53}
.invoice-title-box{text-align:right}
.invoice-title{font-size:30px;font-weight:800;letter-spacing:.06em;color:#233a6b}
.invoice-meta{font-size:13px;color:#344256;margin-top:4px}
.invoice-muted{font-size:13px;color:#5f6c81;line-height:1.45}
.invoice-billto-grid{display:grid;grid-template-columns:1fr 1fr;gap:8mm;margin-top:8mm}
.invoice-box{border:1px solid #d8e0ed;border-radius:8px;padding:10px 12px;background:#fbfcfe}
.invoice-box-title{font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:#6b7280;font-weight:700;margin-bottom:8px}
.invoice-table{width:100%;border-collapse:collapse;margin-top:8mm}
.invoice-table th,.invoice-table td{border:1px solid #d8e0ed;padding:10px 12px;font-size:14px;vertical-align:top}
.invoice-table thead th{background:#eef3fb;text-align:left;color:#24324d}
.ta-r{text-align:right}
.invoice-totals{margin-left:auto;width:min(100%,82mm);margin-top:8mm}
.invoice-total-row{display:flex;justify-content:space-between;gap:12px;padding:8px 0;border-bottom:1px solid #e5eaf3;font-size:14px}
.invoice-total-row.grand{font-size:20px;font-weight:800;border-bottom:0;padding-top:12px;color:#16284f}
.invoice-paybox{margin-top:8mm;border:1px solid #cfe2ff;background:#f6faff;border-radius:8px;padding:12px}
.invoice-note-body{font-size:13px;line-height:1.55;color:#334155;margin-top:6px}
@page{size:A4;margin:12mm}
@media (max-width:900px){
  .invoice-sheet{width:100%;min-height:0;padding:18px;border-radius:16px}
  .invoice-header,.invoice-billto-grid{grid-template-columns:1fr}
  .invoice-title-box{text-align:left}
  .invoice-totals{width:100%}
}
@media print{
  .no-print,.invoice-toolbar,.topbar .sub a,.actions,.btn,details summary::-webkit-details-marker{display:none !important}
  body{background:#fff !important}
  .wrap,.invoice-wrap{max-width:none;padding:0;margin:0}
  .invoice-sheet{width:auto;min-height:auto;padding:0;border:0;box-shadow:none;border-radius:0}
}


















@media print{
  html, body{
    margin:0 !important;
    padding:0 !important;
    height:auto !important;
    min-height:0 !important;
    overflow:visible !important;
    background:#fff !important;
  }

  .btn,
  details,
  .topbar .sub a{
    display:none !important;
  }

  .wrap{
    max-width:none !important;
    width:auto !important;
    margin:0 !important;
    padding:0 !important;
  }

  .card,
  .print-area{
    margin:0 !important;
    padding:0 !important;
    border:none !important;
    border-radius:0 !important;
    box-shadow:none !important;
    background:#fff !important;
    width:auto !important;
    min-height:0 !important;
    height:auto !important;
    page-break-before:auto !important;
    page-break-after:auto !important;
    break-after:auto !important;
    break-before:auto !important;
    break-inside:avoid-page !important;
  }

  .topbar{
    margin:0 0 8px 0 !important;
    padding:0 !important;
  }

  body *{
    page-break-before:auto !important;
    page-break-after:auto !important;
  }
}


/* darker readable text@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@ */
body{
    color:#1f2937;   /* darker readable text */
    font-weight:500;
}
.card{
    border:1px solid #d1d5db;
    border-radius:14px;
    box-shadow:0 2px 6px rgba(0,0,0,0.05);
}
.card .client-name,
.card h3,
.card h2{
    color:#1e40af;
    font-weight:700;
}

.meta{
    border-top:1px solid #e5e7eb;
    border-bottom:1px solid #e5e7eb;
    padding-top:6px;
    padding-bottom:6px;
}

.actions{
    border:1px dashed #cbd5e1;
    background:#f9fafb;
    border-radius:10px;
}

.badge{
    font-weight:600;
    padding:4px 10px;
}


    
 /* how to <button class="month-btn active   or">Mar</button>@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@ */   

.month-btn{
    border:2px solid #cbd5e1;
    background:#f8fafc;
    padding:8px 14px;
    border-radius:10px;
    font-weight:600;
    color:#334155;
}

.month-btn:hover{
    border-color:#3b82f6;
    background:#eef4ff;
}

.month-btn.active{
    background:#3b82f6;
    color:#fff;
    border-color:#3b82f6;
}
  /* @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@ */  
    
