@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,400;9..144,600;9..144,800;9..144,900&family=Inter:wght@400;500;600;700;800&display=swap');

:root{
  --ocean:#001d3d; --ocean-2:#003566; --deep:#000814;
  --turquoise:#00a896; --turquoise-2:#02c39a; --aqua:#7dd3c0;
  --coral:#f77f00; --coral-2:#e63946; --sun:#ffba08;
  --sand:#fdf6e3; --sand-2:#f5ead3;
  --ink:#0a1929; --slate:#3d4a5c; --muted:#7a8a9c;
  --white:#fff; --offwhite:#fafaf7; --soft:#eef2f5;
  --shadow-sm:0 2px 8px rgba(0,29,61,.06),0 1px 2px rgba(0,29,61,.04);
  --shadow:0 10px 30px rgba(0,29,61,.08),0 2px 6px rgba(0,29,61,.05);
  --shadow-lg:0 30px 80px rgba(0,29,61,.18),0 8px 20px rgba(0,29,61,.08);
  --radius:14px; --radius-lg:24px;
  --grad-ocean:linear-gradient(135deg,#003566 0%,#001d3d 50%,#000814 100%);
  --grad-tropic:linear-gradient(135deg,#00a896 0%,#02c39a 100%);
  --grad-sunset:linear-gradient(135deg,#f77f00 0%,#e63946 100%);
  --grad-fade-dark:linear-gradient(180deg,rgba(0,8,20,0) 0%,rgba(0,8,20,.4) 50%,rgba(0,8,20,.92) 100%);
  --grad-fade-side:linear-gradient(90deg,rgba(0,8,20,.85) 0%,rgba(0,8,20,.45) 60%,rgba(0,8,20,0) 100%);
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font:16px/1.65 'Inter',-apple-system,BlinkMacSystemFont,system-ui,sans-serif;color:var(--ink);background:var(--offwhite);overflow-x:hidden;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:var(--turquoise);text-decoration:none;transition:color .2s}
a:hover{color:var(--coral)}

h1,h2,h3,h4{font-family:'Fraunces',Georgia,serif;line-height:1.1;letter-spacing:-.02em;color:var(--ink);font-weight:800;margin:0}
h1{font-size:clamp(2.4rem,5.2vw,4.6rem);font-weight:900}
h2{font-size:clamp(1.8rem,3.5vw,2.6rem);margin:3.5rem 0 1.5rem}
h3{font-size:1.35rem;font-weight:700;margin:1.8rem 0 .6rem}
h4{font-size:1rem;font-weight:700;margin:0 0 .5rem}

p{margin:0 0 1rem}

/* === HEADER === */
.site-header{position:fixed;top:0;left:0;right:0;z-index:100;background:rgba(255,255,255,.85);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid rgba(0,29,61,.06);transition:all .3s}
.site-header .wrap{max-width:1320px;margin:0 auto;padding:1.05rem 1.6rem;display:flex;align-items:center;gap:2.5rem}
.brand{font-family:'Fraunces',serif;font-weight:900;font-size:1.2rem;color:var(--ocean);display:flex;align-items:center;gap:.55rem;letter-spacing:-.02em}
.brand-mark{width:34px;height:34px;background:var(--grad-tropic);border-radius:10px;display:grid;place-items:center;color:#fff;font-size:1rem;box-shadow:0 4px 12px rgba(0,168,150,.4)}
.nav{display:flex;gap:2rem;flex:1}
.nav a{color:var(--ink);font-weight:500;font-size:.94rem;position:relative;padding:.4rem 0}
.nav a::after{content:"";position:absolute;left:0;right:100%;bottom:0;height:2px;background:var(--turquoise);transition:right .25s}
.nav a:hover{color:var(--ocean)}
.nav a:hover::after{right:0}
.nav-cta{padding:.6rem 1.3rem;background:var(--ink);color:#fff!important;border-radius:99px;font-weight:600;font-size:.88rem;transition:all .2s}
.nav-cta:hover{background:var(--coral);transform:translateY(-1px)}

/* === HERO PHOTO === */
.hero-photo{position:relative;height:78vh;min-height:560px;max-height:760px;margin-top:0;display:flex;align-items:flex-end;color:#fff;overflow:hidden}
.hero-photo::before{content:"";position:absolute;inset:0;background-image:var(--bg);background-size:cover;background-position:center;transform:scale(1.05)}
.hero-photo::after{content:"";position:absolute;inset:0;background:var(--grad-fade-dark)}
.hero-photo .container{position:relative;z-index:2;padding:0 1.6rem 4rem;width:100%;max-width:1320px;margin:0 auto}
.hero-photo .breadcrumb{color:rgba(255,255,255,.75);font-size:.86rem;margin-bottom:1.4rem;letter-spacing:.02em}
.hero-photo .breadcrumb a{color:rgba(255,255,255,.85)}
.hero-photo .breadcrumb a:hover{color:#fff}
.hero-photo .kicker{display:inline-block;background:var(--coral);color:#fff;padding:.32rem .9rem;border-radius:99px;font-size:.78rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;margin-bottom:1rem}
.hero-photo h1{color:#fff;max-width:18ch;text-shadow:0 2px 30px rgba(0,0,0,.3)}
.hero-photo .hero-lead{font-size:clamp(1.05rem,1.5vw,1.25rem);max-width:60ch;color:rgba(255,255,255,.92);margin:1rem 0 1.5rem;line-height:1.55}
.hero-photo .meta-strip{display:flex;flex-wrap:wrap;gap:2rem;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.18);font-size:.95rem}
.hero-photo .meta-strip .meta-item{display:flex;flex-direction:column;gap:.15rem}
.hero-photo .meta-strip .meta-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;color:rgba(255,255,255,.6);font-weight:600}
.hero-photo .meta-strip .meta-value{font-weight:600;color:#fff}

/* === LAYOUT === */
.shell{max-width:1320px;margin:0 auto;padding:0 1.6rem}
.content-grid{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:4rem;padding:3.5rem 0 5rem}
.content-grid.full{grid-template-columns:minmax(0,1fr)}
@media(max-width:980px){.content-grid{grid-template-columns:1fr;gap:2rem}}
article.main p{font-size:1.06rem;color:var(--slate);max-width:72ch}
article.main p.lead{font-size:1.18rem;line-height:1.6;color:var(--ink);font-weight:500}

/* === STATS BAR === */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1px;background:var(--soft);border-radius:var(--radius-lg);overflow:hidden;margin:2rem 0;box-shadow:var(--shadow-sm)}
.stats .stat{background:#fff;padding:1.6rem 1.4rem;text-align:center}
.stats .stat .num{font-family:'Fraunces',serif;font-size:2.4rem;font-weight:900;color:var(--ocean);line-height:1;letter-spacing:-.04em}
.stats .stat .num .accent{color:var(--coral)}
.stats .stat .lbl{font-size:.76rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:600;margin-top:.5rem}

/* === FACT CARD === */
.factcard{background:#fff;border-radius:var(--radius-lg);padding:2rem 2.2rem;margin:2rem 0;box-shadow:var(--shadow);border:1px solid var(--soft)}
.factcard h3{margin-top:0;display:flex;align-items:center;gap:.5rem;color:var(--ocean)}
.factcard h3::before{content:"";width:6px;height:24px;background:var(--grad-tropic);border-radius:3px}
.factcard dl{display:grid;grid-template-columns:max-content 1fr;gap:.85rem 1.6rem;margin:0}
.factcard dt{color:var(--muted);font-size:.84rem;text-transform:uppercase;letter-spacing:.05em;font-weight:600;align-self:center}
.factcard dd{margin:0;font-weight:500;color:var(--ink);align-self:center}

/* === PHOTO CARDS === */
.cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;margin:1.5rem 0}
.cards-grid.three{grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}
.pcard{background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);transition:all .3s;display:block;color:inherit;border:1px solid var(--soft)}
.pcard:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);text-decoration:none;color:inherit}
.pcard .pcard-img{aspect-ratio:16/10;background:var(--soft);background-size:cover;background-position:center;position:relative}
.pcard .pcard-img::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 60%,rgba(0,8,20,.4) 100%)}
.pcard .pcard-tag{position:absolute;top:.85rem;left:.85rem;background:rgba(255,255,255,.95);padding:.3rem .75rem;border-radius:99px;font-size:.74rem;font-weight:700;color:var(--ocean);letter-spacing:.04em;text-transform:uppercase;backdrop-filter:blur(10px);z-index:1}
.pcard .pcard-rate{position:absolute;top:.85rem;right:.85rem;background:rgba(0,8,20,.85);color:#ffba08;padding:.3rem .65rem;border-radius:99px;font-size:.78rem;font-weight:700;backdrop-filter:blur(10px);z-index:1}
.pcard .pcard-body{padding:1.1rem 1.3rem 1.4rem}
.pcard h3{font-size:1.15rem;margin:0 0 .35rem;font-weight:700}
.pcard p{font-size:.92rem;color:var(--muted);margin:0;line-height:1.5}
.pcard .pcard-meta{display:flex;align-items:center;gap:.5rem;font-size:.8rem;color:var(--muted);margin-top:.7rem;text-transform:uppercase;letter-spacing:.05em;font-weight:600}
.pcard .pcard-meta .dot{width:4px;height:4px;background:var(--turquoise);border-radius:50%}

/* === SECTION DIVIDERS / FULL-WIDTH BANDS === */
.band{padding:5rem 0;margin:4rem 0}
.band.dark{background:var(--grad-ocean);color:#fff}
.band.dark h2,.band.dark h3{color:#fff}
.band.dark p{color:rgba(255,255,255,.78)}
.band.sand{background:var(--sand)}
.band-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}
.band-header h2{margin:0}
.band-header .seeall{font-size:.92rem;font-weight:600;color:var(--turquoise);text-transform:uppercase;letter-spacing:.06em}

/* === BIG IMAGE BLOCK === */
.image-feature{margin:3rem 0;border-radius:var(--radius-lg);overflow:hidden;position:relative;aspect-ratio:21/9;background-size:cover;background-position:center;box-shadow:var(--shadow-lg)}
.image-feature .caption{position:absolute;bottom:0;left:0;right:0;padding:2rem;color:#fff;background:linear-gradient(180deg,transparent,rgba(0,8,20,.8))}
.image-feature .caption .label{font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;color:var(--aqua);font-weight:700}
.image-feature .caption h3{color:#fff;margin:.3rem 0 0;font-size:1.6rem}

/* === MAP === */
.map{height:380px;border-radius:var(--radius-lg);background:#0a1929 url('https://api.mapbox.com/styles/v1/mapbox/satellite-v9/static/-61.05,14.6,9,0/1200x600?access_token=demo'),linear-gradient(135deg,#003566,#001d3d);background-size:cover;background-position:center;position:relative;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.85);font-size:.92rem;letter-spacing:.04em;border:1px solid var(--soft);box-shadow:var(--shadow);overflow:hidden}
.map::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 50% 40%,transparent,rgba(0,8,20,.5));pointer-events:none}
.map::after{content:"📍";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:3rem;filter:drop-shadow(0 6px 14px rgba(0,0,0,.6));z-index:2}
.map-tag{position:absolute;top:1rem;left:1rem;background:rgba(255,255,255,.95);padding:.4rem .85rem;border-radius:99px;font-size:.78rem;font-weight:700;color:var(--ocean);text-transform:uppercase;letter-spacing:.05em;z-index:3}

/* === FAQ === */
.faq-wrap{margin:2rem 0}
.faq-wrap details{background:#fff;border:1px solid var(--soft);border-radius:var(--radius);padding:1.2rem 1.6rem;margin-bottom:.8rem;transition:all .2s}
.faq-wrap details:hover{border-color:var(--aqua)}
.faq-wrap details[open]{box-shadow:var(--shadow-sm);border-color:var(--turquoise)}
.faq-wrap summary{font-weight:600;cursor:pointer;list-style:none;color:var(--ocean);font-size:1.05rem;display:flex;justify-content:space-between;align-items:center;gap:1rem}
.faq-wrap summary::-webkit-details-marker{display:none}
.faq-wrap summary::after{content:"+";font-size:1.6rem;font-weight:300;color:var(--turquoise);transition:transform .2s}
.faq-wrap details[open] summary::after{transform:rotate(45deg)}
.faq-wrap details p{margin:.85rem 0 0;color:var(--slate)}

/* === TABLE === */
table{width:100%;border-collapse:collapse;margin:1.5rem 0;background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm)}
th,td{padding:.95rem 1.1rem;text-align:left;border-bottom:1px solid var(--soft)}
th{background:var(--ocean);color:#fff;font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;font-weight:700}
tr:last-child td{border:0}
tr:nth-child(even) td{background:var(--offwhite)}

/* === PILLS / TAGS === */
.pills{display:flex;flex-wrap:wrap;gap:.5rem;margin:1rem 0}
.pill{padding:.45rem 1rem;background:rgba(255,255,255,.12);color:#fff;border:1px solid rgba(255,255,255,.25);border-radius:99px;font-size:.82rem;font-weight:600;backdrop-filter:blur(10px)}
.pill.solid{background:#fff;color:var(--ocean);border:0}
.pill.coral{background:var(--coral);color:#fff;border:0}

/* === CTA === */
.cta-row{display:flex;gap:1rem;flex-wrap:wrap;margin:1.5rem 0}
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.95rem 1.8rem;border-radius:99px;font-weight:600;font-size:.95rem;transition:all .2s;text-decoration:none;border:0;cursor:pointer}
.btn-primary{background:var(--coral);color:#fff!important}
.btn-primary:hover{background:var(--coral-2);transform:translateY(-2px);box-shadow:0 12px 30px rgba(247,127,0,.35)}
.btn-ghost{background:transparent;color:var(--ocean)!important;border:1.5px solid var(--ocean)}
.btn-ghost:hover{background:var(--ocean);color:#fff!important}
.btn-light{background:#fff;color:var(--ocean)!important;box-shadow:var(--shadow-sm)}
.btn-light:hover{transform:translateY(-2px);box-shadow:var(--shadow)}

/* === ASIDE === */
aside.aside{font-size:.94rem}
.aside-card{background:#fff;border-radius:var(--radius);padding:1.4rem 1.5rem;margin-bottom:1.5rem;box-shadow:var(--shadow-sm);border:1px solid var(--soft)}
.aside-card h4{font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:.85rem;font-family:'Inter',sans-serif;font-weight:700}
.aside-card ul{padding:0;list-style:none;margin:0}
.aside-card li{padding:.55rem 0;border-bottom:1px solid var(--soft);font-size:.94rem}
.aside-card li:last-child{border:0}
.aside-card li a{color:var(--ink);font-weight:500;display:flex;justify-content:space-between;align-items:center}
.aside-card li a:hover{color:var(--turquoise)}
.aside-card li a span{color:var(--muted);font-size:.82rem;font-weight:600}
.aside-sticky{position:sticky;top:90px}

.aside-club{background:var(--grad-ocean);color:#fff;border:0}
.aside-club h4{color:var(--aqua)}
.aside-club .price{font-family:'Fraunces',serif;font-size:2.4rem;font-weight:900;color:#fff;line-height:1;margin:.4rem 0;letter-spacing:-.03em}
.aside-club .price small{font-size:1rem;font-weight:500;color:rgba(255,255,255,.7)}

/* === FOOTER === */
.site-footer{background:var(--deep);color:rgba(255,255,255,.7);padding:4rem 1.6rem 2rem;margin-top:5rem}
.site-footer .wrap{max-width:1320px;margin:0 auto;display:grid;grid-template-columns:1.5fr repeat(3,1fr);gap:3rem}
@media(max-width:760px){.site-footer .wrap{grid-template-columns:1fr 1fr}}
.site-footer h4{color:#fff;font-family:'Inter',sans-serif;font-size:.84rem;text-transform:uppercase;letter-spacing:.08em;margin-bottom:1.1rem}
.site-footer ul{padding:0;list-style:none;margin:0}
.site-footer li{padding:.35rem 0;font-size:.92rem}
.site-footer a{color:rgba(255,255,255,.7)}
.site-footer a:hover{color:var(--aqua)}
.site-footer .footer-brand{font-family:'Fraunces',serif;font-weight:900;font-size:1.4rem;color:#fff;margin-bottom:.8rem;display:block}
.site-footer .footer-baseline{font-size:.92rem;color:rgba(255,255,255,.55);max-width:32ch;line-height:1.6}
.site-footer .footer-bottom{max-width:1320px;margin:3rem auto 0;padding-top:2rem;border-top:1px solid rgba(255,255,255,.1);font-size:.82rem;color:rgba(255,255,255,.45);display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem}

/* === DEV NOTE === */
.dev-note{background:linear-gradient(135deg,#fff8e1,#fef3c7);border-left:4px solid var(--sun);border-radius:8px;padding:1rem 1.2rem;margin:2rem 0;font-size:.86rem;color:#7a5a05}
.dev-note strong{color:#5a3f00}

/* === INDEX === */
.preview-index{padding:7rem 1.6rem 5rem;max-width:1320px;margin:0 auto}
.preview-index h1{font-size:clamp(2.2rem,4vw,3.6rem);max-width:20ch;margin-bottom:1rem}
.preview-index .lead{font-size:1.15rem;color:var(--slate);max-width:60ch;margin-bottom:3rem}
.bento{display:grid;grid-template-columns:repeat(12,1fr);gap:1.2rem;grid-auto-flow:dense}
.bento-card{background:#fff;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);transition:all .3s;display:block;color:inherit;position:relative;min-height:240px}
.bento-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);text-decoration:none;color:inherit}
.bento-card .bg{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .5s}
.bento-card:hover .bg{transform:scale(1.05)}
.bento-card .bg::after{content:"";position:absolute;inset:0;background:var(--grad-fade-dark)}
.bento-card .body{position:relative;z-index:2;padding:1.6rem;height:100%;display:flex;flex-direction:column;justify-content:flex-end;color:#fff;min-height:260px}
.bento-card .label{font-size:.74rem;text-transform:uppercase;letter-spacing:.1em;font-weight:700;color:var(--aqua);margin-bottom:.4rem}
.bento-card h3{font-size:1.4rem;color:#fff;margin:0 0 .3rem;line-height:1.15}
.bento-card .url{font-size:.78rem;font-family:ui-monospace,monospace;color:rgba(255,255,255,.7);margin-top:.5rem}
.bento-card .vol{position:absolute;top:1rem;right:1rem;background:var(--coral);color:#fff;padding:.3rem .7rem;border-radius:99px;font-size:.74rem;font-weight:700;z-index:3}
.b-12{grid-column:span 12} .b-8{grid-column:span 8} .b-6{grid-column:span 6} .b-4{grid-column:span 4} .b-3{grid-column:span 3}
@media(max-width:900px){.b-8,.b-6,.b-4,.b-3{grid-column:span 12}}
.b-tall{min-height:400px}
.b-tall .body{min-height:400px}
