/* ============================================================
   BLAU — Landing de Preventa
   Mismo sistema visual que la web principal (css/index.css)
   ============================================================ */
:root{
  --blau-50:#f4f8fb;
  --blau-100:#e6eef5;
  --blau-200:#cfdeeb;
  --blau-300:#a9c3d8;
  --blau-400:#7ea4c0;
  --blau-500:#5e86a8;
  --blau-ink:#1f2d3a;
  --blau-gold:#ffeda2;
  --blau-gold-deep:#b8920e;
  --blush:#fbeee7;
  --sand:#f6f1ea;
  --cream:#fbf7f2;
  --green:#1d7a4f;
  --line:rgba(31,45,58,.12);
  --serif:'Fraunces',Georgia,serif;
  --sans:'Inter',system-ui,-apple-system,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{font-size:100%;scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--blau-ink);background:var(--cream);line-height:1.55;-webkit-font-smoothing:antialiased;font-size:1rem}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit}
.wrap{max-width:1180px;margin:0 auto;padding:0 clamp(1rem,4vw,1.75rem)}
h1,h2,h3,h4{font-family:var(--serif);font-weight:400;letter-spacing:-.01em;line-height:1.12}
.eyebrow{font-family:var(--sans);font-size:.6875rem;letter-spacing:.26em;text-transform:uppercase;color:var(--blau-gold-deep);font-weight:600}

.btn{display:inline-flex;align-items:center;justify-content:center;padding:.875rem 1.75rem;border-radius:999px;font-size:.875rem;font-weight:500;letter-spacing:.02em;transition:all .25s ease;cursor:pointer;border:none;text-decoration:none}
.btn-primary{background:var(--blau-ink);color:var(--cream)}
.btn-primary:hover{background:var(--blau-500);transform:translateY(-1px)}
.btn-gold{background:var(--blau-gold);color:var(--blau-ink);font-weight:600}
.btn-gold:hover{background:#f5e080;transform:translateY(-2px);box-shadow:0 8px 28px rgba(255,237,162,.4)}
.btn-ghost-dark{background:transparent;color:var(--blau-ink);border:1.5px solid var(--line)}
.btn-ghost-dark:hover{border-color:var(--blau-ink);background:rgba(31,45,58,.05)}
.btn:disabled{opacity:.45;cursor:not-allowed;transform:none!important;box-shadow:none!important}

.btn-spotlight{position:relative;overflow:hidden;font-size:1rem;padding:1.05rem 2.5rem;box-shadow:0 10px 30px rgba(255,237,162,.45);animation:spotlightPulse 2.8s ease-in-out infinite}
.btn-spotlight .cta-arrow{display:inline-block;margin-left:.55em;transition:transform .25s}
.btn-spotlight:hover{transform:translateY(-3px) scale(1.02);background:#f5e080}
.btn-spotlight:hover .cta-arrow{transform:translateX(5px)}
.btn-spotlight::after{content:"";position:absolute;top:0;left:-120%;width:55%;height:100%;background:linear-gradient(120deg,transparent,rgba(255,255,255,.8),transparent);transform:skewX(-20deg);animation:spotlightShine 3.6s ease-in-out infinite}
@keyframes spotlightPulse{0%,100%{box-shadow:0 8px 24px rgba(255,237,162,.35)}50%{box-shadow:0 14px 44px rgba(255,237,162,.72)}}
@keyframes spotlightShine{0%{left:-120%}55%,100%{left:165%}}
@media(prefers-reduced-motion:reduce){.btn-spotlight{animation:none}.btn-spotlight::after{display:none}}

/* ── ANNOUNCE + NAV ── */
.announce{background:var(--blau-ink);color:var(--cream);text-align:center;padding:10px 20px;font-size:11.5px;letter-spacing:.18em;text-transform:uppercase;position:relative}
.announce::before,.announce::after{content:"";position:absolute;top:0;bottom:0;width:4px;background:var(--blau-gold)}
.announce::before{left:0}.announce::after{right:0}
.announce strong{color:var(--blau-gold)}
.nav{background:var(--cream);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:50}
.nav-inner{display:flex;align-items:center;justify-content:space-between;padding:13px 0}
.logo-img{height:36px;width:auto;display:block}
.nav-actions{display:flex;gap:10px;align-items:center}
.nav-code-btn{font-size:.8125rem;padding:.65rem 1.3rem}
@media(max-width:520px){.nav-code-btn{padding:.6rem 1rem;font-size:.75rem}.logo-img{height:30px}}

/* ── HERO ── */
.hero{background:linear-gradient(160deg,#b4d3e8 0%,#cfe3f0 38%,#e8f3f9 72%,var(--cream) 100%);overflow:hidden;position:relative}
.hero .wrap{position:relative;z-index:1}

/* Fondo ethereal: blobs orgánicos animados */
.ethereal-bg{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:0}
.ethereal-layer{position:absolute;inset:-100px;filter:url(#etherealFilter) blur(3px)}
.ethereal-mask{width:100%;height:100%;
  background:radial-gradient(ellipse 80% 75% at 68% 28%,rgba(94,134,168,.98) 0%,rgba(126,164,192,.72) 38%,rgba(169,195,216,.32) 65%,transparent 100%);
  -webkit-mask-image:url('/landing-preventa/img/ethereal-mask.png');
  mask-image:url('/landing-preventa/img/ethereal-mask.png');
  -webkit-mask-size:cover;mask-size:cover;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;-webkit-mask-position:center;mask-position:center}
.ethereal-noise{position:absolute;inset:0;background-image:url('/landing-preventa/img/ethereal-noise.png');background-size:240px;background-repeat:repeat;opacity:.20}
.ethereal-warm{position:absolute;bottom:0;left:0;right:0;height:50%;background:radial-gradient(ellipse 55% 80% at 12% 95%,rgba(255,237,162,.16) 0%,transparent 60%)}
@media(prefers-reduced-motion:reduce){.ethereal-layer{filter:blur(3px)}}
.hero-grid{display:grid;grid-template-columns:1.18fr .82fr;gap:clamp(1.5rem,4vw,3rem);align-items:center;padding:clamp(3rem,7vw,5.5rem) 0 clamp(3rem,6vw,5rem)}
.hero h1{font-size:clamp(2.4rem,5.4vw,4rem);margin:.9rem 0 1.1rem}
.hero h1 em{font-style:italic;color:var(--blau-500)}
/* Sin max-width: con la columna ancha el subtítulo entra en un solo renglón en desktop */
.hero-sub{font-size:clamp(1rem,1.6vw,1.125rem);opacity:.82;margin-bottom:1.8rem}
.hero-sub strong{color:var(--blau-gold-deep)}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;align-items:center;margin-bottom:1.6rem}
.hero-trust{display:flex;gap:22px;flex-wrap:wrap;font-size:.8125rem;opacity:.72}
.hero-trust span{display:inline-flex;align-items:center;gap:7px}
.hero-trust svg{width:15px;height:15px;stroke:var(--blau-gold-deep);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0}
.hero-media{position:relative;min-height:460px;display:flex;align-items:center;justify-content:center;perspective:1300px}
/* Stack vertical de productos: card central enfocada, vecinas escaladas e inclinadas.
   OJO: sin transform-style:preserve-3d — en un contexto 3D preservado el z-index
   se ignora y las cards semitransparentes se mezclan a través de la principal. */
.vstack{position:relative;width:min(290px,76%);aspect-ratio:4/5;touch-action:pan-x}
.vstack-card{position:absolute;inset:0;border-radius:24px;overflow:hidden;background:#fff;cursor:grab;will-change:transform,opacity;transition:transform .6s cubic-bezier(.22,1,.36,1),opacity .6s cubic-bezier(.22,1,.36,1),box-shadow .6s;backface-visibility:hidden;box-shadow:0 18px 44px rgba(31,45,58,.16)}
.vstack-card:active{cursor:grabbing}
.vstack-card img{width:100%;height:100%;object-fit:cover;pointer-events:none;user-select:none}
.vstack-card::after{content:"";position:absolute;inset-inline:0;bottom:0;height:42%;background:linear-gradient(to top,rgba(31,45,58,.28),transparent);pointer-events:none}
.vstack-dots{position:absolute;right:1%;top:50%;transform:translateY(-50%);display:flex;flex-direction:column;gap:9px;z-index:12}
.vstack-dots button{width:7px;height:7px;border-radius:99px;border:none;padding:0;background:rgba(31,45,58,.25);cursor:pointer;transition:height .35s cubic-bezier(.22,1,.36,1),background .35s}
.vstack-dots button.active{height:24px;background:var(--blau-ink)}
/* Pill de stock: prendida al borde inferior izquierdo de la card activa */
.hero-pill{position:absolute;z-index:13;left:-16px;bottom:22px;background:var(--blau-gold);color:var(--blau-ink);font-size:.75rem;font-weight:600;letter-spacing:.06em;padding:.55rem 1rem;border-radius:999px;box-shadow:0 10px 26px rgba(31,45,58,.22);transform:rotate(-2.5deg);pointer-events:none;white-space:nowrap}
@media(max-width:860px){
  .hero-grid{grid-template-columns:1fr;padding-top:2.4rem}
  .hero-media{min-height:420px;max-width:430px;margin:0 auto;width:100%}
}

/* ── BENEFIT STRIP ── */
.benefits{background:var(--blau-ink);color:var(--cream);padding:1.1rem 0}
.benefits-row{display:flex;justify-content:center;gap:clamp(1.2rem,5vw,4rem);flex-wrap:wrap;align-items:center;text-align:center}
.benefit{display:flex;align-items:center;gap:10px;font-size:.875rem;letter-spacing:.03em}
.benefit b{color:var(--blau-gold);font-weight:600}
.benefit-num{font-family:var(--serif);font-size:1.5rem;font-style:italic;color:var(--blau-gold)}

/* ── SECCIONES ── */
.section{padding:clamp(3rem,7vw,5rem) 0}
.section-head{text-align:center;max-width:620px;margin:0 auto clamp(2rem,5vw,3.2rem)}
.section-head h2{font-size:clamp(1.8rem,3.6vw,2.6rem);margin:.7rem 0 .8rem}
.section-head h2 em{font-style:italic;color:var(--blau-500)}
.section-head p{opacity:.75}

/* ── PRODUCTOS — cards interactivas con tilt 3D ── */
.products-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.4rem,3vw,2.2rem)}
@media(max-width:900px){.products-grid{grid-template-columns:1fr;max-width:400px;margin:0 auto}}
.product{position:relative}
/* La card entera abre el modal; el botón y los dots cortan la propagación */
.product-tilt{position:relative;aspect-ratio:3/4;cursor:pointer;transform-style:preserve-3d;will-change:transform;outline:none}
.product-tilt:focus-visible{outline:3px solid var(--blau-400);outline-offset:4px;border-radius:26px}
/* La imagen vive en su propio wrapper con overflow hidden, así el
   contenido glass puede flotar en 3D sin quedar recortado */
.product-media{position:absolute;inset:0;border-radius:26px;overflow:hidden;background:var(--blau-50);box-shadow:0 18px 48px rgba(31,45,58,.16)}
.product-media img{width:100%;height:100%;object-fit:cover}
.product-shade{position:absolute;inset:0;background:linear-gradient(to top,rgba(31,45,58,.62) 0%,rgba(31,45,58,.14) 40%,transparent 62%)}
.product.selected .product-media{box-shadow:0 0 0 2.5px var(--blau-gold-deep),0 18px 48px rgba(184,146,14,.24)}
.product-check{position:absolute;top:-9px;right:-9px;z-index:6;width:30px;height:30px;border-radius:50%;background:var(--blau-gold-deep);color:#fff;display:none;align-items:center;justify-content:center;font-size:15px;font-weight:700;box-shadow:0 6px 16px rgba(184,146,14,.35)}
.product.selected .product-check{display:flex}
/* Capa de contenido: flota por delante de la imagen al inclinar */
.product-layer{position:absolute;inset:0;padding:clamp(.85rem,1.6vw,1.1rem);display:flex;flex-direction:column;transform:translateZ(42px)}
.product-glass{display:flex;justify-content:space-between;align-items:flex-start;gap:.7rem;border-radius:16px;border:1px solid rgba(255,255,255,.18);background:rgba(31,45,58,.42);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);padding:.85rem 1rem;color:var(--cream)}
.product-name{font-family:var(--serif);font-weight:400;font-size:1.05rem;line-height:1.22;color:var(--cream)}
.product-sub{font-size:.6875rem;opacity:.72;margin-top:.25rem}
.product-brand{font-size:.625rem;letter-spacing:.18em;text-transform:uppercase;color:var(--blau-gold);font-weight:600;white-space:nowrap;margin-top:.25rem}
.product-pills{display:flex;gap:.5rem;align-items:center;margin-top:.7rem}
.product-price{background:var(--blau-gold);color:var(--blau-ink);font-size:.9rem;font-weight:700;padding:.4rem 1rem;border-radius:999px;box-shadow:0 8px 20px rgba(31,45,58,.18)}
.product-stock{background:rgba(255,255,255,.85);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);font-size:.625rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:.45rem .8rem;border-radius:999px;color:var(--blau-ink)}
.product-stock.low{color:#b34a00}
.product-stock.out{color:#be4646}
.product-foot{margin-top:auto;display:flex;flex-direction:column;gap:.75rem}
.product-toggle{width:100%;padding:.9rem;border-radius:999px;border:1px solid rgba(255,255,255,.28);background:rgba(31,45,58,.5);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);color:var(--cream);font-size:.85rem;font-weight:600;cursor:pointer;transition:background .25s,color .25s,border-color .25s}
.product-toggle:hover{background:var(--cream);color:var(--blau-ink);border-color:var(--cream)}
.product.selected .product-toggle{background:var(--blau-gold);border-color:var(--blau-gold);color:var(--blau-ink)}
.product-toggle:disabled{opacity:.55;cursor:not-allowed;background:rgba(31,45,58,.5);color:var(--cream)}
.product-dots{display:flex;gap:7px;justify-content:center;padding-bottom:.15rem}
.product-dots button{width:7px;height:7px;border-radius:50%;border:none;padding:0;background:rgba(251,247,242,.4);cursor:pointer;transition:transform .25s,background .25s}
.product-dots button:hover{background:rgba(251,247,242,.7)}
.product-dots button.active{background:var(--cream);transform:scale(1.3)}

/* ── STICKY BAR ── */
.sticky-bar{position:fixed;left:0;right:0;bottom:0;z-index:80;background:#fff;border-top:1px solid var(--line);box-shadow:0 -10px 40px rgba(31,45,58,.12);transform:translateY(110%);transition:transform .35s cubic-bezier(.4,0,.2,1);padding:.9rem 0;padding-bottom:calc(.9rem + env(safe-area-inset-bottom,0px))}
.sticky-bar.visible{transform:translateY(0)}
.sticky-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem}
.sticky-info{display:flex;flex-direction:column;gap:2px;min-width:0}
.sticky-count{font-size:.8125rem;opacity:.7}
.sticky-totals{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap}
.sticky-total{font-family:var(--serif);font-size:1.35rem}
.sticky-save{font-size:.78rem;font-weight:600;color:var(--green);background:#e7f5ee;padding:.2rem .65rem;border-radius:999px;white-space:nowrap}
.sticky-bar .btn{white-space:nowrap}
@media(max-width:560px){.sticky-total{font-size:1.15rem}.sticky-bar .btn{padding:.8rem 1.2rem;font-size:.8125rem}}

/* ── CÓMO FUNCIONA ── */
.steps{background:var(--blau-50)}
.steps-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(1rem,2.5vw,1.6rem)}
@media(max-width:900px){.steps-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.steps-grid{grid-template-columns:1fr}}
.step{background:#fff;border-radius:18px;padding:1.6rem 1.4rem;box-shadow:0 6px 24px rgba(31,45,58,.06);position:relative}
.step-num{font-family:var(--serif);font-style:italic;font-size:2.2rem;color:var(--blau-300);line-height:1;margin-bottom:.7rem}
.step h3{font-size:1.05rem;margin-bottom:.45rem}
.step p{font-size:.85rem;opacity:.75}
.step p strong{color:var(--blau-gold-deep)}

/* ── FAQ ── */
.faq-list{max-width:680px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{width:100%;background:none;border:none;text-align:left;font-family:var(--serif);font-size:1.05rem;color:var(--blau-ink);padding:1.15rem 2.2rem 1.15rem .2rem;cursor:pointer;position:relative}
.faq-q::after{content:"+";position:absolute;right:.4rem;top:50%;transform:translateY(-50%);font-size:1.4rem;font-family:var(--sans);font-weight:300;color:var(--blau-500);transition:transform .25s}
.faq-item.open .faq-q::after{transform:translateY(-50%) rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .3s ease;font-size:.9rem;opacity:.78;padding:0 .2rem}
.faq-item.open .faq-a{max-height:240px;padding-bottom:1.15rem}

/* ── FOOTER ── */
.footer{background:var(--blau-ink);color:var(--cream);padding:3.2rem 0 0}
.footer .logo-foot{font-family:var(--serif);font-style:italic;font-size:1.6rem;letter-spacing:.06em;margin-bottom:.6rem}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1.2fr 1fr;gap:clamp(1.6rem,4vw,2.8rem);padding-bottom:2.6rem}
.foot-logo{height:34px;width:auto;margin-bottom:1rem}
.foot-brand p{font-size:.8125rem;opacity:.65;line-height:1.7;max-width:30ch}
.foot-col h4{font-family:var(--sans);font-size:.6875rem;letter-spacing:.22em;text-transform:uppercase;color:var(--blau-gold);font-weight:600;margin-bottom:.9rem}
.foot-col a,.foot-col span{display:block;font-size:.84rem;opacity:.72;padding:.26rem 0}
.foot-col a:hover{opacity:1;color:var(--blau-gold)}
.foot-link-btn{display:block;background:none;border:none;color:var(--cream);font-family:var(--sans);font-size:.84rem;opacity:.72;padding:.26rem 0;cursor:pointer;text-align:left}
.foot-link-btn:hover{opacity:1;color:var(--blau-gold)}
.foot-bottom{border-top:1px solid rgba(251,247,242,.14);padding:1.2rem 0 1.4rem;display:flex;justify-content:space-between;align-items:center;gap:.8rem;flex-wrap:wrap}
.foot-bottom span{font-size:.75rem;opacity:.5}
@media(max-width:860px){.foot-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.foot-grid{grid-template-columns:1fr}.foot-bottom{flex-direction:column;align-items:flex-start}}

/* ── MODALES ── */
.modal-backdrop{position:fixed;inset:0;background:rgba(31,45,58,.55);backdrop-filter:blur(5px);z-index:100;opacity:0;pointer-events:none;transition:opacity .3s;display:flex;align-items:center;justify-content:center;padding:1rem}
.modal-backdrop.open{opacity:1;pointer-events:auto}
.modal{background:var(--cream);border-radius:22px;width:min(520px,100%);max-height:92dvh;overflow-y:auto;box-shadow:0 30px 80px rgba(31,45,58,.3);transform:translateY(16px) scale(.98);transition:transform .3s;position:relative}
.modal-backdrop.open .modal{transform:none}
.modal-accent{height:4px;background:linear-gradient(90deg,var(--blau-gold) 0%,var(--blau-400) 60%,var(--blau-gold) 100%);border-radius:22px 22px 0 0}
.modal-close{position:absolute;top:14px;right:16px;background:none;border:none;font-size:26px;cursor:pointer;color:var(--blau-ink);opacity:.45;line-height:1;padding:6px;transition:opacity .2s;z-index:2}
.modal-close:hover{opacity:1}
.modal-body{padding:2rem 2rem 2.2rem}
@media(max-width:520px){.modal-body{padding:1.6rem 1.3rem 1.8rem}}
.modal h3{font-size:1.5rem;margin-bottom:.5rem}
.modal h3 em{font-style:italic;color:var(--blau-500)}
.modal-sub{font-size:.9rem;opacity:.75;margin-bottom:1.4rem}

.form-field{margin-bottom:1rem}
.form-field label{display:block;font-size:.75rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;margin-bottom:.4rem;opacity:.7}
.form-field input,.form-field select{width:100%;padding:.85rem 1rem;border-radius:12px;border:1.5px solid var(--line);background:#fff;font-size:.95rem;font-family:var(--sans);color:var(--blau-ink);transition:border-color .2s}
.form-field input:focus,.form-field select:focus{outline:none;border-color:var(--blau-400)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:.8rem}
@media(max-width:440px){.form-row{grid-template-columns:1fr}}
.form-error{display:none;font-size:.85rem;color:#be4646;background:#fdf0f0;border-radius:10px;padding:.7rem 1rem;margin-bottom:1rem}
.form-error.visible{display:block}
.form-note{font-size:.78rem;opacity:.6;margin-top:.8rem;text-align:center}

/* ── MODAL DETALLE DE PRODUCTO ── */
.modal-product{width:min(940px,100%)}
.pm-body{padding:1.8rem}
@media(max-width:520px){.pm-body{padding:1.4rem 1.1rem 1.6rem}}
.pm-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(1.2rem,3vw,2rem)}
@media(max-width:760px){.pm-grid{grid-template-columns:1fr}}
.pm-main{aspect-ratio:1;border-radius:16px;overflow:hidden;background:var(--blau-50);margin-bottom:.7rem}
.pm-main img{width:100%;height:100%;object-fit:cover}
.pm-thumbs{display:grid;grid-template-columns:repeat(6,1fr);gap:.5rem}
.pm-thumb{aspect-ratio:1;border-radius:10px;overflow:hidden;background:var(--blau-50);border:2px solid transparent;cursor:pointer;padding:0;transition:border-color .2s}
.pm-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.pm-thumb.active{border-color:var(--blau-gold-deep)}
.pm-info h3{font-size:1.45rem;line-height:1.2;margin-bottom:.2rem}
.pm-size{font-size:.8125rem;opacity:.55;margin-bottom:.8rem}
.pm-info .product-skin{display:inline-block;font-size:.75rem;background:var(--blau-50);border:1px solid var(--blau-200);color:var(--blau-500);border-radius:999px;padding:.35rem .85rem;margin-bottom:1rem}
.pm-desc{font-size:.9rem;opacity:.8;margin-bottom:1.1rem}
.pm-specs{margin-bottom:1.3rem}
.pm-spec{margin-bottom:1rem}
.pm-spec h5{font-family:var(--sans);font-size:.6875rem;letter-spacing:.2em;text-transform:uppercase;color:var(--blau-gold-deep);font-weight:600;margin-bottom:.35rem}
.pm-spec p{font-size:.85rem;opacity:.8}
.pm-spec ul{list-style:none;font-size:.85rem}
.pm-spec li{display:flex;gap:8px;padding:.16rem 0;opacity:.82}
.pm-spec li::before{content:"✦";color:var(--blau-gold-deep);font-size:.7rem;margin-top:.12rem}
.pm-foot{border-top:1px solid var(--line);padding-top:1.1rem}
.pm-price{font-family:var(--serif);font-size:1.7rem;margin-bottom:.9rem}
.pm-actions{display:flex;gap:.7rem;flex-wrap:wrap}
.pm-actions .btn{flex:1;white-space:nowrap}

/* Resumen de selección dentro de modales */
.sel-summary{background:#fff;border:1px solid var(--line);border-radius:14px;padding:1rem 1.2rem;margin-bottom:1.2rem}
.sel-line{display:flex;justify-content:space-between;gap:12px;font-size:.875rem;padding:.3rem 0}
.sel-line .name{opacity:.85}
.sel-line.total{border-top:1px solid var(--line);margin-top:.5rem;padding-top:.7rem;font-weight:600;font-size:1rem}
.sel-line.save{color:var(--green);font-weight:600}
.sel-line.ship-free{color:var(--green);font-weight:600}

/* Código de reserva (success) */
.code-display{text-align:center;padding:.6rem 0 .2rem}
.code-display .big-code{display:inline-block;background:var(--blau-gold);color:var(--blau-ink);font-family:'Courier New',monospace;font-size:1.7rem;font-weight:700;letter-spacing:.14em;padding:1rem 2rem;border-radius:14px;margin:.8rem 0 1rem;user-select:all}
.code-display p{font-size:.9rem;opacity:.78;max-width:38ch;margin:0 auto .6rem}
.success-icon{width:54px;height:54px;border-radius:50%;background:#e7f5ee;color:var(--green);display:flex;align-items:center;justify-content:center;font-size:26px;margin:0 auto .8rem}

/* Pasos checkout */
.co-steps{display:flex;gap:6px;margin-bottom:1.4rem}
.co-step-dot{flex:1;height:4px;border-radius:99px;background:var(--blau-100);transition:background .3s}
.co-step-dot.active{background:var(--blau-gold-deep)}
.countdown-pill{display:inline-flex;align-items:center;gap:8px;background:#fdf6dd;border:1px solid var(--blau-gold);color:var(--blau-gold-deep);font-size:.8125rem;font-weight:600;border-radius:999px;padding:.45rem 1rem;margin-bottom:1.1rem}

#cardPaymentBrick_container{min-height:280px}
.pay-error{display:none;font-size:.875rem;color:#be4646;background:#fdf0f0;border-radius:10px;padding:.75rem 1rem;margin-top:.8rem}

/* util */
.hidden{display:none!important}
.spin{display:inline-block;width:16px;height:16px;border:2px solid rgba(31,45,58,.25);border-top-color:var(--blau-ink);border-radius:50%;animation:spin .7s linear infinite;vertical-align:-3px;margin-right:8px}
@keyframes spin{to{transform:rotate(360deg)}}
