/* FILE: assets/css/ca-frontend.css */

.ca-wrap { max-width: 1100px; margin: 0 auto; padding: 12px; }
.ca-tabs { display:flex; gap:10px; flex-wrap:wrap; margin-bottom: 12px; }
.ca-tab { display:inline-flex; padding:10px 14px; border:1px solid #ccd0d4; border-radius: 999px; text-decoration:none; background:#fff; }
.ca-tab--active { border-color:#2271b1; }

.ca-grid-2 { display:grid; grid-template-columns: 1fr 1.4fr; gap:16px; align-items:start; }
.ca-card { background:#fff; border:1px solid #ccd0d4; border-radius:14px; padding:14px; }
.ca-h2 { margin:0 0 10px 0; font-size:18px; }
.ca-h3 { margin:10px 0 6px 0; font-size:15px; }
.ca-muted { color:#50575e; font-size: 13px; }

.ca-form { display:flex; flex-direction:column; gap:12px; }
.ca-row { display:flex; gap:12px; }
.ca-row--wrap { flex-wrap:wrap; }
.ca-label { display:flex; flex-direction:column; gap:6px; font-size:13px; }
.ca-label--inline { min-width: 150px; }
.ca-input { width:100%; padding:10px 12px; border:1px solid #ccd0d4; border-radius:10px; background:#fff; font-size:14px; }

.ca-actions { display:flex; gap:10px; flex-wrap:wrap; align-items:center; }

.ca-btn { display:inline-flex; align-items:center; justify-content:center; gap:8px; padding:10px 12px; border-radius:12px; border:1px solid #ccd0d4; text-decoration:none; cursor:pointer; background:#fff; font-size:14px; line-height:1; }
.ca-btn--sm { padding:8px 10px; border-radius:10px; font-size:13px; }
.ca-btn--primary { border-color:#2271b1; background:#2271b1; color:#fff; }
.ca-btn--ghost { background:#fff; }
.ca-btn--danger { border-color:#d63638; background:#d63638; color:#fff; }
.ca-btn.is-disabled { pointer-events:none; opacity:.5; }

.ca-notice { border-radius:12px; padding:10px 12px; border:1px solid #ccd0d4; background:#fff; margin:10px 0; }
.ca-notice--success { border-color:#00a32a; }
.ca-notice--error { border-color:#d63638; }
.ca-notice--warning { border-color:#dba617; }

.ca-divider { height:1px; background:#e5e5e5; margin:14px 0; }

.ca-table-wrap { width:100%; overflow:auto; -webkit-overflow-scrolling:touch; }
.ca-table { width:100%; border-collapse:collapse; }
.ca-table th, .ca-table td { border-bottom:1px solid #e5e5e5; padding:10px; vertical-align:top; text-align:left; }
.ca-td-actions { display:flex; flex-wrap:wrap; gap:8px; }

.ca-row-latest { outline:2px solid #2271b1; outline-offset:-2px; border-radius:10px; }
.ca-pagination { display:flex; gap:12px; align-items:center; margin-top:12px; flex-wrap:wrap; }

/* Receipt view */
.ca-receipt-box { background:#fff; border:1px solid #ccd0d4; border-radius:14px; padding:14px; }
.ca-sign { display:flex; gap:18px; flex-wrap:wrap; margin-top:16px; }
.ca-sign > div { flex:1; min-width:240px; }
.ca-line { border-top:1px solid #333; margin-top:38px; }

/* Mobile: stack grid + table as cards */
@media (max-width: 840px) {
  .ca-grid-2 { grid-template-columns: 1fr; }
}

@media (max-width: 640px) {
  .ca-row { flex-direction:column; }
  .ca-label--inline { min-width: unset; }

  .ca-table thead { display:none; }
  .ca-table, .ca-table tbody, .ca-table tr, .ca-table td { display:block; width:100%; }
  .ca-table tr { border:1px solid #e5e5e5; border-radius:14px; padding:10px; margin-bottom:10px; }
  .ca-table td { border:none; padding:6px 0; }
  .ca-table td::before {
    content: attr(data-label);
    display:block;
    font-size:12px;
    color:#50575e;
    margin-bottom:3px;
  }
  .ca-td-actions { gap:10px; }
  .ca-btn { width:100%; }
}
