:root{
  --u-font-base:13px;
  --u-font-title:16px;
  --u-font-kpi:20px;
  --u-radius-card:8px;
  --u-radius-ctl:6px;
  --u-space-1:4px;
  --u-space-2:8px;
  --u-space-3:12px;
  --u-space-4:16px;
  --u-border:#e5e7eb;
  --u-bg:#f6f7fb;
  --u-card:#fff;
  --u-text:#111827;
  --u-muted:#6b7280;
  --u-primary:#2563eb;
  --u-success:#16a34a;
  --u-danger:#dc2626;
  --u-warning:#f59e0b;
  --u-shadow:0 1px 2px rgba(17,24,39,.08);
}

body{font-size:var(--u-font-base);color:var(--u-text)}
.content-wrapper{background:var(--u-bg)}

/* Generic card */
.u-card{background:var(--u-card);border:1px solid var(--u-border);border-radius:var(--u-radius-card);box-shadow:var(--u-shadow)}
.u-card__header{padding:var(--u-space-3) var(--u-space-3) var(--u-space-2);border-bottom:1px solid var(--u-border);display:flex;align-items:center;justify-content:space-between}
.u-card__title{margin:0;font-size:var(--u-font-title);font-weight:600}
.u-card__body{padding:var(--u-space-3)}
.u-card--compact .u-card__body{padding:var(--u-space-2) var(--u-space-3)}

/* Buttons */
.u-btn{border-radius:var(--u-radius-ctl);padding:6px 10px;font-weight:600}
.u-btn--sm{padding:4px 8px;font-size:12px}
.u-btn--primary{background:var(--u-primary);border:1px solid var(--u-primary);color:#fff}
.u-btn--ghost{background:#fff;border:1px solid var(--u-border);color:var(--u-text)}
.u-btn--danger{background:var(--u-danger);border:1px solid var(--u-danger);color:#fff}

/* Badges */
.u-badge{display:inline-block;padding:2px 8px;border-radius:999px;font-size:12px;font-weight:600;line-height:18px}
.u-badge--success{background:rgba(22,163,74,.12);color:var(--u-success)}
.u-badge--danger{background:rgba(220,38,38,.12);color:var(--u-danger)}
.u-badge--muted{background:#eef2f7;color:var(--u-muted)}

/* Filter bar */
.u-filterbar{display:flex;flex-wrap:wrap;gap:var(--u-space-2);align-items:end}
.u-filterbar__group{display:flex;flex-direction:column;gap:var(--u-space-1)}
.u-filterbar__actions{margin-left:auto;display:flex;gap:var(--u-space-2);align-items:center}
.u-filterbar label{margin:0;font-weight:600;color:var(--u-muted);font-size:12px}
.u-filterbar .form-control{height:32px;padding:4px 8px;border-radius:var(--u-radius-ctl)}

/* Tables */
.u-table{width:100%;background:#fff}
.u-table th,.u-table td{padding:8px 10px;border-top:1px solid var(--u-border);vertical-align:middle}
.u-table thead th{border-top:0;border-bottom:1px solid var(--u-border);background:#fafafa;font-weight:700;font-size:12px;color:#374151}
.u-table--compact th,.u-table--compact td{padding:6px 8px}
.u-table__num{text-align:right;white-space:nowrap}
.u-table__neg{color:var(--u-danger);font-weight:700}
.u-table tbody tr:hover{background:#f3f4f6}

/* Dashboard helpers */
.u-callout{border:1px solid var(--u-border);border-radius:var(--u-radius-card);background:#fff;padding:10px 12px}
.u-callout__row{display:flex;flex-wrap:wrap;gap:12px;align-items:center;justify-content:space-between}
.u-kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:12px}
.u-kpi{border:1px solid var(--u-border);border-radius:var(--u-radius-card);background:#fff;padding:12px}
.u-kpi__value{font-size:18px;font-weight:800;margin:0;line-height:1.2}
.u-kpi__label{margin:6px 0 0;color:var(--u-muted);font-weight:600}
.u-kpi--danger .u-kpi__value{color:var(--u-danger)}
.u-kpi--success .u-kpi__value{color:var(--u-success)}

/* Reduce legacy "box" weight a bit */
.box{border-top:none;border:1px solid var(--u-border);border-radius:var(--u-radius-card);box-shadow:var(--u-shadow)}
.box-header{border-bottom:1px solid var(--u-border)}

/* Utilities */
.u-hidden{display:none !important}
.u-mb-2{margin-bottom:var(--u-space-2)}
.u-mb-3{margin-bottom:var(--u-space-3)}
.u-mt-3{margin-top:var(--u-space-3)}
.u-mt-4{margin-top:var(--u-space-4)}
.u-mt-30{margin-top:30px}
.u-p-0{padding:0 !important}
.u-pb-0{padding-bottom:0 !important}
.u-h-350{height:350px}
.u-h-335{height:335px}
.u-h-260{max-height:260px;overflow:auto}
.u-h-229{max-height:229px;overflow:auto}
.u-text-center{text-align:center}
.u-m-0{margin:0 !important}
.u-inline{display:inline-block}
.u-inline-select{display:inline-block;width:auto;vertical-align:middle}
.u-label-inline{margin:0 6px 0 0;font-weight:normal}
.u-row-clickable{cursor:pointer}
.u-pr-1{padding-right:4px !important}
.u-pr-2{padding-right:8px !important}

/* Entrytype summary (entries/index) */
.entrytype-summary-card{margin-top:12px;padding:12px 12px 8px;border:1px solid var(--u-border);border-radius:10px;background:#fff}
.entrytype-summary-title{font-weight:600;color:var(--u-text);margin-bottom:8px}
.entrytype-summary-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px}
.entrytype-summary-item{border:1px solid var(--u-border);background:#f9fafb;border-radius:10px;padding:10px;text-align:left;cursor:pointer}
.entrytype-summary-item:hover{background:#f3f4f6}
.entrytype-summary-item--active{border-color:#3c8dbc;background:#eef6fb}
.entrytype-summary-name{font-weight:600;color:var(--u-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.entrytype-summary-meta{font-size:12px;color:var(--u-muted);margin-top:2px}
.entrytype-summary-total{margin-top:6px;font-weight:700;color:var(--u-text)}

/* Report specific */
.report-profitloss table tr td{text-align:right}
.report-profitloss table tr td:first-child{text-align:left}
.report-reconciliation .summary{background-color:#ffffcc;border:1px solid #bbbbbb;border-collapse:collapse;text-align:left;width:100%}
.report-reconciliation .summary td{border:1px solid #bbbbbb}
.report-reconciliation .td-fixwidth-summary{width:80%;vertical-align:text-top}
.report-reconciliation .td-fixwidth-summary-info{width:200px;vertical-align:text-top}

/* Compact report layout */
.report-compact .box-header{padding:10px 12px}
.report-compact .box-header.with-border{border-bottom:2px solid var(--u-border)}
.report-compact .box-title{font-size:15px;font-weight:700}
.report-compact .box-body{padding:12px}
.report-compact .subtitle{font-size:14px;margin:0 0 8px}
.report-compact .btn-group .btn,.report-compact .btn{border-radius:var(--u-radius-ctl)}
.report-compact .balancesheet.form{margin-bottom:var(--u-space-3)}
.report-compact .u-filterbar__group{min-width:220px}
.report-compact .u-filterbar__group .form-control{min-width:220px}

table.stripped th, table.stripped td {
    border: 1px solid var(--u-border);
}