/* Homepage layout (two columns) */
.layout{
  display:grid;
  grid-template-columns: 1fr 320px;
  gap:14px;
}
@media (max-width:900px){
  .layout{ grid-template-columns: 1fr; }
}

/* Hide slideshow panel on mobile only */
@media (max-width:520px){
  aside[aria-label="Photos"]{ display:none; }
}

/* Slideshow */
.slideshow{
  position:relative;
  aspect-ratio:4/3;
  border:1px solid var(--line);
  border-radius:var(--radius);
  overflow:hidden;
  background:#fff;
}
.slideshow img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  opacity:0;
  transition:opacity .45s;
}
.slideshow img.active{ opacity:1; }
.slideshow .controls{
  position:absolute;
  inset:auto 8px 8px 8px;
  display:flex;
  justify-content:space-between;
  gap:8px;
  pointer-events:none;
}
.chip{
  pointer-events:auto;
  font-family:Arial,Helvetica,sans-serif;
  font-weight:800;
  font-size:12px;
  padding:.35rem .55rem;
  border:1px solid rgba(0,0,0,.15);
  border-radius:var(--radius);
  background:rgba(255,255,255,.92);
  color:var(--ink);
  cursor:pointer;
}

/* Locations grid */
.locations-grid{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap:10px;
}
@media (max-width:900px){
  .locations-grid{ grid-template-columns: repeat(2, 1fr); }
}
@media (max-width:520px){
  .locations-grid{ grid-template-columns: 1fr; }
}

.location-tile{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:6px;
  padding:14px 10px;
  border:1px solid var(--line);
  border-radius:var(--radius);
  background:#fff;
  text-decoration:none;
  font-family:Arial,Helvetica,sans-serif;
  font-weight:800;
  color:var(--ink);
}
.location-tile:hover{ background:#fffaf0; }
.location-tile img{ height:28px; width:auto; }
.location-tile .loc-name{
  font-size:18px;
  text-align:center;
}
.location-tile .loc-sub{
  font-size:12px;
  font-weight:700;
  color:var(--muted);
  text-align:center;
  margin-top:-2px;
}

/* ===== Modal ===== */
.locmodal{
  position:fixed;
  inset:0;
  z-index:9999;
  display:grid;
  place-items:center;
}
.locmodal[hidden]{ display:none; }

.locmodal__backdrop{
  position:absolute;
  inset:0;
  background:rgba(0,0,0,.35);
}

.locmodal__panel{
  position:relative;
  width:min(560px, calc(100% - 2rem));
  max-height:calc(100vh - 2rem);
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:var(--radius2);
  box-shadow:var(--shadow);
  display:flex;
  flex-direction:column;
}

.locmodal__header{
  padding:10px 12px;
  border-bottom:1px solid var(--line);
  background:linear-gradient(#fff,#f3ecd9);
  display:flex;
  justify-content:space-between;
  align-items:center;
}

.locmodal__titlewrap{
  display:flex;
  align-items:center;
  gap:10px;
  font-family:Arial,Helvetica,sans-serif;
  font-weight:900;
  color:var(--green);
}

.modal-logo{ height:26px; width:auto; }

.locmodal__body{
  padding:12px;
  overflow:auto;
}

.locmodal__photo{
  border:1px solid var(--line);
  border-radius:var(--radius);
  overflow:hidden;
  background:#fff;
}
.locmodal__photo img{
  width:100%;
  height:220px;
  object-fit:cover;
  display:block;
}

/* Modal info */
.locmodal__info{
  margin-top:10px;
  display:grid;
  gap:8px;
  font-family:Arial,Helvetica,sans-serif;
}
.locmodal__row{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  align-items:baseline;
}
.locmodal__label{
  font-weight:800;
  color:var(--ink);
}
.locmodal__value{
  font-weight:700;
  color:var(--muted);
}
a.locmodal__value{
  color:var(--red);
  text-decoration:none;
}
a.locmodal__value:hover{ text-decoration:underline; }

/* Hours list */
.locmodal__value.hours-list{
  display:grid;
  gap:4px;
}
.locmodal__value.hours-list div{
  line-height:1.25;
}
.locmodal__value.hours-list .hours-line{ font-weight:400; }
.locmodal__value.hours-list .hours-line.is-today{
  font-weight:900;
  color:var(--ink);
}

/* CTA row */
.cta-row{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:12px;
}

/* Hide Call on desktop/tablet (modal only) */
a[data-modal-call]{ display:none; }

/* Mobile modal */
.locmodal__mobileclose{ display:none; }

@media (max-width:720px){
  .locmodal__panel{
    width:100vw;
    height:100vh;
    border-radius:0;
  }

  .modal-logo{ height:18px; }

  .locmodal__photo img{ height:260px; }

  /* show Call on mobile */
  a[data-modal-call]{ display:inline-flex; }

  /* make 3 action buttons equal thirds */
  .cta-row{
    display:grid;
    grid-template-columns: repeat(3, 1fr);
    gap:8px;
  }
  .cta-row .btn{
    width:100%;
    justify-content:center;
  }

  /* pinned Back button */
  .locmodal__mobileclose{
    display:flex;
    justify-content:center;
    align-items:center;
    gap:6px;
    position:sticky;
    bottom:0;
    width:100%;
    margin-top:14px;
    padding:14px 0;
    border-top:1px solid var(--line);
    background:var(--paper);
    font-size:16px;
  }
}
