/*
Theme Name: UMAYA Villa Rentals
Version: 6.0.0
Text Domain: umaya
*/
:root{
  --bg:hsl(40,33%,97%);--fg:hsl(30,10%,15%);--card:hsl(35,30%,94%);
  --muted:hsl(35,18%,92%);--muted-fg:hsl(30,8%,50%);--accent:hsl(30,20%,60%);
  --border:hsl(33,15%,88%);--radius:.75rem;
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'Inter',system-ui,sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth}
body{background:var(--bg);color:var(--fg);font-family:var(--sans);font-weight:400;line-height:1.5;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
h1,h2,h3,h4{font-family:var(--serif);font-weight:400;line-height:1.2;color:var(--fg)}
h1{font-size:clamp(2rem,4.5vw,3.8rem)}
h2{font-size:clamp(1.6rem,3vw,2.8rem)}
h3{font-size:clamp(1.1rem,1.8vw,1.5rem)}
em{font-style:italic;color:var(--accent)}
p{font-size:.95rem;color:var(--muted-fg);line-height:1.85}
.container{width:100%;max-width:1400px;margin:0 auto;padding:0 2rem}
.section{padding:96px 2rem}
.section--card{background:var(--card)}
.section--muted{background:var(--muted)}
.label{font-family:var(--sans);font-size:.62rem;font-weight:600;letter-spacing:.28em;text-transform:uppercase;color:var(--accent);display:block;margin-bottom:.75rem}
.divider{width:40px;height:1px;background:var(--accent);margin:1.2rem 0}
/* BUTTONS */
.btn{display:inline-flex;align-items:center;justify-content:center;padding:13px 30px;font-family:var(--sans);font-size:.72rem;font-weight:500;letter-spacing:.15em;text-transform:uppercase;border-radius:9999px;border:1px solid var(--fg);color:var(--fg);background:transparent;transition:all .3s;cursor:pointer}
.btn:hover{background:var(--fg);color:var(--bg)}
.btn--hero{border-color:rgba(255,255,255,.65);color:#fff;background:rgba(255,255,255,.1);backdrop-filter:blur(6px)}
.btn--hero:hover{background:#fff;color:var(--fg);border-color:#fff}
.btn--dark{background:var(--fg);border-color:var(--fg);color:var(--bg)}
.btn--dark:hover{opacity:.8}
/* HEADER */
#site-header{position:fixed;top:0;left:0;right:0;z-index:1000;padding:22px 40px;display:flex;align-items:center;justify-content:space-between;transition:all .35s ease}
#site-header.scrolled{background:rgba(250,247,242,.96);backdrop-filter:blur(14px);padding:14px 40px;box-shadow:0 1px 24px rgba(0,0,0,.07);border-bottom:1px solid var(--border)}
#header-logo-img{height:56px;width:auto;transition:all .3s}
.header-nav ul{display:flex;gap:30px;align-items:center}
.header-nav a{font-size:.72rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.85);transition:color .2s}
.header-nav a:hover{color:#fff}
#site-header.scrolled .header-nav a{color:var(--fg)}
#site-header.scrolled .header-nav a:hover{color:var(--accent)}
.header-lang-switcher{display:inline-flex;align-items:center;gap:2px}
.header-lang-switcher a{font-size:.68rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.65);padding:0 5px;transition:color .2s}
.header-lang-switcher a:hover,.header-lang-switcher .lang-current{color:#fff;font-weight:700}
#site-header.scrolled .header-lang-switcher a{color:var(--muted-fg)}
#site-header.scrolled .header-lang-switcher .lang-current{color:var(--fg);font-weight:700}
.header-cta{font-size:.7rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;padding:9px 20px;border-radius:9999px;border:1px solid rgba(255,255,255,.55);color:#fff;background:rgba(255,255,255,.08);backdrop-filter:blur(6px);transition:all .3s;white-space:nowrap}
.header-cta:hover{background:#fff;color:var(--fg);border-color:#fff}
#site-header.scrolled .header-cta{border-color:var(--fg);color:var(--fg);background:transparent;backdrop-filter:none}
#site-header.scrolled .header-cta:hover{background:var(--fg);color:var(--bg)}
.menu-toggle{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:5px;padding:4px}
.menu-toggle span{display:block;width:24px;height:1.5px;background:#fff;transition:all .3s}
#site-header.scrolled .menu-toggle span{background:var(--fg)}
/* INNER PAGES */
body:not(.home) #site-header{background:rgba(250,247,242,.96);backdrop-filter:blur(14px);border-bottom:1px solid var(--border)}
body:not(.home) .header-nav a{color:var(--fg)}
body:not(.home) .header-nav a:hover{color:var(--accent)}
body:not(.home) .header-cta{border-color:var(--fg);color:var(--fg);background:transparent;backdrop-filter:none}
body:not(.home) .header-cta:hover{background:var(--fg);color:var(--bg)}
body:not(.home) .menu-toggle span{background:var(--fg)}
body:not(.home) .header-lang-switcher a{color:var(--muted-fg)}
body:not(.home) .header-lang-switcher .lang-current{color:var(--fg);font-weight:700}
/* HERO */
.hero{position:relative;height:100svh;min-height:600px;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center 35%;animation:kenBurns 14s ease-in-out infinite alternate}
@keyframes kenBurns{from{transform:scale(1)}to{transform:scale(1.08)}}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(25,20,15,.18) 0%,rgba(25,20,15,.62) 100%)}
.hero-content{position:relative;z-index:2;max-width:820px;padding:0 2rem;display:flex;flex-direction:column;align-items:center}
.hero-logo{height:220px;width:auto;margin:0 auto 2rem;opacity:0;animation:logoFade 2s ease .5s forwards}
@keyframes logoFade{from{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}
.hero h1{color:#fff;font-weight:300;margin-bottom:1rem;opacity:0;animation:fadeUp 1s ease 2.2s forwards}
.hero-subtitle{font-family:var(--serif);font-size:1.25rem;font-style:italic;color:rgba(255,255,255,.88);margin-bottom:.4rem;opacity:0;animation:fadeUp 1s ease 2.5s forwards}
.hero-tagline{font-size:.65rem;letter-spacing:.3em;text-transform:uppercase;color:rgba(255,255,255,.55);margin-bottom:2.5rem;opacity:0;animation:fadeUp 1s ease 2.7s forwards}
.hero-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;opacity:0;animation:fadeUp 1s ease 2.9s forwards}
.hero-badge{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);font-size:.6rem;letter-spacing:.32em;text-transform:uppercase;color:rgba(255,255,255,.45);z-index:2;white-space:nowrap;opacity:0;animation:fadeUp 1s ease 3.1s forwards}
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
/* SCROLL REVEAL */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
/* INTRO */
.intro{text-align:center;padding:100px 2rem;background:var(--bg)}
.intro h2{margin-bottom:1.5rem}
.intro p{margin:0 auto;max-width:660px;font-size:1rem;line-height:1.9}
/* STANDARDS */
.standards{display:grid;grid-template-columns:1fr 1fr;min-height:560px;background:var(--card)}
.standards-image{overflow:hidden}
.standards-image img{width:100%;height:100%;object-fit:cover;transition:transform 6s ease}
.standards:hover .standards-image img{transform:scale(1.04)}
.standards-text{display:flex;flex-direction:column;justify-content:center;padding:80px}
/* SERVICES */
.services-header{text-align:center;margin-bottom:3rem}
.services-scroll{display:flex;gap:16px;overflow-x:auto;padding:0 2rem 1rem;scrollbar-width:none;-webkit-overflow-scrolling:touch;scroll-snap-type:x mandatory}
.services-scroll::-webkit-scrollbar{display:none}
.service-card{flex:0 0 275px;position:relative;overflow:hidden;border-radius:var(--radius);cursor:pointer;scroll-snap-align:start}
.service-card img{width:100%;height:360px;object-fit:cover;transition:transform .6s;display:block}
.service-card:hover img{transform:scale(1.06)}
.sc-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(20,15,10,.72) 0%,transparent 55%);pointer-events:none}
.sc-cat{position:absolute;top:14px;left:14px;font-size:.58rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.85);background:rgba(0,0,0,.28);padding:3px 10px;border-radius:9999px;backdrop-filter:blur(4px)}
.sc-title{position:absolute;bottom:18px;left:18px;right:18px;font-family:var(--serif);font-size:1.1rem;font-weight:400;color:#fff;line-height:1.3}
.services-cta{text-align:center;margin-top:2.5rem}
.services-full{display:grid;grid-template-columns:repeat(3,1fr);gap:2px}
.sfc{position:relative;overflow:hidden;cursor:pointer;aspect-ratio:3/2}
.sfc img{width:100%;height:100%;object-fit:cover;transition:transform .6s,filter .6s;filter:brightness(.6)}
.sfc:hover img{transform:scale(1.05);filter:brightness(.75)}
.sfc-ov{position:absolute;inset:0;background:linear-gradient(to top,rgba(20,15,10,.8) 0%,transparent 60%)}
.sfc-ct{position:absolute;bottom:0;left:0;right:0;padding:24px}
.sfc-cat{font-size:.58rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);display:block;margin-bottom:.4rem}
.sfc-title{font-family:var(--serif);font-size:1.15rem;color:#fff;margin-bottom:.4rem}
.sfc-desc{font-size:.78rem;color:rgba(255,255,255,.65);line-height:1.6}
/* TEAM */
.team-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;margin-top:4rem}
.team-card{display:flex;flex-direction:column;gap:1.5rem}
.team-card img{width:100%;height:480px;object-fit:cover;object-position:top;border-radius:var(--radius)}
.team-card h3{font-size:1.8rem;margin-bottom:.5rem}
/* PILLARS */
.pillars-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2px}
.pillar{position:relative;overflow:hidden;cursor:pointer;aspect-ratio:4/3}
.pillar img{width:100%;height:100%;object-fit:cover;filter:brightness(.5);transition:filter .6s,transform .6s}
.pillar:hover img{filter:brightness(.65);transform:scale(1.04)}
.pillar-ct{position:absolute;bottom:0;left:0;right:0;padding:30px;background:linear-gradient(to top,rgba(20,15,10,.88),transparent)}
.pillar-ct h3{font-size:1.2rem;color:#fff;margin-bottom:.8rem}
.pillar-ct li{font-size:.74rem;letter-spacing:.06em;color:rgba(255,255,255,.68);margin-bottom:3px}
/* COMING SOON */
.coming-soon{text-align:center;padding:100px 2rem;background:var(--muted);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.coming-soon h2{margin-bottom:1rem}
.coming-soon p{margin:0 auto 2.5rem;max-width:520px}
/* SEO */
.seo-section{padding:80px 2rem;background:var(--card);border-top:1px solid var(--border)}
.seo-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px}
.seo-block h2{font-size:1.35rem;margin-bottom:1rem}
/* CTA BANNER */
.cta-banner{position:relative;padding:140px 2rem;text-align:center;overflow:hidden}
.cta-banner-bg{position:absolute;inset:0;background-size:cover;background-position:center;filter:brightness(.32)}
.cta-banner-content{position:relative;z-index:2;max-width:600px;margin:0 auto}
.cta-banner h2{color:#fff;margin-bottom:1.5rem}
.cta-banner p{color:rgba(255,255,255,.7);margin:0 auto 2.5rem}
/* PAGE HERO */
.page-hero{padding:180px 2rem 80px;text-align:center;background:var(--card);border-bottom:1px solid var(--border)}
.page-hero p{margin:0 auto;max-width:560px}
/* OWNERS */
.owners-intro{display:grid;grid-template-columns:1fr 1fr;gap:80px;padding:100px 40px;align-items:center;background:var(--bg)}
.commission-box{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:40px;margin-top:2.5rem}
.commission-box .big-num{font-family:var(--serif);font-size:5rem;color:hsl(150,10%,30%);line-height:1;margin-bottom:.5rem}
/* CONTACT */
.contact-wrap{display:grid;grid-template-columns:1fr 1fr;gap:80px;padding:120px 40px 100px;max-width:1400px;margin:0 auto}
.contact-detail{display:flex;flex-direction:column;gap:14px;margin:2rem 0}
.contact-detail-item{display:flex;gap:14px;align-items:flex-start;font-size:.88rem;color:var(--muted-fg)}
.cd-label{font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);min-width:70px;padding-top:2px}
.contact-form{display:flex;flex-direction:column;gap:18px}
.form-group{display:flex;flex-direction:column;gap:7px}
.form-group label{font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted-fg)}
.form-group input,.form-group select,.form-group textarea{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:12px 16px;color:var(--fg);font-family:var(--sans);font-size:.9rem;outline:none;transition:border-color .2s;width:100%}
.form-group input:focus,.form-group textarea:focus{border-color:hsl(150,10%,30%)}
.form-group textarea{resize:vertical;min-height:140px}
/* ABOUT */
.about-hero{padding:180px 2rem 100px;text-align:center;background:var(--card)}
.about-story{display:grid;grid-template-columns:1fr 1fr;gap:80px;padding:100px 40px;align-items:center}
.about-story img{width:100%;height:560px;object-fit:cover;object-position:top;border-radius:var(--radius)}
/* FOOTER */
#site-footer{background:var(--fg);padding:64px 40px 28px}
.footer-grid{max-width:1400px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr;gap:60px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.08)}
.footer-logo{height:42px;margin-bottom:1.5rem;filter:brightness(0) invert(1)}
.footer-brand p{font-size:.82rem;color:rgba(255,255,255,.45);max-width:300px;line-height:1.7}
.footer-col h4{font-family:var(--sans);font-size:.6rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.35);margin-bottom:1.2rem}
.footer-col ul{display:flex;flex-direction:column;gap:10px}
.footer-col a{font-size:.82rem;color:rgba(255,255,255,.5);transition:color .2s}
.footer-col a:hover{color:#fff}
.footer-bottom{max-width:1400px;margin:24px auto 0;display:flex;justify-content:space-between;align-items:center}
.footer-bottom p{font-size:.72rem;color:rgba(255,255,255,.22);max-width:none}
/* WHATSAPP */
#whatsapp-btn{position:fixed;bottom:28px;right:24px;z-index:999;width:56px;height:56px;border-radius:9999px;background:#25D366;border:none;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(37,211,102,.4);cursor:pointer;animation:waPulse 2.5s ease-in-out infinite;transition:transform .3s}
#whatsapp-btn:hover{transform:scale(1.1);animation:none}
#whatsapp-btn svg{width:30px;height:30px;fill:#fff}
@keyframes waPulse{0%,100%{box-shadow:0 4px 20px rgba(37,211,102,.4)}50%{box-shadow:0 4px 32px rgba(37,211,102,.7)}}
/* RESPONSIVE */
@media(max-width:1024px){
.standards{grid-template-columns:1fr}
.standards-image{height:400px}
.standards-text{padding:60px 40px}
.pillars-grid{grid-template-columns:1fr}
.team-grid{grid-template-columns:1fr;gap:40px}
.seo-grid{grid-template-columns:1fr;gap:40px}
.owners-intro{grid-template-columns:1fr;padding:60px 1.25rem}
.contact-wrap{grid-template-columns:1fr;gap:50px;padding:120px 1.25rem 60px}
.about-story{grid-template-columns:1fr;padding:60px 1.25rem}
.footer-grid{grid-template-columns:1fr 1fr}
.services-full{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:768px){
#site-header{padding:18px 20px}
#site-header.scrolled{padding:14px 20px}
.header-nav,.header-cta{display:none}
.menu-toggle{display:flex}
.section{padding:60px 1.25rem}
.services-scroll{padding:0 1.25rem 1rem}
.services-full{grid-template-columns:1fr}
.pillars-grid{grid-template-columns:1fr}
.footer-grid{grid-template-columns:1fr;gap:36px}
.footer-bottom{flex-direction:column;gap:8px;text-align:center}
#site-footer{padding:48px 24px 24px}
.page-hero{padding:140px 1.25rem 60px}
.cta-banner{padding:100px 1.25rem}
.hero-logo{height:140px}
.intro{padding:70px 1.25rem}
}
.mobile-nav-open .header-nav{display:flex!important;position:fixed;inset:0;background:var(--bg);flex-direction:column;align-items:center;justify-content:center;gap:32px;z-index:998}
.mobile-nav-open .header-nav a{font-size:1.5rem;letter-spacing:.08em;color:var(--fg)!important}
/* UMAYA HERO — FINAL */
.hero-overlay {
  background: linear-gradient(to bottom, rgba(0,0,0,0.50) 0%, rgba(0,0,0,0.20) 50%, rgba(0,0,0,0.60) 100%) !important;
}
.hero-logo {
  width: 280px !important;
  height: auto !important;
  object-fit: contain !important;
}
.hero h1 {
  font-size: 0.85rem !important;
  font-weight: 300 !important;
  letter-spacing: 0.06em !important;
}

}
.hero-tagline {
  font-size: 11px !important;
  letter-spacing: 0.30em !important;
  text-transform: uppercase !important;
  opacity: 0.65 !important;
}
.hero-badge {
  letter-spacing: 0.32em !important;
  font-size: 10px !important;
  opacity: 0.55 !important;
  text-transform: uppercase !important;
}
.btn {
  border-radius: 2px !important;
}
.hero a[href="#owners"] {
  background: rgba(201,169,110,0.20) !important;
  border: 1px solid #C9A96E !important;
  color: #C9A96E !important;
}
.about-story img {
  max-height: 420px !important;
  width: auto !important;
  max-width: 340px !important;
  object-fit: cover !important;
  border-radius: 4px !important;
}
.villa-gallery {
  position: relative;
  overflow: hidden;
  border-radius: 8px;
  aspect-ratio: 1/1;
  background: #111;
}

.gallery-track {
  display: flex;
  height: 100%;
  transition: transform 0.45s ease;
}

.gallery-track img {
  min-width: 100%;
  width: 100%;
  height: 100%;
  object-fit: cover;
  flex-shrink: 0;
}

.gallery-btn {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background: rgba(0,0,0,0.45);
  color: white;
  border: none;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  font-size: 1rem;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 10;
  transition: background 0.2s;
}

.gallery-btn:hover { background: rgba(0,0,0,0.75); }
.gallery-btn--prev { left: 12px; }
.gallery-btn--next { right: 12px; }
/* ── VILLA GALLERY ── */
.villa-gallery {
  position: relative !important;
  border-radius: 8px !important;
  overflow: hidden !important;
  aspect-ratio: 1 / 1 !important;
  background: #111 !important;
}
.gallery-track {
  display: flex !important;
  width: 100% !important;
  height: 100% !important;
  transition: transform 0.45s ease !important;
}
.gallery-track img {
  min-width: 100% !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  flex-shrink: 0 !important;
  pointer-events: none !important;
}
.gallery-nav {
  position: absolute !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  background: rgba(255,255,255,0.18) !important;
  color: white !important;
  border: 1px solid rgba(255,255,255,0.35) !important;
  width: 38px !important;
  height: 38px !important;
  border-radius: 50% !important;
  font-size: 1rem !important;
  cursor: pointer !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  z-index: 10 !important;
}
.gallery-nav.prev { left: 12px !important; }
.gallery-nav.next { right: 12px !important; }
.gallery-dots {
  position: absolute !important;
  bottom: 10px !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
  display: flex !important;
  gap: 5px !important;
  z-index: 10 !important;
}
.gallery-dot {
  width: 6px !important;
  height: 6px !important;
  border-radius: 50% !important;
  background: rgba(255,255,255,0.5) !important;
  transition: background 0.2s !important;
  cursor: pointer !important;
}
.gallery-dot.active { background: white !important; }
.villa-gallery {
  position: relative !important;
  width: 100% !important;
  height: 500px !important;
  border-radius: 8px !important;
  overflow: hidden !important;
  background: #111 !important;
}
.gallery-track {
  display: flex !important;
  flex-direction: row !important;
  width: 100% !important;
  height: 100% !important;
  transition: transform 0.45s ease !important;
  will-change: transform !important;
}
.gallery-track img {
  flex: 0 0 100% !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block !important;
}
.gallery-nav {
  position: absolute !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  background: rgba(0,0,0,0.5) !important;
  color: white !important;
  border: none !important;
  width: 40px !important;
  height: 40px !important;
  border-radius: 50% !important;
  font-size: 1.1rem !important;
  cursor: pointer !important;
  z-index: 20 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}
.gallery-nav.prev { left: 12px !important; }
.gallery-nav.next { right: 12px !important; }
.gallery-dots {
  position: absolute !important;
  bottom: 12px !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
  display: flex !important;
  gap: 6px !important;
  z-index: 20 !important;
}
.gallery-dot {
  width: 7px !important;
  height: 7px !important;
  border-radius: 50% !important;
  background: rgba(255,255,255,0.5) !important;
  cursor: pointer !important;
}
.gallery-dot.active { background: white !important; }
