/* ============================================
   HANNA RESIDENCES II — Réplica visual Sandbank Villas
   Fuentes, colores, tipografía y layout extraídos pixel-perfect
   ============================================ */

/* FONTS — ivypresto-display (Typekit) + Muli (Google) */
@font-face{font-family:'ivypresto-display';src:url('fonts/ivypresto-light.woff2') format('woff2');font-weight:300;font-style:normal;font-display:swap}
@font-face{font-family:'ivypresto-display';src:url('fonts/ivypresto-bold.woff2') format('woff2');font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:'ivypresto-display';src:url('fonts/ivypresto-light-italic.woff2') format('woff2');font-weight:300;font-style:italic;font-display:swap}
@font-face{font-family:'ivypresto-display';src:url('fonts/ivypresto-bold-italic.woff2') format('woff2');font-weight:700;font-style:italic;font-display:swap}

@import url('https://fonts.googleapis.com/css2?family=Muli:ital,wght@0,300;0,400;0,600;1,300;1,400&display=swap');

/* RESET */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

/* VARIABLES — Exact Sandbank palette */
:root{
  --sand:#E7DCC6;
  --off-white:#FFF DFA;
  --brown:#9E775E;
  --brown-hover:#7D5D48;
  --text:#303030;
  --text-muted:#5A5550;
  --navy:#061C2D;
  --steel:#93B0C0;
  --serif:'ivypresto-display',Georgia,'Times New Roman',serif;
  --sans:'Muli',Helvetica,Arial,sans-serif;
}

html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--sans);font-weight:300;font-size:15.5px;line-height:23px;color:var(--text);background:var(--sand);overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit}

/* CONTAINER — matches Squarespace content-width--wide */
.container{max-width:1500px;margin:0 auto;padding:0 clamp(24px,4vw,80px)}

/* ==================== HEADER ==================== */
.header{position:fixed;top:0;left:0;right:0;z-index:1000;padding:22px clamp(24px,4vw,60px);display:flex;justify-content:space-between;align-items:center;transition:all .4s ease}
.header.scrolled{background:rgba(255,253,250,.95);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:0 1px 0 rgba(0,0,0,.06)}

.header-brand{font-family:var(--serif);font-size:1.4rem;font-weight:300;color:var(--text);letter-spacing:.02em}
.header-brand img{height:32px;width:auto}

.header-nav{display:flex;align-items:center;gap:36px}
.header-nav a{font-family:var(--serif);font-size:15.5px;font-weight:300;color:var(--text);transition:opacity .3s}
.header-nav a:hover{opacity:.55}

.header-cta{font-family:var(--sans);font-size:14.5px;font-weight:600;letter-spacing:.09em;text-transform:uppercase;color:var(--brown);border:1.5px solid var(--brown);border-radius:300px;padding:10px 28px;transition:all .3s}
.header-cta:hover{background:var(--brown);color:#fff}

.hamburger{display:none;background:none;border:none;cursor:pointer;padding:8px}
.hamburger span{display:block;width:22px;height:1.5px;background:var(--text);margin:5px 0;transition:all .3s}

/* MOBILE MENU */
.mobile-menu{display:none;position:fixed;inset:0;background:var(--sand);z-index:1001;flex-direction:column;align-items:center;justify-content:center;gap:28px}
.mobile-menu.open{display:flex}
.mobile-menu a{font-family:var(--serif);font-size:2rem;font-weight:300;color:var(--text)}
.mobile-close{position:absolute;top:28px;right:28px;background:none;border:none;font-size:2.2rem;cursor:pointer;color:var(--text);font-weight:300}

/* ==================== HERO ==================== */
.hero{position:relative;min-height:92vh;display:flex;align-items:center;justify-content:center;overflow:hidden}
.hero-media{position:absolute;inset:0}
.hero-media video,.hero-media img{width:100%;height:100%;object-fit:cover}
.hero-overlay{position:absolute;inset:0;background:rgba(0,0,0,.35)}

.hero-content{position:relative;z-index:2;text-align:center;max-width:56%;padding:0 24px}
.hero-eyebrow{font-family:var(--sans);font-size:14.5px;font-weight:600;text-transform:uppercase;letter-spacing:.12em;color:rgba(255,255,255,.75);margin-bottom:12px}
.hero h1{font-family:var(--serif);font-size:clamp(2.2rem,4.2vw,3.5rem);font-weight:300;line-height:1.25;color:#fff;margin-bottom:4px}
.hero h2{font-family:var(--serif);font-size:clamp(2.8rem,5.5vw,4.5rem);font-weight:300;font-style:italic;line-height:1.1;color:#fff;margin-bottom:8px}
.hero h4{font-family:var(--sans);font-size:14.5px;font-weight:600;text-transform:uppercase;letter-spacing:.12em;color:rgba(255,255,255,.7);margin-bottom:0}
.hero p{font-family:var(--sans);font-size:15.5px;font-weight:300;line-height:23px;color:rgba(255,255,255,.88);max-width:560px;margin:24px auto 36px}
.hero-btn{font-family:var(--serif);font-size:15.5px;font-weight:300;color:#fff;background:var(--brown);border:none;border-radius:0;padding:16px 44px;cursor:pointer;transition:background .3s;letter-spacing:.02em}
.hero-btn:hover{background:var(--brown-hover)}

/* ==================== SECTION COMMON ==================== */
.section{padding:100px 0}
.section-white{background:var(--off-white)}
.section-sand{background:var(--sand)}
.section-navy{background:var(--navy);color:#fff}

.eyebrow{font-family:var(--sans);font-size:14.5px;font-weight:600;text-transform:uppercase;letter-spacing:.12em;color:var(--text);margin-bottom:16px;display:block}
.section-white .eyebrow{color:var(--text)}
.title{font-family:var(--serif);font-size:clamp(2rem,4vw,3.5rem);font-weight:300;line-height:1.25;margin-bottom:0}
.title em{font-style:italic}
.body-text{font-family:var(--sans);font-size:15.5px;font-weight:300;line-height:23px;color:var(--text-muted);max-width:520px}
.section-link{font-family:var(--sans);font-size:14.5px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--brown);border-bottom:1px solid var(--brown);padding-bottom:1px;display:inline-block;margin-top:24px;transition:opacity .3s}
.section-link:hover{opacity:.6}
.text-center{text-align:center}
.text-center .body-text{margin-left:auto;margin-right:auto}

/* ==================== SPLIT SECTIONS ==================== */
/* Exact Sandbank layout: text left + image right, then alternate */
.split{display:grid;grid-template-columns:1fr 1fr;gap:0;align-items:stretch;min-height:560px}
.split-text{display:flex;flex-direction:column;justify-content:center;padding:clamp(48px,8vw,120px) clamp(40px,6vw,100px);max-width:600px}
.split-text.full-center{max-width:none;align-items:center;text-align:center}
.split-image{position:relative;overflow:hidden}
.split-image img{width:100%;height:100%;object-fit:cover}

/* Alternate: image left, text right */
.split-reverse .split-text{order:2}
.split-reverse .split-image{order:1}

/* ==================== GALLERY ==================== */
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:4px;margin-top:48px}
.gallery-item{position:relative;overflow:hidden;cursor:pointer;aspect-ratio:4/3}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.25,.46,.45,.94)}
.gallery-item:hover img{transform:scale(1.04)}

/* ==================== AMENITIES (resort cards) ==================== */
.resort-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px 60px;margin-top:48px}
.resort-card{display:flex;flex-direction:column}
.resort-card img{width:100%;aspect-ratio:16/10;object-fit:cover;margin-bottom:20px}
.resort-card strong{font-family:var(--sans);font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.1em;margin-bottom:4px;display:block}
.resort-card p{font-family:var(--sans);font-size:15.5px;font-weight:300;line-height:23px;color:var(--text-muted)}

/* ==================== PLAN DE PAGO (timeline) ==================== */
.timeline{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin:56px 0;position:relative}
.timeline::after{content:'';position:absolute;top:28px;left:12.5%;right:12.5%;height:1px;background:rgba(255,255,255,.15)}
.t-step{text-align:center;padding:0 16px;position:relative}
.t-step .t-num{width:56px;height:56px;border-radius:50%;background:var(--brown);color:#fff;font-family:var(--serif);font-size:1.1rem;display:flex;align-items:center;justify-content:center;margin:0 auto 24px}
.t-step .t-amount{font-family:var(--serif);font-size:clamp(1.6rem,3vw,2.2rem);font-weight:300;color:#fff;margin-bottom:8px}
.t-step .t-label{font-family:var(--sans);font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:rgba(255,255,255,.5)}

/* ==================== FAQ ==================== */
.faq-list{max-width:720px;margin:0 auto;text-align:left}
.faq-item{border-bottom:1px solid rgba(48,48,48,.12)}
.faq-q{font-family:var(--serif);font-size:1.15rem;font-weight:300;padding:28px 0;cursor:pointer;display:flex;justify-content:space-between;align-items:center;transition:color .3s;line-height:1.4}
.faq-q:hover{color:var(--brown)}
.faq-icon{font-size:1.5rem;font-weight:300;transition:transform .3s;line-height:1}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease}
.faq-item.active .faq-a{max-height:300px}
.faq-item.active .faq-icon{transform:rotate(45deg)}
.faq-a p{padding:0 0 28px;font-family:var(--sans);font-size:15.5px;font-weight:300;line-height:23px;color:var(--text-muted)}

/* ==================== CTA BAR ==================== */
.cta-bar{background:var(--navy);padding:80px 0;text-align:center}
.cta-bar h2{font-family:var(--serif);font-size:clamp(1.5rem,3vw,2.5rem);font-weight:300;color:#fff;margin-bottom:36px;line-height:1.3}
.cta-bar h2 em{font-style:italic}
.cta-btns{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.cta-btn{font-family:var(--serif);font-size:15.5px;font-weight:300;border-radius:0;padding:15px 40px;cursor:pointer;transition:all .3s;letter-spacing:.02em}
.cta-primary{background:var(--brown);color:#fff;border:none}
.cta-primary:hover{background:var(--brown-hover)}
.cta-secondary{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.25)}
.cta-secondary:hover{border-color:#fff}

/* ==================== CONTACT ==================== */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;margin-top:56px;align-items:start}
.contact-form{display:flex;flex-direction:column;gap:28px}
.form-group label{font-family:var(--sans);font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin-bottom:8px;display:block}
.form-group input,.form-group textarea,.form-group select{width:100%;background:transparent;border:none;border-bottom:1px solid rgba(48,48,48,.18);padding:10px 0;font-family:var(--serif);font-size:16px;font-weight:300;color:var(--text);outline:none;transition:border-color .3s}
.form-group input:focus,.form-group textarea:focus{border-color:var(--brown)}
.form-group textarea{min-height:80px;resize:vertical}
.contact-direct{display:flex;flex-direction:column;gap:0;justify-content:center}
.contact-item{display:flex;align-items:center;gap:20px;padding:24px 0;border-bottom:1px solid rgba(48,48,48,.08);transition:opacity .3s}
.contact-item:hover{opacity:.6}
.contact-icon{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0}
.contact-icon.wa{background:rgba(37,211,102,.08)}
.contact-icon.em{background:rgba(158,119,94,.08)}
.contact-icon.wb{background:rgba(48,48,48,.04)}
.contact-item h4{font-family:var(--serif);font-size:1rem;font-weight:300;margin-bottom:2px}
.contact-item p{font-family:var(--sans);font-size:14px;font-weight:300;color:var(--text-muted)}

/* ==================== FOOTER ==================== */
.footer{background:var(--navy);padding:64px 0 28px;color:rgba(255,255,255,.6)}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px}
.footer h5{font-family:var(--sans);font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.12em;color:rgba(255,255,255,.9);margin-bottom:16px}
.footer-brand{font-family:var(--serif);font-size:1.3rem;font-weight:300;color:rgba(255,255,255,.9);margin-bottom:8px}
.footer p{font-family:var(--sans);font-size:14px;font-weight:300;line-height:1.7}
.footer ul{list-style:none}
.footer ul li{margin-bottom:10px}
.footer ul li a{font-family:var(--sans);font-size:14px;font-weight:300;transition:color .3s}
.footer ul li a:hover{color:rgba(255,255,255,.9)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding-top:24px;display:flex;justify-content:space-between;font-size:12px;font-weight:300}

/* ==================== WHATSAPP FLOAT ==================== */
.wa-float{position:fixed;bottom:28px;right:28px;z-index:999;width:56px;height:56px;background:#25D366;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(0,0,0,.18);transition:transform .3s}
.wa-float:hover{transform:scale(1.08)}
.wa-float svg{width:28px;height:28px;fill:#fff}

/* ==================== LIGHTBOX ==================== */
.lightbox{display:none;position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:2000;align-items:center;justify-content:center}
.lightbox.open{display:flex}
.lightbox img{max-width:90vw;max-height:85vh;object-fit:contain}
.lb-btn{position:absolute;background:none;border:none;color:#fff;font-size:2.5rem;cursor:pointer;padding:20px;opacity:.6;transition:opacity .3s}
.lb-btn:hover{opacity:1}
.lb-close{top:12px;right:12px}
.lb-prev{left:12px;top:50%;transform:translateY(-50%)}
.lb-next{right:12px;top:50%;transform:translateY(-50%)}
.lb-counter{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);color:rgba(255,255,255,.5);font-size:14px}

/* ==================== ANIMATIONS ==================== */
.fade-in{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease}
.fade-in.visible{opacity:1;transform:translateY(0)}

/* ==================== RESPONSIVE ==================== */
@media(max-width:1024px){
  .split{grid-template-columns:1fr;min-height:auto}
  .split-text{padding:48px clamp(24px,4vw,48px)}
  .split-reverse .split-text{order:1}
  .split-reverse .split-image{order:2}
  .gallery-grid{grid-template-columns:repeat(3,1fr)}
  .hero-content{max-width:80%}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  .header-nav{display:none}
  .hamburger{display:block}
  .hero{min-height:85vh}
  .hero-content{max-width:92%}
  .hero h1{font-size:1.6rem}
  .hero h2{font-size:2rem}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .resort-grid{grid-template-columns:1fr}
  .timeline{grid-template-columns:1fr 1fr;gap:40px}
  .timeline::after{display:none}
  .contact-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;gap:8px;text-align:center}
  .section{padding:64px 0}
  .cta-bar{padding:56px 0}
}
