body .wrapper .block { padding: 20px 20px; scroll-margin-top: 116px; }
/* offset de salto para que el heading no quede bajo el header sticky (móvil = 2 filas) */
body.admin-bar .wrapper .block,
body.admin-bar .wrapper .bonus-card.facutron-bonus { scroll-margin-top: 162px; }
body .wrapper .block-alt { background-image: linear-gradient(180deg, #160626 0%, #11041d 100%); }
body .wrapper .block .block-inner { max-width: 1100px; margin: 0 auto; }
body .wrapper .block .block-title { font-size: 28px; line-height: 1.15; font-weight: 800; letter-spacing: -0.4px; color: #ffffff; margin-bottom: 16px; }
body .wrapper .block .block-lead { font-size: 16px; line-height: 1.6; color: #D4C5E9; max-width: 720px; margin-bottom: 18px; }
body .wrapper .block .block-lead strong { color: #ffffff; }
body .wrapper .block p { font-size: 16px; line-height: 1.65; color: #CFC0E6; margin-bottom: 14px; }
body .wrapper .block p strong { color: #ffffff; }

/* shared shot placeholders */
body .wrapper .shot .shot-frame { position: relative; border: 2px dashed rgba(255, 87, 255, 0.4); border-radius: 16px; background-image: repeating-linear-gradient(135deg, rgba(255, 87, 255, 0.05) 0px, rgba(255, 87, 255, 0.05) 12px, rgba(255, 255, 255, 0.02) 12px, rgba(255, 255, 255, 0.02) 24px); aspect-ratio: 16 / 10; display: flex; align-items: center; justify-content: center; padding: 18px; }
body .wrapper .shot .shot-frame .shot-inner { display: inline-flex; flex-direction: column; align-items: center; gap: 10px; text-align: center; }
body .wrapper .shot .shot-frame .shot-label { font-size: 13px; font-weight: 700; color: #E2B8F0; max-width: 240px; line-height: 1.4; }
body .wrapper .shot-tall .shot-frame { aspect-ratio: 4 / 5; }
body .wrapper .shot img { width: 100%; height: auto; border-radius: 16px; border: 1px solid rgba(255, 87, 255, 0.28); }
body .wrapper .shot figcaption { font-size: 13px; line-height: 1.5; color: #A593C6; margin-top: 10px; text-align: center; }

/* respuesta rapida + captura del casino */
body .wrapper .answer-block { padding-top: 12px; }
body .wrapper .answer-block .shot { max-width: 820px; margin: 8px auto 0; }

/* split layout */
body .wrapper .block-split { display: grid; grid-template-columns: 1fr; gap: 30px; }
body .wrapper .block-split .block-text { min-width: 0; }

/* shared values */
body .wrapper .sub-heading { font-size: 19px; font-weight: 800; color: #ffffff; margin: 6px 0 16px; }
body .wrapper .values-list { display: grid; grid-template-columns: 1fr; gap: 14px; margin-bottom: 30px; }
body .wrapper .values-list .value { display: flex; align-items: flex-start; gap: 14px; background-color: rgba(255, 255, 255, 0.04); border: 1px solid rgba(255, 87, 255, 0.2); border-radius: 14px; padding: 18px; }
body .wrapper .values-list .value .value-icon { flex: none; display: flex; align-items: center; justify-content: center; width: 42px; height: 42px; border-radius: 12px; background-image: linear-gradient(135deg, #A608FF, #6E00C9); }
body .wrapper .values-list .value .value-title { font-size: 16px; font-weight: 800; color: #ffffff; margin-bottom: 5px; }
body .wrapper .values-list .value .value-body p { margin-bottom: 0; font-size: 14px; line-height: 1.5; color: #CFC0E6; }

/* interactive timeline */
body .wrapper .timeline { margin-top: 6px; }
body .wrapper .timeline .tl-track { position: relative; display: flex; gap: 12px; overflow-x: auto; padding: 8px 4px 18px; scrollbar-width: none; }
body .wrapper .timeline .tl-track::-webkit-scrollbar { display: none; }
body .wrapper .timeline .tl-track::before { content: ""; position: absolute; left: 12px; right: 12px; top: 17px; height: 2px; background-color: rgba(255, 87, 255, 0.25); z-index: 0; }
body .wrapper .timeline .tl-node { position: relative; z-index: 1; display: flex; flex-direction: column; align-items: center; gap: 9px; flex: 1 0 100px; cursor: pointer; -webkit-user-select: none; user-select: none; }
body .wrapper .timeline .tl-node .tl-dot { width: 16px; height: 16px; border-radius: 999px; background-color: #1c0833; border: 2px solid rgba(255, 87, 255, 0.5); transition: transform 0.2s ease, border-color 0.2s ease; }
body .wrapper .timeline .tl-node .tl-year { font-size: 16px; font-weight: 800; color: #C7B3E6; transition: color 0.2s ease; }
body .wrapper .timeline .tl-node.active .tl-dot { background-image: linear-gradient(135deg, #FFD166, #FF8BFF); border-color: #FFD166; transform: scale(1.3); }
body .wrapper .timeline .tl-node.active .tl-year { color: #ffffff; }
body .wrapper .timeline .tl-node:hover .tl-year { color: #FF8BFF; }
body .wrapper .timeline .tl-panel { display: none; background-color: rgba(255, 255, 255, 0.04); border: 1px solid rgba(255, 87, 255, 0.2); border-left: 3px solid #FF57FF; border-radius: 14px; padding: 20px; }
body .wrapper .timeline .tl-panel.active { display: block; animation: tlFade 0.35s ease; }
body .wrapper .timeline .tl-panel .tl-title { font-size: 18px; font-weight: 800; color: #ffffff; margin-bottom: 6px; }
body .wrapper .timeline .tl-panel p { margin-bottom: 0; font-size: 15px; line-height: 1.6; color: #CFC0E6; }
@keyframes tlFade { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }

/* facutron showcase */
body .wrapper .facutron .facutron-head { margin-bottom: 14px; }
body .wrapper .facutron-showcase { display: grid; grid-template-columns: 1fr; gap: 20px; margin-top: 4px; }
body .wrapper .slot-showcase { position: relative; margin: 0; }
body .wrapper .slot-showcase::before { content: ""; position: absolute; left: 50%; top: 50%; width: 88%; height: 78%; transform: translate(-50%, -50%); background-image: radial-gradient(circle, rgba(255, 87, 255, 0.5), rgba(166, 8, 255, 0) 70%); filter: blur(46px); z-index: 0; }
body .wrapper .slot-showcase img { position: relative; z-index: 1; width: 100%; height: auto; border-radius: 16px; border: 1px solid rgba(255, 87, 255, 0.4); box-shadow: 0 24px 60px rgba(8, 1, 18, 0.6); }
body .wrapper .slot-showcase figcaption { position: relative; z-index: 1; font-size: 13px; line-height: 1.5; color: #A593C6; margin-top: 12px; }
/* móvil: una sola línea, scroll horizontal con swipe (scrollbar oculta) */
body .wrapper .spec-chips { display: flex; flex-wrap: nowrap; gap: 10px; margin: 0 0 24px; overflow-x: auto; scrollbar-width: none; -webkit-overflow-scrolling: touch; padding-bottom: 2px; }
body .wrapper .spec-chips::-webkit-scrollbar { display: none; }
body .wrapper .spec-chips .spec-chip { display: inline-flex; align-items: center; gap: 8px; flex: 0 0 auto; white-space: nowrap; background-color: rgba(255, 255, 255, 0.04); border: 1px solid rgba(255, 87, 255, 0.22); border-radius: 999px; padding: 9px 16px; }
body .wrapper .spec-chips .spec-chip .spec-label { font-size: 11px; font-weight: 800; letter-spacing: 0.8px; text-transform: uppercase; color: #FF8BFF; }
body .wrapper .spec-chips .spec-chip .spec-value { font-size: 13px; font-weight: 700; color: #ffffff; }
body .wrapper .bonus-card.facutron-bonus { margin: 0; padding: 18px; display: flex; flex-direction: column; justify-content: space-between; gap: 12px; text-align: left; scroll-margin-top: 116px; }
body .wrapper .bonus-card.facutron-bonus .bonus-head { display: flex; align-items: center; gap: 14px; }
body .wrapper .bonus-card.facutron-bonus .bonus-cover { flex: none; width: 104px; border-radius: 12px; overflow: hidden; border: 1px solid rgba(255, 87, 255, 0.3); line-height: 0; }
body .wrapper .bonus-card.facutron-bonus .bonus-cover img { display: block; width: 100%; height: auto; }
body .wrapper .bonus-card.facutron-bonus .bonus-main { margin-bottom: 0; }
body .wrapper .bonus-card.facutron-bonus .bonus-amount { display: block; font-size: 26px; font-weight: 800; line-height: 1.05; color: #ffffff; }
body .wrapper .bonus-card.facutron-bonus .bonus-game { display: block; font-size: 14px; font-weight: 600; color: #FFD9FF; margin-top: 4px; }
body .wrapper .bonus-card.facutron-bonus .bonus-terms { display: flex; flex-direction: column; gap: 9px; margin-bottom: 0; text-align: center; }
body .wrapper .bonus-card.facutron-bonus .bonus-terms li { display: flex; align-items: center; justify-content: center; gap: 9px; font-size: 13px; color: #ECE0F8; }
body .wrapper .bonus-card.facutron-bonus .bonus-cta { margin-top: 2px; }
body .wrapper .bonus-card.facutron-bonus .bonus-cta .cta-button { display: flex; width: 100%; justify-content: center; padding: 13px 18px; }

/* game grid */
body .wrapper .game-grid { display: grid; grid-template-columns: 1fr; gap: 16px; }
body .wrapper .game-grid-2 { max-width: 760px; margin-left: auto; margin-right: auto; }
body .wrapper .game-grid .game-card .game-logo { display: flex; align-items: center; justify-content: center; min-height: 76px; margin-bottom: 16px; }
body .wrapper .game-grid .game-card .game-logo .game-logo-ph { display: inline-flex; align-items: center; gap: 8px; padding: 12px 16px; border: 2px dashed rgba(255, 87, 255, 0.4); border-radius: 12px; font-size: 12px; font-weight: 700; color: #E2B8F0; }
body .wrapper .game-grid .game-card .game-logo img { width: auto; max-height: 132px; border-radius: 12px; }
body .wrapper .game-grid .game-card { position: relative; background-image: linear-gradient(165deg, rgba(166, 8, 255, 0.16), rgba(22, 6, 38, 0.9)); border: 1px solid rgba(255, 87, 255, 0.24); border-radius: 16px; padding: 22px; }
body .wrapper .game-grid .game-card .game-badge { display: inline-block; font-size: 11px; font-weight: 800; letter-spacing: 1px; text-transform: uppercase; color: #16041f; background-color: #FFD166; padding: 5px 10px; border-radius: 999px; margin-bottom: 12px; }
body .wrapper .game-grid .game-card .game-title { font-size: 20px; font-weight: 800; color: #ffffff; margin-bottom: 8px; }
body .wrapper .game-grid .game-card p { margin-bottom: 0; font-size: 14px; color: #CFC0E6; }

/* bonus card */
body .wrapper .bonus-card { background-image: linear-gradient(160deg, rgba(166, 8, 255, 0.3), rgba(28, 8, 51, 0.94)); border: 1px solid rgba(255, 87, 255, 0.36); border-radius: 22px; padding: 26px; max-width: 560px; box-shadow: 0 24px 60px rgba(8, 1, 18, 0.5); }
body .wrapper .bonus-card .bonus-main { text-align: center; margin-bottom: 18px; }
body .wrapper .bonus-card .bonus-amount { display: block; font-size: 34px; font-weight: 800; line-height: 1.05; color: #ffffff; }
body .wrapper .bonus-card .bonus-game { display: block; font-size: 15px; font-weight: 600; color: #FFD9FF; margin-top: 4px; }
body .wrapper .bonus-card .bonus-terms { display: flex; flex-direction: column; gap: 10px; margin-bottom: 20px; }
body .wrapper .bonus-card .bonus-terms li { display: flex; align-items: center; gap: 10px; font-size: 15px; color: #E7DAF6; }
body .wrapper .bonus-card .bonus-cta { margin-bottom: 12px; }
body .wrapper .bonus-card .bonus-foot { font-size: 11px; line-height: 1.5; color: #BCA9D8; text-align: center; }

/* steps */
body .wrapper .steps { display: grid; grid-template-columns: 1fr; gap: 14px; }
body .wrapper .steps .step { display: flex; align-items: flex-start; gap: 16px; background-color: rgba(255, 255, 255, 0.03); border: 1px solid rgba(255, 87, 255, 0.18); border-radius: 14px; padding: 18px; }
body .wrapper .steps .step .step-num { flex: none; width: 38px; height: 38px; display: flex; align-items: center; justify-content: center; font-size: 18px; font-weight: 800; color: #ffffff; background-image: linear-gradient(135deg, #A608FF, #6E00C9); border-radius: 999px; }
body .wrapper .steps .step .step-head { font-size: 17px; font-weight: 800; color: #ffffff; margin-bottom: 4px; }
body .wrapper .steps .step .step-body p { margin-bottom: 0; font-size: 15px; color: #CFC0E6; }

/* register layout + step carousel */
body .wrapper .register-layout { display: grid; grid-template-columns: 1fr; gap: 24px; }
body .wrapper .register-layout .steps .step { cursor: pointer; transition: border-color 0.2s ease, background-color 0.2s ease; }
body .wrapper .register-layout .steps .step.is-active { border-color: rgba(255, 87, 255, 0.6); background-color: rgba(255, 87, 255, 0.1); }
body .wrapper .step-carousel { display: flex; flex-direction: column; }
body .wrapper .step-carousel .step-frame { max-width: 230px; margin: 0 auto; aspect-ratio: 1 / 1.9; overflow: hidden; border-radius: 22px; border: 2px solid rgba(255, 87, 255, 0.4); background-color: #0c0216; box-shadow: 0 18px 44px rgba(8, 1, 18, 0.5); }
body .wrapper .step-carousel .step-track { display: flex; height: 100%; transition: transform 0.4s ease; }
body .wrapper .step-carousel .step-slide { flex: 0 0 100%; height: 100%; }
body .wrapper .step-carousel .step-slide img { display: block; width: 100%; height: 100%; object-fit: cover; }
body .wrapper .step-carousel .step-slide .step-ph { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 14px; height: 100%; padding: 18px; text-align: center; background-image: repeating-linear-gradient(135deg, rgba(255, 87, 255, 0.06) 0px, rgba(255, 87, 255, 0.06) 12px, rgba(255, 255, 255, 0.02) 12px, rgba(255, 255, 255, 0.02) 24px); }
body .wrapper .step-carousel .step-slide .step-ph .step-ph-num { display: flex; align-items: center; justify-content: center; width: 46px; height: 46px; border-radius: 999px; font-size: 20px; font-weight: 800; color: #ffffff; background-image: linear-gradient(135deg, #A608FF, #6E00C9); }
body .wrapper .step-carousel .step-slide .step-ph .step-ph-label { font-size: 13px; font-weight: 700; line-height: 1.4; color: #E2B8F0; max-width: 170px; }
body .wrapper .step-carousel .carousel-bar { display: flex; align-items: center; justify-content: center; gap: 14px; margin-top: 16px; }
body .wrapper .step-carousel .carousel-arrow { display: inline-flex; align-items: center; justify-content: center; flex: none; width: 40px; height: 40px; border-radius: 999px; cursor: pointer; background-image: linear-gradient(135deg, #A608FF, #6E00C9); box-shadow: 0 6px 16px rgba(166, 8, 255, 0.45); transition: transform 0.18s ease; }
body .wrapper .step-carousel .carousel-arrow:hover { transform: translateY(-2px); }
body .wrapper .step-carousel .carousel-status { font-size: 13px; font-weight: 700; color: #ECE0F8; text-align: center; min-width: 190px; }
body .wrapper .step-carousel .register-cta { width: 100%; max-width: 230px; margin: 18px auto 0; }

/* reasons */
body .wrapper .reason-grid { display: grid; grid-template-columns: 1fr; gap: 16px; }
body .wrapper .reason-grid .reason-card { display: flex; align-items: flex-start; gap: 14px; background-color: rgba(255, 255, 255, 0.04); border: 1px solid rgba(255, 87, 255, 0.2); border-radius: 16px; padding: 20px; }
body .wrapper .reason-grid .reason-card .reason-icon { flex: none; display: flex; align-items: center; justify-content: center; width: 46px; height: 46px; border-radius: 12px; background-image: linear-gradient(135deg, #A608FF, #6E00C9); }
body .wrapper .reason-grid .reason-card .reason-title { font-size: 17px; font-weight: 800; color: #FF8BFF; margin-bottom: 6px; }
body .wrapper .reason-grid .reason-card .reason-body p { margin-bottom: 0; font-size: 14px; line-height: 1.55; color: #CFC0E6; }

/* final cta */
body .wrapper .final-cta { padding: 44px 20px; background-image: radial-gradient(100% 120% at 50% 0%, rgba(255, 87, 255, 0.2), rgba(18, 3, 32, 0) 60%), linear-gradient(180deg, #1c0734, #120320); text-align: center; }
body .wrapper .final-cta .final-inner { max-width: 680px; margin: 0 auto; }
body .wrapper .final-cta .final-title { font-size: 30px; font-weight: 800; color: #ffffff; margin-bottom: 14px; }
body .wrapper .final-cta .final-text { font-size: 17px; line-height: 1.55; color: #D9CBEC; margin-bottom: 26px; }
body .wrapper .final-cta .final-actions { display: flex; justify-content: center; margin-bottom: 18px; }
body .wrapper .final-cta .final-foot { font-size: 12px; color: #B7A6D3; }

@media (min-width: 768px) {
  body .wrapper .block { padding: 28px 30px; }
  body .wrapper .block .block-title { font-size: 34px; }
  body .wrapper .values-list { grid-template-columns: repeat(3, 1fr); }
  body .wrapper .spec-chips { flex-wrap: wrap; justify-content: center; overflow: visible; }
  body .wrapper .facutron-showcase { grid-template-columns: 1fr 1.4fr; align-items: stretch; gap: 26px; }
  body .wrapper .game-grid { grid-template-columns: repeat(3, 1fr); }
  body .wrapper .game-grid.game-grid-2 { grid-template-columns: repeat(2, 1fr); }
  body .wrapper .reason-grid { grid-template-columns: 1fr 1fr; }
  body .wrapper .register-layout { grid-template-columns: 1.5fr 1fr; align-items: stretch; }
  body .wrapper .step-carousel .register-cta { margin-top: auto; }
  body .wrapper .final-cta .final-title { font-size: 38px; }
}
@media (min-width: 1024px) {
  /* en desktop el header es 1 fila (~65px) → offset menor */
  body .wrapper .block,
  body .wrapper .bonus-card.facutron-bonus { scroll-margin-top: 84px; }
  body.admin-bar .wrapper .block,
  body.admin-bar .wrapper .bonus-card.facutron-bonus { scroll-margin-top: 116px; }
  body .wrapper .block-split { grid-template-columns: 1.1fr 0.9fr; align-items: center; gap: 50px; }
  body .wrapper .block-split-reverse .block-text { order: 2; }
  body .wrapper .block-split-reverse .shot { order: 1; }
}
