/* ============================================================
   DIRECTION B — "Modern Clean"
   Airy white, Geist throughout, generous whitespace, crisp grid.
   Split hero, bento property grid, restrained green/gold.
   ============================================================ */
.t-modern {
  --bg: #FBFAF6;
  --surface: #FFFFFF;
  --text: #14241A;
  --text-soft: #5C6A5C;
  --brand: var(--green-800);
  --accent: var(--gold-600);
  --action: var(--green-500);
  --hairline: rgba(20, 36, 26, 0.10);
  --font-display: "Geist", sans-serif;
  --nav-top: #14241A;
  --nav-down: #14241A;
  background: var(--bg);
}
.t-modern .display { font-weight: 700; letter-spacing: -0.035em; }
.t-modern h1.display { font-size: clamp(40px, 5.6vw, 78px); line-height: 1.0; }
.t-modern h2.display { font-size: clamp(30px, 3.8vw, 52px); }
.t-modern .nav.scrolled { background: color-mix(in srgb, #fff 88%, transparent); }
.t-modern .eyebrow { color: var(--green-600); }
.t-modern .eyebrow::before, .t-modern .eyebrow.center::after { background: var(--green-500); }

/* hero — split */
.m-hero { padding-top: 132px; padding-bottom: clamp(40px, 6vw, 80px); }
.m-hero-grid { display: grid; grid-template-columns: 1.02fr 1fr; gap: clamp(32px, 5vw, 72px); align-items: center; }
.m-hero h1 { margin: 22px 0 0; }
.m-hero h1 .accent { color: var(--action); }
.m-hero p { margin-top: 24px; max-width: 46ch; font-size: clamp(16px,1.3vw,19px); color: var(--text-soft); }
.m-hero-cta { display: flex; gap: 14px; margin-top: 32px; flex-wrap: wrap; }
.m-hero-stats { display: flex; gap: 36px; margin-top: 44px; padding-top: 30px; border-top: 1px solid var(--hairline); }
.m-stat .n { font-size: 34px; font-weight: 700; letter-spacing: -0.03em; color: var(--brand); font-feature-settings: "tnum" 1; }
.m-stat .l { font-size: 13px; color: var(--text-soft); margin-top: 2px; }
.m-hero-media { position: relative; display: grid; grid-template-columns: 1fr 1fr; grid-template-rows: 1.3fr 1fr; gap: 14px; height: clamp(420px, 56vw, 560px); }
.m-hero-media .ph { border-radius: var(--r-lg); box-shadow: var(--shadow-md); }
.m-hero-media .ph:nth-child(1) { grid-row: span 2; }
.m-hero-badge { position: absolute; left: -22px; bottom: 30px; background: #fff; border-radius: var(--r-md); box-shadow: var(--shadow-lg); padding: 14px 18px; display: flex; align-items: center; gap: 12px; z-index: 3; }
.m-hero-badge .stars svg { width: 14px; height: 14px; }
.m-hero-badge strong { display: block; font-size: 15px; font-weight: 700; }
.m-hero-badge span { font-size: 12px; color: var(--text-soft); }

/* booking band — clean */
.m-booking { margin-top: clamp(28px, 4vw, 44px); }

/* trust strip */
.m-trust { background: var(--brand); color: #fff; border-radius: var(--r-xl); padding: clamp(36px, 4vw, 56px); display: grid; grid-template-columns: 1.2fr 1fr 1fr; gap: 36px; align-items: center; }
.m-trust .eyebrow { color: var(--gold-300); }
.m-trust .eyebrow::before { background: var(--gold-300); }
.m-trust h2 { color: #fff; margin-top: 14px; }
.m-trust p { color: rgba(255,255,255,0.78); margin-top: 14px; font-size: 15px; max-width: 40ch; }
.m-trust-badge { text-align: center; }
.m-trust-ring { width: 78px; height: 78px; margin: 0 auto 14px; border-radius: 50%; display: grid; place-items: center; background: rgba(255,255,255,0.08); border: 1.5px solid var(--gold-400); color: var(--gold-300); }
.m-trust-ring svg { width: 36px; height: 36px; }
.m-trust-badge strong { display: block; font-size: 16px; color: #fff; }
.m-trust-badge span { font-size: 12.5px; color: rgba(255,255,255,0.6); }

/* properties — bento grid */
.m-props { display: grid; grid-template-columns: repeat(6, 1fr); gap: 18px; }
.m-card { position: relative; border-radius: var(--r-lg); overflow: hidden; min-height: 300px; display: flex; flex-direction: column; justify-content: flex-end; color: #fff; box-shadow: var(--shadow-sm); transition: transform var(--dur-med) var(--ease-out), box-shadow var(--dur-med); }
.m-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-lg); }
.m-card .ph { position: absolute; inset: 0; }
.m-card::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(15,30,20,0) 30%, rgba(15,30,20,0.82) 100%); }
.m-card .m-card-body { position: relative; z-index: 2; padding: 24px; }
.m-card .m-tag { font-size: 11px; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--gold-300); }
.m-card h3 { font-size: 25px; font-weight: 700; letter-spacing: -0.02em; margin: 8px 0 6px; }
.m-card .m-loc { font-size: 13px; color: rgba(255,255,255,0.78); display: flex; align-items: center; gap: 6px; }
.m-card .m-loc svg { width: 14px; height: 14px; }
.m-card .m-go { margin-top: 16px; display: inline-flex; align-items: center; gap: 8px; font-weight: 600; font-size: 14px; color: #fff; opacity: 0; transform: translateY(8px); transition: all var(--dur-med) var(--ease-out); }
.m-card:hover .m-go { opacity: 1; transform: none; }
.m-card .m-go svg { width: 15px; height: 15px; }
.m-card.big { grid-column: span 3; min-height: 420px; }
.m-card.med { grid-column: span 3; }
.m-card.sm { grid-column: span 2; }

/* reviews — single rotator */
.m-reviews { text-align: center; }
.m-rev-stage { position: relative; max-width: 800px; margin: 40px auto 0; min-height: 230px; }
.m-rev-slide { position: absolute; inset: 0; opacity: 0; transform: translateY(14px); transition: opacity var(--dur-slow) var(--ease-out), transform var(--dur-slow) var(--ease-out); pointer-events: none; }
.m-rev-slide.active { opacity: 1; transform: none; pointer-events: auto; }
.m-rev-slide .quote { font-size: clamp(22px, 2.4vw, 30px); font-weight: 600; letter-spacing: -0.02em; line-height: 1.32; color: var(--text); }
.m-rev-slide .who { margin-top: 26px; font-size: 15px; }
.m-rev-slide .who strong { color: var(--brand); }
.m-rev-slide .who span { color: var(--text-soft); }
.m-rev-dots { display: flex; gap: 8px; justify-content: center; margin-top: 34px; }
.m-rev-dots button { width: 8px; height: 8px; border-radius: 50%; background: var(--hairline); transition: all var(--dur-fast); }
.m-rev-dots button.active { width: 26px; border-radius: 5px; background: var(--action); }

/* blog */
.m-blog-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; margin-top: 44px; }
.m-blog { 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); }
.m-blog:hover { transform: translateY(-5px); box-shadow: var(--shadow-md); }
.m-blog .ph { aspect-ratio: 16/10; }
.m-blog .b { padding: 22px; }
.m-blog .meta { font-size: 11.5px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--accent); font-weight: 600; }
.m-blog h4 { font-size: 19px; font-weight: 700; letter-spacing: -0.02em; line-height: 1.2; margin: 10px 0 8px; }
.m-blog p { font-size: 14px; color: var(--text-soft); }

/* CTA */
.m-cta { background: var(--brand); border-radius: var(--r-xl); color: #fff; padding: clamp(48px, 7vw, 96px); text-align: center; position: relative; overflow: hidden; }
.m-cta::before { content: ""; position: absolute; inset: 0; opacity: 0.08; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='60'%3E%3Cpath d='M30 0l30 30-30 30L0 30z' fill='none' stroke='%23ffffff'/%3E%3C/svg%3E"); background-size: 60px; }
.m-cta h2 { color: #fff; position: relative; }
.m-cta p { color: rgba(255,255,255,0.8); max-width: 48ch; margin: 18px auto 30px; position: relative; }

@media (max-width: 980px) {
  .m-hero-grid, .m-trust { grid-template-columns: 1fr; }
  .m-trust-badge { display: flex; align-items: center; gap: 16px; text-align: left; }
  .m-trust-ring { margin: 0; }
  .m-card.big, .m-card.med, .m-card.sm { grid-column: span 6; }
  .m-blog-grid { grid-template-columns: 1fr; }
}
