@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,700;1,400&family=Cormorant+Garamond:ital,wght@0,300;0,400;1,300&family=Jost:wght@300;400;500&display=swap');

:root {
  /* Her Instagram palette — purples, sunsets, cosmic */
  --terracotta: #C4714A;
  --terracotta-light: #E8946A;
  --terracotta-pale: #FAE8E0;

  /* Signature purples & mauves */
  --purple: #7B5EA7;
  --purple-light: #A584CC;
  --purple-pale: #EDE6F5;
  --mauve: #B8769A;
  --mauve-light: #D4A0BD;
  --mauve-pale: #F5E8F0;

  /* Sunset pinks & corals */
  --sunset: #E8826A;
  --rose: #D4698C;
  --peach: #F0B89A;

  /* Dusty sky blues */
  --sky: #7A9BBF;
  --sky-pale: #E4EDF5;

  /* Sage kept for accents */
  --sage: #7A9E7E;
  --sage-light: #A8C5AC;
  --sage-pale: #E8F0E9;

  /* Backgrounds — slightly warmer/deeper */
  --warm-cream: #FAF7F5;
  --warm-brown: #2E1F3E;       /* deep purple-brown instead of coffee */
  --warm-brown-light: #5C3D6E;
  --gold: #C9A96E;
  --gold-light: #E8C98A;

  /* Text */
  --text-dark: #1A1028;
  --text-mid: #5C4070;
  --text-light: #9080A8;

  /* Gradients used throughout */
  --grad-sunset: linear-gradient(135deg, #E8826A 0%, #C4619A 50%, #7B5EA7 100%);
  --grad-dusk: linear-gradient(135deg, #7B5EA7 0%, #4A3A7A 50%, #1A1028 100%);
  --grad-cosmic: linear-gradient(135deg, #2E1F3E 0%, #4A2D5A 50%, #1A1028 100%);
  --grad-aurora: linear-gradient(135deg, #7A9BBF 0%, #B8769A 50%, #E8826A 100%);
}

* { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body { font-family:'Jost',sans-serif; background:var(--warm-cream); color:var(--text-dark); overflow-x:hidden; }

/* ── NAV ── */
nav {
  position:fixed; top:0; left:0; right:0; z-index:100;
  padding:1rem 3rem;
  display:flex; justify-content:space-between; align-items:center;
  backdrop-filter:blur(12px);
  background:rgba(250,247,245,0.95);
  border-bottom:1px solid rgba(196,113,74,0.15);
}
.logo { font-family:'Playfair Display',serif; font-size:1.4rem; color:var(--warm-brown); letter-spacing:0.05em; text-decoration:none; }
.logo span { color:var(--terracotta); font-style:italic; }
.nav-links { display:flex; gap:1.5rem; list-style:none; align-items:center; margin-left:2.5rem; }
.nav-links a { text-decoration:none; color:var(--text-mid); font-size:0.75rem; font-weight:400; letter-spacing:0.08em; text-transform:uppercase; transition:all 0.2s; position:relative; white-space:nowrap; }
.nav-links a:hover { color:var(--purple); }
.nav-links a.active { color:var(--purple); font-weight:600; border-bottom:2px solid var(--purple); padding-bottom:2px; }
.nav-book { background:var(--terracotta) !important; color:white !important; padding:0.45rem 1.1rem; border-radius:2px; white-space:nowrap; }
.nav-book:hover { background:var(--warm-brown) !important; }
.lang-toggle { display:flex; gap:0.4rem; }
.nav-whatsapp-btn { display:flex; align-items:center; gap:0.4rem; padding:0.38rem 0.85rem 0.38rem 0.65rem; background:#25D366; color:white; border-radius:20px; text-decoration:none; font-size:0.72rem; font-weight:600; letter-spacing:0.05em; transition:all 0.25s; box-shadow:0 2px 10px rgba(37,211,102,0.35); white-space:nowrap; }
.nav-whatsapp-btn:hover { background:#1ebe5c; transform:translateY(-1px); box-shadow:0 4px 16px rgba(37,211,102,0.45); }
.lang-btn { background:none; border:1px solid var(--terracotta-light); color:var(--terracotta); padding:0.22rem 0.55rem; border-radius:20px; cursor:pointer; font-family:'Jost',sans-serif; font-size:0.7rem; letter-spacing:0.1em; transition:all 0.2s; }
.lang-btn.active, .lang-btn:hover { background:var(--terracotta); color:white; }
.hamburger { display:none; background:none; border:none; cursor:pointer; flex-direction:column; gap:5px; padding:4px; }
.hamburger span { display:block; width:22px; height:2px; background:var(--warm-brown); transition:all 0.3s; }
.mobile-menu { display:none; position:fixed; top:0; left:0; right:0; bottom:0; background:var(--warm-cream); z-index:101; overflow-y:scroll; -webkit-overflow-scrolling:touch; }
.mobile-menu.open { display:block; }
.mobile-close { position:sticky; top:0; display:block; width:100%; text-align:right; background:var(--warm-cream); border:none; font-size:1.5rem; cursor:pointer; color:var(--text-mid); padding:1rem 1.5rem 0.5rem; z-index:1; }
.mobile-menu a { font-family:'Playfair Display',serif; font-size:1.4rem; color:var(--warm-brown); text-decoration:none; text-align:center; padding:0.6rem 2rem; display:block; }
.mobile-menu a:hover { color:var(--purple); }
.mobile-menu .lang-toggle { display:flex; justify-content:center; margin:1rem 0 2rem; }

/* ── SHARED COMPONENTS ── */
.section-label { font-size:0.68rem; letter-spacing:0.3em; text-transform:uppercase; color:var(--purple); margin-bottom:0.8rem; display:flex; align-items:center; gap:0.8rem; }
.section-label::after { content:''; display:inline-block; width:2rem; height:1px; background:var(--purple-light); }
.section-label.center { justify-content:center; }
.section-label.center::before { content:''; display:inline-block; width:2rem; height:1px; background:var(--purple-light); }
h1 { font-family:'Playfair Display',serif; font-size:clamp(2.8rem,5vw,5rem); line-height:1.05; color:var(--warm-brown); }
h1 em { font-style:italic; color:var(--terracotta); display:block; }
h2 { font-family:'Playfair Display',serif; font-size:clamp(1.8rem,3vw,2.8rem); color:var(--warm-brown); line-height:1.2; margin-bottom:1.2rem; }
h2 em { font-style:italic; color:var(--rose); }
h3 { font-family:'Playfair Display',serif; font-size:1.3rem; color:var(--warm-brown); margin-bottom:0.6rem; }
.serif { font-family:'Cormorant Garamond',serif; font-size:1.1rem; font-weight:300; line-height:1.8; color:var(--text-mid); }
.btn-primary { background:var(--terracotta); color:white; padding:0.85rem 2rem; border:none; border-radius:2px; font-family:'Jost',sans-serif; font-size:0.78rem; letter-spacing:0.15em; text-transform:uppercase; cursor:pointer; text-decoration:none; display:inline-block; transition:all 0.3s; }
.btn-primary:hover { background:var(--warm-brown); transform:translateY(-2px); box-shadow:0 8px 25px rgba(92,61,46,0.2); }
.btn-outline { background:transparent; color:var(--warm-brown); padding:0.85rem 2rem; border:1px solid var(--purple-light); border-radius:2px; font-family:'Jost',sans-serif; font-size:0.78rem; letter-spacing:0.15em; text-transform:uppercase; cursor:pointer; text-decoration:none; display:inline-block; transition:all 0.3s; }
.btn-outline:hover { border-color:var(--purple); color:var(--purple); }
.btn-gold { background:var(--gold); color:var(--warm-brown); padding:0.85rem 2rem; border:none; border-radius:2px; font-family:'Jost',sans-serif; font-size:0.78rem; letter-spacing:0.15em; text-transform:uppercase; cursor:pointer; text-decoration:none; display:inline-block; transition:all 0.3s; font-weight:500; }
.btn-gold:hover { background:var(--gold-light); transform:translateY(-2px); }
.page-hero { padding:9rem 6rem 5rem; background:var(--warm-cream); position:relative; overflow:hidden; }
.page-hero::before { content:''; position:absolute; top:-100px; right:-100px; width:500px; height:500px; background:radial-gradient(circle, var(--terracotta-pale) 0%, transparent 70%); border-radius:50%; }
.badge { background:var(--purple-pale); color:var(--purple); border:1px solid var(--purple-light); padding:0.35rem 0.9rem; border-radius:20px; font-size:0.72rem; letter-spacing:0.1em; }

/* ── FOOTER ── */
footer { background:var(--grad-dusk); background:linear-gradient(160deg, #1A1028 0%, #2E1F3E 50%, #1A1028 100%); padding:4rem 6rem 2rem; }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:3rem; margin-bottom:3rem; }
.footer-brand .logo { color:var(--warm-cream); display:block; margin-bottom:1rem; }
.footer-brand p { font-size:0.82rem; color:rgba(250,246,240,0.45); line-height:1.6; max-width:220px; }
.footer-col h4 { font-family:'Jost',sans-serif; font-size:0.68rem; letter-spacing:0.2em; text-transform:uppercase; color:var(--gold); margin-bottom:1.2rem; }
.footer-col a { display:block; color:rgba(250,246,240,0.5); text-decoration:none; font-size:0.8rem; margin-bottom:1.1rem; transition:color 0.2s; }
.footer-col a:hover { color:var(--terracotta-light); }
.footer-bottom { border-top:1px solid rgba(255,255,255,0.08); padding-top:1.5rem; margin-top:1rem; display:flex; flex-direction:column; align-items:center; gap:0.5rem; text-align:center; }
.footer-bottom span { color:rgba(250,246,240,0.25); font-size:0.72rem; letter-spacing:0.1em; }
.footer-inner { text-align:center; }
.footer-logo { font-family:'Jost',sans-serif; font-size:1.4rem; font-weight:300; letter-spacing:0.15em; text-transform:uppercase; color:var(--warm-cream); margin-bottom:0.8rem; }
.footer-logo span { color:var(--gold); }
.footer-links { display:flex; flex-direction:column; align-items:center; gap:0.9rem; margin-top:1.5rem; }
.footer-links a { color:rgba(250,246,240,0.45); text-decoration:none; font-size:0.8rem; letter-spacing:0.08em; transition:color 0.2s; }
.footer-links a:hover { color:var(--terracotta-light); }
.social-links { display:flex; gap:1rem; }
.social-links a { color:rgba(250,246,240,0.4); text-decoration:none; font-size:0.75rem; letter-spacing:0.1em; text-transform:uppercase; transition:color 0.2s; }
.social-links a:hover { color:var(--terracotta-light); }

/* ── CHATBOT ── */
#chat-bubble { position:fixed; bottom:2rem; right:2rem; z-index:999; }
#chat-toggle { width:58px; height:58px; border-radius:50%; background:linear-gradient(135deg, var(--purple), var(--rose)); border:none; cursor:pointer; box-shadow:0 6px 25px rgba(196,113,74,0.4); display:flex; align-items:center; justify-content:center; font-size:1.4rem; transition:all 0.3s; color:white; }
#chat-toggle:hover { background:linear-gradient(135deg, var(--rose), var(--purple)); transform:scale(1.05); }
#chat-window { position:absolute; bottom:70px; right:0; width:320px; background:var(--warm-cream); border-radius:12px; box-shadow:0 20px 60px rgba(44,24,16,0.2); display:none; flex-direction:column; overflow:hidden; border:1px solid rgba(196,113,74,0.15); max-height:500px; }
#chat-window.open { display:flex; }
.chat-header { background:linear-gradient(135deg, #2E1F3E, #4A2D5A); padding:0.9rem 1.1rem; display:flex; align-items:center; gap:0.7rem; }
.chat-avatar-circle { width:34px; height:34px; border-radius:50%; background:var(--terracotta); border:2px solid var(--gold); display:flex; align-items:center; justify-content:center; color:white; font-family:'Playfair Display',serif; font-size:0.9rem; flex-shrink:0; }
.chat-header-name { color:white; font-size:0.88rem; font-weight:500; font-family:'Playfair Display',serif; }
.chat-header-status { color:rgba(255,255,255,0.55); font-size:0.68rem; letter-spacing:0.08em; }
.chat-close { background:none; border:none; color:rgba(255,255,255,0.45); cursor:pointer; font-size:1.1rem; margin-left:auto; }
.chat-close:hover { color:white; }
#chat-messages { flex:1; overflow-y:auto; padding:1rem; display:flex; flex-direction:column; gap:0.7rem; min-height:280px; max-height:340px; }
.msg { max-width:85%; padding:0.65rem 0.9rem; border-radius:12px; font-size:0.85rem; line-height:1.5; }
.msg.bot { background:white; color:var(--text-dark); align-self:flex-start; border-bottom-left-radius:3px; box-shadow:0 2px 8px rgba(0,0,0,0.06); }
.msg.user { background:var(--terracotta); color:white; align-self:flex-end; border-bottom-right-radius:3px; }
.msg.typing { color:var(--text-light); font-style:italic; font-size:0.8rem; }
#chat-chips { display:flex; flex-wrap:wrap; gap:0.4rem; padding:0.2rem 0 0.5rem 0; }
.chat-chips-label { width:100%; font-size:0.7rem; letter-spacing:0.08em; text-transform:uppercase; color:var(--text-light); margin-bottom:0.2rem; font-family:'Jost',sans-serif; }
.chat-chip { background:white; border:1px solid rgba(196,113,74,0.3); color:var(--terracotta); border-radius:20px; padding:0.35rem 0.75rem; font-size:0.75rem; cursor:pointer; font-family:'Jost',sans-serif; transition:all 0.2s; white-space:nowrap; text-align:left; }
.chat-chip:hover { background:var(--terracotta); color:white; border-color:var(--terracotta); }
.chat-chip-topic { background:linear-gradient(135deg,#F8F5FF,#F0E8F5); border-color:rgba(120,80,160,0.25); color:var(--purple); font-weight:500; width:100%; }
.chat-chip-topic:hover { background:var(--purple); color:white; border-color:var(--purple); }
.chat-chip-back { background:transparent; border-color:rgba(92,61,46,0.2); color:var(--text-light); font-size:0.72rem; }
.chat-chip-back:hover { background:rgba(92,61,46,0.06); color:var(--text-dark); border-color:rgba(92,61,46,0.3); }
.chat-input-area { padding:0.7rem 0.9rem; border-top:1px solid rgba(196,113,74,0.1); display:flex; gap:0.5rem; background:white; }
#chat-input { flex:1; border:1px solid rgba(196,113,74,0.2); border-radius:20px; padding:0.5rem 0.9rem; font-family:'Jost',sans-serif; font-size:0.82rem; outline:none; color:var(--text-dark); background:var(--warm-cream); }
#chat-input:focus { border-color:var(--terracotta); }
#chat-send { width:34px; height:34px; border-radius:50%; background:var(--terracotta); border:none; cursor:pointer; color:white; font-size:0.9rem; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
#chat-send:hover { background:var(--warm-brown); }

/* ── LANG ── */
[data-lang="es"] { display:none; }
body.lang-es [data-lang="en"] { display:none; }
body.lang-es [data-lang="es"] { display:revert; }

/* ── ANIMATIONS ── */
@keyframes fadeUp { from{opacity:0;transform:translateY(24px);} to{opacity:1;transform:translateY(0);} }
@keyframes floatSym { 0%,100%{transform:translateY(0) rotate(0deg);} 50%{transform:translateY(-12px) rotate(8deg);} }

/* ── MOBILE ── */
@media(max-width:900px){
  html, body { overflow-x:hidden; max-width:100vw; }
  nav { padding:1rem 1.2rem; }
  .nav-links { display:none; }
  .nav-whatsapp-btn { display:none !important; }
  .hamburger { display:flex; }
  .page-hero { padding:7rem 1.5rem 3rem; }
  footer { padding:3rem 1.5rem 1.5rem; }
  .footer-grid { grid-template-columns:1fr 1fr; gap:2rem 1.5rem; }
  .footer-links { gap:0.8rem; }
  #chat-window { width:290px; right:-0.3rem; }
  .services-grid { grid-template-columns:1fr !important; padding:0 1rem; }
  .service-card { width:100%; box-sizing:border-box; }
  .book-btn { width:100%; text-align:center; white-space:normal; box-sizing:border-box; }
}


/* ── COSMIC COLOR ADDITIONS ── */
#hero {
  background: linear-gradient(160deg, #FAF7F5 0%, #F0E8F5 100%);
}
.hero-right {
  background: linear-gradient(160deg, #E8D5F0 0%, #D4B8E0 50%, #C4A0D0 100%) !important;
}
#about-snippet { background: linear-gradient(160deg, white 0%, #F5EEF8 100%); }
#services-snippet { background: linear-gradient(160deg, #F8F5FF 0%, #F0E8F5 100%); }
#reviews-snippet { background: linear-gradient(160deg, #F0EBF8 0%, #E8DFF5 100%); }
.hero-tag { color: var(--purple) !important; }
.hero-tag::before { background: var(--purple) !important; }
.trust-item span { color: var(--purple) !important; }
.about-float-card { background: var(--grad-dusk) !important; background: linear-gradient(135deg, #2E1F3E, #7B5EA7) !important; }
.nav-book { background: linear-gradient(135deg, var(--purple), var(--rose)) !important; }
.nav-book:hover { background: linear-gradient(135deg, var(--rose), var(--purple)) !important; }
.footer-col h4 { color: var(--mauve-light) !important; }
.footer-col a:hover { color: var(--peach) !important; }
.social-links a:hover { color: var(--peach) !important; }
.lang-btn { border-color: var(--purple-light) !important; color: var(--purple) !important; }
.lang-btn.active, .lang-btn:hover { background: var(--purple) !important; color: white !important; border-color: var(--purple) !important; }
.footer-brand .logo span { color: var(--mauve-light) !important; }

/* ── Cosmic events grid responsive ── */
.cosmic-events-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.2rem; max-width:900px; margin:0 auto 2.5rem; }
@media(max-width:900px) { .cosmic-events-grid { grid-template-columns:1fr; gap:0.8rem; } }

/* ── Better btn-gold (pill shape) ── */
.btn-gold { border-radius:50px !important; padding:0.9rem 2.2rem !important; box-shadow:0 4px 20px rgba(201,169,110,0.3); letter-spacing:0.12em; }
.btn-gold:hover { box-shadow:0 6px 28px rgba(201,169,110,0.45); transform:translateY(-1px); }

/* ── Booking cards flex layout so buttons always align at bottom ── */
.booking-card { display:flex; flex-direction:column; }
.booking-card .book-btn-wrap { margin-top:auto; }

/* ── Blog coming-soon card ── */
.coming-soon-post { background:linear-gradient(135deg,#F8F2FF,#FDF0F8); border-radius:12px; padding:3.5rem 3rem; text-align:center; border:1px solid rgba(155,111,212,0.15); }
