/* ============================================================
   The Event Catalogue — design system
   ============================================================ */

:root{
  /* Warm charcoal (ink) */
  --ink-900:#211d17;
  --ink-800:#2d271f;
  --ink-600:#5f574a;
  --ink-400:#8f8577;
  --ink-200:#ddd3c3;

  /* Sand neutrals */
  --cream-50:#fdfcf8;
  --cream-100:#f8f3ea;
  --cream-200:#efe6d4;

  /* Evergreen (primary — was plum) */
  --plum-700:#1f3d2b;
  --plum-600:#2b5540;
  --plum-500:#3a7156;

  /* Terracotta / copper (accent — was gold) */
  --gold-500:#b95d33;
  --gold-400:#cf7c4a;
  --gold-300:#e5a878;

  /* Olive (tags — was teal) */
  --teal-500:#5b7444;

  --success:#2f7a4b;

  --radius-sm:12px;
  --radius-md:18px;
  --radius-lg:28px;
  --radius-pill:999px;

  --shadow-sm: 0 1px 2px rgba(33,29,23,.06), 0 1px 1px rgba(33,29,23,.04);
  --shadow-md: 0 8px 24px -6px rgba(33,29,23,.16), 0 2px 8px -2px rgba(33,29,23,.08);
  --shadow-lg: 0 24px 60px -12px rgba(33,29,23,.28), 0 8px 24px -8px rgba(33,29,23,.16);
  --shadow-gold: 0 8px 30px -6px rgba(185,93,51,.35);

  --font-display: "Bodoni Moda", "Times New Roman", Georgia, serif;
  --font-body: "Manrope", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;

  --container: 1240px;
}

*, *::before, *::after{ box-sizing: border-box; }
html{ scroll-behavior: smooth; }
body{
  margin:0;
  font-family: var(--font-body);
  color: var(--ink-900);
  background: var(--cream-50);
  -webkit-font-smoothing: antialiased;
}
h1,h2,h3,h4{ font-family: var(--font-display); margin:0; font-weight:600; letter-spacing:-0.01em; }
p{ margin:0; }
ul{ margin:0; padding:0; list-style:none; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }
img{ display:block; max-width:100%; }

.icon svg{ width:1em; height:1em; display:block; }
.icon{ display:inline-flex; width:20px; height:20px; }

.wrap{
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 32px;
}

/* ---------------- Buttons ---------------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding: 12px 22px;
  border-radius: var(--radius-pill);
  border: 1px solid transparent;
  font-weight: 600;
  font-size: 14.5px;
  transition: transform .15s ease, box-shadow .2s ease, background .2s ease, color .2s ease, border-color .2s ease;
  white-space: nowrap;
}
.btn:active{ transform: scale(.97); }
.btn-primary{
  background: linear-gradient(135deg, var(--plum-600), var(--plum-700));
  color: var(--cream-50);
  box-shadow: var(--shadow-sm);
}
.btn-primary:hover{ box-shadow: var(--shadow-md); transform: translateY(-1px); }
.btn-gold{
  background: linear-gradient(135deg, var(--gold-400), var(--gold-500));
  color: #fff;
  box-shadow: var(--shadow-gold);
}
.btn-gold:hover{ transform: translateY(-1px); box-shadow: 0 12px 34px -6px rgba(185,93,51,.45); }
.btn-ghost{
  background: transparent;
  border-color: var(--ink-200);
  color: var(--ink-900);
}
.btn-ghost:hover{ border-color: var(--ink-400); background: var(--cream-100); }
.btn-sm{ padding: 8px 16px; font-size: 13px; }
.btn-block{ width:100%; }

/* ---------------- Top navigation ---------------- */
.nav{
  position: sticky; top:0; z-index: 50;
  background: rgba(253,252,248,.62);
  backdrop-filter: blur(26px) saturate(190%);
  -webkit-backdrop-filter: blur(26px) saturate(190%);
  border-bottom: 1px solid rgba(33,29,23,.07);
}
.nav-inner{
  display:flex; align-items:center; justify-content:space-between;
  height: 76px;
  gap: 24px;
}
.brand{
  display:flex; align-items:center;
  font-family: var(--font-display);
  color: var(--ink-900);
  transition: opacity .15s;
}
.brand:hover{ opacity:.85; }
.brand-word{ display:flex; flex-direction:column; align-items:center; gap:5px; line-height:1; }
.brand-line{ font-size:22px; font-weight:700; letter-spacing:.02em; white-space:nowrap; }
.brand-line em{ font-style:italic; font-weight:500; }
.brand-sub{
  display:flex; align-items:center; gap:10px;
  font-family: var(--font-body);
  font-size:9px; font-weight:800;
  letter-spacing:.42em; text-indent:.42em;
  text-transform:uppercase;
  color: var(--gold-500);
  white-space:nowrap;
}
.brand-sub::before, .brand-sub::after{
  content:""; width:22px; height:1px; flex:none;
  background: linear-gradient(90deg, transparent, var(--gold-400));
}
.brand-sub::after{ background: linear-gradient(90deg, var(--gold-400), transparent); }

.nav-links{ display:flex; align-items:center; gap: 28px; }
.nav-links a{ font-size: 14.5px; font-weight:600; color: var(--ink-600); transition: color .15s; }
.nav-links a:hover{ color: var(--plum-700); }
.nav-actions{ display:flex; align-items:center; gap: 12px; }

.nav-mobile-toggle{ display:none; background:none; border:none; color:var(--ink-900); padding:6px; }

/* ---------------- Hero ---------------- */
.hero{
  position: relative;
  overflow: hidden;
  padding: 76px 0 96px;
  background:
    radial-gradient(720px 420px at 85% -10%, rgba(207,124,74,.32), transparent 60%),
    radial-gradient(900px 520px at -10% 10%, rgba(58,113,86,.38), transparent 60%),
    linear-gradient(180deg, var(--ink-900), var(--plum-700) 60%, var(--plum-600));
  color: var(--cream-50);
}
.hero::after{
  content:"";
  position:absolute; inset:0;
  background-image: radial-gradient(rgba(255,255,255,.16) 1px, transparent 1px);
  background-size: 22px 22px;
  opacity:.25;
  pointer-events:none;
}
.hero-inner{ position:relative; z-index:1; text-align:center; }
.hero-eyebrow{
  display:inline-flex; align-items:center; gap:8px;
  padding: 7px 16px;
  border-radius: var(--radius-pill);
  background: rgba(255,255,255,.1);
  border: 1px solid rgba(255,255,255,.18);
  font-size: 13px; font-weight:600; letter-spacing:.03em; text-transform:uppercase;
  color: var(--gold-300);
  margin-bottom: 26px;
}
.hero h1{
  font-size: clamp(38px, 5.4vw, 68px);
  line-height: 1.06;
  max-width: 920px;
  margin: 0 auto 20px;
  font-weight: 600;
}
.hero h1 em{ font-style:italic; color: var(--gold-300); }
.hero-sub{
  font-size: 18px;
  color: rgba(253,252,248,.78);
  max-width: 600px;
  margin: 0 auto 40px;
  line-height:1.6;
}

/* Search card */
.search-card{
  max-width: 900px;
  margin: 0 auto;
  background: var(--cream-50);
  border-radius: var(--radius-lg);
  padding: 10px;
  box-shadow: var(--shadow-lg);
  display:flex;
  align-items:stretch;
  gap: 6px;
  flex-wrap: wrap;
}
.search-field{
  flex:1;
  min-width: 200px;
  display:flex; align-items:center; gap:10px;
  padding: 12px 18px;
  border-radius: var(--radius-md);
  color: var(--ink-900);
  text-align:left;
  transition: background .15s;
}
.search-field:hover{ background: var(--cream-100); }
.search-field .icon{ color: var(--ink-400); flex:none; }
.search-field-label{ font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.04em; color: var(--ink-400); }
.search-field input, .search-field select{
  border:none; outline:none; background:transparent; font-family:inherit;
  font-size: 14.5px; font-weight:600; color: var(--ink-900); width:100%;
}
.search-divider{ width:1px; background: var(--ink-200); margin: 8px 0; }
.search-submit{ flex:none; align-self:center; margin: 4px; }

.hero-stats{
  display:flex; justify-content:center; gap: 48px;
  margin-top: 56px;
  flex-wrap: wrap;
}
.hero-stat{ text-align:center; }
.hero-stat b{ display:block; font-family:var(--font-display); font-size: 30px; color:var(--cream-50); }
.hero-stat span{ font-size: 13px; color: rgba(253,252,248,.65); }

/* ---------------- Occasions slider ---------------- */
.occasions{ padding: 0; background: var(--ink-900); }
.occasions-head{ padding: 64px 0 36px; text-align:center; }
.occasions-head .section-kicker{ color: var(--gold-400); }
.occasions-head h2{ color: var(--cream-50); }
.occasions-head p{ color: rgba(253,252,248,.62); margin: 10px auto 0; }

.occasions-slider{
  position: relative;
  overflow: hidden;
  height: min(74vh, 620px);
  min-height: 420px;
}
.occasions-track{
  display:flex;
  height: 100%;
  transition: transform .6s cubic-bezier(.65,0,.35,1);
  will-change: transform;
}
.occasion-slide{
  position: relative;
  flex: 0 0 100%;
  height: 100%;
}
.occasion-slide img{
  width:100%; height:100%; object-fit:cover;
  filter: saturate(1.05);
}
.occasion-slide::before{
  content:"";
  position:absolute; inset:0;
  background: linear-gradient(0deg, rgba(20,16,11,.88) 0%, rgba(20,16,11,.35) 46%, rgba(20,16,11,.05) 68%),
              linear-gradient(90deg, rgba(20,16,11,.45) 0%, transparent 45%);
}
.occasion-copy{
  position:absolute; left:0; right:0; bottom:0;
  padding: 0 6vw 56px;
  color: var(--cream-50);
  max-width: 720px;
}
.occasion-eyebrow{
  display:inline-flex; align-items:center; gap:8px;
  font-size:12.5px; font-weight:700; text-transform:uppercase; letter-spacing:.12em;
  color: var(--gold-300);
  margin-bottom: 14px;
}
.occasion-eyebrow::before{ content:""; width:22px; height:2px; background: var(--gold-400); display:inline-block; }
.occasion-headline{
  font-size: clamp(30px, 4.2vw, 52px);
  line-height: 1.05;
  margin-bottom: 14px;
  text-wrap: balance;
}
.occasion-caption{ font-size: 16.5px; color: rgba(253,252,248,.82); line-height:1.6; max-width: 520px; }
.occasion-cta{
  display:inline-flex; align-items:center; gap:8px;
  margin-top: 22px; font-size:14px; font-weight:700; color: var(--cream-50);
  border-bottom: 1px solid rgba(253,252,248,.4);
  padding-bottom: 3px;
  transition: border-color .2s, color .2s, gap .2s;
}
.occasion-cta:hover{ color: var(--gold-300); border-color: var(--gold-300); gap:12px; }

.slider-arrow{
  position:absolute; top:50%; transform: translateY(-50%);
  width:48px; height:48px; border-radius:50%;
  background: rgba(253,252,248,.14);
  backdrop-filter: blur(6px);
  border: 1px solid rgba(253,252,248,.22);
  color:#fff;
  display:flex; align-items:center; justify-content:center;
  z-index: 5;
  transition: background .2s, transform .2s;
}
.slider-arrow:hover{ background: rgba(253,252,248,.28); }
.slider-arrow .icon{ width:20px; height:20px; }
.slider-arrow.prev{ left: 24px; }
.slider-arrow.next{ right: 24px; }

.slider-dots{
  position:absolute; bottom: 22px; left:50%; transform: translateX(-50%);
  display:flex; gap:9px; z-index:5;
}
.slider-dot{
  width: 8px; height:8px; border-radius:50%;
  background: rgba(253,252,248,.35);
  border: none;
  transition: background .2s, transform .2s, width .2s;
}
.slider-dot.is-active{ background: var(--gold-400); width:26px; border-radius: var(--radius-pill); }

.slider-progress{
  position:absolute; top:0; left:0; right:0; height:3px;
  background: rgba(253,252,248,.15);
  z-index: 5;
}
.slider-progress-bar{
  height:100%; width:0%;
  background: linear-gradient(90deg, var(--gold-400), var(--gold-500));
}

@media (max-width: 760px){
  .occasion-copy{ padding: 0 24px 44px; max-width: none; }
  .slider-arrow{ width:38px; height:38px; }
  .slider-arrow.prev{ left:12px; } .slider-arrow.next{ right:12px; }
  .occasion-caption{ max-width:none; }
}

/* ---------------- Immersive hero stage ---------------- */
.hero-stage{
  position: relative;
  height: calc(100vh - 76px);
  min-height: 560px;
  max-height: 880px;
  overflow: hidden;
  background: var(--ink-900);
}
.hero-slide{
  position: absolute; inset: 0;
  opacity: 0;
  transition: opacity 1.1s ease;
  pointer-events: none;
}
.hero-slide.is-active{ opacity: 1; pointer-events: auto; }
.hero-slide img{ width:100%; height:100%; object-fit:cover; }
.hero-slide.is-active img{ animation: kenburns 8s ease-out forwards; }
@keyframes kenburns{ from{ transform: scale(1.02); } to{ transform: scale(1.11); } }
.hero-scrim{
  position:absolute; inset:0;
  background:
    linear-gradient(0deg, rgba(20,16,11,.88) 0%, rgba(20,16,11,.32) 46%, rgba(20,16,11,.10) 72%),
    linear-gradient(90deg, rgba(20,16,11,.46), transparent 55%);
}
.hero-slide-copy{
  position:absolute; left:0; right:0; bottom: 196px;
  color: var(--cream-50);
}
.hero-slide-headline{
  font-family: var(--font-display);
  font-size: clamp(34px, 5vw, 64px);
  line-height: 1.04;
  font-weight: 600;
  max-width: 800px;
  margin: 14px 0 12px;
  text-wrap: balance;
}
.hero-slide-caption{
  font-size: 17px;
  color: rgba(253,252,248,.85);
  max-width: 540px;
  line-height: 1.6;
  margin-bottom: 20px;
}

.hero-stage-overlay{
  position:absolute; left:0; right:0; bottom: 32px;
  z-index: 6;
}
.glass-search{
  display:flex; align-items:center; gap:4px;
  max-width: 720px;
  padding: 8px;
  border-radius: 26px;
  background: rgba(253,252,248,.14);
  border: 1px solid rgba(253,252,248,.28);
  backdrop-filter: blur(24px) saturate(170%);
  -webkit-backdrop-filter: blur(24px) saturate(170%);
  box-shadow: 0 20px 55px -14px rgba(20,16,11,.55);
}
.glass-search-field{
  flex:1; min-width:0;
  display:flex; align-items:center; gap:10px;
  padding: 10px 16px;
  color:#fff;
}
.glass-search-field .icon{ color: rgba(253,252,248,.72); flex:none; width:18px; height:18px; }
.glass-search-field input,
.glass-search-field select{
  width:100%; border:none; outline:none; background:transparent;
  font-family:inherit; font-size:14.5px; font-weight:600; color:#fff;
}
.glass-search-field input::placeholder{ color: rgba(253,252,248,.62); }
.glass-search-field select option{ color: var(--ink-900); }
.glass-divider{ width:1px; height:26px; background: rgba(253,252,248,.25); flex:none; }
.glass-search-btn{ border-radius: 19px; flex:none; }
.hero-trust{
  display:flex; align-items:center; gap:14px;
  margin-top: 16px;
  font-size: 13px; font-weight: 600;
  color: rgba(253,252,248,.82);
}
.hero-trust i{ width:3px; height:3px; border-radius:50%; background: rgba(253,252,248,.5); }

.hero-stage .slider-dots{
  top: 100px; right: 5vw; bottom:auto; left:auto; transform:none;
}
.hero-stage .slider-progress{ top:auto; bottom:0; }

/* ---------------- Booking configurator ---------------- */
.config-section{ background: linear-gradient(180deg, var(--cream-100), var(--cream-50)); }
.section-head-center{ justify-content:center; text-align:center; }
.section-head-center p{ margin-left:auto; margin-right:auto; }
.config-card{
  background: rgba(255,255,255,.62);
  backdrop-filter: blur(22px) saturate(160%);
  -webkit-backdrop-filter: blur(22px) saturate(160%);
  border: 1px solid rgba(255,255,255,.8);
  border-radius: var(--radius-lg);
  box-shadow: 0 24px 60px -20px rgba(33,29,23,.2), 0 2px 10px -4px rgba(33,29,23,.08);
  padding: 32px 34px;
  max-width: 980px;
  margin: 0 auto;
}
.config-label{
  font-size: 12.5px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .05em;
  color: var(--ink-600);
  margin-bottom: 14px;
}
.config-chips{ display:flex; gap:10px; flex-wrap:wrap; margin-bottom: 28px; }
.chip .icon{ width:15px; height:15px; }
.config-grid{
  display:grid; grid-template-columns: repeat(3, 1fr);
  gap: 16px; margin-bottom: 26px;
}
.cfg-field{ display:flex; flex-direction:column; gap:8px; }
.cfg-field > span{
  font-size: 12px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .04em;
  color: var(--ink-400);
}
.cfg-field input, .cfg-field select{
  padding: 12px 16px;
  border-radius: 16px;
  border: 1px solid rgba(33,29,23,.12);
  background: rgba(255,255,255,.85);
  font-family: inherit; font-size: 14.5px; font-weight: 600;
  color: var(--ink-900);
  outline: none;
  transition: border-color .15s, box-shadow .15s;
}
.cfg-field input:focus, .cfg-field select:focus{
  border-color: var(--plum-500);
  box-shadow: 0 0 0 3px rgba(58,113,86,.15);
}
.cfg-budget{ margin-bottom: 10px; }
.config-footer{
  display:flex; align-items:center; justify-content:space-between;
  gap: 18px; flex-wrap: wrap;
  padding-top: 22px;
  border-top: 1px dashed var(--ink-200);
}
.cfg-count{ font-size: 15px; color: var(--ink-600); }
.cfg-count b{ font-family: var(--font-display); font-size: 22px; color: var(--ink-900); margin-right: 4px; }

@media (max-width: 760px){
  .hero-stage{ min-height: 520px; height: calc(100svh - 76px); }
  .hero-slide-copy{ bottom: 236px; }
  .hero-slide-caption{ display:none; }
  .glass-search{ flex-wrap: wrap; }
  .glass-search-btn{ width:100%; }
  .glass-divider{ display:none; }
  .hero-stage .slider-dots{ top: 84px; }
  .config-grid{ grid-template-columns: 1fr; }
  .config-card{ padding: 24px 20px; }
}

/* ---------------- Section shell ---------------- */
.section{ padding: 88px 0; }
.section-tight{ padding: 56px 0; }
.section-head{
  display:flex; align-items:flex-end; justify-content:space-between;
  gap: 24px;
  margin-bottom: 40px;
  flex-wrap:wrap;
}
.section-kicker{
  font-size: 13px; font-weight:700; letter-spacing:.06em; text-transform:uppercase;
  color: var(--gold-500);
  margin-bottom: 10px;
  display:block;
}
.section-head h2{ font-size: clamp(28px,3vw,38px); color: var(--ink-900); }
.section-head p{ color: var(--ink-600); font-size:15.5px; margin-top:10px; max-width:520px; }
.section-alt{ background: var(--cream-100); }

/* ---------------- Categories ---------------- */
.cat-grid{
  display:grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 18px;
}
.cat-card{
  position:relative;
  background: var(--cream-50);
  border: 1px solid rgba(33,29,23,.07);
  border-radius: var(--radius-lg);
  padding: 26px 20px;
  display:flex; flex-direction:column; gap:14px;
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
  overflow:hidden;
}
.cat-card::before{
  content:"";
  position:absolute; inset:0;
  background: linear-gradient(135deg, var(--plum-500), var(--gold-400));
  opacity:0;
  transition: opacity .25s ease;
  z-index:0;
}
.cat-card:hover{ transform: translateY(-5px); box-shadow: var(--shadow-md); border-color:transparent; }
.cat-card:hover::before{ opacity:1; }
.cat-card > *{ position:relative; z-index:1; }
.cat-icon{
  width: 46px; height:46px; border-radius: 13px;
  background: var(--cream-200);
  display:flex; align-items:center; justify-content:center;
  color: var(--plum-600);
  transition: background .25s, color .25s;
}
.cat-card:hover .cat-icon{ background: rgba(255,255,255,.22); color:#fff; }
.cat-icon .icon{ width:22px; height:22px; }
.cat-name{ font-family:var(--font-display); font-size:17px; font-weight:600; color: var(--ink-900); transition: color .25s; }
.cat-card:hover .cat-name{ color:#fff; }
.cat-blurb{ font-size:13px; color: var(--ink-500,var(--ink-600)); transition: color .25s; }
.cat-card:hover .cat-blurb{ color: rgba(255,255,255,.85); }
.cat-count{ font-size:12px; font-weight:700; color: var(--gold-500); transition: color .25s; }
.cat-card:hover .cat-count{ color:#fff; }

/* ---------------- Budget filter ---------------- */
.filter-panel{
  background: var(--cream-50);
  border: 1px solid rgba(33,29,23,.08);
  border-radius: var(--radius-lg);
  padding: 30px 32px;
  box-shadow: var(--shadow-sm);
  display:flex;
  gap: 40px;
  align-items:flex-start;
  flex-wrap: wrap;
}
.filter-block{ flex:1; min-width: 280px; }
.filter-label{
  display:flex; align-items:center; justify-content:space-between;
  font-size: 13px; font-weight:700; text-transform:uppercase; letter-spacing:.04em;
  color: var(--ink-600);
  margin-bottom: 18px;
}
.filter-label .amounts{
  font-family: var(--font-display); font-size:17px; font-weight:600;
  color: var(--plum-700); text-transform:none; letter-spacing:0;
}

.range-slider{ position:relative; height: 40px; }
.range-slider .track{
  position:absolute; top:50%; left:0; right:0; height:6px; transform:translateY(-50%);
  background: var(--ink-200); border-radius: var(--radius-pill);
}
.range-slider .track-fill{
  position:absolute; top:50%; height:6px; transform:translateY(-50%);
  background: linear-gradient(90deg, var(--gold-400), var(--plum-500));
  border-radius: var(--radius-pill);
}
.range-slider input[type=range]{
  position:absolute; top:0; left:0; width:100%; height:40px;
  margin:0; background:transparent; appearance:none; -webkit-appearance:none;
  pointer-events:none;
}
.range-slider input[type=range]::-webkit-slider-runnable-track{ background:transparent; }
.range-slider input[type=range]::-webkit-slider-thumb{
  -webkit-appearance:none; pointer-events:all;
  width:22px; height:22px; border-radius:50%;
  background: var(--cream-50);
  border: 3px solid var(--plum-600);
  box-shadow: var(--shadow-md);
  cursor: grab;
  margin-top: 9px;
  transition: transform .12s ease;
}
.range-slider input[type=range]:active::-webkit-slider-thumb{ cursor:grabbing; transform: scale(1.12); }
.range-slider input[type=range]::-moz-range-thumb{
  pointer-events:all;
  width:22px; height:22px; border-radius:50%;
  background: var(--cream-50);
  border: 3px solid var(--plum-600);
  box-shadow: var(--shadow-md);
  cursor:grab;
}
.range-scale{ display:flex; justify-content:space-between; margin-top:10px; font-size:12px; color: var(--ink-400); }

.filter-chips{ display:flex; flex-wrap:wrap; gap:10px; }
.chip{
  padding: 9px 16px;
  border-radius: var(--radius-pill);
  border: 1px solid var(--ink-200);
  font-size: 13.5px; font-weight:600;
  color: var(--ink-600);
  background: var(--cream-50);
  transition: all .15s;
  display:flex; align-items:center; gap:6px;
}
.chip:hover{ border-color: var(--plum-500); color: var(--plum-700); }
.chip.is-active{
  background: var(--plum-700); border-color: var(--plum-700); color: #fff;
}
.filter-divider{ width:1px; align-self:stretch; background: rgba(33,29,23,.08); }

/* ---------------- Results toolbar ---------------- */
.results-toolbar{
  display:flex; align-items:center; justify-content:space-between;
  margin: 36px 0 24px;
  flex-wrap:wrap; gap:16px;
}
.results-count{ font-size:15px; color: var(--ink-600); }
.results-count b{ color: var(--ink-900); }
.sort-select{
  padding: 10px 14px; border-radius: var(--radius-pill);
  border:1px solid var(--ink-200); background: var(--cream-50);
  font-size:13.5px; font-weight:600; color:var(--ink-900);
}

/* ---------------- Storefront cards ---------------- */
.grid{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 26px;
}
.card{
  background: var(--cream-50);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  border: 1px solid rgba(33,29,23,.06);
  transition: transform .2s ease, box-shadow .2s ease;
  display:flex; flex-direction:column;
}
.card:hover{ transform: translateY(-6px); box-shadow: var(--shadow-lg); }
.card-media{ position:relative; aspect-ratio: 4/3; overflow:hidden; background: var(--cream-200); }
.card-media img{ width:100%; height:100%; object-fit:cover; transition: transform .5s ease; }
.card:hover .card-media img{ transform: scale(1.07); }
.card-badge{
  position:absolute; top:12px; left:12px;
  background: rgba(33,29,23,.72); color:#fff; backdrop-filter: blur(4px);
  font-size:11.5px; font-weight:700; padding:6px 12px; border-radius: var(--radius-pill);
  text-transform:capitalize;
}
.card-fav{
  position:absolute; top:12px; right:12px;
  width:34px; height:34px; border-radius:50%;
  background: rgba(255,255,255,.88);
  display:flex; align-items:center; justify-content:center;
  color: var(--ink-600);
  border:none;
  transition: color .15s, transform .15s;
}
.card-fav:hover{ color:#c0355b; transform: scale(1.08); }
.card-body{ padding: 18px 18px 20px; display:flex; flex-direction:column; gap:8px; flex:1; }
.card-top{ display:flex; align-items:flex-start; justify-content:space-between; gap:8px; }
.card-name{ font-family: var(--font-display); font-size:17px; font-weight:600; line-height:1.25; }
.card-rating{ display:flex; align-items:center; gap:4px; font-size:13.5px; font-weight:700; flex:none; white-space:nowrap; }
.card-rating .icon{ width:14px; height:14px; color: var(--gold-500); }
.card-tagline{ font-size:13.5px; color: var(--ink-600); line-height:1.45; }
.card-meta{ display:flex; align-items:center; gap:6px; font-size:12.5px; color: var(--ink-400); }
.card-meta .icon{ width:14px; height:14px; }
.card-tags{ display:flex; flex-wrap:wrap; gap:6px; margin-top:2px; }
.card-tag{ font-size:11.5px; font-weight:600; color: var(--teal-500); background: rgba(91,116,68,.12); padding:4px 9px; border-radius: var(--radius-pill); }
.card-footer{ margin-top:auto; padding-top:12px; border-top:1px dashed var(--ink-200); display:flex; align-items:baseline; justify-content:space-between; }
.card-price b{ font-family: var(--font-display); font-size:18px; color: var(--ink-900); }
.card-price span{ font-size:12px; color: var(--ink-400); margin-left:4px; }
.card-arrow{ width:32px; height:32px; border-radius:50%; background: var(--cream-200); display:flex; align-items:center; justify-content:center; color: var(--ink-600); transition: background .2s, color .2s; }
.card:hover .card-arrow{ background: var(--plum-700); color:#fff; }
.card-arrow .icon{ width:15px; height:15px; }

.empty-state{
  text-align:center; padding: 80px 20px; color: var(--ink-600);
}
.empty-state h3{ font-size:22px; margin-bottom:10px; color:var(--ink-900); }

/* ---------------- How it works ---------------- */
.steps{ display:grid; grid-template-columns: repeat(3,1fr); gap: 28px; }
.step{ text-align:left; }
.step-num{
  width:44px; height:44px; border-radius:50%;
  background: linear-gradient(135deg, var(--plum-500), var(--plum-700));
  color: var(--gold-300); display:flex; align-items:center; justify-content:center;
  font-family: var(--font-display); font-weight:700; font-size:18px;
  margin-bottom: 20px;
}
.step h3{ font-size:19px; margin-bottom:8px; }
.step p{ color: var(--ink-600); font-size:14.5px; line-height:1.6; }

/* ---------------- CTA band (vendor) ---------------- */
.vendor-cta{
  background: linear-gradient(120deg, var(--plum-700), var(--ink-900));
  border-radius: var(--radius-lg);
  padding: 64px;
  color: var(--cream-50);
  display:flex; align-items:center; justify-content:space-between; gap:40px;
  overflow:hidden; position:relative;
}
.vendor-cta::before{
  content:""; position:absolute; width:420px; height:420px; border-radius:50%;
  background: radial-gradient(circle, rgba(207,124,74,.35), transparent 70%);
  top:-160px; right:-120px;
}
.vendor-cta-copy{ position:relative; z-index:1; max-width: 520px; }
.vendor-cta h2{ font-size: clamp(24px,3vw,32px); margin-bottom:14px; }
.vendor-cta p{ color: rgba(253,252,248,.78); font-size:15.5px; line-height:1.6; }
.vendor-cta-actions{ position:relative; z-index:1; display:flex; gap:12px; flex-shrink:0; flex-wrap:wrap; }

/* ---------------- Footer ---------------- */
.footer{ background: var(--ink-900); color: rgba(253,252,248,.7); padding: 64px 0 32px; }
.footer-grid{ display:grid; grid-template-columns: 2fr repeat(3,1fr); gap: 40px; margin-bottom:48px; }
.footer-brand p{ margin-top:14px; font-size:13.5px; line-height:1.7; color: rgba(253,252,248,.55); max-width:280px; }
.footer h4{ font-family:var(--font-body); font-size:13px; text-transform:uppercase; letter-spacing:.05em; color: rgba(253,252,248,.9); margin-bottom:16px; }
.footer li{ margin-bottom:10px; font-size:14px; }
.footer a:hover{ color:#fff; }
.footer-bottom{ border-top:1px solid rgba(255,255,255,.1); padding-top:24px; display:flex; justify-content:space-between; font-size:12.5px; color: rgba(253,252,248,.45); flex-wrap:wrap; gap:12px; }

/* ---------------- Breadcrumb ---------------- */
.breadcrumb{ display:flex; align-items:center; gap:8px; font-size:13.5px; color: var(--ink-400); margin-bottom: 24px; flex-wrap:wrap; }
.breadcrumb a{ font-weight:600; color: var(--ink-600); }
.breadcrumb a:hover{ color: var(--plum-700); }

/* ---------------- Provider detail page ---------------- */
.provider-hero{ padding: 32px 0 0; }
.provider-gallery{
  display:grid; grid-template-columns: 1.6fr 1fr; gap: 12px;
  border-radius: var(--radius-lg); overflow:hidden; height: 440px;
}
.provider-gallery img{ width:100%; height:100%; object-fit:cover; }
.provider-gallery-side{ display:grid; grid-template-rows:1fr 1fr; gap:12px; }

.provider-layout{ display:grid; grid-template-columns: 1fr 380px; gap: 56px; margin-top: 44px; align-items:flex-start; }
.provider-title-row{ display:flex; justify-content:space-between; align-items:flex-start; gap:20px; padding-bottom: 28px; border-bottom:1px solid rgba(33,29,23,.08); margin-bottom: 28px; }
.provider-title-row h1{ font-size: clamp(28px,3.4vw,38px); margin-bottom: 10px; }
.provider-sub{ display:flex; align-items:center; gap:16px; font-size:14.5px; color: var(--ink-600); flex-wrap:wrap; }
.provider-sub .rating-inline{ display:flex; align-items:center; gap:6px; font-weight:700; color:var(--ink-900); }
.provider-sub .rating-inline .icon{ color: var(--gold-500); width:15px; height:15px; }

.provider-block{ margin-bottom: 36px; }
.provider-block h3{ font-size:20px; margin-bottom:14px; }
.provider-block p{ color: var(--ink-600); font-size:15px; line-height:1.75; }
.tag-row{ display:flex; flex-wrap:wrap; gap:10px; }
.tag-pill{ font-size:13px; font-weight:600; color: var(--plum-700); background: rgba(43,85,64,.09); padding:8px 16px; border-radius: var(--radius-pill); }

.package-card{
  border:1px solid rgba(33,29,23,.1); border-radius: var(--radius-md);
  padding: 22px 24px; margin-bottom:16px;
  display:flex; justify-content:space-between; gap: 20px; align-items:center;
  transition: border-color .15s, box-shadow .15s;
}
.package-card:hover{ border-color: var(--plum-500); box-shadow: var(--shadow-sm); }
.package-name{ font-family: var(--font-display); font-size:17px; margin-bottom:8px; }
.package-includes{ font-size:13.5px; color: var(--ink-600); }
.package-includes li{ display:flex; align-items:center; gap:8px; margin-bottom:5px; }
.package-includes .icon{ width:14px; height:14px; color: var(--success); flex:none; }
.package-price{ text-align:right; flex:none; }
.package-price b{ font-family: var(--font-display); font-size:22px; display:block; }
.package-price span{ font-size:12px; color: var(--ink-400); }

.booking-card{
  border:1px solid rgba(33,29,23,.08); border-radius: var(--radius-lg);
  padding: 28px; box-shadow: var(--shadow-md);
  position: sticky; top: 96px;
}
.booking-price{ display:flex; align-items:baseline; gap:6px; margin-bottom:6px; }
.booking-price b{ font-family: var(--font-display); font-size: 28px; }
.booking-price span{ font-size:13px; color: var(--ink-400); }
.booking-rating{ display:flex; align-items:center; gap:6px; font-size:13.5px; font-weight:700; margin-bottom:22px; }
.booking-rating .icon{ color: var(--gold-500); width:14px; height:14px; }
.booking-field{ margin-bottom:14px; }
.booking-field label{ font-size:12px; font-weight:700; text-transform:uppercase; letter-spacing:.03em; color: var(--ink-400); display:block; margin-bottom:6px; }
.booking-field input, .booking-field select{
  width:100%; padding: 11px 14px; border-radius: var(--radius-sm);
  border:1px solid var(--ink-200); font-family:inherit; font-size:14px;
}
.booking-note{ font-size:12.5px; color: var(--ink-400); text-align:center; margin-top:14px; }

.related-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; margin-top: 20px; }

/* ---------------- Category page header ---------------- */
.category-hero{
  padding: 54px 0 44px;
  background: linear-gradient(160deg, var(--cream-200), var(--cream-50));
  border-bottom: 1px solid rgba(33,29,23,.06);
}
.category-hero-inner{ display:flex; align-items:center; gap:22px; }
.category-hero .cat-icon{ width:64px; height:64px; border-radius:18px; }
.category-hero .cat-icon .icon{ width:30px; height:30px; }
.category-hero h1{ font-size: clamp(28px,3.6vw,40px); margin-bottom:6px; }
.category-hero p{ color: var(--ink-600); font-size:15.5px; }

/* ---------------- Toast ---------------- */
.toast{
  position: fixed; bottom: 28px; left:50%; transform: translateX(-50%) translateY(20px);
  background: var(--ink-900); color:#fff; padding: 14px 24px; border-radius: var(--radius-pill);
  font-size:14px; font-weight:600; box-shadow: var(--shadow-lg);
  display:flex; align-items:center; gap:10px;
  opacity:0; pointer-events:none; transition: opacity .25s ease, transform .25s ease;
  z-index: 200;
}
.toast.is-visible{ opacity:1; transform: translateX(-50%) translateY(0); }
.toast .icon{ color: var(--gold-400); width:16px; height:16px; }

/* ---------------- Responsive ---------------- */
@media (max-width: 1080px){
  .grid{ grid-template-columns: repeat(3,1fr); }
  .cat-grid{ grid-template-columns: repeat(3,1fr); }
  .related-grid{ grid-template-columns: repeat(3,1fr); }
  .provider-layout{ grid-template-columns: 1fr; }
  .booking-card{ position:static; }
  .footer-grid{ grid-template-columns: repeat(2,1fr); }
}
@media (max-width: 760px){
  .wrap{ padding: 0 20px; }
  .nav-links{ display:none; }
  .nav-mobile-toggle{ display:flex; }
  .grid{ grid-template-columns: repeat(2,1fr); gap:16px; }
  .cat-grid{ grid-template-columns: repeat(2,1fr); }
  .related-grid{ grid-template-columns: repeat(2,1fr); }
  .search-card{ flex-direction:column; }
  .search-divider{ display:none; }
  .filter-panel{ flex-direction:column; gap:24px; }
  .filter-divider{ display:none; }
  .vendor-cta{ flex-direction:column; padding: 40px 28px; text-align:center; }
  .vendor-cta-copy{ max-width:none; }
  .provider-gallery{ grid-template-columns:1fr; height:auto; }
  .provider-gallery-side{ display:none; }
  .section{ padding: 56px 0; }
  .footer-grid{ grid-template-columns: 1fr 1fr; gap:28px; }
}
@media (max-width: 480px){
  .grid{ grid-template-columns: 1fr; }
  .cat-grid{ grid-template-columns: 1fr 1fr; }
  .related-grid{ grid-template-columns: 1fr; }
  .hero-stats{ gap:28px; }
  .footer-grid{ grid-template-columns: 1fr; }
}
