
:root{
  --c-primary:#2150A8;
  --c-primary-dark:#163d80;
  --c-yellow:#F5B516;
  --c-yellow-d:#d99a0c;
  --c-text:#1b2a4a;
  --c-muted:#6b7589;
  --c-bg:#f6f8fc;
  --c-white:#fff;
  --c-success:#1f7a3a;
  --c-danger:#c0392b;
  --c-border:#e1e6f0;
  --shadow-sm:0 4px 12px rgba(20,40,80,.10);
  --shadow-md:0 6px 18px rgba(20,40,80,.15);
}
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0;font-family:'Poppins',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;color:var(--c-text);background:var(--c-bg);line-height:1.5}
img{max-width:100%;display:block}
a{color:var(--c-primary);text-decoration:none}
a:hover{text-decoration:underline}

/* === HEADER === */
.at-header{
  background:var(--c-white);
  box-shadow:0 1px 4px rgba(20,40,80,.08);
  position:sticky;top:0;z-index:100;
}
.at-header__row{
  max-width:1280px;margin:0 auto;padding:14px 24px;
  display:flex;align-items:center;gap:24px;
}
.at-logo{font-weight:800;font-size:1.3rem;color:var(--c-primary);text-decoration:none;display:flex;align-items:center;gap:8px}
.at-logo:hover{text-decoration:none}
.at-logo span.dot{width:10px;height:10px;background:var(--c-yellow);border-radius:50%}
.at-nav{display:flex;gap:4px;flex:1;justify-content:center}
.at-nav__item{position:relative}
.at-nav__link{
  display:inline-flex;align-items:center;gap:4px;
  padding:10px 14px;font-weight:600;font-size:.95rem;color:var(--c-text);
  border-radius:8px;cursor:pointer;background:none;border:none;
}
.at-nav__link:hover{background:#eaf0fa;text-decoration:none;color:var(--c-primary)}
.at-nav__caret{font-size:.7em;margin-top:2px}
.at-nav__drop{
  position:absolute;top:100%;left:0;background:var(--c-white);
  border-radius:10px;box-shadow:var(--shadow-md);padding:8px 0;
  min-width:220px;display:none;z-index:50;
}
.at-nav__item.is-open .at-nav__drop{display:block}
.at-nav__drop a{
  display:block;padding:8px 16px;color:var(--c-text);font-size:.93rem;
}
.at-nav__drop a:hover{background:#eaf0fa;color:var(--c-primary);text-decoration:none}
.at-cta{
  background:var(--c-yellow);color:var(--c-white);font-weight:700;
  padding:10px 22px;border-radius:999px;font-size:.95rem;line-height:1;
  border:none;cursor:pointer;text-decoration:none;
  display:inline-flex;align-items:center;justify-content:center;
  white-space:nowrap;
}
.at-cta:hover{background:var(--c-yellow-d);text-decoration:none;color:var(--c-white)}
.at-langs{display:flex;gap:6px;align-items:center}
.at-lang{display:inline-block;width:26px;height:18px;border-radius:3px;overflow:hidden;border:1px solid rgba(0,0,0,.15);box-shadow:0 1px 2px rgba(0,0,0,.1);text-decoration:none;line-height:0;vertical-align:middle}
.at-lang.is-active{outline:2px solid var(--c-yellow);outline-offset:1px}
.at-lang--en{background:url("/img/flags/en.svg") center/cover no-repeat;color:transparent}
.at-lang--es{background:url("/img/flags/es.svg") center/cover no-repeat;color:transparent}
.at-lang--de{background:url("/img/flags/de.svg") center/cover no-repeat;color:transparent}
.at-burger{display:none;background:none;border:none;cursor:pointer;padding:8px;font-size:1.5rem;color:var(--c-primary)}

/* MOBILE */
@media(max-width:899px){
  .at-nav{display:none;position:absolute;top:100%;left:0;right:0;background:var(--c-white);flex-direction:column;padding:12px;box-shadow:var(--shadow-sm)}
  .at-nav.is-open{display:flex}
  .at-nav__link{width:100%;text-align:left}
  .at-nav__drop{position:static;box-shadow:none;display:none;padding-left:16px}
  .at-nav__item.is-open .at-nav__drop{display:block}
  .at-burger{display:block}
  .at-cta{padding:8px 14px;font-size:.8rem;white-space:nowrap;line-height:1}
}

/* === HERO === */
.at-hero{
  position:relative;min-height:600px;
  background-size:cover;background-position:center;
  display:flex;align-items:center;justify-content:center;
  color:var(--c-white);text-align:center;padding:80px 24px;
}
.at-hero::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(20,30,60,.40) 0%,rgba(20,30,60,.30) 50%,rgba(20,30,60,.60) 100%);
}
.at-hero__inner{position:relative;z-index:2;max-width:900px}
.at-hero h1{font-size:3rem;margin:0 0 12px;font-weight:800;text-shadow:0 4px 16px rgba(0,0,0,.5)}
.at-hero__sub{font-size:1.2rem;margin:0 0 8px;opacity:.95;text-shadow:0 2px 8px rgba(0,0,0,.5)}
.at-hero__claim{font-size:1.5rem;font-style:italic;margin:24px 0;text-shadow:0 2px 8px rgba(0,0,0,.5)}
.at-hero__cta{
  display:inline-flex;background:var(--c-yellow);color:#1b2a4a;padding:18px 48px;
  border-radius:999px;font-weight:800;font-size:1.15rem;
  box-shadow:0 8px 24px rgba(245,181,22,.5);
  margin-top:16px;
}
.at-hero__cta:hover{background:var(--c-yellow-d);text-decoration:none;color:#1b2a4a;transform:translateY(-2px)}
@media(max-width:599px){
  .at-hero{min-height:480px;padding:60px 16px}
  .at-hero h1{font-size:2rem}
  .at-hero__sub{font-size:1rem}
  .at-hero__claim{font-size:1.1rem}
  .at-hero__cta{padding:14px 32px;font-size:1rem}
}

/* === SECTIONS === */
.at-section{padding:60px 24px;max-width:1280px;margin:0 auto}
.at-section h2{font-size:2rem;color:var(--c-primary);margin:0 0 12px;text-align:center}
.at-section .lead{text-align:center;color:var(--c-muted);font-size:1.05rem;margin:0 0 40px}
.at-cards{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;
}
.at-card{
  background:var(--c-primary);color:var(--c-white);
  border-radius:16px;padding:32px 24px;text-decoration:none;
  box-shadow:var(--shadow-md);
  transition:transform .15s,box-shadow .15s;
  display:flex;flex-direction:column;align-items:center;text-align:center;
}
.at-card:hover{transform:translateY(-4px);box-shadow:0 12px 28px rgba(20,40,80,.20);color:var(--c-white);text-decoration:none}
.at-card__img{
  width:96px;height:96px;background:rgba(255,255,255,.08);border-radius:50%;
  display:flex;align-items:center;justify-content:center;margin-bottom:16px;
  font-size:2.5rem;
}
.at-card h3{margin:0 0 8px;font-size:1.4rem}
.at-card p{margin:0 0 16px;font-size:.95rem;opacity:.9}
.at-card__btn{
  background:var(--c-yellow);color:#1b2a4a;font-weight:700;
  padding:10px 24px;border-radius:999px;font-size:.95rem;
  margin-top:auto;text-decoration:none;
}
.at-card__btn:hover{background:var(--c-yellow-d);text-decoration:none;color:#1b2a4a}

/* light card variant */
.at-card--light{background:var(--c-white);color:var(--c-text)}
.at-card--light h3{color:var(--c-primary)}
.at-card--light p{color:var(--c-muted);opacity:1}

/* === FOOTER === */
.at-footer{
  background:#1b2a4a;color:#cbd5e1;padding:48px 24px 24px;margin-top:60px;
}
.at-footer__row{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:32px;margin-bottom:32px}
.at-footer h4{color:var(--c-white);font-size:1rem;margin:0 0 12px}
.at-footer a{color:#cbd5e1;font-size:.9rem;display:block;margin-bottom:6px}
.at-footer a:hover{color:var(--c-yellow);text-decoration:none}
.at-footer__bottom{max-width:1280px;margin:0 auto;border-top:1px solid #2d3a5e;padding-top:16px;text-align:center;font-size:.85rem;color:#94a3b8}

/* === ATTRACTION CARDS GRID === */
.at-att-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px;margin-top:20px}
.at-att-card{
  display:block;background:#fff;border-radius:14px;overflow:hidden;
  box-shadow:var(--shadow-sm);text-decoration:none;color:inherit;
  transition:transform .15s,box-shadow .15s;
}
.at-att-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);text-decoration:none;color:inherit}
.at-att-card__img{
  width:100%;height:220px;background-size:cover;background-position:center;background-color:var(--c-primary);
}
.at-att-card__body{padding:20px}
.at-att-card__body h3{margin:0 0 8px;color:var(--c-primary);font-size:1.3rem}
.at-att-card__body p{margin:0 0 12px;color:var(--c-muted);font-size:.95rem}
.at-att-card__btn{color:var(--c-yellow-d);font-weight:700;font-size:.95rem}

/* === ATTRACTION DETAIL PAGE === */
.at-att-detail{max-width:1280px;margin:0 auto;padding:0 0 60px}
.at-att-detail__img{
  width:100%;height:420px;background-size:cover;background-position:center;
  margin-bottom:32px;background-color:var(--c-primary);
}
.at-att-detail__body{max-width:760px;margin:0 auto;padding:0 24px}
.at-att-back{display:inline-block;color:var(--c-muted);font-size:.9rem;margin-bottom:12px}
.at-att-back:hover{color:var(--c-primary);text-decoration:none}
.at-att-detail__body h1{margin:0 0 4px;color:var(--c-primary);font-size:2.5rem}
.at-att-cat{color:var(--c-yellow-d);font-weight:700;text-transform:uppercase;letter-spacing:1px;font-size:.85rem;margin-bottom:20px}
.at-att-desc{font-size:1.1rem;color:var(--c-text);margin-bottom:32px;line-height:1.6}

@media(max-width:599px){
  .at-att-detail__img{height:240px;margin-bottom:20px}
  .at-att-detail__body h1{font-size:1.8rem}
}

/* Header logo image styling */
.at-logo img{height:56px;width:auto;display:block}
@media(max-width:899px){
  .at-logo img{height:44px}
}

/* === TICKET GROUP CARDS (paso0) === */
.at-ticket-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:24px;margin-top:24px}
.at-ticket-card{
  display:flex;flex-direction:column;background:#fff;border-radius:16px;overflow:hidden;
  text-decoration:none;color:inherit;box-shadow:var(--shadow-sm);
  transition:transform .15s,box-shadow .15s;
}
.at-ticket-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);text-decoration:none;color:inherit}
.at-ticket-card__img{
  width:100%;height:200px;background-size:cover;background-position:center;background-color:var(--c-primary);
}
.at-ticket-card__body{padding:20px;display:flex;flex-direction:column;flex:1}
.at-ticket-card__body h3{margin:0 0 8px;font-size:1.3rem;color:var(--c-primary)}
.at-ticket-card__body p{margin:0 0 16px;color:var(--c-muted);font-size:.95rem;flex:1}
.at-ticket-card__btn{
  align-self:stretch;
  display:flex;align-items:center;justify-content:center;
  background:var(--c-yellow);color:#1b2a4a;
  padding:12px 22px;border-radius:999px;
  font-weight:700;font-size:1rem;line-height:1;
  text-align:center;white-space:nowrap;
  min-height:46px;margin-top:auto;
  transition:background .15s, transform .12s, box-shadow .15s;
}
.at-ticket-card__btn:hover{background:var(--c-yellow-d);transform:translateY(-1px);box-shadow:0 6px 14px rgba(0,0,0,.15);}

/* === Card with donor image (replaces emoji circle) === */
.at-card__img[style*="background-image"]{
  width:100% !important;
  height:160px !important;
  border-radius:12px !important;
  margin:0 0 16px 0 !important;
  background-color:rgba(255,255,255,0.08) !important;
}
.at-card{padding:0;overflow:hidden}
.at-card__img + h3,
.at-card__img + p,
.at-card > h3,
.at-card > p,
.at-card > .at-card__btn{
  padding-left:24px;padding-right:24px;
}
.at-card > h3{margin-top:0}
.at-card__btn{margin-bottom:24px}

/* For light variant make image have light overlay */
.at-card--light .at-card__img[style*="background-image"]{
  background-color:#eaf0fa !important;
}

/* === PASO 1 === */
.at-p1{max-width:1200px;margin:0 auto;padding:40px 24px 80px}
.at-p1-steps{display:flex;justify-content:space-between;align-items:center;background:#fff;border-radius:14px;padding:18px 24px;box-shadow:var(--shadow-sm);margin-bottom:24px;gap:12px}
.at-p1-step{display:flex;align-items:center;gap:10px;flex:1}
.at-p1-step span{
  width:32px;height:32px;border-radius:50%;background:#eaf0fa;color:var(--c-muted);
  display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.9rem;flex-shrink:0;
}
.at-p1-step.is-active span{background:var(--c-yellow);color:#fff;box-shadow:0 3px 8px rgba(245,181,22,.4)}
.at-p1-step label{font-weight:600;font-size:.9rem;color:var(--c-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.at-p1-step.is-active label{color:var(--c-text)}
@media(max-width:599px){
  .at-p1-step label{font-size:.75rem}
}

.at-p1 h1{font-size:2rem;color:var(--c-primary);margin:0 0 24px;text-align:center}

.at-p1-grid{display:grid;grid-template-columns:1fr 360px;gap:24px;align-items:start}
@media(max-width:899px){
  .at-p1-grid{grid-template-columns:1fr}
}

.at-p1-card{background:#fff;border-radius:14px;padding:20px;box-shadow:var(--shadow-sm);margin-bottom:16px}
.at-p1-card h3{margin:0 0 14px;color:var(--c-primary);font-size:1.1rem}

.at-p1-date{
  width:100%;padding:12px 14px;border:2px solid var(--c-border);border-radius:10px;font-size:1rem;font-family:inherit;color:var(--c-text);
}
.at-p1-date:focus{border-color:var(--c-yellow);outline:none}

.at-p1-residente{display:flex;justify-content:space-between;align-items:center;gap:16px}
.at-p1-residente__label{font-weight:700;color:var(--c-text);font-size:1rem;margin-bottom:4px}
.at-p1-residente__sub{font-size:.85rem;color:var(--c-muted);line-height:1.4}

.at-p1-switch{position:relative;display:inline-block;width:52px;height:30px;flex-shrink:0}
.at-p1-switch input{opacity:0;width:0;height:0}
.at-p1-switch__slider{
  position:absolute;cursor:pointer;inset:0;background:#cbd5e1;
  transition:.2s;border-radius:30px;
}
.at-p1-switch__slider:before{
  content:"";position:absolute;height:24px;width:24px;left:3px;bottom:3px;
  background:#fff;transition:.2s;border-radius:50%;box-shadow:0 2px 4px rgba(0,0,0,.2);
}
.at-p1-switch input:checked + .at-p1-switch__slider{background:var(--c-yellow)}
.at-p1-switch input:checked + .at-p1-switch__slider:before{transform:translateX(22px)}

.at-p1-ticket{display:flex;align-items:center;justify-content:space-between;padding:14px 0;border-bottom:1px dashed var(--c-border);gap:12px}
.at-p1-ticket:last-child{border-bottom:none}
.at-p1-ticket__info{flex:1}
.at-p1-ticket__name{font-weight:700;color:var(--c-text)}
.at-p1-ticket__sub{font-size:.85rem;color:var(--c-muted)}
.at-p1-ticket__price{color:var(--c-yellow-d);font-weight:700;font-size:.95rem;margin-top:2px}
.at-p1-ticket__qty{display:flex;align-items:center;gap:8px}
.at-p1-qty-btn{
  width:36px;height:36px;border-radius:50%;border:none;
  background:var(--c-yellow);color:#1b2a4a;font-weight:700;font-size:1.2rem;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
}
.at-p1-qty-btn:hover{background:var(--c-yellow-d)}
.at-p1-qty-val{min-width:30px;text-align:center;font-weight:700;font-size:1.1rem}

.at-p1-summary{background:#fff;border-radius:14px;padding:20px;box-shadow:var(--shadow-md);position:sticky;top:90px}
.at-p1-summary h3{margin:0 0 14px;color:var(--c-primary)}
.at-p1-cart-line{display:flex;justify-content:space-between;padding:6px 0;gap:8px}
.at-p1-cart-qty{background:var(--c-yellow);color:#fff;border-radius:6px;padding:1px 6px;font-weight:700;font-size:.78rem}
.at-p1-cart-name{flex:1;font-size:.92rem}
.at-p1-cart-sub{font-weight:700;font-size:.95rem}
.at-p1-cart-empty{color:var(--c-muted);font-style:italic;padding:10px 0;text-align:center;font-size:.9rem}
.at-p1-total{display:flex;justify-content:space-between;padding:14px 0;border-top:1px solid var(--c-border);margin-top:10px;font-weight:700;font-size:1.1rem;color:var(--c-primary)}
.at-p1-next{
  display:block;width:100%;padding:14px;
  background:var(--c-yellow);color:#1b2a4a;font-weight:700;font-size:1rem;
  border:none;border-radius:999px;cursor:pointer;
  box-shadow:0 4px 12px rgba(245,181,22,.4);
  margin-top:8px;transition:transform .12s;
}
.at-p1-next:not(:disabled):hover{transform:translateY(-1px)}
.at-p1-next:disabled{background:#cbd5e1;cursor:not-allowed;box-shadow:none}
.at-p1-back{display:block;text-align:center;color:var(--c-muted);margin-top:12px;font-size:.9rem}

/* === PASO 2 extras === */
.at-p2-extra{
  display:flex;background:#fff;border-radius:14px;overflow:hidden;
  box-shadow:var(--shadow-sm);margin-bottom:14px;
}
.at-p2-extra__img{width:140px;height:140px;background-size:cover;background-position:center;flex-shrink:0;background-color:#eaf0fa}
.at-p2-extra__body{padding:14px 18px;flex:1;display:flex;flex-direction:column;justify-content:center}
.at-p2-extra__name{font-weight:700;color:var(--c-text);font-size:1rem}
.at-p2-extra__sub{font-size:.85rem;color:var(--c-muted);margin-bottom:6px}
.at-p2-extra__price{color:var(--c-yellow-d);font-weight:700;margin-bottom:10px}
@media(max-width:599px){
  .at-p2-extra__img{width:90px;height:90px}
  .at-p2-extra__body{padding:10px 12px}
}

/* === PASO 3 fields === */
.at-p3-field{margin-bottom:14px;display:flex;flex-direction:column}
.at-p3-field label{font-size:.85rem;font-weight:600;color:var(--c-muted);margin-bottom:4px}
.at-p3-field input, .at-p3-field select{
  padding:12px 14px;border:2px solid var(--c-border);border-radius:10px;font-size:1rem;
  font-family:inherit;color:var(--c-text);background:#fff;
}
.at-p3-field input:focus, .at-p3-field select:focus{border-color:var(--c-yellow);outline:none}
.at-p3-row{display:flex;gap:12px}
.at-p3-error{
  background:#fee;color:#c0392b;padding:10px 14px;border-radius:8px;font-size:.9rem;margin-top:8px;
}
.at-p3-visit-row{
  background:#fef3d7;border-radius:10px;padding:10px 14px;margin-bottom:14px;
  display:flex;justify-content:space-between;align-items:center;
  font-size:.9rem;
}
.at-p3-visit-row strong{color:var(--c-text)}
.at-p3-pay-row{display:flex;gap:6px;width:100%;margin-top:14px}
.at-p3-pay{
  flex:1;padding:14px 6px;border:none;border-radius:999px;
  font:600 14px/1 system-ui,-apple-system,sans-serif;cursor:pointer;
  display:inline-flex;align-items:center;justify-content:center;gap:4px;
}
.at-p3-pay:disabled{opacity:.6;cursor:wait}
.at-p3-pay--apple{background:#000;color:#fff}
.at-p3-pay--gpay{background:#fff;color:#3c4043;border:1px solid #dadce0}
.at-p3-pay--card{background:var(--c-yellow);color:#1b2a4a}
.at-p3-pay--card:hover{background:var(--c-yellow-d)}
.at-p3-secure{font-size:.8rem;color:var(--c-muted);text-align:center;margin-top:10px}

/* cart remove button */
.at-p1-cart-line { display:flex; align-items:center; gap:8px; padding:6px 0; }
.at-p1-cart-line .at-p1-cart-qty { color:#2150A8; font-weight:700; min-width:28px; }
.at-p1-cart-line .at-p1-cart-name { flex:1; }
.at-p1-cart-line .at-p1-cart-sub { color:#2150A8; font-weight:700; }
.at-p1-cart-rm {
  width:24px; height:24px; border-radius:50%; border:none;
  background:#eef1f6; color:#7a8395; cursor:pointer;
  display:inline-flex; align-items:center; justify-content:center;
  font-size:18px; line-height:1; padding:0; margin-left:6px;
  transition:background .15s, color .15s;
}
.at-p1-cart-rm:hover { background:#F5B516; color:#fff; }

/* paso3 pay buttons v2 */
.at-p3-pay-row { display:flex; gap:8px; align-items:stretch; }
.at-p3-pay { flex:1; min-height:48px; border-radius:24px; border:1px solid transparent; cursor:pointer; display:inline-flex; align-items:center; justify-content:center; padding:0 14px; font-weight:600; font-size:14px; transition:transform .12s, box-shadow .12s; }
.at-p3-pay:hover { transform:translateY(-1px); box-shadow:0 4px 12px rgba(0,0,0,.12); }
.at-p3-pay--apple { background:#000; color:#fff; }
.at-p3-pay--gpay { background:#fff; color:#3c4043; border-color:#dadce0; }
.at-p3-pay--card { background:#F5B516; color:#1d2545; }
.at-p3-pay svg { display:block; }

/* attraction-page hero */
.at-hero--attr { min-height:460px; }
.at-hero__overlay { display:none; }
.at-hero { position:relative; }
.at-hero__inner { position:relative; z-index:1; }
.at-hero__logoimg { max-width:340px; height:auto; margin:0 auto 18px; display:block; filter:drop-shadow(0 4px 16px rgba(0,0,0,.55)); }
.at-hero__logoimg--main { max-width:340px; padding:0; background:transparent; border-radius:0; filter:drop-shadow(0 4px 18px rgba(0,0,0,.6)); }
@media (max-width:640px) { .at-hero__logoimg { max-width:200px; } .at-hero__logoimg--main { max-width:230px; padding:10px 16px; } }

/* attraction text + meta grid */
.at-attr-grid { display:grid; grid-template-columns: minmax(0,1fr) 280px; gap:32px; align-items:start; }
.at-attr-text h2 { margin-top:0; color:#2150A8; }
.at-attr-text p { line-height:1.7; color:#26313f; font-size:16px; }
.at-attr-meta { background:#f5f7fb; border-radius:14px; padding:22px; }
.at-meta-block { padding:10px 0; border-bottom:1px solid #e7eaf2; }
.at-meta-block:last-child { border-bottom:none; }
.at-meta-label { color:#7a8395; font-size:13px; text-transform:uppercase; letter-spacing:.04em; margin-bottom:4px; }
.at-meta-value a { color:#2150A8; font-weight:600; text-decoration:none; }
.at-meta-value a:hover { text-decoration:underline; }

@media (max-width:840px) { .at-attr-grid { grid-template-columns:1fr; } }

/* slider */
.at-slider-section h2 { color:#2150A8; }
.at-slider { position:relative; max-width:1080px; margin:0 auto; }
.at-slider-stage { position:relative; aspect-ratio: 16 / 9; background:#0e1626; border-radius:14px; overflow:hidden; box-shadow:0 8px 26px rgba(0,0,0,.18); }
.at-slide { position:absolute; inset:0; opacity:0; transition:opacity .35s ease; }
.at-slide.is-active { opacity:1; }
.at-slide img { width:100%; height:100%; object-fit:cover; display:block; }
.at-slider-nav { display:flex; align-items:center; justify-content:center; gap:16px; margin-top:14px; }
.at-slider-btn { width:42px; height:42px; border-radius:50%; border:none; background:#2150A8; color:#fff; font-size:24px; line-height:1; cursor:pointer; display:inline-flex; align-items:center; justify-content:center; padding:0; transition:background .15s, transform .12s; flex:none; }
.at-slider-btn:hover { background:#1a3f86; transform:translateY(-1px); }
.at-slider-dots { display:flex; gap:8px; align-items:center; }
.at-slider-dot { width:10px; height:10px; border-radius:50%; border:none; background:#cdd4e0; cursor:pointer; padding:0; transition:background .15s, transform .15s; }
.at-slider-dot.is-active { background:#F5B516; transform:scale(1.25); }
@media (max-width:520px) { .at-slider-btn { width:38px; height:38px; font-size:22px; } }

/* blog & paseanual */
.at-blog-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(290px, 1fr)); gap:22px; }

.at-blog-card:hover { transform:translateY(-2px); box-shadow:0 10px 24px rgba(0,0,0,.1); }

.at-pa-grid { display:grid; grid-template-columns:repeat(auto-fit, minmax(320px, 1fr)); gap:26px; }

/* hero badges (site-wide on home / blog / paseanual) */
.at-hero__badges--site { display:flex; align-items:center; justify-content:space-between; gap:24px; margin:8px auto 18px; max-width:1100px; }
.at-hero__badge { display:inline-block; line-height:0; transition:transform .15s; flex:0 0 auto; }
.at-hero__badge:hover { transform:translateY(-2px) scale(1.04); }
.at-hero__badge--sn img { width:160px; height:auto; filter:drop-shadow(0 4px 12px rgba(0,0,0,.5)); }
.at-hero__badge--fp img { width:150px; height:auto; filter:drop-shadow(0 4px 12px rgba(0,0,0,.5)); }
.at-hero__dragon-cta { display:inline-block; line-height:0; transition:transform .15s; flex:0 1 auto; }
.at-hero__dragon-cta:hover { transform:translateY(-2px) scale(1.03); }
.at-hero__dragon-cta img { max-width:360px; width:100%; height:auto; filter:drop-shadow(0 6px 18px rgba(0,0,0,.55)); }
@media (max-width:780px) {
  .at-hero__badges--site { gap:12px; flex-wrap:wrap; justify-content:center; }
  .at-hero__badge--sn img, .at-hero__badge--fp img { width:90px; }
  .at-hero__dragon-cta img { max-width:240px; }
}

/* home v2 */





.at-card-slim:hover { transform:translateY(-2px); box-shadow:0 10px 22px rgba(0,0,0,.10); }

.at-kingdom__grid { display:grid; grid-template-columns: minmax(0,1fr) minmax(0,1fr); gap:32px; align-items:center; }
.at-kingdom__text { text-align:center; }
.at-kingdom__text h2 { color:#2150A8; margin-top:0; }
.at-kingdom__text p { line-height:1.7; font-size:16px; color:#26313f; max-width:540px; margin-left:auto; margin-right:auto; }
.at-kingdom__text .at-cta--lg { margin-top:8px; }
.at-kingdom__img { aspect-ratio:4 / 3; border-radius:18px; background-size:cover; background-position:center; box-shadow:0 8px 24px rgba(0,0,0,.18); min-height:300px; }
@media (max-width:840px) { .at-kingdom__grid { grid-template-columns:1fr; } }

.at-vip-grid { display:grid; grid-template-columns:repeat(auto-fit, minmax(260px, 1fr)); gap:22px; }

.at-food .at-food-row { display:flex; gap:32px; align-items:center; justify-content:space-around; flex-wrap:wrap; padding:14px 0; }
.at-food-logo { display:inline-flex; align-items:center; justify-content:center; height:84px; }
.at-food-logo img { max-height:84px; max-width:140px; object-fit:contain; filter:saturate(.9); transition:transform .15s, filter .15s; }
.at-food-logo:hover img { transform:scale(1.05); filter:saturate(1); }

.at-reviews-grid { display:grid; grid-template-columns:repeat(auto-fit, minmax(260px, 1fr)); gap:18px; }
.at-review { background:#fff; border-radius:14px; padding:18px; box-shadow:0 4px 14px rgba(0,0,0,.06); display:flex; flex-direction:column; gap:10px; }
.at-review__head { display:flex; gap:10px; align-items:center; }
.at-review__head img { width:42px; height:42px; border-radius:50%; object-fit:cover; }
.at-review__head strong { display:block; color:#1d2545; font-size:14.5px; }
.at-review__date { color:#7a8395; font-size:12.5px; }
.at-review__stars { color:#F5B516; font-size:14px; letter-spacing:1px; }
.at-review p { margin:0; color:#26313f; line-height:1.55; font-size:14px; }

.at-awards { display:grid; grid-template-columns:repeat(auto-fit, minmax(220px, 1fr)); gap:24px; max-width:1080px; margin:14px auto 0; }



/* ============ Aligned cards & CTAs (v3) ============ */

/* Generic large CTA — used across the site (Book now, See more, Buy tickets…) */
.at-cta--lg {
  display:inline-flex; align-items:center; justify-content:center;
  min-height:46px; padding:0 28px;
  background:#F5B516; color:#1d2545;
  font-weight:700; font-size:15px; line-height:1;
  border:none; border-radius:30px; text-decoration:none;
  transition:background .15s, transform .12s, box-shadow .15s;
}
.at-cta--lg:hover { background:#e6a90b; transform:translateY(-1px); box-shadow:0 6px 14px rgba(0,0,0,.15); color:#1d2545; }

/* Awards row */
.at-award {
  background:#fff; border-radius:14px; padding:24px 18px;
  text-align:center; box-shadow:0 4px 14px rgba(0,0,0,.07);
  display:flex; flex-direction:column; align-items:center; justify-content:flex-start;
}
.at-award__badge {
  display:block; margin:0 auto 18px;
  height:90px; width:auto; max-width:160px;
  object-fit:contain;
}
.at-award h3 { margin:0 0 8px; font-size:16px; color:#2150A8; line-height:1.3; }
.at-award p  { margin:0; font-size:13.5px; line-height:1.5; color:#26313f; max-width:220px; }

/* VIP cards — equal height, centered text + centered button at bottom */
.at-vip-card {
  background:#fff; border-radius:14px; overflow:hidden;
  box-shadow:0 4px 16px rgba(0,0,0,.08);
  display:flex; flex-direction:column;
}
.at-vip-card__img {
  aspect-ratio:16 / 10; background-color:#0e1626;
  background-size:cover; background-position:center;
}
.at-vip-card__body {
  flex:1 1 auto;
  padding:22px 22px 24px;
  display:flex; flex-direction:column; align-items:center;
  text-align:center; gap:10px;
}
.at-vip-card__body h3 { margin:0; color:#2150A8; font-size:20px; }
.at-vip-card__body p  { margin:0; color:#26313f; line-height:1.55; font-size:14.5px; max-width:300px; }
.at-vip-card__body .at-cta--lg { margin-top:auto; align-self:center; }

/* Slim cards (attractions carousel on home) */
.at-card-slim {
  background:#fff; border-radius:14px; overflow:hidden;
  box-shadow:0 4px 14px rgba(0,0,0,.06);
  text-decoration:none; color:inherit;
  display:flex; flex-direction:column;
  transition:transform .15s, box-shadow .15s;
}
.at-card-slim:hover { transform:translateY(-2px); box-shadow:0 10px 22px rgba(0,0,0,.10); }
.at-card-slim__img { aspect-ratio:4 / 3; background-color:#0e1626; background-size:cover; background-position:center; }
.at-card-slim__body {
  flex:1 1 auto;
  padding:16px 16px 18px;
  display:flex; flex-direction:column; align-items:center;
  text-align:center; gap:6px;
}
.at-card-slim__body h3 { margin:0; color:#2150A8; font-size:17px; line-height:1.3; }
.at-card-slim__body p  { margin:0; color:#7a8395; font-size:13.5px; line-height:1.4; }
.at-card-slim__btn { color:#F5B516; font-weight:700; font-size:13.5px; margin-top:auto; padding-top:10px; }

/* Blog cards */
.at-blog-card {
  display:flex; flex-direction:column;
  background:#fff; border-radius:14px; overflow:hidden;
  box-shadow:0 4px 14px rgba(0,0,0,.06);
  text-decoration:none; color:inherit;
  transition:transform .15s, box-shadow .15s;
}
.at-blog-card:hover { transform:translateY(-2px); box-shadow:0 10px 24px rgba(0,0,0,.1); }
.at-blog-card__img { aspect-ratio: 16 / 10; background-color:#0e1626; background-size:cover; background-position:center; }
.at-blog-card__body {
  flex:1 1 auto;
  padding:18px 18px 22px;
  display:flex; flex-direction:column; align-items:center;
  text-align:center; gap:10px;
}
.at-blog-card__body h3 { margin:0; color:#2150A8; font-size:18px; line-height:1.3; }
.at-blog-card__body p  { margin:0; color:#26313f; line-height:1.55; font-size:14.5px; }
.at-blog-card__btn { margin-top:auto; color:#F5B516; font-weight:700; padding-top:6px; }

/* Paseanual cards */
.at-pa-card {
  background:#fff; border-radius:16px; overflow:hidden;
  box-shadow:0 4px 16px rgba(0,0,0,.08);
  display:flex; flex-direction:column;
}
.at-pa-card__img { aspect-ratio:16 / 9; background-size:cover; background-position:center; }
.at-pa-card__body {
  flex:1 1 auto;
  padding:24px;
  display:flex; flex-direction:column; align-items:center;
  text-align:center; gap:10px;
}
.at-pa-card__body h3 { margin:0; color:#2150A8; font-size:20px; }
.at-pa-card__body p  { margin:0; color:#26313f; line-height:1.6; }
.at-pa-card__price { margin:14px 0 18px; font-size:17px; color:#7a8395; }
.at-pa-card__price strong { color:#2150A8; font-size:24px; }
.at-pa-card__body .at-cta--lg { margin-top:auto; }





/* attractions v2 */

/* attractions v2 */
.at-hero--compact { min-height:320px; padding:48px 16px 36px; }
.at-hero--compact .at-hero__logoimg { max-width:240px; margin:0 auto 10px; }
.at-hero--compact h1 { margin:0 0 4px; font-size:34px; }
.at-hero--compact .at-hero__sub { font-size:16px; margin-bottom:4px; }
.at-hero--compact .at-hero__claim { font-size:15px; margin-bottom:18px; opacity:.95; }
.at-hero--compact .at-cta--lg { margin-top:6px; }
@media (max-width:640px) {
  .at-hero--compact { min-height:260px; padding:36px 14px 26px; }
  .at-hero--compact h1 { font-size:26px; }
  .at-hero--compact .at-hero__logoimg { max-width:180px; }
}

.at-attr-sec { padding-top:56px; padding-bottom:56px; }
.at-attr-grid { display:grid; grid-template-columns: minmax(0,1fr) minmax(0,1fr); gap:36px; align-items:start; }
.at-attr-text h2 { color:#2150A8; margin-top:0; }
.at-attr-text p { line-height:1.7; font-size:15.5px; color:#26313f; }
.at-attr-media { width:100%; max-width:560px; border-radius:14px; overflow:hidden; box-shadow:0 8px 24px rgba(0,0,0,.16); position:relative; }
.at-attr-media > img { display:block; width:100%; height:auto; max-height:420px; object-fit:cover; }
.at-attr-media .at-slider-stage { aspect-ratio: 4 / 3; max-height:420px; }
.at-attr-media .at-slider-nav { margin-top:10px; }
@media (max-width:840px) {
  .at-attr-grid { grid-template-columns:1fr; gap:24px; }
  .at-attr-media { max-width:none; }
}

.at-related-title { color:#2150A8; margin-top:0; }

/* single-image-above layout */
.at-attr-photo { max-width:920px; margin:0 auto 30px; border-radius:14px; overflow:hidden; box-shadow:0 8px 24px rgba(0,0,0,.16); }
.at-attr-photo img { display:block; width:100%; height:auto; max-height:460px; object-fit:cover; }
.at-attr-grid--narrow { grid-template-columns: minmax(0, 920px); justify-content:center; }
.at-attr-grid--narrow .at-attr-text { max-width:760px; margin:0 auto; }

/* offers + carousel arrows */








@media (max-width:640px) {
  
  
  
}

/* legacy unified */
.at-legal-content { max-width:860px; margin:0 auto; font-size:15.5px; line-height:1.7; color:#26313f; }
.at-legal-content h2 { color:#2150A8; margin-top:30px; }
.at-legal-content h3 { color:#2150A8; margin-top:22px; font-size:18px; }
.at-legal-content p { margin:10px 0 14px; }
.at-legal-content ul { margin:8px 0 18px; padding-left:20px; }
.at-legal-content li { margin-bottom:6px; }


@media (max-width:520px) {  }

/* ---- home v3 final ---- */


@media (max-width:520px){  }





@media (max-width:520px){  }
.at-offers-grid { display:grid; grid-template-columns:repeat(auto-fit, minmax(280px, 1fr)); gap:24px; }
.at-offer-price { margin:6px 0 14px; font-size:15.5px; color:#7a8395; text-align:center; }
.at-offer-price strong { color:#2150A8; font-size:22px; font-weight:800; }

/* ---- carousel polish ---- */
.at-row--scroll {
  display:flex; flex-wrap:nowrap; gap:16px;
  overflow-x:auto; padding:4px 4px 4px;
  scroll-snap-type:x mandatory; scroll-behavior:smooth;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;          /* Firefox */
  -ms-overflow-style:none;       /* IE/Edge legacy */
}
.at-row--scroll::-webkit-scrollbar { display:none; height:0; }
.at-row--scroll > .at-card-slim {
  flex:0 0 240px; width:240px; scroll-snap-align:start;
}
@media (max-width:520px){ .at-row--scroll > .at-card-slim { flex:0 0 200px; width:200px; } }

.at-row-wrap { position:relative; padding:0 34px; }
.at-row-arrow {
  position:absolute; top:50%; transform:translateY(-50%);
  width:40px; height:40px; border-radius:50%;
  border:none; background:#fff; color:#2150A8;
  font-size:22px; line-height:1; padding:0; cursor:pointer;
  z-index:5; display:inline-flex; align-items:center; justify-content:center;
  box-shadow:0 4px 14px rgba(20,40,80,.14), 0 1px 3px rgba(0,0,0,.08);
  transition:background .15s, transform .12s, box-shadow .15s, color .15s;
}
.at-row-arrow:hover {
  background:#F5B516; color:#1d2545;
  transform:translateY(-50%) scale(1.06);
  box-shadow:0 8px 20px rgba(20,40,80,.18);
}
.at-row-arrow--prev { left:0; }
.at-row-arrow--next { right:0; }
@media (max-width:520px){ .at-row-arrow { width:34px; height:34px; font-size:18px; } }


/* vip types */
.at-vip-types__item {
  display:grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap:28px; align-items:center; margin:30px 0;
  scroll-margin-top:90px;
}
.at-vip-types__item:nth-child(odd) .at-vip-types__img { order:1; }
.at-vip-types__img img { width:100%; height:auto; border-radius:14px; box-shadow:0 8px 22px rgba(0,0,0,.14); display:block; }
.at-vip-types__body h3 { color:#2150A8; margin:0 0 10px; }
.at-vip-types__body p { line-height:1.6; color:#26313f; margin:0 0 14px; }
.at-vip-types__body .at-offer-price { text-align:left; margin:0 0 6px; }
.at-vip-types__body .at-extra-pax { color:#7a8395; font-size:13.5px; margin:0 0 16px; }
.at-offer-pax { display:block; color:#7a8395; font-size:13.5px; margin-top:2px; font-weight:500; }
@media (max-width:840px){
  .at-vip-types__item { grid-template-columns:1fr; }
  .at-vip-types__item:nth-child(odd) .at-vip-types__img { order:0; }
}

/* vip includes list */
.at-vip-includes { margin:8px 0 14px; padding:0; list-style:none; text-align:left; }
.at-vip-includes li {
  position:relative; padding:4px 0 4px 22px; font-size:14px; color:#26313f; line-height:1.45;
}
.at-vip-includes li::before {
  content:""; position:absolute; left:0; top:11px;
  width:8px; height:8px; border-radius:50%; background:#F5B516;
}
.at-incl-heading { display:block; color:#2150A8; font-weight:700; margin-top:4px; }
.at-vip-card__body { align-items:stretch; text-align:left; }
.at-vip-card__body h3 { text-align:center; }
.at-vip-card__body > p { text-align:center; }
.at-vip-card__body .at-offer-price { text-align:center; margin-top:auto; }

/* paso1 rich tickets */
.at-p1-ticket { display:flex; align-items:center; gap:16px; padding:14px 0; border-top:1px solid #eef1f6; }
.at-p1-ticket:first-child { border-top:none; }
.at-p1-ticket__img {
  flex:0 0 96px; width:96px; height:96px; border-radius:10px;
  background-size:cover; background-position:center; background-color:#f0f3f8;
}
.at-p1-ticket__info { flex:1 1 auto; min-width:0; display:flex; flex-direction:column; gap:3px; }
.at-p1-ticket__name { color:#1d2545; font-weight:700; font-size:15.5px; }
.at-p1-ticket__sub { color:#7a8395; font-size:13px; }
.at-p1-ticket__desc { color:#26313f; font-size:13.5px; line-height:1.45; margin-top:4px; }
.at-p1-ticket__price { color:#F5B516; font-weight:800; font-size:16px; margin-top:6px; }
.at-p1-ticket__qty { flex:0 0 auto; display:flex; align-items:center; gap:10px; }
@media (max-width:520px) {
  .at-p1-ticket { gap:10px; padding:12px 0; }
  .at-p1-ticket__img { flex:0 0 72px; width:72px; height:72px; }
  .at-p1-ticket__desc { font-size:12.5px; }
}

/* mega nav */
.at-nav__item--mega { position:static; }
.at-nav__item--mega .at-nav__drop.at-mega {
  display:none;
  position:absolute; left:50%; transform:translateX(-50%);
  top:100%; margin-top:6px;
  flex-direction:row; gap:0;
  min-width:min(1080px, 96vw); max-width:96vw;
  padding:18px 22px; background:#fff;
  border-radius:14px; box-shadow:0 16px 36px rgba(20,40,80,.18);
}
.at-nav__item--mega.is-open .at-nav__drop.at-mega { display:flex; }
.at-mega__col { flex:1 1 0; padding:0 14px; border-right:1px solid #eef1f6; min-width:160px; }
.at-mega__col:last-child { border-right:none; }
.at-mega__head {
  display:block; font-weight:800; color:#2150A8; padding:4px 0 10px;
  border-bottom:2px solid #F5B516; margin-bottom:8px; text-decoration:none;
}
.at-mega__head:hover { color:#1a3f86; text-decoration:underline; }
.at-mega__col a { display:block; padding:5px 0; color:#1d2545; text-decoration:none; font-size:14px; }
.at-mega__col a:hover { color:#F5B516; }

@media (max-width:1000px) {
  .at-nav__item--mega .at-nav__drop.at-mega {
    position:static; transform:none; flex-direction:column; gap:8px; padding:8px 0;
    box-shadow:none; min-width:0; max-width:none; background:transparent;
  }
  .at-mega__col { border-right:none; padding:0; }
  .at-mega__head { padding:6px 0; border-bottom:1px solid #eef1f6; }
}

/* Wrapper that gets glued to the viewport bottom on mobile */
  .at-p1-summary,
  .at-p3-summary,
  aside.at-p1-summary {
    position: sticky;
    bottom: 0;
    top: auto;
    z-index: 50;
    margin: 14px 0 0;
    padding: 14px 16px;
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
    border-radius: 16px 16px 0 0;
    box-shadow: 0 -10px 30px rgba(20, 40, 80, .14);
    background: #fff;
    max-height: 70vh;
    overflow-y: auto;
    overflow-x: hidden;
    -webkit-overflow-scrolling: touch;
  }
  /* Make sure inner rows respect the box width */
  .at-p1-summary > *, .at-p3-summary > * { max-width: 100%; }
  .at-p1-cart-line, .at-p1-total, .at-p3-visit-row {
    width: 100%; max-width: 100%; box-sizing: border-box;
  }
  /* Give the page enough room so content above is not covered by the bar */
  .at-p1, .at-p2, .at-p3 { padding-bottom: 220px; }

  /* Make the most important controls bigger inside the sticky bar */
  .at-p1-summary h3,
  .at-p3-summary h3 { margin-top: 0; margin-bottom: 10px; }
  .at-p1-total { font-size: 1.05rem; padding: 10px 0; margin-top: 8px; }
  .at-p1-next, .at-p3-pay-row .at-p3-pay { min-height: 48px; }
}


/* tiny screens cta */
@media (max-width:480px){
  .at-cta{ padding:7px 12px; font-size:.78rem; }
  .at-header__row{ gap:6px; }
}


/* centered CTA in mobile */
@media (max-width:840px){
  .at-kingdom__text { text-align:center; }
  .at-kingdom__text .at-cta--lg,
  .at-attr-text .at-cta--lg {
    display:inline-flex; margin-left:auto; margin-right:auto;
  }
  .at-attr-text { text-align:center; }
  .at-vip-types__body { text-align:center; }
  .at-vip-types__body .at-cta--lg,
  .at-vip-types__body .at-vip-includes,
  .at-vip-types__body .at-offer-price { margin-left:auto; margin-right:auto; }
  .at-vip-types__body .at-vip-includes { display:inline-block; text-align:left; }
}

/* mobile viewport fit */
html, body { max-width:100%; }
img, video, iframe { max-width:100%; height:auto; }

/* keep sections from creating an inline-scroll on the body */
.at-section { padding-left:16px; padding-right:16px; }

@media (max-width:520px){
  .at-section { padding:40px 14px; }
  .at-row-wrap { padding:0 8px; }
  .at-row--scroll { padding-left:0; padding-right:0; }
  .at-row-arrow--prev { left:-4px; }
  .at-row-arrow--next { right:-4px; }
  /* header crowding */
  .at-header__row { padding:10px 14px; gap:8px; }
  /* hero text padding */
  .at-hero, .at-hero--compact { padding-left:14px !important; padding-right:14px !important; }
  /* grids that may overflow at very small width */
  .at-offers-grid, .at-blog-grid, .at-vip-grid, .at-pa-grid, .at-reviews-grid, .at-cards { gap:14px; }
}

/* hard overflow fix */
@media (max-width:999px){
  /* Mega menu: cancel min-width / max-width when it's inline on mobile */
  .at-nav__item--mega .at-nav__drop.at-mega {
    min-width:0 !important;
    max-width:none !important;
    width:100% !important;
    left:auto !important; transform:none !important;
  }
}

/* Negative-positioned arrows never poke out of the viewport */
.at-row-wrap { overflow:visible; }
@media (max-width:520px){
  .at-row-arrow--prev { left:0 !important; }
  .at-row-arrow--next { right:0 !important; }
  .at-row-wrap { padding-left:0; padding-right:0; }
}

/* Catch-all clamp */
.at-section, .at-hero, .at-hero__inner, .at-row-wrap, .at-row--scroll,
.at-offers-grid, .at-vip-grid, .at-blog-grid, .at-pa-grid, .at-reviews-grid,
.at-awards, .at-cards, .at-food-row, .at-attr-grid, .at-kingdom__grid {
  max-width:100%;
}

/* sticky paso1 fix */
@media (max-width:899px){
  .at-p1-grid { align-items:stretch !important; grid-template-rows:auto auto !important; }
}
/* the body must NOT have overflow set, otherwise sticky breaks.
   horizontal overflow must be tamed at element level only. */

/* paso3 form polish */
.at-p3-form { max-width:520px; }
.at-p3-field { margin-bottom:12px; }
.at-p3-field input,
.at-p3-field select {
  padding:10px 12px !important;
  font-size:.95rem !important;
  border-width:1.5px !important;
  border-radius:8px !important;
  height:42px !important;
  line-height:1.2 !important;
}
.at-p3-row { gap:10px; }
.at-p3-field label { font-size:.8rem; margin-bottom:3px; }

/* On mobile keep them full-width but a bit shorter */
@media (max-width:520px) {
  .at-p3-form { max-width:none; }
  .at-p3-field input,
  .at-p3-field select { height:40px !important; font-size:.92rem !important; }
}

/* paso1 compact desktop */
@media (min-width:900px){
  /* narrower left column so cards are not too wide */
  .at-p1 { max-width:1080px; }
  .at-p1-grid { grid-template-columns: minmax(0, 1fr) 340px; gap:20px; }
  .at-p1-card { padding:18px 20px; }
  /* tickets row: title/desc block constrained, gap before qty buttons stays reasonable */
  .at-p1-ticket { padding:12px 0; }
  .at-p1-ticket__info { flex:1 1 auto; min-width:0; max-width:560px; }
  .at-p1-ticket__qty { margin-left:auto; }
}

/* date input polish */
.at-p1-date {
  max-width:320px; height:44px; padding:8px 14px;
  font-size:.95rem; line-height:1.2; cursor:pointer;
  border-width:1.5px; border-radius:8px;
}
.at-p1-date::-webkit-calendar-picker-indicator {
  cursor:pointer; padding:6px; opacity:.7;
  filter:invert(20%) sepia(45%) saturate(700%) hue-rotate(190deg);
  transform:scale(1.2); transform-origin:center;
}
.at-p1-date::-webkit-calendar-picker-indicator:hover { opacity:1; }
@media (max-width:520px){ .at-p1-date { max-width:none; } }

/* paso1 steps mobile compact */
@media (max-width:599px){
  .at-p1-steps { padding:12px 14px; gap:6px; }
  .at-p1-step { gap:6px; flex:0 0 auto; }
  /* hide labels on inactive steps; only active step shows its label */
  .at-p1-step label { display:none; }
  .at-p1-step.is-active { flex:1 1 auto; }
  .at-p1-step.is-active label { display:inline; font-size:.85rem; }
  .at-p1-step span { width:28px; height:28px; font-size:.85rem; }
}

/* sticky summary mobile (collapsible) — clean v2 */
@media (max-width:899px){
  .at-p1-summary,
  aside.at-p1-summary,
  .at-p3-summary {
    position: sticky;
    bottom: 8px;
    top: auto;
    z-index: 50;
    margin: 14px auto 8px;
    padding: 18px 14px 14px;
    width: calc(100% - 16px);
    max-width: calc(100% - 16px);
    box-sizing: border-box;
    border-radius: 16px;
    box-shadow: 0 8px 30px rgba(20, 40, 80, .20);
    background: #fff;
    display: flex;
    flex-direction: column;
    gap: 8px;
    transition: max-height .25s ease;
  }
  /* COLLAPSED: hide everything except Total / Next / Pay / secure / Back */
  .at-p1-summary:not(.is-open) > h3,
  .at-p1-summary:not(.is-open) > #p1-cart,
  .at-p1-summary:not(.is-open) > #p2-cart,
  .at-p1-summary:not(.is-open) > #p3-cart,
  .at-p1-summary:not(.is-open) > #p3-visit {
    display: none !important;
  }
  /* OPEN: show full list with cap on height for scrolling */
  .at-p1-summary.is-open {
    max-height: 70vh;
    overflow-y: auto;
  }
  /* Handle pill at top */
  
  
  /* Disable stale ::after if any */
  .at-p1-summary::after,
  aside.at-p1-summary::after,
  .at-p3-summary::after { content: none; }
  /* Inner widths */
  .at-p1-summary > *, .at-p3-summary > * { max-width:100%; }
  .at-p1-cart-line, .at-p1-total, .at-p3-visit-row {
    width:100%; max-width:100%; box-sizing:border-box;
  }
  /* Reserve enough room above the sticky bar so content isn't hidden */
  .at-p1, .at-p2 { padding-bottom: 220px; }
  .at-p3 { padding-bottom: 280px; }
}

/* summary toggle hint */
@media (max-width:899px){
  .at-summary-toggle {
    display: flex; align-items: center; justify-content: center;
    gap: 6px;
    width: 100%;
    background: #eef1f6; color: #2150A8;
    border: none; border-radius: 8px;
    padding: 8px 12px; margin: 0 0 10px;
    font-size: .85rem; font-weight: 600; font-family: inherit;
    cursor: pointer; line-height: 1;
    transition: background .15s ease, color .15s ease;
  }
  .at-summary-toggle:hover { background:#dfe5ee; color:#1a3f86; }
  .at-summary-toggle .at-summary-toggle__icon {
    display:inline-block; width:0; height:0;
    border-left:5px solid transparent; border-right:5px solid transparent;
    border-bottom:6px solid #2150A8;
    transition: transform .25s ease;
  }
  .at-p1-summary.is-open .at-summary-toggle__icon { transform: rotate(180deg); }
}
/* Hide toggle on desktop — the summary stays open there */
@media (min-width:900px){
  .at-summary-toggle { display:none; }
}

/* date input mobile tappable */
@media (max-width:899px){
  .at-p1-date {
    min-height:48px; padding:10px 14px;
    font-size:16px; /* iOS won't zoom on focus when >=16px */
    appearance:none; -webkit-appearance:none;
    background-color:#fff;
  }
  /* Make the native calendar indicator a comfortable tap target */
  .at-p1-date::-webkit-calendar-picker-indicator {
    width:32px; height:32px; padding:6px;
    margin-right:-4px;
  }
}

/* resident card to bottom on mobile */
@media (max-width:899px){
  .at-p1-main { display:flex; flex-direction:column; gap:0; }
  /* Tickets card stays at order:1 (after date which is 0) */
  /* Resident card moves to bottom */
  .at-p1-main > .at-p1-card:has(.at-p1-residente) { order: 9; }
}

/* kingdom mobile fit */
@media (max-width:840px){
  .at-kingdom__grid { gap:18px; }
  .at-kingdom__text { min-width:0; width:100%; padding:0; }
  .at-kingdom__text p {
    max-width:none;
    margin-left:0; margin-right:0;
    word-wrap:break-word; overflow-wrap:break-word;
  }
  .at-kingdom__img { min-height:200px; }
}

/* sitewide mobile overflow guard */
@media (max-width:899px){

  /* Every text-containing element should wrap, never push the layout */
  .at-section, .at-section *,
  .at-hero, .at-hero *,
  .at-attr-grid, .at-attr-grid *,
  .at-attr-text, .at-attr-text *,
  .at-vip-types__body, .at-vip-types__body *,
  .at-vip-card__body, .at-vip-card__body *,
  .at-card-slim__body, .at-card-slim__body *,
  .at-blog-card__body, .at-blog-card__body *,
  .at-pa-card__body, .at-pa-card__body *,
  .at-review, .at-review *,
  .at-award, .at-award *,
  .at-footer, .at-footer *,
  .at-legal-content, .at-legal-content *,
  .at-p1-card, .at-p1-card *,
  .at-p3-form, .at-p3-form *,
  .at-p2-extra, .at-p2-extra * {
    word-wrap:break-word; overflow-wrap:break-word; min-width:0;
  }

  /* Grid children: allow shrinking below content-min */
  .at-attr-grid > *,
  .at-kingdom__grid > *,
  .at-vip-types__item > *,
  .at-vip-grid > *,
  .at-offers-grid > *,
  .at-cards > *,
  .at-reviews-grid > *,
  .at-awards > *,
  .at-blog-grid > *,
  .at-pa-grid > *,
  .at-p1-grid > * { min-width:0; }

  /* Long inline text (no spaces) — long URLs etc. */
  .at-section a, .at-section h1, .at-section h2, .at-section h3, .at-section p {
    overflow-wrap:anywhere; word-break:normal;
  }

  /* Attraction text + media: drop fixed max-widths so they fit the column */
  .at-attr-text { max-width:none; }
  .at-attr-media { max-width:none; }

  /* VIP / Pa / Blog cards inner padding tightened */
  .at-vip-card__body, .at-pa-card__body, .at-blog-card__body { padding:16px; }
  .at-vip-types__body { padding:0 4px; }

  /* Footer columns should not be narrower than 100% on mobile */
  .at-footer__row { grid-template-columns:1fr; gap:18px; }
  .at-footer__row > div { max-width:100%; }
  .at-footer__row a { display:inline-block; }

  /* Awards row tighten */
  .at-awards { grid-template-columns:repeat(auto-fit, minmax(140px, 1fr)); gap:14px; }
  .at-award__badge { height:64px; }
  .at-award p { max-width:none; font-size:13px; }

  /* Reviews tighten */
  .at-review p { font-size:13.5px; }

  /* Restaurant logos row: smaller on mobile so 5 fit nicely */
  .at-food-row { gap:18px; }
  .at-food-logo img { max-height:60px; max-width:100px; }

  /* Hero compact on small screens */
  .at-hero--compact h1 { font-size:1.8rem; }
  .at-hero--compact .at-hero__sub,
  .at-hero--compact .at-hero__claim { padding:0 8px; }

  /* Legal & long-form content: clean wrap on small screens */
  .at-legal-content { padding:0 6px; }
  .at-legal-content p, .at-legal-content li { font-size:14.5px; line-height:1.6; }
}
