/* ======================================================================
 * GPH — Destination Page + Venue Card  (gph_dest_page_render / gphdc)
 * Brand: cream #fdfbf6/#f1ece1 · gold #c9ac70/#aa8c57 · teal #2a8676 ·
 *        charcoal #14110d · headings Playfair Display, body Open Sans/system.
 * Designed for AFFLUENT 50+ UK GOLFERS: spacious, high-contrast, large
 * legible type, big imagery, trust + phone prominent. Matches the existing
 * .gphpkg / .gphfb-card branded visual language.
 * ====================================================================== */

.gphdp{
	--cream:#fdfbf6; --cream-2:#f1ece1; --sand:#fffdf9;
	--gold:#c9ac70; --gold-2:#aa8c57; --gold-3:#8a6e38;
	--teal:#2a8676; --charcoal:#14110d; --ink:#2a241c;
	--muted:#6f6557; --muted-2:#9c8c70; --line:#ece4d2;
	display:block; box-sizing:border-box; color:var(--ink);
	background:var(--cream);
	font-family:'Open Sans',-apple-system,BlinkMacSystemFont,'Segoe UI',system-ui,sans-serif;
	font-size:17px; line-height:1.6;
}
.gphdp *{box-sizing:border-box}
.gphdp a{color:inherit}
.gphdp [hidden]{display:none !important}

/* ---------------------------------------------------------------- HERO */
.gphdp__hero{
	position:relative; min-height:clamp(420px,56vh,580px);
	display:flex; align-items:flex-end;
	background:#1f6356 center/cover no-repeat;
	color:#fff;
}
.gphdp__hero-in{
	width:100%; max-width:1180px; margin:0 auto;
	padding:clamp(2rem,5vw,3.4rem) clamp(1.2rem,4vw,2.4rem);
}
.gphdp__crumb{
	font-size:.8rem; font-weight:700; letter-spacing:.18em; text-transform:uppercase;
	color:#e7d8b4; margin:0 0 .6rem;
}
.gphdp__title{
	margin:0 0 .7rem; color:#fff;
	font-family:'Playfair Display',Georgia,serif; font-weight:800;
	font-size:clamp(2.4rem,6vw,4rem); line-height:1.04;
	text-shadow:0 2px 24px rgba(20,17,13,.35);
}
.gphdp__season{
	display:inline-flex; align-items:center; gap:.5rem; margin:0 0 1rem;
	background:rgba(253,251,246,.14); border:1px solid rgba(201,172,112,.55);
	color:#fdfbf6; font-size:.92rem; font-weight:600;
	padding:.5rem .95rem; border-radius:999px; backdrop-filter:blur(2px);
}
.gphdp__season strong{font-weight:800; color:#f0dfb6}
.gphdp__season svg{color:var(--gold); flex:none}
.gphdp__hook{
	margin:0 0 1.2rem; max-width:640px;
	font-size:clamp(1.05rem,2vw,1.32rem); line-height:1.55;
	color:rgba(255,255,255,.94); font-weight:400;
}
.gphdp__facts{display:flex; flex-wrap:wrap; gap:.6rem; margin:0 0 1.5rem}
.gphdp__facts span{
	background:rgba(253,251,246,.16); border:1px solid rgba(255,255,255,.28);
	color:#fdfbf6; font-size:.92rem; font-weight:600;
	padding:.42rem .9rem; border-radius:999px;
}
.gphdp__facts span strong{font-weight:800}
.gphdp__facts .gphdp__facts-price{
	background:linear-gradient(180deg,var(--gold),var(--gold-2));
	border-color:transparent; color:var(--charcoal); font-weight:800;
}
.gphdp__hero-cta{display:flex; flex-wrap:wrap; gap:.8rem}

/* buttons */
.gphdp__btn{
	display:inline-flex; align-items:center; gap:.5rem;
	font-family:inherit; font-size:1rem; font-weight:700;
	padding:.85rem 1.5rem; border-radius:999px; text-decoration:none;
	cursor:pointer; border:1.5px solid transparent; line-height:1.2;
	transition:transform .16s ease, box-shadow .16s ease, background .16s ease, color .16s ease;
}
.gphdp__btn--gold{
	background:linear-gradient(180deg,var(--gold),var(--gold-2));
	color:var(--charcoal); font-weight:800;
	box-shadow:0 8px 22px rgba(170,140,87,.34);
}
.gphdp__btn--gold:hover{transform:translateY(-2px); box-shadow:0 12px 30px rgba(170,140,87,.42)}
.gphdp__btn--ghost{
	background:rgba(253,251,246,.10); color:#fff; border-color:rgba(255,255,255,.5);
}
.gphdp__btn--ghost:hover{background:rgba(253,251,246,.2); transform:translateY(-2px)}
.gphdp__btn--outline{
	background:#fff; color:var(--gold-3); border-color:var(--gold);
}
.gphdp__btn--outline:hover{background:var(--gold); color:var(--charcoal); transform:translateY(-2px)}
.gphdp__btn-arr{transition:transform .16s ease}
.gphdp__btn--outline:hover .gphdp__btn-arr{transform:translateY(2px)}

/* -------------------------------------------------------------- BANDS */
.gphdp__band{max-width:1180px; margin:0 auto; padding:clamp(2.4rem,5vw,3.8rem) clamp(1.2rem,4vw,2.4rem)}
.gphdp__band-head{max-width:760px; margin:0 0 1.8rem}
.gphdp__eyebrow{
	margin:0 0 .5rem; font-size:.74rem; font-weight:800;
	text-transform:uppercase; letter-spacing:.2em; color:var(--gold-2);
}
.gphdp__h2{
	margin:0 0 .5rem; color:var(--charcoal);
	font-family:'Playfair Display',Georgia,serif; font-weight:700;
	font-size:clamp(1.7rem,3.4vw,2.5rem); line-height:1.15;
}
.gphdp__lede{margin:0; color:var(--muted); font-size:1.08rem; line-height:1.6}
.gphdp__lede strong{color:var(--ink)}

/* ABOUT / country profile */
.gphdp__about{background:var(--sand); border-bottom:1px solid var(--cream-2)}
.gphdp__about-in{max-width:820px; margin:0 auto; padding:clamp(2.4rem,5vw,3.6rem) clamp(1.2rem,4vw,2.4rem)}
.gphdp__about-eyebrow{
	margin:0 0 .8rem; font-size:.74rem; font-weight:800;
	text-transform:uppercase; letter-spacing:.2em; color:var(--gold-2);
}
.gphdp__about-in p{margin:0 0 1.1rem; font-size:1.18rem; line-height:1.78; color:#3a352c}
.gphdp__about-in p:first-of-type::first-letter{
	font-family:'Playfair Display',Georgia,serif; font-weight:700;
	font-size:3.4rem; line-height:.8; float:left; margin:.18rem .6rem 0 0; color:var(--teal);
}

/* ------------------------------------------------- SUB-REGION CARDS */
.gphdp__subs{background:var(--cream)}
.gphdp__subgrid{
	display:grid; grid-template-columns:repeat(auto-fill,minmax(240px,1fr));
	gap:1.2rem;
}
.gphds{
	display:flex; flex-direction:column; text-decoration:none; color:var(--ink);
	background:#fff; border:1px solid var(--line); border-radius:16px; overflow:hidden;
	box-shadow:0 6px 18px rgba(42,36,28,.06);
	transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.gphds:hover{transform:translateY(-4px); border-color:var(--gold); box-shadow:0 18px 36px rgba(42,36,28,.15)}
.gphds__img{display:block; height:160px; background:var(--cream-2) center/cover no-repeat; transition:transform .4s ease}
.gphds:hover .gphds__img{transform:scale(1.05)}
.gphds__body{padding:1rem 1.15rem 1.2rem; display:flex; flex-direction:column; gap:.3rem}
.gphds__name{
	font-family:'Playfair Display',Georgia,serif; font-weight:700;
	font-size:1.22rem; color:var(--charcoal); line-height:1.2;
}
.gphds__count{font-size:.86rem; font-weight:600; color:var(--muted-2)}
.gphds__go{
	margin-top:.45rem; font-size:.9rem; font-weight:700; color:var(--teal);
	transition:gap .16s ease;
}
.gphds:hover .gphds__go{color:var(--gold-3)}

/* -------------------------------------------------- VENUE GRID + CARD */
.gphdp__venues{background:var(--cream)}
.gphdp__grid{
	display:grid; grid-template-columns:repeat(auto-fill,minmax(330px,1fr));
	gap:1.6rem;
}
.gphdp__grid--more{margin-top:1.6rem}
.gphdp__browse{margin-top:2rem; text-align:center}
.gphdp__empty{font-size:1.1rem; color:var(--muted)}
.gphdp__empty a{color:var(--gold-3); font-weight:700}

/* the branded venue card — large, spacious, premium */
.gphdc{
	display:flex; flex-direction:column;
	background:#fff; border:1px solid var(--line); border-radius:18px; overflow:hidden;
	box-shadow:0 8px 22px rgba(42,36,28,.07);
	transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.gphdc:hover{transform:translateY(-4px); border-color:var(--gold); box-shadow:0 20px 42px rgba(42,36,28,.16)}
.gphdc__media{position:relative; display:block; overflow:hidden}
.gphdc__img{
	display:block; height:230px; background:var(--cream-2) center/cover no-repeat;
	transition:transform .5s ease;
}
.gphdc:hover .gphdc__img{transform:scale(1.06)}
.gphdc__tag{
	position:absolute; top:14px; left:14px;
	background:linear-gradient(135deg,var(--gold-2),var(--gold-3)); color:#fffdf9;
	font-size:.68rem; font-weight:800; letter-spacing:.08em; text-transform:uppercase;
	padding:.34rem .7rem; border-radius:999px; line-height:1.2;
	box-shadow:0 3px 10px rgba(20,17,13,.25);
}
/* three honest voices — same shape, distinct, calm tint */
.gphdc__tag--resort{background:linear-gradient(135deg,var(--gold-2),var(--gold-3))}
.gphdc__tag--hotel{background:rgba(20,17,13,.82)}
.gphdc__tag--course{background:linear-gradient(135deg,#2f9282,var(--teal))}
.gphdc__body{padding:1.3rem 1.4rem 1.4rem; display:flex; flex-direction:column; gap:.55rem; flex:1}
.gphdc__name{margin:0; line-height:1.2}
.gphdc__name a{
	font-family:'Playfair Display',Georgia,serif; font-weight:700;
	font-size:1.42rem; color:var(--charcoal); text-decoration:none;
}
.gphdc__name a:hover{color:var(--gold-3)}
.gphdc__stars{margin:0; display:flex; align-items:center; gap:.5rem; color:var(--gold); font-size:1.05rem; letter-spacing:.06em}
.gphdc__stars-txt{font-family:inherit; font-size:.8rem; font-weight:600; color:var(--muted-2); letter-spacing:0}
.gphdc__plays{
	margin:0; font-size:.98rem; line-height:1.5; color:var(--ink);
}
.gphdc__plays-lbl{
	display:block; font-size:.7rem; font-weight:800; letter-spacing:.1em;
	text-transform:uppercase; color:var(--muted-2); margin-bottom:.12rem;
}
.gphdc__plays a{color:var(--teal); text-decoration:underline; text-decoration-color:#cfe0db; text-underline-offset:2px; font-weight:600}
.gphdc__plays a:hover{color:var(--gold-3); text-decoration-color:var(--gold)}
/* COURSE voice — pedigree badges (NO stars on a course) */
.gphdc__peds{display:flex; flex-wrap:wrap; gap:.4rem; margin:.1rem 0 .1rem}
.gphdc__ped{
	display:inline-flex; align-items:center; gap:.35rem;
	background:#faf3e3; border:1px solid #ecdcba; color:var(--gold-3);
	font-size:.78rem; font-weight:700; letter-spacing:.01em;
	padding:.22rem .6rem; border-radius:999px; line-height:1.3;
}
.gphdc__ped svg{color:var(--gold-2); flex:none}
/* COURSE voice — "Stay & play" block (the hotel's stars live HERE) */
.gphdc__stay{
	margin:.2rem 0 .1rem; padding:.7rem .85rem;
	background:var(--cream); border:1px solid var(--line); border-radius:12px;
}
.gphdc__stay-lbl{
	display:block; font-size:.66rem; font-weight:800; letter-spacing:.12em;
	text-transform:uppercase; color:var(--gold-2); margin-bottom:.25rem;
}
.gphdc__stay-hotel{
	display:flex; align-items:center; flex-wrap:wrap; gap:.5rem;
	font-weight:700; font-size:.98rem; color:var(--charcoal); line-height:1.3;
}
.gphdc__stay-hotel a{color:var(--charcoal); text-decoration:none}
.gphdc__stay-hotel a:hover{color:var(--gold-3)}
.gphdc__stay-stars{color:var(--gold); letter-spacing:.1em; font-size:.95rem}
.gphdc__trust{
	margin:.1rem 0 0; display:inline-flex; align-items:center; gap:.45rem;
	font-size:.85rem; font-weight:600; color:var(--teal);
}
.gphdc__trust-ico{color:var(--teal); flex:none}
.gphdc__foot{
	margin-top:auto; padding-top:1rem; border-top:1px solid #f1ead9;
	display:flex; align-items:flex-end; justify-content:space-between; gap:1rem; flex-wrap:wrap;
}
.gphdc__price{margin:0; display:flex; align-items:baseline; gap:.25rem; line-height:1}
.gphdc__price-pre{font-size:.72rem; font-weight:700; text-transform:uppercase; letter-spacing:.1em; color:var(--muted-2)}
.gphdc__price-fig{font-family:'Playfair Display',Georgia,serif; font-weight:800; font-size:1.85rem; color:var(--charcoal)}
.gphdc__price-unit{font-size:.78rem; font-weight:700; color:var(--muted)}
.gphdc__price-poa{font-family:'Playfair Display',Georgia,serif; font-weight:700; font-size:1.15rem; color:var(--muted)}
.gphdc__cta-grp{display:flex; gap:.5rem; align-items:stretch}
.gphdc__cta{
	display:inline-flex; align-items:center; gap:.4rem;
	background:linear-gradient(180deg,var(--gold-2),var(--gold-3)); color:#fffdf9;
	font-family:inherit; font-size:.95rem; font-weight:800; letter-spacing:.01em;
	text-decoration:none; padding:.7rem 1.1rem; border-radius:10px; line-height:1.2;
	transition:transform .16s ease, box-shadow .16s ease, background .16s ease; white-space:nowrap;
}
.gphdc__cta:hover{background:linear-gradient(180deg,#b89865,var(--gold-3)); box-shadow:0 8px 22px rgba(170,140,87,.34); transform:translateY(-2px)}
.gphdc__cta-arr{transition:transform .15s ease}
.gphdc__cta:hover .gphdc__cta-arr{transform:translateX(3px)}
.gphdc__call{
	display:inline-flex; align-items:center; gap:.35rem;
	background:#fff; color:var(--gold-3); border:1.5px solid var(--gold);
	font-family:inherit; font-size:.92rem; font-weight:700;
	text-decoration:none; padding:.7rem .95rem; border-radius:10px; line-height:1.2;
	transition:background .16s ease, color .16s ease, transform .16s ease; white-space:nowrap;
}
.gphdc__call:hover{background:var(--gold); color:var(--charcoal); transform:translateY(-2px)}
.gphdc__call-txt{font-weight:700}

/* ----------------------------------------------- SIBLING CROSS-LINKS */
.gphdp__siblings{background:var(--cream); padding-top:1rem}
.gphdp__sibrow{display:flex; flex-wrap:wrap; gap:.6rem; margin-top:.4rem}
.gphdp__sibchip{
	display:inline-flex; background:#fff; border:1px solid var(--line); color:var(--ink);
	font-size:.95rem; font-weight:600; text-decoration:none;
	padding:.55rem 1.1rem; border-radius:999px;
	transition:background .15s ease, border-color .15s ease, color .15s ease, transform .15s ease;
}
.gphdp__sibchip:hover{border-color:var(--gold); color:var(--gold-3); transform:translateY(-1px); box-shadow:0 4px 12px rgba(42,36,28,.08)}

/* ----------------------------------------------- REASSURANCE FOOTER */
.gphdp__assure{background:var(--charcoal); color:var(--cream)}
.gphdp__assure-in{
	max-width:1180px; margin:0 auto; padding:clamp(2rem,4vw,3rem) clamp(1.2rem,4vw,2.4rem);
	display:grid; grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); gap:1.6rem;
}
.gphdp__assure-item{display:flex; align-items:flex-start; gap:.85rem; font-size:.98rem; line-height:1.5; color:rgba(253,251,246,.86)}
.gphdp__assure-item svg{color:var(--gold); flex:none; margin-top:.1rem}
.gphdp__assure-item strong{color:#fff; font-weight:700; font-size:1.05rem}
.gphdp__assure-item a{color:var(--gold); font-weight:700; text-decoration:none}
.gphdp__assure-item a:hover{text-decoration:underline}

/* ---------------------------------------------------------- RESPONSIVE */
@media(max-width:640px){
	.gphdp{font-size:16px}
	.gphdp__grid{grid-template-columns:1fr}
	.gphdp__hero{min-height:420px}
	.gphdp__foot{flex-direction:column; align-items:stretch}
	.gphdc__cta-grp{justify-content:space-between}
	.gphdc__cta{flex:1; justify-content:center}
}

@media(prefers-reduced-motion:reduce){
	.gphds,.gphdc,.gphds__img,.gphdc__img,.gphdp__btn,.gphdc__cta,.gphdc__call,.gphdp__sibchip{transition:none}
	.gphds:hover .gphds__img,.gphdc:hover .gphdc__img{transform:none}
}
