/* ===== Container (centered) ===== */
.institute-page-layout{
  max-width:1200px;        /* theme container ???? */
  margin:20px auto;
  padding:0 15px;
  display:grid;
  grid-template-columns:260px 1fr;
  gap:25px;
}

/* Sidebar box */
.institute-sidebar{
  background:#fff;
  border-radius:12px;
  box-shadow:0 4px 12px rgba(0,0,0,.08);
  padding:20px;
  height:fit-content;
}
.institute-sidebar h3{
  font-size:16px;font-weight:600;margin:0 0 12px;color:#111;
  border-bottom:1px solid #eee;padding-bottom:6px;
}

/* Search */
.institute-sidebar .institute-search-form{
  display:flex;flex-direction:column;gap:12px;margin-bottom:20px;
}
.institute-sidebar .institute-search-form input{
  border:1px solid #ddd;border-radius:6px;padding:10px 14px;width:100%;
}
.institute-sidebar .institute-search-form button{
  border:0;border-radius:6px;padding:10px 14px;background:#4f46e5;color:#fff;cursor:pointer;
}

/* Sidebar filter group (heading static, list scrolls) */
.sidebar-filter-group{ margin-bottom:20px; }
.sidebar-filter-group .filter-list{
  max-height:1200px; overflow-y:auto; padding:8px; margin-top:10px;
  border:1px solid #eee;border-radius:6px;background:#fafafa;
}
.sidebar-filter-group .filter-btn{
  display:block;width:100%;text-align:left;margin:6px 0;padding:8px 14px;
  border-radius:6px;background:#f9f9f9;color:#333;transition:.3s;
}
.sidebar-filter-group .filter-btn:hover{ background:#ff0066;color:#fff; }
.sidebar-filter-group .filter-btn.active{ background:#cc0055;color:#fff; }

/* Heading + intro */
.tcd-loc-head{ margin-bottom:10px; }
.tcd-loc-title{ margin:0 0 6px; }
.tcd-loc-desc{ margin:0 0 12px; color:#4b5563; }

/* Selected filters chips */
.selected-filters{
  margin:0 0 20px; display:flex; flex-wrap:wrap; gap:8px; align-items:center;
  background:#f9fafb; padding:10px 15px; border:1px solid #e5e7eb; border-radius:8px;
}
.filter-tag{
  display:inline-flex; align-items:center; gap:6px; background:#eef2ff; color:#111827;
  padding:6px 12px; border-radius:20px; font-size:13px; text-decoration:none;
  border:1px solid #c7d2fe; transition:.2s;
}
.filter-tag:hover{ background:#4f46e5;color:#fff;border-color:#4f46e5; }
.clear-all{
  display:inline-flex; align-items:center; gap:6px; background:#f87171; color:#fff !important;
  padding:6px 14px; border-radius:20px; font-size:13px; text-decoration:none; border:1px solid #ef4444;
}
.clear-all:hover{ background:#dc2626; border-color:#dc2626; }

/* ===== Grid & cards ===== */
.institute-content .institute-grid{
  display:grid; grid-template-columns:repeat(auto-fill, minmax(280px,1fr)); gap:20px;
}
.institute-card{
  background:#fff;border-radius:12px;box-shadow:0 4px 12px rgba(0,0,0,.1);
  padding:15px;text-align:center;transition:.3s;
}
.institute-card:hover{ transform:translateY(-4px); box-shadow:0 8px 18px rgba(0,0,0,.14); }
.institute-card .thumb img{
  width:100%; height:190px; object-fit:cover; border-radius:10px; margin-bottom:10px;
}
.inst-title{ font-size:20px; margin:10px 0; }

/* Stars center */
.institute-card .rating{
  text-align:center !important; display:flex; flex-direction:column;
  align-items:center; justify-content:center; margin:8px 0 10px;
}
.institute-card .rating .glsr-summary{
  display:flex; flex-direction:column; align-items:center; text-align:center !important;
}

/* Term tags (location/coaching) center */
.location-type,.coaching-type{
  margin-top:8px; display:flex; flex-wrap:wrap; gap:6px; justify-content:center; text-align:center;
}
.term-btn{ display:inline-block; background:#f1f1f7; color:#333; padding:2px 7px; border-radius:20px; font-size:13px; }
.term-btn:hover{ background:#000040; color:#fff; }
.term-btn1{ display:inline-block; background:#FFF2F9; color:#333; padding:2px 7px; border-radius:20px; font-size:13px; }
.term-btn1:hover{ background:#E60073; color:#fff; }

/* Pagination basic */
.pagination{ display:flex; justify-content:center; margin:26px 0; }
.pagination .page-numbers{
  display:inline-flex; align-items:center; justify-content:center; min-width:40px; height:40px;
  padding:0 14px; margin:0 6px; border:1px solid #e5e7eb; border-radius:999px; background:#fff; color:#111827;
}

/* ===== Mobile off-canvas sidebar ===== */
.filter-toggle-btn{
  display:none; margin-bottom:15px; padding:10px 16px; border:0; border-radius:6px;
  background:#4f46e5; color:#fff; font-size:14px; font-weight:500; cursor:pointer;
}
.sidebar-close{ display:none; position:sticky; top:0; margin:-10px -10px 10px auto; padding:6px 10px; border:0; background:#f3f4f6; border-radius:6px; }
.sidebar-close:hover{ background:#e5e7eb; }

@media (max-width:992px){
  .institute-page-layout{ grid-template-columns:1fr; }
  .filter-toggle-btn{ display:block; }
  .institute-sidebar{
    position:fixed; top:0; left:-100%; width:80%; max-width:340px; height:100vh; background:#fff;
    z-index:9999; overflow-y:auto; box-shadow:2px 0 14px rgba(0,0,0,.25); transition:left .3s; padding:20px;
  }
  .institute-sidebar.active{ left:0; }
  .sidebar-close{ display:inline-block; }
  body.sidebar-open::after{ content:""; position:fixed; inset:0; background:rgba(0,0,0,.4); z-index:9998; }
}

/* Mobile Filter Toggle Button */
.filter-toggle-btn{
  display:none;
  margin-bottom:15px;
  padding:10px 16px;
  border:none;
  border-radius:6px;
  background:#4f46e5;
  color:#fff;
  font-size:14px;
  font-weight:500;
  cursor:pointer;
}

/* Sidebar close button (inside off-canvas) */
.sidebar-close{
  display:none;
  position:sticky;
  top:0;
  margin:-10px -10px 10px auto;
  padding:6px 10px;
  border:none;
  background:#f3f4f6;
  color:#111;
  border-radius:6px;
  cursor:pointer;
}
.sidebar-close:hover{ background:#e5e7eb; }

/* Off-canvas behaviour (mobile only) */
@media (max-width: 992px){
  .institute-page-layout{ grid-template-columns:1fr; }

  .filter-toggle-btn{ display:block; }

  .institute-sidebar{
    position:fixed;
    top:0;
    left:-100%;
    width:80%;
    max-width:340px;
    height:100vh;
    background:#fff;
    z-index:9999;
    overflow-y:auto;
    box-shadow:2px 0 14px rgba(0,0,0,.25);
    transition:left .3s ease-in-out;
    padding:20px;
  }
  .institute-sidebar.active{ left:0; }
  .sidebar-close{ display:inline-block; }

  /* page overlay */
  body.sidebar-open::after{
    content:"";
    position:fixed; inset:0;
    background:rgba(0,0,0,.4);
    z-index:9998;
  }
}

.sidebar-filter-group .filter-list{
  max-height:1000px; overflow-y:auto; padding:8px; margin-top:10px;
  border:1px solid #eee; border-radius:6px; background:#fafafa;
}
.sidebar-filter-group .filter-btn{
  display:block; width:100%; text-align:left; margin:6px 0; padding:8px 14px;
  border-radius:6px; background:#f9f9f9; color:#333; text-decoration:none; transition:.3s;
}
.sidebar-filter-group .filter-btn:hover{ background:#ff0066; color:#fff; }
.sidebar-filter-group .filter-btn.active{
  background:#cc0055; color:#fff; cursor:default;
}

.tcd-loc-title {
  font-size: 22px;
  font-weight: 600;
  margin-bottom: 10px;
  color: #111;
}

.tcd-loc-title .loc-count {
  font-size: 16px;
  font-weight: 400;
  color: #555;
  margin-left: 6px;
}

/* Chips */
.term-btn1 {
  display:inline-block;
  padding:6px 10px;
  border-radius:8px;
  background:#f4f4f4;
  text-decoration:none;
  color:#333;
  font-size:13px;
  margin:2px;
}

.coaching-more-btn {
  background: #AE0057;
  color:#fff;
  border:none;
  cursor:pointer;
  padding:4px 8px;
  border-radius:8px;
  font-size:13px;
  margin:2px;
}

/* Floating popup (global, reused for all buttons) */
.coaching-more-popup--floating {
  position: fixed;
  min-width: 160px;
  max-width: 300px;
  background: #fff;
  box-shadow: 0 8px 24px rgba(0,0,0,0.15);
  border-radius: 8px;
  padding: 8px;
  opacity: 0;
  visibility: hidden;
  transition: opacity .16s ease, transform .16s ease;
  z-index: 99999;
  pointer-events: none;
}
.coaching-more-popup--floating.show {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}
.coaching-more-popup--floating .term-btn1 {
  display:block;
  margin:5px 0;
}

/* Location chips */
.term-btn2 {
  display:inline-block;
  padding:6px 10px;
  border-radius:8px;
  background:#e8f1fb;   /* light blue */
  text-decoration:none;
  color:#0056b3;        /* dark blue text */
  font-size:13px;
  margin:2px;
}

.location-more-btn {
  background: #006A9D;
  color:#fff;
  border:none;
  cursor:pointer;
  padding:4px 8px;
  border-radius:8px;
  font-size:13px;
  margin:2px;
}

/* Floating popup reused (global) — we can style differently by wrapper */
.location-popup .term-btn2 {
  display:block;
  margin:5px 0;
}
