/* ============================================================
   DIRECTION A — "Serene Boutique"
   Warm sand canvas, Cormorant serif display, gold hairlines,
   heritage calm. Full-bleed hero, editorial property rows.
   ============================================================ */
.t-serene {
  --bg: #F6F1E7;
  --surface: #FFFFFF;
  --text: #20271F;
  --text-soft: #5C6A5C;
  --brand: var(--green-800);
  --accent: var(--gold-600);
  --action: var(--green-700);
  --hairline: rgba(30, 58, 40, 0.14);
  --font-display: "Cormorant Garamond", Georgia, serif;
  --nav-down: #20271F;
  background: var(--bg);
}
.t-serene .display { font-weight: 600; letter-spacing: -0.01em; }
.t-serene h1.display { font-size: clamp(48px, 7vw, 92px); line-height: 0.98; }
.t-serene h2.display { font-size: clamp(34px, 4.6vw, 60px); }
.t-serene .brand-name { font-weight: 600; }

/* hero */
.s-hero { position: relative; min-height: 100svh; display: flex; align-items: flex-end; color: #fff; }
.s-hero .ph { position: absolute; inset: 0; }
.s-hero::after { content: ""; position: absolute; inset: 0; background: linear-gradient(102deg, rgba(11,22,15,0.84) 0%, rgba(11,22,15,0.5) 42%, rgba(11,22,15,0.12) 74%), linear-gradient(180deg, rgba(11,22,15,0) 45%, rgba(11,22,15,0.72) 100%); }
.s-hero-inner { position: relative; z-index: 3; padding-bottom: clamp(120px, 16vh, 200px); }
.s-hero .eyebrow { color: var(--gold-300); }
.s-hero .eyebrow::before { background: var(--gold-300); }
.s-hero h1 { max-width: 16ch; text-shadow: 0 2px 18px rgba(0,0,0,0.5); }
.s-hero p { color: rgba(255,255,255,0.9); max-width: 46ch; margin-top: 22px; font-size: clamp(17px,1.5vw,21px); text-shadow: 0 1px 12px rgba(0,0,0,0.55); }
.s-hero-cta { display: flex; gap: 14px; margin-top: 34px; flex-wrap: wrap; }
.s-hero-kb { animation: kenburns 22s ease-in-out infinite alternate; }
@keyframes kenburns { from { transform: scale(1.04); } to { transform: scale(1.16) translate(-1.5%, -1.5%); } }
@media (prefers-reduced-motion: reduce) { .s-hero-kb { animation: none; } }

/* booking overlap */
.s-booking-band { margin-top: -68px; position: relative; z-index: 30; }

/* the salaam way */
.s-way { display: grid; grid-template-columns: 1.05fr 0.95fr; gap: clamp(40px, 6vw, 90px); align-items: center; }
.s-way-media { position: relative; }
.s-way-media .ph { aspect-ratio: 4/5; border-radius: var(--r-lg); }
.s-way-media .ph.b { position: absolute; width: 56%; aspect-ratio: 1; right: -8%; bottom: -10%; border-radius: var(--r-lg); border: 8px solid var(--bg); }
.s-certs { display: flex; gap: 28px; margin-top: 30px; flex-wrap: wrap; }
.s-values { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; margin-top: 34px; }
.s-value { display: flex; gap: 14px; }
.s-value-ic { width: 44px; height: 44px; flex: none; border-radius: 50%; display: grid; place-items: center; background: var(--green-50); color: var(--brand); border: 1px solid var(--hairline); }
.s-value-ic svg { width: 21px; height: 21px; }
.s-value h4 { font-size: 16px; font-weight: 600; margin-bottom: 3px; }
.s-value p { font-size: 13.5px; color: var(--text-soft); line-height: 1.5; }

/* properties — editorial rows */
.s-props { display: flex; flex-direction: column; gap: clamp(48px, 7vw, 110px); }
.s-prop { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(32px, 5vw, 72px); align-items: center; }
.s-prop:nth-child(even) .s-prop-media { order: 2; }
.s-prop-media .ph { aspect-ratio: 5/4; border-radius: var(--r-lg); box-shadow: var(--shadow-lg); }
.s-prop-tag { font-size: 12px; font-weight: 700; letter-spacing: 0.16em; text-transform: uppercase; color: var(--accent); }
.s-prop h3 { font-family: var(--font-display); font-size: clamp(30px, 3.4vw, 46px); line-height: 1.02; margin: 12px 0 6px; }
.s-prop .loc { display: inline-flex; align-items: center; gap: 7px; color: var(--text-soft); font-size: 14px; margin-bottom: 18px; }
.s-prop .loc svg { width: 15px; height: 15px; color: var(--accent); }
.s-prop ul.feat { display: grid; grid-template-columns: 1fr 1fr; gap: 10px 22px; margin: 20px 0 26px; }
.s-prop ul.feat li { position: relative; padding-left: 24px; font-size: 14px; color: var(--text-soft); }
.s-prop ul.feat li::before { content: ""; position: absolute; left: 0; top: 8px; width: 9px; height: 9px; border-radius: 50%; background: var(--green-100); border: 1.5px solid var(--action); }
.s-prop-cta { display: flex; gap: 12px; align-items: center; flex-wrap: wrap; }

/* reviews */
.s-reviews { background: var(--green-850); color: #fff; }
.s-reviews .eyebrow { color: var(--gold-300); }
.s-reviews .eyebrow::before, .s-reviews .eyebrow.center::after { background: var(--gold-300); }
.s-rev-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; margin-top: 48px; }
.s-rev-card { background: rgba(255,255,255,0.05); border: 1px solid rgba(255,255,255,0.10); border-radius: var(--r-lg); padding: 30px; }
.s-rev-card .quote { font-family: var(--font-display); font-size: 22px; line-height: 1.3; margin: 16px 0 22px; color: #fff; }
.s-rev-who { display: flex; align-items: center; gap: 12px; }
.s-rev-av { width: 42px; height: 42px; border-radius: 50%; background: var(--gold-500); color: #20180a; display: grid; place-items: center; font-weight: 700; }
.s-rev-who strong { display: block; font-size: 14.5px; color: #fff; }
.s-rev-who span { font-size: 12.5px; color: rgba(255,255,255,0.55); }

/* blog teaser */
.s-blog-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; margin-top: 48px; }
.s-blog-card { background: var(--surface); border: 1px solid var(--hairline); border-radius: var(--r-lg); overflow: hidden; transition: transform var(--dur-med) var(--ease-out), box-shadow var(--dur-med); }
.s-blog-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-lg); }
.s-blog-card .ph { aspect-ratio: 16/10; }
.s-blog-body { padding: 24px; }
.s-blog-body .meta { font-size: 11.5px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--accent); font-weight: 600; }
.s-blog-body h4 { font-family: var(--font-display); font-size: 24px; line-height: 1.12; margin: 12px 0 10px; }
.s-blog-body p { font-size: 14px; color: var(--text-soft); }

/* CTA */
.s-cta { position: relative; color: #fff; text-align: center; overflow: hidden; }
.s-cta .ph { position: absolute; inset: 0; }
.s-cta::after { content: ""; position: absolute; inset: 0; background: linear-gradient(rgba(15,30,20,0.62), rgba(15,30,20,0.72)); }
.s-cta-inner { position: relative; z-index: 3; padding-block: clamp(80px, 12vw, 160px); }
.s-cta h2 { max-width: 18ch; margin-inline: auto; text-shadow: 0 2px 24px rgba(0,0,0,0.55), 0 1px 6px rgba(0,0,0,0.35); }
.s-cta p { color: rgba(255,255,255,0.82); max-width: 50ch; margin: 18px auto 32px; text-shadow: 0 1px 10px rgba(0,0,0,0.45); }

/* WhatsApp button — usable on any page using this theme */
.btn-wa { background: #1FA855; color: #fff; box-shadow: 0 4px 16px rgba(31,168,85,0.30); }
.btn-wa:hover { background: #178a45; transform: translateY(-2px); }
.btn-wa svg { width: 18px; height: 18px; flex: none; }

@media (max-width: 860px) {
  .s-way, .s-prop, .s-prop:nth-child(even) .s-prop-media { grid-template-columns: 1fr; order: 0; }
  .s-rev-grid, .s-blog-grid { grid-template-columns: 1fr; }
  .s-values { grid-template-columns: 1fr; }
}
