 *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

    :root {
      --orange: #F7941D;
      --orange-dark: #D97B0A;
      --black: #0D0D0D;
      --dark: #111111;
      --dark2: #1A1A1A;
      --white: #FFFFFF;
      --gray-light: #F4F4F4;
      --font-display: 'Barlow Condensed', sans-serif;
      --font-body: 'Barlow', sans-serif;
    }

    html { scroll-behavior: smooth; }

    body {
      font-family: var(--font-body);
      background: var(--black);
      color: var(--white);
      line-height: 1.6;
    }

    /* ── HERO ─────────────────────────────────────────────── */
    .hero {
      position: relative;
      min-height: 88vh;
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      text-align: center;
      padding: 60px 24px 80px;
      overflow: hidden;
    }


    .hero__content {
      position: relative;
      z-index: 1;
      max-width: 1440px;
    }

    .hero__logo {
      width: 265px;
      margin-bottom: 32px;
      filter: drop-shadow(0 4px 24px rgba(0,0,0,0.7));
    }

    .hero__title {
      font-family: var(--font-display);
      font-size: clamp(2.8rem, 7vw, 5.2rem);
      font-weight: 900;
      line-height: 1.0;
      text-transform: uppercase;
      letter-spacing: 0.02em;
      color: var(--white);
      text-shadow: 0 2px 24px rgba(0,0,0,0.9);
    }

    .hero__title span {
      color: var(--orange);
    }

    .hero__sub {
      margin-top: 22px;
      font-size: 1.1rem;
      color: rgba(255,255,255,0.9);
      max-width: 560px;
      margin-left: auto;
      margin-right: auto;
      line-height: 1.7;
    }

    .btn {
      display: inline-block;
      margin-top: 32px;
      background: var(--orange);
      color: var(--black);
      font-family: var(--font-display);
      font-weight: 800;
      font-size: 1rem;
      letter-spacing: 0.06em;
      text-transform: uppercase;
      padding: 14px 38px;
      border-radius: 4px;
      border: none;
      text-decoration: none;
      transition: background 0.2s, transform 0.15s;
      cursor: pointer;
    }

    .btn:hover {
      background: var(--orange-dark);
      transform: translateY(-2px);
    }

    /* Botão verde — usado no hero */
    .btn--green {
      background: #3A9E2F;
      color: var(--white);
      border: 2px solid #5ABF4E;
      border-radius: 6px;
      padding: 16px 48px;
      font-size: 1.05rem;
      letter-spacing: 0.08em;
    }

    .btn--green:hover {
      background: #2E8024;
      border-color: #4EAF42;
      transform: translateY(-2px);
    }

    /* ── FEATURES BAR ────────────────────────────────────── */
    .features-bar {
      background: var(--orange);
      padding: 18px 24px;
      display: flex;
      justify-content: center;
      align-items: center;
      gap: 0;
      flex-wrap: wrap;
    }

    .features-bar__item {
      font-family: var(--font-display);
      font-weight: 700;
      font-size: 0.95rem;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: var(--black);
      padding: 0 28px;
    }

    .features-bar__sep {
      color: var(--black);
      font-size: 1.2rem;
      opacity: 0.5;
    }

    /* ── WHY CLUB ─────────────────────────────────────────── */
    .why-club {
      background: var(--white);
      color: var(--black);
      padding: 72px 24px;
      text-align: center;
    }

    .section-title {
      font-family: var(--font-display);
      font-weight: 900;
      font-size: clamp(1.8rem, 4vw, 2.8rem);
      text-transform: uppercase;
      letter-spacing: 0.04em;
      color: var(--black);
    }

    .section-title--white { color: var(--white); }

    .orange-label {
      display: inline-block;
      background: var(--orange);
      color: var(--black);
      font-family: var(--font-display);
      font-weight: 700;
      font-size: 0.9rem;
      letter-spacing: 0.1em;
      text-transform: uppercase;
      padding: 5px 18px;
      border-radius: 3px;
      margin-top: 12px;
    }

    .timeline {
      display: flex;
      justify-content: center;
      align-items: flex-start;
      gap: 0;
      margin: 48px auto;
      max-width: 860px;
      position: relative;
    }

    .timeline::before {
      content: '';
      position: absolute;
      top: 16px;
      left: calc(12.5% + 16px);
      right: calc(12.5% + 16px);
      height: 3px;
      background: var(--orange);
      z-index: 0;
    }
	

    .timeline__item {
      flex: 1;
      display: flex;
      flex-direction: column;
      align-items: center;
      text-align: center;
      padding: 0 12px;
    }

    .timeline__dot {
      width: 34px;
      height: 34px;
      background: var(--orange);
      border-radius: 50%;
      border: 4px solid var(--white);
      box-shadow: 0 0 0 3px var(--orange);
      z-index: 1;
      flex-shrink: 0;
      margin-bottom: 14px;
    }

    .timeline__label {
      font-family: var(--font-body);
      font-size: 0.88rem;
      font-weight: 600;
      color: #333;
      line-height: 1.3;
    }

    /* ── EXPERIENCE ──────────────────────────────────────── */
    .experience {
      background: var(--white);
      color: var(--black);
      padding: 72px 24px;
    }

    .experience__inner {
      max-width: 1080px;
      margin: 0 auto;
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 48px;
      align-items: center;
    }

    .experience__title {
      font-family: var(--font-display);
      font-weight: 900;
      font-size: clamp(2rem, 4vw, 3rem);
      text-transform: uppercase;
      line-height: 1.05;
    }

    .experience__title span {
      color: var(--orange);
      font-style: italic;
    }

    .experience__list {
      margin: 20px 0;
      list-style: none;
      font-size: 1rem;
      color: #222;
      line-height: 2;
    }

    .experience__list li::before {
      content: '· ';
      color: var(--orange);
      font-weight: bold;
    }

    .experience__claim {
      margin-top: 16px;
      font-family: var(--font-display);
      font-weight: 800;
      font-size: 1.15rem;
      text-transform: uppercase;
      letter-spacing: 0.03em;
    }

    .photo-grid {
      display: grid;
      grid-template-columns: 1fr 1fr;
      grid-template-rows: auto auto;
      gap: 10px;
    }

    .photo-grid img:first-child {
      grid-column: 1 / -1;
      width: 100%;
      height: 220px;
      object-fit: cover;
      border-radius: 6px;
    }

    .photo-grid img:not(:first-child) {
      width: 100%;
      height: 220px;
      object-fit: cover;
      border-radius: 6px;
    }

    /* ── TEXTURA GLITTER — usada em todas as seções escuras ── */
    .glitter-bg {
	  background-image: linear-gradient(rgba(0,0,0,0.9), rgba(0,0,0,0.9)),
						url('img/imagem1.jpg');
	  background-size: cover;
	  background-position: center;
	  background-repeat: no-repeat;
}

    /* ── STRUCTURE ───────────────────────────────────────── */
    .structure {
       
    }

    .structure__header {
      background: var(--orange);
      padding: 28px 24px;
      text-align: center;
    }

    .structure__header h2 {
      font-family: var(--font-display);
      font-weight: 900;
      font-size: clamp(2rem, 5vw, 3.2rem);
      text-transform: uppercase;
      letter-spacing: 0.06em;
      color: var(--black);
    }

    .structure__body {
      padding: 60px 24px;
      text-align: center;
      max-width: 900px;
      margin: 0 auto;
    }

    .video-wrapper {
      position: relative;
      padding-bottom: 56.25%;
      height: 0;
      overflow: hidden;
      border-radius: 8px;
      box-shadow: 0 8px 40px rgba(0,0,0,0.6);
    }

    .video-wrapper iframe {
      position: absolute;
      top: 0; left: 0;
      width: 100%;
      height: 100%;
      border: 0;
    }

    .stats-row {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 24px;
      margin-top: 40px;
    }

    .stat {
      background: rgba(26, 26, 26, 0.6);
      border: 1px solid rgba(255,255,255,0.08);
      border-radius: 6px;
      padding: 24px 16px;
    }

    .stat__value {
      font-family: var(--font-display);
      font-weight: 900;
      font-size: 1.4rem;
      color: var(--orange);
      text-transform: uppercase;
    }

    .stat__label {
      font-size: 0.85rem;
      color: rgba(255,255,255,0.7);
      margin-top: 6px;
      line-height: 1.4;
    }

    /* ── PROFESSIONAL ────────────────────────────────────── */
    .professional {
     
      padding: 72px 24px;
      text-align: center;
    }

    .professional__sub {
      font-size: 1rem;
      color: rgba(255,255,255,0.7);
      margin-top: 8px;
    }

    .logos-row {
      display: flex;
      justify-content: center;
      align-items: center;
      gap: 32px;
      flex-wrap: wrap;
      margin: 36px auto;
      max-width: 1400px;
    }

    .logos-row img {
      height: 120px;
      width: auto;
      object-fit: contain;
      filter: drop-shadow(0 2px 8px rgba(0,0,0,0.5));
      transition: transform 0.2s;
    }

    .logos-row img:hover { transform: scale(1.05); }

    .means-row {
      margin-top: 24px;
      font-family: var(--font-display);
      font-weight: 700;
      font-size: 1rem;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: rgba(255,255,255,0.9);
    }

    .means-row span {
      color: var(--orange);
      margin: 0 8px;
    }

    /* ── STORE ───────────────────────────────────────────── */
    .store {
     
      padding: 72px 24px;
      text-align: center;
    }

    .brands-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 16px;
      max-width: 680px;
      margin: 36px auto 0;
    }

    .brands-grid img {
      width: 100%;
      height: 100px;
      object-fit: contain;
      
      border-radius: 6px;
      padding: 3px 3px;
      transition: transform 0.2s;
    }

    .brands-grid img:hover { transform: scale(1.03); }

    .store__note {
      margin-top: 32px;
      font-size: 0.88rem;
      color: rgba(255,255,255,0.6);
      line-height: 1.8;
    }

    .store__note strong {
      color: var(--orange);
    }

    .warning-text {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      margin-top: 24px;
      color: rgba(255,255,255,0.5);
      font-size: 0.82rem;
    }

    .warning-text::before {
      content: '⚠';
      color: var(--orange);
      font-size: 1rem;
    }

    /* ── FOR WHO ─────────────────────────────────────────── */
    .for-who {
      background: var(--black);
      padding: 72px 24px;
    }

    .for-who__inner {
      max-width: 680px;
      margin: 0 auto;
    }

    .for-who__list {
      list-style: none;
      margin-top: 32px;
    }

    .for-who__list li {
      padding: 14px 0;
      border-bottom: 1px solid #2a2a2a;
      font-size: 1.05rem;
      color: rgba(255,255,255,0.85);
      display: flex;
      align-items: center;
      gap: 14px;
    }

    .for-who__list li::before {
      content: '';
      display: inline-block;
      width: 10px;
      height: 10px;
      background: var(--orange);
      border-radius: 50%;
      flex-shrink: 0;
    }


    /* ── RESPONSIVE ──────────────────────────────────────── */
    @media (max-width: 768px) {
		.experience {
			padding: 0px 24px;
		}
		.experience__inner {
			grid-template-columns: 1fr;
		}
		.professional {
			padding: 0px 24px;
		}

      .timeline {
        flex-direction: column;
        align-items: flex-start;
        gap: 24px;
      }

      .timeline::before { display: none; }

      .timeline__item {
        flex-direction: row;
        text-align: left;
        gap: 16px;
      }

      .timeline__dot { margin-bottom: 0; flex-shrink: 0; }

      .stats-row { grid-template-columns: 1fr; }

      .brands-grid { grid-template-columns: repeat(2, 1fr); }




      .features-bar { gap: 8px; }
      .features-bar__item { font-size: 0.8rem; padding: 4px 12px; }
    }

    /* ══════════════════════════════════════════════════════
       ANIMAÇÕES
    ══════════════════════════════════════════════════════ */

    /* ── Keyframes ───────────────────────────────────────── */
    @keyframes fadeUp {
      from { opacity: 0; transform: translateY(40px); }
      to   { opacity: 1; transform: translateY(0); }
    }
    @keyframes fadeDown {
      from { opacity: 0; transform: translateY(-40px); }
      to   { opacity: 1; transform: translateY(0); }
    }
    @keyframes fadeLeft {
      from { opacity: 0; transform: translateX(-50px); }
      to   { opacity: 1; transform: translateX(0); }
    }
    @keyframes fadeRight {
      from { opacity: 0; transform: translateX(50px); }
      to   { opacity: 1; transform: translateX(0); }
    }
    @keyframes zoomIn {
      from { opacity: 0; transform: scale(0.82); }
      to   { opacity: 1; transform: scale(1); }
    }
    @keyframes popIn {
      0%   { opacity: 0; transform: scale(0.6); }
      70%  { transform: scale(1.08); }
      100% { opacity: 1; transform: scale(1); }
    }
    @keyframes slideBar {
      from { transform: scaleX(0); }
      to   { transform: scaleX(1); }
    }
    @keyframes pulse {
      0%, 100% { box-shadow: 0 0 0 0 rgba(58,158,47,0.55); }
      50%       { box-shadow: 0 0 0 12px rgba(58,158,47,0); }
    }
    @keyframes pulsOrange {
      0%, 100% { box-shadow: 0 0 0 0 rgba(247,148,29,0.5); }
      50%       { box-shadow: 0 0 0 12px rgba(247,148,29,0); }
    }
    @keyframes drawLine {
      from { width: 0; }
      to   { width: calc(100% - 32px); }
    }
    @keyframes dotPop {
      0%   { transform: scale(0); opacity: 0; }
      60%  { transform: scale(1.3); }
      100% { transform: scale(1); opacity: 1; }
    }
    @keyframes heroKenBurns {
      from { transform: scale(1); }
      to   { transform: scale(1.08); }
    }
    @keyframes shimmer {
      0%   { background-position: -200% center; }
      100% { background-position: 200% center; }
    }
    @keyframes cowboySlide {
      from { opacity: 0; transform: translateX(-60px); }
      to   { opacity: 1; transform: translateX(0); }
    }
    @keyframes barIn {
      from { opacity: 0; transform: translateY(20px); }
      to   { opacity: 1; transform: translateY(0); }
    }

    /* ── Hero animations (rodam automático, sem JS) ──────── */
    .hero__bg {
      animation: heroKenBurns 14s ease-in-out infinite alternate;
    }

    .hero__logo {
      animation: fadeDown 0.8s cubic-bezier(.22,1,.36,1) 0.2s both;
    }

    .hero__title {
      animation: fadeUp 0.9s cubic-bezier(.22,1,.36,1) 0.55s both;
    }

    .hero__sub {
      animation: fadeUp 0.9s cubic-bezier(.22,1,.36,1) 0.8s both;
    }

    .hero .btn {
      animation: fadeUp 0.9s cubic-bezier(.22,1,.36,1) 1.05s both,
                 pulse 2.5s ease 2.5s infinite;
    }

    /* Features bar */
    .features-bar__item {
      animation: fadeUp 0.7s cubic-bezier(.22,1,.36,1) both;
    }
    .features-bar__item:nth-child(1) { animation-delay: 0.1s; }
    .features-bar__item:nth-child(3) { animation-delay: 0.25s; }
    .features-bar__item:nth-child(5) { animation-delay: 0.4s; }

    /* ── Scroll reveal — estado inicial ─────────────────── */
    .reveal            { opacity: 0; transform: translateY(38px);   transition: opacity .7s cubic-bezier(.22,1,.36,1), transform .7s cubic-bezier(.22,1,.36,1); }
    .reveal-left       { opacity: 0; transform: translateX(-50px);  transition: opacity .7s cubic-bezier(.22,1,.36,1), transform .7s cubic-bezier(.22,1,.36,1); }
    .reveal-right      { opacity: 0; transform: translateX(50px);   transition: opacity .7s cubic-bezier(.22,1,.36,1), transform .7s cubic-bezier(.22,1,.36,1); }
    .reveal-zoom       { opacity: 0; transform: scale(0.85);        transition: opacity .65s cubic-bezier(.22,1,.36,1), transform .65s cubic-bezier(.22,1,.36,1); }
    .reveal-pop        { opacity: 0; transform: scale(0.7);         transition: opacity .5s cubic-bezier(.34,1.56,.64,1), transform .5s cubic-bezier(.34,1.56,.64,1); }

    /* Estado visível (adicionado pelo JS) */
    .reveal.is-visible,
    .reveal-left.is-visible,
    .reveal-right.is-visible,
    .reveal-zoom.is-visible,
    .reveal-pop.is-visible {
      opacity: 1;
      transform: none;
    }

    /* Delays escalonados */
    .d1 { transition-delay: .1s !important; }
    .d2 { transition-delay: .2s !important; }
    .d3 { transition-delay: .3s !important; }
    .d4 { transition-delay: .4s !important; }
    .d5 { transition-delay: .5s !important; }
    .d6 { transition-delay: .6s !important; }

    /* ── Timeline: linha cresce + dots aparecem ──────────── */
    .timeline-line {
      position: absolute;
      top: 16px;
      left: calc(12.5% + 16px);
      height: 3px;
      background: var(--orange);
      width: 0;
      transform-origin: left;
      transition: width 1s cubic-bezier(.22,1,.36,1) .3s;
      z-index: 0;
    }
    .timeline-line.is-visible { width: calc(75% - 32px); }
	@media (max-width: 800px) {
		.timeline-line {
			display: none;
		}
	}
    .timeline__dot {
      opacity: 0;
      transform: scale(0);
      transition: opacity .4s, transform .4s cubic-bezier(.34,1.56,.64,1);
    }
    .timeline__dot.is-visible { opacity: 1; transform: scale(1); }

    /* ── Botões — pulso contínuo ─────────────────────────── */
    .btn--green { animation: pulse 2.8s ease 3s infinite; }
    .btn:not(.btn--green):not(.btn--large) { }
    .why-club .btn,
    .experience .btn,
    .structure__body .btn { animation: pulsOrange 2.8s ease 3.5s infinite; }

    /* ── Foto grid: zoom no hover ────────────────────────── */
    .photo-grid img {
      transition: transform .4s cubic-bezier(.22,1,.36,1), box-shadow .4s;
      overflow: hidden;
    }
    .photo-grid img:hover {
      transform: scale(1.04);
      box-shadow: 0 8px 32px rgba(0,0,0,0.4);
      z-index: 2;
    }

    /* ── Stats: borda laranja cresce no hover ────────────── */
    .stat {
      transition: border-color .3s, transform .3s;
    }
    .stat:hover {
      border-color: var(--orange);
      transform: translateY(-4px);
    }

    /* ── Logo row: brilho no hover ───────────────────────── */
    .logos-row img {
      transition: transform .3s, filter .3s;
    }
    .logos-row img:hover {
      transform: scale(1.1) translateY(-4px);
      filter: drop-shadow(0 4px 14px rgba(247,148,29,.7));
    }

    /* ── Brand logos: lift no hover ──────────────────────── */
    .brands-grid img {
      transition: transform .3s cubic-bezier(.22,1,.36,1), box-shadow .3s;
    }
    .brands-grid img:hover {
      transform: translateY(-5px) scale(1.04);
      box-shadow: 0 8px 24px rgba(0,0,0,0.3);
    }

    /* ── For-who list: slide reveal individual ───────────── */
    .for-who__list li {
      opacity: 0;
      transform: translateX(-30px);
      transition: opacity .5s, transform .5s cubic-bezier(.22,1,.36,1);
    }
    .for-who__list li.is-visible { opacity: 1; transform: none; }

    /* ── Cowboy: desliza da esquerda ─────────────────────── */
    .final-cta__cowboy img.cowboy {
      opacity: 0;
      transform: translateX(-40px);
      transition: opacity .9s cubic-bezier(.22,1,.36,1) .3s,
                  transform .9s cubic-bezier(.22,1,.36,1) .3s;
    }
    .final-cta__cowboy img.cowboy.is-visible {
      opacity: 1;
      transform: translateX(0);
    }

    /* ── Orange label shimmer ────────────────────────────── */
    .orange-label {
      background: linear-gradient(90deg, var(--orange) 40%, #ffcc80 50%, var(--orange) 60%);
      background-size: 200% auto;
      animation: shimmer 3s linear 2s infinite;
      -webkit-background-clip: text;
      -webkit-text-fill-color: transparent;
      background-clip: text;
      color: transparent;
    }

    /* ── Section titles: underline cresce ───────────────── */
    .section-title {
      position: relative;
      display: inline-block;
    }
    .section-title::after {
      content: '';
      position: absolute;
      left: 50%;
      bottom: -6px;
      transform: translateX(-50%) scaleX(0);
      transform-origin: center;
      width: 60%;
      height: 3px;
      background: var(--orange);
      border-radius: 2px;
      transition: transform .6s cubic-bezier(.22,1,.36,1) .4s;
    }
    .section-title.is-visible::after { transform: translateX(-50%) scaleX(1); }