/* CMS page content enhancements (scoped) */

.cms-page-content {
  --cms-text: #222;
  --cms-muted: #5a5a5a;
  /* Match global `a` in css/style.css (body link teal) */
  --cms-link: #5fcac7;
  --cms-card: #ffffff;
  --cms-border: rgba(0, 0, 0, 0.08);
  --cms-shadow: 0 10px 30px rgba(0, 0, 0, 0.08);

  color: var(--cms-text);
  font-size: clamp(1rem, 0.96rem + 0.2vw, 1.0625rem);
  line-height: 1.7;
}

.cms-page-content > :first-child {
  margin-top: 0;
}

.cms-page-content p {
  margin: 0 0 0.9em;
}

.cms-page-content a {
  color: var(--cms-link);
  text-decoration: underline;
  text-underline-offset: 0.18em;
  text-decoration-thickness: 1px;
}

.cms-page-content a:hover,
.cms-page-content a:focus-visible {
  text-decoration-thickness: 2px;
}

.cms-page-content h2,
.cms-page-content h3 {
  line-height: 1.25;
  margin: 1.1em 0 0.5em;
  letter-spacing: -0.01em;
}

.cms-page-content h2 {
  font-size: clamp(1.25rem, 1.05rem + 1vw, 1.75rem);
}

.cms-page-content h3 {
  font-size: clamp(1.125rem, 1rem + 0.6vw, 1.35rem);
}

/* Media + content utilities (for long copy pages) */
.cms-page-content .cms-divider {
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(0, 0, 0, 0.12), transparent);
  margin: 1.25rem 0;
}

.cms-page-content figure {
  margin: 1rem 0;
}

.cms-page-content .cms-figure {
  background: var(--cms-card);
  border: 1px solid var(--cms-border);
  border-radius: 16px;
  padding: 0.75rem;
  box-shadow: var(--cms-shadow);
}

.cms-page-content .cms-figure img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 12px;
  border: 1px solid var(--cms-border);
}

.cms-page-content .cms-figure figcaption {
  margin-top: 0.65rem;
  font-size: 0.95em;
  color: var(--cms-muted);
  line-height: 1.45;
}

/* Float images on desktop; automatically un-float on small screens */
.cms-page-content .cms-float {
  max-width: min(380px, 42%);
  margin: 0.2rem 1.25rem 0.75rem 0;
  float: left;
}

.cms-page-content .cms-float--right {
  float: right;
  margin: 0.2rem 0 0.75rem 1.25rem;
}

@media (max-width: 767.98px) {
  .cms-page-content .cms-float,
  .cms-page-content .cms-float--right {
    float: none;
    max-width: 100%;
    margin: 1rem 0;
  }
}

.cms-page-content .cms-callout {
  border-left: 4px solid rgba(177, 26, 43, 0.55);
  background: rgba(177, 26, 43, 0.06);
  border-radius: 12px;
  padding: 0.9rem 1rem;
  margin: 1rem 0;
}

.cms-page-content .cms-callout p:last-child {
  margin-bottom: 0;
}

/* Simple timeline blocks */
.cms-page-content .cms-timeline {
  margin: 1.25rem 0;
  padding-left: 0;
  list-style: none;
  border-left: 2px solid rgba(0, 0, 0, 0.08);
}

.cms-page-content .cms-timeline > li {
  position: relative;
  padding: 0.25rem 0 0.25rem 1.1rem;
  margin: 0.65rem 0;
}

.cms-page-content .cms-timeline > li::before {
  content: "";
  position: absolute;
  left: -7px;
  top: 0.6rem;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: #fff;
  border: 2px solid rgba(177, 26, 43, 0.55);
}

.cms-page-content .cms-timeline .cms-year {
  font-weight: 800;
  letter-spacing: 0.02em;
  margin-right: 0.35rem;
}

.cms-page-content .cms-timeline p {
  margin: 0.35rem 0 0;
  color: var(--cms-muted);
}

/* Embedded social/video (Facebook, etc.) */
.cms-page-content .cms-video {
  max-width: 560px;
  margin: 1.25rem auto;
}

.cms-page-content .cms-video > * {
  max-width: 100%;
}

/* Google Maps iframe embeds (TinyMCE): override fixed width/height so they stay inside the content column */
.cms-page-content iframe[src*="google.com/maps/embed"],
.cms-page-content iframe[src*="maps.google.com"] {
  display: block;
  width: 100% !important;
  max-width: 100%;
  height: auto !important;
  aspect-ratio: 4 / 3;
  min-height: 200px;
  border: 0 !important;
  border-radius: 12px;
  box-shadow: var(--cms-shadow);
  margin: 1rem 0;
}

/* When the map is the only thing in a paragraph, avoid extra bottom gap from empty line boxes */
.cms-page-content p:has(> iframe[src*="google.com/maps/embed"]),
.cms-page-content p:has(> iframe[src*="maps.google.com"]) {
  margin-bottom: 0.5rem;
}

/* Contact Us layout */
.cms-page-content .contactmap {
  margin-top: 1rem;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(1rem, 0.7rem + 1.2vw, 1.5rem);
  align-items: start;
}

/* Mobile / tablet: location switcher (inserted by site-contactmap-tabs.js) */
.cms-page-content .contactmap .contactmap-loc-tabs {
  display: none;
  grid-column: 1 / -1;
  flex-direction: row;
  flex-wrap: nowrap;
  gap: 0;
  margin: 0 0 0.75rem;
  padding: 0.2rem;
  border-radius: 12px;
  border: 1px solid var(--cms-border);
  background: rgba(0, 0, 0, 0.04);
}

.cms-page-content .contactmap .contactmap-loc-tabs.contactmap-loc-tabs--visible {
  display: flex;
}

.cms-page-content .contactmap .contactmap-loc-tab {
  flex: 1 1 0;
  min-height: 2.75rem;
  padding: 0.5rem 0.65rem;
  margin: 0;
  border: 0;
  border-radius: 10px;
  font: inherit;
  font-size: clamp(0.9rem, 0.82rem + 0.35vw, 1rem);
  font-weight: 600;
  line-height: 1.25;
  color: var(--cms-muted);
  background: transparent;
  cursor: pointer;
  transition:
    background 0.15s ease,
    color 0.15s ease,
    box-shadow 0.15s ease;
}

.cms-page-content .contactmap .contactmap-loc-tab:hover {
  color: var(--cms-text);
}

.cms-page-content .contactmap .contactmap-loc-tab.is-active {
  color: var(--cms-text);
  background: var(--cms-card);
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.08);
}

.cms-page-content .contactmap .contactmap-loc-tab:focus {
  outline: none;
}

.cms-page-content .contactmap .contactmap-loc-tab:focus-visible {
  outline: 2px solid var(--cms-link);
  outline-offset: 2px;
}

.cms-page-content .contactmap.contactmap--tab-mode > .theMapDiv:not([hidden]) {
  grid-column: 1 / -1;
}

@media (max-width: 991.98px) {
  .cms-page-content .contactmap {
    grid-template-columns: 1fr;
  }
}

.cms-page-content .contactmap .theMapDiv {
  background: var(--cms-card);
  border: 1px solid var(--cms-border);
  border-radius: 16px;
  padding: clamp(1rem, 0.85rem + 0.6vw, 1.25rem);
  box-shadow: var(--cms-shadow);
}

.cms-page-content .contactmap .theMapDiv a {
  text-decoration: none;
}

.cms-page-content .contactmap .theMapDiv a:hover,
.cms-page-content .contactmap .theMapDiv a:focus-visible {
  text-decoration: none;
}

.cms-page-content .contactmap .theMapDiv img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 12px;
  border: 1px solid var(--cms-border);
  background: #f4f4f4;
}

.cms-page-content .contactmap .theMapDiv h2 {
  margin: 0.75rem 0 0.35rem;
  font-size: clamp(1.35rem, 1.1rem + 1.1vw, 1.9rem);
  letter-spacing: -0.02em;
}

.cms-page-content .contactmap .theMapDiv p {
  margin-bottom: 0.8rem;
  color: var(--cms-muted);
}

.cms-page-content .contactmap .theMapDiv p a {
  color: inherit;
  text-decoration: none;
}

.cms-page-content .contactmap .theMapDiv p a:hover,
.cms-page-content .contactmap .theMapDiv p a:focus-visible {
  color: var(--cms-link);
  text-decoration: underline;
  text-underline-offset: 0.18em;
}

.cms-page-content .contactmap .theMapDiv ul {
  list-style: none;
  padding-left: 0;
  margin: 0;
  border-top: 1px solid var(--cms-border);
  padding-top: 0.75rem;
}

.cms-page-content .contactmap .theMapDiv ul li {
  margin: 0.2rem 0;
  color: var(--cms-muted);
}

.cms-page-content .contactmap .theMapDiv ul li:first-child {
  font-weight: 700;
  color: var(--cms-text);
  margin-top: 0;
}

.cms-page-content .contactmap .theMapDiv ul em {
  font-style: normal;
  color: var(--cms-text);
}

/* Bottom centered note (your final h2) */
.cms-page-content .contactmap > h2 {
  grid-column: 1 / -1;
  text-align: center !important;
  margin: 0.25rem 0 0;
  padding: 0.9rem 1rem;
  border-radius: 14px;
  border: 1px dashed rgba(177, 26, 43, 0.35);
  background: rgba(177, 26, 43, 0.06);
}

/* Inner pages: space below hero banner before main content (scales with viewport) */
main > .page-title + .page-section {
  margin-top: clamp(1.25rem, 2.5vw + 0.75rem, 3rem);
}

main > .page-title + .sidebar-page-container {
  margin-top: clamp(1.25rem, 2.5vw + 0.75rem, 3rem);
  /* theme .sidebar-page-container uses 80px top padding; alone that is enough */
  padding-top: 1.5rem;
  padding-bottom: 2.5rem;
}

/* Breadcrumb sits directly above: do not stack large margin + 80px theme padding */
main > .page-title + .page-section.page-breadcrumb-row + .sidebar-page-container {
  margin-top: 0.5rem;
  padding-top: 1.25rem;
  padding-bottom: 2.5rem;
}

.page-breadcrumb-row {
  padding-top: 0.35rem;
  padding-bottom: 0.15rem;
}

.page-breadcrumb-row .auto-container {
  text-align: left;
}

/* Breadcrumb row + “Celebrating 50 Years” on one line (CMS inner pages) */
.page-breadcrumb-row__layout {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.35rem 1.25rem;
}

.page-breadcrumb-row__layout > .page-breadcrumb {
  flex: 1 1 auto;
  min-width: 0;
  margin-top: 0;
  margin-bottom: 0;
}

.page-breadcrumb-anniversary {
  margin: 0;
  padding: 0;
  font-family: 'Merienda One', cursive;
  font-size: clamp(1.05rem, 0.95rem + 0.45vw, 1.4rem);
  font-weight: 400;
  letter-spacing: 0.02em;
  color: var(--cms-muted, #5a5a5a);
  flex: 0 0 auto;
  text-align: right;
  align-self: center;
  line-height: 1.3;
}

/* Inside hero image (gallery templates): match white breadcrumb text */
.page-title .page-breadcrumb-anniversary {
  color: #ffffff;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.35);
}

.page-breadcrumb--below-hero {
  margin-top: 0;
  margin-bottom: 0;
}

.page-breadcrumb--below-hero li {
  color: var(--cms-muted, #5a5a5a);
}

.page-breadcrumb--below-hero li::after {
  color: rgba(0, 0, 0, 0.35);
}

.page-breadcrumb--below-hero li a {
  color: var(--cms-link, #5fcac7);
  font-weight: 600;
}

.page-breadcrumb--below-hero li a:hover {
  opacity: 1;
  text-decoration: underline;
  text-underline-offset: 0.15em;
}

/* Policies / long-form legal copy — wrap CMS HTML in <div class="cms-policies">…</div> */
.cms-page-content .cms-policies {
  max-width: min(100%, 52rem);
  margin-inline: auto;
}

/* Optional: only if you still want an in-content link row (breadcrumb lives in .page-breadcrumb-row) */
.cms-page-content .cms-policies > p.cms-policies-topnav {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.35rem 0.5rem;
  margin: 0 0 1.1rem;
  padding: 0.55rem 0.85rem;
  font-size: clamp(0.9rem, 0.86rem + 0.2vw, 0.98rem);
  line-height: 1.45;
  color: var(--cms-muted);
  background: rgba(0, 0, 0, 0.03);
  border: 1px solid var(--cms-border);
  border-radius: 10px;
}

.cms-page-content .cms-policies > p.cms-policies-topnav a {
  font-weight: 600;
  text-decoration: none;
}

.cms-page-content .cms-policies > p.cms-policies-topnav a:hover,
.cms-page-content .cms-policies > p.cms-policies-topnav a:focus-visible {
  text-decoration: underline;
}

.cms-page-content .cms-policies ul {
  margin: 0 0 1.15em;
  padding-left: 1.2em;
  list-style-position: outside;
}

.cms-page-content .cms-policies ul li {
  margin: 0.4em 0;
  padding-left: 0.15em;
}

.cms-page-content .cms-policies ul li::marker {
  color: rgba(177, 26, 43, 0.55);
}

.cms-page-content .cms-policies ul li em {
  display: inline-block;
  margin-top: 0.15em;
  font-size: 0.95em;
  color: var(--cms-muted);
}

/* Address lines immediately before an hours list (e.g. under "Store Hours") */
.cms-page-content .cms-policies p:has(+ ul) {
  margin: 0 0 0.5rem;
  padding: 0.65rem 0.85rem;
  font-weight: 600;
  font-size: clamp(0.95rem, 0.9rem + 0.25vw, 1.05rem);
  line-height: 1.45;
  color: var(--cms-text);
  background: var(--cms-card);
  border: 1px solid var(--cms-border);
  border-radius: 12px;
  box-shadow: var(--cms-shadow);
  overflow-wrap: anywhere;
  word-break: break-word;
}

.cms-page-content .cms-policies h3 + p:has(+ ul) + ul {
  margin-bottom: clamp(1.25rem, 1rem + 1.2vw, 1.75rem);
}

.cms-page-content .cms-policies h3 + .cms-store-locations {
  margin-top: 0.25rem;
  margin-bottom: clamp(1.25rem, 1rem + 1.2vw, 1.75rem);
}

.cms-page-content .cms-policies .cms-store-locations > ul {
  margin-bottom: clamp(0.85rem, 0.65rem + 0.8vw, 1.15rem);
}

/* Store address lines (text-only paragraphs before the map) */
.cms-page-content .cms-policies .cms-store-locations > p:not(:has(iframe)) {
  margin: 0 0 0.5rem;
  padding: 0.65rem 0.85rem;
  font-weight: 600;
  font-size: clamp(0.95rem, 0.9rem + 0.25vw, 1.05rem);
  line-height: 1.45;
  color: var(--cms-text);
  background: var(--cms-card);
  border: 1px solid var(--cms-border);
  border-radius: 12px;
  box-shadow: var(--cms-shadow);
  overflow-wrap: anywhere;
  word-break: break-word;
}

/* Google Maps embed: responsive frame, no inline width overflow */
.cms-page-content .cms-policies .cms-store-locations > p:has(iframe) {
  margin: 0 0 0.65rem;
  padding: 0;
  line-height: 0;
  border-radius: 14px;
  overflow: hidden;
  border: 1px solid var(--cms-border);
  box-shadow: var(--cms-shadow);
  background: var(--cms-card);
}

.cms-page-content .cms-policies .cms-store-locations iframe {
  display: block;
  width: 100%;
  max-width: 100%;
  height: auto;
  aspect-ratio: 4 / 3;
  min-height: 200px;
  border: 0 !important;
  vertical-align: bottom;
}

/* Optional: wrap both store blocks (address + ul pairs) for a two-column layout on wide screens */
@media (min-width: 900px) {
  /* Children: p, ul, p, ul — or with maps: p, p+iframe, ul × 2 — column flow stacks each store in one column */
  .cms-page-content .cms-policies .cms-store-locations {
    display: grid;
    grid-auto-flow: column;
    grid-template-rows: auto auto;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.35rem clamp(1rem, 0.6rem + 1.2vw, 1.5rem);
    align-items: start;
    margin-bottom: 0.5rem;
  }

  .cms-page-content .cms-policies .cms-store-locations:has(iframe) {
    grid-template-rows: repeat(3, auto);
  }

  .cms-page-content .cms-policies .cms-store-locations > ul {
    margin-bottom: 0;
  }
}

/* Awards / press logos + copy — optional <div class="cms-awards"> wrapper narrows width */
.cms-page-content .cms-awards {
  max-width: min(100%, 48rem);
  margin-inline: auto;
}

/* Mini nav row (matches in-content “Home | Section” look used on policies) */
.cms-page-content .cms-awards > p:first-child:not(:has(img)),
.cms-page-content > p:first-child:not(:has(img)):has(+ p:has(> img:first-child)) {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.35rem 0.5rem;
  margin: 0 0 1.35rem;
  padding: 0.55rem 0.85rem;
  font-size: clamp(0.9rem, 0.86rem + 0.2vw, 0.98rem);
  line-height: 1.45;
  color: var(--cms-muted);
  background: rgba(0, 0, 0, 0.03);
  border: 1px solid var(--cms-border);
  border-radius: 10px;
}

.cms-page-content .cms-awards > p:first-child:not(:has(img)) a,
.cms-page-content > p:first-child:not(:has(img)):has(+ p:has(> img:first-child)) a {
  font-weight: 600;
  text-decoration: none;
}

.cms-page-content .cms-awards > p:first-child:not(:has(img)) a:hover,
.cms-page-content .cms-awards > p:first-child:not(:has(img)) a:focus-visible,
.cms-page-content > p:first-child:not(:has(img)):has(+ p:has(> img:first-child)) a:hover,
.cms-page-content > p:first-child:not(:has(img)):has(+ p:has(> img:first-child)) a:focus-visible {
  text-decoration: underline;
}

/* Logo / badge + paragraph as a card (img must be first element in <p>) */
.cms-page-content .cms-awards > p:has(> img:first-child),
.cms-page-content > p:has(> img:first-child) {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  align-items: center;
  gap: clamp(1rem, 3vw, 1.65rem);
  margin: 0 0 1.15rem;
  padding: clamp(1rem, 2.2vw, 1.35rem) clamp(1rem, 2.5vw, 1.5rem);
  background: var(--cms-card);
  border: 1px solid var(--cms-border);
  border-radius: 16px;
  box-shadow: var(--cms-shadow);
}

.cms-page-content .cms-awards > p:has(> img:first-child) img,
.cms-page-content > p:has(> img:first-child) img {
  flex: 0 0 auto;
  width: clamp(104px, 22vw, 168px);
  max-width: min(40vw, 180px);
  height: auto;
  object-fit: contain;
}

.cms-page-content .cms-awards > p:has(> img:first-child) a,
.cms-page-content > p:has(> img:first-child) a {
  font-weight: 600;
}

.cms-page-content .cms-awards > p:has(> img:first-child):last-child,
.cms-page-content > p:has(> img:first-child):last-child {
  margin-bottom: 0;
}

@media (max-width: 575.98px) {
  .cms-page-content .cms-awards > p:has(> img:first-child),
  .cms-page-content > p:has(> img:first-child) {
    flex-direction: column;
    align-items: center;
    text-align: center;
  }

  .cms-page-content .cms-awards > p:has(> img:first-child) img,
  .cms-page-content > p:has(> img:first-child) img {
    width: min(200px, 72vw);
    max-width: 100%;
  }
}

