/* ============================================================
   TITAN THEME — ti- prefix
   Palette: Red #dc2626, Gold #f59e0b | Bebas Neue + Roboto
   Signature: stats band, comparison table hero, left-border bonus cards
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Roboto:wght@300;400;500;700&display=swap');

/* ── Variables ─────────────────────────────────────────────── */
:root {--ti_card:    rgba(34,34,34,1);--ti_red:     #dc2626;--ti_white:   rgba(255,255,255,1);--ti_border:  rgba(46,46,46,1);--ti_muted:   #9a9a9a;--ti_bg:      #0d0d0d;--ti_r-lg:    10px;--ti_r:       6px;--ti_gold-lt: #fcd34d;--ti_red-dk:  #b91c1c;--ti_text:    #e5e5e5;--ti_shadow:  0 4px 20px rgba(0,0,0,.55);--ti_gold:    rgba(245,158,11,1);--ti_surface: #1a1a1a}

/* ── Reset ──────────────────────────────────────────────────── */
*, *::before, *::after {margin: 0;box-sizing: border-box;padding: 0}
html { scroll-behavior: smooth; }
body {font-family: 'Roboto', sans-serif;color: var(--ti_text);font-size: 16px;background: var(--ti_bg);line-height: 1.6;min-height: 100vh;visibility:visible;pointer-events:auto;user-select:auto;outline-offset:0}
img {max-width: 100%;display: block;height: auto}
a {color: var(--ti_gold);text-decoration: none}
a:hover { text-decoration: underline; }

/* ── Typography ─────────────────────────────────────────────── */
h1, h2, h3, h4, h5, h6 {letter-spacing: .04em;font-family: 'Bebas Neue', sans-serif;color: var(--ti_white);line-height: 1.1}
h1 { font-size: clamp(2.4rem, 5vw, 4rem); }
h2 { font-size: clamp(1.8rem, 3.5vw, 2.8rem); }
h3 { font-size: clamp(1.4rem, 2.5vw, 1.9rem); }
p  {color: var(--ti_text);font-size: 1rem}

/* ── Layout ─────────────────────────────────────────────────── */
.ti-container {padding: 0 20px;width: 100%;max-width: 1160px;margin: 0 auto}
.ti-section   { padding: 70px 0; }

/* ── Stats Band ─────────────────────────────────────────────── */
.ti-stats-band {overflow: hidden;background: var(--ti_red);padding: 0}
.ti-stats-band__inner {flex-wrap: wrap;padding: 14px 20px;display: flex;align-items: center;gap: 10px;justify-content: space-around}
.ti-stat-item {flex-direction: column;align-items: center;display: flex;min-width: 120px;gap: 2px}
.ti-stat-item__num {font-size: 2rem;font-family: 'Bebas Neue', sans-serif;color: var(--ti_white);line-height: 1;letter-spacing: .05em}
.ti-stat-item__label {color: rgba(255,255,255,.8);font-size: .72rem;letter-spacing: .08em;font-weight: 500;text-transform: uppercase}
.ti-stat-item + .ti-stat-item {border-left: 1px solid rgba(255,255,255,.2);padding-left: 10px}

/* ── Nav ────────────────────────────────────────────────────── */
.ti-nav {background: var(--ti_bg);z-index: 100;top: 0;position: sticky;border-bottom: 2px solid var(--ti_red)}
.ti-nav__inner {height: 62px;padding: 0 20px;align-items: center;display: flex;max-width: 1160px;justify-content: space-between;margin: 0 auto}
.ti-nav__logo {color: var(--ti_white);font-size: 1.6rem;letter-spacing: .06em;font-family: 'Bebas Neue', sans-serif}
.ti-nav__logo span { color: var(--ti_gold); }
.ti-nav__links {display: flex;list-style: none;gap: 28px}
.ti-nav__links a {color: var(--ti_muted);text-transform: uppercase;font-weight: 500;transition: color .2s;font-size: .88rem;letter-spacing: .06em}
.ti-nav__links a:hover {color: var(--ti_gold);text-decoration: none}
.ti-nav__cta {font-size: .85rem;transition: background .2s;font-weight: 700;color: var(--ti_white) !important;letter-spacing: .08em;border-radius: var(--ti_r);background: var(--ti_red);padding: 8px 20px;text-transform: uppercase}
.ti-nav__cta:hover {text-decoration: none;background: var(--ti_red-dk)}
.ti-burger {padding: 4px;gap: 5px;flex-direction: column;display: none;background: none;border: none;cursor: pointer}
.ti-burger span {background: var(--ti_white);height: 2px;width: 24px;transition: all .3s;display: block}

/* ── Hero (comparison layout) ───────────────────────────────── */
.ti-hero {padding: 60px 0 50px;background: radial-gradient(ellipse at 70% 50%, rgba(220,38,38,.12) 0%, transparent 60%),
              var(--ti_bg)}
.ti-hero__inner {grid-template-columns: 1fr 480px;align-items: start;gap: 50px;padding: 0 20px;display: grid;margin: 0 auto;max-width: 1160px}
.ti-hero__tag {display: inline-flex;border: 1px solid rgba(245,158,11,.3);background: rgba(245,158,11,.12);color: var(--ti_gold);font-weight: 600;align-items: center;margin-bottom: 16px;letter-spacing: .08em;border-radius: 20px;gap: 6px;text-transform: uppercase;padding: 4px 14px;font-size: .78rem}
.ti-hero__h1 { margin-bottom: 16px; }
.ti-hero__h1 em {color: var(--ti_gold);font-style: normal}
.ti-hero__lead {margin-bottom: 28px;color: var(--ti_muted);font-size: 1.05rem;max-width: 480px}
.ti-hero__actions {display: flex;gap: 14px;flex-wrap: wrap}

/* Review badge */
.ti-review-badge {align-items: center;display: inline-flex;background: var(--ti_surface);border: 1px solid var(--ti_border);gap: 8px;padding: 10px 16px;border-radius: var(--ti_r);margin-bottom: 22px}
.ti-review-badge__stars {font-size: 1rem;color: var(--ti_gold);letter-spacing: 2px}
.ti-review-badge__text {font-size: .82rem;color: var(--ti_muted)}
.ti-review-badge__text strong { color: var(--ti_white); }

/* Comparison Table */
.ti-cmp-table-wrap {border: 1px solid var(--ti_border);background: var(--ti_surface);border-radius: var(--ti_r-lg);box-shadow: var(--ti_shadow);overflow: hidden}
.ti-cmp-table-wrap__head {background: var(--ti_red);padding: 14px 20px;text-align: center}
.ti-cmp-table-wrap__head h3 {color: var(--ti_white);font-size: 1.3rem;font-family: 'Bebas Neue', sans-serif;letter-spacing: .06em}
.ti-cmp-table {width: 100%;border-collapse: collapse;font-size: .9rem}
.ti-cmp-table thead th {border-bottom: 1px solid var(--ti_border);font-weight: 600;padding: 10px 16px;font-size: .72rem;color: var(--ti_muted);background: var(--ti_card);letter-spacing: .08em;text-transform: uppercase}
.ti-cmp-table thead th:first-child { text-align: left; }
.ti-cmp-table thead th:last-child {background: rgba(245,158,11,.08);color: var(--ti_gold)}
.ti-cmp-table tbody tr {transition: background .15s;border-bottom: 1px solid var(--ti_border)}
.ti-cmp-table tbody tr:last-child { border-bottom: none; }
.ti-cmp-table tbody tr:hover { background: rgba(255,255,255,.03); }
.ti-cmp-table td {padding: 12px 16px;color: var(--ti_muted);text-align: center}
.ti-cmp-table td:first-child {font-weight: 500;color: var(--ti_text);text-align: left}
.ti-cmp-table td:last-child {font-weight: 700;color: var(--ti_gold);background: rgba(245,158,11,.05)}
.ti-check {color: rgb(34,197,94);font-size: 1.1rem}
.ti-cross {color: rgba(239,68,68,1);font-size: 1.1rem}

.ti-cmp-table-wrap__footer {background: var(--ti_card);border-top: 1px solid var(--ti_border);text-align: center;padding: 16px 20px}

/* ── Buttons ────────────────────────────────────────────────── */
.ti-btn {letter-spacing: .06em;font-weight: 700;text-decoration: none !important;text-transform: uppercase;border-radius: var(--ti_r);font-family: 'Roboto', sans-serif;cursor: pointer;border: none;transition: all .2s;align-items: center;font-size: .95rem;padding: 14px 28px;gap: 8px;display: inline-flex}
.ti-btn--primary {color: var(--ti_white);background: var(--ti_red);box-shadow: 0 4px 14px rgba(220,38,38,.4)}
.ti-btn--primary:hover {transform: translateY(-1px);box-shadow: 0 6px 20px rgba(220,38,38,.5);background: var(--ti_red-dk)}
.ti-btn--gold {color: #000;background: var(--ti_gold);box-shadow: 0 4px 14px rgba(245,158,11,.35)}
.ti-btn--gold:hover {transform: translateY(-1px);background: var(--ti_gold-lt)}
.ti-btn--outline {border: 1.5px solid var(--ti_border);background: transparent;color: var(--ti_text)}
.ti-btn--outline:hover {color: var(--ti_gold);border-color: var(--ti_gold)}
.ti-btn--sm {font-size: .82rem;padding: 9px 18px}
.ti-btn--full {width: 100%;justify-content: center}

/* ── Feature Cards ─────────────────────────────────────────── */
.ti-features {
  background: var(--ti_surface);
}
.ti-features__head {margin-bottom: 44px;text-align: center}
.ti-features__head p {margin-top: 10px;color: var(--ti_muted)}
.ti-features__grid {grid-template-columns: repeat(3, 1fr);display: grid;gap: 22px}
.ti-feat-card {padding: 26px 22px;border: 1px solid var(--ti_border);position: relative;transition: border-color .2s, transform .2s;border-radius: var(--ti_r-lg);background: var(--ti_card)}
.ti-feat-card:hover {border-color: var(--ti_red);transform: translateY(-3px)}
.ti-feat-card__icon {display: flex;font-size: 1.5rem;margin-bottom: 16px;justify-content: center;border-radius: var(--ti_r);background: rgba(220,38,38,.12);width: 48px;align-items: center;height: 48px}
.ti-feat-card__title {margin-bottom: 10px;font-size: 1.25rem;font-family: 'Bebas Neue', sans-serif;color: var(--ti_white);letter-spacing: .04em}
.ti-feat-card__text {font-size: .9rem;color: var(--ti_muted);line-height: 1.6}

/* ── Bonus Cards (left-border accent) ──────────────────────── */
.ti-bonus-section { background: var(--ti_bg); }
.ti-bonus-section__head {margin-bottom: 44px;text-align: center}
.ti-bonus-section__head p {margin-top: 10px;color: var(--ti_muted)}
.ti-bonus-grid {gap: 20px;grid-template-columns: repeat(2, 1fr);display: grid}
.ti-bonus-card {flex-direction: column;background: var(--ti_card);transition: border-color .2s;border-radius: var(--ti_r-lg);gap: 10px;display: flex;border-left: 4px solid var(--ti_gold);padding: 24px 22px;border: 1px solid var(--ti_border)}
.ti-bonus-card:hover {border-left-color: var(--ti_red);border-color: var(--ti_gold)}
.ti-bonus-card__tag {background: rgba(245,158,11,.1);font-weight: 700;text-transform: uppercase;padding: 3px 10px;letter-spacing: .1em;color: var(--ti_gold);align-self: flex-start;font-size: .7rem;border-radius: 12px}
.ti-bonus-card__amount {line-height: 1;font-size: 2rem;letter-spacing: .04em;color: var(--ti_white);font-family: 'Bebas Neue', sans-serif}
.ti-bonus-card__title {font-size: .95rem;color: var(--ti_text);font-weight: 700}
.ti-bonus-card__text {color: var(--ti_muted);font-size: .88rem;line-height: 1.55}
.ti-bonus-card__terms {color: var(--ti_muted);font-size: .75rem;padding-top: 10px;margin-top: 4px;border-top: 1px solid var(--ti_border)}

/* ── FAQ ────────────────────────────────────────────────────── */
.ti-faq { background: var(--ti_surface); }
.ti-faq__head {margin-bottom: 44px;text-align: center}
.ti-faq__head p {color: var(--ti_muted);margin-top: 10px}
.ti-faq__list {display: flex;flex-direction: column;gap: 10px;margin: 0 auto;max-width: 760px}
.ti-faq-item {border-radius: var(--ti_r);overflow: hidden;transition: border-color .2s;border: 1px solid var(--ti_border);background: var(--ti_card)}
.ti-faq-item:focus-within { border-color: var(--ti_red); }
.ti-faq-item__q {align-items: center;color: var(--ti_white);display: flex;border: none;width: 100%;text-align: left;gap: 16px;font-family: 'Roboto', sans-serif;cursor: pointer;font-weight: 600;font-size: .98rem;justify-content: space-between;background: none;padding: 18px 20px}
.ti-faq-item__q:hover { color: var(--ti_gold); }
.ti-faq-item__arrow {flex-shrink: 0;color: var(--ti_gold);justify-content: center;width: 20px;align-items: center;background: rgba(245,158,11,.12);font-size: .7rem;height: 20px;border-radius: 50%;transition: transform .3s;display: flex}
.ti-faq-item[data-open] .ti-faq-item__arrow { transform: rotate(180deg); }
.ti-faq-item__a {overflow: hidden;padding: 0 20px;max-height: 0;transition: max-height .35s ease, padding .35s ease}
.ti-faq-item[data-open] .ti-faq-item__a {padding: 0 20px 18px;max-height: 400px}
.ti-faq-item__a p {color: var(--ti_muted);line-height: 1.7;font-size: .9rem}

/* ── Payments ───────────────────────────────────────────────── */
.ti-payments { background: var(--ti_bg); }
.ti-payments__head {text-align: center;margin-bottom: 40px}
.ti-payments__head p {margin-top: 10px;color: var(--ti_muted)}
.ti-pay-grid {gap: 14px;display: grid;grid-template-columns: repeat(5, 1fr)}
.ti-pay-card {border-radius: var(--ti_r);transition: border-color .2s;padding: 18px 14px;background: var(--ti_card);text-align: center;border: 1px solid var(--ti_border)}
.ti-pay-card:hover { border-color: var(--ti_gold); }
.ti-pay-card__icon {font-size: 1.8rem;margin-bottom: 8px}
.ti-pay-card__name {font-size: .78rem;font-weight: 600;color: var(--ti_text)}
.ti-pay-card__time {font-size: .7rem;margin-top: 2px;color: var(--ti_muted)}

/* ── CTA Section ────────────────────────────────────────────── */
.ti-cta-section {padding: 70px 0;background: linear-gradient(135deg, var(--ti_red-dk) 0%, #7f1d1d 100%);text-align: center;position: relative;overflow: hidden}
.ti-cta-section::before {content: '';height: 600px;border-radius: 50%;width: 600px;top: -50%;left: 50%;pointer-events: none;background: rgba(245,158,11,.08);transform: translateX(-50%);position: absolute}
.ti-cta-section h2 {margin-bottom: 14px;color: var(--ti_white)}
.ti-cta-section p {margin-bottom: 28px;color: rgba(255,255,255,.75);font-size: 1.05rem}
.ti-cta-section .ti-btn--gold {padding: 16px 36px;font-size: 1.05rem}

/* ── Footer ─────────────────────────────────────────────────── */
.ti-footer {padding: 54px 0 28px;border-top: 1px solid var(--ti_border);background: #000}
.ti-footer__grid {grid-template-columns: 1.5fr 1fr 1fr 1fr;gap: 40px;display: grid;margin-bottom: 44px}
.ti-footer__brand {margin-bottom: 14px;font-family: 'Bebas Neue', sans-serif;font-size: 1.5rem;letter-spacing: .06em;color: var(--ti_white)}
.ti-footer__brand span { color: var(--ti_gold); }
.ti-footer__desc {font-size: .85rem;line-height: 1.65;color: var(--ti_muted)}
.ti-footer__col h4 {font-size: .72rem;font-weight: 700;color: var(--ti_muted);letter-spacing: .1em;text-transform: uppercase;margin-bottom: 14px}
.ti-footer__col ul {list-style: none;flex-direction: column;display: flex;gap: 8px}
.ti-footer__col ul a {font-size: .88rem;transition: color .2s;color: var(--ti_muted)}
.ti-footer__col ul a:hover {color: var(--ti_gold);text-decoration: none}
.ti-footer__bottom {align-items: center;justify-content: space-between;flex-wrap: wrap;gap: 12px;padding-top: 22px;border-top: 1px solid var(--ti_border);display: flex}
.ti-footer__copy {color: var(--ti_muted);font-size: .8rem}
.ti-footer__warn {max-width: 500px;font-size: .75rem;text-align: right;color: var(--ti_muted)}

/* ── Sticky CTA ─────────────────────────────────────────────── */
.sf-sticky-cta {position: fixed;transform: translateY(100%);transition: transform .4s cubic-bezier(.22,1,.36,1);z-index: 200;background: var(--ti_red);box-shadow: 0 -4px 20px rgba(0,0,0,.5);left: 0;right: 0;bottom: 0}
.sf-sticky-cta.is-visible { transform: translateY(0); }
.sf-sticky-cta__inner {display: flex;align-items: center;gap: 16px;max-width: 1160px;margin: 0 auto;justify-content: space-between;padding: 12px 20px}
.sf-sticky-cta__text {font-size: .92rem;font-weight: 600;color: var(--ti_white)}
.sf-sticky-cta__text span { color: var(--ti_gold-lt); }
.sf-sticky-cta__actions {align-items: center;display: flex;gap: 12px}
.sf-sticky-cta__close {color: rgba(255,255,255,.7);padding: 4px;background: none;line-height: 1;font-size: 1.1rem;border: none;cursor: pointer}
.sf-sticky-cta__close:hover { color: #fff; }

/* ── Generic / Legal pages ──────────────────────────────────── */
.ti-page-hero {background: var(--ti_surface);padding: 50px 0 40px;border-bottom: 1px solid var(--ti_border)}
.ti-page-hero__tag {letter-spacing: .1em;text-transform: uppercase;margin-bottom: 10px;font-weight: 700;color: var(--ti_gold);font-size: .75rem}
.ti-content {margin: 0 auto;max-width: 780px}
.ti-content h2 {font-size: 1.6rem;margin: 36px 0 12px;color: var(--ti_white)}
.ti-content h3 {font-size: 1.2rem;margin: 28px 0 10px;color: var(--ti_text)}
.ti-content p  {margin-bottom: 16px;color: var(--ti_muted)}
.ti-content ul, .ti-content ol { margin: 0 0 16px 22px; }
.ti-content li {color: var(--ti_muted);font-size: .95rem;margin-bottom: 8px}
.ti-content a  { color: var(--ti_gold); }

/* ── Login ──────────────────────────────────────────────────── */
.ti-login-wrap {align-items: center;justify-content: center;display: flex;padding: 60px 20px;min-height: 80vh}
.ti-login-card {background: var(--ti_surface);padding: 44px 40px;max-width: 440px;border-radius: var(--ti_r-lg);width: 100%;box-shadow: var(--ti_shadow);border: 1px solid var(--ti_border)}
.ti-login-card h2 {margin-bottom: 8px;text-align: center}
.ti-login-card__sub {margin-bottom: 28px;font-size: .92rem;color: var(--ti_muted);text-align: center}
.ti-form {flex-direction: column;display: flex;gap: 16px}
.ti-form label {margin-bottom: 6px;font-weight: 600;color: var(--ti_text);font-size: .82rem;display: block}
.ti-form input {background: var(--ti_card);width: 100%;padding: 12px 14px;font-size: .95rem;transition: border-color .2s;border-radius: var(--ti_r);color: var(--ti_white);font-family: 'Roboto', sans-serif;border: 1px solid var(--ti_border)}
.ti-form input:focus {border-color: var(--ti_red);outline: none}
.ti-form__hint {text-align: center;color: var(--ti_muted);margin-top: 4px;font-size: .78rem}

/* ── Plataforma page ────────────────────────────────────────── */
.ti-plat-grid {gap: 20px;grid-template-columns: repeat(3, 1fr);display: grid}
.ti-plat-card {border-radius: var(--ti_r-lg);border-left: 4px solid var(--ti_red);background: var(--ti_card);transition: border-color .2s;padding: 24px 20px;border: 1px solid var(--ti_border)}
.ti-plat-card:hover { border-color: var(--ti_red); }
.ti-plat-card__num {font-family: 'Bebas Neue', sans-serif;font-size: 2.4rem;letter-spacing: .04em;color: var(--ti_red);margin-bottom: 8px;line-height: 1}
.ti-plat-card__title {margin-bottom: 8px;font-weight: 700;color: var(--ti_white)}
.ti-plat-card__text {color: var(--ti_muted);font-size: .88rem}

/* ── Mobile ─────────────────────────────────────────────────── */
.ti-nav__mobile { display: none; }
@media (max-width: 900px) {
  .ti-hero__inner { grid-template-columns: 1fr; }
  .ti-cmp-table-wrap { order: -1; }
  .ti-features__grid { grid-template-columns: repeat(2, 1fr); }
  .ti-bonus-grid { grid-template-columns: 1fr; }
  .ti-pay-grid { grid-template-columns: repeat(3, 1fr); }
  .ti-footer__grid { grid-template-columns: 1fr 1fr; }
  .ti-plat-grid { grid-template-columns: 1fr 1fr; }
  .ti-nav__links { display: none; }
  .ti-nav__cta { display: none; }
  .ti-burger { display: flex; }
  .ti-nav__mobile {border-top: 1px solid var(--ti_border);flex-direction: column;padding: 16px 20px;display: none;gap: 12px;background: var(--ti_surface)}
  .ti-nav__mobile.is-open { display: flex; }
  .ti-nav__mobile a {color: var(--ti_text);border-bottom: 1px solid var(--ti_border);padding: 8px 0;font-size: .95rem}
}
@media (max-width: 540px) {
  .ti-features__grid { grid-template-columns: 1fr; }
  .ti-pay-grid { grid-template-columns: repeat(2, 1fr); }
  .ti-footer__grid { grid-template-columns: 1fr; }
  .ti-plat-grid { grid-template-columns: 1fr; }
  .ti-stats-band__inner {gap: 14px;flex-direction: column}
  .ti-stat-item + .ti-stat-item {padding-top: 10px;padding-left: 0;border-left: none;border-top: 1px solid rgba(255,255,255,.2)}
  .sf-sticky-cta__text { font-size: .8rem; }
  .ti-login-card { padding: 28px 22px; }
}

/* siteforge-footer-overlap-guard: stable mobile footer layout + sticky CTA clearance */
:where(footer,[class*='-footer']){z-index:1;position:relative;overflow:visible}
:where([class*='footer__grid'],[class*='footer__strip'],[class*='footer__bar']){min-width:0}
:where([class*='footer__grid'],[class*='footer__strip'],[class*='footer__bar'])>*{min-width:0;max-width:100%}
:where([class*='footer__brandblock'],[class*='footer__summary'],[class*='footer__meta'],[class*='footer__copy'],[class*='footer__warn'],[class*='linkstack']){overflow-wrap:anywhere;word-break:break-word}
@media(max-width:760px){
  .sf-has-sticky-cta :where([class*='-shell']),.sf-has-sticky-cta main{padding-bottom:calc(140px + env(safe-area-inset-bottom,0px)) !important}
  .sf-has-sticky-cta main~footer,.sf-has-sticky-cta :where(footer,[class$='-footer']){padding-bottom:calc(112px + env(safe-area-inset-bottom,0px)) !important}
  :where([class*='footer__grid'],[class*='footer__strip'],[class*='footer__bar']){gap:16px !important;grid-template-columns:1fr !important;align-items:start !important;display:grid !important}
  :where([class*='footer__summary'],[class*='footer__bottom']){gap:10px;flex-direction:column;align-items:flex-start;text-align:left;display:flex}
  :where([class*='footer__brand']){float:none !important;max-height:110px;margin-bottom:12px;max-width:110px;clear:both}
}
