/* =========================================================
   SISTEMA DE RESERVAS — Lightbox "máquina de reservaciones"
   Teotihuacán Balloons · paleta cyan/azul/naranja
   ========================================================= */
:root{
  --rsv-ink:#0a2236; --rsv-ink2:#3d5a6c; --rsv-ink3:#8198a6;
  --rsv-cyan:#00aad5; --rsv-blue:#134668; --rsv-blue-deep:#0a2236;
  --rsv-orange:#f26c25; --rsv-orange-soft:#fff1e8;
  --rsv-cyan-soft:#e6f7fc; --rsv-line:#e3eef5; --rsv-surface:#fff; --rsv-surface2:#f3f9fc;
  --rsv-green:#1f8a5b; --rsv-radius:22px;
  --rsv-shadow:0 24px 70px rgba(10,34,54,.28);
  --rsv-fdisplay:'Playfair Display',Georgia,serif; --rsv-fbody:'DM Sans',system-ui,sans-serif;
}
/* Overlay + contenedor */
.rsv-overlay{position:fixed;inset:0;z-index:100000;background:rgba(10,34,54,.62);backdrop-filter:blur(8px);
  display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:opacity .35s ease;}
.rsv-overlay.open{opacity:1;pointer-events:auto;}
.rsv-modal{background:var(--rsv-surface);width:min(960px,100%);max-height:92vh;border-radius:28px;overflow:hidden;
  display:grid;grid-template-columns:1fr 320px;box-shadow:var(--rsv-shadow);transform:translateY(24px) scale(.97);
  transition:transform .4s cubic-bezier(.16,1,.3,1);font-family:var(--rsv-fbody);color:var(--rsv-ink);}
.rsv-overlay.open .rsv-modal{transform:none;}
@media(max-width:780px){.rsv-modal{grid-template-columns:1fr;max-height:96vh;}}

/* Panel principal (pasos) */
.rsv-main{padding:26px 30px 24px;overflow-y:auto;max-height:92vh;}
.rsv-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;}
.rsv-head .rsv-brand{display:flex;align-items:center;gap:10px;font-family:var(--rsv-fdisplay);font-weight:700;font-size:18px;color:var(--rsv-ink);}
.rsv-brand .rsv-logo{width:34px;height:34px;border-radius:50%;background:var(--rsv-cyan);display:grid;place-items:center;color:#fff;}
.rsv-close{width:38px;height:38px;border-radius:50%;background:var(--rsv-surface2);border:none;cursor:pointer;color:var(--rsv-ink2);font-size:18px;transition:all .2s;}
.rsv-close:hover{background:var(--rsv-orange-soft);color:var(--rsv-orange);transform:rotate(90deg);}

/* Stepbar */
.rsv-steps{display:flex;gap:6px;align-items:center;margin-bottom:22px;overflow-x:auto;scrollbar-width:none;}
.rsv-steps::-webkit-scrollbar{display:none;}
.rsv-step{display:flex;align-items:center;gap:7px;padding:6px 11px;border-radius:999px;font-size:12px;font-weight:600;color:var(--rsv-ink3);white-space:nowrap;flex-shrink:0;}
.rsv-step .n{width:21px;height:21px;border-radius:50%;display:grid;place-items:center;background:var(--rsv-surface2);font-size:11px;transition:all .25s;}
.rsv-step.done .n{background:var(--rsv-cyan);color:#fff;}
.rsv-step.active{background:var(--rsv-cyan-soft);color:var(--rsv-blue);}
.rsv-step.active .n{background:var(--rsv-cyan);color:#fff;box-shadow:0 0 0 4px var(--rsv-cyan-soft);}

/* Screens */
.rsv-screen{animation:rsvUp .4s cubic-bezier(.2,.7,.2,1);}
@keyframes rsvUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
.rsv-screen h3{font-family:var(--rsv-fdisplay);font-weight:700;font-size:26px;letter-spacing:-.01em;margin:0 0 4px;color:var(--rsv-ink);}
.rsv-screen .rsv-sub{color:var(--rsv-ink3);font-size:14px;margin-bottom:18px;}

/* Calendario */
.rsv-cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;}
.rsv-cal-month{font-family:var(--rsv-fdisplay);font-weight:700;font-size:19px;}
.rsv-cal-nav{display:flex;gap:6px;}
.rsv-cal-nav button{width:34px;height:34px;border-radius:10px;background:var(--rsv-surface2);border:none;cursor:pointer;color:var(--rsv-ink);transition:.2s;}
.rsv-cal-nav button:hover{background:var(--rsv-cyan-soft);color:var(--rsv-blue);}
.rsv-cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:5px;}
.rsv-dow{font-size:10.5px;color:var(--rsv-ink3);text-transform:uppercase;letter-spacing:.05em;font-weight:600;text-align:center;padding:6px 0;}
.rsv-day{aspect-ratio:1;display:grid;place-items:center;border-radius:11px;font-size:13.5px;font-weight:600;cursor:pointer;position:relative;transition:all .15s;}
.rsv-day:hover:not(.dis):not(.sel){background:var(--rsv-cyan-soft);color:var(--rsv-blue);}
.rsv-day.dis{color:var(--rsv-ink3);opacity:.32;cursor:not-allowed;}
.rsv-day.avail::after{content:'';position:absolute;bottom:5px;left:50%;transform:translateX(-50%);width:4px;height:4px;border-radius:50%;background:var(--rsv-green);}
.rsv-day.scarce::after{background:var(--rsv-orange);}
.rsv-day.sel{background:var(--rsv-cyan);color:#fff;box-shadow:0 6px 16px rgba(0,170,213,.34);}

/* Steppers pasajeros */
.rsv-pax-row{display:flex;align-items:center;justify-content:space-between;padding:16px 0;border-bottom:1px solid var(--rsv-line);}
.rsv-pax-row:last-child{border-bottom:none;}
.rsv-pax-name{font-family:var(--rsv-fdisplay);font-size:19px;font-weight:700;}
.rsv-pax-hint{color:var(--rsv-ink3);font-size:12.5px;margin-top:1px;}
.rsv-stepper{display:flex;align-items:center;gap:14px;}
.rsv-sbtn{width:38px;height:38px;border-radius:50%;background:var(--rsv-surface2);color:var(--rsv-ink);font-size:19px;font-weight:600;display:grid;place-items:center;border:none;cursor:pointer;transition:.15s;}
.rsv-sbtn:hover:not(:disabled){background:var(--rsv-cyan);color:#fff;transform:scale(1.06);}
.rsv-sbtn:disabled{opacity:.3;cursor:not-allowed;}
.rsv-sval{font-family:var(--rsv-fdisplay);font-size:23px;font-weight:700;min-width:30px;text-align:center;}

/* Horarios */
.rsv-slots{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:9px;margin-top:6px;}
.rsv-slot{padding:13px;border-radius:13px;border:1px solid var(--rsv-line);background:var(--rsv-surface);cursor:pointer;text-align:center;transition:.15s;}
.rsv-slot:hover{border-color:var(--rsv-cyan);}
.rsv-slot.sel{background:var(--rsv-blue);color:#fff;border-color:var(--rsv-blue);}
.rsv-slot .t{font-weight:700;font-size:14px;}
.rsv-slot .i{font-size:10.5px;color:var(--rsv-ink3);margin-top:2px;}
.rsv-slot.sel .i{color:rgba(255,255,255,.7);}
.rsv-slot.scarce .i{color:var(--rsv-orange);font-weight:600;}

/* Addons */
.rsv-addons{display:grid;grid-template-columns:1fr 1fr;gap:11px;}
@media(max-width:600px){.rsv-addons{grid-template-columns:1fr;}}
.rsv-addon{border:1.5px solid var(--rsv-line);border-radius:16px;padding:16px;cursor:pointer;transition:.2s;position:relative;}
.rsv-addon:hover{border-color:var(--rsv-cyan);}
.rsv-addon.sel{border-color:var(--rsv-cyan);background:linear-gradient(135deg,var(--rsv-cyan-soft),var(--rsv-surface));}
.rsv-addon .chk{width:22px;height:22px;border-radius:7px;border:1.5px solid var(--rsv-ink3);display:grid;place-items:center;margin-bottom:10px;transition:.2s;color:transparent;}
.rsv-addon.sel .chk{border-color:var(--rsv-cyan);background:var(--rsv-cyan);color:#fff;}
.rsv-addon .an{font-family:var(--rsv-fdisplay);font-weight:700;font-size:16px;margin-bottom:3px;}
.rsv-addon .ad{color:var(--rsv-ink3);font-size:12.5px;line-height:1.4;margin-bottom:8px;}
.rsv-addon .ap{font-weight:700;font-size:13.5px;color:var(--rsv-orange);}

/* Form */
.rsv-fg{display:flex;flex-direction:column;gap:5px;margin-bottom:13px;}
.rsv-fg label{font-size:11px;color:var(--rsv-ink3);font-weight:600;letter-spacing:.04em;text-transform:uppercase;}
.rsv-input{padding:13px 15px;border-radius:12px;border:1px solid var(--rsv-line);background:var(--rsv-surface);color:var(--rsv-ink);font:inherit;font-size:14.5px;transition:.15s;}
.rsv-input:focus{outline:none;border-color:var(--rsv-cyan);box-shadow:0 0 0 3px var(--rsv-cyan-soft);}
.rsv-frow{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
@media(max-width:600px){.rsv-frow{grid-template-columns:1fr;}}

/* Urgency + countdown + social proof */
.rsv-urgency{display:flex;align-items:center;gap:8px;padding:9px 13px;border-radius:11px;background:linear-gradient(90deg,var(--rsv-orange-soft),transparent);color:var(--rsv-orange);font-size:12px;font-weight:600;margin:14px 0;}
.rsv-urgency .bar{flex:1;height:5px;background:var(--rsv-orange-soft);border-radius:999px;overflow:hidden;}
.rsv-urgency .bar>div{height:100%;background:var(--rsv-orange);border-radius:999px;}
.rsv-countdown{display:flex;align-items:center;gap:8px;background:linear-gradient(90deg,var(--rsv-cyan-soft),transparent);padding:9px 13px;border-radius:11px;font-size:12px;color:var(--rsv-blue);font-weight:600;margin:8px 0 0;}
.rsv-countdown b{font-variant-numeric:tabular-nums;font-family:'JetBrains Mono',monospace;font-size:13px;}

/* Sidebar resumen */
.rsv-side{background:var(--rsv-surface2);padding:26px 24px;display:flex;flex-direction:column;border-left:1px solid var(--rsv-line);}
@media(max-width:780px){.rsv-side{border-left:none;border-top:1px solid var(--rsv-line);}}
.rsv-side-img{aspect-ratio:16/10;border-radius:14px;background-size:cover;background-position:center;margin-bottom:14px;}
.rsv-side h4{font-family:var(--rsv-fdisplay);font-size:19px;font-weight:700;margin:0 0 2px;line-height:1.1;}
.rsv-side .rsv-rate{display:flex;align-items:center;gap:5px;color:var(--rsv-ink2);font-size:12.5px;margin-bottom:14px;}
.rsv-side .rsv-rate b{color:var(--rsv-orange);}
.rsv-sline{display:flex;justify-content:space-between;font-size:13.5px;padding:6px 0;color:var(--rsv-ink2);}
.rsv-sline .v{font-weight:600;color:var(--rsv-ink);text-align:right;}
.rsv-stotal{border-top:1px dashed var(--rsv-line);margin-top:10px;padding-top:14px;display:flex;justify-content:space-between;align-items:baseline;}
.rsv-stotal .lbl{font-weight:700;}
.rsv-stotal .amt{font-family:var(--rsv-fdisplay);font-size:28px;font-weight:800;color:var(--rsv-cyan);letter-spacing:-.02em;}
.rsv-social{display:flex;align-items:center;gap:9px;margin-top:14px;padding-top:14px;border-top:1px solid var(--rsv-line);font-size:12px;color:var(--rsv-ink2);}
.rsv-av{display:flex;}
.rsv-av>span{width:26px;height:26px;border-radius:50%;border:2px solid var(--rsv-surface2);margin-left:-8px;background:linear-gradient(135deg,var(--rsv-cyan),var(--rsv-blue));display:grid;place-items:center;color:#fff;font-size:10px;font-weight:700;}
.rsv-av>span:first-child{margin-left:0;}
.rsv-trust{margin-top:auto;padding-top:16px;display:flex;flex-direction:column;gap:7px;font-size:11.5px;color:var(--rsv-ink3);}
.rsv-trust span{display:flex;align-items:center;gap:7px;}
.rsv-trust i{color:var(--rsv-green);}

/* Nav acciones */
.rsv-nav{display:flex;justify-content:space-between;align-items:center;margin-top:24px;padding-top:18px;border-top:1px solid var(--rsv-line);gap:12px;}
.rsv-btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;padding:14px 26px;border-radius:999px;font-weight:700;font-size:14.5px;border:none;cursor:pointer;transition:transform .15s,box-shadow .2s,background .2s;}
.rsv-btn-primary{background:var(--rsv-cyan);color:#fff;box-shadow:0 8px 20px rgba(0,170,213,.35);}
.rsv-btn-primary:hover{background:var(--rsv-blue);transform:translateY(-1px);box-shadow:0 12px 28px rgba(0,170,213,.42);}
.rsv-btn-primary:disabled{opacity:.4;cursor:not-allowed;transform:none;box-shadow:none;}
.rsv-btn-ghost{background:var(--rsv-surface2);color:var(--rsv-ink);}
.rsv-btn-ghost:hover{background:var(--rsv-cyan-soft);color:var(--rsv-blue);}
.rsv-btn-wa{background:#25D366;color:#fff;}

/* Ticket / confirmación */
.rsv-confirm{text-align:center;padding:8px 0;}
.rsv-check{width:74px;height:74px;border-radius:50%;background:var(--rsv-cyan);color:#fff;display:grid;place-items:center;margin:0 auto 16px;font-size:36px;animation:rsvPop .6s cubic-bezier(.34,1.56,.64,1);}
@keyframes rsvPop{from{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}
.rsv-ticket{max-width:440px;margin:18px auto 0;background:var(--rsv-surface);border:1px solid var(--rsv-line);border-radius:22px;overflow:hidden;box-shadow:var(--rsv-shadow);text-align:left;}
.rsv-ticket-top{padding:22px 26px;background:linear-gradient(135deg,var(--rsv-cyan),var(--rsv-blue));color:#fff;position:relative;}
.rsv-ticket-top::after{content:'';position:absolute;bottom:-11px;left:0;right:0;height:22px;background-image:radial-gradient(circle at 11px 11px,var(--rsv-surface) 7px,transparent 8px);background-size:22px 22px;background-repeat:repeat-x;}
.rsv-ticket-top h4{font-family:var(--rsv-fdisplay);font-size:22px;margin:0;}
.rsv-ticket-body{padding:24px 26px;}
.rsv-trow{display:flex;justify-content:space-between;padding:9px 0;border-bottom:1px dashed var(--rsv-line);font-size:13.5px;}
.rsv-trow:last-child{border-bottom:none;}
.rsv-trow .l{color:var(--rsv-ink3);}
.rsv-trow .r{font-weight:600;}
.rsv-qr{width:120px;height:120px;margin:18px auto 0;border-radius:14px;background:#fff;background-image:linear-gradient(45deg,var(--rsv-ink) 25%,transparent 25%,transparent 75%,var(--rsv-ink) 75%),linear-gradient(45deg,var(--rsv-ink) 25%,transparent 25%,transparent 75%,var(--rsv-ink) 75%);background-size:15px 15px;background-position:0 0,7.5px 7.5px;border:2px dashed var(--rsv-line);}

/* Confetti canvas */
.rsv-confetti-c{position:fixed;inset:0;pointer-events:none;z-index:100001;}

/* Botón flotante "Reservar" que puede inyectarse en tours */
.rsv-cta{display:inline-flex;align-items:center;gap:10px;background:var(--rsv-cyan);color:#fff;padding:15px 30px;border-radius:999px;font-weight:700;font-size:15px;border:none;cursor:pointer;box-shadow:0 8px 22px rgba(0,170,213,.35);transition:.2s;}
.rsv-cta:hover{background:var(--rsv-blue);transform:translateY(-2px);box-shadow:0 12px 30px rgba(0,170,213,.45);}

/* ===== Sticky booking bar (aparece al scroll en páginas de tour) ===== */
.rsv-stickybar{position:fixed;left:0;right:0;bottom:0;z-index:9998;background:rgba(255,255,255,.9);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);border-top:1px solid var(--rsv-line);box-shadow:0 -10px 34px rgba(10,34,54,.14);transform:translateY(115%);transition:transform .45s cubic-bezier(.16,1,.3,1);padding:13px 26px;display:flex;align-items:center;justify-content:space-between;gap:18px;}
.rsv-stickybar.show{transform:none;}
.rsv-stickybar .sb-l{display:flex;align-items:center;gap:14px;min-width:0;}
.rsv-stickybar .sb-thumb{width:46px;height:46px;border-radius:12px;background-size:cover;background-position:center;flex-shrink:0;}
.rsv-stickybar .sb-name{font-family:var(--rsv-fdisplay);font-weight:700;font-size:16px;color:var(--rsv-ink);line-height:1.1;}
.rsv-stickybar .sb-meta{font-size:12px;color:var(--rsv-ink3);margin-top:1px;}
.rsv-stickybar .sb-meta b{color:var(--rsv-orange);}
.rsv-stickybar .sb-r{display:flex;align-items:center;gap:18px;}
.rsv-stickybar .sb-price{font-family:var(--rsv-fdisplay);font-weight:800;font-size:23px;color:var(--rsv-cyan);letter-spacing:-.02em;white-space:nowrap;}
.rsv-stickybar .sb-price small{font-size:12px;color:var(--rsv-ink3);font-weight:400;}
.rsv-stickybar .sb-cta{background:var(--rsv-cyan);color:#fff;border:none;border-radius:999px;padding:14px 30px;font-weight:700;font-size:14.5px;cursor:pointer;white-space:nowrap;box-shadow:0 8px 22px rgba(0,170,213,.38);transition:.2s;display:inline-flex;align-items:center;gap:8px;}
.rsv-stickybar .sb-cta:hover{background:var(--rsv-blue);transform:translateY(-1px);}
@media(max-width:620px){.rsv-stickybar{padding:11px 16px;}.rsv-stickybar .sb-thumb,.rsv-stickybar .sb-meta{display:none;}.rsv-stickybar .sb-price{font-size:19px;}.rsv-stickybar .sb-cta{padding:12px 20px;}}

/* ===== Flechas "doodle" guía REALES de TuriTop (PNG/WebP del cliente) ===== */
.rsv-hint{display:flex;align-items:flex-end;gap:9px;animation:rsvHintIn .45s ease both;pointer-events:none;}
.rsv-hint-t{font-family:var(--rsv-fdisplay);font-style:italic;font-size:18px;line-height:1.1;color:var(--rsv-ink2);padding-bottom:7px;}
.rsv-doodle{height:54px;width:auto;flex-shrink:0;opacity:.85;animation:rsvDoodleIn .55s cubic-bezier(.2,.8,.3,1) both;}
@keyframes rsvDoodleIn{from{opacity:0;transform:translateY(-7px) scale(.8) rotate(-6deg);}to{opacity:.85;transform:none;}}
@keyframes rsvDoodleInFlip{from{opacity:0;transform:translateY(-7px) scaleX(-1) scale(.8) rotate(6deg);}to{opacity:.85;transform:scaleX(-1);}}
.rsv-hint-cal .rsv-doodle,.rsv-hint-extras .rsv-doodle{animation-name:rsvDoodleInFlip;}
@keyframes rsvHintIn{from{opacity:0;transform:translateY(6px);}to{opacity:1;transform:none;}}
.rsv-hint-cal{justify-content:flex-start;margin:14px 0 2px;padding-left:8px;}
.rsv-hint-time{margin:10px 0 2px;padding-left:6px;}
.rsv-hint-time .rsv-doodle{height:46px;}
.rsv-hint-extras{margin:8px 0 6px;padding-left:6px;}
.rsv-hint-extras .rsv-doodle{height:48px;}
@media(prefers-reduced-motion:reduce){.rsv-doodle,.rsv-hint{animation:none;}.rsv-hint-cal .rsv-doodle,.rsv-hint-extras .rsv-doodle{transform:scaleX(-1);}}

/* ===== FIX: evitar que el launcher de WhatsApp (.wa-float) choque con la sticky booking bar ===== */
/* La sticky bar (.rsv-stickybar) se inyecta al final del body, asi que .wa-float queda ANTES en el DOM:
   usamos :has() (order-independent) para subir el launcher SOLO cuando la barra esta visible (.show).
   En paginas donde no existe la barra (o no esta .show) esta regla no aplica y el WhatsApp queda igual. */
body:has(.rsv-stickybar.show) .wa-float{bottom:120px;transition:bottom .45s cubic-bezier(.16,1,.3,1);}
@media(max-width:620px){body:has(.rsv-stickybar.show) .wa-float{bottom:104px;}}
/* Reserva espacio a la derecha de la barra para que su CTA nunca quede bajo el circulo de WhatsApp */
.rsv-stickybar{padding-right:96px;}
@media(max-width:620px){.rsv-stickybar{padding-right:78px;}}
