/* ══════════════════════════════════════
   VARIABLES & RESET
══════════════════════════════════════ */
:root {
  --cream:  #FAF5EF;
  --blush:  #E8C4B8;
  --rose:   #C4817A;
  --deep:   #2A1F1D;
  --gold:   #B89A6A;
  --mist:   #F0E8E2;
  --text:   #3D2B28;
  --wa:     #25D366;
  --nav-h:  72px;
}
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; font-size:16px; }
body { font-family:'Raleway',sans-serif; background:var(--cream); color:var(--text); overflow-x:hidden; }
img { display:block; max-width:100%; }
a  { text-decoration:none; }
button { cursor:pointer; }

/* ══════════════════════════════════════
   CUSTOM CURSOR (desktop only)
══════════════════════════════════════ */
@media (pointer:fine) {
  * { cursor:none !important; }
  #cursor      { width:10px; height:10px; border-radius:50%; background:var(--rose); position:fixed; top:0; left:0; pointer-events:none; z-index:9999; transition:transform .12s; mix-blend-mode:multiply; }
  #cursor-ring { width:34px; height:34px; border-radius:50%; border:1px solid var(--rose); position:fixed; top:0; left:0; pointer-events:none; z-index:9998; transition:transform .3s; opacity:.5; }
}

/* ══════════════════════════════════════
   NAV
══════════════════════════════════════ */
nav {
  position:fixed; top:0; width:100%; z-index:500;
  height:var(--nav-h);
  display:flex; align-items:center; justify-content:space-between;
  padding:0 clamp(20px,5vw,60px);
  background:rgba(250,245,239,.92);
  backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(180,100,90,.1);
  transition:box-shadow .3s;
}
nav.scrolled { box-shadow:0 4px 32px rgba(42,31,29,.08); }

/* Logo SVG inline */
.nav-logo { display:flex; align-items:center; gap:10px; }
.nav-logo svg { width:38px; height:38px; }
.nav-logo-text {
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(20px,3vw,26px); font-weight:300; letter-spacing:6px;
  color:var(--deep);
}

.nav-links { display:flex; gap:clamp(20px,3vw,40px); list-style:none; }
.nav-links a { font-size:11px; font-weight:400; letter-spacing:3px; text-transform:uppercase; color:var(--deep); opacity:.65; transition:opacity .3s; }
.nav-links a:hover { opacity:1; }
.nav-links li.cta a {
  background:var(--rose); color:white; opacity:1;
  padding:8px 20px; letter-spacing:2px; font-size:10px;
  transition:background .3s;
}
.nav-links li.cta a:hover { background:var(--deep); }

/* Hamburger */
.hamburger { display:none; flex-direction:column; gap:5px; background:none; border:none; padding:6px; }
.hamburger span { display:block; width:24px; height:2px; background:var(--deep); transition:all .3s; }
.hamburger.open span:nth-child(1) { transform:rotate(45deg) translate(5px,5px); }
.hamburger.open span:nth-child(2) { opacity:0; }
.hamburger.open span:nth-child(3) { transform:rotate(-45deg) translate(5px,-5px); }

.mobile-menu {
  display:none; position:fixed; top:var(--nav-h); left:0; right:0;
  background:var(--cream); z-index:490;
  flex-direction:column; padding:24px clamp(20px,5vw,60px);
  border-bottom:1px solid var(--blush);
  box-shadow:0 20px 40px rgba(42,31,29,.1);
}
.mobile-menu.open { display:flex; }
.mobile-menu a { font-size:13px; letter-spacing:3px; text-transform:uppercase; color:var(--deep); padding:14px 0; border-bottom:1px solid rgba(42,31,29,.06); opacity:.7; }
.mobile-menu a:last-child { border-bottom:none; }
.mobile-menu a.wa-mobile {
  color:var(--wa); opacity:1; font-weight:600;
  display:flex; align-items:center; gap:10px; margin-top:8px;
}

/* ══════════════════════════════════════
   WHATSAPP FLOAT BUTTON
══════════════════════════════════════ */
.wa-float {
  position:fixed; bottom:28px; right:28px; z-index:400;
  width:58px; height:58px; border-radius:50%;
  background:var(--wa); color:white;
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 8px 28px rgba(37,211,102,.45);
  transition:transform .3s, box-shadow .3s;
  animation:waPulse 2.5s ease-in-out infinite;
}
.wa-float:hover { transform:scale(1.12); box-shadow:0 12px 36px rgba(37,211,102,.6); }
.wa-float svg { width:30px; height:30px; }
@keyframes waPulse {
  0%,100% { box-shadow:0 8px 28px rgba(37,211,102,.45); }
  50%      { box-shadow:0 8px 40px rgba(37,211,102,.75), 0 0 0 12px rgba(37,211,102,.12); }
}

/* ══════════════════════════════════════
   HERO
══════════════════════════════════════ */
.hero {
  min-height:100vh;
  display:grid; grid-template-columns:1fr 1fr;
  padding-top:var(--nav-h);
}
.hero-left {
  display:flex; flex-direction:column; justify-content:center;
  padding:clamp(48px,8vw,120px) clamp(24px,5vw,60px) clamp(48px,6vw,80px);
}
.hero-tag { font-size:10px; font-weight:500; letter-spacing:5px; text-transform:uppercase; color:var(--gold); margin-bottom:28px; display:flex; align-items:center; gap:14px; }
.hero-tag::before { content:''; display:block; width:36px; height:1px; background:var(--gold); }
.hero-title { font-family:'Cormorant Garamond',serif; font-size:clamp(52px,7vw,108px); font-weight:300; line-height:.92; color:var(--deep); }
.hero-title em { font-style:italic; color:var(--rose); }
.hero-sub { font-size:13px; font-weight:300; letter-spacing:1.5px; line-height:2; color:var(--text); opacity:.7; margin-top:32px; max-width:380px; }
.hero-cta { margin-top:44px; display:flex; flex-wrap:wrap; gap:20px; align-items:center; }
.btn-primary { background:var(--deep); color:var(--cream); padding:15px 40px; font-size:11px; letter-spacing:3px; text-transform:uppercase; border:none; font-family:'Raleway',sans-serif; font-weight:400; transition:background .3s, transform .3s; display:inline-flex; align-items:center; gap:10px; }
.btn-primary:hover { background:var(--rose); transform:translateY(-2px); }
.btn-wa { background:var(--wa); color:white; padding:15px 32px; font-size:11px; letter-spacing:2px; text-transform:uppercase; font-family:'Raleway',sans-serif; font-weight:500; display:inline-flex; align-items:center; gap:10px; transition:background .3s, transform .3s; border:none; }
.btn-wa:hover { background:#1ebe5a; transform:translateY(-2px); }
.btn-wa svg { width:18px; height:18px; }
.btn-ghost { font-size:11px; letter-spacing:3px; text-transform:uppercase; color:var(--text); opacity:.6; border-bottom:1px solid currentColor; padding-bottom:2px; transition:opacity .3s; }
.btn-ghost:hover { opacity:1; }
.hero-right { position:relative; overflow:hidden; }
.hero-bg { position:absolute; inset:0; background:linear-gradient(135deg,#E8C4B8 0%,#D4A090 40%,#B87878 80%,#8B5A5A 100%); }
.hero-bg::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse at 30% 40%,rgba(255,220,200,.4) 0%,transparent 60%); }
.hero-bg::after { content:'✿'; font-size:260px; opacity:.07; position:absolute; bottom:-40px; right:-40px; color:var(--deep); line-height:1; }
.hero-float {
  position:absolute; bottom:clamp(32px,5vw,60px); left:clamp(-20px,-3vw,-40px);
  background:var(--cream); padding:22px 32px;
  box-shadow:0 16px 48px rgba(42,31,29,.15); z-index:3;
}
.hero-float p { font-size:9px; letter-spacing:3px; text-transform:uppercase; opacity:.5; }
.hero-float h3 { font-family:'Cormorant Garamond',serif; font-size:26px; font-weight:300; margin-top:4px; color:var(--deep); }

/* ══════════════════════════════════════
   MARQUEE
══════════════════════════════════════ */
.marquee-wrap { background:var(--deep); padding:16px 0; overflow:hidden; }
.marquee-track { display:flex; animation:marquee 28s linear infinite; white-space:nowrap; }
.marquee-track span { font-size:11px; letter-spacing:4px; text-transform:uppercase; color:var(--blush); padding:0 44px; display:inline-flex; align-items:center; gap:44px; }
.marquee-track span::after { content:'◆'; color:var(--gold); font-size:8px; }
@keyframes marquee { from { transform:translateX(0); } to { transform:translateX(-50%); } }

/* ══════════════════════════════════════
   SECTIONS SHARED
══════════════════════════════════════ */
.section { padding:clamp(64px,10vw,120px) clamp(20px,5vw,60px); }
.section-header { display:flex; justify-content:space-between; align-items:flex-end; margin-bottom:clamp(40px,6vw,80px); flex-wrap:wrap; gap:20px; }
.section-label { font-size:10px; letter-spacing:5px; text-transform:uppercase; color:var(--gold); margin-bottom:14px; }
.section-title { font-family:'Cormorant Garamond',serif; font-size:clamp(36px,4vw,64px); font-weight:300; line-height:1; color:var(--deep); }
.section-title em { font-style:italic; color:var(--rose); }
.section-link { font-size:11px; letter-spacing:3px; text-transform:uppercase; color:var(--text); opacity:.5; border-bottom:1px solid currentColor; padding-bottom:2px; transition:opacity .3s; white-space:nowrap; }
.section-link:hover { opacity:1; }

/* ══════════════════════════════════════
   SERVICIOS
══════════════════════════════════════ */
.services-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:2px; }
.service-card { background:var(--mist); padding:clamp(32px,4vw,52px) clamp(24px,3vw,40px); position:relative; overflow:hidden; transition:background .4s; }
.service-card:hover { background:var(--deep); }
.service-card:hover .service-name,
.service-card:hover .service-desc,
.service-card:hover .service-price { color:var(--cream); }
.service-card:hover .service-num { color:var(--rose); }
.service-num { font-family:'Cormorant Garamond',serif; font-size:64px; font-weight:300; line-height:1; color:rgba(180,100,90,.12); margin-bottom:20px; transition:color .4s; }
.service-icon { font-size:26px; margin-bottom:16px; display:block; }
.service-img { margin-bottom:18px; overflow:hidden; border-radius:20px; }
.service-img img { width:100%; display:block; height:auto; object-fit:cover; }
.service-name { font-family:'Cormorant Garamond',serif; font-size:24px; font-weight:400; color:var(--deep); margin-bottom:10px; transition:color .4s; }
.service-desc { font-size:12px; font-weight:300; letter-spacing:1px; line-height:1.9; color:var(--text); opacity:.7; margin-bottom:24px; transition:color .4s; }
.service-price { font-size:13px; letter-spacing:2px; color:var(--rose); font-weight:500; transition:color .4s; }

/* ══════════════════════════════════════
   PRODUCTOS (JSON)
══════════════════════════════════════ */
.products-bg { background:var(--mist); }
.products-filter { display:flex; flex-wrap:wrap; gap:10px; margin-bottom:40px; }
.filter-btn { background:transparent; border:1px solid rgba(42,31,29,.2); padding:8px 20px; font-size:10px; letter-spacing:3px; text-transform:uppercase; color:var(--deep); font-family:'Raleway',sans-serif; transition:all .3s; }
.filter-btn.active, .filter-btn:hover { background:var(--deep); color:var(--cream); border-color:var(--deep); }
.products-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:clamp(12px,2vw,24px); }
.product-card { position:relative; overflow:hidden; }
.product-img { aspect-ratio:3/4; position:relative; overflow:hidden; }
.product-img-inner { width:100%; height:100%; display:flex; align-items:center; justify-content:center; font-size:clamp(48px,5vw,64px); transition:transform .6s ease; background-position:center; background-size:cover; }
.product-img-inner img { width:100%; height:100%; object-fit:cover; }
.product-card:hover .product-img-inner { transform:scale(1.06); }
.product-badge { position:absolute; top:14px; left:14px; background:var(--rose); color:white; font-size:9px; letter-spacing:2px; text-transform:uppercase; padding:5px 11px; font-weight:500; }
.product-info { padding:18px 0; }
.product-category { font-size:9px; letter-spacing:3px; text-transform:uppercase; color:var(--gold); margin-bottom:7px; }
.product-name { font-family:'Cormorant Garamond',serif; font-size:19px; font-weight:400; color:var(--deep); margin-bottom:10px; }
.product-desc { font-size:11px; color:var(--text); opacity:.6; line-height:1.6; margin-bottom:12px; }
.product-price-row { display:flex; justify-content:space-between; align-items:center; }
.product-price { font-size:14px; font-weight:500; letter-spacing:1px; color:var(--rose); }
.product-wa { background:var(--wa); color:white; border:none; padding:9px 16px; font-size:10px; letter-spacing:1.5px; font-family:'Raleway',sans-serif; font-weight:600; display:flex; align-items:center; gap:6px; transition:all .3s; }
.product-wa:hover { background:#1ebe5a; transform:translateY(-1px); }
.product-wa svg { width:14px; height:14px; }

/* ══════════════════════════════════════
   ACCESORIOS
══════════════════════════════════════ */
.acc-grid { display:grid; grid-template-columns:1.5fr 1fr 1fr; grid-template-rows:auto auto; gap:16px; margin-top:60px; }
.acc-card { padding:clamp(28px,4vw,48px); position:relative; overflow:hidden; display:flex; flex-direction:column; justify-content:flex-end; min-height:clamp(200px,25vw,280px); transition:transform .4s; }
.acc-card:hover { transform:translateY(-4px); }
.acc-card.large { grid-row:span 2; min-height:clamp(360px,45vw,580px); }
.acc-card-1 { background:linear-gradient(135deg,#2A1F1D,#5C3A2E); }
.acc-card-2 { background:linear-gradient(135deg,#E8C4B8,#C4817A); }
.acc-card-3 { background:linear-gradient(135deg,#B89A6A,#8A7050); }
.acc-card-4 { background:linear-gradient(135deg,#C4817A,#8B5A5A); }
.acc-card-5 { background:linear-gradient(135deg,#F0E8E2,#E8C4B8); }
.acc-emoji { position:absolute; top:28px; right:28px; font-size:clamp(32px,4vw,48px); opacity:.4; }
.acc-tag { font-size:9px; letter-spacing:3px; text-transform:uppercase; color:rgba(255,255,255,.55); margin-bottom:6px; }
.acc-name { font-family:'Cormorant Garamond',serif; font-size:clamp(20px,2.5vw,28px); font-weight:300; color:white; line-height:1.2; }
.acc-card-5 .acc-name { color:var(--deep); }
.acc-card-5 .acc-tag { color:var(--text); opacity:.6; }

/* ══════════════════════════════════════
   ABOUT
══════════════════════════════════════ */
.about-section { padding:clamp(64px,10vw,120px) clamp(20px,5vw,60px); display:grid; grid-template-columns:1fr 1fr; gap:clamp(40px,7vw,100px); align-items:center; }
.about-img { aspect-ratio:4/5; background:linear-gradient(160deg,#E8C4B8 0%,#B87878 50%,#2A1F1D 100%); position:relative; display:flex; align-items:center; justify-content:center; font-size:clamp(60px,8vw,100px); }
.about-img::after { content:''; position:absolute; top:20px; left:20px; right:-20px; bottom:-20px; border:1px solid var(--blush); z-index:-1; }
.about-stats { display:grid; grid-template-columns:1fr 1fr; gap:28px; margin-top:48px; }
.stat-num { font-family:'Cormorant Garamond',serif; font-size:clamp(36px,4vw,52px); font-weight:300; color:var(--rose); line-height:1; }
.stat-label { font-size:10px; letter-spacing:3px; text-transform:uppercase; opacity:.6; margin-top:4px; }

/* ══════════════════════════════════════
   TESTIMONIOS
══════════════════════════════════════ */
.testimonials { background:var(--deep); padding:clamp(64px,10vw,120px) clamp(20px,5vw,60px); }
.testimonials .section-title { color:var(--cream); }
.testi-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(20px,3vw,40px); margin-top:clamp(40px,6vw,72px); }
.testi-card { padding:clamp(24px,3vw,44px); border:1px solid rgba(255,255,255,.08); }
.testi-stars { font-size:13px; letter-spacing:4px; color:var(--gold); margin-bottom:20px; }
.testi-text { font-family:'Cormorant Garamond',serif; font-size:clamp(17px,2vw,20px); font-weight:300; font-style:italic; color:rgba(250,245,239,.85); line-height:1.6; margin-bottom:28px; }
.testi-author { display:flex; align-items:center; gap:14px; }
.testi-avatar { width:42px; height:42px; border-radius:50%; background:var(--rose); display:flex; align-items:center; justify-content:center; font-size:17px; color:white; font-weight:600; flex-shrink:0; }
.testi-name { font-size:12px; letter-spacing:2px; text-transform:uppercase; color:var(--cream); font-weight:500; }
.testi-sub { font-size:11px; color:rgba(255,255,255,.4); margin-top:2px; }

/* ══════════════════════════════════════
   RESERVAS
══════════════════════════════════════ */
.booking-section { padding:clamp(64px,10vw,120px) clamp(20px,5vw,60px); display:grid; grid-template-columns:1fr 1fr; gap:clamp(40px,7vw,100px); align-items:start; }
.booking-form { display:flex; flex-direction:column; gap:16px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.form-group { display:flex; flex-direction:column; gap:8px; }
.form-group label { font-size:10px; letter-spacing:3px; text-transform:uppercase; opacity:.6; }
.form-group input, .form-group select, .form-group textarea { border:none; border-bottom:1px solid rgba(42,31,29,.2); padding:13px 0; background:transparent; font-family:'Raleway',sans-serif; font-size:14px; color:var(--deep); outline:none; transition:border-color .3s; resize:none; }
.form-group input:focus, .form-group select:focus, .form-group textarea:focus { border-bottom-color:var(--rose); }
.btn-book { margin-top:16px; background:var(--rose); color:white; border:none; padding:17px 48px; font-size:11px; letter-spacing:3px; text-transform:uppercase; font-family:'Raleway',sans-serif; font-weight:500; align-self:flex-start; transition:background .3s, transform .3s; }
.btn-book:hover { background:var(--deep); transform:translateY(-2px); }
.contact-info { display:flex; flex-direction:column; gap:24px; margin-top:40px; }
.contact-row { display:flex; align-items:flex-start; gap:16px; }
.contact-icon { font-size:20px; flex-shrink:0; margin-top:2px; }
.contact-label { font-size:10px; letter-spacing:3px; text-transform:uppercase; opacity:.5; margin-bottom:3px; }
.contact-val { font-size:14px; }

/* ══════════════════════════════════════
   FOOTER
══════════════════════════════════════ */
footer { background:var(--deep); padding:clamp(48px,8vw,80px) clamp(20px,5vw,60px) clamp(24px,4vw,40px); }
.footer-top { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:clamp(24px,4vw,60px); padding-bottom:clamp(40px,6vw,60px); border-bottom:1px solid rgba(255,255,255,.08); }
.footer-logo-wrap { display:flex; align-items:center; gap:10px; margin-bottom:18px; }
.footer-logo-wrap svg { width:40px; height:40px; }
.footer-logo-text { font-family:'Cormorant Garamond',serif; font-size:clamp(22px,3vw,30px); font-weight:300; letter-spacing:7px; color:var(--cream); }
.footer-desc { font-size:12px; line-height:2; color:rgba(255,255,255,.4); max-width:280px; }
.footer-socials { display:flex; gap:12px; margin-top:28px; flex-wrap:wrap; }
.social-btn { width:40px; height:40px; border:1px solid rgba(255,255,255,.15); display:flex; align-items:center; justify-content:center; color:var(--cream); transition:all .3s; }
.social-btn:hover { background:var(--rose); border-color:var(--rose); }
.social-btn svg { width:18px; height:18px; }
.footer-col h4 { font-size:10px; letter-spacing:4px; text-transform:uppercase; color:var(--gold); margin-bottom:22px; }
.footer-col ul { list-style:none; display:flex; flex-direction:column; gap:12px; }
.footer-col ul a { font-size:13px; color:rgba(255,255,255,.5); transition:color .3s; }
.footer-col ul a:hover { color:var(--cream); }
.footer-bottom { padding-top:28px; display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:12px; }
.footer-copy { font-size:11px; color:rgba(255,255,255,.3); letter-spacing:1px; }

/* ══════════════════════════════════════
   SCROLL ANIMATIONS
══════════════════════════════════════ */
.fade-up { opacity:0; transform:translateY(36px); transition:opacity .75s ease, transform .75s ease; }
.fade-up.visible { opacity:1; transform:translateY(0); }

/* ══════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════ */
@media (max-width:1024px) {
  .services-grid { grid-template-columns:repeat(2,1fr); }
  .products-grid  { grid-template-columns:repeat(3,1fr); }
  .footer-top     { grid-template-columns:1fr 1fr; }
  .acc-grid       { grid-template-columns:1fr 1fr; }
  .acc-card.large { grid-row:span 1; }
}

@media (max-width:768px) {
  :root { --nav-h:64px; }
  .nav-links { display:none; }
  .hamburger { display:flex; }

  .hero { grid-template-columns:1fr; }
  .hero-right { display:none; }

  .services-grid  { grid-template-columns:1fr; }
  .products-grid  { grid-template-columns:repeat(2,1fr); }
  .testi-grid     { grid-template-columns:1fr; }
  .form-row       { grid-template-columns:1fr; }
  .about-section  { grid-template-columns:1fr; }
  .booking-section{ grid-template-columns:1fr; }
  .acc-grid       { grid-template-columns:1fr; }
  .acc-card.large { min-height:280px; }
  .footer-top     { grid-template-columns:1fr; }
}

@media (max-width:480px) {
  .products-grid { grid-template-columns:1fr; max-width:320px; margin:0 auto; }
  .hero-cta      { flex-direction:column; align-items:flex-start; }
}
