/* ============================================================
   CASA LUNA — Explore Page CSS
   ============================================================ */

/* ── PAGE HERO ───────────────────────────────────────────────── */
.page-hero { position:relative; height:70vh; min-height:520px; display:flex; align-items:flex-end; overflow:hidden; }
.ph-bg { position:absolute; inset:0; }
.ph-bg img { width:100%; height:100%; object-fit:cover; object-position:center 35%; }
.ph-overlay { position:absolute; inset:0; background:linear-gradient(to top, rgba(28,20,10,0.85) 0%, rgba(28,20,10,0.25) 60%, transparent 100%); }
.ph-content { position:relative; z-index:2; padding-bottom:4rem; }
.ph-title { font-family:var(--font-display); font-size:clamp(2.8rem,6vw,5rem); font-weight:400; color:white; line-height:1.0; margin:0.5rem 0; }
.ph-title em { font-style:italic; color:var(--gold-lt); }
.ph-sub { font-family:var(--font-ui); font-size:1rem; color:rgba(255,255,255,0.7); font-weight:300; max-width:620px; line-height:1.7; margin-top:0.75rem; }

/* ── DISTANCE BANNER ─────────────────────────────────────────── */
.dbanner { display:flex; flex-wrap:wrap; justify-content:center; }
.db-item { display:flex; flex-direction:column; align-items:center; padding:1.25rem 2rem; border-right:1px solid rgba(255,255,255,0.08); }
.db-item:last-child { border-right:none; }
.db-t { font-family:var(--font-display); font-size:1.5rem; color:var(--gold-lt); line-height:1; }
.db-n { font-family:var(--font-ui); font-size:0.6rem; letter-spacing:0.18em; text-transform:uppercase; color:rgba(255,255,255,0.45); margin-top:4px; }

/* ── REGION BANNER (cinematic full-width header image) ───────── */
.region-banner {
  position:relative; border-radius:8px; overflow:hidden;
  aspect-ratio:21/7; box-shadow:0 20px 60px rgba(28,20,10,0.25);
  margin-bottom:3.5rem;
}
.region-banner img { width:100%; height:100%; object-fit:cover; object-position:center 40%; }
.rb-overlay {
  position:absolute; inset:0;
  background:linear-gradient(to top, rgba(28,20,10,0.82) 0%, rgba(28,20,10,0.2) 55%, transparent 100%);
  display:flex; flex-direction:column; justify-content:flex-end; padding:2.5rem 3rem;
}
.rb-overlay .section-label { margin-bottom:0.5rem; }
.rb-overlay .section-title { margin:0; font-size:clamp(2rem,4vw,3.2rem); color:white; }
.rb-overlay .section-title em { color:var(--gold-lt); }

/* ── NICCONE VALLEY ──────────────────────────────────────────── */
#niccone { background:var(--parchment); }

/* Two-column intro: image left, text right */
.niccone-intro {
  display:grid; grid-template-columns:1fr 1fr; gap:5rem;
  align-items:center;
}
.niccone-intro-img { position:relative; padding-bottom:2.5rem; }
.niccone-intro-img img {
  width:100%; aspect-ratio:4/3; object-fit:cover;
  border-radius:6px; box-shadow:0 24px 60px rgba(28,20,10,0.2);
}
.niccone-fact-overlay {
  position:absolute; bottom:0; right:-1.5rem;
  background:var(--charcoal); padding:1.25rem 1.5rem;
  border-radius:4px; max-width:240px;
  box-shadow:0 12px 40px rgba(28,20,10,0.35);
}
.nfo-label { font-family:var(--font-ui); font-size:0.58rem; letter-spacing:0.2em; text-transform:uppercase; color:var(--gold-lt); display:block; margin-bottom:0.4rem; }
.niccone-fact-overlay p { font-family:var(--font-ui); font-size:0.76rem; color:rgba(255,255,255,0.72); font-weight:300; line-height:1.6; margin:0; }

.niccone-intro-text .lead-text { font-family:var(--font-body); font-size:1.05rem; color:var(--stone-dk); line-height:1.85; margin-bottom:1.25rem; font-weight:300; }
.niccone-intro-text p { font-family:var(--font-ui); font-size:0.87rem; color:var(--stone); line-height:1.8; font-weight:300; margin-bottom:1rem; }

/* ── NICCONE ACTIVITIES — full-width below intro ─────────────── */
.niccone-activities { }

.act-heading {
  font-family:var(--font-display); font-size:1.7rem; color:var(--charcoal);
  margin:0 0 2rem; padding-bottom:1rem;
  border-bottom:2px solid var(--cream-dk);
}
.act-heading em { font-style:italic; color:var(--terracotta-dk); }

/* 3-column activity grid — full width of container */
.activities-grid {
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:1.75rem;
}

.act-card-new {
  background:white;
  border-radius:8px;
  padding:1.75rem 1.75rem 1.5rem;
  box-shadow:0 2px 20px rgba(28,20,10,0.07);
  border-top:3px solid var(--gold);
  transition:transform 0.25s ease, box-shadow 0.25s ease;
  display:flex;
  flex-direction:column;
}
.act-card-new:hover {
  transform:translateY(-5px);
  box-shadow:0 10px 36px rgba(28,20,10,0.13);
}
.act-card-new .act-ico {
  font-size:2rem; display:block; margin-bottom:0.75rem; line-height:1;
}
.act-card-new h4 {
  font-family:var(--font-display); font-size:1.15rem;
  color:var(--charcoal); margin-bottom:0.6rem;
}
.act-card-new p {
  font-family:var(--font-ui); font-size:0.78rem;
  color:var(--stone); font-weight:300; line-height:1.72;
  margin-bottom:0.6rem;
}
.act-card-new p strong {
  color:var(--charcoal); font-weight:600; font-size:0.72rem;
  text-transform:uppercase; letter-spacing:0.04em;
}

/* Vendor list inside activity cards */
.vendor-list {
  list-style:none; padding:0; margin:0.5rem 0 0;
  display:flex; flex-direction:column; gap:0.4rem;
}
.vendor-list li {
  font-family:var(--font-ui); font-size:0.71rem;
  color:var(--stone-dk); font-weight:300; line-height:1.55;
  padding:0.5rem 0.75rem;
  background:var(--parchment); border-radius:3px;
  border-left:2px solid var(--gold);
}
.vendor-list li a { color:var(--terracotta); font-weight:600; text-decoration:none; }
.vendor-list li a:hover { color:var(--terracotta-dk); text-decoration:underline; }

/* ── GOLF ────────────────────────────────────────────────────── */
.golf-section { position:relative; min-height:520px; display:flex; align-items:center; overflow:hidden; }
.golf-bg { position:absolute; inset:0; }
.golf-bg img { width:100%; height:100%; object-fit:cover; object-position:center 45%; }
.golf-overlay { position:absolute; inset:0; background:linear-gradient(105deg, rgba(28,20,10,0.9) 0%, rgba(28,20,10,0.55) 55%, rgba(28,20,10,0.1) 100%); }
.golf-content { position:relative; z-index:2; padding:5rem 0; }
.golf-inner { max-width:580px; }
.golf-body p { font-family:var(--font-ui); font-size:0.88rem; color:rgba(255,255,255,0.76); font-weight:300; line-height:1.8; margin-bottom:1rem; }
.golf-facts { display:flex; gap:2.5rem; margin:2rem 0 1.5rem; flex-wrap:wrap; }
.gf-item { display:flex; flex-direction:column; }
.gf-val { font-family:var(--font-display); font-size:1.8rem; color:var(--gold-lt); line-height:1; }
.gf-lbl { font-family:var(--font-ui); font-size:0.6rem; letter-spacing:0.18em; text-transform:uppercase; color:rgba(255,255,255,0.4); margin-top:3px; }

/* ── UMBRIAN TOWNS ───────────────────────────────────────────── */
#umbria { background:var(--cream); }
.town-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.75rem; }
.town-card {
  background:white; border-radius:8px; padding:2rem;
  box-shadow:0 2px 16px rgba(28,20,10,0.05);
  transition:transform 0.25s, box-shadow 0.25s;
  border-bottom:3px solid transparent;
  display:flex; flex-direction:column;
}
.town-card:hover { transform:translateY(-5px); box-shadow:0 12px 40px rgba(28,20,10,0.12); border-bottom-color:var(--terracotta); }
.tc-badge {
  display:inline-block; margin-bottom:0.75rem;
  font-family:var(--font-ui); font-size:0.6rem; font-weight:700;
  letter-spacing:0.15em; text-transform:uppercase;
  background:var(--terracotta); color:white;
  padding:0.22rem 0.7rem; border-radius:20px; align-self:flex-start;
}
.town-card h3 { font-family:var(--font-display); font-size:1.3rem; color:var(--charcoal); margin-bottom:0.75rem; }
.town-card p { font-family:var(--font-ui); font-size:0.78rem; color:var(--stone); font-weight:300; line-height:1.75; flex:1; }
.tc-tags { display:flex; flex-wrap:wrap; gap:0.35rem; margin-top:1rem; }
.tc-tags span {
  font-family:var(--font-ui); font-size:0.58rem; letter-spacing:0.08em;
  text-transform:uppercase; padding:0.22rem 0.65rem;
  background:var(--parchment); color:var(--stone-dk);
  border-radius:20px; border:1px solid var(--cream-dk);
}

/* ── TUSCANY ─────────────────────────────────────────────────── */
#tuscany { background:var(--parchment); }
.tuscany-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.75rem; }
.tuscany-card {
  background:white; border-radius:8px; padding:2rem 2rem 1.75rem;
  box-shadow:0 2px 16px rgba(28,20,10,0.06);
  border-left:4px solid var(--gold);
  transition:transform 0.25s, box-shadow 0.25s;
  display:flex; flex-direction:column;
}
.tuscany-card:hover { transform:translateY(-5px); box-shadow:0 12px 40px rgba(28,20,10,0.13); }
.tsc-dist {
  font-family:var(--font-display); font-size:2.2rem;
  color:var(--gold); line-height:1; margin-bottom:0.35rem;
}
.tuscany-card h3 { font-family:var(--font-display); font-size:1.3rem; color:var(--charcoal); margin-bottom:0.75rem; }
.tuscany-card p { font-family:var(--font-ui); font-size:0.78rem; color:var(--stone); font-weight:300; line-height:1.75; flex:1; }

/* ── EXCURSIONS ──────────────────────────────────────────────── */
.exc-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:2rem; }
.exc-card {
  background:white; border-radius:8px; padding:2rem;
  box-shadow:0 2px 16px rgba(28,20,10,0.06);
  border-top:3px solid var(--gold);
  display:flex; flex-direction:column; gap:1rem;
  transition:transform 0.25s, box-shadow 0.25s;
}
.exc-card:hover { transform:translateY(-4px); box-shadow:0 8px 32px rgba(28,20,10,0.12); }
.exc-icon { font-size:2.2rem; line-height:1; }
.exc-content h3 { font-family:var(--font-display); font-size:1.3rem; color:var(--charcoal); margin-bottom:0.5rem; }
.exc-content p { font-family:var(--font-ui); font-size:0.8rem; color:var(--stone); font-weight:300; line-height:1.7; }
.exc-vendors { display:flex; flex-direction:column; gap:0.45rem; margin-top:0.5rem; }
.exc-vendor-btn {
  display:flex; align-items:center; justify-content:space-between; gap:0.5rem;
  padding:0.55rem 0.85rem; background:var(--parchment);
  border:1px solid var(--cream-dk); border-radius:4px;
  font-family:var(--font-ui); font-size:0.73rem; font-weight:500;
  color:var(--charcoal); text-decoration:none;
  transition:all 0.2s; flex-wrap:wrap;
}
.exc-vendor-btn:hover { background:var(--cream); border-color:var(--terracotta); color:var(--terracotta-dk); }
.exc-vendor-btn span { font-size:0.63rem; color:var(--stone); font-weight:400; font-style:italic; }
.exc-vendor-secondary {
  background:transparent; border-color:var(--terracotta);
  color:var(--terracotta); font-weight:600; font-size:0.68rem; justify-content:center;
}
.exc-vendor-secondary:hover { background:var(--terracotta); color:white; }
.exc-meta {
  display:flex; gap:1rem; flex-wrap:wrap;
  padding-top:0.75rem; border-top:1px solid var(--cream-dk); margin-top:auto;
}
.exc-meta span { font-family:var(--font-ui); font-size:0.68rem; color:var(--stone); font-weight:300; }

/* ── FOOD & WINE ─────────────────────────────────────────────── */
.fw-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:2rem; }
.fw-card { background:rgba(255,255,255,0.06); border-radius:6px; padding:2rem; border:1px solid rgba(255,255,255,0.08); }
.fw-icon { font-size:2rem; display:block; margin-bottom:1rem; }
.fw-card h3 { font-family:var(--font-display); font-size:1.1rem; color:var(--gold-lt); margin-bottom:0.6rem; }
.fw-card p { font-family:var(--font-ui); font-size:0.78rem; color:rgba(255,255,255,0.6); font-weight:300; line-height:1.7; }

/* ── RESPONSIVE ──────────────────────────────────────────────── */
@media (max-width:1100px) {
  .niccone-intro { grid-template-columns:1fr; gap:3rem; }
  .niccone-fact-overlay { right:0; }
  .activities-grid { grid-template-columns:repeat(2,1fr); }
  .town-grid { grid-template-columns:repeat(2,1fr); }
  .tuscany-grid { grid-template-columns:repeat(2,1fr); }
  .exc-grid { grid-template-columns:repeat(2,1fr); }
  .fw-grid { grid-template-columns:repeat(2,1fr); }
}
@media (max-width:680px) {
  .activities-grid,
  .town-grid,
  .tuscany-grid,
  .exc-grid,
  .fw-grid { grid-template-columns:1fr; }
  .db-item { padding:0.9rem 1.2rem; }
  .niccone-fact-overlay { position:static; max-width:100%; margin-top:1rem; }
  .rb-overlay { padding:1.5rem; }
  .region-banner { aspect-ratio:16/7; }
}
