/* Buttons */
.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:8px;font-size:13.5px;font-weight:500;border:1px solid var(--border-strong);background:#fff;color:var(--text);cursor:pointer;text-decoration:none}
.btn:hover{background:#F4F8F5;text-decoration:none}
.btn-primary{background:var(--homi-forest);color:#fff;border-color:var(--homi-forest)}
.btn-primary:hover{background:var(--homi-mid);color:#fff}
.btn-gold{background:var(--homi-gold);color:#3A2B07;border-color:var(--homi-gold)}
.btn-gold:hover{background:#E6B12A}
.btn-ghost{background:transparent;border-color:transparent;color:var(--text-muted)}
.btn-ghost:hover{background:var(--homi-mint);color:var(--homi-forest)}
.btn-danger{background:#fff;color:var(--danger);border-color:#F3D2D2}
.btn-danger:hover{background:#FEF2F2}
.btn-sm{padding:5px 10px;font-size:12.5px}

/* Cards */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:18px;margin-bottom:16px}
.card-pad-0{padding:0}
.card h2,.card h3{margin-top:0}
.card-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 18px;border-bottom:1px solid var(--border)}
.card-body{padding:18px}
.card-foot{padding:12px 18px;border-top:1px solid var(--border);background:var(--surface-alt);display:flex;justify-content:flex-end;gap:8px;border-radius:0 0 var(--radius) var(--radius)}

/* KPI tiles */
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-bottom:20px}
.kpi{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:16px 18px;display:flex;flex-direction:column;gap:6px;position:relative;overflow:hidden}
.kpi::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--homi-mid)}
.kpi.is-warn::before{background:var(--homi-gold)}
.kpi.is-danger::before{background:var(--danger)}
.kpi-label{font-size:12px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}
.kpi-value{font-size:24px;font-weight:700;color:var(--text);font-variant-numeric:tabular-nums}
.kpi-sub{font-size:12px;color:var(--text-muted)}

/* Tables */
.table-wrap{overflow:auto;border:1px solid var(--border);border-radius:var(--radius);background:#fff}
.table{width:100%;border-collapse:collapse;font-size:13.5px}
.table th,.table td{padding:10px 12px;border-bottom:1px solid var(--border);text-align:left;vertical-align:top}
.table th{background:var(--surface-alt);font-weight:600;color:var(--text-muted);font-size:11.5px;text-transform:uppercase;letter-spacing:.06em}
.table tbody tr:hover{background:var(--homi-mint)}
.table .num{text-align:right;font-variant-numeric:tabular-nums}

/* Forms */
.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px 18px}
.form-row{display:flex;flex-direction:column;gap:4px;margin-bottom:14px}
.form-row label{font-size:12.5px;color:var(--text-muted);font-weight:500}
.form-row .hint{font-size:11.5px;color:var(--text-faint)}
.input, select, textarea{
  width:100%;padding:8px 11px;border:1px solid var(--border-strong);border-radius:8px;
  font-size:14px;background:#fff;color:var(--text);font-family:inherit;
}
textarea{min-height:80px;resize:vertical}
.input:focus, select:focus, textarea:focus{outline:none;border-color:var(--homi-mid);box-shadow:0 0 0 3px rgba(45,106,79,.14)}
.input[disabled],.input[readonly]{background:#F6F8F7;color:var(--text-muted)}
.form-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:16px}

/* Badges */
.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:999px;font-size:11.5px;font-weight:600;background:#EFF3F0;color:var(--text-muted)}
.badge-success{background:#E6F4EC;color:#1F5236}
.badge-warn{background:#FEF3CF;color:#7A4D04}
.badge-danger{background:#FCE7E7;color:#8C1F1F}
.badge-info{background:#E1F0F2;color:#0E5A6A}
.badge-draft{background:#EAEDEB;color:#4B5650}
.badge-approved{background:#E6F4EC;color:#1F5236}
.badge-pending{background:#FEF3CF;color:#7A4D04}
.badge-rejected{background:#FCE7E7;color:#8C1F1F}

/* Flash */
.flash{padding:11px 14px;border-radius:8px;margin-bottom:14px;font-size:13.5px;border:1px solid transparent}
.flash-success{background:#E6F4EC;color:#1F5236;border-color:#BFE0CD}
.flash-error{background:#FEEAEA;color:#8C1F1F;border-color:#F3C7C7}

/* Toolbar */
.toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:14px}
.toolbar .grow{flex:1}
.toolbar .input{max-width:280px}

/* Page header */
.page-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;gap:12px;flex-wrap:wrap}
.page-head h1{margin:0}
.page-head .actions{display:flex;gap:8px}

/* Tabs */
.tabs{display:flex;gap:2px;border-bottom:1px solid var(--border);margin-bottom:18px}
.tabs a{padding:10px 14px;color:var(--text-muted);border-bottom:2px solid transparent;font-size:13.5px}
.tabs a:hover{color:var(--text);text-decoration:none}
.tabs a.is-active{color:var(--homi-forest);border-bottom-color:var(--homi-gold);font-weight:600}

/* Empty state */
.empty{padding:48px 24px;text-align:center;color:var(--text-muted)}
.empty .title{font-size:15px;color:var(--text);font-weight:600;margin-bottom:4px}

/* Pagination */
.pager{display:flex;gap:6px;justify-content:flex-end;margin-top:14px}
.pager a,.pager span{padding:6px 10px;border:1px solid var(--border);border-radius:6px;font-size:12.5px;color:var(--text-muted);background:#fff}
.pager .is-active{background:var(--homi-forest);color:#fff;border-color:var(--homi-forest)}
