/* ===============================
   FONTS — RIGHT GROTESK
=============================== */

@font-face {
  font-family: "Right Grotesk";
  src: url("../fonts/right-grotesk/RightGrotesk-Regular.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Right Grotesk";
  src: url("../fonts/right-grotesk/RightGrotesk-Medium.woff2") format("woff2");
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Right Grotesk";
  src: url("../fonts/right-grotesk/RightGrotesk-Bold.woff2") format("woff2");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

/* ===============================
   FONT TOKENS
=============================== */

:root {
  --font-primary: "Right Grotesk", "Inter", system-ui, -apple-system, sans-serif;
  --font-secondary: "Inter", system-ui, -apple-system, sans-serif;
}


html, body {
  font-family: var(--font-primary);
}

/* FAQ: respeitar quebras de linha do texto (\n) */
.lp2-faq__content{
  white-space: pre-line;
}

/* UI layer (isolada) - modais e componentes do demo */
:root{--ui-green:#39a900;--ui-text:#111;--ui-muted:#667085;--ui-line:#e7e7ea;--ui-bg:#fff;--ui-shadow:0 20px 60px rgba(0,0,0,.25)}

.ui-infobar{background:var(--ui-green);color:#fff;padding:10px 16px;font-size:14px;text-align:center}
.ui-infobar__inner{max-width:1120px;margin:0 auto;display:flex;gap:10px;align-items:center;justify-content:center;flex-wrap:wrap}
.ui-infobar a{color:#fff;text-decoration:underline}

.ui-infobar{
  position: sticky;
  top: 0;
  z-index: 99999;
}

.ui-modal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;z-index:10000}
.ui-modal.is-open{display:flex}
.ui-modal__overlay{position:absolute;inset:0;background:rgba(0,0,0,.55)}
.ui-modal__dialog{position:relative;background:var(--ui-bg);border-radius:18px;box-shadow:var(--ui-shadow);width:min(1100px,calc(100% - 28px));max-height:92vh;overflow:hidden}
.ui-modal__close{position:absolute;top:16px;right:16px;width:34px;height:34px;border-radius:999px;display:grid;place-items:center;background:rgba(0,0,0,.25);color:#fff;border:0;cursor:pointer}

/* =========================================================
   ALIASES (HTML novo) -> reaproveita o CSS antigo de modal
   HTML usa: .ui-modal__backdrop e .ui-modal__panel
   CSS antigo usa: .ui-modal__overlay e .ui-modal__dialog
   ========================================================= */

.ui-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.55);
}

/* garante que clique/scroll não “vaze” pro fundo */
.ui-modal__backdrop {
  pointer-events: auto;
}

.ui-modal__panel {
  position: relative;
  background: var(--ui-bg);
  border-radius: 18px;
  box-shadow: var(--ui-shadow);
  width: min(1100px, calc(100% - 28px));
  max-height: 92vh;
  overflow: hidden; /* padrão (para modais comuns) */
}

/* regras costuma ter bastante conteúdo: deixa scroll dentro do modal */
.ui-modal__panel--rules {
  overflow: auto;
}

/* trava scroll do fundo quando modal estiver aberto (classe do modals.js) */
body.modal-open,
html.modal-open {
  overflow: hidden !important;
}

/* Modal Regras */
.ui-rules__hero::after{content:'';position:absolute;inset:0;background:rgba(0,0,0,.5)}
.ui-rules__heroText{position:relative;color:#fff;text-align:center;font-weight:800;line-height:1.05}
.ui-rules__heroText .a{display:block;font-size:54px;color:#c9ff00;letter-spacing:-1px}
.ui-rules__heroText .b{display:block;font-size:52px;color:#c9ff00;letter-spacing:-1px}
.ui-rules__heroText .c{display:block;font-size:64px}
.ui-rules__heroText .d{display:block;font-size:44px}
.ui-rules__body{padding:22px}
.ui-rules__title{font-size:38px;margin:0 0 14px 0;color:var(--ui-text)}
.ui-rules__card{border:1px solid var(--ui-line);border-radius:12px;padding:18px;max-height:320px;overflow:auto;background:#fff}
.ui-form{margin-top:16px}
.ui-label{font-size:12px;font-weight:700;color:#111;display:block;margin:10px 0 8px}
.ui-input{width:100%;border:1px solid var(--ui-line);border-radius:10px;padding:12px 14px;font-size:14px}
.ui-check{display:flex;gap:10px;align-items:center;margin:14px 0}
.ui-check input{width:18px;height:18px;accent-color:var(--ui-green)}
.ui-actions{display:flex;gap:12px}
.ui-btn{border:1px solid var(--ui-line);border-radius:10px;padding:12px 16px;font-weight:700;background:#fff;cursor:pointer}
.ui-btn--primary{background:var(--ui-green);border-color:var(--ui-green);color:#fff;flex:1}

/* Modal Números */
.ui-lucky__top{padding:18px 22px;border-bottom:1px solid var(--ui-line)}
.ui-lucky__money{font-weight:800;font-size:18px}
.ui-lucky__sub{color:var(--ui-muted);margin-top:6px;font-size:13px}
.ui-lucky__content{padding:16px 22px 22px}
.ui-lucky__bar{display:flex;gap:10px;align-items:center;margin:10px 0 14px}
.ui-search{flex:1;display:flex;align-items:center;gap:8px;border:1px solid var(--ui-line);border-radius:10px;padding:10px 12px}
.ui-search input{border:0;outline:0;flex:1;font-size:13px}
.ui-pill{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--ui-line);border-radius:999px;padding:6px 10px;font-size:13px;color:#444;background:#fff}
.ui-pill__dot{width:8px;height:8px;border-radius:999px;background:var(--ui-green)}
.ui-filterBtn{border:1px solid var(--ui-line);border-radius:10px;padding:10px 12px;background:#fff;cursor:pointer;display:flex;gap:8px;align-items:center}

.ui-tabs{display:flex;gap:10px;background:#f3f4f6;border-radius:10px;padding:6px;margin:10px 0 12px}
.ui-tab{flex:1;text-align:center;padding:10px;border-radius:8px;font-weight:700;font-size:13px;cursor:pointer;color:#6b7280}
.ui-tab.is-active{background:#fff;color:#111;border:1px solid var(--ui-line)}

.ui-filterPanel{display:none;border:1px solid var(--ui-line);border-radius:12px;padding:12px;background:#fff;margin:10px 0 12px}
.ui-filterPanel.is-open{display:block}
.ui-grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.ui-select{width:100%;border:1px solid var(--ui-line);border-radius:10px;padding:12px 14px;font-size:13px;background:#fff}
.ui-filterActions{display:flex;gap:12px;margin-top:12px}
.ui-btn--ghost{flex:0 0 180px;background:#fff}

.ui-lucky__label{font-size:12px;color:#666;letter-spacing:.06em;text-transform:uppercase;margin:8px 0}
.ui-numbers{display:grid;grid-template-columns:repeat(9,1fr);gap:10px}
.ui-number{background:var(--ui-green);color:#fff;border-radius:999px;padding:7px 8px;text-align:center;font-weight:800;font-size:12px}

.ui-lucky__footer{display:flex;align-items:center;justify-content:space-between;margin-top:14px}
.ui-pagination{display:flex;gap:8px;align-items:center}
.ui-page{width:28px;height:28px;border-radius:8px;display:grid;place-items:center;border:1px solid var(--ui-line);cursor:pointer;background:#fff;font-size:13px}
.ui-page.is-active{background:#111;color:#fff;border-color:#111}

@media (max-width:900px){
  .ui-modal__dialog{width:calc(100% - 16px)}
  .ui-rules__title{font-size:28px}
  .ui-numbers{grid-template-columns:repeat(4,1fr)}
  .ui-grid2{grid-template-columns:1fr}
  .ui-btn--ghost{flex:1}
}

.ui-modal{ position:fixed; inset:0; z-index:999; display:none; }
.ui-modal.is-open{ display:block; }

.ui-modal__backdrop{ position:absolute; inset:0; background:rgba(0,0,0,.55); }

.ui-modal__panel{
  position:relative;
  width:min(720px, calc(100vw - 32px));
  margin:72px auto 24px;
  background:#fff;
  border-radius:14px;
  overflow:hidden;
  box-shadow:0 24px 80px rgba(0,0,0,.35);
  transform: translateY(10px);
  opacity:0;
  transition:.18s ease;
}
.ui-modal.is-open .ui-modal__panel{ transform:translateY(0); opacity:1; }

@media (max-width: 900px) {
  .ui-modal.is-open .ui-modal__panel{ max-height: stretch; overflow-y: scroll;}  
}

.ui-modal__header{
  display:flex; align-items:center; justify-content:space-between;
  gap:12px; padding:14px 16px; border-bottom:1px solid #eee;
}
.ui-modal__body{ padding:16px; max-height:min(70vh, 640px); overflow:auto; }
.ui-modal__close{ border:0; background:transparent; font-size:18px; cursor:pointer; }

body.modal-open{ overflow:hidden; }


/* =========================================================
   MODAL REGULAMENTO - match referência
   ========================================================= */

.ui-modal--rules{ z-index: 999; }
.ui-modal__panel--rules{
  width: min(860px, calc(100vw - 24px));
  margin: 28px auto;
  border-radius: 12px;
  overflow: hidden;
  background: #fff;
  box-shadow: 0 30px 90px rgba(0,0,0,.45);
  position: relative;
}

/* botão fechar no topo do banner */
.rules-modal__close{
  position: absolute;
  top: 14px;
  right: 16px;
  z-index: 3;
  width: 34px;
  height: 34px;
  border: 0;
  border-radius: 10px;
  background: rgba(0,0,0,.25);
  color: #fff;
  font-size: 22px;
  line-height: 34px;
  cursor: pointer;
}
.rules-modal__close:hover{ background: rgba(0,0,0,.35); }

/* Banner escuro com padrão */
.rules-modal__hero{
  position: relative;
  height: 360px;
  background: #171717;
  overflow: hidden;
}

/* padrão tipo “círculos” (aproxima o artwork) */
.rules-modal__hero::before{
  content:"";
  position:absolute;
  inset:-40px;
  opacity:.22;
  background:
    radial-gradient(circle at 15% 25%, transparent 0 32px, rgba(255,255,255,.35) 33px 34px, transparent 35px),
    radial-gradient(circle at 85% 20%, transparent 0 44px, rgba(255,255,255,.25) 45px 46px, transparent 47px),
    radial-gradient(circle at 70% 80%, transparent 0 52px, rgba(255,255,255,.20) 53px 54px, transparent 55px),
    radial-gradient(circle at 25% 75%, transparent 0 46px, rgba(255,255,255,.20) 47px 48px, transparent 49px),
    radial-gradient(circle at 45% 40%, transparent 0 40px, rgba(255,255,255,.16) 41px 42px, transparent 43px);
  filter: blur(.2px);
}

.rules-modal__hero-inner{
  position: relative;
  z-index: 1;
  height: 100%;
  display:flex;
  align-items:center;
  justify-content:center;
  padding: 16px;
  text-align:center;
}

.rules-modal__hero-title{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap: 6px;
  transform: translateY(4px);
}

/* Tipografia “forte” */
.rules-modal__hero-line{
  text-transform: uppercase;
  letter-spacing: -0.02em;
  font-weight: 900;
  line-height: .92;
  font-size: clamp(38px, 6vw, 58px);
  font-family: var(--font-secondary);
}
.rules-modal__hero-line--green{ color: #b9ff00; }
.rules-modal__hero-line--white{ color: #fff; }

.rules-modal__hero-plus{
  display:flex;
  align-items:flex-end;
  gap: 8px;
  margin-top: 6px;
  margin-bottom: 2px;
  color:#fff;
  font-weight: 900;
  letter-spacing: -0.03em;
  line-height: .9;
}
.rules-modal__hero-plus-sign{
  font-size: clamp(34px, 5vw, 56px);
  transform: translateY(-2px);
}
.rules-modal__hero-plus-num{
  font-size: clamp(64px, 10vw, 110px);
}
.rules-modal__hero-plus-mil{
  font-size: clamp(28px, 4.5vw, 58px);
  text-transform: uppercase;
  transform: translateY(-8px);
}

.rules-modal__hero-logo{
  position:absolute;
  right: 18px;
  bottom: 16px;
  height: 20px;
  width: auto;
  opacity: .95;
}

/* Conteúdo */
.rules-modal__content{
  padding: 18px 18px 20px;
}
.rules-modal__h1{
  margin: 4px 0 14px;
  font-size: 1.6em;
  letter-spacing: -0.03em;
  line-height: 1.0;
  color:#111;
  font-family: var(--font-secondary);
}

.rules-modal__box{
  border: 1px solid #ececec;
  border-radius: 10px;
  padding: 14px 14px;
  background: #fff;
  font-family: var(--font-secondary);
}
.rules-modal__box p{
  margin: 0 0 10px;
  color:#222;
  font-size: 14px;
  line-height: 1.55;
  font-family: var(--font-secondary);
}
.rules-modal__list{
  margin: 8px 0 12px 18px;
  padding: 0;
  color:#222;
  font-size: 14px;
  line-height: 1.55;
}
.rules-modal__list li{ margin: 0 0 10px; }

/* Form */
.rules-modal__form{ margin-top: 14px; }
.rules-modal__label{
  display:block;
  font-size: 12px;
  color:#111;
  font-weight: 700;
  margin: 10px 0 8px;
  font-family: var(--font-secondary);
}

.rules-modal__input{
  width: 100%;
  height: 46px;
  border-radius: 10px;
  border: 1px solid #e6e6e6;
  padding: 0 14px;
  font-size: 14px;
  outline: none;
  font-family: var(--font-secondary);
}
.rules-modal__input:focus{
  border-color: rgba(102,198,28,.55);
  box-shadow: 0 0 0 4px rgba(102,198,28,.15);
}

/* Checkbox estilo */
.rules-modal__check{
  display:flex;
  align-items:center;
  gap: 10px;
  margin: 14px 0 16px;
  user-select:none;
  cursor:pointer;
}
.rules-modal__check-input{ position:absolute; opacity:0; pointer-events:none; }
.rules-modal__check-box{
  width: 18px;
  height: 18px;
  border-radius: 4px;
  border: 1.5px solid #cfcfcf;
  background:#fff;
  display:inline-block;
  position:relative;
  flex: 0 0 auto;
}
.rules-modal__check-input:checked + .rules-modal__check-box{
  background: #2f9f0d;
  border-color: #2f9f0d;
}
.rules-modal__check-input:checked + .rules-modal__check-box::after{
  content:"";
  position:absolute;
  left: 5px;
  top: 2px;
  width: 5px;
  height: 10px;
  border: 2px solid #fff;
  border-top: 0;
  border-left: 0;
  transform: rotate(45deg);
}
.rules-modal__check-text{
  font-size: 14px;
  color:#111;
  font-family: var(--font-secondary);
}

.rules-modal__submit{
  width: 100%;
  height: 52px;
  border-radius: 8px;
  border: 0;
  background: #2f9f0d;
  color:#fff;
  font-weight: 700;
  font-size: 14px;
  cursor:pointer;
  font-family: var(--font-secondary);
  transition: opacity .2s ease, filter .2s ease, background .2s ease;
}

.rules-modal__submit:hover{
  filter: brightness(.97);
}

.rules-modal__submit:disabled,
.rules-modal__submit[aria-disabled="true"]{
  background: #bfc6ce;
  color: #f8fafc;
  cursor: not-allowed;
  filter: none;
  opacity: 1;
}

/* ===== FIX: modal rules centralizado + backdrop bloqueando ===== */

.ui-modal--rules.is-open{
  display: flex !important;
  align-items: center;
  justify-content: center;
  padding: 24px;
}

/* garante que o backdrop cubra e "capture" interação */
.ui-modal--rules .ui-modal__backdrop{
  position: fixed;
  inset: 0;
  pointer-events: auto;
}

/* painel centralizado e com scroll interno */
.ui-modal--rules .ui-modal__panel--rules{
  margin: 0 !important;
  max-height: calc(100vh - 48px);
  overflow: auto;
  -webkit-overflow-scrolling: touch;
}

/* impede “vazar” scroll do modal pro fundo */
.ui-modal--rules .ui-modal__panel--rules{
  overscroll-behavior: contain;
  touch-action: pan-y;
}

html.modal-open,
body.modal-open{
  overflow: hidden !important;
  overscroll-behavior: none;
}

/* mantém o fundo travado, mas permite scroll dentro do modal */
html.modal-open .ui-modal,
html.modal-open .ui-modal__panel,
html.modal-open .ui-modal__body,
html.modal-open .db2-filter__nums,
html.modal-open #modal-rules .ui-modal__panel{
  overscroll-behavior: contain;
  -webkit-overflow-scrolling: touch;
  touch-action: pan-y;
}

/* Mobile: ocupa mais a tela e ajusta título */
@media (max-width: 520px){
  .ui-modal__panel--rules{
    width: calc(100vw - 16px);
    margin: 18px auto;
    border-radius: 12px;
  }
  .rules-modal__hero{ height: 240px; }
  .rules-modal__h1{ font-size: 26px; }
}
