/* =====================================================================
 * CRDB Bank — Motor Claim flow styling
 * Built on the bank's own tokens: green #43B02A, dark green #215732,
 * Tembolic font (global), 20px rounded cards.
 * ===================================================================== */

:root {
  --crdb-green: #43B02A;
  --crdb-green-dark: #215732;
  --crdb-green-light: #F3FAF2;
  --crdb-ink: #1f2d29;
  --crdb-muted: #6c757d;
  --crdb-line: #e6e9e7;
}

/* ---- Authentic license-plate font (client app: FeFont) ------------- */
@font-face { font-family: "FeFont"; src: url('../fonts/ffe_font.ttf') format('truetype'); font-display: swap; }

/* ---- Layout host ---------------------------------------------------- */
/* Force the bank typeface so nothing falls back to serif/cursive */
.crdb-claim-wrap, #motorClaimModal { font-family: "Tembolic", Arial, "Helvetica Neue", Helvetica, sans-serif; }
.crdb-claim-wrap { max-width: 1180px; margin: 0 auto; padding: 0 1rem 4rem; }
.crdb-claim-wrap a { text-decoration: none; }

/* ---- Generic card --------------------------------------------------- */
.crdb-card {
  background: #fff;
  border: 1px solid var(--crdb-line);
  border-radius: 20px;
  box-shadow: 0 6px 22px rgba(33, 87, 50, 0.06);
  overflow: hidden;
}
.crdb-card + .crdb-card { margin-top: 1.5rem; }
.crdb-card__head {
  display: flex; align-items: flex-start; justify-content: space-between; gap: 1rem;
  padding: 1.25rem 1.5rem; border-bottom: 1px solid var(--crdb-line);
}
.crdb-card__title {
  font-family: "Tembolic Bold", Arial, sans-serif;
  color: var(--crdb-green-dark);
  font-size: 1.15rem; font-weight: 700; margin: 0;
}
.crdb-card__body { padding: 1.5rem; }

/* ---- Key/value grid ------------------------------------------------- */
.crdb-kv { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 1rem 1.5rem; }
@media (max-width: 575px) { .crdb-kv { grid-template-columns: 1fr; } }
.crdb-kv__k { font-size: .72rem; text-transform: uppercase; letter-spacing: .04em; color: var(--crdb-muted); margin: 0 0 2px; }
.crdb-kv__v { font-size: .98rem; font-weight: 600; color: var(--crdb-ink); margin: 0; word-break: break-word; }

/* ---- Status chip ---------------------------------------------------- */
.crdb-chip {
  display: inline-flex; align-items: center; gap: .45rem;
  padding: .35rem .85rem; border-radius: 999px;
  font-size: .8rem; font-weight: 700; color: #fff; line-height: 1;
}
.crdb-chip__dot { width: .5rem; height: .5rem; border-radius: 50%; background: rgba(255,255,255,.85); }

/* ---- Status notice banner (clean, bank tone, no emoji) ------------- */
.crdb-remark {
  display: flex; gap: 1rem; align-items: stretch;
  border: 1px solid var(--crdb-line); border-radius: 16px;
  padding: 1.1rem 1.35rem; background: #fff; margin-bottom: 1.5rem;
  box-shadow: 0 6px 22px rgba(33, 87, 50, 0.05);
}
.crdb-remark__bar { flex: none; width: 4px; border-radius: 4px; background: var(--crdb-green); }
.crdb-remark__title { font-family: "Tembolic Bold", Arial, sans-serif; font-weight: 700; color: var(--crdb-green-dark); margin: 0 0 .2rem; font-size: 1.02rem; }
.crdb-remark__desc { margin: 0; color: #55605b; font-size: .92rem; line-height: 1.5; }
.crdb-remark--info    .crdb-remark__bar { background: #17A2B8; }
.crdb-remark--warning .crdb-remark__bar { background: #E8830C; }
.crdb-remark--success .crdb-remark__bar { background: #19873F; }
.crdb-remark--error   .crdb-remark__bar { background: #D8392B; }

/* ---- License plate (mirrors crdb-client LicensePlate) --------------- */
.crdb-plate {
  display: inline-flex; align-items: center; gap: .4rem;
  border: 2px solid #111; border-radius: 8px; padding: 5px 7px;
  background: #f4c20d; box-shadow: 0 4px 10px rgba(0,0,0,.18);
}
.crdb-plate--white { background: #fff; }
.crdb-plate__flag {
  width: 22px; height: 15px; border: 1px solid #111; border-radius: 2px; overflow: hidden;
  background: linear-gradient(to bottom right,
    #1eb53a 0%, #1eb53a 37%, #fcd116 37%, #fcd116 43%,
    #000 43%, #000 57%, #fcd116 57%, #fcd116 63%, #00a3dd 63%, #00a3dd 100%);
}
.crdb-plate__no {
  font-family: "FeFont", "Tembolic", Arial, sans-serif;
  letter-spacing: .04em; color: #1a1a1a; font-size: 1.3rem; line-height: 1;
  text-shadow: 0.5px 0.5px 1px rgba(0, 0, 0, .5), -0.5px -0.5px 1px rgba(255, 255, 255, .6);
}

/* ---- Claim update / note (mirrors ClaimUpdatesCard) ----------------- */
.crdb-notes { display: flex; flex-direction: column; gap: 1.4rem; }
.crdb-note__head { display: flex; align-items: baseline; justify-content: space-between; gap: 1rem; margin-bottom: .5rem; }
.crdb-note__author { font-size: .9rem; font-weight: 700; color: var(--crdb-ink); }
.crdb-note__time { font-size: .75rem; color: var(--crdb-muted); white-space: nowrap; }
.crdb-note__body { background: var(--crdb-green-light); border: 1px solid var(--crdb-line); border-radius: 12px; padding: .8rem 1rem; }
.crdb-note__body p { margin: 0; font-size: .92rem; color: #2b3a35; white-space: pre-wrap; }

/* ---- Document categories + files ------------------------------------ */
.crdb-files-group + .crdb-files-group { margin-top: 1.75rem; }
.crdb-files-group__label {
  font-size: .78rem; text-transform: uppercase; letter-spacing: .06em;
  color: var(--crdb-muted); font-weight: 700; margin: 0 0 .75rem;
}
.crdb-file-cat {
  border: 1px solid var(--crdb-line); border-radius: 14px; padding: 1rem 1.15rem; background: #fff;
}
.crdb-file-cat + .crdb-file-cat { margin-top: .9rem; }
.crdb-file-cat__top { display: flex; align-items: center; justify-content: space-between; gap: .75rem; flex-wrap: wrap; }
.crdb-file-cat__name { font-weight: 700; color: var(--crdb-green-dark); }
.crdb-req {
  font-size: .65rem; font-weight: 700; text-transform: uppercase; letter-spacing: .05em;
  padding: .15rem .5rem; border-radius: 999px; margin-left: .5rem; vertical-align: middle;
}
.crdb-req--need { color: #b23b00; background: #ffe9dd; }
.crdb-req--done { color: #19873f; background: #e4f6e8; }
.crdb-file-list { list-style: none; margin: .85rem 0 0; padding: 0; display: flex; flex-direction: column; gap: .5rem; }
.crdb-file {
  display: flex; align-items: center; gap: .7rem;
  border: 1px solid var(--crdb-line); border-radius: 10px; padding: .55rem .7rem; background: #fbfcfb;
}
.crdb-file__ic { width: 30px; height: 30px; flex: none; border-radius: 7px; background: var(--crdb-green-light); display: flex; align-items: center; justify-content: center; color: var(--crdb-green-dark); }
.crdb-file__meta { flex: 1; min-width: 0; }
.crdb-file__name { font-size: .85rem; font-weight: 600; color: var(--crdb-ink); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.crdb-file__sub { font-size: .72rem; color: var(--crdb-muted); }
.crdb-file__actions { display: flex; gap: .35rem; flex: none; }

/* ---- Small buttons (avoid the giant default .btn) ------------------- */
.crdb-btn {
  display: inline-flex; align-items: center; gap: .4rem; cursor: pointer;
  font-family: "Tembolic Bold", Arial, sans-serif; font-size: .8rem; font-weight: 700;
  border-radius: 999px; padding: .5rem 1rem; border: 1.5px solid var(--crdb-green);
  background: #fff; color: var(--crdb-green); transition: all .15s ease; line-height: 1;
}
.crdb-btn:hover { background: var(--crdb-green); color: #fff; }
.crdb-btn--solid { background: var(--crdb-green); color: #fff; }
.crdb-btn--solid:hover { background: #389021; border-color: #389021; }
.crdb-btn--ghost { border-color: var(--crdb-line); color: var(--crdb-muted); }
.crdb-btn--ghost:hover { background: #f1f3f2; color: var(--crdb-ink); border-color: var(--crdb-line); }
.crdb-btn--danger { border-color: #e2c3bf; color: #c0392b; }
.crdb-btn--danger:hover { background: #c0392b; color: #fff; border-color: #c0392b; }
.crdb-btn--xs { padding: .35rem .7rem; font-size: .72rem; }
.crdb-btn[disabled] { opacity: .5; cursor: not-allowed; pointer-events: none; }

/* ---- Page actions bar ----------------------------------------------- */
.crdb-actions { display: flex; flex-wrap: wrap; gap: .6rem; margin-top: 1.25rem; }

/* ---- Financials emphasis ------------------------------------------- */
.crdb-total-row { display: flex; align-items: center; justify-content: space-between; padding-top: .9rem; margin-top: .4rem; border-top: 2px solid var(--crdb-green-light); }
.crdb-total-row .crdb-kv__k { font-size: .8rem; }
.crdb-total-row .crdb-kv__v { font-size: 1.25rem; color: var(--crdb-green-dark); }

/* ---- Demo control panel -------------------------------------------- */
.crdb-demo {
  border: 1px dashed #c7ccc9; border-radius: 14px; padding: 1rem 1.15rem;
  background: #fbfbfa; margin-top: 1.5rem;
}
.crdb-demo__title { font-size: .8rem; font-weight: 700; color: var(--crdb-muted); text-transform: uppercase; letter-spacing: .05em; margin: 0 0 .15rem; }
.crdb-demo__hint { font-size: .78rem; color: var(--crdb-muted); margin: 0 0 .75rem; }
.crdb-demo__btns { display: flex; flex-wrap: wrap; gap: .45rem; }
.crdb-demo__btns .crdb-btn.is-active { background: var(--crdb-green-dark); border-color: var(--crdb-green-dark); color: #fff; }

/* ---- Empty state ---------------------------------------------------- */
.crdb-empty { text-align: center; color: var(--crdb-muted); padding: 1.5rem 1rem; font-size: .92rem; }

/* ===== Entry modal (policy picker / verify) ========================= */
#motorClaimModal .modal-content { padding: 2rem; border-radius: 20px; }
@media (max-width: 575px) { #motorClaimModal .modal-content { padding: 1.25rem; } }
.crdb-step { display: none; }
.crdb-step.is-active { display: block; }
.crdb-step__title { font-family: "Tembolic Bold", Arial, sans-serif; color: var(--crdb-green-dark); font-size: 1.45rem; margin: 0 0 .4rem; }
.crdb-step__sub { color: var(--crdb-muted); margin: 0 0 1.4rem; font-size: .95rem; }

/* choice cards (Yes / No) */
.crdb-choices { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
@media (max-width: 575px) { .crdb-choices { grid-template-columns: 1fr; } }
.crdb-choice {
  cursor: pointer; text-align: left; border: 2px solid var(--crdb-line); border-radius: 16px;
  padding: 1.4rem; background: #fff; transition: all .15s ease; width: 100%;
}
.crdb-choice:hover { border-color: var(--crdb-green); box-shadow: 0 8px 24px rgba(67,176,42,.12); }
.crdb-choice__ic { width: 46px; height: 46px; border-radius: 12px; background: var(--crdb-green-light); color: var(--crdb-green-dark); display: flex; align-items: center; justify-content: center; margin-bottom: .8rem; }
.crdb-choice__h { font-family: "Tembolic Bold", Arial, sans-serif; font-weight: 700; color: var(--crdb-green-dark); font-size: 1.05rem; margin: 0 0 .25rem; }
.crdb-choice__p { color: var(--crdb-muted); font-size: .85rem; margin: 0; }

/* policy picker */
.crdb-policy-list { display: flex; flex-direction: column; gap: .9rem; max-height: 60vh; overflow: auto; padding: 2px; }
.crdb-policy {
  cursor: pointer; text-align: left; width: 100%;
  border: 2px solid var(--crdb-line); border-radius: 16px; padding: 1.1rem 1.2rem; background: #fff;
  transition: all .15s ease; display: flex; align-items: center; justify-content: space-between; gap: 1rem;
}
.crdb-policy:hover { border-color: var(--crdb-green); box-shadow: 0 8px 24px rgba(67,176,42,.12); }
.crdb-policy__main { min-width: 0; }
.crdb-policy__veh { font-weight: 700; color: var(--crdb-ink); margin: .6rem 0 .15rem; }
.crdb-policy__meta { font-size: .8rem; color: var(--crdb-muted); }
.crdb-policy__right { text-align: right; flex: none; }
.crdb-policy__cover { font-size: .72rem; font-weight: 700; text-transform: uppercase; letter-spacing: .04em; color: var(--crdb-green-dark); }
.crdb-policy__total { font-weight: 800; color: var(--crdb-green-dark); }

/* verify form */
.crdb-form .form-label { font-weight: 600; color: var(--crdb-green-dark); font-size: .85rem; margin-bottom: .3rem; }
.crdb-form .form-control, .crdb-form .form-select { height: 52px; border-radius: 10px; }
.crdb-cover-toggle { display: grid; grid-template-columns: 1fr 1fr; gap: .6rem; }
.crdb-cover-toggle label {
  display: block; cursor: pointer; text-align: center; border: 2px solid var(--crdb-line);
  border-radius: 12px; padding: .8rem; font-weight: 600; color: var(--crdb-ink);
}
.crdb-cover-toggle input { position: absolute; opacity: 0; pointer-events: none; }
.crdb-cover-toggle input:checked + label,
.crdb-cover-toggle label.is-active { border-color: var(--crdb-green); background: var(--crdb-green-light); color: var(--crdb-green-dark); }
.crdb-modal-actions { display: flex; justify-content: space-between; gap: .6rem; margin-top: 1.6rem; }

/* modal back link */
.crdb-back { background: none; border: 0; color: var(--crdb-muted); font-weight: 600; font-size: .85rem; cursor: pointer; padding: 0; }
.crdb-back:hover { color: var(--crdb-green-dark); }

/* field error */
.crdb-err { color: #c0392b; font-size: .78rem; margin-top: .3rem; display: none; }
.crdb-err.is-shown { display: block; }
