/* ═══════════════════════════════
   RESET & BASE
═══════════════════════════════ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:15px}
body{font-family:'Be Vietnam Pro',sans-serif;font-weight:400;background:#f5f5f0;color:#1a1a1a;min-height:100vh}

/* ═══════════════════════════════
   HEADER
═══════════════════════════════ */
header{
  background:#fff;
  border-bottom:2px solid #e5e5e0;
  padding:0 32px;
  display:flex;align-items:center;justify-content:space-between;
  height:68px;
  position:sticky;top:0;z-index:100;
  box-shadow:0 2px 8px rgba(0,0,0,0.06);
}
/* ── MOBILE HEADER: logo giữa, nav phải ── */
@media(max-width:700px){
  header{
    padding:0 14px;
    height:56px;
    justify-content:center;
    position:relative;
  }
  header .logo{
    /* logo căn giữa tuyệt đối */
    position:absolute;
    left:50%;
    transform:translateX(-50%);
  }
  header nav{
    position:absolute;
    right:14px;
    top:50%;
    transform:translateY(-50%);
  }
  .logo-text strong{font-size:11px}
  .logo-text span{display:none}
  .logo-icon{width:36px;height:36px;font-size:15px}
}
.logo{display:flex;align-items:center;gap:12px;cursor:pointer;text-decoration:none}
.logo-img{height:44px;width:auto}
.logo-img-file{
  height:44px;
  width:auto;
  max-width:160px;
  object-fit:contain;
  flex-shrink:0;
}
.logo-icon{
  width:44px;height:44px;background:#05532C;
  display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:18px;color:#fff;letter-spacing:-1px;
  border-radius:2px;flex-shrink:0;
}
@media(max-width:700px){
  .logo-img-file{height:36px;max-width:120px}
  .logo-text{display:none}
}
.logo-text{line-height:1.25}
.logo-text strong{display:block;font-size:13px;font-weight:700;color:#05532C;letter-spacing:0.04em;text-transform:uppercase}
.logo-text span{font-size:10.5px;color:#888;letter-spacing:0.06em;text-transform:uppercase}

nav{display:flex;gap:4px}
.nav-btn{
  padding:8px 18px;
  background:transparent;border:1px solid transparent;
  color:#666;font-family:inherit;font-size:13px;font-weight:500;
  cursor:pointer;border-radius:4px;transition:all .2s;
  letter-spacing:0.02em;
}
.nav-btn:hover{background:#f5f5f0;color:#1a1a1a;border-color:#e0e0d8}
.nav-btn.active{background:#05532C;color:#fff;border-color:#05532C}

/* ═══════════════════════════════
   PAGES
═══════════════════════════════ */
.page{display:none}
.page.active{display:block}

/* ═══════════════════════════════
   SEARCH PAGE LAYOUT
═══════════════════════════════ */
.search-page{max-width:780px;margin:0 auto;padding:40px 24px 80px}

/* ── Brand hero ── */
.brand-hero{
  text-align:center;
  padding:24px 0 32px;
}
.logo-hero-gif{
  display:block;
  margin:0 auto 12px;
  max-width:320px;
  width:100%;
  height:auto;
}
.brand-hero h1{font-size:26px;font-weight:700;color:#1a1a1a;letter-spacing:-0.01em}
@media(max-width:650px){
  .logo-hero-gif{max-width:240px}
  .brand-hero h1{font-size:22px}
}

/* ── Search box ── */
.search-card{
  background:#fff;
  border:1px solid #e5e5e0;
  border-radius:8px;
  padding:28px 32px;
  box-shadow:0 2px 12px rgba(0,0,0,0.06);
}
.search-row{display:flex;gap:0;border:1.5px solid #d0d0c8;border-radius:6px;overflow:hidden;transition:border-color .2s,box-shadow .2s}
.search-row:focus-within{border-color:#05532C;box-shadow:0 0 0 3px rgba(5,83,44,0.1)}
.search-row input{
  flex:1;padding:13px 18px;
  border:none;outline:none;background:transparent;
  font-family:inherit;font-size:16px;font-weight:500;color:#1a1a1a;
  letter-spacing:0.04em;
}
.search-row input::placeholder{color:#aaa;font-weight:400;font-size:15px}
/* .search-row button{
  padding:13px 28px;
  background:#05532C;border:none;
  color:#fff;font-family:inherit;font-size:14px;font-weight:600;
  letter-spacing:0.04em;cursor:pointer;transition:background .2s;
  white-space:nowrap;display:flex;align-items:center;gap:8px;
} */
 .search-row button{
  padding:13px 28px;
  background:#05532C;border:none;
  color:#fff;font-family:inherit;font-size:14px;font-weight:600;
  letter-spacing:0.04em;cursor:pointer;transition:background .2s;
  white-space:nowrap;display:flex;align-items:center;gap:8px;
}
/* Thêm vào cuối block @media(max-width:650px) */
@media(max-width:650px){
  .search-row button{
    padding:13px 16px;
    font-size:13px;
    gap:5px;
  }
  .search-row input{
    font-size:14px;
    padding:13px 12px;
  }
}
.search-row button:hover{background:#044A26}
.search-row button:disabled{opacity:.6;cursor:not-allowed}

.quick-links{margin-top:12px;font-size:12.5px;color:#999;display:flex;align-items:center;flex-wrap:wrap;gap:6px}
.quick-links span{color:#bbb}
.chip{
  padding:3px 10px;
  border:1px solid #e0e0d8;border-radius:20px;
  font-size:12px;font-weight:500;color:#666;
  cursor:pointer;transition:all .2s;background:#fff;
}
.chip:hover{border-color:#05532C;color:#05532C;background:#fff8f7}

/* ═══════════════════════════════
   RESULT CARD
═══════════════════════════════ */
#result{margin-top:24px}

.result-card{
  background:#fff;
  border:1px solid #e5e5e0;
  border-radius:8px;
  overflow:hidden;
  box-shadow:0 2px 12px rgba(0,0,0,0.07);
  animation:slideUp .35s ease both;
}
@keyframes slideUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}

/* Result header bar */
.r-topbar{
  background:linear-gradient(135deg,#05532C 0%,#033D1F 100%);
  padding:20px 28px;
  display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;
}
.r-topbar .r-ma{font-size:22px;font-weight:700;color:#fff;letter-spacing:0.06em}
.r-topbar .r-loai{
  background:rgba(255,255,255,0.2);
  padding:4px 14px;border-radius:20px;
  font-size:12px;font-weight:600;color:#fff;letter-spacing:0.06em;
}

/* Thông tin chung */
.r-body{padding:24px 28px;overflow-x:hidden}

.info-row{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:1px;background:#e8e8e4;
  border:1px solid #e8e8e4;border-radius:6px;
  overflow:hidden;margin-bottom:20px;
}
.info-cell{background:#fff;padding:14px 16px}
.info-cell .ic-label{font-size:10.5px;color:#999;font-weight:500;letter-spacing:0.06em;text-transform:uppercase;margin-bottom:5px}
.info-cell .ic-val{font-size:16px;font-weight:700;color:#1a1a1a;line-height:1.2}
.info-cell .ic-val small{font-size:11px;font-weight:400;color:#888;margin-left:2px}

/* Nội thất box (hàng 2) */
.noi-that-box{
  display:grid;
  grid-template-columns:1fr auto 1fr;
  border:1px solid #d4eadb;
  border-radius:6px;
  background:#f5faf7;
  padding:18px 22px;
  margin-bottom:22px;
  gap:0;
}
.nt-cell{display:flex;flex-direction:column;gap:5px}
.nt-label{font-size:11px;color:#999;font-weight:500;letter-spacing:0.04em}
.nt-gia{font-size:22px;font-weight:700;color:#1a1a1a;line-height:1.2}
.nt-unit{font-size:12px;font-weight:400;color:#888}
.nt-thanh-label{font-size:11px;color:#999;margin-top:8px}
.nt-thanh{font-size:14px;font-weight:700;color:#05532C}
.nt-tong-label{
  font-size:10.5px;color:#888;font-weight:600;
  letter-spacing:.03em;text-transform:uppercase;
  margin-top:12px;padding-top:10px;
  border-top:1px solid #c8ddd0;
}
.nt-tong{font-size:16px;font-weight:800;color:#033D1F}

.nt-divider{width:1px;background:#d4eadb;margin:0 24px}
@media(max-width:650px){
  .noi-that-box{grid-template-columns:1fr}
  .nt-divider{width:100%;height:1px;margin:16px 0}
  .nt-gia{font-size:18px}
}

/* Section title */
.sec-title{
  font-size:14px;font-weight:700;color:#1a1a1a;
  letter-spacing:0.03em;margin-bottom:12px;
  padding-bottom:8px;border-bottom:2px solid #f0f0ea;
  display:flex;align-items:center;gap:8px;
}
.sec-title::before{content:'';width:3px;height:16px;background:#05532C;border-radius:2px;flex-shrink:0}

/* Payment table */
.pay-table{width:100%;border-collapse:collapse;margin-bottom:0;font-size:14px}
.pay-table thead tr{background:#f8f8f4}
.pay-table th{
  padding:10px 14px;text-align:left;
  font-size:11px;font-weight:600;color:#888;
  letter-spacing:0.05em;text-transform:uppercase;
  border-bottom:1px solid #e8e8e4;white-space:nowrap;
}
.pay-table td{padding:13px 14px;border-bottom:1px solid #f0f0ea;vertical-align:middle}
.pay-table tbody tr:last-child td{border-bottom:none}
.pay-table tbody tr:hover{background:#faf9f7}

/* ── MOBILE TABLE: chuyển sang card layout ── */
@media(max-width:700px){
  .pay-table thead{display:none}
  .pay-table tbody{display:block}
  .pay-table tr{
    display:flex;
    align-items:center;
    padding:10px 12px;
    border-bottom:1px solid #f0f0ea;
    gap:10px;
  }
  .pay-table tr:last-child{border-bottom:none}
  .pay-table td{
    display:block;
    padding:0;
    border:none;
  }
  /* Cột đợt: badge nhỏ */
  .pay-table td:nth-child(1){flex-shrink:0}
  /* Cột hạn: chiếm không gian còn lại */
  .pay-table td:nth-child(2){flex:1;font-size:12.5px;line-height:1.35}
  /* Cột tỷ lệ: ẩn trên mobile */
  .pay-table td:nth-child(3){display:none}
  /* Cột số tiền: cố định bên phải */
  .pay-table td:nth-child(4){
    flex-shrink:0;
    text-align:right;
    font-size:13px;
    font-weight:700;
  }
  .dot-badge{width:28px;height:28px;font-size:12px}
  .amount-cell{font-size:13px}
}

.dot-badge{
  display:inline-flex;align-items:center;justify-content:center;
  width:26px;height:26px;border-radius:50%;
  background:#05532C;color:#fff;
  font-size:12px;font-weight:700;flex-shrink:0;
}
.pay-table .han{color:#444;font-size:13.5px}
.pay-table .pct-wrap{display:flex;align-items:center;gap:8px}
.pct-bar{width:80px;height:5px;background:#f0f0ea;border-radius:3px;overflow:hidden;flex-shrink:0}
.pct-fill{height:100%;background:#05532C;border-radius:3px;width:0;transition:width 1s cubic-bezier(.4,0,.2,1);max-width:100%}
.pct-num{font-size:12px;color:#888;font-weight:500;min-width:28px}
.pay-table .so-tien{text-align:right;font-weight:700;font-size:15px;color:#1a1a1a;font-variant-numeric:tabular-nums}
.pay-table .so-tien.dot1{color:#05532C}

/* Source note */
.source-note{
  font-size:11.5px;color:#aaa;
  padding:12px 28px;
  border-top:1px solid #f0f0ea;
  background:#fafaf8;
  font-style:italic;
}

/* Image section */
.img-section{padding:0 28px 24px}
.img-frame{
  border:1px solid #e8e8e4;border-radius:6px;
  overflow:hidden;background:#f8f8f4;
  position:relative;
}
.img-frame img{width:100%;height:auto;max-height:none;object-fit:contain;display:block;background:#f8f8f4}
.img-placeholder{
  height:280px;display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:12px;
  color:#ccc;
}
.img-placeholder svg{opacity:.4}
.img-placeholder p{font-size:12px;letter-spacing:0.08em;text-transform:uppercase;color:#bbb}
.upload-row{margin-top:12px;display:flex;align-items:center;gap:12px;flex-wrap:wrap}
#imgFileInput{display:none}
.upload-lbl{
  display:inline-flex;align-items:center;gap:8px;
  padding:9px 20px;border:1.5px solid #d0d0c8;border-radius:5px;
  background:#fff;color:#666;font-family:inherit;
  font-size:12.5px;font-weight:500;letter-spacing:0.04em;
  cursor:pointer;transition:all .2s;
}
.upload-lbl:hover{border-color:#05532C;color:#05532C}
.upload-hint{font-size:11.5px;color:#bbb}

/* Error */
.error-box{
  background:#fff;border:1px solid #e5e5e0;border-radius:8px;
  padding:48px 24px;text-align:center;
  box-shadow:0 2px 12px rgba(0,0,0,0.06);
}
.error-box .err-ico{font-size:40px;margin-bottom:12px}
.error-box .err-txt{font-size:15px;color:#888;font-weight:500}

/* ═══════════════════════════════
   ADMIN PAGE
═══════════════════════════════ */
.admin-page{max-width:960px;margin:0 auto;padding:36px 24px 80px}
.admin-page h2{font-size:22px;font-weight:700;margin-bottom:6px}
.admin-page .sub{font-size:13.5px;color:#888;margin-bottom:32px}

.admin-tabs{display:flex;gap:4px;margin-bottom:28px;border-bottom:2px solid #e8e8e4}
.tab-btn{
  padding:10px 22px;background:transparent;border:none;
  font-family:inherit;font-size:14px;font-weight:600;color:#999;
  cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;
  transition:all .2s;
}
.tab-btn.active{color:#05532C;border-bottom-color:#05532C}
.tab-btn:hover:not(.active){color:#444}

.tab-panel{display:none}
.tab-panel.active{display:block}

/* Forms */
.form-card{
  background:#fff;border:1px solid #e5e5e0;border-radius:8px;
  padding:24px 28px;margin-bottom:28px;
  box-shadow:0 1px 6px rgba(0,0,0,0.05);
}
.form-card h3{font-size:15px;font-weight:700;margin-bottom:18px;color:#444}
.fg-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px 18px;margin-bottom:18px}
.fg-grid.col2{grid-template-columns:1fr 1fr}
.fg-grid.col4{grid-template-columns:repeat(4,1fr)}
.form-group{display:flex;flex-direction:column;gap:6px}
.form-group.full{grid-column:1/-1}
.form-group label{font-size:11px;font-weight:600;color:#888;letter-spacing:0.07em;text-transform:uppercase}
.form-group input,.form-group select,.form-group textarea{
  padding:10px 13px;
  border:1.5px solid #e0e0d8;border-radius:5px;
  background:#fff;color:#1a1a1a;
  font-family:inherit;font-size:14px;outline:none;
  transition:border-color .2s,box-shadow .2s;
}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{
  border-color:#05532C;box-shadow:0 0 0 3px rgba(5,83,44,0.1);
}
.form-group select option{background:#fff}
.required::after{content:' *';color:#05532C}

.btn-primary{
  padding:11px 28px;background:#05532C;border:none;
  color:#fff;font-family:inherit;font-size:13.5px;font-weight:600;
  border-radius:5px;cursor:pointer;transition:background .2s;
}
.btn-primary:hover{background:#044A26}
.btn-sm{padding:6px 14px;font-size:12px;border-radius:4px}
.btn-ghost{
  padding:8px 16px;background:transparent;
  border:1.5px solid #e0e0d8;color:#666;
  font-family:inherit;font-size:12.5px;font-weight:500;
  border-radius:4px;cursor:pointer;transition:all .2s;
}
.btn-ghost:hover{border-color:#05532C;color:#05532C}
.btn-danger-sm{
  padding:6px 14px;background:transparent;
  border:1.5px solid rgba(5,83,44,.35);color:rgba(5,83,44,.7);
  font-family:inherit;font-size:12px;font-weight:500;
  border-radius:4px;cursor:pointer;transition:all .2s;
}
.btn-danger-sm:hover{border-color:#05532C;color:#05532C;background:rgba(5,83,44,.05)}

/* Data table (admin list) */
.data-table{width:100%;border-collapse:collapse;font-size:13.5px}
.data-table th{
  background:#f8f8f4;padding:10px 14px;
  text-align:left;font-size:11px;font-weight:700;
  color:#888;letter-spacing:0.07em;text-transform:uppercase;
  border-bottom:2px solid #e8e8e4;
}
.data-table td{padding:11px 14px;border-bottom:1px solid #f0f0ea;vertical-align:middle}
.data-table tbody tr:hover{background:#faf9f7}
.data-table tbody tr:last-child td{border-bottom:none}
.ma-cell{font-weight:700;color:#05532C;font-size:15px}
.actions{display:flex;gap:6px}

/* Edit inline */
.edit-input{
  padding:5px 8px;border:1.5px solid #e0e0d8;border-radius:4px;
  font-family:inherit;font-size:13px;width:100%;outline:none;
}
.edit-input:focus{border-color:#05532C}

/* Summary badges */
.badge{
  display:inline-block;padding:3px 10px;border-radius:12px;
  font-size:11px;font-weight:600;letter-spacing:0.04em;
}
.badge-type{background:#fff3cd;color:#856404}
.badge-count{background:#e8f4fd;color:#0c5460}

/* ═══════════════════════════════
   TOAST
═══════════════════════════════ */
.toast{
  position:fixed;bottom:28px;right:28px;
  padding:13px 22px;border-radius:6px;
  background:#1a1a1a;color:#fff;
  font-size:13.5px;font-weight:500;
  box-shadow:0 4px 20px rgba(0,0,0,.2);
  z-index:9999;
  transform:translateY(12px);opacity:0;
  transition:all .32s cubic-bezier(.4,0,.2,1);
  pointer-events:none;max-width:360px;
}
.toast.show{transform:translateY(0);opacity:1}
.toast.ok{background:#1a7a4a}
.toast.err{background:#05532C}

/* Spinner */
.spin{
  display:inline-block;width:14px;height:14px;
  border:2px solid rgba(255,255,255,.4);border-top-color:#fff;
  border-radius:50%;animation:sp .7s linear infinite;
  vertical-align:middle;
}
@keyframes sp{to{transform:rotate(360deg)}}


/* Admin button reveal animation */
@keyframes fadeInBtn {
  from { opacity: 0; transform: translateY(-6px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ═══════════════════════════════
   RESULT TABS (Lịch TT / Lịch Vay NH)
═══════════════════════════════ */
.res-tabs{
  display:flex;gap:0;flex-wrap:wrap;
  border-bottom:2px solid #f0f0ea;
  margin-bottom:18px;
}
.res-tab-btn{
  padding:9px 20px;
  background:transparent;border:none;border-bottom:2px solid transparent;
  font-family:inherit;font-size:13px;font-weight:600;color:#aaa;
  cursor:pointer;margin-bottom:-2px;
  transition:all .2s;white-space:nowrap;
}
.res-tab-btn.active{color:#05532C;border-bottom-color:#05532C}
.res-tab-btn:hover:not(.active){color:#444}
.res-tab-panel{display:none}
.res-tab-panel.active{display:block}

/* Form tính vay */
.loan-form{
  background:#f5faf7;
  border:1px solid #d4eadb;
  border-radius:8px;
  padding:20px 22px;
  margin-bottom:20px;
}
.loan-form-title{
  font-size:13px;font-weight:700;color:#05532C;
  margin-bottom:14px;display:flex;align-items:center;gap:7px;
}
.loan-form-grid{
  display:grid;
  grid-template-columns:1fr 1fr 1fr auto;
  gap:12px 14px;
  align-items:flex-end;
}
@media(max-width:700px){
  /* Tự động cascade xuống 1fr 1fr khai báo trong @max-width:650px */
}
.loan-fg{display:flex;flex-direction:column;gap:5px}
.loan-fg label{font-size:11px;font-weight:600;color:#888;letter-spacing:.06em;text-transform:uppercase}
.loan-fg input,.loan-fg select{
  padding:9px 12px;
  border:1.5px solid #c8ddd0;border-radius:5px;
  background:#fff;color:#1a1a1a;
  font-family:inherit;font-size:14px;outline:none;
  transition:border-color .2s,box-shadow .2s;
}
.loan-fg input:focus,.loan-fg select:focus{
  border-color:#05532C;box-shadow:0 0 0 3px rgba(5,83,44,0.1);
}
.loan-calc-btn{
  padding:10px 22px;
  background:#05532C;border:none;border-radius:5px;
  color:#fff;font-family:inherit;font-size:13px;font-weight:600;
  cursor:pointer;transition:background .2s;white-space:nowrap;
  height:42px;
}
.loan-calc-btn:hover{background:#044A26}

/* Summary tóm tắt vay */
.loan-summary{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1px;background:#e8e8e4;
  border:1px solid #e8e8e4;border-radius:6px;
  overflow:hidden;margin-bottom:18px;
}
/* loan-summary mobile handled in 650px breakpoint */
.ls-cell{background:#fff;padding:13px 15px}
.ls-label{font-size:10.5px;color:#999;font-weight:500;letter-spacing:.06em;text-transform:uppercase;margin-bottom:4px}
.ls-val{font-size:14px;font-weight:700;color:#1a1a1a}
.ls-val.highlight{color:#05532C;font-size:15px}

/* Bảng lịch trả nợ */
.loan-table-wrap{overflow-x:auto;border-radius:6px;border:1px solid #e8e8e4}
.loan-table{
  width:100%;border-collapse:collapse;
  font-size:12px;min-width:820px;
}
.loan-table thead tr{background:#f8f8f4}
.loan-table th{
  padding:9px 12px;text-align:right;
  font-size:10.5px;font-weight:600;color:#888;
  letter-spacing:.05em;text-transform:uppercase;
  border-bottom:2px solid #e8e8e4;white-space:nowrap;
}
.loan-table th:first-child{text-align:center}
.loan-table td{
  padding:8px 10px;border-bottom:1px solid #f0f0ea;
  text-align:right;font-variant-numeric:tabular-nums;
  vertical-align:middle;white-space:nowrap;
}
.loan-table td:first-child{text-align:center;font-weight:700;color:#05532C}
.loan-table tbody tr:last-child td{border-bottom:none}
.loan-table tbody tr:hover{background:#faf9f7}
.loan-table .col-lai{color:#c0392b}
.loan-table .col-goc{color:#2471a3}
.loan-table .col-tong{font-weight:700;color:#1a1a1a}
/* Highlight các tháng trả gốc (NHCS) */
.loan-table tr.has-goc td{background:#f0faf5}
.loan-table tr.has-goc td:first-child{background:#e8f5ee}

/* Pager */
.loan-pager{
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 4px 0;font-size:12.5px;color:#888;
}
.loan-pager-btns{display:flex;gap:6px}
.loan-pager-btn{
  padding:5px 14px;border:1.5px solid #e0e0d8;border-radius:4px;
  background:#fff;font-family:inherit;font-size:12px;font-weight:500;
  color:#666;cursor:pointer;transition:all .2s;
}
.loan-pager-btn:hover:not(:disabled){border-color:#05532C;color:#05532C}
.loan-pager-btn:disabled{opacity:.4;cursor:not-allowed}

/* Filters */
.loan-filters{display:flex;gap:4px;flex-wrap:wrap;background:#f0f0ea;padding:4px;border-radius:6px}
.lf-btn{
  padding:6px 14px;background:transparent;border:none;border-radius:4px;
  font-family:inherit;font-size:12px;font-weight:600;color:#666;
  cursor:pointer;transition:all .2s;
}
.lf-btn.active{background:#fff;color:#05532C;box-shadow:0 1px 3px rgba(0,0,0,.08)}
.lf-btn:hover:not(.active){color:#1a1a1a}

/* Tiêu đề lãi suất badge */
.laisuat-badge{
  display:inline-block;padding:2px 10px;border-radius:12px;
  font-size:11px;font-weight:600;letter-spacing:.03em;
  background:#fff3cd;color:#856404;margin-left:8px;
}
.laisuat-badge.bidv{background:#dbeafe;color:#1e40af}

/* ═══════════════════════════════
   RESPONSIVE – MOBILE (≤650px)
═══════════════════════════════ */
@media(max-width:650px){
  /* Search page */
  .search-page{padding:24px 14px 60px}
  .search-card{padding:18px 14px}

  /* Result card body */
  .r-body{padding:14px 12px}
  .r-topbar{padding:14px 16px}
  .r-ma{font-size:20px}
  .source-note{padding:10px 12px}

  /* Info row: 2×2 thay vì 1×4 */
  .info-row{grid-template-columns:1fr 1fr}
  .info-cell{padding:11px 12px}
  .info-cell .ic-val{font-size:14px}

  /* Nội thất box: xếp dọc */
  .noi-that-box{
    grid-template-columns:1fr;
    padding:14px 14px;
    gap:0;
  }
  .nt-divider{width:100%;height:1px;margin:14px 0}
  .nt-gia{font-size:17px}
  .nt-tong{font-size:14px}

  /* Res-tabs: thu nhỏ padding */
  .res-tab-btn{
    padding:8px 12px;
    font-size:12px;
    flex:1;
    text-align:center;
  }

  /* Image section */
  .img-section{padding:0 12px 18px}

  /* Admin */
  .admin-page{padding:20px 12px 60px}
  .fg-grid,.fg-grid.col2,.fg-grid.col4{grid-template-columns:1fr 1fr}

  /* Loan form: 2 cột trên ≥480, 1 cột trên <480 */
  .loan-form{padding:14px 14px}
  .loan-form-grid{
    grid-template-columns:1fr 1fr;
    gap:10px;
  }
  .loan-calc-btn{
    grid-column:1/-1;
    width:100%;
    height:44px;
  }

  /* Loan summary: 2×2 */
  .loan-summary{grid-template-columns:1fr 1fr}
  .ls-cell{padding:11px 12px}
  .ls-val{font-size:13px}
  .ls-val.highlight{font-size:14px}

  /* Loan table wrapper: scroll ngang */
  .loan-table-wrap{
    margin-left:-12px;
    margin-right:-12px;
    border-radius:0;
    border-left:none;
    border-right:none;
  }

  /* Loan pager: stack */
  .loan-pager{
    flex-direction:column;
    align-items:flex-start;
    gap:8px;
  }
}

/* ═══════════════════════════════
   RESPONSIVE – XS (≤400px)
═══════════════════════════════ */
@media(max-width:400px){
  .brand-hero h1{font-size:18px}
  .r-ma{font-size:18px}

  /* Info row: xếp 1 cột */
  .info-row{grid-template-columns:1fr}
  .info-cell:not(:last-child){border-bottom:1px solid #e8e8e4}

  /* Loan form: 1 cột */
  .loan-form-grid{grid-template-columns:1fr}
  .loan-calc-btn{grid-column:1}

  /* Loan summary: 1 cột */
  .loan-summary{grid-template-columns:1fr}

  /* Tab buttons: rất nhỏ */
  .res-tab-btn{padding:7px 8px;font-size:11px}

  /* Admin grid: 1 cột */
  .fg-grid,.fg-grid.col2,.fg-grid.col4{grid-template-columns:1fr}
}
