:root{
  --bg:#eef4fb;
  --card:#ffffff;
  --text:#18314f;
  --muted:#6a7c92;
  --line:#dbe6f2;
  --primary:#4361ee;
  --primary-dark:#3146b8;
  --secondary:#14b8a6;
  --warning:#f59e0b;
  --danger:#ef4444;
  --month-soft:#edf3ff;
  --ytd-soft:#ecfbf8;
}
*{box-sizing:border-box}
body{margin:0;font-family:Inter,Segoe UI,Arial,sans-serif;background:linear-gradient(180deg,#f6f9fd 0%,#eef4fb 100%);color:var(--text)}
a{text-decoration:none;color:inherit}
.page-shell{max-width:1380px;margin:0 auto;padding:24px}
.topbar{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:24px}
.topbar h1{margin:4px 0 0;font-size:32px}
.eyebrow{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:#7a8ea8}
.topbar-nav a{padding:10px 14px;border-radius:12px;background:#fff;border:1px solid var(--line);font-weight:600}
.grid{display:grid;gap:20px}.two-col{grid-template-columns:minmax(0,1fr) 360px}.stack{display:flex;flex-direction:column;gap:20px}.row{display:flex;align-items:center}.gap-12{gap:12px}
.section-card{background:rgba(255,255,255,.92);border:1px solid var(--line);border-radius:24px;padding:24px;box-shadow:0 12px 32px rgba(23,43,77,.06)}
.section-card-tight{padding:20px}.section-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}.section-head h2{margin:0;font-size:22px}
.hero-card{display:flex;justify-content:space-between;align-items:center;gap:20px;background:linear-gradient(135deg,#fff 0%,#f8fbff 100%)}
.hero-card h2{margin:4px 0 0;font-size:30px}.muted{color:var(--muted)}.mini{font-size:12px}.mt-16{margin-top:16px}
.badge{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:7px 12px;font-weight:700;font-size:12px}.badge-soft{background:#ecf2ff;color:#3550d2}
.cards-grid{display:grid;gap:16px}.client-cards-grid{grid-template-columns:repeat(auto-fill,minmax(230px,1fr))}
.client-card{position:relative;background:linear-gradient(180deg,#fff 0%,#f8fbff 100%);border:1px solid var(--line);border-radius:22px;padding:20px;display:flex;flex-direction:column;gap:14px}
.client-card h3{margin:0;font-size:22px}.template-pill{display:inline-flex;align-self:flex-start;padding:8px 12px;border-radius:999px;background:#eef3ff;color:#3550d2;font-weight:700;font-size:12px}
.btn{display:inline-flex;align-items:center;justify-content:center;border:0;border-radius:14px;padding:12px 16px;font-weight:700;cursor:pointer;transition:.2s}
.btn-primary{background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff}.btn-secondary{background:linear-gradient(135deg,#20c9b8,#0f9f90);color:#fff}.btn-ghost{background:#fff;border:1px solid var(--line);color:var(--text)}.btn-remove{background:#fff1f2;border:1px solid #fecdd3;color:#be123c}
.form-compact label,.form-grid label{display:flex;flex-direction:column;gap:8px;font-weight:600;font-size:14px;color:#31425d}
input,select{width:100%;border:1px solid #d4deea;background:#fff;border-radius:14px;padding:13px 14px;font:inherit;color:var(--text)}
input:focus,select:focus{outline:none;border-color:#6c88ff;box-shadow:0 0 0 3px rgba(67,97,238,.12)}
.readonly-input{background:#f8fbff;color:#385067;font-weight:700}
.check-row{flex-direction:row!important;align-items:center;gap:10px!important}.check-row input{width:auto}
.accountant-list{gap:10px}.accountant-row{padding:12px 14px;border:1px solid var(--line);border-radius:14px;background:#fbfdff}
.year-nav{display:flex;align-items:center;gap:12px}.year-badge{padding:12px 18px;border-radius:16px;background:#eef3ff;color:#3550d2;font-weight:800;font-size:18px}
.legend-inline,.chart-legend{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:16px}.legend-item,.chart-legend-item{display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border-radius:999px;background:#f8fbff;border:1px solid var(--line);font-weight:600;color:#31425d}.dot,.chart-swatch{width:12px;height:12px;border-radius:50%}.chart-swatch-income{background:#4361ee}.chart-swatch-expense{background:#2ec4b6}.chart-swatch-taxes{background:#ff9f1c}.chart-swatch-salary{background:#ef476f}
.month-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}.month-card{border-radius:22px;padding:18px;border:1px solid var(--line);background:#fff;display:flex;flex-direction:column;gap:16px;transition:.2s}.month-card:hover{transform:translateY(-2px);box-shadow:0 12px 28px rgba(23,43,77,.08)}
.month-card-filled{background:linear-gradient(180deg,#fff 0%,#f4fffb 100%);border-color:#b7eadc}.month-card-needs_review{background:linear-gradient(180deg,#fff 0%,#fff8ea 100%);border-color:#f9d382}.month-card-missing{background:linear-gradient(180deg,#fff 0%,#f8fbff 100%)}
.month-head{display:flex;justify-content:space-between;gap:10px;align-items:flex-start}.month-status{padding:6px 10px;border-radius:999px;background:rgba(255,255,255,.8);font-size:12px;font-weight:700;color:#3f5068;border:1px solid rgba(0,0,0,.05)}
.month-income{font-size:24px;font-weight:800;color:#16324f}.month-body{display:flex;flex-direction:column;gap:8px}
.chart-wrap{background:linear-gradient(180deg,#fff 0%,#f9fbff 100%);border:1px solid var(--line);border-radius:24px;padding:18px}.chart-wrap img{display:block;width:100%;border-radius:16px}
.top-form-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.form-grid{display:grid;gap:16px}.dual-panels{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:20px}.panel{border-radius:24px;padding:22px;border:1px solid var(--line)}.panel-month{background:linear-gradient(180deg,var(--month-soft) 0%,#ffffff 100%)}.panel-ytd{background:linear-gradient(180deg,var(--ytd-soft) 0%,#ffffff 100%)}.panel-title{font-size:18px;font-weight:800;margin-bottom:16px}.metrics-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
.payment-row{display:grid;grid-template-columns:160px 1fr 170px 120px;gap:12px;align-items:end;padding:14px;border:1px solid var(--line);border-radius:18px;background:#fbfdff}
.report-meta{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;font-weight:600}
.status-dot-inline{display:inline-block;width:10px;height:10px;border-radius:50%;margin-right:8px}
.panel-report{padding-top:18px}.panel-month-report{background:linear-gradient(180deg,#eef3ff 0%,#fff 100%)}.panel-ytd-report{background:linear-gradient(180deg,#ecfbf8 0%,#fff 100%)}
.report-cards-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}.metric-card{background:#fff;border:1px solid var(--line);border-radius:20px;padding:20px;box-shadow:0 8px 18px rgba(23,43,77,.04)}.centered-card{text-align:center}.metric-label{font-size:14px;color:var(--muted);margin-bottom:10px;font-weight:700}.metric-value{font-size:28px;font-weight:800;color:#16324f}
.payments-card{background:linear-gradient(180deg,#fff8ea 0%,#fff 100%)}.payments-table{display:flex;flex-direction:column;border:1px solid #f8d28b;border-radius:18px;overflow:hidden}.payments-head,.payments-item{display:grid;grid-template-columns:180px 1fr 180px;gap:16px;padding:14px 18px;align-items:center}.payments-head{background:#fff2d8;font-weight:800}.payments-item:nth-child(even){background:#fffaf0}
.empty-state{padding:28px;border-radius:18px;background:#f8fbff;border:1px dashed var(--line);color:var(--muted);text-align:center;font-weight:600}
@media (max-width:1100px){.two-col,.dual-panels,.report-meta,.report-cards-grid,.payment-row,.metrics-grid,.top-form-grid{grid-template-columns:1fr}.clients-layout{grid-template-columns:1fr}.payments-head,.payments-item{grid-template-columns:1fr}.hero-card{flex-direction:column;align-items:flex-start}}

.error-box{padding:14px 16px;border-radius:16px;background:#fff1f2;border:1px solid #fecdd3;color:#9f1239;font-weight:700;display:flex;flex-direction:column;gap:6px}

.report-row-card{padding:18px 22px}.report-row-card-month{background:linear-gradient(180deg,#eff4ff 0%,#ffffff 100%)}.report-row-card-ytd{background:linear-gradient(180deg,#eefbf8 0%,#ffffff 100%)}
.report-row-layout{display:grid;grid-template-columns:180px 1fr;gap:18px;align-items:center}
.report-row-label{font-size:18px;font-weight:800;color:#26415f;line-height:1.2;padding-left:6px}
.report-cards-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;max-width:100%;align-items:stretch}.metric-card{background:#fff;border:1px solid var(--line);border-radius:18px;padding:18px 14px;box-shadow:0 8px 18px rgba(23,43,77,.04);display:flex;flex-direction:column;justify-content:center;min-height:108px}.centered-card{text-align:center;align-items:center}.metric-label{font-size:14px;color:var(--muted);margin-bottom:10px;font-weight:700}.metric-value{font-size:26px;font-weight:800;color:#102a43;line-height:1.1;text-align:center}
.chart-wrap{background:linear-gradient(180deg,#fff 0%,#f9fbff 100%);border:1px solid var(--line);border-radius:24px;padding:12px 16px}.chart-wrap img{display:block;width:100%;border-radius:16px;max-height:460px;object-fit:contain}
@media (max-width: 1100px){.report-row-layout{grid-template-columns:1fr;gap:12px}.report-row-label{padding-left:0}.report-cards-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}

textarea{width:100%;border:1px solid #d4deea;background:#fff;border-radius:16px;padding:14px;font:inherit;color:var(--text);resize:vertical;min-height:140px}
textarea:focus{outline:none;border-color:#6c88ff;box-shadow:0 0 0 3px rgba(67,97,238,.12)}
.recommendations-card{background:linear-gradient(180deg,#f7fbff 0%,#fff 100%)}
.recommendations-box{border:1px solid var(--line);border-radius:18px;background:#fff;padding:18px 20px;line-height:1.6;color:#334155}


.metric-card-delta{position:relative;padding-top:16px}
.metric-delta{position:absolute;top:12px;right:14px;font-size:12px;font-weight:800;line-height:1;border-radius:999px;padding:4px 8px;background:#f8fbff;border:1px solid #dbe6f2}
.metric-delta.delta-up{color:#16a34a;background:#ecfdf3;border-color:#bbf7d0}
.metric-delta.delta-down{color:#dc2626;background:#fef2f2;border-color:#fecaca}
.metric-delta.delta-flat{color:#64748b;background:#f8fafc;border-color:#e2e8f0}


.risk-options-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px 14px}
.risk-check{display:flex;align-items:flex-start;gap:10px;padding:14px 16px;border:1px solid var(--line);border-radius:16px;background:#fbfdff;font-weight:600;color:#31425d;line-height:1.4}
.risk-check input{width:auto;margin-top:2px;accent-color:var(--primary)}
.risk-summary-grid{display:grid;grid-template-columns:minmax(0,1.35fr) minmax(280px,.85fr);gap:18px;align-items:stretch}
.risk-summary-list{display:flex;flex-direction:column;gap:12px}
.risk-summary-item{padding:14px 16px 14px 34px;border:1px solid var(--line);border-radius:16px;background:#fff;position:relative;line-height:1.45;color:#334155}
.risk-summary-item::before{content:'';position:absolute;left:14px;top:19px;width:10px;height:10px;border-radius:50%;background:#4361ee}
.risk-gauge-card{border:1px solid var(--line);border-radius:20px;background:#fff;padding:16px;display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:260px}
.risk-gauge{width:100%;max-width:300px;height:auto;display:block}
.risk-gauge-bg{fill:none;stroke:#e5edf6;stroke-width:14;stroke-linecap:round}
.risk-gauge-progress{fill:none;stroke-width:14;stroke-linecap:round}
.risk-gauge-value{font-size:24px;font-weight:800}
.risk-gauge-caption{font-size:10px;fill:#6b7d92}
.risk-gauge-meta{margin-top:8px;font-weight:700;color:#4b5d74;text-align:center}
@media (max-width:1100px){.risk-options-grid,.risk-summary-grid{grid-template-columns:1fr}}

/* HTML -> PDF styles */
@page {
  size: A4 landscape;
  margin: 16mm 14mm;
}
.pdf-body{
  background:#eef4fb;
  margin:0;
  padding:0;
  font-family:Inter,Segoe UI,Arial,sans-serif;
  color:var(--text);
}
.pdf-report-page{
  width:100%;
  min-height:180mm;
  display:block;
}
.pdf-report-page > *{margin-bottom:10px}
.pdf-report-page > *:last-child{margin-bottom:0}
.pdf-page-break{
  break-before:page;
}
.pdf-header-card,
.pdf-subheader-card,
.pdf-meta-card{
  background:rgba(255,255,255,.94);
  border:1px solid var(--line);
  border-radius:22px;
  padding:14px 18px;
}
.pdf-header-card{
  display:flex;
  justify-content:space-between;
  align-items:flex-end;
}
.pdf-company-name{
  font-size:26px;
  font-weight:800;
  line-height:1.1;
  color:#16324f;
}
.pdf-company-name-small{
  font-size:24px;
}
.pdf-header-right{
  font-size:24px;
  font-weight:800;
  line-height:1.1;
  color:#355a84;
  text-align:right;
}
.pdf-subtitle{
  margin-top:4px;
  font-size:14px;
  color:#6a7c92;
}
.pdf-meta-card{
  display:flex;
  gap:24px;
  align-items:center;
  font-size:12px;
  font-weight:600;
}
.pdf-tight-section{padding:12px 16px}
.pdf-report-row-layout{grid-template-columns:128px 1fr;gap:10px}
.pdf-report-row-layout .report-row-label{font-size:16px;line-height:1.05;white-space:normal}
.pdf-report-row-layout .report-cards-grid{gap:10px}
.pdf-report-row-layout .metric-card{min-height:74px;padding:10px 10px 12px 10px}
.pdf-report-row-layout .metric-label{font-size:11px;margin-bottom:4px}
.pdf-report-row-layout .metric-value{font-size:20px;line-height:1.05}
.pdf-report-row-layout .metric-delta{top:8px;right:10px;font-size:10px;padding:3px 7px}
.pdf-chart-section{padding:12px 14px 14px 14px}
.pdf-chart-wrap{padding:8px 10px}
.pdf-chart-wrap img{max-height:215px;object-fit:contain}
.pdf-risk-grid{grid-template-columns:1.35fr .9fr;gap:16px}
.pdf-risk-list-card{background:#fff;border:1px solid var(--line);border-radius:20px;padding:14px 16px;gap:10px}
.pdf-risk-list-title{font-size:15px;font-weight:800;color:#334155;margin-bottom:2px}
.pdf-risk-list-card .risk-summary-item{padding:0 0 0 18px;border:0;background:transparent;border-radius:0;line-height:1.35;font-size:14px}
.pdf-risk-list-card .risk-summary-item::before{left:0;top:6px;width:8px;height:8px}
.pdf-risk-gauge-card{min-height:250px;gap:4px}
.risk-gauge-meta-top{font-size:13px;font-weight:700;color:#6a7c92;text-align:center}
.pdf-risk-gauge{max-width:260px}
.pdf-payments-card{margin-top:2px}


.pdf-risk-gauge-image{width:220px;max-width:100%;height:auto;display:block;margin-top:2px}
.pdf-risk-percent{font-size:28px;font-weight:800;line-height:1;margin-top:-4px}
.pdf-risk-caption{font-size:12px;color:#6b7d92}


/* PDF payments table fixes */
.pdf-payments-card .payments-table{
  display:block;
  border:1px solid #f2c46d;
  border-radius:18px;
  overflow:hidden;
  background:#fffdf8;
}
.pdf-payments-card .payments-head,
.pdf-payments-card .payments-item{
  display:grid !important;
  grid-template-columns:140px minmax(0,1fr) 150px !important;
  gap:14px;
  align-items:center;
  padding:12px 16px;
}
.pdf-payments-card .payments-head{
  background:#fff2d8;
  font-size:12px;
  font-weight:800;
  color:#8a5a00;
}
.pdf-payments-card .payments-item{
  background:#fff;
  border-top:1px solid #f5e4bf;
}
.pdf-payments-card .payments-item:nth-child(even){
  background:#fffaf0;
}
.pdf-payments-card .payments-head > span:nth-child(3),
.pdf-payments-card .payments-item > span:nth-child(3){
  text-align:right;
  font-weight:700;
}
.pdf-payments-card .payments-head > span:nth-child(1),
.pdf-payments-card .payments-item > span:nth-child(1){
  white-space:nowrap;
}


.public-view { background: #eef3fa; }
.public-shell { max-width: 1320px; padding-top: 20px; }

.topbar-nav-wide{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.user-pill{display:inline-flex;align-items:center;padding:10px 14px;border-radius:999px;background:#eff6ff;border:1px solid #bfdbfe;color:#1e3a8a;font-weight:700}
.btn-small{padding:9px 12px;font-size:13px}
.login-body{min-height:100vh;background:linear-gradient(180deg,#eef4ff 0%,#f8fbff 100%);display:flex;align-items:center;justify-content:center;padding:24px}
.login-shell{width:100%;max-width:520px}.login-card{background:#fff;border:1px solid var(--line);border-radius:28px;box-shadow:0 20px 50px rgba(17,24,39,.08);padding:32px}
.hidden{display:none !important}
.inline-assign-form{display:grid;grid-template-columns:1fr auto;align-items:center;gap:8px}.inline-assign-form select{min-width:0}
.user-row{padding:10px 12px;border-radius:14px;background:#f8fbff;border:1px solid #dbe6f2}
.fixed-user-box{display:flex;flex-direction:column;justify-content:center;padding:14px 16px;border:1px solid var(--line);border-radius:16px;background:#f8fbff;min-height:76px}
.mt-8{margin-top:8px}
.mt-12{margin-top:12px}
.mt-16{margin-top:16px}

@media (max-width: 980px){
  .clients-layout{grid-template-columns:1fr}
  .inline-assign-form{grid-template-columns:1fr}
}
.success-box{padding:14px 16px;border-radius:16px;background:#ecfdf3;border:1px solid #bbf7d0;color:#166534;font-weight:700}
.wrap-row{flex-wrap:wrap}
.user-row-extended{display:flex;justify-content:space-between;align-items:flex-start;gap:14px}
.user-row-main{display:flex;flex-direction:column;gap:6px;min-width:0}
.user-row-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.status-chip{display:inline-flex;align-items:center;padding:6px 10px;border-radius:999px;font-size:12px;font-weight:800}
.status-chip-active{background:#ecfdf3;color:#166534;border:1px solid #bbf7d0}
.status-chip-inactive{background:#f8fafc;color:#64748b;border:1px solid #e2e8f0}
.profile-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}
.profile-box{padding:16px 18px;border-radius:18px;border:1px solid var(--line);background:#f8fbff}
.profile-value{margin-top:6px;font-size:18px;font-weight:800;color:#16324f}
@media (max-width:980px){.user-row-extended,.user-row-actions{flex-direction:column;align-items:stretch}.profile-grid{grid-template-columns:1fr}}


.mb-16{margin-bottom:16px}
.compact-check{font-weight:700;color:#31425d}
.client-card-inactive{opacity:.76}
.client-card-top{justify-content:space-between;align-items:flex-start}
.audit-preview-list{gap:10px}
.audit-preview-item{padding:12px 14px;border:1px solid var(--line);border-radius:16px;background:#fbfdff}
.audit-log-list{display:flex;flex-direction:column;gap:12px}
.audit-log-row{display:flex;justify-content:space-between;gap:16px;padding:14px 16px;border:1px solid var(--line);border-radius:18px;background:#fbfdff}
.audit-log-main{display:flex;flex-direction:column;gap:6px}
.audit-log-time{white-space:nowrap}
.report-meta-5{grid-template-columns:repeat(5,minmax(0,1fr))}
.month-card-draft{background:linear-gradient(180deg,#fff 0%,#f8fafc 100%);border-color:#dbe4ee}.month-card-review{background:linear-gradient(180deg,#fff 0%,#fff8ea 100%);border-color:#f9d382}.month-card-approved{background:linear-gradient(180deg,#fff 0%,#ecfdf5 100%);border-color:#a7f3d0}.month-card-sent{background:linear-gradient(180deg,#fff 0%,#f5f3ff 100%);border-color:#d8b4fe}
@media (max-width:1100px){.report-meta-5{grid-template-columns:1fr}.audit-log-row{flex-direction:column}.audit-log-time{white-space:normal}}
