/* ============================================================
   Wedding Day Offers (weddingdayoffers.co.uk) — UK Wedding Directory
   Stage 1.5: AJAX-rendered content
   ------------------------------------------------------------
   Palette
   --myrtle   : deep botanical green (brand anchor)
   --ivory    : warm page background
   --rose     : dusty rose accent
   --sand     : muted gold for ratings / fine details
   --ink      : body text
   ============================================================ */

:root{
  --myrtle:      #2e4b3f;
  --myrtle-dark: #22382f;
  --ivory:       #faf7f2;
  --ivory-deep:  #f1ebe2;
  --rose:        #c98a8e;
  --rose-soft:   #eddcdd;
  --sand:        #b99a6b;
  --ink:         #26221e;
  --ink-soft:    #6b645c;
  --white:       #ffffff;
  --line:        #e4ddd2;

  --font-display: "Cormorant Garamond", Georgia, serif;
  --font-body:    "Mulish", "Segoe UI", sans-serif;

  --radius: 14px;
  --arch: 190px;                 /* signature arch-top card shape */
  --container: 1180px;
  --shadow: 0 12px 34px rgba(38,34,30,.10);
  --transition: .28s ease;
}

/* ---------- Reset & base ---------- */
*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; }
body{
  font-family:var(--font-body);
  font-size:1rem; line-height:1.65;
  color:var(--ink); background:var(--ivory);
  -webkit-font-smoothing:antialiased;
}
img{ display:block; max-width:100%; height:auto; }
a{ color:inherit; text-decoration:none; }
ul,ol{ list-style:none; }
button{ font:inherit; cursor:pointer; background:none; border:0; color:inherit; }
:focus-visible{ outline:3px solid var(--rose); outline-offset:3px; border-radius:4px; }

.container{ width:min(var(--container), 92%); margin-inline:auto; }
.visually-hidden{
  position:absolute; width:1px; height:1px; margin:-1px;
  clip-path:inset(50%); overflow:hidden; white-space:nowrap;
}

/* ---------- Type helpers ---------- */
h1,h2,h3{ font-family:var(--font-display); font-weight:500; line-height:1.15; }
h2{ font-size:clamp(1.9rem, 3.4vw, 2.7rem); }
h3{ font-size:1.35rem; }
em{ font-style:italic; }

.eyebrow{
  font-size:.72rem; font-weight:700; letter-spacing:.28em;
  text-transform:uppercase; color:var(--rose); margin-bottom:.7rem;
}
.eyebrow--light{ color:var(--rose-soft); }

/* ---------- Buttons ---------- */
.btn{
  display:inline-block; padding:.85rem 1.9rem;
  font-size:.82rem; font-weight:700; letter-spacing:.14em; text-transform:uppercase;
  border-radius:50px; transition:background var(--transition), color var(--transition), border-color var(--transition), transform var(--transition);
}
.btn--solid{ background:var(--myrtle); color:var(--white); }
.btn--solid:hover{ background:var(--myrtle-dark); transform:translateY(-2px); }
.btn--ghost{ border:1.5px solid var(--myrtle); color:var(--myrtle); }
.btn--ghost:hover{ background:var(--myrtle); color:var(--white); }
.btn--lg{ padding:1.05rem 2.4rem; }

/* ============================================================
   Top bar
   ============================================================ */
.topbar{ background:var(--myrtle-dark); color:var(--ivory); font-size:.78rem; }
.topbar__inner{
  display:flex; align-items:center; justify-content:space-between;
  gap:1rem; padding:.45rem 0;
}
.topbar__note{ opacity:.75; }
.topbar__link{ letter-spacing:.05em; }
.topbar__link:hover{ color:var(--rose); }

/* ============================================================
   Header & navigation
   ============================================================ */
.site-header{
  position:sticky; top:0; z-index:60;
  background:rgba(250,247,242,.94); backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line);
}
.site-header__inner{
  display:flex; align-items:center; justify-content:space-between;
  gap:2rem; padding:.9rem 0;
}

.brand{ display:flex; align-items:baseline; gap:.7rem; }
.brand__mark{
  display:grid; place-items:center; align-self:center;
  width:44px; height:44px; border-radius:50% 50% 50% 4px;
  background:var(--myrtle); color:var(--ivory);
  font-family:var(--font-display); font-size:1.05rem; font-style:italic;
}
.brand__name{
  font-family:var(--font-display); font-size:1.6rem; letter-spacing:.02em;
}
.brand__name em{ color:var(--rose); }
.brand__tag{
  font-size:.62rem; letter-spacing:.24em; text-transform:uppercase;
  color:var(--ink-soft);
}

.primary-nav__list{ display:flex; align-items:center; gap:2rem; }
.primary-nav a, .dropdown-trigger{
  font-size:.85rem; font-weight:600; letter-spacing:.1em; text-transform:uppercase;
  padding:.4rem 0; position:relative; display:inline-flex; align-items:center; gap:.4rem;
}
.primary-nav a::after, .dropdown-trigger::after{
  content:""; position:absolute; left:0; bottom:-2px;
  width:0; height:2px; background:var(--rose); transition:width var(--transition);
}
.primary-nav a:hover::after, .primary-nav a.is-current::after,
.has-dropdown:hover .dropdown-trigger::after{ width:100%; }

.chevron{
  width:7px; height:7px; border-right:1.5px solid currentColor; border-bottom:1.5px solid currentColor;
  transform:rotate(45deg) translateY(-2px); transition:transform var(--transition);
}
.has-dropdown{ position:relative; }
.has-dropdown:hover .chevron,
.dropdown-trigger[aria-expanded="true"] .chevron{ transform:rotate(-135deg) translateY(-2px); }

.dropdown{
  position:absolute; top:calc(100% + 14px); left:50%; translate:-50% 0;
  min-width:240px; background:var(--white); border:1px solid var(--line);
  border-radius:var(--radius); box-shadow:var(--shadow); padding:.7rem 0;
  opacity:0; visibility:hidden; transform:translateY(8px);
  transition:opacity var(--transition), transform var(--transition), visibility var(--transition);
}
.has-dropdown:hover .dropdown,
.has-dropdown.is-open .dropdown{ opacity:1; visibility:visible; transform:translateY(0); }
.dropdown a{
  display:block; padding:.5rem 1.4rem; font-size:.8rem; text-transform:none;
  letter-spacing:.03em; font-weight:500;
}
.dropdown a::after{ display:none; }
.dropdown a:hover{ background:var(--ivory); color:var(--myrtle); }
.dropdown__all{ border-top:1px solid var(--line); margin-top:.5rem; padding-top:.4rem; }
.dropdown__all a{ color:var(--rose); font-weight:700; }

/* Mobile toggle */
.nav-toggle{ display:none; flex-direction:column; gap:5px; padding:.5rem; }
.nav-toggle__bar{ width:26px; height:2px; background:var(--ink); transition:transform var(--transition), opacity var(--transition); }
.nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(2){ opacity:0; }
.nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* ============================================================
   Hero
   ============================================================ */
.hero{
  position:relative; min-height:74vh;
  display:flex; align-items:center; text-align:center;
  color:var(--white); overflow:hidden;
}
.hero__slides, .hero__slide{ position:absolute; inset:0; }
.hero__slide{
  background-size:cover; background-position:center;
  opacity:0; transition:opacity 1.4s ease;
}
.hero__slide.is-active{ opacity:1; }
.hero__scrim{
  position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(30,38,33,.35) 0%, rgba(30,38,33,.55) 70%, rgba(30,38,33,.75) 100%);
}
.hero__content{ position:relative; z-index:2; padding:7rem 0 9rem; }
.hero__title{
  font-size:clamp(2.5rem, 6vw, 4.4rem); font-weight:500; margin-bottom:1.2rem;
  text-shadow:0 2px 24px rgba(0,0,0,.35);
}
.hero__title em{ color:var(--rose-soft); }
.hero__lede{
  max-width:620px; margin-inline:auto; font-size:1.06rem; font-weight:300;
  color:rgba(255,255,255,.92);
}
.hero__dots{
  position:absolute; z-index:3; bottom:6.5rem; left:50%; translate:-50% 0;
  display:flex; gap:.7rem;
}
.hero__dot{
  width:10px; height:10px; border-radius:50%;
  background:rgba(255,255,255,.45); transition:background var(--transition), transform var(--transition);
}
.hero__dot.is-active{ background:var(--white); transform:scale(1.25); }

/* ============================================================
   Search panel — signature element, overlaps hero
   ============================================================ */
.search-panel{ margin-top:-4.5rem; position:relative; z-index:5; }
.search-panel__card{
  display:grid; grid-template-columns:1.2fr 1.2fr 1fr auto;
  gap:1.2rem; align-items:end;
  background:var(--white); border:1px solid var(--line);
  border-radius:var(--radius); box-shadow:var(--shadow);
  padding:1.6rem 1.8rem;
}
.search-field label{
  display:block; font-size:.68rem; font-weight:700; letter-spacing:.2em;
  text-transform:uppercase; color:var(--ink-soft); margin-bottom:.45rem;
}
.search-field .optional{ text-transform:none; letter-spacing:0; font-weight:400; }
.search-field select, .search-field input{
  width:100%; padding:.75rem .9rem;
  font:inherit; color:var(--ink);
  background:var(--ivory); border:1px solid var(--line); border-radius:8px;
}
.search-field select:focus, .search-field input:focus{
  outline:none; border-color:var(--rose); box-shadow:0 0 0 3px var(--rose-soft);
}
.search-panel__submit{ height:fit-content; white-space:nowrap; }

/* ============================================================
   Sections (shared)
   ============================================================ */
.section{ padding:5.5rem 0; }
.section--tint{ background:var(--ivory-deep); }
.section-head{ text-align:center; max-width:640px; margin:0 auto 3.2rem; }
.section-head__sub{ margin-top:.9rem; color:var(--ink-soft); }
.section-head--split{
  max-width:none; display:flex; align-items:end; justify-content:space-between;
  text-align:left; gap:2rem; flex-wrap:wrap;
}

/* ============================================================
   Category grid — arch-top cards
   ============================================================ */
.cat-grid{
  display:grid; grid-template-columns:repeat(4, 1fr); gap:2rem 1.6rem;
}
.cat-card{ text-align:center; display:block; }
.cat-card__frame{
  display:block; overflow:hidden;
  border-radius:var(--arch) var(--arch) var(--radius) var(--radius);
  border:1px solid var(--line);
  box-shadow:0 6px 18px rgba(38,34,30,.06);
  aspect-ratio:3/4;
  transition:box-shadow var(--transition), transform var(--transition);
}
.cat-card__frame img{
  width:100%; height:100%; object-fit:cover;
  transition:transform .6s ease;
}
.cat-card:hover .cat-card__frame{ transform:translateY(-6px); box-shadow:var(--shadow); }
.cat-card:hover img{ transform:scale(1.06); }
.cat-card__title{
  display:block; margin-top:1.1rem;
  font-family:var(--font-display); font-size:1.3rem; color:var(--ink);
}
.cat-card__sub{
  display:block; font-size:.78rem; letter-spacing:.12em; text-transform:uppercase;
  color:var(--ink-soft); margin-top:.15rem;
}

/* ============================================================
   How it works
   ============================================================ */
.steps{
  display:grid; grid-template-columns:repeat(3,1fr); gap:2.4rem;
  counter-reset:step;
}
.step{ text-align:center; padding:0 .6rem; }
.step__badge{
  display:grid; place-items:center; width:58px; height:58px; margin:0 auto 1.2rem;
  border:1.5px solid var(--rose); border-radius:50% 50% 50% 4px;
  font-family:var(--font-display); font-size:1.5rem; font-style:italic; color:var(--rose);
}
.step h3{ margin-bottom:.6rem; }
.step p{ color:var(--ink-soft); font-size:.95rem; }

/* ============================================================
   Listing cards (venues & suppliers)
   ============================================================ */
.listing-grid{
  display:grid; grid-template-columns:repeat(4, 1fr); gap:1.6rem;
}
.listing-grid--three{ grid-template-columns:repeat(3, 1fr); }

.listing-card{
  background:var(--white); border:1px solid var(--line); border-radius:var(--radius);
  overflow:hidden; display:flex; flex-direction:column;
  transition:transform var(--transition), box-shadow var(--transition);
}
.listing-card:hover{ transform:translateY(-5px); box-shadow:var(--shadow); }

.listing-card__media{ position:relative; aspect-ratio:4/3; overflow:hidden; }
.listing-card__media img{ width:100%; height:100%; object-fit:cover; transition:transform .6s ease; }
.listing-card:hover .listing-card__media img{ transform:scale(1.05); }

.listing-card__badge{
  position:absolute; left:.9rem; bottom:.9rem;
  background:rgba(46,75,63,.9); color:var(--white);
  font-size:.62rem; font-weight:700; letter-spacing:.18em; text-transform:uppercase;
  padding:.35rem .8rem; border-radius:40px;
}
.listing-card__badge--rose{ background:rgba(201,138,142,.92); }

.fav{
  position:absolute; top:.8rem; right:.8rem;
  width:38px; height:38px; border-radius:50%;
  background:rgba(255,255,255,.9); color:var(--myrtle);
  font-size:1.15rem; line-height:1; display:grid; place-items:center;
  transition:background var(--transition), color var(--transition), transform var(--transition);
}
.fav:hover{ transform:scale(1.1); }
.fav[aria-pressed="true"]{ background:var(--rose); color:var(--white); }

.listing-card__body{ padding:1.3rem 1.3rem 1.4rem; display:flex; flex-direction:column; flex:1; }
.listing-card__meta{
  font-size:.74rem; letter-spacing:.1em; text-transform:uppercase;
  color:var(--ink-soft); margin:.3rem 0 .7rem;
}
.listing-card__desc{ font-size:.92rem; color:var(--ink-soft); flex:1; }
.listing-card__foot{
  display:flex; align-items:center; justify-content:space-between;
  margin-top:1.1rem; padding-top:1rem; border-top:1px solid var(--line);
}
.rating{ color:var(--sand); font-weight:700; font-size:.92rem; }
.rating small{ color:var(--ink-soft); font-weight:400; }
.price{
  font-family:var(--font-display); font-size:1.08rem; font-style:italic; color:var(--myrtle);
}

/* ============================================================
   Testimonials
   ============================================================ */
.quote-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.8rem; }
.quote{
  background:var(--white); border:1px solid var(--line); border-radius:var(--radius);
  padding:2.1rem 1.9rem; position:relative;
}
.quote::before{
  content:"\201C"; position:absolute; top:.6rem; left:1.4rem;
  font-family:var(--font-display); font-size:4.4rem; line-height:1;
  color:var(--rose-soft);
}
.quote blockquote{
  position:relative; font-family:var(--font-display); font-size:1.16rem;
  font-style:italic; line-height:1.5; margin-bottom:1.3rem; padding-top:1.4rem;
}
.quote figcaption strong{ display:block; font-size:.92rem; letter-spacing:.04em; }
.quote figcaption span{ font-size:.78rem; color:var(--ink-soft); }

/* ============================================================
   County cloud
   ============================================================ */
.county-cloud{
  display:flex; flex-wrap:wrap; justify-content:center; gap:.7rem;
  max-width:900px; margin-inline:auto;
}
.county-cloud a{
  display:inline-block; padding:.55rem 1.25rem;
  background:var(--white); border:1px solid var(--line); border-radius:40px;
  font-size:.86rem; font-weight:600;
  transition:background var(--transition), color var(--transition), border-color var(--transition);
}
.county-cloud a:hover{ background:var(--myrtle); border-color:var(--myrtle); color:var(--white); }
.county-cloud__all a{ background:var(--rose-soft); border-color:var(--rose-soft); color:var(--myrtle-dark); font-weight:700; }

/* ============================================================
   CTA banner
   ============================================================ */
.cta{
  background-size:cover; background-position:center;
  color:var(--white); text-align:center; padding:6.5rem 0;
}
.cta h2{ margin-bottom:1rem; }
.cta p{ max-width:560px; margin:0 auto 2rem; color:rgba(255,255,255,.9); }

/* ============================================================
   Blog / inspiration
   ============================================================ */
.post-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.8rem; }
.post-card{
  background:var(--white); border:1px solid var(--line); border-radius:var(--radius);
  overflow:hidden; transition:transform var(--transition), box-shadow var(--transition);
}
.post-card:hover{ transform:translateY(-5px); box-shadow:var(--shadow); }
.post-card__media{ display:block; aspect-ratio:16/10; overflow:hidden; }
.post-card__media img{ width:100%; height:100%; object-fit:cover; transition:transform .6s ease; }
.post-card:hover .post-card__media img{ transform:scale(1.05); }
.post-card__body{ padding:1.4rem 1.5rem 1.6rem; }
.post-card__meta{
  font-size:.72rem; letter-spacing:.14em; text-transform:uppercase;
  color:var(--rose); font-weight:700; margin-bottom:.5rem;
}
.post-card h3{ margin-bottom:.6rem; }
.post-card h3 a:hover{ color:var(--myrtle); }
.post-card p{ font-size:.92rem; color:var(--ink-soft); }

/* ============================================================
   Newsletter
   ============================================================ */
.newsletter{ background:var(--myrtle); color:var(--ivory); padding:3.6rem 0; }
.newsletter__inner{
  display:flex; align-items:center; justify-content:space-between;
  gap:2.5rem; flex-wrap:wrap;
}
.newsletter h2{ font-size:1.8rem; margin-bottom:.4rem; }
.newsletter p{ color:rgba(250,247,242,.75); font-size:.94rem; max-width:480px; }
.newsletter__form{ display:flex; gap:.8rem; flex:1; min-width:300px; max-width:460px; }
.newsletter__form input{
  flex:1; padding:.85rem 1.1rem; font:inherit;
  border:1px solid rgba(250,247,242,.3); border-radius:50px;
  background:rgba(255,255,255,.08); color:var(--ivory);
}
.newsletter__form input::placeholder{ color:rgba(250,247,242,.5); }
.newsletter__form .btn--solid{ background:var(--rose); }
.newsletter__form .btn--solid:hover{ background:#b47478; }

/* ============================================================
   Footer
   ============================================================ */
.site-footer{ background:var(--myrtle-dark); color:rgba(250,247,242,.8); font-size:.9rem; }
.footer-grid{
  display:grid; grid-template-columns:2fr 1fr 1.2fr 1fr;
  gap:2.6rem; padding:4.2rem 0 3rem;
}
.brand__name--footer{ font-size:1.9rem; color:var(--ivory); margin-bottom:.9rem; }
.footer-contact{ margin-top:1.1rem; }
.footer-contact a:hover{ color:var(--rose); }
.footer-col h3{
  font-family:var(--font-body); font-size:.76rem; font-weight:700;
  letter-spacing:.22em; text-transform:uppercase; color:var(--ivory); margin-bottom:1rem;
}
.footer-col li{ margin-bottom:.55rem; }
.footer-col a:hover{ color:var(--rose); }
.footer-legal{
  display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap;
  padding:1.4rem 0; border-top:1px solid rgba(250,247,242,.14); font-size:.78rem;
}
.footer-legal a:hover{ color:var(--rose); }

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width: 1024px){
  .cat-grid{ grid-template-columns:repeat(3,1fr); }
  .listing-grid{ grid-template-columns:repeat(2,1fr); }
  .listing-grid--three{ grid-template-columns:repeat(2,1fr); }
  .search-panel__card{ grid-template-columns:1fr 1fr; }
  .search-panel__submit{ grid-column:1 / -1; }
  .footer-grid{ grid-template-columns:1fr 1fr; }
}

@media (max-width: 820px){
  .topbar__note{ display:none; }
  .nav-toggle{ display:flex; }
  .primary-nav{
    position:absolute; top:100%; left:0; right:0;
    background:var(--white); border-bottom:1px solid var(--line);
    box-shadow:var(--shadow);
    max-height:0; overflow:hidden; transition:max-height .4s ease;
  }
  .primary-nav.is-open{ max-height:640px; overflow-y:auto; }
  .primary-nav__list{ flex-direction:column; align-items:stretch; gap:0; padding:1rem 0; }
  .primary-nav__list > li{ border-bottom:1px solid var(--line); }
  .primary-nav__list > li:last-child{ border-bottom:0; }
  .primary-nav a, .dropdown-trigger{ display:flex; width:100%; padding:1rem 6%; justify-content:space-between; }
  .primary-nav a::after, .dropdown-trigger::after{ display:none; }
  .dropdown{
    position:static; translate:none; min-width:0; box-shadow:none; border:0;
    border-radius:0; background:var(--ivory); padding:0;
    max-height:0; overflow:hidden; opacity:1; visibility:visible; transform:none;
    transition:max-height .35s ease;
  }
  .has-dropdown.is-open .dropdown{ max-height:520px; }
  .dropdown a{ padding:.75rem 9%; }
  .quote-grid, .steps, .post-grid{ grid-template-columns:1fr; }
  .steps{ gap:2rem; }
  .section{ padding:3.8rem 0; }
  .hero__content{ padding:5rem 0 8rem; }
  .newsletter__inner{ flex-direction:column; align-items:flex-start; }
}

@media (max-width: 560px){
  .cat-grid{ grid-template-columns:repeat(2,1fr); gap:1.4rem 1rem; }
  .listing-grid, .listing-grid--three{ grid-template-columns:1fr; }
  .search-panel__card{ grid-template-columns:1fr; padding:1.3rem; }
  .brand__tag{ display:none; }
  .footer-grid{ grid-template-columns:1fr; gap:2rem; }
  .footer-legal{ flex-direction:column; text-align:center; }
  :root{ --arch:140px; }
}

/* ============================================================
   Venue detail page — hero image, at-a-glance panel
   ============================================================ */
.venue-hero{
  min-height:62vh; display:flex; align-items:flex-end;
  background-size:cover; background-position:center;
  color:var(--white);
}
.venue-hero__content{ padding:7rem 0 3.2rem; }
.venue-hero__crumbs{
  font-size:.74rem; font-weight:700; letter-spacing:.2em; text-transform:uppercase;
  color:var(--rose-soft); margin-bottom:.9rem;
}
.venue-hero__crumbs a{ color:inherit; }
.venue-hero__crumbs a:hover{ color:var(--white); }
.venue-hero__crumbs span{ margin:0 .35rem; opacity:.6; }
.venue-hero__title{
  font-family:var(--font-display); font-weight:500;
  font-size:clamp(2.6rem, 6.5vw, 4.4rem); line-height:1.05; margin-bottom:.9rem;
  text-shadow:0 2px 24px rgba(0,0,0,.35);
}
.venue-hero__meta{ font-size:1.02rem; color:var(--ivory); }
.venue-hero__dot{ margin:0 .5rem; opacity:.7; }
.venue-hero__rating{ color:var(--sand); font-weight:700; }
.venue-hero__rating small{ color:var(--ivory); font-weight:400; }

.venue-detail__grid{
  display:grid; grid-template-columns:1.6fr 1fr; gap:3.5rem; align-items:start;
}
.venue-detail h2{ margin-bottom:1.1rem; }
.venue-detail__desc{ font-size:1.08rem; line-height:1.75; }
.venue-detail__note{
  margin-top:1.4rem; padding-top:1.4rem; border-top:1px solid var(--line);
  color:var(--ink-soft); font-size:.95rem;
}
.fact-card{
  background:var(--white); border:1px solid var(--line); border-radius:var(--radius);
  box-shadow:var(--shadow); padding:1.8rem;
  position:sticky; top:1.5rem;
}
.fact-card h3{ margin-bottom:1.2rem; }
.fact-card__list div{
  display:flex; justify-content:space-between; gap:1rem;
  padding:.65rem 0; border-bottom:1px solid var(--line);
}
.fact-card__list dt{
  font-size:.7rem; font-weight:700; letter-spacing:.18em; text-transform:uppercase;
  color:var(--ink-soft); align-self:center;
}
.fact-card__list dd{ text-align:right; }
.fact-card__cta{ display:block; text-align:center; margin-top:1.5rem; }
.fact-card__back{
  display:block; text-align:center; margin-top:1rem;
  font-size:.88rem; color:var(--ink-soft);
}
.fact-card__back:hover{ color:var(--myrtle); }

@media (max-width: 900px){
  .venue-detail__grid{ grid-template-columns:1fr; gap:2.4rem; }
  .fact-card{ position:static; }
  .venue-hero{ min-height:48vh; }
}

/* ---------- Clickable listing cards ---------- */
.listing-card__media a{ display:block; width:100%; height:100%; }
.listing-card__body h3 a{ color:inherit; }
.listing-card__body h3 a:hover{ color:var(--rose); }

/* ============================================================
   Venues page — page hero + filter bar
   ============================================================ */
.page-hero{
  background:linear-gradient(rgba(34,56,47,.85),rgba(34,56,47,.85)),
    url('https://images.pexels.com/photos/18322558/pexels-photo-18322558.jpeg?auto=compress&cs=tinysrgb&w=1200') center/cover;
  color:var(--white); text-align:center;
  padding:5.5rem 0 8rem;
}
.page-hero h1{
  font-family:"Cormorant Garamond", serif; font-weight:500;
  font-size:clamp(2.4rem, 5vw, 3.6rem); line-height:1.1; margin:.4rem 0 .9rem;
}
.page-hero__lede{ max-width:560px; margin:0 auto; color:var(--ivory); opacity:.9; }

.filter-panel{ margin-top:-4.5rem; position:relative; z-index:5; }
.filter-panel__card{
  display:grid; grid-template-columns:1.4fr 1fr 1fr 1.2fr auto;
  gap:1.2rem; align-items:end;
  background:var(--white); border:1px solid var(--line);
  border-radius:var(--radius); box-shadow:var(--shadow);
  padding:1.6rem 1.8rem;
}
.filter-panel .search-field label{ margin-bottom:.45rem; }
.filter-panel__clear{ height:fit-content; white-space:nowrap; }

.section--flush{ padding-top:3rem; }
.results-count{ margin-bottom:1.8rem; color:var(--ink-soft); }
.results-count strong{ color:var(--ink); font-size:1.15em; }
.page-error--inline{ padding:3rem 1rem 4rem; }

@media (max-width: 900px){
  .filter-panel__card{ grid-template-columns:1fr 1fr; }
  .filter-panel__clear{ grid-column:1 / -1; }
}
@media (max-width: 560px){
  .filter-panel__card{ grid-template-columns:1fr; padding:1.3rem; }
  .page-hero{ padding:3.6rem 0 7rem; }
}

/* ---------- AJAX loading & error states ---------- */
.page-loading{
  display:flex; flex-direction:column; align-items:center; gap:1.1rem;
  padding:7rem 1rem; color:var(--myrtle); font-size:1.05rem;
}
.page-loading__spinner{
  width:46px; height:46px; border-radius:50%;
  border:3px solid var(--rose-soft); border-top-color:var(--rose);
  animation:page-spin .9s linear infinite;
}
@keyframes page-spin{ to{ transform:rotate(360deg); } }
.page-error{
  text-align:center; padding:6rem 1rem; color:var(--myrtle);
}
.page-error h2{ margin-bottom:.6rem; }
.page-error p{ margin-bottom:1.6rem; }

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{ transition-duration:.01ms !important; animation-duration:.01ms !important; }
  html{ scroll-behavior:auto; }
}
