/* ============ Single beach page — "The Editorial" (Grace Bay) ============ */

/* breadcrumb (over hero) */
.crumb { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; font-family: var(--font-ui); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; font-weight: 500; }
.crumb a { color: rgba(255,255,255,0.72); }
.crumb a:hover { color: #fff; }
.crumb .sep { opacity: 0.5; }
.crumb .here { color: rgba(255,255,255,0.92); }

/* beach hero */
.bhero { position: relative; height: 78vh; min-height: 540px; display: flex; align-items: flex-end; overflow: hidden; color: #fff; }
.bhero__bg { position: absolute; inset: -12% 0; z-index: 0; will-change: transform; }
.bhero__bg .ph, .bhero__bg img { width: 100%; height: 100%; object-fit: cover; }
.bhero__scrim { position: absolute; inset: 0; z-index: 1; background: linear-gradient(to bottom, rgba(10,20,24,0.20), transparent 40%, rgba(10,20,24,0.55)); }
.bhero__inner { position: relative; z-index: 2; width: 100%; padding-top: clamp(92px,12vh,124px); padding-bottom: clamp(48px,6vw,72px); }
.bhero__rankbadge { display: inline-flex; align-items: baseline; gap: 10px; font-family: var(--font-ui); font-size: 11px; letter-spacing: 0.24em; text-transform: uppercase; font-weight: 500; background: rgba(255,255,255,0.08); color: #fff; border: 1px solid rgba(255,255,255,0.6); border-radius: 0; padding: 9px 18px; backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px); }
.bhero h1 { font-family: var(--font-display); font-weight: 400; font-size: clamp(48px, 6vw, 92px); line-height: 1.02; letter-spacing: 0; margin: 22px 0 0; text-wrap: balance; text-shadow: 0 2px 40px rgba(0,0,0,0.2); }
.bhero__tagline { font-family: var(--font-ui); font-style: normal; font-weight: 300; font-size: clamp(15px, 1.5vw, 19px); color: rgba(255,255,255,0.9); margin-top: 18px; max-width: 52ch; line-height: 1.6; }
.bhero__bar { margin-top: 22px; display: flex; align-items: baseline; gap: clamp(20px,4vw,40px); flex-wrap: wrap; font-size: 12px; letter-spacing: 0.18em; text-transform: uppercase; padding-top: 0; border-top: 0; }
.bhero__stat { display: flex; align-items: baseline; gap: 8px; }
.bhero__stat .v { font-family: var(--font-ui); font-weight: 600; font-size: 12px; letter-spacing: 0.14em; line-height: 1; color: #fff; }
.bhero__stat .v .star { color: var(--accent); }
.bhero__stat .k { font-family: var(--font-ui); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: rgba(255,255,255,0.62); margin: 0; }
.bhero__bar .spacer { flex: 1; }
.bhero__bar .btn { background: rgba(255,255,255,0.08); border-color: rgba(255,255,255,0.55); color: #fff; }
.bhero__bar .btn:hover { background: #fff; color: var(--ink); border-color: #fff; }
@media (max-width: 700px){ .bhero__bar .spacer { display: none; } .bhero__bar .btn { width: 100%; justify-content: center; } }

/* facts grid → clean hairline panel */
.facts { display: grid; grid-template-columns: repeat(3, 1fr); border: 1px solid var(--ink); border-radius: 0; overflow: hidden; background: var(--bg); }
@media (max-width: 760px){ .facts { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 460px){ .facts { grid-template-columns: 1fr; } }
.fact { padding: clamp(22px, 2.4vw, 32px); border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.fact .k { font-family: var(--font-ui); font-weight: 600; font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--muted); }
.fact .v { font-family: var(--font-display); font-weight: 400; font-size: clamp(22px, 2.4vw, 28px); line-height: 1.08; margin: 12px 0 6px; }
.fact .note { font-size: 13.5px; font-weight: 300; color: var(--ink-soft); line-height: 1.6; }

/* essay + sticky read panel */
.bsplit { display: grid; grid-template-columns: 1.4fr 1fr; gap: clamp(40px, 6vw, 84px); align-items: start; }
@media (max-width: 1020px){ .bsplit { grid-template-columns: 1fr; gap: 48px; } }
.bintro p { font-size: 16px; font-weight: 300; line-height: 1.9; color: #3c4246; margin: 0 0 26px; max-width: 62ch; }
.bintro p:first-child::first-letter { font-family: var(--font-display); font-size: 64px; line-height: 0.8; float: left; padding: 8px 14px 0 0; color: var(--accent); font-weight: 400; }
.know { background: var(--bg); border: 1px solid var(--ink); border-radius: 0; padding: clamp(28px, 3vw, 38px); position: sticky; top: 116px; }
.know h4 { font-family: var(--font-ui); font-weight: 600; font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--accent); margin: 0 0 18px; }
.know ul { list-style: none; margin: 0; padding: 0; }
.know li { display: flex; gap: 14px; padding: 14px 0; font-size: 14.5px; font-weight: 300; color: var(--ink-soft); border-top: 1px solid var(--line); line-height: 1.6; }
.know li:first-child { border-top: 0; }
.know li::before { content: ""; flex: none; width: 6px; height: 6px; border-radius: 50%; background: var(--accent); margin-top: 9px; }

/* clubs → hairline rows */
.ranked { display: flex; flex-direction: column; }
.rclub { display: grid; grid-template-columns: auto 1fr auto auto; gap: clamp(16px, 2.4vw, 28px); align-items: center; background: transparent; border: 0; border-bottom: 1px solid var(--line); border-radius: 0; padding: 24px 8px; transition: background .25s, padding-left .25s; }
.rclub:first-child { border-top: 1px solid var(--ink); }
.rclub:hover { border-color: var(--line); transform: none; box-shadow: none; background: var(--sand); padding-left: 22px; }
.rclub__rank { font-family: var(--font-display); font-size: 30px; line-height: 1; color: var(--muted); text-align: center; min-width: 44px; }
.rclub__media { display: none; }
.rclub__name { font-family: var(--font-display); font-weight: 400; font-size: 22px; line-height: 1.1; margin: 0; }
.rclub__rating { display: inline-flex; align-items: center; gap: 6px; font-family: var(--font-ui); font-size: 12px; color: var(--muted); margin-top: 6px; }
.rclub__rating .star { color: var(--accent); }
.rclub__blurb { color: var(--muted); font-size: 12.5px; font-weight: 300; line-height: 1.55; margin: 5px 0 0; }
.rclub__tags { display: flex; gap: 7px; flex-wrap: wrap; margin-top: 10px; }
.tag { font-family: var(--font-ui); font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; padding: 4px 10px; border-radius: 0; border: 1px solid var(--line); color: var(--muted); }
.rclub__act { text-align: right; display: flex; flex-direction: column; align-items: flex-end; gap: 8px; min-width: 130px; }
.rclub__price .from { font-family: var(--font-ui); font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--muted); }
.rclub__price .amt { font-family: var(--font-display); font-size: 24px; line-height: 1; }
.rclub__price .per { font-family: var(--font-ui); font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--muted); }
.rclub__soldout { font-family: var(--font-ui); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--muted); border: 1px solid var(--line); padding: 10px 16px; border-radius: 0; }
@media (max-width: 880px){ .rclub { grid-template-columns: auto 1fr; grid-template-areas: "rank body" "act act"; row-gap: 14px; } .rclub__rank { grid-area: rank; text-align: left; } .rclub__body { grid-area: body; } .rclub__act { grid-area: act; flex-direction: row; align-items: center; justify-content: space-between; width: 100%; } }

/* location strip */
.loc { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(24px, 4vw, 56px); align-items: center; }
@media (max-width: 760px){ .loc { grid-template-columns: 1fr; } }
.loc__map { position: relative; border-radius: 0; overflow: hidden; aspect-ratio: 16/10; border: 1px solid var(--line); background: var(--sand); }
.loc__map .ph { position: absolute; inset: 0; width: 100%; height: 100%; }
.loc__map .marker { position: absolute; left: 50%; top: 52%; transform: translate(-50%,-50%); width: 16px; height: 16px; border-radius: 50%; background: var(--accent); border: 3px solid #fff; box-shadow: 0 0 0 6px rgba(29,93,99,0.28); }
.loc__coords { font-family: var(--font-ui); font-size: 13px; letter-spacing: 0.06em; color: var(--ink-soft); display: flex; gap: 24px; margin-top: 20px; }

/* nearby / similar */
.nearby { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
@media (max-width: 760px){ .nearby { grid-template-columns: 1fr; } }
.ncard { position: relative; border-radius: 0; overflow: hidden; aspect-ratio: 4/3; display: flex; align-items: flex-end; cursor: pointer; background: var(--sand); }
.ncard .ph { position: absolute; inset: 0; width: 100%; height: 100%; transition: transform 1.4s cubic-bezier(.16,1,.3,1); }
.ncard:hover .ph { transform: scale(1.05); }
.ncard__scrim { position: absolute; inset: 0; background: linear-gradient(to top, rgba(10,20,24,0.7), transparent 60%); }
.ncard__body { position: relative; z-index: 2; padding: 18px; color: #fff; }
.ncard__name { font-family: var(--font-display); font-weight: 400; font-size: 24px; line-height: 1; }
.ncard__meta { font-family: var(--font-ui); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; opacity: 0.85; margin-top: 6px; }

/* image credit chip (Google Places attribution) */
.imgcred{font-family:var(--font-mono);font-size:10px;letter-spacing:0.08em;text-transform:uppercase;color:oklch(0.95 0.01 90 / 0.8);position:absolute;right:12px;bottom:12px;z-index:3;background:oklch(0.2 0.02 240 / 0.42);border:1px solid oklch(0.99 0.01 90 / 0.22);padding:4px 9px;border-radius:2px;backdrop-filter:blur(3px);}
.imgcred a{color:inherit;text-decoration:underline;}
