:root{
  --cream:#fff0d7;
  --cream-2:#ffe8bd;
  --navy:#071b3d;
  --navy-2:#102e5c;
  --coffee:#381608;
  --coffee-2:#6a2e12;
  --caramel:#c77725;
  --gold:#e8b94e;
  --gold-2:#fff1a8;
  --ink:#1b120d;
  --muted:#684b37;
  --white:#fffaf0;
  --shadow:0 25px 70px rgba(20, 10, 2, .22);
  --radius:28px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:'Montserrat', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  color:var(--ink);
  background:var(--cream);
  overflow-x:hidden;
}
img,video{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit}

.site-bg{
  position:fixed;
  inset:0;
  z-index:-2;
  background:
    radial-gradient(circle at 12% 12%, rgba(232,185,78,.24), transparent 26%),
    radial-gradient(circle at 85% 18%, rgba(106,46,18,.18), transparent 28%),
    linear-gradient(135deg, #fff6e7 0%, #ffe5bb 45%, #f7d49d 100%);
}
.site-bg::after{
  content:"";
  position:absolute;
  inset:0;
  background-image:
    linear-gradient(rgba(56,22,8,.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(56,22,8,.035) 1px, transparent 1px);
  background-size:34px 34px;
  mask-image:linear-gradient(to bottom, transparent, #000 16%, #000 82%, transparent);
}

.container{width:min(1160px, calc(100% - 36px));margin:0 auto}
.section-pad{padding:92px 0}
.section-head{max-width:760px;margin-bottom:38px}
.section-head.center{text-align:center;margin-left:auto;margin-right:auto}
.section-kicker{
  display:inline-flex;
  align-items:center;
  gap:10px;
  margin:0 0 12px;
  color:var(--coffee-2);
  font-size:.82rem;
  font-weight:800;
  letter-spacing:.18em;
  text-transform:uppercase;
}
.section-kicker::before,.section-kicker::after{
  content:"";
  width:28px;
  height:2px;
  background:linear-gradient(90deg,var(--gold),var(--coffee-2));
  border-radius:99px;
}
.section-head h2,.intro h2,.place h2,.contact h2{
  margin:0;
  color:var(--navy);
  font-family:'Bebas Neue', Impact, sans-serif;
  font-size:clamp(2.4rem, 6vw, 5rem);
  letter-spacing:.035em;
  line-height:.92;
}
.section-head p,.intro p,.place p,.contact p{color:var(--muted);line-height:1.8;font-weight:600}

.topbar{
  position:fixed;
  top:16px;
  left:50%;
  transform:translateX(-50%);
  z-index:50;
  width:min(1160px, calc(100% - 28px));
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  padding:10px 12px;
  border:1px solid rgba(255,240,215,.25);
  border-radius:999px;
  background:rgba(7,27,61,.82);
  backdrop-filter:blur(18px);
  box-shadow:0 16px 55px rgba(0,0,0,.18);
  color:var(--white);
  transition:all .25s ease;
}
.topbar.scrolled{top:8px;background:rgba(7,27,61,.94)}
.brand{display:flex;align-items:center;gap:10px;font-weight:900}
.brand img{width:68px;height:auto;max-height:58px;border-radius:10px;object-fit:contain;background:transparent}
.brand span{font-family:'Lobster Two', Georgia, serif;font-size:1.42rem;color:var(--gold-2)}
.nav{display:flex;align-items:center;gap:4px}
.nav a{
  padding:12px 15px;
  border-radius:999px;
  color:#fff6e7;
  font-weight:800;
  font-size:.88rem;
  transition:.25s ease;
}
.nav a:hover{background:rgba(232,185,78,.18);color:var(--gold-2)}
.menu-toggle{display:none;background:none;border:0;width:44px;height:44px;padding:9px;cursor:pointer}
.menu-toggle span{display:block;height:2px;background:var(--gold-2);margin:6px 0;border-radius:99px;transition:.25s ease}

.hero{
  position:relative;
  min-height:100svh;
  display:grid;
  place-items:center;
  padding:140px 18px 80px;
  color:var(--white);
  background:
    linear-gradient(115deg, rgba(5,8,12,.94) 0%, rgba(36,14,5,.88) 48%, rgba(7,27,61,.80) 100%),
    url('../assets/images/lugar-referencia.webp') center/cover no-repeat;
  isolation:isolate;
  overflow:hidden;
}
.hero::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 50% 32%, rgba(232,185,78,.22), transparent 26%),
    linear-gradient(to bottom, rgba(0,0,0,.25), rgba(0,0,0,.58));
  z-index:-1;
}
.hero__shine{
  position:absolute;
  width:420px;
  height:420px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(255,241,168,.3), transparent 64%);
  filter:blur(6px);
  top:13%;
  right:7%;
  animation:float 6s ease-in-out infinite alternate;
}
.hero__content{text-align:center;max-width:920px;margin:auto}
.logo-frame{
  width:min(360px, 78vw);
  margin:0 auto 24px;
  padding:12px;
  border-radius:34px;
  background:linear-gradient(145deg, rgba(255,241,168,.95), rgba(58,23,7,.86));
  box-shadow:0 18px 70px rgba(232,185,78,.28), inset 0 0 0 1px rgba(255,255,255,.24);
}
.logo-frame img{width:100%;height:auto;border-radius:24px;object-fit:contain;background:#101010;display:block}
.eyebrow{
  display:inline-block;
  margin:0 0 14px;
  padding:10px 18px;
  border:1px solid rgba(232,185,78,.35);
  border-radius:999px;
  color:var(--gold-2);
  font-weight:900;
  letter-spacing:.16em;
  text-transform:uppercase;
  background:rgba(255,255,255,.08);
}
.hero h1{
  margin:0;
  font-family:'Lobster Two', Georgia, serif;
  font-size:clamp(3.6rem, 12vw, 8.4rem);
  line-height:.88;
  color:var(--gold-2);
  text-shadow:0 4px 0 rgba(75,30,7,.55), 0 22px 70px rgba(232,185,78,.24);
}
.hero__phrase{
  max-width:760px;
  margin:22px auto 0;
  color:#fff3d3;
  font-size:clamp(1.1rem, 3vw, 1.75rem);
  font-weight:800;
  line-height:1.45;
}
.hero__actions,.place__actions{display:flex;justify-content:center;gap:14px;flex-wrap:wrap;margin-top:32px}
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  min-height:52px;
  padding:14px 24px;
  border-radius:999px;
  border:1px solid transparent;
  font-weight:900;
  cursor:pointer;
  transition:transform .25s ease, box-shadow .25s ease, background .25s ease;
}
.btn:hover{transform:translateY(-3px)}
.btn--primary{background:linear-gradient(135deg,var(--gold-2),var(--gold),var(--caramel));color:#301304;box-shadow:0 15px 35px rgba(199,119,37,.3)}
.btn--ghost{border-color:rgba(255,240,215,.46);color:#fff7e6;background:rgba(255,255,255,.08)}
.btn--ghost.dark{color:var(--navy);border-color:rgba(7,27,61,.2);background:rgba(7,27,61,.06)}
.btn--small{min-height:44px;padding:11px 18px;background:var(--navy);color:var(--white);font-size:.9rem;margin-top:8px}
.hero__card{
  position:absolute;
  right:min(6vw,70px);
  bottom:44px;
  width:min(360px, calc(100% - 36px));
  padding:22px;
  border-radius:24px;
  background:rgba(255,240,215,.12);
  border:1px solid rgba(255,240,215,.24);
  backdrop-filter:blur(16px);
  box-shadow:var(--shadow);
}
.hero__label{color:var(--gold-2);font-weight:900;text-transform:uppercase;letter-spacing:.16em;font-size:.75rem}
.hero__card p{margin:8px 0 0;line-height:1.55;font-weight:700;color:#fff3d3}.hero__card-row + .hero__card-row{margin-top:16px;padding-top:16px;border-top:1px solid rgba(255,240,215,.22)}

.intro{background:linear-gradient(180deg, rgba(255,250,240,.72), rgba(255,232,189,.52))}
.intro__grid{display:grid;grid-template-columns:1.05fr .95fr;gap:36px;align-items:center}
.intro__text{padding:34px;border-radius:var(--radius);background:rgba(255,250,240,.7);box-shadow:var(--shadow);border:1px solid rgba(106,46,18,.12)}
.mini-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.mini-cards a{
  min-height:130px;
  display:flex;
  align-items:flex-end;
  padding:22px;
  border-radius:26px;
  color:var(--white);
  font-family:'Bebas Neue', Impact, sans-serif;
  font-size:clamp(1.65rem,3.4vw,2.4rem);
  letter-spacing:.04em;
  background:
    linear-gradient(135deg, rgba(7,27,61,.92), rgba(106,46,18,.86)),
    radial-gradient(circle at top right, rgba(232,185,78,.55), transparent 36%);
  box-shadow:var(--shadow);
  transition:.25s ease;
}
.mini-cards a:hover{transform:translateY(-6px) scale(1.01)}

.video-section{background:linear-gradient(180deg, rgba(7,27,61,.98), rgba(38,15,5,.95));color:var(--white);position:relative;overflow:hidden}
.video-section .section-head h2{color:var(--gold-2)}
.video-section .section-head p{color:#f4d6a7}
.video-section .section-kicker{color:var(--gold-2)}
.video-wrap{
  position:relative;
  padding:10px;
  border-radius:34px;
  background:linear-gradient(135deg, rgba(255,241,168,.75), rgba(106,46,18,.45), rgba(16,46,92,.7));
  box-shadow:0 25px 90px rgba(0,0,0,.35);
}
.video-wrap video{width:100%;max-height:660px;object-fit:contain;background:#070707;border-radius:26px}

.menu{position:relative}
.menu-grid{display:grid;grid-template-columns:repeat(2, minmax(0, 1fr));gap:22px}
.menu-card{
  position:relative;
  padding:28px;
  border-radius:var(--radius);
  background:
    linear-gradient(180deg, rgba(255,250,240,.94), rgba(255,232,189,.86));
  border:1px solid rgba(106,46,18,.16);
  box-shadow:var(--shadow);
  overflow:hidden;
}
.menu-card::before{
  content:"";
  position:absolute;
  inset:0 0 auto 0;
  height:9px;
  background:linear-gradient(90deg,var(--navy),var(--caramel),var(--gold));
}
.menu-card__top{display:flex;align-items:flex-start;gap:16px;margin-bottom:22px}
.menu-card__top span{
  flex:0 0 auto;
  width:46px;height:46px;border-radius:16px;
  display:grid;place-items:center;
  background:var(--navy);
  color:var(--gold-2);
  font-weight:900;
}
.menu-card h3{
  margin:0;
  color:var(--navy);
  font-family:'Bebas Neue', Impact, sans-serif;
  font-size:clamp(2.2rem, 4vw, 3.3rem);
  line-height:.95;
  letter-spacing:.04em;
}
.price-list{display:grid;gap:10px}
.price-list div{display:flex;align-items:center;justify-content:space-between;gap:12px;border-bottom:1px dashed rgba(56,22,8,.25);padding:8px 0}
.price-list strong{font-size:1.05rem;color:var(--coffee)}
.price-list span{font-weight:900;color:var(--navy);font-size:1.2rem}
.price-list p{margin:0 0 8px;color:var(--muted);line-height:1.6;font-weight:600}
.tag-list{display:flex;flex-wrap:wrap;gap:9px;margin-top:20px}
.tag-list span{
  padding:9px 12px;
  border-radius:999px;
  background:#fff5df;
  border:1px solid rgba(106,46,18,.14);
  color:var(--coffee-2);
  font-weight:800;
  font-size:.88rem;
}
.tag-list.big span{background:var(--navy);color:#fff7e7;border-color:transparent}
.columns-list{display:grid;gap:14px;margin-top:16px}
.columns-list div{padding:14px;border-radius:18px;background:rgba(255,250,240,.7);border:1px solid rgba(106,46,18,.12)}
.columns-list b{display:block;color:var(--coffee);margin-bottom:5px}
.columns-list span{display:block;color:var(--muted);line-height:1.6;font-weight:600}
.columns-list.compact{grid-template-columns:repeat(2,1fr)}

.pdf-section{background:linear-gradient(180deg, rgba(255,250,240,.4), rgba(7,27,61,.08))}
.pdf-gallery{display:grid;grid-template-columns:repeat(4, minmax(0, 1fr));gap:18px;align-items:start}
.pdf-page{
  padding:0;
  border:0;
  background:transparent;
  border-radius:22px;
  cursor:zoom-in;
  box-shadow:0 18px 45px rgba(56,22,8,.20);
  overflow:hidden;
  transition:.25s ease;
}
.pdf-page:hover{transform:translateY(-8px);box-shadow:0 30px 70px rgba(56,22,8,.28)}
.pdf-page img{width:100%;height:auto;border-radius:22px;background:var(--cream)}

.place{background:linear-gradient(180deg, rgba(7,27,61,.96), rgba(56,22,8,.94));color:var(--white)}
.place__grid{display:grid;grid-template-columns:1.05fr .95fr;gap:34px;align-items:center}
.place__gallery{display:grid;gap:18px}.place__photo{margin:0;padding:10px;border-radius:34px;background:linear-gradient(135deg,var(--gold),rgba(255,255,255,.12),var(--coffee-2));box-shadow:0 25px 90px rgba(0,0,0,.3)}.place__photo img{width:100%;height:auto;border-radius:26px;object-fit:contain;background:#090909}
.place h2{color:var(--gold-2)}
.place p{color:#ffe5bd}
.place__info{padding:34px;border-radius:var(--radius);background:rgba(255,255,255,.08);border:1px solid rgba(255,240,215,.16);backdrop-filter:blur(14px)}
.contact-box{display:grid;gap:6px;margin:22px 0 0;padding:20px;border-radius:22px;background:rgba(255,240,215,.12);border:1px solid rgba(255,240,215,.16)}
.contact-box span{color:var(--gold-2);font-weight:900;text-transform:uppercase;letter-spacing:.12em;font-size:.8rem}
.contact-box strong{font-size:clamp(1.8rem, 4vw, 2.8rem);font-family:'Bebas Neue',Impact,sans-serif;letter-spacing:.05em;color:#fff}
.place__actions{justify-content:flex-start}

.contact{background:linear-gradient(180deg, rgba(255,232,189,.4), rgba(255,250,240,.9))}
.contact__card{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
  padding:38px;
  border-radius:34px;
  background:var(--white);
  box-shadow:var(--shadow);
  border:1px solid rgba(106,46,18,.12);
}
.contact__card h2{font-size:clamp(2.2rem, 5vw, 4.2rem)}
.contact__card p{margin:8px 0}

.footer{
  text-align:center;
  padding:54px 18px 72px;
  color:#fff5dd;
  background:linear-gradient(135deg,#05080c,var(--navy),#2c1005);
}
.footer img{width:min(220px,70vw);height:auto;margin:0 auto 16px;border-radius:22px;object-fit:contain;background:#101010;border:2px solid rgba(232,185,78,.8)}
.footer p{margin:0;font-family:'Lobster Two', Georgia, serif;font-size:2rem;color:var(--gold-2)}
.footer strong{display:block;margin-top:8px;color:#ffe4ae}

.whatsapp-float{
  position:fixed;
  right:18px;
  bottom:18px;
  z-index:45;
  min-height:54px;
  padding:0 18px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  background:#1fbd5a;
  color:white;
  font-weight:900;
  box-shadow:0 16px 40px rgba(0,0,0,.25);
}
.whatsapp-float::before{content:"✆";font-size:1.2rem;margin-right:8px}

.lightbox{
  position:fixed;
  inset:0;
  display:none;
  align-items:center;
  justify-content:center;
  padding:24px;
  background:rgba(0,0,0,.82);
  z-index:100;
}
.lightbox.active{display:flex}
.lightbox img{max-width:min(920px, 92vw);max-height:88vh;border-radius:18px;box-shadow:0 30px 90px rgba(0,0,0,.45)}
.lightbox__close{
  position:absolute;
  top:18px;
  right:18px;
  width:46px;height:46px;
  border:0;border-radius:50%;
  background:var(--cream);
  color:var(--coffee);
  font-size:2rem;
  line-height:1;
  cursor:pointer;
}

.reveal{opacity:0;transform:translateY(22px);transition:opacity .75s ease, transform .75s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
.delay-1{transition-delay:.12s}
@keyframes float{from{transform:translateY(0)}to{transform:translateY(28px)}}

@media (max-width: 980px){
  .section-pad{padding:76px 0}
  .intro__grid,.place__grid{grid-template-columns:1fr}
  .menu-grid{grid-template-columns:1fr}
  .pdf-gallery{grid-template-columns:repeat(2, minmax(0, 1fr))}
  .contact__card{align-items:flex-start;flex-direction:column}
  .hero__card{position:relative;right:auto;bottom:auto;margin-top:34px}
}
@media (max-width: 760px){
  .topbar{border-radius:26px;align-items:flex-start;flex-wrap:wrap}
  .menu-toggle{display:block;margin-left:auto}
  .nav{
    display:none;
    width:100%;
    flex-direction:column;
    align-items:stretch;
    padding:6px 0 4px;
  }
  .nav.open{display:flex}
  .nav a{text-align:center;background:rgba(255,255,255,.06)}
  .topbar.menu-open{border-radius:28px}
  .menu-toggle.active span:nth-child(1){transform:translateY(8px) rotate(45deg)}
  .menu-toggle.active span:nth-child(2){opacity:0}
  .menu-toggle.active span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}
  .hero{padding-top:132px;background-position:center}
  .logo-frame{width:min(300px, 82vw)}
  .hero__actions,.place__actions{flex-direction:column}
  .btn{width:100%}
  .mini-cards{grid-template-columns:1fr}
  .columns-list.compact{grid-template-columns:1fr}
  .video-wrap{border-radius:24px;padding:6px}
  .video-wrap video{border-radius:18px}
  .whatsapp-float span{display:none}
  .whatsapp-float{width:58px;height:58px;padding:0;border-radius:50%}
  .whatsapp-float::before{margin:0}
}
@media (max-width: 520px){
  .container{width:min(100% - 24px, 1160px)}
  .section-pad{padding:62px 0}
  .pdf-gallery{grid-template-columns:1fr}
  .menu-card,.intro__text,.place__info,.contact__card{padding:24px;border-radius:24px}
  .hero h1{font-size:clamp(3.2rem, 17vw, 5rem)}
  .hero__phrase{font-size:1.08rem}
}

.contact__actions{display:flex;gap:14px;flex-wrap:wrap;justify-content:flex-end}
@media (max-width:760px){.contact__actions{width:100%;flex-direction:column}.contact__actions .btn{width:100%}}
