
:root{
  --bg:#fbf7f2;
  --paper:#ffffff;
  --ink:#273232;
  --muted:#687272;
  --line:#eadfd3;
  --sand:#f1e5d8;
  --accent:#b97856;
  --accent-dark:#8b533d;
  --sea:#466b73;
  --wave-light:#7CA7C4;
  --wave-dark:#466B73;
  --shadow:0 18px 55px rgba(39,50,50,.12);
  --radius:24px;
  --max:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:"Manrope", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;background:var(--bg);color:var(--ink);line-height:1.65;text-rendering:optimizeLegibility}
body.menu-open{overflow:hidden}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{max-width:var(--max);margin:0 auto;padding:0 22px}
.skip-link{position:absolute;left:-999px;top:10px;background:#fff;padding:10px 14px;border-radius:10px;z-index:1000}.skip-link:focus{left:10px}
.site-header{position:sticky;top:0;z-index:50;background:rgba(251,247,242,.88);backdrop-filter:blur(18px);border-bottom:1px solid rgba(234,223,211,.78)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:16px;min-height:78px}
.brand{display:flex;align-items:center;gap:12px;font-weight:800;letter-spacing:.02em}.brand-mark{width:44px;height:44px;border-radius:14px;background:var(--paper);box-shadow:0 8px 22px rgba(39,50,50,.12);display:grid;place-items:center;color:var(--accent);font-family:Georgia,serif;font-size:19px}.brand small{display:block;font-weight:600;color:var(--muted);font-size:12px;margin-top:-3px}
.nav{display:flex;align-items:center;gap:20px;font-size:14px;font-weight:700;color:#3d4b4b}.nav a{padding:8px 0;border-bottom:2px solid transparent}.nav a:hover,.nav a:focus{border-color:var(--accent);color:var(--accent-dark)}
.header-actions{display:flex;align-items:center;gap:10px}.language{position:relative}.lang-button{border:1px solid var(--line);background:#fff;border-radius:999px;padding:9px 12px;font-weight:800;cursor:pointer;box-shadow:0 8px 20px rgba(39,50,50,.06)}.lang-menu{position:absolute;right:0;top:calc(100% + 10px);width:min(320px,88vw);background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow);padding:10px;display:none;grid-template-columns:1fr 1fr;gap:4px}.language.open .lang-menu{display:grid}.lang-menu a{padding:8px 10px;border-radius:12px;font-size:13px;font-weight:700}.lang-menu a:hover,.lang-menu a.current{background:var(--sand)}
.menu-toggle{display:none;border:0;background:var(--ink);color:#fff;border-radius:999px;padding:10px 14px;font-weight:800}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:999px;padding:12px 20px;font-weight:900;letter-spacing:.01em;transition:.2s ease;border:1px solid transparent}.btn-primary{background:var(--accent);color:#fff;box-shadow:0 12px 26px rgba(185,120,86,.28)}.btn-primary:hover{background:var(--accent-dark);transform:translateY(-1px)}.btn-ghost{background:rgba(255,255,255,.82);border-color:rgba(255,255,255,.7);color:var(--ink)}.btn-outline{background:#fff;border-color:var(--line);color:var(--ink)}
.hero{position:relative;isolation:isolate;min-height:720px;display:flex;align-items:center;overflow:hidden;background:#111}.hero:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(39,50,50,.77),rgba(39,50,50,.47),rgba(39,50,50,.08));z-index:-1}.hero picture,.hero-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2}.hero-img{filter:blur(2.4px);transform:scale(1.04);transform-origin:center center}.hero-content{max-width:760px;color:#fff;padding:110px 0 86px}.eyebrow{font-weight:900;letter-spacing:.18em;text-transform:uppercase;font-size:13px;color:#f5d8c6}.hero h1{font-family:Georgia,serif;font-size:clamp(40px,6vw,76px);line-height:1.02;margin:14px 0 20px}.hero p{font-size:clamp(17px,2vw,22px);max-width:690px;color:rgba(255,255,255,.94);margin:0 0 28px}.hero-actions{display:flex;flex-wrap:wrap;gap:12px}.hero-badges{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-top:-44px;position:relative;z-index:5}.hero-badge{background:#fff;border:1px solid var(--line);box-shadow:var(--shadow);padding:18px;border-radius:18px;font-weight:900;text-align:center;color:var(--sea)}
section{padding:92px 0}.section-head{max-width:760px;margin-bottom:36px}.section-head.center{text-align:center;margin-left:auto;margin-right:auto}.section-label{text-transform:uppercase;letter-spacing:.16em;font-size:12px;font-weight:900;color:var(--accent)}h2{font-family:Georgia,serif;font-size:clamp(32px,4vw,52px);line-height:1.1;margin:8px 0 14px}h3{font-family:Georgia,serif;font-size:25px;line-height:1.18;margin:0 0 10px}.lead{font-size:19px;color:var(--muted);max-width:790px}.intro-grid{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(300px,.8fr);gap:40px;align-items:start}.intro-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:30px;box-shadow:var(--shadow)}.facts{display:grid;grid-template-columns:1fr 1fr;gap:14px}.fact{background:var(--sand);border-radius:18px;padding:18px}.fact strong{display:block;font-size:22px;color:var(--accent-dark)}.fact span{color:var(--muted);font-weight:700}
.split{display:grid;grid-template-columns:minmax(300px,.92fr) minmax(0,1.08fr);gap:46px;align-items:center}.photo-card{border-radius:30px;overflow:hidden;box-shadow:var(--shadow);background:#fff}.photo-card img{width:100%;height:620px;object-fit:cover}.copy p{color:var(--muted);font-size:17px}.space-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;margin-top:30px}.space-card{background:#fff;border:1px solid var(--line);border-radius:20px;padding:22px;box-shadow:0 10px 30px rgba(39,50,50,.06)}.space-icon{width:42px;height:42px;border-radius:14px;background:var(--sand);display:grid;place-items:center;margin-bottom:12px;color:var(--accent-dark);font-weight:900}.space-card p{color:var(--muted);font-size:14px;margin:0}
.amenities{background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}.amenity-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.amenity{display:flex;align-items:flex-start;gap:10px;background:var(--bg);border:1px solid var(--line);border-radius:16px;padding:13px 15px;font-weight:750}.amenity:before{content:"✓";width:22px;height:22px;border-radius:50%;background:#fff;color:var(--accent-dark);display:inline-grid;place-items:center;flex:0 0 22px;font-size:13px;border:1px solid var(--line)}
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.gallery-item{position:relative;border:0;padding:0;border-radius:18px;overflow:hidden;cursor:pointer;background:#ddd;box-shadow:0 10px 26px rgba(39,50,50,.08)}.gallery-item img{width:100%;height:236px;object-fit:cover;transition:transform .28s ease}.gallery-item:hover img{transform:scale(1.035)}.gallery-item.feature{grid-column:span 2;grid-row:span 2}.gallery-item.feature img{height:486px}
.location{background:linear-gradient(180deg,#fff 0%,#fbf7f2 100%)}.nearby{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin-top:28px}.nearby li{list-style:none;background:#fff;border:1px solid var(--line);border-radius:18px;padding:18px;font-weight:800;color:var(--sea);box-shadow:0 10px 30px rgba(39,50,50,.05)}.nearby ul{padding:0;margin:0}.ideal-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.ideal-card{background:#fff;border:1px solid var(--line);border-radius:22px;padding:24px;box-shadow:0 10px 30px rgba(39,50,50,.06)}.ideal-card p{color:var(--muted);margin:0}.rules{background:var(--sea);color:#fff}.rules .lead,.rules p{color:rgba(255,255,255,.84)}.rules-card{background:rgba(255,255,255,.09);border:1px solid rgba(255,255,255,.16);border-radius:24px;padding:30px;max-width:900px}.faq-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.faq details{background:#fff;border:1px solid var(--line);border-radius:18px;padding:18px 20px}.faq summary{font-weight:900;cursor:pointer}.faq p{color:var(--muted);margin:10px 0 0}
.contact{background:#fff}.contact-grid{display:grid;grid-template-columns:minmax(0,.8fr) minmax(300px,1.2fr);gap:40px}.contact-card{background:var(--bg);border:1px solid var(--line);border-radius:24px;padding:28px}.contact-form{display:grid;grid-template-columns:1fr 1fr;gap:14px}.field{display:flex;flex-direction:column;gap:6px}.field.full{grid-column:1/-1}label{font-weight:900;font-size:13px;color:var(--sea)}input,textarea{width:100%;border:1px solid var(--line);border-radius:14px;background:#fff;padding:13px 14px;font:inherit;color:var(--ink)}textarea{min-height:140px;resize:vertical}.form-note{font-size:13px;color:var(--muted);margin-top:14px}.site-footer{padding:34px 0;background:var(--ink);color:#fff}.footer-inner{display:flex;align-items:center;justify-content:space-between;gap:20px}.footer-inner p{margin:0;color:rgba(255,255,255,.72)}.footer-links{display:flex;gap:14px;font-weight:800;color:#fff}
.lightbox{position:fixed;inset:0;background:rgba(0,0,0,.88);display:none;align-items:center;justify-content:center;z-index:100;padding:24px}.lightbox.open{display:flex}.lightbox-inner{max-width:min(1120px,94vw);max-height:90vh}.lightbox img{max-height:82vh;border-radius:18px;box-shadow:0 20px 80px rgba(0,0,0,.5)}.lightbox-close,.lightbox-prev,.lightbox-next{position:absolute;border:0;background:#fff;color:#111;border-radius:999px;cursor:pointer;font-weight:900}.lightbox-close{top:18px;right:18px;width:46px;height:46px;font-size:24px}.lightbox-prev,.lightbox-next{top:50%;transform:translateY(-50%);width:46px;height:46px;font-size:26px}.lightbox-prev{left:18px}.lightbox-next{right:18px}
@media (max-width:980px){.nav{position:fixed;inset:78px 0 auto 0;background:#fff;border-bottom:1px solid var(--line);padding:18px 22px;display:none;flex-direction:column;align-items:flex-start}.nav.open{display:flex}.menu-toggle{display:inline-flex}.hero{min-height:650px}.hero-badges{grid-template-columns:1fr 1fr;margin-top:20px}.intro-grid,.split,.contact-grid{grid-template-columns:1fr}.photo-card img{height:420px}.space-grid,.ideal-grid{grid-template-columns:1fr 1fr}.amenity-grid{grid-template-columns:1fr 1fr}.gallery-grid{grid-template-columns:1fr 1fr}.nearby{grid-template-columns:1fr 1fr}.faq-grid{grid-template-columns:1fr}}
@media (max-width:620px){.container{padding:0 16px}.header-inner{min-height:70px}.brand small{display:none}.hero{min-height:600px}.hero-content{padding:88px 0 54px}.hero:before{background:linear-gradient(90deg,rgba(39,50,50,.82),rgba(39,50,50,.5))}.hero-badges,.facts,.space-grid,.ideal-grid,.amenity-grid,.gallery-grid,.nearby,.contact-form{grid-template-columns:1fr}.gallery-item.feature{grid-column:auto;grid-row:auto}.gallery-item.feature img,.gallery-item img{height:280px}.footer-inner{flex-direction:column;align-items:flex-start}.lang-menu{grid-template-columns:1fr;width:260px}.btn{width:100%}section{padding:68px 0}}


.map-grid{display:grid;grid-template-columns:minmax(0,1.25fr) minmax(280px,.75fr);gap:24px;align-items:stretch;margin:32px 0 30px}.map-card{border-radius:24px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow);background:#fff;min-height:380px}.map-card iframe{width:100%;height:100%;min-height:380px;border:0;display:block}.map-copy{background:#fff;border:1px solid var(--line);border-radius:24px;padding:28px;box-shadow:0 10px 30px rgba(39,50,50,.06);display:flex;flex-direction:column;align-items:flex-start;justify-content:center}.map-copy p{color:var(--muted);margin:0 0 20px}.area-head{max-width:820px;margin:42px 0 22px}.area-head p{color:var(--muted);font-size:17px}.area-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.area-card{background:#fff;border:1px solid var(--line);border-radius:22px;overflow:hidden;box-shadow:0 10px 30px rgba(39,50,50,.06)}.area-card img{width:100%;height:230px;object-fit:cover;transition:transform .28s ease}.area-card a:hover img{transform:scale(1.035)}.area-card-body{padding:18px}.area-card-body h3{font-size:22px}.area-card-body p{color:var(--muted);margin:0 0 12px}.area-card-body small{display:block;color:#7b8585;font-size:11px;line-height:1.4}.photo-credit-note{margin:18px 0 0;color:var(--muted);font-size:13px}.photo-credit-note a{text-decoration:underline;font-weight:800;color:var(--accent-dark)}.credits-page{padding:92px 0}.credits-list{display:grid;gap:12px}.credit-item{background:#fff;border:1px solid var(--line);border-radius:18px;padding:18px}.credit-item h2{font-size:22px;margin:0 0 6px}.credit-item p{margin:0;color:var(--muted)}.credit-item a{text-decoration:underline;color:var(--accent-dark);font-weight:800}
@media (max-width:980px){.map-grid{grid-template-columns:1fr}.area-grid{grid-template-columns:1fr 1fr}.map-card,.map-card iframe{min-height:320px}}
@media (max-width:620px){.area-grid{grid-template-columns:1fr}.area-card img{height:240px}.map-copy{padding:22px}}


.area-card-wide{grid-column:1/-1;display:grid;grid-template-columns:minmax(0,1.6fr) minmax(260px,.7fr)}.area-card-wide img{height:260px}.area-card-wide .area-card-body{display:flex;flex-direction:column;justify-content:center}@media (max-width:760px){.area-card-wide{display:block}.area-card-wide img{height:190px}}

.gallery-groups{display:grid;gap:34px}.gallery-group{display:grid;gap:14px}.gallery-group-title{display:none!important}.gallery-item figcaption{display:none!important}.gallery-group .gallery-grid{margin-top:0}@media (max-width:620px){.gallery-groups{gap:26px}.gallery-group-title{display:none!important}}


/* Casa Elegante logo integration */
.brand{display:flex;align-items:center;gap:0;flex-shrink:0}
.brand-logo{display:block;width:clamp(190px,24vw,310px);height:auto;max-height:58px;object-fit:contain}
.footer-inner{align-items:center}
.footer-logo{width:min(280px,70vw);height:auto;object-fit:contain;margin-bottom:12px}
@media (max-width:980px){
  .brand-logo{width:clamp(180px,42vw,260px);max-height:52px}
}
@media (max-width:620px){
  .brand-logo{width:clamp(168px,56vw,230px);max-height:48px}
  .footer-logo{width:min(240px,72vw)}
}


/* v14 typography and logo-theme refinements */
body{letter-spacing:.002em}
h1,h2,h3,h4,.nav,.btn,.section-label,.eyebrow,.lang-button,.hero-badge,.fact strong{
  font-family:"Raleway","Manrope",ui-sans-serif,system-ui,sans-serif;
}
h1,h2,h3,h4{letter-spacing:.01em}
.nav{font-size:14px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}
.btn{font-size:14px;letter-spacing:.08em;text-transform:uppercase}
.section-label,.eyebrow{letter-spacing:.18em;text-transform:uppercase}
.hero h1{font-family:"Raleway","Manrope",ui-sans-serif,sans-serif;font-weight:700;letter-spacing:.015em}
.hero p,.copy p,.intro p,.fact span{font-family:"Manrope",ui-sans-serif,system-ui,sans-serif}
.hero{min-height:760px}
.hero:before{background:linear-gradient(90deg,rgba(32,43,46,.78),rgba(39,50,50,.50),rgba(39,50,50,.16))}
.hero-content{max-width:760px;padding:102px 0 88px}
.hero-logo-wrap{display:flex;flex-direction:column;align-items:flex-start;gap:10px;margin:0 0 12px}
.hero-logo{width:min(520px,72vw);height:auto;filter:drop-shadow(0 10px 28px rgba(0,0,0,.18))}
.hero-wave{width:min(160px,26vw);height:auto;opacity:.96}
.hero .eyebrow{color:#f0d7bc}
.hero-badges{margin-top:-56px}
.section-label{position:relative;display:inline-block;padding-bottom:14px}
.section-label:after{content:"";position:absolute;left:0;bottom:0;width:92px;height:16px;background:url('../img/waves-accent.svg') no-repeat left center/contain;opacity:.95}
.intro .container{position:relative}
.section-wave-accent{display:block;width:min(180px,36vw);height:auto;margin:18px 0 0 auto;opacity:.88}
.site-header{background:rgba(251,247,242,.92)}
.brand-logo{max-height:60px}
@media (max-width:980px){
  .hero{min-height:700px}
  .hero-logo{width:min(420px,78vw)}
  .hero-wave{width:min(142px,32vw)}
}
@media (max-width:620px){
  .nav{letter-spacing:.05em}
  .hero-content{padding:96px 0 82px}
  .hero-logo-wrap{margin-bottom:10px}
  .hero-logo{width:min(320px,82vw)}
  .hero-wave{width:min(120px,34vw)}
  .section-wave-accent{width:min(140px,40vw)}
}


/* v15 final typography adjustments */
.hero h1{
  font-family:"GFS Neohellenic","Manrope",ui-sans-serif,system-ui,sans-serif;
  font-weight:400;
  font-style:italic;
  letter-spacing:-.006em;
  line-height:1.04;
}
h2,.section-head h2,.copy h2,.rules-card h2,.contact h2,.faq h2{
  font-family:"Raleway","Manrope",ui-sans-serif,system-ui,sans-serif;
  font-weight:300;
  letter-spacing:.105em;
  text-transform:uppercase;
}
h3,.space-card h3,.ideal-card h3,.area-card-body h3{
  font-family:"Raleway","Manrope",ui-sans-serif,system-ui,sans-serif;
  font-weight:400;
  letter-spacing:.055em;
}
.section-label{
  font-family:"Raleway","Manrope",ui-sans-serif,system-ui,sans-serif;
  font-weight:500;
  letter-spacing:.2em;
}
.hero-logo-wrap{
  margin:0 0 18px;
  position:relative;
  display:inline-flex;
  width:clamp(112px,12vw,148px);
  aspect-ratio:1/1;
  align-items:center;
  justify-content:center;
  padding:0;
  border-radius:50%;
  isolation:isolate;
  background:radial-gradient(circle at center, rgba(255,255,255,.18) 0%, rgba(255,255,255,.11) 28%, rgba(255,255,255,.05) 48%, rgba(255,255,255,.015) 62%, rgba(255,255,255,0) 74%);
  box-shadow:none;
  backdrop-filter:blur(6px);
}
.hero-logo-wrap::before{
  content:"";
  position:absolute;
  inset:-24px;
  border-radius:50%;
  background:radial-gradient(circle at center, rgba(255,255,255,.62) 0%, rgba(255,255,255,.42) 26%, rgba(255,255,255,.22) 48%, rgba(255,255,255,.09) 66%, rgba(255,255,255,.025) 79%, rgba(255,255,255,0) 100%);
  filter:blur(18px);
  z-index:-2;
  pointer-events:none;
}
.hero-logo-wrap::after{
  content:"";
  position:absolute;
  inset:-8px;
  border-radius:50%;
  background:radial-gradient(circle at center, rgba(255,255,255,.14) 0%, rgba(255,255,255,.07) 42%, rgba(255,255,255,0) 78%);
  filter:blur(8px);
  z-index:-1;
  pointer-events:none;
}
.hero-icon-logo{
  width:74%;
  height:auto;
  display:block;
  position:relative;
  z-index:1;
  filter:drop-shadow(0 6px 12px rgba(0,0,0,.12));
}
.hero-wave{
  display:none!important;
}
@media (max-width:620px){
  .hero-logo-wrap{width:clamp(92px,24vw,118px)}
  .hero-icon-logo{width:74%}
  h2,.section-head h2,.copy h2,.rules-card h2,.contact h2,.faq h2{
    letter-spacing:.07em;
  }
}


/* v17 hero eyebrow refinement */
.hero .eyebrow{
  font-family:"Raleway","Manrope",ui-sans-serif,system-ui,sans-serif;
  font-weight:300;
  font-size:12px;
  letter-spacing:.28em;
  text-transform:uppercase;
  line-height:1.15;
  color:#f0d7bc;
}
@media (max-width:620px){
  .hero .eyebrow{
    font-size:11px;
    letter-spacing:.22em;
  }
}


/* v18 tighter italic hero title spacing */
.hero h1{
  letter-spacing:-.006em;
}


/* v19 even tighter italic hero title spacing */
.hero h1{
  letter-spacing:-.006em;
}


/* v20 subtle wave animation */
@keyframes waveDrift {
  0% { transform: translateX(0) translateY(0); }
  25% { transform: translateX(4px) translateY(-1px); }
  50% { transform: translateX(8px) translateY(0); }
  75% { transform: translateX(4px) translateY(1px); }
  100% { transform: translateX(0) translateY(0); }
}

.section-label:after,
.section-wave-accent {
  animation: waveDrift 7.5s ease-in-out infinite;
  will-change: transform;
}

@media (prefers-reduced-motion: reduce) {
  .section-label:after,
  .section-wave-accent {
    animation: none !important;
  }
}


/* v21 wave size refinement */
.section-label:after{
  width:132px;
  height:18px;
  background-size:contain;
}
.section-wave-accent{
  width:min(220px,44vw);
}
@media (max-width:620px){
  .section-label:after{
    width:116px;
    height:16px;
  }
  .section-wave-accent{
    width:min(170px,46vw);
  }
}


/* v22 proportional wave sizing */
.section-label{
  display:inline-block;
}
.section-label:after{
  left:50%;
  transform:translateX(-50%);
  width:calc(100% + 20px);
  min-width:84px;
  max-width:230px;
  height:18px;
  background-size:100% auto;
}
.area-head .section-label:after{
  width:calc(100% + 16px);
  min-width:150px;
  max-width:300px;
}
.section-wave-accent{
  width:min(240px,48vw);
}
@media (max-width:620px){
  .section-label:after{
    width:calc(100% + 16px);
    min-width:76px;
    max-width:190px;
    height:16px;
  }
  .area-head .section-label:after{
    min-width:132px;
    max-width:250px;
  }
  .section-wave-accent{
    width:min(190px,52vw);
  }
}


/* v23 centered animated waves */
@keyframes waveDriftCentered {
  0% { transform: translateX(-50%) translateY(0) translateX(0); }
  25% { transform: translateX(-50%) translateY(-1px) translateX(4px); }
  50% { transform: translateX(-50%) translateY(0) translateX(8px); }
  75% { transform: translateX(-50%) translateY(1px) translateX(4px); }
  100% { transform: translateX(-50%) translateY(0) translateX(0); }
}

.section-label{
  text-align:center;
}

.section-label:after{
  left:50%;
  right:auto;
  transform:translateX(-50%);
  transform-origin:center;
  animation:waveDriftCentered 7.5s ease-in-out infinite;
}

.section-wave-accent{
  margin:18px auto 0;
  display:block;
}

@media (prefers-reduced-motion: reduce) {
  .section-label:after{
    transform:translateX(-50%);
  }
}


/* v24 footer logo visibility fix */
.site-footer{
  background:linear-gradient(180deg,#273232 0%,#1f2929 100%);
}
.footer-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:22px;
}
.footer-logo{
  display:block;
  width:min(320px,74vw);
  height:auto;
  background:#fbf7f2;
  padding:12px 16px;
  border-radius:18px;
  box-shadow:0 12px 30px rgba(0,0,0,.22);
  margin:0;
}
@media (max-width:620px){
  .footer-inner{
    align-items:flex-start;
  }
  .footer-logo{
    width:min(280px,82vw);
    padding:10px 14px;
    margin-bottom:4px;
  }
}


/* v25 selected refinements: floating contact, reveal, icons, direct-booking, experience, lightbox count */
.intro-signature{
  margin-top:22px;
  font-family:"GFS Neohellenic","Manrope",ui-sans-serif,system-ui,sans-serif;
  font-style:italic;
  font-size:clamp(21px,2.5vw,31px);
  line-height:1.35;
  color:var(--accent-dark);
}

.amenity{
  position:relative;
  padding-left:48px;
  min-height:54px;
}
.amenity:before{
  content:"";
  position:absolute;
  left:18px;
  top:50%;
  width:18px;
  height:18px;
  transform:translateY(-50%);
  border:1.5px solid var(--accent);
  border-radius:50%;
}
.amenity:after{
  content:"";
  position:absolute;
  left:24px;
  top:50%;
  width:7px;
  height:3px;
  border-left:1.5px solid var(--sea);
  border-bottom:1.5px solid var(--sea);
  transform:translateY(-65%) rotate(-45deg);
}

.gallery-item{
  transition:transform .26s ease, box-shadow .26s ease;
}
.gallery-item:hover{
  transform:translateY(-3px);
  box-shadow:0 16px 36px rgba(39,50,50,.14);
}
.gallery-item img{
  transform-origin:center;
  transition:transform .45s ease, filter .45s ease;
}
.gallery-item:hover img{
  transform:scale(1.045);
  filter:saturate(1.04) contrast(1.02);
}

.book-direct{
  background:linear-gradient(180deg,#fbf7f2 0%,#fff 100%);
  padding:72px 0;
}
.book-direct-card{
  position:relative;
  overflow:hidden;
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:28px;
  align-items:center;
  background:#fff;
  border:1px solid var(--line);
  border-radius:30px;
  box-shadow:var(--shadow);
  padding:34px;
}
.book-direct-card:before{
  content:"";
  position:absolute;
  right:-80px;
  top:-70px;
  width:280px;
  height:190px;
  background:url('../img/waves-accent.svg') no-repeat center/contain;
  opacity:.18;
}
.book-direct-card > *{
  position:relative;
}
.book-direct-card h2,
.local-experience-card h2{
  margin:10px 0 12px;
}
.book-direct-actions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  justify-content:flex-end;
}

.local-experience{
  padding:72px 0;
  background:#fff;
}
.local-experience-card{
  position:relative;
  overflow:hidden;
  border-radius:30px;
  border:1px solid var(--line);
  background:linear-gradient(135deg,#fbf7f2 0%,#fff 58%,#f3ece4 100%);
  box-shadow:0 14px 42px rgba(39,50,50,.08);
  padding:42px;
}
.local-experience-card:after{
  content:"";
  position:absolute;
  right:36px;
  bottom:18px;
  width:220px;
  height:70px;
  background:url('../img/waves-accent.svg') no-repeat center/contain;
  opacity:.22;
}
.local-experience-card .lead{
  max-width:820px;
}

.floating-contact{
  position:fixed;
  right:18px;
  bottom:18px;
  z-index:80;
  display:flex;
  gap:8px;
  padding:8px;
  border-radius:999px;
  background:rgba(255,255,255,.92);
  border:1px solid var(--line);
  box-shadow:0 16px 42px rgba(39,50,50,.18);
  backdrop-filter:blur(12px);
}
.floating-contact a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:42px;
  padding:0 14px;
  border-radius:999px;
  font-family:"Raleway","Manrope",ui-sans-serif,system-ui,sans-serif;
  font-weight:700;
  letter-spacing:.06em;
  text-transform:uppercase;
  font-size:12px;
}
.float-viber{
  background:var(--accent);
  color:#fff;
}
.float-call{
  background:var(--ink);
  color:#fff;
}

.lightbox-count{
  margin-top:12px;
  text-align:center;
  color:rgba(255,255,255,.78);
  font-family:"Raleway","Manrope",ui-sans-serif,system-ui,sans-serif;
  letter-spacing:.12em;
  font-size:12px;
}
.lightbox-inner{
  display:flex;
  flex-direction:column;
  align-items:center;
}

.reveal{
  opacity:0;
  transform:translateY(18px);
  transition:opacity .8s ease, transform .8s ease;
}
.reveal.in-view{
  opacity:1;
  transform:translateY(0);
}

.footer-signature{
  margin:0;
  color:#f1e5d8!important;
  font-family:"GFS Neohellenic","Manrope",ui-sans-serif,system-ui,sans-serif;
  font-style:italic;
  font-size:22px;
  line-height:1.25;
}

@media (max-width:980px){
  .book-direct-card{
    grid-template-columns:1fr;
  }
  .book-direct-actions{
    justify-content:flex-start;
  }
}
@media (max-width:620px){
  .book-direct,
  .local-experience{
    padding:58px 0;
  }
  .book-direct-card,
  .local-experience-card{
    padding:26px;
    border-radius:24px;
  }
  .book-direct-actions .btn{
    width:auto;
    min-width:0;
  }
  .floating-contact{
    left:16px;
    right:16px;
    bottom:14px;
    justify-content:center;
  }
  .floating-contact a{
    flex:1;
  }
  .lightbox-count{
    font-size:11px;
  }
}
@media (prefers-reduced-motion: reduce){
  .reveal{
    opacity:1!important;
    transform:none!important;
    transition:none!important;
  }
  .gallery-item,
  .gallery-item img{
    transition:none!important;
  }
}




/* v28 alternating paired button colors */
.btn-primary,
.btn-outline,
.btn-ghost,
.menu-toggle,
.lang-button{
  background:var(--wave-light)!important;
  border-color:var(--wave-light)!important;
  color:#ffffff!important;
  box-shadow:0 12px 26px rgba(70,107,115,.18);
}

.btn-primary:hover,
.btn-primary:focus-visible,
.btn-primary:active,
.btn-outline:hover,
.btn-outline:focus-visible,
.btn-outline:active,
.btn-ghost:hover,
.btn-ghost:focus-visible,
.btn-ghost:active,
.menu-toggle:hover,
.menu-toggle:focus-visible,
.menu-toggle:active,
.lang-button:hover,
.lang-button:focus-visible,
.lang-button:active{
  background:var(--wave-dark)!important;
  border-color:var(--wave-dark)!important;
  color:#ffffff!important;
}

/* If buttons are next to each other, alternate colors */
.hero-actions .btn:nth-child(odd),
.book-direct-actions .btn:nth-child(odd),
.contact-actions .btn:nth-child(odd),
.floating-contact a:nth-child(odd){
  background:var(--wave-light)!important;
  border-color:var(--wave-light)!important;
  color:#ffffff!important;
}
.hero-actions .btn:nth-child(even),
.book-direct-actions .btn:nth-child(even),
.contact-actions .btn:nth-child(even),
.floating-contact a:nth-child(even){
  background:var(--wave-dark)!important;
  border-color:var(--wave-dark)!important;
  color:#ffffff!important;
}

/* On hover/press, each one swaps to the opposite tone */
.hero-actions .btn:nth-child(odd):hover,
.hero-actions .btn:nth-child(odd):focus-visible,
.hero-actions .btn:nth-child(odd):active,
.book-direct-actions .btn:nth-child(odd):hover,
.book-direct-actions .btn:nth-child(odd):focus-visible,
.book-direct-actions .btn:nth-child(odd):active,
.contact-actions .btn:nth-child(odd):hover,
.contact-actions .btn:nth-child(odd):focus-visible,
.contact-actions .btn:nth-child(odd):active,
.floating-contact a:nth-child(odd):hover,
.floating-contact a:nth-child(odd):focus-visible,
.floating-contact a:nth-child(odd):active{
  background:var(--wave-dark)!important;
  border-color:var(--wave-dark)!important;
}
.hero-actions .btn:nth-child(even):hover,
.hero-actions .btn:nth-child(even):focus-visible,
.hero-actions .btn:nth-child(even):active,
.book-direct-actions .btn:nth-child(even):hover,
.book-direct-actions .btn:nth-child(even):focus-visible,
.book-direct-actions .btn:nth-child(even):active,
.contact-actions .btn:nth-child(even):hover,
.contact-actions .btn:nth-child(even):focus-visible,
.contact-actions .btn:nth-child(even):active,
.floating-contact a:nth-child(even):hover,
.floating-contact a:nth-child(even):focus-visible,
.floating-contact a:nth-child(even):active{
  background:var(--wave-light)!important;
  border-color:var(--wave-light)!important;
}


/* v29 language menu color refinement */
.lang-menu a:hover,
.lang-menu a.current{
  background:var(--wave-light)!important;
  color:#ffffff!important;
}


/* v30 soft sea hover + underline for header nav */
.nav a{
  position:relative;
  transition:color .24s ease;
}
.nav a::after{
  content:"";
  position:absolute;
  left:50%;
  bottom:-8px;
  width:0;
  height:2px;
  background:var(--wave-light);
  border-radius:999px;
  transform:translateX(-50%);
  transition:width .24s ease, opacity .24s ease;
  opacity:.9;
}
.nav a:hover,
.nav a:focus-visible{
  color:var(--wave-light);
}
.nav a:hover::after,
.nav a:focus-visible::after,
.nav a.active::after{
  width:100%;
}
.nav a.active{
  color:var(--wave-light);
}


/* v31 nav underline color refinement */
.nav a:hover,
.nav a:focus,
.nav a:focus-visible,
.nav a.active{
  border-color:var(--wave-light)!important;
  color:var(--wave-light);
}
.nav a::after{
  background:var(--wave-dark)!important;
}


/* v32 platform booking links and AMA */
.platform-links{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin:8px 0 14px;
}
.platform-links a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  padding:8px 13px;
  font-family:"Raleway","Manrope",ui-sans-serif,system-ui,sans-serif;
  font-size:12px;
  font-weight:700;
  letter-spacing:.06em;
  text-transform:uppercase;
  background:var(--wave-light);
  color:#fff;
  transition:.22s ease;
}
.platform-links a:nth-child(even){
  background:var(--wave-dark);
}
.platform-links a:hover,
.platform-links a:focus-visible{
  transform:translateY(-1px);
  filter:brightness(.96);
}
.book-direct-actions .platform-booking,
.book-direct-actions .platform-airbnb{
  white-space:nowrap;
}
.ama-number{
  font-size:12px;
  letter-spacing:.06em;
  color:rgba(255,255,255,.68)!important;
  margin:0;
}


/* v33 softer booking block and tighter late-section large titles */
.book-direct{
  background:linear-gradient(180deg,#fff 0%,#fbf7f2 100%);
}
.book-direct-card{
  box-shadow:0 12px 36px rgba(39,50,50,.08);
  border-color:rgba(234,223,211,.9);
}
.book-direct-card:before{
  opacity:.12;
}
.book-direct-actions{
  align-items:center;
  row-gap:10px;
}
.book-direct-actions .btn{
  padding:11px 17px;
  font-size:12px;
}
.book-direct-card h2,
.local-experience-card h2,
.contact h2{
  letter-spacing:.04em;
}
.contact h2{
  max-width:780px;
}
@media (max-width:620px){
  .book-direct-actions{
    gap:8px;
  }
  .book-direct-actions .btn{
    width:auto;
    flex:1 1 42%;
  }
  .book-direct-card h2,
  .local-experience-card h2,
  .contact h2{
    letter-spacing:.025em;
  }
}


/* v34 SEO natural content */
.seo-natural-copy{
  color:var(--muted);
  font-size:15px;
}


/* v39 privacy page */
.privacy-page{
  padding:150px 0 90px;
  background:linear-gradient(180deg,#fbf7f2 0%,#ffffff 45%,#f7fbfd 100%);
}
.privacy-card{
  max-width:920px;
}
.privacy-card h1{
  margin:.2em 0 .25em;
  font-family:"GFS Neohellenic",serif;
  font-size:clamp(42px,6vw,78px);
  font-weight:400;
  letter-spacing:.035em;
  color:var(--ink);
}
.privacy-updated{
  color:var(--muted);
  font-size:14px;
  margin:0 0 34px;
}
.privacy-section{
  padding:24px 0;
  border-top:1px solid rgba(225,216,204,.9);
}
.privacy-section h2{
  margin:0 0 8px;
  font-family:"Raleway","Manrope",sans-serif;
  font-size:18px;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--wave-dark);
}
.privacy-section p{
  margin:0;
  color:var(--muted);
  line-height:1.8;
}
.privacy-back{
  margin-top:26px;
}


/* v41 tighter, taller large-title typography */
/* Applies to the big page/section titles only — logo images remain untouched. */
.hero h1,
.privacy-card h1{
  letter-spacing:-.026em;
  line-height:.96;
  font-weight:400;
}

h2,
.section-head h2,
.copy h2,
.rules-card h2,
.contact h2,
.faq h2,
.book-direct-card h2,
.local-experience-card h2,
.privacy-section h2{
  letter-spacing:-.018em;
  line-height:.94;
  font-weight:300;
  font-stretch:condensed;
}

.section-head h2,
.copy h2,
.book-direct-card h2,
.local-experience-card h2,
.contact h2,
.faq h2{
  font-size:clamp(36px,4.7vw,64px);
}

@media (max-width:620px){
  .hero h1,
  .privacy-card h1{
    letter-spacing:-.018em;
    line-height:1;
  }

  h2,
  .section-head h2,
  .copy h2,
  .rules-card h2,
  .contact h2,
  .faq h2,
  .book-direct-card h2,
  .local-experience-card h2,
  .privacy-section h2{
    letter-spacing:-.012em;
    line-height:1;
  }
}


/* v49 move small hero logo to the left of the text */
.hero-content{
  display:grid;
  grid-template-columns:clamp(104px,13vw,150px) minmax(0,1fr);
  column-gap:24px;
  align-items:start;
}
.hero-copy{
  min-width:0;
}
.hero-logo-wrap{
  margin:8px 0 0;
  justify-self:start;
}
.hero-copy .eyebrow{
  margin-top:2px;
}
.hero-copy h1{
  margin-top:10px;
}
@media (max-width:820px){
  .hero-content{
    grid-template-columns:1fr;
    row-gap:12px;
  }
  .hero-logo-wrap{
    margin-top:0;
  }
}


/* v50 lower and further-left hero logo placement */
.hero-content{
  position:relative;
  display:block;
  max-width:760px;
}
.hero-copy{
  margin-left:136px;
  min-width:0;
}
.hero-logo-wrap{
  position:absolute;
  left:-26px;
  top:52%;
  transform:translateY(-50%);
  margin:0;
  justify-self:auto;
}
.hero-copy .eyebrow{
  margin-top:0;
}
.hero-copy h1{
  margin-top:10px;
}
@media (max-width:820px){
  .hero-content{
    display:block;
  }
  .hero-copy{
    margin-left:0;
  }
  .hero-logo-wrap{
    position:relative;
    left:auto;
    top:auto;
    transform:none;
    margin:0 0 14px;
  }
}


/* v51 fine-tune hero logo position */
.hero-copy{
  margin-left:142px;
}
.hero-logo-wrap{
  left:-8px;
  top:28%;
  transform:translateY(-50%);
}
@media (max-width:820px){
  .hero-copy{
    margin-left:0;
  }
  .hero-logo-wrap{
    left:auto;
    top:auto;
    transform:none;
  }
}


/* v52 push hero logo to the far left */
.hero-logo-wrap{
  left:calc(-1 * clamp(118px, 11vw, 170px));
  top:28%;
}
@media (max-width:820px){
  .hero-logo-wrap{
    left:auto;
    top:auto;
  }
}


/* v53 move hero logo even further left, slightly lower, and a bit larger */
.hero-logo-wrap{
  left:calc(-1 * clamp(150px, 15vw, 220px));
  top:34%;
  width:clamp(126px,14vw,172px);
}
.hero-icon-logo{
  width:78%;
}
@media (max-width:820px){
  .hero-logo-wrap{
    left:auto;
    top:auto;
    width:clamp(92px,24vw,118px);
  }
  .hero-icon-logo{
    width:74%;
  }
}


/* v54 make hero logo a bit larger */
.hero-logo-wrap{
  width:clamp(138px,16vw,188px);
}
.hero-icon-logo{
  width:82%;
}
@media (max-width:820px){
  .hero-logo-wrap{
    width:clamp(98px,26vw,126px);
  }
  .hero-icon-logo{
    width:76%;
  }
}


/* v55 scale hero logo to sit just slightly smaller than the adjacent text */
.hero-logo-wrap{
  width:clamp(152px,17vw,206px);
}
.hero-icon-logo{
  width:84%;
}
@media (max-width:820px){
  .hero-logo-wrap{
    width:clamp(102px,27vw,132px);
  }
  .hero-icon-logo{
    width:78%;
  }
}


/* v56 make hero logo a bit larger again */
.hero-logo-wrap{
  width:clamp(164px,18vw,220px);
}
.hero-icon-logo{
  width:86%;
}
@media (max-width:820px){
  .hero-logo-wrap{
    width:clamp(106px,28vw,138px);
  }
  .hero-icon-logo{
    width:80%;
  }
}


/* v57 double hero logo size */
.hero-logo-wrap{
  width:clamp(328px,36vw,440px);
}
.hero-icon-logo{
  width:86%;
}
@media (max-width:820px){
  .hero-logo-wrap{
    width:clamp(190px,52vw,260px);
  }
  .hero-icon-logo{
    width:82%;
  }
}


/* v58 move hero logo further left and reduce size by about 20% */
.hero-logo-wrap{
  left:calc(-1 * clamp(205px, 22vw, 300px));
  width:clamp(262px,29vw,352px);
}
.hero-icon-logo{
  width:86%;
}
@media (max-width:820px){
  .hero-logo-wrap{
    left:auto;
    width:clamp(152px,42vw,208px);
  }
  .hero-icon-logo{
    width:82%;
  }
}


/* v59 elegant intro logo fade */
.ce-intro{
  position:fixed;
  inset:0;
  z-index:9999;
  display:grid;
  place-items:center;
  background:
    radial-gradient(circle at 50% 48%, rgba(255,255,255,.96) 0%, rgba(251,247,242,.94) 34%, rgba(234,223,206,.86) 100%);
  animation:ceIntroExit 2.6s ease forwards;
}
.ce-intro__inner{
  text-align:center;
  animation:ceIntroLogo 2.35s ease forwards;
}
.ce-intro__logo{
  width:min(440px,70vw);
  height:auto;
  filter:drop-shadow(0 18px 35px rgba(35,42,42,.16));
}
.ce-intro__wave{
  width:140px;
  height:10px;
  margin:24px auto 0;
  border-radius:999px;
  background:linear-gradient(90deg,var(--sea),var(--sea-dark));
  opacity:.65;
}
.ce-intro.is-hidden{
  display:none;
}
body.has-ce-intro{
  overflow:hidden;
}
@keyframes ceIntroLogo{
  0%{opacity:0; transform:translateY(10px) scale(.96)}
  22%{opacity:1; transform:translateY(0) scale(1)}
  70%{opacity:1; transform:translateY(0) scale(1)}
  100%{opacity:0; transform:translateY(-8px) scale(.985)}
}
@keyframes ceIntroExit{
  0%,72%{opacity:1; visibility:visible}
  100%{opacity:0; visibility:hidden; pointer-events:none}
}
@media (prefers-reduced-motion: reduce){
  .ce-intro,
  .ce-intro__inner{
    animation:none;
  }
  .ce-intro{
    opacity:0;
    visibility:hidden;
    pointer-events:none;
  }
}


/* v60 thinner typography in the top banner */
.site-header,
.navbar,
.nav-links a,
.lang-toggle,
.brand,
.brand-text,
.brand-name,
.brand-tagline{
  font-weight:300;
}
.nav-links a,
.lang-toggle{
  letter-spacing:.06em;
}
.brand-name{
  font-weight:300;
  letter-spacing:.08em;
}
.brand-tagline{
  font-weight:300;
  letter-spacing:.12em;
}

/* v62 top banner font: Segoe Semilight feeling, a little fuller than Light */
.site-header .nav,
.site-header .nav a,
.site-header .lang-button,
.site-header .lang-menu a,
.site-header .menu-toggle{
  font-family:"Segoe UI Semilight","Segoe UI",Raleway,Manrope,ui-sans-serif,system-ui,sans-serif;
  font-weight:350 !important;
  letter-spacing:.095em;
  text-transform:uppercase;
  font-size:13px;
  line-height:1.25;
}
.site-header .lang-button{
  font-weight:350 !important;
  padding:9px 14px;
}
.site-header .lang-menu a{
  font-size:12px;
  letter-spacing:.06em;
  text-transform:none;
}
.site-header .menu-toggle{
  letter-spacing:.12em;
}
@media (max-width:620px){
  .site-header .nav,
  .site-header .nav a,
  .site-header .lang-button,
  .site-header .menu-toggle{
    font-size:12px;
    letter-spacing:.085em;
  }
}
