/* 동일: 공통 */
.mora-empty{max-width:860px;margin:120px auto;padding:60px 24px;border-radius:14px;background:#fafafa;
  text-align:center;font-size:18px;color:#555}
.branch-hero{background:#f6f0ff;padding:80px 0 44px;text-align:center}
.branch-hero .inner{max-width:1120px;margin:0 auto;padding:0 20px}
.branch-title{font-size:42px;font-weight:800;margin:0 0 10px}
.branch-sub{font-size:17px;color:#666}

/* ✅ 리스트 캔버스: 1620px 고정폭 */
.branch-products .inner{
  max-width: 1620px;      /* 핵심 */
  margin: 0 auto;
  padding: 60px 20px 100px;
}

/* ✅ 4열 그리드 (1620 기준) */
.item-grid{
  display:grid;
  grid-template-columns: repeat(4, minmax(0, 1fr)); /* 핵심 */
  gap: 28px; /* 시안과 비슷한 여백 (원하면 32px로) */
}

/* 카드 스타일 동일 */
.card{display:flex;flex-direction:column;border-radius:16px;overflow:hidden;background:#fff;
  box-shadow:0 4px 16px rgba(0,0,0,.06);text-decoration:none;color:#111;
  transition:transform .22s ease, box-shadow .22s ease}
.card:hover{transform:translateY(-4px);box-shadow:0 10px 26px rgba(0,0,0,.09)}

/* ✅ 썸네일 비율 고정 (3:2). aspect-ratio 지원 + padding-top 폴백 */
.thumb{
  width:100%;
  aspect-ratio: 3 / 2;                       /* 최신 브라우저 */
  background:#eee center/cover no-repeat;
  position:relative;
}
@supports not (aspect-ratio: 3 / 2){
  .thumb{ padding-top:66.6667%; }            /* 폴백 */
}

.badges{position:absolute;top:10px;left:10px;display:flex;gap:6px}
.badge{display:inline-block;padding:4px 8px;border-radius:6px;font-size:11px;font-weight:700;color:#fff}
.badge.new{background:#7f58ff}.badge.best{background:#ff6ba3}.badge.hot{background:#ff4d4d}
.badge.md{background:#00c896}.badge.only{background:#f9a825}

.meta{padding:16px 18px 22px}
.name{font-size:18px;font-weight:800;margin-bottom:6px}
.desc{color:#777;font-size:14px;line-height:1.45;min-height:38px}
.price{margin-top:10px;font-size:17px;font-weight:800;text-align:right;color:#222}

/* Branch chips slider */
.branch-chips{margin-top:32px;display:flex;flex-direction:column;gap:12px;align-items:stretch;position:relative;z-index: 4;width:100%;max-width:1200px;margin-left:auto;margin-right:auto}
.branch-chip-all{display:inline-flex;align-items:center;gap:8px;padding:10px 18px;border-radius:999px;border:1px solid rgba(255,255,255,0.55);background:rgba(255,255,255,0.16);color:#fff;font-weight:700;text-decoration:none;transition:all .2s ease}
.branch-chip-all.active{background:#fff;color:#2b0e3a;border-color:#fff}
.region-filter__head{display:flex;align-items:center;gap:12px;flex-wrap:wrap;justify-content:center}
.region-filter__hint{color:#f6f6f6;font-size:14px}
.region-tabs-wrapper{display:flex;align-items:center;gap:10px;position:relative;z-index:3;overflow:visible;width:100%;justify-content:center}
.region-tabs-viewport{flex:1 1 auto;overflow-x:auto;overflow-y:visible;-ms-overflow-style:none;scrollbar-width:none;position:relative;z-index:3;padding:6px 0}
.region-tabs-viewport::-webkit-scrollbar{display:none}
.region-tabs{display:flex;flex-wrap:nowrap;align-items:flex-start;gap:10px;padding:6px 2px;position:relative;z-index:3;min-width:fit-content;pointer-events:auto;width:100%}
.region-arrow{flex:0 0 auto;width:36px;height:36px;border-radius:50%;border:1px solid rgba(255,255,255,0.55);background:#fff;color:#2b0e3a;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:800;cursor:pointer;transition:background .2s,color .2s,opacity .2s}
.region-arrow:hover{background:#2b0e3a;color:#fff}
.region-arrow:disabled{opacity:0.35;cursor:default;background:rgba(255,255,255,0.6);color:#7d6a8a}
.region-tab{position:relative;flex:0 0 auto}
.region-btn{display:flex;align-items:center;gap:8px;padding:12px 16px;border-radius:14px;border:1px solid rgba(255,255,255,0.7);background:#fff;font-weight:800;color:#2b0e3a;cursor:pointer;box-shadow:0 4px 12px rgba(0,0,0,0.08);transition:transform .15s, box-shadow .15s}
.region-btn:hover{transform:translateY(-1px);box-shadow:0 8px 18px rgba(0,0,0,0.12)}
.region-name{font-size:15px}
.region-count{font-size:13px;color:#8f8f8f}
.region-btn .chevron{width:10px;height:10px;border-right:2px solid #5a4a39;border-bottom:2px solid #5a4a39;transform:rotate(45deg);transition:transform .2s}
.region-tab.open .region-btn .chevron{transform:rotate(-135deg)}
.region-dropdown{position:absolute;left:0;top:calc(100% + 6px);min-width:240px;max-width:320px;background:#fff;border:1px solid #e6dff0;border-radius:12px;box-shadow:0 10px 26px rgba(0,0,0,0.12);padding:0;max-height:0;overflow:hidden;transition:max-height .25s ease, padding .2s ease, opacity .2s ease;opacity:0;pointer-events:none;z-index:40;isolation:auto}
.region-dropdown.is-layered{position:absolute;max-height:70vh;overflow:auto;opacity:1;pointer-events:auto;padding:10px 12px;transition:none;z-index:60}
.region-tab.open .region-dropdown{padding:10px 12px;opacity:1;pointer-events:auto;max-height:none;overflow:visible}
.region-dropdown-layer{position:absolute;left:0;right:0;top:100%;pointer-events:none;z-index:50}
.region-branch{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;border-radius:10px;background:#fefaf4;border:1px solid #e6dff0;color:#4a3d2a;text-decoration:none;font-weight:700;margin-bottom:8px;position:relative;z-index: 2;}
.region-branch:last-child{margin-bottom:0}
.region-branch:hover{background:#2b0e3a;color:#fff}
.region-branch.active{background:#2b0e3a;color:#fff}
.region-empty{padding:6px 2px;color:#9c8c7a}

/* ✅ 반응형 단계 (1620 → 3/2/1열 스텝 다운) */
@media (max-width: 1400px){ .item-grid{ grid-template-columns: repeat(3, minmax(0,1fr)); } }
@media (max-width: 990px){  .item-grid{ grid-template-columns: repeat(2, minmax(0,1fr)); } }
@media (max-width: 560px){  .item-grid{ grid-template-columns: 1fr; } }
/* 그리드: 1620px 기준 4열, 좌우 여백 포함 */
.branch-products .inner{max-width:1620px;margin:0 auto;padding:60px 20px 100px}
.item-grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:28px 24px;
}
@media (max-width:1400px){
  .item-grid{grid-template-columns:repeat(3, 1fr);}
}
@media (max-width:1024px){
  .item-grid{grid-template-columns:repeat(2, 1fr);}
}
@media (max-width:600px){
  .item-grid{grid-template-columns:1fr;}
}

/* 카드/썸네일/뱃지 기존 스타일 유지 */
.card{display:flex;flex-direction:column;border-radius:16px;overflow:hidden;background:#fff;
  box-shadow:0 4px 16px rgba(0,0,0,.06);text-decoration:none;color:#111;
  transition:transform .22s ease, box-shadow .22s ease}
.card:hover{transform:translateY(-4px);box-shadow:0 10px 26px rgba(0,0,0,.09)}
.thumb{width:100%;padding-top:66%;background:#eee center/cover no-repeat;position:relative}
.badges{position:absolute;top:10px;left:10px;display:flex;gap:6px;z-index:2}
.badge{display:inline-block;padding:4px 8px;border-radius:6px;font-size:11px;font-weight:700;color:#fff}
.badge.new{background:#7f58ff}.badge.best{background:#ff6ba3}.badge.hot{background:#ff4d4d}
.badge.md{background:#00c896}.badge.only{background:#f9a825}
.meta{padding:16px 18px 22px}
.name{font-size:18px;font-weight:800;margin-bottom:6px}
.desc{color:#777;font-size:14px;line-height:1.45;min-height:38px}
.price{margin-top:10px;font-size:17px;font-weight:800;text-align:right;color:#222}

/* 판매중지/품절 카드 */
.card.disabled{
  pointer-events:none; /* 클릭 방지 */
  filter: grayscale(0.2);
  position: relative;
}
.card.disabled .thumb::after{
  content:"";
  position:absolute;inset:0;
  background:rgba(0,0,0,.45);
  z-index:1;
}
.soldout-cover{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  z-index:3;
}
.soldout-cover span{
  display:inline-block;
  background: #ffffff;
  color: #000000;
  font-weight:800;
  padding: 10px 25px;
  border-radius:999px;
  font-size: 20px;
  letter-spacing: 0;
  box-shadow:0 6px 16px rgba(0,0,0,.35);
}

/* 히어로(그대로) */
.mora-empty{max-width:860px;margin:120px auto;padding:60px 24px;border-radius:14px;background:#fafafa;
  text-align:center;font-size:18px;color:#555}
.branch-hero{background:#f6f0ff;text-align:center;position: relative;height: 500px;display: flex;align-items: center;justify-content: center;}
.branch-hero .inner{max-width: 1620px;margin:0 auto;padding:0 20px;position: relative;}
.branch-title{font-size: 55px;font-weight:800;margin:0 0 10px;color: #fff;}
.branch-sub{font-size: 22px;color: #ffffff;font-weight: 300;}

.card.disabled::after{
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: #00000082;
}
.bg{
    position: absolute;
    top: 0;
    left: 0;
    z-index: 0;
    width: 100%;
    height: 100%;
}
.bg img{
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* ===== Responsive (branch.php) ===== */
/* Container guard to avoid overflow on small screens */
.branch-products .inner { max-width: 1620px; width: 100%; box-sizing: border-box; }

/* Tablet tweaks */
@media (max-width: 1024px){
  /* Hero */
  .branch-hero { height: 380px; padding: 0; }
  .branch-hero .inner { padding: 0 24px; }
  .branch-title { font-size: 40px; }
  .branch-sub { font-size: 16px; }

  /* Chips */
  .branch-chips {margin-top: 24px;gap: 10px;width: calc(100vw - 40px);}
  .branch-chip-all { padding: 10px 16px; font-size: 14px; }
  .region-tabs-wrapper{gap:8px}
  .region-tabs-viewport{padding:4px 0}
  .region-btn{padding:10px 14px;}
  .region-dropdown{min-width:220px;max-width:300px}

  /* Grid */
  .branch-products .inner { padding: 40px 20px 80px; }
}

/* Phablet */
@media (max-width: 768px){
  .branch-hero {height: 500px;}
  .branch-hero .inner { padding: 0 18px; }
  .branch-title { font-size: 32px; }
  .branch-sub { font-size: 14px; }
  .item-grid { gap: 20px; }
}
@media (max-width: 700px){
  .branch-chips{
  }
}
/* Mobile (<=500px) */
@media (max-width: 500px){
  .region-filter__head{
    display: flex;
    flex-direction: column;
    align-items: center;
  }
  .region-name{font-size: 12px;}
  .region-branch{
    font-size: 12px;
  }
  /* Hero */
  .branch-hero {height: auto;padding: 30px 0;}
  .branch-hero .inner { padding: 0 14px; }
  .branch-title { font-size: 24px; line-height: 1.25; }
  .branch-sub { font-size: 13px; opacity: .95; }

  /* Chips */
  .branch-chips {margin-top: 18px;gap: 8px;}
  .branch-chip-all {width: auto;justify-content:center;font-size: 12px;padding: 8px 10px;}
  .region-tabs-wrapper{gap:6px}
  .region-tabs-viewport{padding:2px 0}
  .region-tabs{gap:8px}
  .region-btn{padding: 8px 10px;font-size:13px}
  .region-arrow{width:32px;height:32px}
  .region-dropdown{min-width: 140px;max-width: 256px;}

  /* Product grid/cards */
  .branch-products .inner { padding: 28px 14px 60px; }
  .item-grid { grid-template-columns: 1fr; gap: 14px; }
  .meta { padding: 12px 14px 14px; }
  .name { font-size: 16px; }
  .desc { display: none; }
  .price { text-align: left; font-size: 18px; margin-top: 6px; }

  /* Empty state */
  .mora-empty { margin: 72px auto; padding: 32px 16px; font-size: 16px; }
}
@media (max-width: 400px){
  .branch-chips{
  }
}