/* ════════════════════════════════════════════════════════
   City Landing Pages — CSS additions
   Loaded AFTER base.css (cascade). Adds classes for /[city]/ pages
   that don't exist in base.css.
   Brand variables (--brand, --gold, --dark, --container) come from base.css.
   ════════════════════════════════════════════════════════ */

/* ─── Header ─── */
.site-header .header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:1rem 0;
  gap:1.5rem
}
.site-header .header-nav{
  display:flex;
  align-items:center;
  gap:1.5rem
}
.site-header .header-nav a{
  font-weight:500;
  color:var(--dark,#1a0a12);
  transition:color .2s
}
.site-header .header-nav a:hover{ color:var(--brand,#e91e63) }

/* ─── Buttons ─── */
.btn-cta{
  display:inline-block;
  padding:.85rem 1.5rem;
  background:var(--brand,#e91e63);
  color:#fff !important;
  border-radius:8px;
  font-weight:600;
  font-size:.95rem;
  letter-spacing:.02em;
  text-transform:none;
  box-shadow:0 4px 14px rgba(233,30,99,.35);
  transition:all .2s ease
}
.btn-cta:hover{
  background:var(--brand-dark,#c2185b);
  transform:translateY(-1px);
  box-shadow:0 6px 20px rgba(233,30,99,.45)
}

/* ─── Hero (city) ─── */
.hero-city{
  position:relative;
  min-height:520px;
  display:flex;
  align-items:center;
  color:#fff;
  padding:4rem 0;
  margin-bottom:2rem;
  /* base solid color in case the inline gradient/image fails */
  background-color:#1a0a12;
  isolation:isolate;
}
/* Dark overlay over the background image to guarantee text legibility
   even when the underlying photo has bright zones (e.g. white houses, sky). */
.hero-city::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,
    rgba(0,0,0,.55) 0%,
    rgba(0,0,0,.65) 50%,
    rgba(0,0,0,.80) 100%);
  pointer-events:none;
  z-index:0;
}
.hero-city > *{ position:relative; z-index:1 }
.hero-city .container{
  width:100%;
  max-width:980px;
  padding:0 1.5rem;
  position:relative;
  z-index:1;
}
.hero-city .breadcrumb{
  font-size:.88rem;
  margin-bottom:1rem;
  color:rgba(255,255,255,.95);
  text-shadow:0 1px 4px rgba(0,0,0,.6);
  font-weight:500
}
.hero-city .breadcrumb a{
  color:#fff;
  text-decoration:underline;
  text-underline-offset:3px;
  font-weight:600
}
.hero-city .breadcrumb a:hover{ color:var(--gold,#d4af37) }
.hero-city .breadcrumb span{ margin:0 .4rem; color:rgba(255,255,255,.75) }
.hero-city h1{
  font-size:clamp(2rem,5vw,3.4rem);
  line-height:1.15;
  margin-bottom:1rem;
  font-weight:800;
  letter-spacing:-.02em;
  color:#fff;
  text-shadow:0 2px 12px rgba(0,0,0,.65), 0 1px 3px rgba(0,0,0,.5);
}
.hero-city h1 .accent{ color:var(--gold,#d4af37) }
.hero-city .lead{
  font-size:clamp(1.02rem,1.5vw,1.2rem);
  line-height:1.65;
  max-width:780px;
  margin-bottom:1.75rem;
  color:#fff;
  opacity:1;
  text-shadow:0 1px 6px rgba(0,0,0,.7), 0 1px 2px rgba(0,0,0,.5);
  font-weight:400
}
.hero-city .hero-cta{ margin-bottom:1.25rem }
.hero-city .hero-cta .btn-cta{
  padding:1rem 1.85rem;
  font-size:1.05rem;
  background:var(--gold,#d4af37);
  color:var(--dark,#1a0a12) !important;
  box-shadow:0 4px 14px rgba(0,0,0,.4), 0 0 0 1px rgba(255,255,255,.15);
  font-weight:700;
  letter-spacing:.01em
}
.hero-city .hero-cta .btn-cta:hover{
  background:#e8c548;
  transform:translateY(-2px);
  box-shadow:0 8px 22px rgba(0,0,0,.5)
}
.hero-city .trust-line{
  font-size:.9rem;
  color:rgba(255,255,255,.92);
  font-style:italic;
  text-shadow:0 1px 4px rgba(0,0,0,.6);
  font-weight:500
}

/* ─── Section spacing ─── */
section{ padding:3rem 0 }
section.intro,
section.why-us,
section.packages,
section.city-info,
section.faq,
section.final-cta{ padding:3rem 0 }
section h2{
  font-size:clamp(1.5rem,3vw,2rem);
  line-height:1.25;
  margin-bottom:1.5rem;
  color:var(--dark,#1a0a12);
  font-weight:700
}
section .section-sub{
  color:var(--muted,#6b6b6b);
  margin-bottom:1.5rem;
  font-size:.95rem
}
section .section-cta{
  margin-top:2rem;
  text-align:center
}

/* ─── Intro ─── */
.intro p{
  font-size:1.05rem;
  line-height:1.75;
  max-width:780px;
  color:#333
}

/* ─── Why us — check list ─── */
.why-us{ background:var(--bg-light,#fff5f9) }
.check-list{
  list-style:none;
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:.75rem 2rem;
  padding:0
}
.check-list li{
  position:relative;
  padding-left:2rem;
  line-height:1.6;
  font-size:.98rem;
  color:#222
}
.check-list li::before{
  content:"✓";
  position:absolute;
  left:0;
  top:0;
  width:1.4rem;
  height:1.4rem;
  background:var(--brand,#e91e63);
  color:#fff;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:.85rem;
  font-weight:700
}

/* ─── Packages grid ─── */
.pkg-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:1.25rem;
  margin-top:1.5rem
}
.pkg-card{
  background:#fff;
  border:1px solid #ececec;
  border-radius:12px;
  padding:1.5rem;
  box-shadow:0 2px 8px rgba(0,0,0,.04);
  transition:transform .2s,box-shadow .2s
}
.pkg-card:hover{
  transform:translateY(-3px);
  box-shadow:0 8px 24px rgba(0,0,0,.08);
  border-color:var(--brand-light,#fce4ec)
}
.pkg-card header{
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  margin-bottom:.85rem;
  gap:.75rem;
  flex-wrap:wrap
}
.pkg-card h3{
  font-size:1.1rem;
  font-weight:700;
  color:var(--dark,#1a0a12);
  margin:0
}
.pkg-price{
  font-size:1.4rem;
  font-weight:800;
  color:var(--brand,#e91e63);
  white-space:nowrap
}
.pkg-card p{
  font-size:.92rem;
  line-height:1.55;
  color:#444;
  margin:0
}

/* ─── City info dl ─── */
.city-info{ background:#fafafa }
.city-facts{
  display:grid;
  grid-template-columns:auto 1fr;
  gap:.5rem 1.5rem;
  max-width:780px;
  font-size:.95rem
}
.city-facts dt{
  font-weight:700;
  color:var(--dark,#1a0a12);
  padding:.4rem 0
}
.city-facts dd{
  color:#444;
  padding:.4rem 0;
  border-bottom:1px solid #eee
}
.city-facts dt:last-of-type+dd,
.city-facts dt:last-of-type{ border-bottom:none }

/* ─── FAQ ─── */
.faq-list{ max-width:820px }
.faq-item{
  border:1px solid #ececec;
  border-radius:8px;
  margin-bottom:.75rem;
  background:#fff;
  overflow:hidden;
  transition:border-color .2s
}
.faq-item[open]{ border-color:var(--brand,#e91e63) }
.faq-item summary{
  padding:1rem 1.25rem;
  cursor:pointer;
  font-weight:600;
  color:var(--dark,#1a0a12);
  list-style:none;
  position:relative;
  padding-right:2.5rem;
  font-size:.98rem
}
.faq-item summary::-webkit-details-marker{ display:none }
.faq-item summary::after{
  content:"+";
  position:absolute;
  right:1.25rem;
  top:50%;
  transform:translateY(-50%);
  font-size:1.4rem;
  color:var(--brand,#e91e63);
  font-weight:300;
  transition:transform .2s
}
.faq-item[open] summary::after{ content:"−"; transform:translateY(-50%) }
.faq-item p{
  padding:0 1.25rem 1.15rem;
  line-height:1.65;
  color:#444;
  font-size:.95rem
}

/* ─── Final CTA ─── */
.final-cta{
  background:linear-gradient(135deg,var(--brand,#e91e63) 0%,var(--brand-dark,#c2185b) 100%);
  color:#fff;
  text-align:center
}
.final-cta h2{ color:#fff; margin-bottom:1rem }
.final-cta p{
  font-size:1.05rem;
  line-height:1.65;
  max-width:680px;
  margin:0 auto 1.75rem;
  opacity:.95
}
.final-cta .btn-cta{
  background:var(--gold,#d4af37);
  color:var(--dark,#1a0a12) !important;
  padding:1rem 2rem;
  font-size:1.05rem
}
.final-cta .btn-cta:hover{
  background:#e8c548;
  transform:translateY(-2px)
}

/* ─── Footer additions ─── */
.footer-legal{
  margin-top:2rem;
  padding-top:1.5rem;
  border-top:1px solid rgba(255,255,255,.12);
  font-size:.82rem;
  text-align:center;
  opacity:.65
}

/* ─── How it works (numbered list) ─── */
.how-list{
  list-style:none;
  counter-reset:howstep;
  padding:0;
  max-width:880px;
  margin-top:1rem
}
.how-list li{
  position:relative;
  padding:1.1rem 1.25rem 1.1rem 1.25rem;
  margin-bottom:.85rem;
  background:#fff;
  border:1px solid #ececec;
  border-radius:10px;
  line-height:1.65;
  font-size:.97rem;
  color:#333;
  box-shadow:0 1px 3px rgba(0,0,0,.03);
  transition:border-color .2s
}
.how-list li:hover{ border-color:var(--brand-light,#fce4ec) }
.how-list li strong{
  color:var(--dark,#1a0a12);
  display:block;
  margin-bottom:.25rem;
  font-size:1.02rem
}

/* ─── Testimonials / Reviews ─── */
.reviews-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:1.25rem;
  margin-top:1.5rem
}
.review-card{
  background:#fff;
  border:1px solid #ececec;
  border-left:4px solid var(--brand,#e91e63);
  border-radius:10px;
  padding:1.25rem 1.4rem;
  margin:0;
  box-shadow:0 2px 8px rgba(0,0,0,.04);
  transition:transform .2s,box-shadow .2s
}
.review-card:hover{
  transform:translateY(-2px);
  box-shadow:0 6px 20px rgba(0,0,0,.08)
}
.review-stars{
  color:var(--gold,#d4af37);
  font-size:1.05rem;
  letter-spacing:.1em;
  margin-bottom:.6rem;
  line-height:1
}
.review-text{
  font-size:.95rem;
  line-height:1.6;
  color:#222;
  margin:0 0 .85rem;
  font-style:italic
}
.review-author{
  font-size:.85rem;
  color:var(--muted,#6b6b6b);
  font-style:normal;
  font-weight:600
}

/* ─── Footer columns: lists ─── */
.footer-col ul{ list-style:none; padding:0; margin:0 }
.footer-col li{ margin:.35rem 0; font-size:.92rem }
.footer-col a{ color:rgba(255,255,255,.82); transition:color .2s }
.footer-col a:hover{ color:#fff }
.footer-col h4{
  font-size:.95rem;
  margin:0 0 .85rem;
  color:#fff;
  text-transform:uppercase;
  letter-spacing:.08em;
  font-weight:700;
  opacity:.85
}

/* ─── Service landing & matrix specifics ─── */
.service-hero{ background:linear-gradient(135deg,#1a0a12 0%,#2d0f1d 100%) }
.service-hero .lead{ max-width:820px }

.cities-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:1rem;
  margin-top:1.5rem
}
.city-link{
  display:block;
  padding:1rem 1.25rem;
  background:#fff;
  border:1px solid #ececec;
  border-radius:8px;
  text-decoration:none;
  color:var(--dark,#1a0a12);
  font-weight:600;
  transition:all .2s
}
.city-link:hover{
  border-color:var(--brand,#e91e63);
  transform:translateY(-2px);
  box-shadow:0 4px 12px rgba(233,30,99,.15)
}
.city-link .arrow{ color:var(--brand,#e91e63); float:right }

/* ─── Blog ─── */
.blog-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(300px,1fr));
  gap:1.5rem;
  margin-top:1.5rem
}
.blog-card{
  background:#fff;
  border:1px solid #ececec;
  border-radius:12px;
  overflow:hidden;
  transition:transform .2s,box-shadow .2s
}
.blog-card:hover{
  transform:translateY(-3px);
  box-shadow:0 8px 24px rgba(0,0,0,.08)
}
.blog-card-body{ padding:1.25rem 1.4rem }
.blog-card h3{
  font-size:1.1rem;
  margin:0 0 .5rem;
  color:var(--dark,#1a0a12);
  line-height:1.3
}
.blog-card h3 a{ color:inherit; text-decoration:none }
.blog-card h3 a:hover{ color:var(--brand,#e91e63) }
.blog-card .meta{
  font-size:.82rem;
  color:var(--muted,#6b6b6b);
  margin-bottom:.5rem
}
.blog-card p{
  font-size:.92rem;
  line-height:1.55;
  color:#444;
  margin:0
}

.blog-post article{ max-width:780px; margin:0 auto }
.blog-post h1{
  font-size:clamp(1.8rem,4vw,2.6rem);
  line-height:1.2;
  margin-bottom:.5rem
}
.blog-post .post-meta{
  color:var(--muted,#6b6b6b);
  font-size:.9rem;
  margin-bottom:1.5rem
}
.blog-post h2{
  font-size:clamp(1.3rem,2.5vw,1.6rem);
  margin-top:2.25rem;
  margin-bottom:.85rem
}
.blog-post h3{
  font-size:1.15rem;
  margin-top:1.75rem;
  margin-bottom:.65rem;
  color:var(--dark,#1a0a12)
}
.blog-post p{
  font-size:1.02rem;
  line-height:1.75;
  color:#333;
  margin-bottom:1.1rem
}
.blog-post ul, .blog-post ol{
  padding-left:1.5rem;
  margin-bottom:1.1rem;
  line-height:1.7
}
.blog-post li{ margin-bottom:.4rem }
.blog-post blockquote{
  border-left:4px solid var(--brand,#e91e63);
  padding:.5rem 1.25rem;
  margin:1.5rem 0;
  background:var(--bg-light,#fff5f9);
  font-style:italic;
  color:#333
}

/* ─── Responsive tweaks ─── */
@media (max-width:640px){
  .hero-city{ min-height:auto; padding:3rem 0 }
  .city-facts{ grid-template-columns:1fr; gap:.25rem }
  .city-facts dt{ padding:.4rem 0 .1rem; border:none }
  .check-list{ grid-template-columns:1fr }
  .reviews-grid{ grid-template-columns:1fr }
  .blog-grid{ grid-template-columns:1fr }
}
