/*
Theme Name: Mar del Sol
Theme URI: https://mardelsol.com/
Author: Mar del Sol
Author URI: https://mardelsol.com/
Description: Single-page WordPress theme for Mar del Sol, a beachfront family villa in Playa Coyote, Guanacaste, Costa Rica. Apple-inspired one-pager with full-bleed image breaks, scroll-snap carousels, SEO-optimized for European and AI search.
Version: 1.3.4
Requires at least: 5.8
Tested up to: 6.5
Requires PHP: 7.4
License: All rights reserved
License URI: https://mardelsol.com/
Text Domain: mar-del-sol
Tags: one-page, real-estate, custom-colors, custom-menu, theme-options, threaded-comments, translation-ready
*/

:root{
  --bg:#fafaf7;
  --bg-2:#f3f1ea;
  --bg-3:#e9e6dd;
  --ink:#0d0d0d;
  --ink-2:#39393a;
  --mute:#7a7a75;
  --line:#dad7cf;
  --line-soft:#e8e5dc;
  --accent:#0a4f53;
  --radius:14px;
  --font:-apple-system,BlinkMacSystemFont,"SF Pro Display","SF Pro Text","Inter","Helvetica Neue",Arial,sans-serif;
  --serif:"New York","Times New Roman",ui-serif,Georgia,serif;
  --display:"Cinzel","Trajan Pro","Trajan","Cormorant Garamond",Georgia,ui-serif,serif;
  --t:cubic-bezier(.22,.61,.36,1);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{background:var(--bg);color:var(--ink);font-family:var(--font);font-weight:400;line-height:1.55;letter-spacing:-.005em;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;border:0;cursor:pointer;background:none;color:inherit}
.container{max-width:1280px;margin:0 auto;padding:0 32px}
.container-wide{max-width:1440px;margin:0 auto;padding:0 32px}
.eyebrow{font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--mute);font-weight:500}

h1,h2,h3{font-weight:400;letter-spacing:-.025em;line-height:1.04}
h1{font-family:var(--display);font-size:clamp(48px,8vw,118px);letter-spacing:.04em;font-weight:500;text-transform:uppercase}
h2{font-family:var(--display);font-size:clamp(28px,4.2vw,56px);font-weight:500;letter-spacing:.015em;line-height:1.12}
h2.tight{font-size:clamp(24px,3.2vw,40px)}
h3{font-size:clamp(17px,1.5vw,21px);letter-spacing:-.012em;font-weight:500}
p.lead{font-size:clamp(17px,1.5vw,21px);line-height:1.55;color:var(--ink-2);max-width:62ch;font-weight:300}
.serif{font-family:var(--serif);font-style:italic;font-weight:400}

.nav{position:fixed;top:0;left:0;right:0;z-index:50;display:flex;justify-content:space-between;align-items:center;padding:20px 32px;backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px);background:rgba(250,250,247,.72);border-bottom:1px solid transparent;transition:border-color .3s var(--t),background .3s var(--t)}
.nav.scrolled{border-bottom-color:var(--line)}
.nav-brand{font-family:var(--display);font-weight:500;letter-spacing:.18em;font-size:15px;text-transform:uppercase}
.nav-cta{font-size:13px;font-weight:400;padding:9px 18px;border:1px solid var(--ink);border-radius:99px;transition:background .2s,color .2s}
.nav-cta:hover{background:var(--ink);color:var(--bg)}

.hero{position:relative;min-height:100vh;display:flex;flex-direction:column;justify-content:flex-end;padding:128px 32px 72px;overflow:hidden;color:#fff}
.hero::before{content:"";position:absolute;inset:0;z-index:0;background-image:var(--hero-img);background-size:cover;background-position:center;transform:scale(1.02)}
.hero::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(0,0,0,.25) 0%,rgba(0,0,0,0) 30%,rgba(0,0,0,0) 60%,rgba(0,0,0,.55) 100%)}
.hero-inner{position:relative;z-index:2;max-width:1280px;margin:0 auto;width:100%}
.hero-tag{font-size:11px;letter-spacing:.32em;text-transform:uppercase;color:rgba(255,255,255,.88);margin-bottom:32px}
.hero h1{color:#fff;margin-bottom:26px;letter-spacing:-.045em}
.hero-sub{color:rgba(255,255,255,.92);font-size:clamp(18px,1.6vw,22px);font-weight:300;max-width:38ch;letter-spacing:-.005em}

section{padding:140px 0;position:relative}
section.tight{padding:84px 0}
section.tighter{padding:60px 0}
.section-head{margin-bottom:72px;max-width:920px}
.section-head .eyebrow{margin-bottom:20px;display:block}
.section-head h2{margin-bottom:22px}
.section-head p{color:var(--ink-2);font-size:clamp(17px,1.4vw,20px);max-width:62ch;font-weight:300;line-height:1.55}

.fullbleed{position:relative;width:100%;height:min(85vh,820px);background-size:cover;background-position:center;display:flex;align-items:flex-end;color:#fff;overflow:hidden}
.fullbleed.tall{height:min(95vh,940px)}
.fullbleed::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.15) 0%,rgba(0,0,0,0) 30%,rgba(0,0,0,.55) 100%);pointer-events:none}
.fullbleed .ovly{position:relative;z-index:2;padding:0 32px 80px;max-width:1280px;margin:0 auto;width:100%}
.fullbleed .ovly .eyebrow{color:rgba(255,255,255,.78);margin-bottom:16px;display:block}
.fullbleed .ovly h2{color:#fff;max-width:18ch;letter-spacing:-.03em;font-weight:300}
.fullbleed .ovly p{color:rgba(255,255,255,.92);max-width:50ch;margin-top:18px;font-size:18px;font-weight:300}

.statement{padding:180px 0}
.statement h2{max-width:24ch;letter-spacing:-.03em}
.statement .credit{margin-top:36px;font-size:13px;letter-spacing:.18em;text-transform:uppercase;color:var(--mute)}

.snapshot{background:var(--bg-2);padding:72px 0}
.snapshot-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:28px 24px}
.snap{padding:8px 4px}
.snap .k{font-size:clamp(26px,2.8vw,40px);font-weight:300;letter-spacing:-.02em;color:var(--ink)}
.snap .l{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--mute);margin-top:8px}

.beds{margin-top:48px;display:grid;grid-template-columns:repeat(5,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.bed{padding:32px 26px;background:var(--bg);min-height:170px;display:flex;flex-direction:column;justify-content:space-between}
.bed .lab{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--mute)}
.bed .cfg{font-size:17px;font-weight:400;line-height:1.4;margin-top:28px;color:var(--ink)}
.bed .num{font-size:13px;color:var(--mute);margin-top:6px}
.beds-foot{margin-top:24px;font-size:13px;color:var(--mute);max-width:62ch}

.flex-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;max-width:780px}
.flex-cell{padding:26px 24px;background:var(--bg)}
.flex-lab{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--mute)}
.flex-val{font-size:16px;margin-top:14px;color:var(--ink)}

.video-wrap{position:relative;width:100%;aspect-ratio:16/9;background:#000;overflow:hidden;border-radius:var(--radius)}
.video-wrap video{width:100%;height:100%;object-fit:cover;display:block}
.video-pair{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.video-pair .video-wrap{aspect-ratio:9/16}
@media (max-width:760px){.video-pair{grid-template-columns:1fr}}

.carousel-track{display:flex;gap:14px;overflow-x:auto;overflow-y:hidden;scroll-snap-type:x mandatory;scroll-behavior:smooth;padding:0 32px 28px;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.carousel-track::-webkit-scrollbar{display:none}
.carousel-track .card{flex:0 0 auto;width:min(80vw,880px);aspect-ratio:4/3;scroll-snap-align:center;border-radius:var(--radius);overflow:hidden;background:#eee;position:relative}
.carousel-track .card img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--t)}
.carousel-track .card:hover img{transform:scale(1.02)}
.carousel-track .card.portrait{aspect-ratio:3/4;width:min(60vw,560px)}
.carousel-track .card.wide{aspect-ratio:16/9;width:min(85vw,1100px)}
.carousel-controls{display:flex;justify-content:space-between;align-items:center;padding:0 32px;margin-top:24px}
.carousel-arrows{display:flex;gap:8px}
.car-btn{width:44px;height:44px;border-radius:50%;border:1px solid var(--line);background:var(--bg);display:flex;align-items:center;justify-content:center;transition:background .2s,border-color .2s;font-size:18px;color:var(--ink-2);font-weight:300}
.car-btn:hover{background:var(--ink);border-color:var(--ink);color:var(--bg)}
.car-btn:disabled{opacity:.3;cursor:not-allowed}
.car-progress{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--mute);font-variant-numeric:tabular-nums}

.specs{padding:140px 0;background:var(--ink);color:#fff}
.specs .container{display:grid;grid-template-columns:1fr 1.1fr;gap:80px;align-items:start}
.specs h2{color:#fff;margin-bottom:24px;font-weight:300}
.specs p{color:rgba(255,255,255,.78);font-size:17px;max-width:54ch;margin-bottom:16px;line-height:1.6;font-weight:300}
.spec-list{display:flex;flex-direction:column;gap:1px;background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.10);border-radius:var(--radius);overflow:hidden}
.spec-list .row{padding:22px 26px;background:var(--ink);display:flex;justify-content:space-between;align-items:baseline;gap:24px}
.spec-list .row .k{color:rgba(255,255,255,.55);font-size:12px;letter-spacing:.18em;text-transform:uppercase;flex-shrink:0;min-width:140px}
.spec-list .row .v{font-size:15px;font-weight:400;text-align:right;color:rgba(255,255,255,.95);line-height:1.45}

.feature-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.feat{padding:34px 28px;border:1px solid var(--line);border-radius:var(--radius);background:var(--bg);transition:transform .3s var(--t),border-color .3s}
.feat:hover{transform:translateY(-2px);border-color:var(--accent)}
.feat .n{font-size:34px;font-weight:300;color:var(--accent);letter-spacing:-.02em;margin-bottom:14px;line-height:1}
.feat h3{margin-bottom:8px;font-size:16px;font-weight:500}
.feat p{color:var(--mute);font-size:14px;line-height:1.55;font-weight:400}

.location-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.location-img{aspect-ratio:5/4;border-radius:var(--radius);overflow:hidden;background:#ddd}
.location-img img{width:100%;height:100%;object-fit:cover}
.travel-list{margin-top:32px;display:grid;grid-template-columns:1fr 1fr;gap:22px 28px}
.travel-list .t{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--mute);margin-bottom:6px}
.travel-list .v{font-size:15px;color:var(--ink);line-height:1.45}

.pull{padding:120px 0;background:var(--bg-2)}
.pull .container{max-width:980px}
.pull h2{font-weight:300;letter-spacing:-.025em;font-size:clamp(28px,3.4vw,46px)}
.pull .by{margin-top:36px;font-size:12px;letter-spacing:.24em;text-transform:uppercase;color:var(--mute)}

.inquire{padding:140px 0;background:linear-gradient(180deg,var(--bg) 0%,var(--bg-2) 100%)}
.inquire-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
.price-line{margin:40px 0 32px;padding-top:28px;border-top:1px solid var(--line)}
.price{font-size:clamp(40px,5.4vw,72px);font-weight:300;letter-spacing:-.025em;color:var(--ink);line-height:1}
.price-note{margin-top:16px;font-size:13px;color:var(--mute);max-width:42ch;line-height:1.55}
.contact-channels{display:flex;flex-direction:column;gap:10px;margin-top:24px}
.contact-channels .ch{display:flex;justify-content:space-between;align-items:center;padding:18px 22px;background:var(--bg);border:1px solid var(--line);border-radius:10px;transition:border-color .2s,transform .2s;cursor:pointer}
.contact-channels .ch:hover{border-color:var(--ink);transform:translateY(-1px)}
.contact-channels .ch .label{font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--mute)}
.contact-channels .ch .value{font-size:15px;font-weight:400;margin-top:4px;color:var(--ink)}
.contact-channels .ch .arrow{font-size:18px;color:var(--mute)}

form{display:flex;flex-direction:column;gap:14px}
form label{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--mute);margin-bottom:6px;display:block}
form .field{display:flex;flex-direction:column}
form input,form textarea{font-family:inherit;font-size:15px;color:var(--ink);padding:14px 16px;background:var(--bg);border:1px solid var(--line);border-radius:8px;transition:border-color .2s}
form input:focus,form textarea:focus{outline:none;border-color:var(--accent)}
form textarea{resize:vertical;min-height:120px}
.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 28px;border-radius:99px;font-size:14px;font-weight:400;transition:transform .25s var(--t),background .25s,color .25s,border-color .25s;letter-spacing:.02em}
.btn-dark{background:var(--ink);color:#fff;border:1px solid var(--ink)}
.btn-dark:hover{background:transparent;color:var(--ink)}

/* Inquiry status messages */
#inquiry-status{font-size:13px;margin-top:14px;line-height:1.55;color:var(--mute)}
#inquiry-status.err{color:#a33}
#inquiry-status.sending{color:var(--mute)}
.thank-you{
  padding:40px 36px;
  background:var(--bg);
  border:1px solid var(--accent);
  border-radius:var(--radius);
  text-align:left;
}
.thank-you .eyebrow{color:var(--accent);margin-bottom:14px;display:block}
.thank-you h3{font-family:var(--display);font-size:clamp(22px,2.4vw,30px);font-weight:500;letter-spacing:.025em;text-transform:uppercase;color:var(--ink);margin-bottom:14px;line-height:1.2}
.thank-you p{color:var(--ink-2);font-size:15px;line-height:1.6;max-width:48ch;margin-bottom:18px}
.thank-you p:last-child{margin-bottom:0}
.thank-you .send-again{font-size:13px;color:var(--mute);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px;cursor:pointer;background:none;border:0;padding:0;font-family:inherit;letter-spacing:0;text-transform:none}
.thank-you .send-again:hover{color:var(--ink)}

.site-footer{padding:60px 32px 80px;background:var(--ink);color:rgba(255,255,255,.65)}
.site-footer .container{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:32px}
.site-footer .brand{font-size:22px;font-weight:300;color:#fff;letter-spacing:-.02em}
.site-footer .meta{font-size:12px;line-height:1.7}

.reveal{opacity:0;transform:translateY(18px);transition:opacity 1s var(--t),transform 1s var(--t)}
.reveal.in{opacity:1;transform:none}

@media (max-width:980px){
  section{padding:84px 0}
  .container,.container-wide{padding:0 22px}
  .snapshot-grid{grid-template-columns:repeat(2,1fr);gap:24px 18px}
  .beds{grid-template-columns:repeat(2,1fr) !important}
  .feature-grid{grid-template-columns:repeat(2,1fr);gap:14px}
  .flex-grid{grid-template-columns:1fr}
  .specs .container,.inquire-grid,.location-grid{grid-template-columns:1fr;gap:48px}
  .nav{padding:14px 20px}
  .hero{padding:120px 22px 56px}
  .carousel-track .card{width:88vw}
  .carousel-track .card.portrait{width:70vw}
  .carousel-track .card.wide{width:92vw}
  .spec-list .row{flex-direction:column;align-items:flex-start;gap:8px}
  .spec-list .row .v{text-align:left}
  .fullbleed{height:min(70vh,640px)}
  .fullbleed .ovly{padding-bottom:48px}
}
@media (max-width:560px){
  .snapshot-grid{grid-template-columns:repeat(2,1fr)}
  .beds{grid-template-columns:1fr !important}
  .feature-grid{grid-template-columns:1fr}
}

@media (prefers-reduced-motion:reduce){
  *{transition:none !important;animation:none !important;scroll-behavior:auto !important}
  .reveal{opacity:1;transform:none}
}
