/* =======================
   ICR Careers – Global overrides (TOÀN SITE)
   ======================= */

/* Ẩn Google Map ở footer (nếu có) */
.footer-map { display: none !important; }
footer iframe[src*="google.com/maps"] { display: none !important; }

/* Ẩn widget Jobs ở footer */
.site-footer .widget_joblist,
.site-footer .widget_joblist .widget-title { display: none !important; }

/* Rollback mọi grid đã lỡ áp vào .icr-single */
.icr-single{ display:block !important; }
.icr-single #primary,
.icr-single .site-main{ display:block !important; }

/* Wrapper: chiều ngang TOÀN SITE 70% + căn giữa */
.icr-single .container,
.jobs-wrapper{
  width:70% !important;
  max-width:1600px;
  margin:0 auto;
  box-sizing:border-box;
}

/* Layout 2 cột 7–3 nếu có dùng */
.icr-single .container .grid.grid-2{
  display:grid !important;
  grid-template-columns: minmax(0, 7fr) minmax(280px, 3fr);
  gap:24px;
  align-items:start;
}

/* NỀN chung */
body{ background:#f0f3f7 !important; }

/* =======================
   JOBS WRAPPER
   ======================= */
.jobs-wrapper{
  display:flex; gap:24px; align-items:flex-start;
  padding:24px;
}

/* Khung joblist luôn chiếm hết vùng 70% */
.jobs-wrapper > section[class*="jobs-list"],
.jobs-list.jobs-table,
section[class*="jobs-list"]{
  width:100% !important;
  max-width:none !important;
  box-sizing:border-box;
}

/* FILTER */
.jobs-filter{
  flex:0 0 320px;
  background:transparent !important;
  border-radius:0 !important;
  padding:0;
  box-shadow:none !important;
}
.jobs-filter h2{
  margin:0 0 14px; font-weight:800;
  font-size:clamp(22px,2.2vw,28px);
  color:#1d3d8f;
}
.jobs-filter label{ display:block; margin:16px 0 8px; font-weight:700; color:#1d3d8f; }
.jobs-filter select,
.jobs-filter input[type="text"]{
  width:100%; padding:14px 16px; border-radius:14px;
  border:1px solid #E7ECF4; background:#fff; color:#0F172A; font-size:16px;
}
.jobs-filter select:focus,
.jobs-filter input[type="text"]:focus{
  border-color:#1d3d8f; box-shadow:0 0 0 4px rgba(29,61,143,.12); outline:none;
}
.jobs-filter .btn{ width:160px; }

/* =======================
   JOB LIST – khung bảng
   ======================= */
.jobs-list.jobs-table{
  display:block; background:#fff;
  border:1px solid #E1E6EF; border-radius:18px; overflow:hidden;
  box-shadow:0 8px 18px rgba(13,26,60,.08);
  padding-bottom:8px;
}

/* ===== GRID BỀN VỮNG: POSITION ~40% (2fr); 3 cột còn lại 1fr; có min-width an toàn ===== */
.jobs-table-head{
  display:grid !important;
  grid-template-columns:
    minmax(0, 2fr)               /* POSITION ~40% */
    minmax(160px, 1fr)           /* LOCATION */
    minmax(140px, 1fr)           /* EXPIRED */
    minmax(180px, 1fr);          /* VIEW: đủ chỗ cho nút */
  gap:16px; align-items:center;
  padding:14px 28px;             /* đệm phải để chữ VIEW không bị cắt */
  background:#173472; color:#fff;
  font-weight:700; letter-spacing:.3px;
  border-radius:18px 18px 0 0;
  margin:0; box-sizing:border-box; overflow:visible;
}
.jobs-table-head > *{ white-space:nowrap; }

.job-row{ padding:16px 18px; margin:0; background:#fff; }
.job-row + .job-row{ border-top:1px solid #E9EEF6; }

.job-row__line{
  display:grid !important;
  grid-template-columns:
    minmax(0, 2fr)
    minmax(160px, 1fr)
    minmax(140px, 1fr)
    minmax(180px, 1fr);
  gap:16px; align-items:center;
}

/* VIEW căn phải (desktop) – cover cả khi theme đổi class/markup */
.jobs-table-head > *:last-child,
.job-row__line > *:last-child,
.job-row__line > .col-cta{
  justify-self:end !important;
  text-align:right !important;
  display:flex !important;
  justify-content:flex-end !important;
  align-items:center !important;
}
.job-row__line > *:last-child .view-btn,
.job-row__line > .col-cta .view-btn{
  margin-left:auto; margin-right:0;
  min-width:140px; padding:12px 22px;
  border-radius:999px; line-height:1;
  max-width:100%;
}

/* Mô tả ngắn */
.job-row__desc{
  margin-top:6px;
  font-size:12px; line-height:1.5;
  color:#667085;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden; text-overflow:ellipsis; max-width:100%;
}

/* Typography & Chips */
.job-title{
  color:#1d3d8f; font-weight:600;
  font-size:26px;                /* desktop: +20% */
  line-height:1.25; text-decoration:none;
  overflow-wrap:anywhere;
}
.job-title:hover{ text-decoration:underline; }

.chip{
  display:inline-block; padding:4px 10px; border-radius:999px;
  background:#E8F1FF; border:1px solid #C9D8EE; color:#0F172A;
  font-size:12px; font-weight:700;
  max-width:100%; overflow:hidden; text-overflow:ellipsis; white-space:nowrap;
}

/* Buttons */
.btn, .view-btn, .jobs-filter button{
  display:flex; align-items:center; justify-content:center;
  text-align:center; white-space:nowrap;
  padding:10px 18px; 
  border-radius:24px; border:0; cursor:pointer;
  font-weight:700; letter-spacing:.2px; line-height:1;
}
.btn, .jobs-filter button{
  background:#1d3d8f; color:#fff; box-shadow:inset 0 -4px 0 rgba(0,0,0,.06);
}
.btn:hover, .jobs-filter button:hover{ background:#173472; }
.view-btn{
  background:#E5463F; color:#fff;
  box-shadow:inset 0 -3px 0 rgba(0,0,0,.08);
  min-width:100px; width:auto;
}
.view-btn:hover{ background:#D13E37; }
.col-cta{ text-align:right; }

/* Hover */
.job-row:hover{ background:#fbfdff; }

/* =======================
   Responsive
   ======================= */
@media (max-width:1200px){
  .jobs-wrapper{ width:72% !important; } /* nếu muốn luôn 70% thì xoá dòng này */
}

/* MOBILE ≤1024px */
@media (max-width:1024px){
  .jobs-wrapper{ width:90% !important; flex-direction:column; }
  .jobs-filter{ width:100%; }
  .jobs-table-head{ display:none; }
  .job-row__line{ grid-template-columns:1fr !important; gap:10px; }
  .col-cta{ text-align:left; }
  .view-btn{ width:100%; min-width:0; }
  .job-title{ font-size:31px; line-height:1.3; }   /* mobile: +20% */
  .job-row__desc{ font-size:14px; line-height:1.6; }

  /* View căn trái + full width */
  .job-row__line > *:last-child,
  .job-row__line > .col-cta{
    justify-self:start !important;
    text-align:left !important;
    display:block !important;
  }
  .job-row__line > *:last-child .view-btn,
  .job-row__line > .col-cta .view-btn{
    width:100% !important; text-align:center; margin:0 !important;
  }
}

/* Section joblist (các trang khác) – đồng bộ grid */
section[class*="jobs-list"]{
  background:#fff !important;
  border:1px solid #E1E6EF;
  border-radius:18px;
  overflow:hidden;
  box-shadow:0 8px 18px rgba(13,26,60,.08);
  padding-bottom:8px;
}
section[class*="jobs-list"] .jobs-table-head{
  background:#173472; color:#fff; margin:0; padding:14px 28px;
  grid-template-columns:
    minmax(0, 2fr)
    minmax(160px, 1fr)
    minmax(140px, 1fr)
    minmax(180px, 1fr);
  box-sizing:border-box;
}
section[class*="jobs-list"] .job-row{ background:#fff !important; }
section[class*="jobs-list"] .job-row + .job-row{ border-top:1px solid #E9EEF6; }
section[class*="jobs-list"] .job-row__line{
  display:grid !important;
  grid-template-columns:
    minmax(0, 2fr)
    minmax(160px, 1fr)
    minmax(140px, 1fr)
    minmax(180px, 1fr);
  gap:16px; align-items:center;
}
section[class*="jobs-list"] .view-btn{
  display:flex; align-items:center; justify-content:center;
  background:#E5463F; color:#fff; border:0; border-radius:24px;
  padding:10px 18px; line-height:1; min-width:100px; width:auto;
  box-shadow:inset 0 -3px 0 rgba(0,0,0,.08);
}
section[class*="jobs-list"] .view-btn:hover{ background:#D13E37; }
section[class*="jobs-list"] .job-row__desc{
  margin-top:6px; font-size:13px; line-height:1.5; color:#667085;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical;
  overflow:hidden; text-overflow:ellipsis;
}

/* MOBILE nhỏ ≤600px */
@media (max-width:600px){
  .jobs-wrapper{ width:94% !important; padding:16px !important; }
  .job-row{ padding:16px 16px !important; }
  .chip{ font-size:11px; padding:4px 10px; }
  .job-title{
    display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical;
    overflow:hidden; text-overflow:ellipsis;
  }
}
