/* ============================================
   GALEGO TREKKING — Lençóis Maranhenses
   Cores: Laranja #FF7A00 · Tiffany #0ABAB5 · Branco
============================================ */

:root{
  --orange:#FF7A00;
  --orange-2:#ff9a33;
  --tiffany:#0ABAB5;
  --tiffany-2:#1ed4cf;
  --white:#ffffff;
  --sand:#f7f1e8;
  --ink:#0f1720;
  --ink-2:#1c2530;
  --muted:#6b7280;
  --line:rgba(15,23,32,.08);

  --font-display: 'Playfair Display', serif;
  --font-sans: 'Manrope', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;

  --radius: 18px;
  --radius-lg: 28px;

  --shadow-sm: 0 4px 14px rgba(15,23,32,.06);
  --shadow-md: 0 18px 50px -20px rgba(15,23,32,.25);
  --shadow-lg: 0 30px 80px -30px rgba(15,23,32,.35);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-tap-highlight-color:transparent}
body{
  font-family:var(--font-sans);
  color:var(--ink);
  background:var(--white);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
ul{list-style:none}
::selection{background:var(--orange);color:#fff}

.container{width:100%;max-width:1200px;margin:0 auto;padding:0 24px}

/* ===== Buttons ===== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:14px 24px;border-radius:999px;font-weight:700;font-size:15px;
  transition:transform .25s ease, box-shadow .25s ease, background .25s ease, color .25s ease, border-color .25s ease;
  white-space:nowrap;letter-spacing:.01em;will-change: transform;
}
.btn--sm{padding:10px 16px;font-size:13px}
.btn--lg{padding:17px 30px;font-size:16px}
.btn--full{width:100%}
.btn--orange{background:var(--orange);color:#fff;box-shadow:0 10px 30px -10px rgba(255,122,0,.6)}
.btn--orange:hover{transform:translateY(-2px);background:var(--orange-2);box-shadow:0 16px 40px -12px rgba(255,122,0,.7)}
.btn--tiffany{background:rgba(255,122,0,.7);color:#fff;box-shadow:0 10px 30px -10px rgba(255,122,0,.7)}
.btn--tiffany:hover{transform:translateY(-2px);background:var(--tiffany-2)}
.btn--whats{background:#25D366;color:#fff}
.btn--whats:hover{transform:translateY(-2px);background:#1ebb58}
.btn--outline{background:transparent;color:var(--ink);border:2px solid var(--ink)}
.btn--outline:hover{background:var(--ink);color:#fff;transform:translateY(-2px)}
.btn--ghost{background:rgba(15,23,32,.06);color:var(--ink)}
.btn--ghost:hover{background:rgba(15,23,32,.12)}

/* ===== Typography ===== */
.h2{
  font-family:var(--font-display);font-weight:700;
  font-size:clamp(32px,4.5vw,56px);line-height:1.08;letter-spacing:-.01em;
  color:var(--ink);max-width:900px;margin-bottom:28px;
}
.h2 em{font-style:italic;color:var(--orange)}
.h2--light{color:#fff}
.h2--light em{color:var(--orange-2)}
.eyebrow{
  display:inline-block;text-transform:uppercase;letter-spacing:.22em;
  font-size:12px;font-weight:700;color:var(--tiffany);margin-bottom:14px;
}
.eyebrow--light{color:var(--orange-2)}

/* ===== Reveal ===== */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .9s ease, transform .9s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* ===== NAV ===== */
.nav{position:fixed;top:0;left:0;right:0;z-index:60;transition:background .3s ease, backdrop-filter .3s ease, box-shadow .3s ease}
.nav__inner{display:flex;align-items:center;justify-content:space-between;padding:14px 24px}
.nav__logo img{height:46px;filter:drop-shadow(0 4px 12px rgba(0,0,0,.35))}
.nav__links{display:flex;gap:28px}
.nav__links a{position:relative;color:#fff;font-weight:600;font-size:14px;padding:8px 0;text-shadow:0 2px 6px rgba(0,0,0,.5)}
.nav__links a::after{content:'';position:absolute;left:0;bottom:2px;width:0;height:2px;background:var(--orange);transition:width .35s ease}
.nav__links a:hover::after{width:100%}
.nav--scrolled{background:rgba(10,186,181,.6);backdrop-filter:blur(16px);box-shadow:0 10px 30px -15px rgba(0,0,0,.15)}
.nav--scrolled .nav__links a{color:var(--ink);text-shadow:none}
.nav--scrolled .nav__logo img{filter:none}
.nav__burger{display:none;flex-direction:column;gap:5px;padding:8px}
.nav__burger span{width:24px;height:2px;background:#fff;transition:transform .3s, opacity .3s, background .3s}
.nav--scrolled .nav__burger span{background:var(--ink)}
.nav__mobile{display:none;flex-direction:column;gap:6px;padding:20px 24px;background:#fff;border-top:1px solid var(--line)}
.nav__mobile a{padding:12px 0;font-weight:600;border-bottom:1px solid var(--line)}
.nav__mobile.open{display:flex}
@media (max-width: 900px){
  .nav__links{display:none}
  .nav__cta{display:none}
  .nav__burger{display:flex}
}

/* ===== HERO ===== */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;color:#fff;overflow:hidden}
.hero__bg{position:absolute;inset:0;z-index:0}
.hero__bg img{width:100%;height:100%;object-fit:cover;transform:scale(1.08);animation:heroZoom 18s ease-in-out infinite alternate}
@keyframes heroZoom{to{transform:scale(1.18)}}
.hero__vignette{
  position:absolute;inset:0;
  background:
    linear-gradient(180deg, rgba(10,14,20,.55) 0%, rgba(10,14,20,.25) 40%, rgba(10,14,20,.85) 100%),
    radial-gradient(ellipse at 30% 20%, rgba(255,122,0,.25), transparent 60%);
}
.hero__grain{
  position:absolute;inset:0;opacity:.12;mix-blend-mode:overlay;pointer-events:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/></filter><rect width='100%' height='100%' filter='url(%23n)' opacity='0.6'/></svg>");
}
.hero__content{position:relative;z-index:2;padding:140px 24px 80px}
.hero__tag{
  display:inline-flex;align-items:center;gap:10px;padding:8px 16px;border-radius:999px;
  background:rgba(255,255,255,.1);backdrop-filter:blur(14px);border:1px solid rgba(255,255,255,.2);
  font-size:13px;font-weight:600;letter-spacing:.04em;margin-bottom:24px;
}
.hero__tag .dot{width:8px;height:8px;border-radius:50%;background:var(--orange);box-shadow:0 0 0 6px rgba(255,122,0,.25);animation:pulse 2s infinite}
@keyframes pulse{50%{box-shadow:0 0 0 10px rgba(255,122,0,0)}}
.hero__title{
  font-family:var(--font-display);font-weight:700;font-size:clamp(38px,6.2vw,84px);
  line-height:1.02;letter-spacing:-.02em;max-width:960px;margin-bottom:22px;
}
.hero__title em{font-style:italic;color:var(--orange-2)}
.hero__title .accent{color:var(--tiffany-2);position:relative;white-space:nowrap}
.hero__title .accent::after{
  content:'';position:absolute;left:0;right:0;bottom:-4px;height:6px;
  background:var(--orange);border-radius:4px;transform:skewX(-12deg);opacity:.8;
}
.hero__sub{font-size:clamp(16px,1.6vw,20px);max-width:640px;color:rgba(255,255,255,.86);margin-bottom:36px}
.hero__ctas{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:60px}
.hero__stats{display:flex;gap:48px;flex-wrap:wrap}
.hero__stats div{display:flex;flex-direction:column}
.hero__stats strong{font-family:var(--font-display);font-size:34px;color:var(--orange-2)}
.hero__stats span{font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.7)}
.hero__scroll{
  position:absolute;bottom:24px;left:50%;transform:translateX(-50%);
  width:28px;height:48px;border:2px solid rgba(255,255,255,.5);border-radius:20px;
  display:flex;justify-content:center;padding-top:8px;
}
.hero__scroll span{width:3px;height:10px;background:#fff;border-radius:3px;animation:scroll 1.6s infinite}
@keyframes scroll{0%{transform:translateY(0);opacity:1}100%{transform:translateY(18px);opacity:0}}

/* ===== MARQUEE ===== */
.marquee{background:var(--ink);color:#fff;overflow:hidden;padding:20px 0;border-top:1px solid rgba(255,255,255,.08)}
.marquee__track{display:flex;gap:40px;white-space:nowrap;animation:scrollx 36s linear infinite;font-family:var(--font-display);font-style:italic;font-size:28px}
.marquee__track i{color:var(--orange);font-style:normal}
@keyframes scrollx{to{transform:translateX(-50%)}}

/* ===== SOBRE ===== */
.sobre{padding:120px 0;background:var(--sand)}
.sobre__grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.sobre__img{position:relative;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg)}
.sobre__img img{width:100%;height:560px;object-fit:cover;transition:transform 1.2s ease}
.sobre__img:hover img{transform:scale(1.04)}
.sobre__badge{position:absolute;bottom:24px;left:24px;padding:16px 20px;background:#fff;border-radius:16px;box-shadow:var(--shadow-md)}
.sobre__badge strong{display:block;font-family:var(--font-display);font-size:32px;color:var(--orange);line-height:1}
.sobre__badge span{font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.sobre__text p{color:var(--ink-2);margin-bottom:18px;font-size:17px}
.sobre__signature{display:flex;align-items:center;gap:14px;margin-top:30px}
.sobre__signature small{font-family:var(--font-display);font-style:italic;font-size:18px;color:var(--ink)}
@media (max-width:900px){.sobre__grid{grid-template-columns:1fr;gap:40px}.sobre__img img{height:400px}}

/* ===== DIFF ===== */
.diff{padding:120px 0}
.diff__grid{display:grid;grid-template-columns:repeat(5,1fr);gap:18px;margin-top:50px}
.diff__card{
  padding:32px 22px;border:1px solid var(--line);border-radius:var(--radius);background:#fff;
  transition:transform .35s ease, box-shadow .35s ease, border-color .35s;position:relative;overflow:hidden;
}
.diff__card::before{
  content:'';position:absolute;inset:auto -30% -50% auto;width:140px;height:140px;
  background:radial-gradient(circle, rgba(255,122,0,.18), transparent 70%);transition:transform .5s ease;
}
.diff__card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);border-color:transparent}
.diff__card:hover::before{transform:translate(-20px,-20px) scale(1.4)}
.diff__icon{
  width:56px;height:56px;border-radius:14px;display:grid;place-items:center;
  background:linear-gradient(135deg,var(--tiffany),var(--tiffany-2));color:#fff;font-size:22px;margin-bottom:18px;
}
.diff__card:nth-child(even) .diff__icon{background:linear-gradient(135deg,var(--orange),var(--orange-2))}
.diff__card h3{font-family:var(--font-display);font-size:22px;margin-bottom:8px}
.diff__card p{color:var(--muted);font-size:14px}
@media (max-width:1000px){.diff__grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:600px){.diff__grid{grid-template-columns:1fr}}

/* ===== ROTEIROS ===== */
.roteiros{padding:80px 0;background:var(--ink);color:#fff}
.roteiros .eyebrow{color:var(--orange-2)}
.roteiros .h2{color:#fff}
.roteiros .h2 em{color:var(--tiffany-2)}
.roteiros__row{display:flex;flex-wrap:wrap;gap:14px;margin-top:30px}
.roteiros__pill{
  display:inline-flex;align-items:center;gap:10px;padding:14px 22px;
  border:1px solid rgba(255,255,255,.15);border-radius:999px;
  font-weight:600;font-size:15px;transition:all .3s ease;backdrop-filter:blur(8px);
}
.roteiros__pill i{color:var(--orange-2)}
.roteiros__pill:hover{background:var(--orange);border-color:var(--orange);transform:translateY(-3px)}
.roteiros__pill:hover i{color:#fff}

/* ===== INCLUSOS ===== */
.inclusos{padding:120px 0;background:var(--sand)}
.inclusos__grid{display:grid;grid-template-columns:repeat(6,1fr);gap:16px;margin-top:40px}
.inc{background:#fff;border-radius:16px;padding:24px 16px;text-align:center;border:1px solid var(--line);transition:all .3s ease}
.inc i{font-size:28px;color:var(--orange);margin-bottom:10px;display:block;transition:transform .3s}
.inc span{font-weight:600;font-size:14px}
.inc:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:transparent}
.inc:hover i{transform:scale(1.2) rotate(-8deg);color:var(--tiffany)}
@media (max-width:900px){.inclusos__grid{grid-template-columns:repeat(3,1fr)}}
@media (max-width:500px){.inclusos__grid{grid-template-columns:repeat(2,1fr)}}

/* ===== PASSEIOS ===== */
.passeios{padding:120px 0}
.passeios__help{
  display:inline-flex;align-items:center;gap:10px;padding:12px 18px;
  background:rgba(10,186,181,.08);color:var(--tiffany);border-radius:999px;
  font-size:14px;margin:10px 0 40px;border:1px solid rgba(10,186,181,.22);
}
.passeios__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;
  transition:transform .4s ease, box-shadow .4s ease;position:relative;display:flex;flex-direction:column;
}
.card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg)}
.card.selected{border-color:var(--orange);box-shadow:0 0 0 3px rgba(255,122,0,.18), var(--shadow-md)}
.card__img{position:relative;aspect-ratio:4/3;overflow:hidden;background:linear-gradient(135deg,#1c2530,#0ABAB5)}
.card__img img{width:100%;height:100%;object-fit:cover;transition:transform 1s ease}
.card:hover .card__img img{transform:scale(1.1)}
.card__emoji{position:absolute;top:16px;left:16px;width:46px;height:46px;border-radius:14px;background:rgba(255,255,255,.95);display:grid;place-items:center;font-size:24px}
.card__duration{position:absolute;top:16px;right:16px;padding:6px 12px;border-radius:999px;background:rgba(15,23,32,.7);color:#fff;font-size:12px;font-weight:600;backdrop-filter:blur(8px)}
.card__body{padding:26px;display:flex;flex-direction:column;flex:1}
.card__title{font-family:var(--font-display);font-size:26px;margin-bottom:10px;line-height:1.15}
.card__desc{color:var(--muted);font-size:14px;margin-bottom:18px;flex:1}
.card__prices{display:flex;flex-direction:column;gap:6px;padding:14px;border-radius:14px;background:var(--sand);margin-bottom:18px}
.card__prices .price{display:flex;justify-content:space-between;font-size:14px}
.card__prices .price strong{color:var(--orange);font-family:var(--font-display);font-size:20px}
.card__note{font-size:11px;color:var(--muted);margin-top:6px;font-style:italic}
.card__btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px;border-radius:999px;
  background:var(--ink);color:#fff;font-weight:700;transition:all .3s ease;
}
.card__btn:hover{background:var(--orange)}
.card.selected .card__btn{background:var(--orange)}
.card.selected .card__btn::before{content:"\f00c";font-family:"Font Awesome 6 Free";font-weight:900;margin-right:6px}
@media (max-width:900px){.passeios__grid{grid-template-columns:1fr}}

/* ===== TRAVESSIAS ===== */
.travessias{position:relative;padding:140px 0;color:#fff;overflow:hidden}
.travessias__bg{
  position:absolute;inset:0;z-index:0;
  background:
    linear-gradient(135deg, rgba(15,23,32,.85), rgba(10,186,181,.7)),
url('./IMG-20260501-WA0207.jpg.jpeg')
}
.travessias__inner{position:relative;z-index:2}
.travessias__lead{max-width:720px;font-size:18px;color:rgba(255,255,255,.88);margin-bottom:50px}
.travessias__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.trav{
  background:rgba(255,255,255,.08);backdrop-filter:blur(18px);
  border:1px solid rgba(255,255,255,.16);border-radius:var(--radius-lg);
  padding:34px;display:flex;flex-direction:column;gap:16px;
  transition:transform .4s ease, background .3s;position:relative;
}
.trav:hover{transform:translateY(-8px);background:rgba(255,255,255,.14)}
.trav--featured{background:rgba(255,255,255,.96);color:var(--ink)}
.trav--featured:hover{background:#fff}
.trav__ribbon{
  position:absolute;top:-12px;right:24px;padding:6px 14px;background:var(--orange);color:#fff;
  font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;border-radius:999px;
}
.trav header{display:flex;align-items:baseline;gap:10px;font-family:var(--font-display)}
.trav header span{font-size:54px;font-weight:700;color:var(--orange-2)}
.trav--featured header span{color:var(--orange)}
.trav header small{font-size:14px;letter-spacing:.2em;text-transform:uppercase;opacity:.7}
.trav h3{font-family:var(--font-display);font-size:26px}
.trav ul{display:flex;flex-direction:column;gap:8px;flex:1}
.trav ul li{display:flex;align-items:center;gap:10px;font-size:14px}
.trav ul li i{color:var(--orange)}
.trav--featured ul li i{color:var(--tiffany)}
@media (max-width:900px){.travessias__grid{grid-template-columns:1fr}}

/* ===== INFO ===== */
.info{padding:100px 0;background:var(--sand)}
.info__grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.info__card{padding:40px;background:#fff;border-radius:var(--radius-lg);border:1px solid var(--line);transition:transform .3s}
.info__card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.info__card--tiffany{background:linear-gradient(135deg,var(--tiffany),var(--tiffany-2));color:#fff;border:none}
.info__card h3{font-family:var(--font-display);font-size:26px;margin-bottom:20px;display:flex;align-items:center;gap:12px}
.info__card h3 i{color:var(--orange)}
.info__card--tiffany h3 i{color:#fff}
.info__card ul{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.info__card li{padding:10px 14px;border-radius:10px;background:rgba(15,23,32,.04);font-size:14px}
.info__card--tiffany li{background:rgba(255,255,255,.15)}
@media (max-width:700px){.info__grid{grid-template-columns:1fr}.info__card ul{grid-template-columns:1fr}}

/* ===== GALERIA ===== */
.galeria{padding:120px 0}
.galeria__fotos{display:grid !important;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;grid-auto-rows:220px}



.galeria__fotos{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;grid-auto-rows:220px}
.photo{
  border-radius:20px;overflow:hidden;position:relative;cursor:pointer;transition:transform .4s ease, box-shadow .4s ease;
}
.photo img,
.photo span{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
}
.photo img{object-fit:cover}
.photo:hover{transform:scale(1.05);box-shadow:var(--shadow-lg)}
.photo--tall{grid-row:span 2}
.photo--wide{grid-column:span 2}
.photo--sq{grid-row:span 1}

/* ===== FAQ ===== */
.faq{padding:100px 0;background:var(--sand)}
.faq__list{display:flex;flex-direction:column;gap:12px;max-width:860px;margin-top:40px}
.faq details{background:#fff;border-radius:16px;border:1px solid var(--line);overflow:hidden;transition:box-shadow .3s}
.faq details[open]{box-shadow:var(--shadow-md)}
.faq summary{padding:22px 26px;font-weight:700;font-size:17px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:'\2b';font-family:"Font Awesome 6 Free";font-weight:900;color:var(--orange);transition:transform .3s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq p{padding:0 26px 22px;color:var(--muted);font-size:15px}

/* ===== RESERVA ===== */
.reserva{padding:140px 0 120px;background:var(--ink);color:#fff;position:relative;overflow:hidden}
.reserva::before{content:'';position:absolute;top:-200px;right:-100px;width:500px;height:500px;background:radial-gradient(circle, rgba(255,122,0,.25), transparent 65%)}
.reserva::after{content:'';position:absolute;bottom:-150px;left:-120px;width:420px;height:420px;background:radial-gradient(circle, rgba(10,186,181,.25), transparent 65%)}
.reserva__grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;position:relative;z-index:2}
.reserva__left p{color:rgba(255,255,255,.78);font-size:17px;margin-bottom:30px}
.reserva__contatos{display:flex;flex-direction:column;gap:10px}
.rc{
  display:flex;align-items:center;gap:12px;padding:14px 18px;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);
  border-radius:12px;font-weight:600;transition:all .3s;
}
.rc i{color:var(--orange-2);font-size:18px}
a.rc:hover{background:rgba(255,122,0,.15);border-color:var(--orange);transform:translateX(4px)}
.reserva__form{background:#fff;color:var(--ink);border-radius:var(--radius-lg);padding:36px;display:flex;flex-direction:column;gap:14px}
.reserva__form h3{font-family:var(--font-display);font-size:26px;margin-bottom:6px}
.reserva__form label{display:flex;flex-direction:column;gap:6px;font-weight:600;font-size:13px;color:var(--ink-2)}
.reserva__form input,.reserva__form textarea{
  padding:13px 14px;border:1.5px solid var(--line);border-radius:10px;
  font-family:inherit;font-size:15px;color:var(--ink);background:#fff;
  transition:border-color .2s, box-shadow .2s;
}
.reserva__form input:focus,.reserva__form textarea:focus{
  outline:none;border-color:var(--orange);box-shadow:0 0 0 3px rgba(255,122,0,.15);
}
.reserva__form .row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.reserva__disclaimer{color:var(--muted);font-size:12px;text-align:center;margin-top:-4px}

.chips{display:flex;flex-wrap:wrap;gap:8px;min-height:46px;padding:10px;border:1.5px dashed var(--line);border-radius:10px;background:var(--sand)}
.chips__empty{color:var(--muted);font-size:13px;font-style:italic;font-weight:400}
.chip{
  display:inline-flex;align-items:center;gap:8px;padding:6px 12px;
  background:var(--orange);color:#fff;border-radius:999px;font-size:13px;font-weight:600;
  animation:pop .3s ease;
}
@keyframes pop{from{transform:scale(.5);opacity:0}to{transform:scale(1);opacity:1}}
.chip button{color:#fff;opacity:.9;font-size:12px}
.chip button:hover{opacity:1}

@media (max-width:900px){
  .reserva{padding:100px 0 80px}
  .reserva__grid{grid-template-columns:1fr;gap:40px}
  
  .reserva__left p{font-size:16px}
  .reserva__contatos{gap:8px}
  .rc{padding:12px 16px;font-size:14px}
  
  .reserva__form{padding:28px 24px;gap:12px}
  .reserva__form h3{font-size:22px}
  .reserva__form label{font-size:12px}
  .reserva__form input,.reserva__form textarea{font-size:14px;padding:12px 12px}
  .reserva__form .row{gap:12px}
  
  .chips{gap:6px;padding:8px;min-height:42px}
  .chip{font-size:12px;padding:5px 10px}
  
  .reserva__disclaimer{font-size:11px}
}

@media (max-width:600px){
  .reserva{padding:80px 0 60px}
  .reserva__grid{gap:32px}
  .reserva__form{padding:24px 20px;gap:10px}
  .reserva__form h3{font-size:20px}
  .reserva__form input,.reserva__form textarea{padding:11px 11px;font-size:16px}
  .reserva__form label{font-size:11px}
}

@media (max-width:480px){
  .reserva__form .row{grid-template-columns:1fr}
  .reserva__form{gap:10px;padding:20px 16px}
  .chips{padding:6px;min-height:auto}
}

/* ===== PAY ===== */
.pay{padding:90px 0}

@media (max-width:700px){
  .pay{padding:70px 0}
  .pay__grid{gap:20px}
  .pay__card{padding:28px 24px}
  .pay__list{gap:8px}
  .pay__list li{padding:10px 12px;font-size:13px}
}

@media (max-width:480px){
  .pay{padding:50px 0}
  .pay__card{padding:24px 20px}
}
.pay__grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.pay__card{padding:34px;background:var(--sand);border-radius:var(--radius-lg);transition:transform .3s}
.pay__card:hover{transform:translateY(-4px)}
.pay__card h3{font-family:var(--font-display);font-size:24px;margin-bottom:18px;display:flex;align-items:center;gap:12px}
.pay__card h3 i{color:var(--orange)}
.pay__list{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.pay__list--stack{grid-template-columns:1fr}
.pay__list li{padding:12px 14px;background:#fff;border-radius:10px;font-size:14px;display:flex;gap:10px;align-items:center}
.pay__list li i{color:var(--tiffany)}
@media (max-width:800px){.pay__grid{grid-template-columns:1fr}.pay__list{grid-template-columns:1fr}}

/* ===== FOOTER ===== */
.footer{background:#0a0f16;color:rgba(255,255,255,.7);padding:70px 0 30px}

@media (max-width:700px){
  .footer{padding:60px 0 24px}
  .footer__grid{gap:32px}
}

@media (max-width:480px){
  .footer{padding:50px 0 20px}
  .footer__grid{gap:24px}
  .footer h4{font-size:18px}
  .footer a{font-size:14px}
  .footer__bottom{flex-direction:column;gap:12px;text-align:center}
}
.footer__grid{display:grid;grid-template-columns:1.3fr 1fr 1.2fr 1.2fr;gap:40px;margin-bottom:40px}
.footer__logo{height:70px;margin-bottom:18px}
.footer h4{color:#fff;font-family:var(--font-display);font-size:20px;margin-bottom:14px}
.footer a{display:block;padding:4px 0;transition:color .2s}
.footer a:hover{color:var(--orange-2)}
.footer__bottom{border-top:1px solid rgba(255,255,255,.08);padding-top:24px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:13px}
@media (max-width:800px){.footer__grid{grid-template-columns:1fr 1fr}}
@media (max-width:500px){.footer__grid{grid-template-columns:1fr}}

/* ===== WHATSAPP FLOAT ===== */
.whats-float{
  position:fixed;right:22px;bottom:22px;z-index:55;
  width:62px;height:62px;border-radius:50%;background:#25D366;color:#fff;
  display:grid;place-items:center;font-size:28px;
  box-shadow:0 18px 40px -10px rgba(37,211,102,.55);transition:transform .3s;
}
.whats-float:hover{transform:scale(1.08) rotate(-6deg)}
.whats-float__pulse{position:absolute;inset:-4px;border-radius:50%;border:2px solid #25D366;animation:whatsPulse 2s infinite}
@keyframes whatsPulse{0%{transform:scale(1);opacity:.8}100%{transform:scale(1.6);opacity:0}}

/* ===== TOAST ===== */
.toast{
  position:fixed;left:50%;bottom:100px;transform:translateX(-50%) translateY(30px);
  background:var(--ink);color:#fff;padding:14px 22px;border-radius:999px;
  font-weight:600;font-size:14px;z-index:70;opacity:0;pointer-events:none;
  transition:opacity .3s, transform .3s;box-shadow:var(--shadow-lg);
  display:flex;align-items:center;gap:10px;
}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast i{color:var(--orange-2)}

/* ===== PICKER MODAL ===== */
.picker{position:fixed;inset:0;z-index:80;display:none}
.picker.open{display:block;animation:fadeIn .25s ease}
.picker__backdrop{position:absolute;inset:0;background:rgba(10,15,22,.7);backdrop-filter:blur(6px)}
.picker__panel{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:min(560px,92vw);max-height:82vh;background:#fff;border-radius:24px;
  display:flex;flex-direction:column;overflow:hidden;box-shadow:var(--shadow-lg);
}
.picker__panel header{padding:22px 24px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--line)}
.picker__panel header h3{font-family:var(--font-display);font-size:24px}
.picker__close{width:38px;height:38px;border-radius:50%;background:var(--sand);display:grid;place-items:center}
.picker__close:hover{background:var(--line)}
.picker__list{padding:16px 24px;overflow-y:auto;display:flex;flex-direction:column;gap:8px}
.picker__item{
  display:flex;align-items:center;gap:12px;padding:14px;border-radius:12px;
  border:1.5px solid var(--line);cursor:pointer;transition:all .2s;
}
.picker__item:hover{border-color:var(--orange);background:rgba(255,122,0,.05)}
.picker__item.on{border-color:var(--orange);background:rgba(255,122,0,.08)}
.picker__item input{width:18px;height:18px;accent-color:var(--orange)}
.picker__item span{font-weight:600;flex:1}
.picker__item small{color:var(--muted);font-size:12px}
.picker__panel footer{padding:18px 24px;display:flex;justify-content:flex-end;gap:10px;border-top:1px solid var(--line)}

@media (prefers-reduced-motion: reduce){*{animation:none !important;transition:none !important}}

/* ===== Lightbox Galeria ===== */
.lightbox{position:fixed;inset:0;z-index:100;display:none;align-items:center;justify-content:center;background:rgba(0,0,0,.95);backdrop-filter:blur(8px);padding:20px}
.lightbox.open{display:flex}
.lightbox__content{position:relative;max-width:90vw;max-height:90vh}
.lightbox video{max-width:100vw;max-height:100vh;width:auto;height:auto}
.lightbox img{max-width:100vw;max-height:100vh;width:auto;height:auto}
.lightbox__close{position:absolute;top:-50px;right:0;width:44px;height:44px;border-radius:50%;background:var(--ink);color:#fff;display:grid;place-items:center;font-size:18px;cursor:pointer;transition:all .3s}
.lightbox__close:hover{transform:scale(1.1);background:var(--orange)}
