:root {
    --yellow: #F5C518;
    --yellow-dark: #D4A800;
    --blue-dark: #0A0B1A;
    --blue-mid: #0D1030;
    --blue-deep: #060814;
    --blue-accent: #080B1F;
    --purple: #1A0D35;
    --white: #FFFFFF;
    --white-80: rgba(255,255,255,0.82);
    --white-60: rgba(255,255,255,0.6);
    --card-bg: #E8D99A;
  }
  html { scroll-behavior: smooth; }
  * { margin:0; padding:0; box-sizing:border-box; }
  body { font-family:"Montserrat",sans-serif; background:var(--blue-dark); color:var(--white); overflow-x:hidden; }

  .hero { min-height:80vh; display:flex; flex-direction:column; align-items:center; justify-content:center; position:relative; overflow:hidden; padding:70px 80px; text-align:center; }
  .hero-bg { position:absolute; inset:0; background-size:cover; background-position:center top; filter:brightness(0.82) saturate(1.05); z-index:0; }
  .hero::after { content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(6,8,20,0.32) 0%, rgba(6,8,20,0.58) 100%); z-index:1; }
  .hero-text { position:relative; z-index:2; max-width:860px; width:100%; }
  .hero-visual { display:none; }
  .hero h1 { font-family:"Montserrat",sans-serif; font-size:clamp(1.9rem,3.4vw,3.2rem); font-weight:800; line-height:1.2; color:var(--white); margin-bottom:20px; }
  .hero h1 em { color:var(--yellow); font-style:normal; }
  .hero .subheadline { font-size:clamp(1rem,1.5vw,1.15rem); color:var(--white-80); line-height:1.8; margin-bottom:30px; max-width:680px; margin-left:auto; margin-right:auto; }
  .hero-vsl { width:100%; max-width:800px; margin:0 auto 60px; }
  .vsl-label { font-size:0.78rem; letter-spacing:0.2em; color:var(--yellow); text-transform:uppercase; font-weight:800; margin-bottom:12px; }
  .vsl-wrapper { border-radius:12px; overflow:hidden; box-shadow:0 8px 48px rgba(0,0,0,0.65); border:2px solid rgba(245,197,24,0.3); }
  .vsl-hint { margin-top:12px; font-size:0.88rem; color:rgba(255,255,255,0.55); }
  .btn-yellow { display:inline-flex; align-items:center; gap:10px; background:var(--yellow); color:#000; font-family:"Montserrat",sans-serif; font-weight:900; font-size:1.05rem; letter-spacing:0.06em; text-transform:uppercase; padding:20px 44px; border-radius:60px; border:none; cursor:pointer; text-decoration:none; transition:background 0.2s, transform 0.15s, box-shadow 0.2s; box-shadow:0 8px 30px rgba(245,197,24,0.35); }
  .btn-yellow:hover { background:var(--yellow-dark); transform:translateY(-2px); box-shadow:0 12px 40px rgba(245,197,24,0.5); }
  .cover-img { display:none; }

  .divider { height:3px; background:linear-gradient(90deg, transparent, var(--yellow), transparent); }

  .section { padding:80px 80px; position:relative; overflow:hidden; }
  .section-dark { background:var(--blue-mid); }
  .section-deeper { background:var(--blue-deep); }
  .section-purple { background:linear-gradient(135deg, #0D0B20 0%, #1A0D35 50%, #0D0B20 100%); }

  .accent-banner { background:var(--blue-accent); border-top:3px solid rgba(245,197,24,0.6); border-bottom:3px solid rgba(245,197,24,0.6); padding:60px 80px; position:relative; overflow:hidden; }
  .accent-banner::before { content:""; position:absolute; inset:0; background:radial-gradient(ellipse 60% 80% at 50% 50%, rgba(245,197,24,0.07) 0%, transparent 70%); pointer-events:none; }
  .accent-banner-inner { max-width:800px; margin:0 auto; text-align:center; position:relative; z-index:2; }
  .accent-banner .icon-wrap { width:60px; height:60px; background:rgba(245,197,24,0.1); border:1px solid rgba(245,197,24,0.3); border-radius:50%; display:flex; align-items:center; justify-content:center; margin:0 auto 20px; font-size:1.8rem; box-shadow:0 0 20px rgba(245,197,24,0.15); }
  .accent-banner h2 { font-family:"Montserrat",sans-serif; font-size:clamp(1.5rem,2.8vw,2.2rem); font-weight:900; color:var(--yellow); text-transform:uppercase; letter-spacing:0.04em; margin-bottom:20px; line-height:1.3; }
  .accent-banner p { font-size:1.15rem; color:var(--white-80); line-height:1.85; max-width:640px; margin:0 auto; }
  .accent-banner p strong { color:var(--white); }

  .section-title { font-family:"Montserrat",sans-serif; font-size:clamp(1.5rem,2.8vw,2.4rem); font-weight:900; color:var(--yellow); text-transform:uppercase; text-align:center; line-height:1.3; margin-bottom:48px; letter-spacing:0.02em; }
  .section-title span { color:var(--white); }

  /* CHECKLIST ELEGANTE */
  .checklist-wrap {
    max-width: 700px;
    margin: 0 auto 48px;
    position: relative;
    z-index: 2;
  }
  .checklist-item {
    display: flex;
    align-items: flex-start;
    gap: 20px;
    padding: 24px 0;
    border-bottom: 1px solid rgba(245,197,24,0.12);
    transition: background 0.2s;
  }
  .checklist-item:last-child { border-bottom: none; }
  .checklist-item:hover { background: rgba(245,197,24,0.03); border-radius: 8px; padding-left: 8px; }
  .check-icon {
    width: 36px;
    height: 36px;
    min-width: 36px;
    background: rgba(245,197,24,0.12);
    border: 1.5px solid rgba(245,197,24,0.4);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--yellow);
    font-size: 1rem;
    font-weight: 900;
    margin-top: 2px;
  }
  .check-content h4 {
    font-family: "Montserrat", sans-serif;
    font-size: 1.05rem;
    font-weight: 800;
    color: var(--white);
    margin-bottom: 6px;
    line-height: 1.3;
  }
  .check-content p {
    font-size: 0.88rem;
    color: var(--white-60);
    line-height: 1.65;
  }

  .cards-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; max-width:1000px; margin:0 auto 40px; position:relative; z-index:2; }
  .card { background:var(--card-bg); border-radius:16px; padding:30px 24px; color:#1a1208; }
  .card h3 { font-family:"Montserrat",sans-serif; font-size:1rem; font-weight:800; margin-bottom:12px; color:#1a1208; }
  .card p { font-size:0.88rem; line-height:1.65; color:#3a2a10; }

  .bonus-cards { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; max-width:1000px; margin:0 auto 40px; position:relative; z-index:2; align-items:start; }
  .bonus-card { background:rgba(255,255,255,0.04); border:1px solid rgba(245,197,24,0.25); border-radius:16px; padding:28px 24px 32px; text-align:center; display:flex; flex-direction:column; align-items:center; }
  .bonus-icon { font-size:2.5rem; margin-bottom:14px; display:block; }
  .bonus-card h3 { font-family:"Montserrat",sans-serif; font-size:1.05rem; font-weight:700; color:var(--yellow); margin-bottom:10px; line-height:1.4; }
  .bonus-card p { font-size:0.93rem; color:var(--white-60); line-height:1.65; flex:1; }
  .bonus-badge { display:inline-block; background:rgba(245,197,24,0.15); border:1px solid rgba(245,197,24,0.4); color:var(--yellow); font-size:0.7rem; font-weight:900; letter-spacing:0.12em; padding:5px 16px; border-radius:20px; margin-bottom:20px; text-transform:uppercase; align-self:center; }

  .ident-inner { max-width:680px; margin:0 auto; text-align:center; position:relative; z-index:2; }
  .ident-inner .intro { font-family:"Montserrat",sans-serif; font-size:1.55rem; color:var(--yellow); font-style:italic; margin-bottom:28px; }
  .ident-inner p { color:var(--white-80); font-size:1.15rem; line-height:1.95; margin-bottom:16px; }
  .ident-inner strong { color:var(--white); }
  .text-drama { font-family:"Montserrat",sans-serif; font-size:1.3rem; color:rgba(245,197,24,0.85); line-height:2.4; margin:22px 0; }

  .price-section { background:linear-gradient(135deg, #080B1F 0%, #0D1030 50%, #080B1F 100%); border-top:3px solid rgba(245,197,24,0.5); padding:80px 80px; text-align:center; position:relative; overflow:hidden; }
  .price-section::before { content:""; position:absolute; inset:0; background:radial-gradient(ellipse 60% 60% at 50% 50%, rgba(245,197,24,0.06) 0%, transparent 70%); pointer-events:none; }
  .price-stack { max-width:580px; margin:0 auto 40px; position:relative; z-index:2; }
  .price-stack h2 { font-family:"Montserrat",sans-serif; font-size:clamp(1.3rem,2.2vw,1.8rem); color:var(--yellow); font-weight:900; text-transform:uppercase; margin-bottom:28px; letter-spacing:0.03em; }
  .price-item { display:flex; justify-content:space-between; align-items:center; padding:14px 0; border-bottom:1px solid rgba(255,255,255,0.07); font-size:0.95rem; color:var(--white-60); }
  .price-item .item-name { font-weight:500; }
  .price-item .item-price {
    font-weight:800;
    color: #e05555;
    text-decoration: line-through;
    text-decoration-color: rgba(224,85,85,0.7);
    text-decoration-thickness: 2px;
    opacity: 0.85;
  }
  .price-total {
    display:flex;
    justify-content:space-between;
    align-items:center;
    padding:14px 0;
    border-top: 2px solid rgba(255,255,255,0.12);
    font-size:0.95rem;
    font-weight:800;
    color:var(--white);
    margin-top:4px;
  }
  .price-total .total-label { color: var(--white-80); font-weight:700; }
  .price-total .total-amount {
    font-weight: 900;
    color: var(--white);
    letter-spacing: 0.01em;
  }
  .price-offer { margin-top:32px; position:relative; z-index:2; }
  .price-offer p { font-size:1.1rem; color:var(--white-80); font-weight:600; margin-bottom:12px; }
  .por-apenas { font-size:0.75rem; color:var(--white-60); text-transform:uppercase; letter-spacing:0.2em; font-weight:700; margin-bottom:14px; }

  .price-highlight-box {
    display: inline-block;
    position: relative;
    margin: 0 auto 10px;
  }
  .price-highlight-box::before {
    content: "";
    position: absolute;
    inset: -16px -30px;
    background: radial-gradient(ellipse 80% 80% at 50% 50%, rgba(245,197,24,0.18) 0%, transparent 70%);
    border-radius: 20px;
    pointer-events: none;
  }
  .price-big {
    font-family:"Montserrat",sans-serif;
    font-size: clamp(4rem,8vw,6.5rem);
    font-weight: 900;
    color: var(--yellow);
    line-height: 1;
    letter-spacing: -0.02em;
    text-shadow: 0 0 60px rgba(245,197,24,0.5), 0 4px 20px rgba(0,0,0,0.4);
  }
  .price-divider {
    width: 60px;
    height: 2px;
    background: linear-gradient(90deg, transparent, var(--yellow), transparent);
    margin: 16px auto;
  }
  .price-note { font-size:0.82rem; color:var(--white-60); margin-bottom:34px; font-style:italic; line-height:1.7; }

  .guarantee-box { max-width:580px; margin:0 auto; background:rgba(10,12,30,0.75); border:2px solid rgba(245,197,24,0.3); border-radius:20px; padding:50px 40px; position:relative; z-index:2; text-align:center; backdrop-filter:blur(4px); }
  .guarantee-icon { font-size:4rem; margin-bottom:20px; display:block; }
  .guarantee-box h2 { font-family:"Montserrat",sans-serif; font-size:clamp(1.4rem,2.3vw,1.8rem); font-weight:900; color:var(--yellow); margin-bottom:18px; text-transform:uppercase; letter-spacing:0.04em; }
  .guarantee-box p { color:var(--white-80); font-size:1rem; line-height:1.85; }

  .final-cta { background:var(--blue-deep); padding:90px 80px; text-align:center; position:relative; overflow:hidden; }
  .final-cta::before { content:""; position:absolute; inset:0; background:radial-gradient(ellipse 70% 60% at 50% 50%, rgba(245,197,24,0.07) 0%, transparent 70%); pointer-events:none; }
  .final-cta h2 { font-family:"Montserrat",sans-serif; font-size:clamp(1.4rem,2.5vw,2rem); font-weight:800; color:var(--white); margin-bottom:16px; line-height:1.5; position:relative; z-index:2; max-width:700px; margin-left:auto; margin-right:auto; }
  .final-cta .sub { font-size:1.1rem; color:var(--white-80); font-weight:500; margin-bottom:24px; position:relative; z-index:2; line-height:1.85; }
  .final-cta .btn-yellow { position:relative; z-index:2; }

  .section-sub { text-align:center; font-size:1.05rem; color:var(--white-80); margin-bottom:34px; position:relative; z-index:2; line-height:1.7; }


  footer { background:#030408; padding:30px 80px; text-align:center; color:rgba(255,255,255,0.22); font-size:0.75rem; border-top:1px solid rgba(245,197,24,0.1); }

  /* ── Responsive line-break utilities ── */
  .br-desk { display: block; }
  .br-mob  { display: none;  }

  /* ── Pain/dor bullet list ── */
  .pain-list {
    list-style: none;
    text-align: left;
    display: inline-block;
    width: 100%;
    max-width: 520px;
    margin: 16px auto 20px;
    padding: 0;
  }
  .pain-list li {
    position: relative;
    padding: 8px 0 8px 1.6em;
    color: var(--white-80);
    font-size: 1.05rem;
    line-height: 1.65;
  }
  .pain-list li::before {
    content: "•";
    position: absolute;
    left: 0;
    color: var(--yellow);
    font-weight: 900;
    font-size: 1.1rem;
    line-height: 1.65;
  }
  .pain-list li strong { color: var(--white); }

  /* IMAGE BACKGROUND SECTIONS — fallback direto no CSS */
  #heroBg { background-image: url('../img/hero_bg.jpg'); }
  #secIdent { background-image: url('../img/img_ident_desk.jpg'); }
  #secMilitar { background-image: url('../img/img_militar_desk.jpg'); }
  /* #secBonus usa bg-aurora via .section-purple — não sobrescrever */
  #secCta { background-image: url('../img/img_cta_desk.jpg'); }

  @media (max-width: 900px) {
    #secIdent  { background-image: url('../img/img_ident_mob.png'); }
    #secMilitar{ background-image: url('../img/img_militar_mob.png'); }
    #secCta    { background-image: url('../img/img_cta_mob.png'); }
  }

  .section-img-bg {
    position: relative;
    background-size: cover;
    background-position: center;
  }
  .section-img-bg::after {
    content: "";
    position: absolute;
    inset: 0;
    background: rgba(6, 8, 20, 0.78);
    z-index: 0;
    pointer-events: none;
  }
  .section-img-bg > * {
    position: relative;
    z-index: 2;
  }

  /* EXAUST LAYOUT */
  .exaust-layout {
    display: grid;
    grid-template-columns: 1fr 1fr;
    align-items: center;
    gap: 60px;
    max-width: 1000px;
    margin: 0 auto;
    position: relative;
    z-index: 2;
  }
  .exaust-img {
    width: 100%;
    max-width: 360px;
    border-radius: 16px;
    box-shadow: 0 20px 60px rgba(0,0,0,0.6);
    justify-self: center;
  }

  /* ─── DEPOIMENTOS ─── */
  .dep-section { padding:80px 40px; }
  .dep-eyebrow { text-align:center; font-size:0.78rem; letter-spacing:0.22em; color:var(--yellow); text-transform:uppercase; font-weight:800; margin-bottom:14px; }
  .dep-main-title { font-family:"Montserrat",sans-serif; font-size:clamp(1.5rem,2.8vw,2.4rem); font-weight:900; color:var(--yellow); text-transform:uppercase; text-align:center; line-height:1.3; margin-bottom:64px; letter-spacing:0.02em; }
  .dep-main-title span { color:var(--white); }

  /* Mockups lado a lado — tamanho controlado */
  .dep-mockups-wrap { display:flex; justify-content:center; align-items:flex-end; gap:32px; max-width:960px; margin:0 auto 72px; }
  .dep-mockup { width:30%; max-width:260px; height:auto; display:block; filter:drop-shadow(0 20px 50px rgba(0,0,0,0.65)) drop-shadow(0 0 24px rgba(245,197,24,0.1)); }

  /* Animações mockups */
  .anim-mockup-left   { opacity:0; transform:translateX(-60px) translateY(18px); transition: opacity 0.85s cubic-bezier(0.22,1,0.36,1), transform 0.85s cubic-bezier(0.22,1,0.36,1); }
  .anim-mockup-center { opacity:0; transform:translateY(18px);                   transition: opacity 0.85s cubic-bezier(0.22,1,0.36,1) 0.1s, transform 0.85s cubic-bezier(0.22,1,0.36,1) 0.1s; }
  .anim-mockup-right  { opacity:0; transform:translateX(60px)  translateY(18px); transition: opacity 0.85s cubic-bezier(0.22,1,0.36,1) 0.2s, transform 0.85s cubic-bezier(0.22,1,0.36,1) 0.2s; }
  .anim-mockup-left.is-visible   { opacity:1; transform:translateX(0) translateY(0); }
  .anim-mockup-center.is-visible { opacity:1; transform:translateY(0); }
  .anim-mockup-right.is-visible  { opacity:1; transform:translateX(0) translateY(0); }

  /* ── Cards de depoimentos escritos ── */
  .dep-written-wrap { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; max-width:1100px; margin:0 auto 80px; }

  .dep-written-card {
    position: relative;
    background: linear-gradient(160deg, rgba(255,255,255,0.06) 0%, rgba(255,255,255,0.02) 100%);
    border: 1.5px solid rgba(245,197,24,0.22);
    border-top: 3px solid var(--yellow);
    border-radius: 18px;
    padding: 36px 28px 28px;
    display: flex;
    flex-direction: column;
    box-shadow: 0 8px 40px rgba(0,0,0,0.35);
    transition: transform 0.25s ease, box-shadow 0.25s ease;
  }
  .dep-written-card:hover { transform: translateY(-5px); box-shadow: 0 16px 50px rgba(0,0,0,0.45), 0 0 0 1px rgba(245,197,24,0.2); }

  .dep-written-stars { color:var(--yellow); font-size:0.95rem; letter-spacing:3px; margin-bottom:20px; }

  .dep-written-body {
    position: relative;
    color: rgba(255,255,255,0.88);
    font-size: 0.96rem;
    line-height: 1.85;
    flex: 1;
    margin-bottom: 28px;
    font-style: italic;
    padding-left: 22px;
  }
  .dep-written-body::before {
    content: "❝";
    position: absolute;
    left: 0;
    top: -2px;
    font-family: "Playfair Display", Georgia, serif;
    font-size: 1.4rem;
    color: var(--yellow);
    line-height: 1;
    font-style: normal;
  }

  .dep-written-author {
    display: flex;
    align-items: center;
    gap: 12px;
    border-top: 1px solid rgba(245,197,24,0.15);
    padding-top: 18px;
    margin-top: auto;
  }
  .dep-written-avatar {
    width: 40px;
    height: 40px;
    min-width: 40px;
    border-radius: 50%;
    background: linear-gradient(135deg, rgba(245,197,24,0.3), rgba(245,197,24,0.08));
    border: 1.5px solid rgba(245,197,24,0.4);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
    color: var(--yellow);
    font-weight: 900;
  }
  .dep-written-name { color:var(--yellow); font-weight:700; font-size:0.93rem; margin:0; line-height:1.3; }
  .dep-written-city { color:rgba(255,255,255,0.38); font-size:0.78rem; margin:3px 0 0; }

  .dep-cta-wrap { text-align:center; }

  /* Mobile */
  @media (max-width: 900px) {
    .dep-section { padding:50px 20px; }
    .dep-main-title { margin-bottom:40px; }
    .dep-mockups-wrap { flex-direction:column; align-items:center; gap:16px; margin-bottom:56px; }
    .dep-mockup { width:84%; max-width:320px; }
    .anim-mockup-left   { transform:translateY(50px); }
    .anim-mockup-center { transform:translateY(50px); }
    .anim-mockup-right  { transform:translateY(50px); }
    .anim-mockup-left.is-visible   { transform:translateY(0); }
    .anim-mockup-center.is-visible { transform:translateY(0); }
    .anim-mockup-right.is-visible  { transform:translateY(0); }
    .dep-written-wrap { grid-template-columns:1fr; gap:18px; margin-bottom:48px; }
    .dep-written-card { padding:28px 22px 24px; }
  }

  @media (max-width: 900px) {

    /* Hero */
    .hero { padding: 44px 20px 50px; min-height: auto; }
    .hero-vsl { max-width: 100%; margin-bottom: 40px; }
    .hero h1 { font-size: clamp(1.35rem, 5.5vw, 2.0rem); }
    .hero .subheadline { font-size: 0.97rem; max-width: 100%; margin-bottom: 24px; }
    .vsl-hint { font-size: 0.82rem; }
    .btn-yellow { font-size: 0.88rem; padding: 18px 24px; width: 100%; justify-content: center; white-space: normal; text-align: center; line-height: 1.35; }

    /* Sections */
    .section { padding: 50px 20px; }
    .accent-banner { padding: 44px 20px; }
    .price-section { padding: 50px 20px; }
    .final-cta { padding: 60px 20px; }
    footer { padding: 30px 20px; }

    /* Product box */
    .produto-box { padding: 22px 20px !important; width: 100%; box-sizing: border-box; }

    /* Price — evita overflow de texto */
    .price-item { flex-wrap: wrap; gap: 4px; }
    .price-item .item-name { flex: 1; min-width: 0; }
    .price-item .item-price { white-space: nowrap; }

    /* Identification */
    .ident-inner { padding: 0 4px; }
    .ident-inner p { font-size: 1rem; }
    .text-drama { font-size: 1.05rem; line-height: 2.2; }
    .ident-inner .intro { font-size: 1.25rem; }

    /* Section titles */
    .section-title { font-size: clamp(1.3rem, 5.5vw, 1.8rem); margin-bottom: 32px; }

    /* Exaust layout */
    .exaust-layout {
      grid-template-columns: 1fr;
      gap: 20px;
      text-align: center;
    }
    .exaust-img { max-width: 75%; width: 75%; max-height: 260px; object-fit: cover; object-position: top; margin: 0 auto; border-radius: 12px; }
    .accent-banner .icon-wrap { margin-left: auto; margin-right: auto; width: 44px; height: 44px; font-size: 1.2rem; margin-bottom: 14px; }
    #secExaust .exaust-layout > div { text-align: center; }
    #secExaust .exaust-layout > div .icon-wrap { margin-left: auto !important; margin-right: auto !important; width: 44px; height: 44px; font-size: 1.2rem; }

    /* Cards grid */
    .cards-grid { grid-template-columns: 1fr; gap: 16px; }
    .card { padding: 22px 18px; }
    .card h3 { font-size: 0.95rem; }
    .card p { font-size: 0.85rem; }

    /* Checklist */
    .checklist-wrap { padding: 0 4px; }
    .checklist-item { gap: 14px; padding: 20px 0; }
    .check-content h4 { font-size: 0.95rem; }
    .check-content p { font-size: 0.82rem; }

    /* Bonus */
    .bonus-cards { grid-template-columns: 1fr; gap: 16px; }
    .bonus-card { padding: 24px 18px; }
    .bonus-card h3 { font-size: 1rem; }
    .bonus-card p { font-size: 0.88rem; }

    /* Product box */
    .section-sub { font-size: 0.95rem; }

    /* Price */
    .price-stack h2 { font-size: 1.1rem; }
    .price-item { font-size: 0.88rem; }
    .price-big { font-size: clamp(3rem, 14vw, 4.5rem); }
    .price-note { font-size: 0.78rem; }

    /* Guarantee */
    .guarantee-box { padding: 36px 20px; }
    .guarantee-box h2 { font-size: 1.3rem; }
    .guarantee-box p { font-size: 0.92rem; }

    /* Responsive break utilities */
    .br-desk { display: none; }
    .br-mob  { display: block; }

    /* Pain list — keep left-aligned even in centered containers */
    .pain-list { text-align: left; max-width: 100%; }
    .pain-list li { font-size: 0.97rem; }

    /* Final CTA */
    .final-cta h2 { font-size: clamp(1.2rem, 5vw, 1.6rem); }
    .final-cta .sub { font-size: 0.97rem; }

    /* Accent banner */
    .accent-banner h2 { font-size: clamp(1.3rem, 5.5vw, 1.8rem); }
    .accent-banner p { font-size: 1rem; }
  }

  /* ═══════════════════════════════════
     SCROLL ANIMATIONS
  ═══════════════════════════════════ */

  /* Base states - hidden before animation */
  .anim-fade-up       { opacity:0; transform:translateY(50px); transition: opacity 0.75s ease, transform 0.75s ease; }
  .anim-fade-down     { opacity:0; transform:translateY(-40px); transition: opacity 0.75s ease, transform 0.75s ease; }
  .anim-fade-left     { opacity:0; transform:translateX(-60px); transition: opacity 0.75s ease, transform 0.75s ease; }
  .anim-fade-right    { opacity:0; transform:translateX(60px); transition: opacity 0.75s ease, transform 0.75s ease; }
  .anim-scale-up      { opacity:0; transform:scale(0.88); transition: opacity 0.7s ease, transform 0.7s cubic-bezier(0.34,1.56,0.64,1); }
  .anim-scale-in      { opacity:0; transform:scale(0.75); transition: opacity 0.6s ease, transform 0.6s cubic-bezier(0.34,1.56,0.64,1); }
  .anim-blur-in       { opacity:0; filter:blur(12px); transform:translateY(20px); transition: opacity 0.8s ease, filter 0.8s ease, transform 0.8s ease; }
  .anim-flip-up       { opacity:0; transform:perspective(600px) rotateX(20deg) translateY(30px); transition: opacity 0.7s ease, transform 0.7s ease; }
  .anim-rotate-in     { opacity:0; transform:rotate(-8deg) scale(0.9); transition: opacity 0.7s ease, transform 0.7s cubic-bezier(0.34,1.56,0.64,1); }

  /* Delays */
  .delay-1 { transition-delay: 0.1s !important; }
  .delay-2 { transition-delay: 0.2s !important; }
  .delay-3 { transition-delay: 0.3s !important; }
  .delay-4 { transition-delay: 0.4s !important; }
  .delay-5 { transition-delay: 0.5s !important; }
  .delay-6 { transition-delay: 0.6s !important; }

  /* Visible state - triggered by JS */
  .anim-fade-up.is-visible,
  .anim-fade-down.is-visible,
  .anim-fade-left.is-visible,
  .anim-fade-right.is-visible    { opacity:1; transform:translateY(0) translateX(0); }
  .anim-scale-up.is-visible,
  .anim-scale-in.is-visible      { opacity:1; transform:scale(1); }
  .anim-blur-in.is-visible       { opacity:1; filter:blur(0); transform:translateY(0); }
  .anim-flip-up.is-visible       { opacity:1; transform:perspective(600px) rotateX(0deg) translateY(0); }
  .anim-rotate-in.is-visible     { opacity:1; transform:rotate(0deg) scale(1); }

  /* Line draw animation for divider */
  .divider-anim {
    background: linear-gradient(90deg, transparent, var(--yellow), transparent);
    height: 3px;
    transform: scaleX(0);
    transition: transform 1s cubic-bezier(0.4,0,0.2,1);
    transform-origin: left;
  }
  .divider-anim.is-visible { transform: scaleX(1); }

  /* Stagger children helper */
  .stagger-children > * { opacity:0; transform:translateY(30px); transition: opacity 0.6s ease, transform 0.6s ease; }
  .stagger-children.is-visible > *:nth-child(1) { opacity:1; transform:none; transition-delay:0.05s; }
  .stagger-children.is-visible > *:nth-child(2) { opacity:1; transform:none; transition-delay:0.18s; }
  .stagger-children.is-visible > *:nth-child(3) { opacity:1; transform:none; transition-delay:0.31s; }
  .stagger-children.is-visible > *:nth-child(4) { opacity:1; transform:none; transition-delay:0.44s; }
  .stagger-children.is-visible > *:nth-child(5) { opacity:1; transform:none; transition-delay:0.57s; }

  /* Pulse on CTA button */
  @keyframes pulse-glow {
    0%, 100% { box-shadow: 0 8px 30px rgba(245,197,24,0.35); }
    50%       { box-shadow: 0 8px 50px rgba(245,197,24,0.7), 0 0 0 8px rgba(245,197,24,0.1); }
  }
  .btn-yellow.is-visible { animation: pulse-glow 2.5s ease-in-out infinite; }

  /* Counter number bounce */
  @keyframes bounce-in {
    0%   { opacity:0; transform:scale(0.5) translateY(20px); }
    60%  { transform:scale(1.1) translateY(-5px); }
    100% { opacity:1; transform:scale(1) translateY(0); }
  }
  .anim-bounce.is-visible { animation: bounce-in 0.7s cubic-bezier(0.34,1.56,0.64,1) forwards; }
  .anim-bounce { opacity:0; }

/* ══════════════════════════════════════════════════════════════
   AJUSTES 1–10
══════════════════════════════════════════════════════════════ */

/* AJUSTE 1 — Headline única 4 linhas
   Usa .hero .hero-h1 (especificidade 0,2,0) para vencer
   .hero h1 (0,1,1) do CSS original */
.hero .hero-h1 {
  font-family: "Montserrat", sans-serif;
  font-size: clamp(1.6rem, 2.7vw, 2.5rem);
  font-weight: 900;
  line-height: 1.25;
  color: var(--white);
  text-align: center;
  margin-bottom: 20px;
}

/* AJUSTE 2 — Bloco de justificação dentro do hero */
.hero-justification {
  margin-top: 48px;
  padding: 36px 32px;
  background: rgba(6, 8, 20, 0.80);
  border: 1px solid rgba(245, 197, 24, 0.18);
  border-radius: 20px;
  text-align: center;
  max-width: 720px;
  margin-left: auto;
  margin-right: auto;
  position: relative;
  z-index: 2;
}
.hero-justification .just-intro {
  font-size: 1.05rem;
  color: var(--white-80);
  margin-bottom: 8px;
}
.hero-justification .just-intro strong {
  color: var(--white);
}
.hero-justification .just-drama {
  font-family: "Montserrat", sans-serif;
  font-size: clamp(1.1rem, 2.2vw, 1.5rem);
  color: rgba(245, 197, 24, 0.9);
  line-height: 1.7;
  margin: 14px 0 18px;
}
.hero-justification p:last-child {
  font-size: 0.97rem;
  color: var(--white-80);
  line-height: 1.75;
}

/* AJUSTE 3 — Seção de estatística */
.stat-section {
  padding: 70px 80px;
  background: var(--blue-mid);
  text-align: center;
  position: relative;
  overflow: hidden;
}
.stat-section::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 60% 60% at 50% 50%, rgba(245,197,24,0.06) 0%, transparent 70%);
  pointer-events: none;
}
.stat-number {
  font-family: "Montserrat", sans-serif;
  font-size: clamp(5rem, 12vw, 8rem);
  font-weight: 900;
  color: var(--yellow);
  line-height: 1;
  text-shadow: 0 0 80px rgba(245, 197, 24, 0.4);
  position: relative;
  z-index: 2;
}
.stat-desc {
  font-size: clamp(1rem, 1.6vw, 1.15rem);
  color: var(--white-80);
  max-width: 640px;
  margin: 16px auto 36px;
  line-height: 1.8;
  position: relative;
  z-index: 2;
}
.stat-image {
  width: 100%;
  max-width: 520px;
  border-radius: 18px;
  display: block;
  margin: 0 auto;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.6), 0 0 0 2px rgba(245,197,24,0.18);
  position: relative;
  z-index: 2;
}

/* AJUSTE 4 — Seção "Dormir em paz" */
.dormir-cta-section {
  text-align: center;
  padding: 70px 80px;
}
.dormir-titulo {
  font-family: "Montserrat", sans-serif;
  font-size: clamp(1.6rem, 2.8vw, 2.4rem);
  font-weight: 900;
  color: var(--white);
  text-transform: uppercase;
  margin-bottom: 16px;
  line-height: 1.25;
  position: relative;
  z-index: 2;
}
.dormir-subtitulo {
  font-size: clamp(1.1rem, 1.8vw, 1.3rem);
  color: var(--yellow);
  font-weight: 700;
  margin-bottom: 36px;
  position: relative;
  z-index: 2;
}

/* AJUSTE 5 — Pain list com ícones FA */
.pain-list {
  list-style: none;
  text-align: left !important;
  display: block;
  width: 100%;
  max-width: 520px;
  margin: 16px auto 20px;
  padding: 0;
}
.pain-list li {
  display: flex !important;
  align-items: flex-start;
  gap: 14px;
  padding: 8px 0;
  border-bottom: none;
}
.pain-list li::before {
  display: none !important;
}
.pain-icon {
  width: 40px;
  height: 40px;
  min-width: 40px;
  background: rgba(245, 197, 24, 0.08);
  border: 1px solid rgba(245, 197, 24, 0.25);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  margin-top: 2px;
}
.pain-icon i {
  color: var(--yellow);
  font-size: 1rem;
}
.pain-text {
  color: var(--white-80);
  font-size: 1.02rem;
  line-height: 1.6;
  padding-top: 9px;
}

/* AJUSTE 6 — Moon divider */
.moon-divider {
  display: flex;
  align-items: center;
  gap: 14px;
  margin: 24px 0;
  width: 100%;
  max-width: 520px;
}
.moon-divider::before,
.moon-divider::after {
  content: "";
  flex: 1;
  height: 1.5px;
  background: linear-gradient(90deg, transparent, rgba(245,197,24,0.45), transparent);
}
.moon-divider span {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  background: rgba(245, 197, 24, 0.1);
  border: 1px solid rgba(245, 197, 24, 0.35);
  border-radius: 50%;
  flex-shrink: 0;
}
.moon-divider i {
  color: var(--yellow);
  font-size: 1rem;
}

/* AJUSTE 7 — Setas em linhas separadas */
.arrows-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-top: 10px;
  font-size: 1.05rem;
  color: var(--white);
  font-weight: 700;
}
.arrows-list span {
  display: block;
}
.arrow-icon {
  color: var(--yellow);
  margin-right: 8px;
}

/* AJUSTE 8 — Quebra de crença: fundo estrelado + attempts list */
.section-deeper.quebra-section {
  background:
    radial-gradient(ellipse 80% 60% at 50% 0%, rgba(13, 20, 80, 0.7) 0%, transparent 70%),
    var(--blue-deep);
  position: relative;
}
.section-deeper.quebra-section::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(1.5px 1.5px at 10% 15%, rgba(255,255,255,0.55) 0%, transparent 100%),
    radial-gradient(1px 1px at 20% 40%, rgba(255,255,255,0.4) 0%, transparent 100%),
    radial-gradient(2px 2px at 30% 10%, rgba(255,255,255,0.6) 0%, transparent 100%),
    radial-gradient(1px 1px at 40% 65%, rgba(255,255,255,0.35) 0%, transparent 100%),
    radial-gradient(1.5px 1.5px at 55% 25%, rgba(255,255,255,0.5) 0%, transparent 100%),
    radial-gradient(1px 1px at 65% 55%, rgba(255,255,255,0.45) 0%, transparent 100%),
    radial-gradient(2px 2px at 75% 8%, rgba(255,255,255,0.55) 0%, transparent 100%),
    radial-gradient(1px 1px at 80% 75%, rgba(255,255,255,0.4) 0%, transparent 100%),
    radial-gradient(1.5px 1.5px at 88% 35%, rgba(255,255,255,0.5) 0%, transparent 100%),
    radial-gradient(1px 1px at 92% 60%, rgba(255,255,255,0.35) 0%, transparent 100%),
    radial-gradient(1px 1px at 5% 80%, rgba(255,255,255,0.45) 0%, transparent 100%),
    radial-gradient(1.5px 1.5px at 48% 90%, rgba(255,255,255,0.5) 0%, transparent 100%);
  pointer-events: none;
  z-index: 0;
}
.section-deeper.quebra-section > * {
  position: relative;
  z-index: 2;
}

.attempts-list {
  list-style: none;
  padding: 0;
  margin: 20px auto 28px;
  max-width: 500px;
  text-align: left;
}
.attempts-list li {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 10px 0;
  border-bottom: 1px solid rgba(245, 197, 24, 0.1);
  font-size: 1.02rem;
  color: var(--white-80);
  line-height: 1.5;
}
.attempts-list li:last-child {
  border-bottom: none;
}
.att-icon {
  width: 38px;
  height: 38px;
  min-width: 38px;
  background: rgba(245, 197, 24, 0.08);
  border: 1px solid rgba(245, 197, 24, 0.22);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.att-icon i {
  color: var(--yellow);
  font-size: 0.95rem;
}

/* stagger 6 filhos */
.stagger-children.is-visible > *:nth-child(6) { opacity: 1; transform: none; transition-delay: 0.70s; }

/* AJUSTE 9 — Produto imagem sem fundo, sem círculo */
/* PNG é 1080x1920 — conteúdo visível fica na faixa central.
   Negative margins compensam o espaço transparente acima e abaixo. */
.produto-img-wrap {
  text-align: center;
  margin-bottom: 0;
  position: relative;
  z-index: 2;
}
.produto-img {
  max-width: 280px;
  width: 100%;
  height: auto;
  border-radius: 0;
  border: none;
  box-shadow: none;
  display: block;
  margin: -145px auto -120px;
  object-fit: contain;
}
.produto-label {
  font-size: 0.72rem;
  letter-spacing: 0.22em;
  color: var(--yellow);
  text-transform: uppercase;
  font-weight: 800;
  margin-bottom: 8px;
}
.produto-nome {
  font-family: "Montserrat", sans-serif;
  font-size: clamp(1.4rem, 2.8vw, 2.2rem);
  font-weight: 900;
  color: var(--white);
  line-height: 1.3;
  margin-bottom: 0;
}
.produto-nome span {
  color: var(--yellow);
}

/* Título do produto — menos margem para não distanciar da imagem abaixo */
.section-dark .section-title:first-child {
  margin-bottom: 20px;
}
/* Subtítulo logo abaixo da imagem do produto */
.section-dark .section-sub {
  margin-bottom: 24px;
}

/* AJUSTE 10 — Itens de preço com ícone imagem */
.price-item-icon {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.07);
}
.price-bonus-img {
  width: 44px;
  height: 44px;
  min-width: 44px;
  border-radius: 50%;
  object-fit: contain;
  background: #fff;
  padding: 3px;
}
.item-name-icon {
  flex: 1;
  font-size: 0.88rem;
  color: var(--white-60);
  font-weight: 500;
  line-height: 1.4;
}
.item-price-icon {
  font-weight: 800;
  color: #e05555;
  text-decoration: line-through;
  text-decoration-color: rgba(224, 85, 85, 0.7);
  text-decoration-thickness: 2px;
  opacity: 0.85;
  font-size: 0.9rem;
  white-space: nowrap;
}

/* Passos "Você só precisa" */
.passos-list {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  margin: 0 auto 8px;
  position: relative;
  z-index: 2;
}
.passo-item {
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 1.05rem;
  color: var(--white-80);
  font-weight: 600;
}
.passo-arrow {
  color: var(--yellow);
  font-size: 0.95rem;
  flex-shrink: 0;
}

/* Ícones FA nos itens de preço */
.price-bonus-fa {
  width: 48px;
  height: 48px;
  min-width: 48px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1.5px solid rgba(245, 197, 24, 0.35);
  box-shadow: 0 2px 12px rgba(0,0,0,0.35);
}
.price-bonus-fa i {
  color: var(--yellow);
  font-size: 1.4rem;
}

/* bonus-icon FA */
.bonus-icon {
  font-size: 2.2rem;
  margin-bottom: 14px;
  display: block;
  color: var(--yellow);
}

/* ── MOBILE — AJUSTES ── */
@media (max-width: 900px) {

  /* AJUSTE 1 — sobrescreve .hero h1 (0,1,1) com seletor 0,2,0
     SE(375px): 4.0vw=15px | 12/13(390px): 15.6px | XR(414px): 16.6px */
  .hero .hero-h1 { font-size: 4.0vw; line-height: 1.32; }

  /* AJUSTE 2 */
  .hero-justification { padding: 24px 18px; margin-top: 32px; border-radius: 14px; }
  .hero-justification .just-drama { font-size: clamp(1rem, 3.8vw, 1.2rem); }

  /* AJUSTE 3 */
  .stat-section { padding: 50px 20px; }
  .stat-image { border-radius: 12px; }

  /* AJUSTE 4 */
  .dormir-cta-section { padding: 44px 20px; }

  /* AJUSTE 5 */
  .pain-icon { width: 36px; height: 36px; min-width: 36px; }
  .pain-text { font-size: 0.95rem; }

  /* AJUSTE 6 */
  .moon-divider { max-width: 100%; }

  /* AJUSTE 7 */
  .arrows-list { font-size: 0.97rem; }

  /* AJUSTE 8 */
  .att-icon { width: 34px; height: 34px; min-width: 34px; }
  .attempts-list { max-width: 100%; }

  /* AJUSTE 9 */
  .produto-img { max-width: 210px; margin: -105px auto -90px; }
  .produto-img-wrap { margin-bottom: 0; }
  .section-dark .section-title:first-child { margin-bottom: 12px; }
  .produto-nome { font-size: clamp(1.15rem, 4.5vw, 1.5rem); }

  /* AJUSTE 10 */
  .price-item-icon { gap: 10px; }
  .item-name-icon { font-size: 0.82rem; }
  .item-price-icon { font-size: 0.82rem; }

  /* Exaust layout — centralizar no mobile */
  #secExaust .pain-list { text-align: left !important; margin-left: 0; }
  #secExaust .moon-divider { margin-left: 0; }
  #secExaust .arrows-list { text-align: left; }
}

/* ══════════════════════════════════════════════════════
   VISUAL UPGRADE — BACKGROUNDS VARIADOS POR SEÇÃO
══════════════════════════════════════════════════════ */

/* ── Cada bloco tem seu tema visual ── */

/* stat + price + final-cta: noite estrelada */
.stat-section,
.price-section,
.final-cta {
  background-image: url('../img/bg-starry-night.jpg');
  background-size: cover;
  background-attachment: fixed;
}

/* section-dark (produto): nebulosa roxa — foco/mente */
.section-dark {
  background-image: url('../img/bg-nebula-purple.jpg');
  background-size: cover;
  background-attachment: fixed;
  background-color: transparent;
}

/* section-purple (bônus): aurora boreal — mágico/presente */
.section-purple {
  background-image: url('../img/bg-aurora.jpg');
  background-size: cover;
  background-attachment: fixed;
  background-color: transparent;
}

/* dep-section (depoimentos): tom quente — resultados humanos */
.dep-section {
  background-image: url('../img/bg-warm-amber.jpg');
  background-size: cover;
  background-attachment: fixed;
  background-color: transparent;
}

/* section-deeper (garantia, dormir-cta): noite estrelada */
.section-deeper {
  background-image: url('../img/bg-starry-night.jpg');
  background-size: cover;
  background-attachment: fixed;
  background-color: transparent;
}

/* accent-banners: fallback estrelado (IDs sobrescrevem com img própria) */
.accent-banner {
  background-image: url('../img/bg-starry-night.jpg') !important;
  background-size: cover !important;
  background-attachment: fixed !important;
}
.accent-banner::before {
  background: radial-gradient(ellipse 60% 80% at 50% 50%, rgba(245,197,24,0.06) 0%, transparent 70%) !important;
  background-image: none !important;
}

/* ── Overlays escuros por tipo — garantem legibilidade ── */
.stat-section::before { background: rgba(5,7,25,0.88) !important; background-image: none !important; }

.section-dark::before { content:""; position:absolute; inset:0; background:rgba(8,6,26,0.86); z-index:0; pointer-events:none; }
.section-dark > *     { position:relative; z-index:2; }

.section-deeper::before { content:""; position:absolute; inset:0; background:rgba(5,7,22,0.90); z-index:0; pointer-events:none; }
.section-deeper > *   { position:relative; z-index:2; }

.section-purple::before { content:""; position:absolute; inset:0; background:rgba(5,4,20,0.84); z-index:0; pointer-events:none; }
.section-purple > *   { position:relative; z-index:2; }

.price-section::before { content:""; position:absolute; inset:0; background:rgba(6,7,22,0.91); z-index:0; pointer-events:none; }
.price-section > *    { position:relative; z-index:2; }

.final-cta::before    { background:rgba(5,6,20,0.88) !important; background-image:none !important; }

.dep-section::before  { content:""; position:absolute; inset:0; background:rgba(6,4,12,0.84); z-index:0; pointer-events:none; }
.dep-section > *      { position:relative; z-index:2; }

/* ── Quebra-section: noite estrelada com overlay leve ── */
.section-deeper.quebra-section {
  background-image: url('../img/bg-starry-night.jpg') !important;
  background-size: cover !important;
  background-position: center top !important;
  background-attachment: fixed !important;
}
.section-deeper.quebra-section::before {
  background: rgba(5,7,26,0.78) !important;
  background-image: none !important;
}

/* ── Layout interno da quebra-section ── */
.quebra-content {
  max-width: 700px;
  margin: 0 auto;
  position: relative;
  z-index: 2;
}

.quebra-subtitulo {
  text-align: center;
  font-size: 1.12rem;
  color: var(--white-80);
  margin-bottom: 32px;
  font-weight: 600;
}

.quebra-tentativas {
  margin-bottom: 36px;
}

/* ── Grupos de tentativas com círculo ilustrado ── */
.attempts-grouped {
  display: flex;
  flex-direction: column;
  gap: 18px;
  max-width: 580px;
  margin: 0 auto;
}

.attempt-group {
  display: flex;
  align-items: center;
  gap: 24px;
}

.attempt-circle {
  width: 112px;
  height: 112px;
  min-width: 112px;
  border-radius: 50%;
  overflow: hidden;
  border: 2.5px solid rgba(245,197,24,0.6);
  box-shadow:
    0 0 0 5px rgba(245,197,24,0.08),
    0 0 28px rgba(245,197,24,0.22),
    0 8px 32px rgba(0,0,0,0.6);
  flex-shrink: 0;
  background: #0a0c28;
}

.attempt-circle img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center center;
  padding: 8px;
}

.attempt-items {
  list-style: none;
  padding: 0;
  margin: 0;
}

.attempt-items li {
  color: var(--white-80);
  font-size: 1.02rem;
  line-height: 1.7;
  padding: 2px 0;
  position: relative;
  padding-left: 18px;
}

.attempt-items li::before {
  content: "•";
  position: absolute;
  left: 0;
  color: var(--yellow);
  font-weight: 900;
  font-size: 1.1rem;
}

.attempt-items li strong {
  color: #fff;
  font-weight: 800;
}

/* ── Seção inferior: texto + imagem lado a lado ── */
.quebra-bottom {
  display: flex;
  align-items: flex-end;
  gap: 36px;
  margin-top: 36px;
  padding-top: 32px;
  border-top: 1px solid rgba(245,197,24,0.14);
  position: relative;
  z-index: 2;
}

.quebra-bottom-text {
  flex: 1;
}

.quebra-bottom-text p {
  font-size: 1.0rem;
  color: var(--white-80);
  line-height: 1.75;
  margin-bottom: 14px;
}

.quebra-bottom-text strong {
  color: #fff;
}

.motivo-intro {
  font-size: 1.08rem !important;
  font-weight: 700;
  color: var(--white-80) !important;
  margin-top: 8px;
}

/* ── Callouts com emoji de mão apontando ── */
.hand-points {
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin-top: 16px;
}

.hand-point {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  font-size: 1.02rem;
  color: var(--white-80);
  line-height: 1.65;
}

.hand-emoji {
  font-size: 1.45rem;
  flex-shrink: 0;
  line-height: 1.45;
  filter: drop-shadow(0 0 6px rgba(245,197,24,0.5));
}

.hand-point p {
  margin: 0;
}

.hand-point strong {
  color: var(--yellow) !important;
  font-weight: 800;
}

/* ── Imagem decorativa lateral (pessoa na cama) ── */
.quebra-person-img {
  width: 210px;
  min-width: 210px;
  flex-shrink: 0;
  border-radius: 22px;
  overflow: hidden;
  box-shadow:
    0 24px 70px rgba(0,0,0,0.75),
    0 0 0 2px rgba(245,197,24,0.28),
    0 0 40px rgba(245,197,24,0.1);
}

.quebra-person-img img {
  width: 100%;
  display: block;
  object-fit: cover;
  object-position: center 10%;
  max-height: 310px;
}

/* ── Bônus: ícones ilustrados em vez de Font Awesome ── */
.bonus-icon-illustrated {
  width: 150px;
  height: 150px;
  margin: 0 auto 20px;
  display: block;
  object-fit: contain;
  filter:
    drop-shadow(0 4px 16px rgba(245,197,24,0.3))
    drop-shadow(0 0 32px rgba(245,197,24,0.1));
  border-radius: 0;
}

/* ── Produto: ícone-cerebro acima da imagem do produto ── */
.produto-cerebro-icon {
  width: 90px;
  height: 90px;
  display: block;
  margin: 0 auto 16px;
  object-fit: contain;
  filter: drop-shadow(0 4px 20px rgba(245,197,24,0.4));
}

/* ── Dormir-cta: aurora para variar do stat-section acima ── */
.dormir-cta-section {
  background-image: url('../img/bg-aurora.jpg') !important;
  background-size: cover !important;
  background-attachment: fixed !important;
}

/* ── Seção de garantia: warm amber para variar da price-section ── */
.section.section-deeper:has(.guarantee-box) {
  background-image: url('../img/bg-warm-amber.jpg') !important;
  background-size: cover !important;
  background-attachment: fixed !important;
}

/* ══════════════════════════════════════════════════════
   MOBILE — VISUAL UPGRADE
══════════════════════════════════════════════════════ */
@media (max-width: 900px) {
  .stat-section,
  .section-dark,
  .section-deeper,
  .section-purple,
  .price-section,
  .final-cta,
  .dep-section,
  .accent-banner,
  .dormir-cta-section,
  .section.section-deeper:has(.guarantee-box) {
    background-attachment: scroll; /* fixed não funciona bem no iOS */
  }

  .quebra-bottom {
    flex-direction: column-reverse;
    gap: 28px;
    align-items: center;
  }

  .quebra-person-img {
    width: 100%;
    min-width: unset;
    max-width: 300px;
    margin: 0 auto;
  }

  .quebra-person-img img {
    max-height: 260px;
  }

  .attempts-grouped {
    max-width: 100%;
    gap: 14px;
  }

  .attempt-group {
    gap: 16px;
  }

  .attempt-circle {
    width: 76px;
    height: 76px;
    min-width: 76px;
  }

  .attempt-items li {
    font-size: 0.94rem;
  }

  .bonus-icon-illustrated {
    width: 120px;
    height: 120px;
  }

  .quebra-content {
    padding: 0 4px;
  }
}

/* ══════════════════════════════════════════════════════
   AJUSTE 3 — Highlight amarelo na headline do hero
══════════════════════════════════════════════════════ */
.hl-yellow {
  color: var(--yellow);
}

/* ══════════════════════════════════════════════════════
   AJUSTE 1 — Pain grid 2×2 com imagem acima do texto
══════════════════════════════════════════════════════ */
.pain-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  width: 100%;
  max-width: 520px;
  margin: 16px auto 24px;
}

.pain-card {
  background: rgba(0,0,0,0.35);
  border: 1px solid rgba(245,197,24,0.2);
  border-radius: 14px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: transform 0.2s, box-shadow 0.2s;
}
.pain-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 28px rgba(245,197,24,0.15);
}

.pain-card-img-wrap {
  width: 100%;
  aspect-ratio: 4/3;
  overflow: hidden;
}
.pain-card-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  display: block;
  filter: brightness(0.88) saturate(0.85);
  transition: transform 0.3s;
}
.pain-card:hover .pain-card-img {
  transform: scale(1.04);
}

.pain-card-text {
  padding: 10px 12px 14px;
  font-size: 0.82rem;
  color: var(--white-80);
  line-height: 1.55;
  margin: 0;
}

/* Mobile */
@media (max-width: 900px) {
  .pain-grid {
    grid-template-columns: 1fr 1fr;
    gap: 12px;
    max-width: 100%;
  }
  .pain-card-text {
    font-size: 0.78rem;
    padding: 8px 10px 12px;
  }
}

/* ══════════════════════════════════════════════════════
   AJUSTE 2 — Seção solução rica (ref 2)
══════════════════════════════════════════════════════ */
.solucao-section {
  position: relative;
  overflow: hidden;
  padding: 70px 40px;
  border-top: 3px solid rgba(245,197,24,0.6);
  border-bottom: 3px solid rgba(245,197,24,0.6);
  background-color: var(--blue-accent);
}
.solucao-section::after {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(6,8,20,0.82);
  z-index: 0;
  pointer-events: none;
}
.solucao-inner {
  position: relative;
  z-index: 2;
  max-width: 720px;
  margin: 0 auto;
}

/* Decorações laterais */
.solucao-deco {
  position: absolute;
  z-index: 1;
  opacity: 0.6;
  pointer-events: none;
}
.solucao-deco-left  { left: -30px; top: 50%; transform: translateY(-50%); }
.solucao-deco-right { right: -20px; top: 40%; transform: translateY(-50%); }

/* Cabeçalho */
.solucao-header {
  text-align: center;
  margin-bottom: 36px;
}
.solucao-star-icon {
  width: 58px;
  height: 58px;
  background: rgba(245,197,24,0.12);
  border: 1.5px solid rgba(245,197,24,0.45);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 18px;
  box-shadow: 0 0 24px rgba(245,197,24,0.2);
}
.solucao-star-icon i {
  color: var(--yellow);
  font-size: 1.4rem;
}
.solucao-titulo {
  font-family: "Montserrat", sans-serif;
  font-size: clamp(1.4rem, 2.6vw, 2.1rem);
  font-weight: 900;
  color: var(--yellow);
  text-transform: uppercase;
  line-height: 1.25;
  letter-spacing: 0.03em;
  margin: 0;
}

/* 4 cards de benefício */
.solucao-cards {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  margin-bottom: 40px;
}
.solucao-card {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(245,197,24,0.3);
  border-radius: 14px;
  padding: 20px 14px 18px;
  text-align: center;
}
.solucao-card-icon {
  width: 46px;
  height: 46px;
  background: rgba(245,197,24,0.1);
  border: 1.5px solid rgba(245,197,24,0.4);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 12px;
}
.solucao-card-icon i {
  color: var(--yellow);
  font-size: 1.1rem;
}
.solucao-card h4 {
  font-family: "Montserrat", sans-serif;
  font-size: 0.72rem;
  font-weight: 900;
  color: var(--yellow);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin-bottom: 6px;
}
.solucao-card p {
  font-size: 0.78rem;
  color: var(--white-60);
  line-height: 1.5;
  margin: 0;
}

/* Passos do processo */
.solucao-steps {
  display: flex;
  flex-direction: column;
  gap: 20px;
  margin-bottom: 36px;
}
.solucao-step {
  display: flex;
  align-items: center;
  gap: 20px;
  padding: 18px 20px;
  background: rgba(255,255,255,0.03);
  border-left: 3px solid rgba(245,197,24,0.5);
  border-radius: 0 12px 12px 0;
}
.solucao-step-icon {
  width: 54px;
  height: 54px;
  min-width: 54px;
  background: rgba(245,197,24,0.1);
  border: 2px solid rgba(245,197,24,0.45);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 0 20px rgba(245,197,24,0.15);
  flex-shrink: 0;
}
.solucao-step-icon i {
  color: var(--yellow);
  font-size: 1.35rem;
}
.solucao-step-text {
  font-size: 0.97rem;
  color: var(--white-80);
  line-height: 1.7;
}
.solucao-step-text strong {
  color: var(--yellow);
  font-weight: 800;
  display: block;
  margin-top: 2px;
  font-size: 1.0rem;
  letter-spacing: 0.02em;
}

/* Caixa de destaque */
.solucao-highlight {
  margin-bottom: 32px;
  border-radius: 16px;
  background: linear-gradient(135deg, rgba(245,197,24,0.08) 0%, rgba(245,197,24,0.03) 100%);
  border: 2px solid rgba(245,197,24,0.4);
  box-shadow: 0 0 40px rgba(245,197,24,0.1), inset 0 0 30px rgba(245,197,24,0.03);
  padding: 32px 28px;
  text-align: center;
}
.solucao-hl-sub {
  font-size: 1.1rem;
  color: var(--white-60);
  font-weight: 600;
  margin-bottom: 4px;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}
.solucao-hl-title {
  font-family: "Montserrat", sans-serif;
  font-size: clamp(1.6rem, 3vw, 2.4rem);
  font-weight: 900;
  color: var(--yellow);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: 20px;
  text-shadow: 0 0 40px rgba(245,197,24,0.3);
}
.solucao-pills {
  display: flex;
  justify-content: center;
  gap: 14px;
  flex-wrap: wrap;
}
.solucao-pills span {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  background: rgba(245,197,24,0.1);
  border: 1px solid rgba(245,197,24,0.35);
  color: var(--yellow);
  font-size: 0.82rem;
  font-weight: 700;
  padding: 7px 16px;
  border-radius: 30px;
  letter-spacing: 0.04em;
}
.solucao-pills span i {
  font-size: 0.78rem;
}

/* CTA final da seção */
.solucao-cta-prompt {
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
}
.solucao-star-sm {
  width: 44px !important;
  height: 44px !important;
}
.solucao-star-sm i {
  font-size: 1.1rem !important;
}
.solucao-cta-prompt p {
  font-family: "Montserrat", sans-serif;
  font-size: 1.0rem;
  font-weight: 800;
  color: var(--white-80);
  letter-spacing: 0.05em;
  text-transform: uppercase;
  max-width: 420px;
  line-height: 1.5;
}

/* Mobile — AJUSTE 2 */
@media (max-width: 900px) {
  .solucao-section { padding: 50px 20px; }
  .solucao-deco { display: none; }
  .solucao-cards { grid-template-columns: repeat(2, 1fr); gap: 10px; }
  .solucao-card { padding: 16px 10px 14px; }
  .solucao-card h4 { font-size: 0.68rem; }
  .solucao-card p { font-size: 0.74rem; }
  .solucao-step { gap: 14px; padding: 14px 16px; }
  .solucao-step-icon { width: 44px; height: 44px; min-width: 44px; }
  .solucao-step-icon i { font-size: 1.1rem; }
  .solucao-step-text { font-size: 0.9rem; }
  .solucao-highlight { padding: 24px 18px; }
  .solucao-pills { gap: 10px; }
  .solucao-pills span { font-size: 0.78rem; padding: 6px 12px; }
}

/* ═══════════════════ ORIGEM DO MÉTODO ═══════════════════ */
.origem-section {
  position: relative;
  overflow: hidden;
  padding: 70px 32px 60px;
  background: linear-gradient(180deg, var(--blue-deep) 0%, var(--blue-mid) 100%);
  border-top: 3px solid rgba(245,197,24,0.5);
  border-bottom: 3px solid rgba(245,197,24,0.5);
}
.origem-section::before {
  content: "";
  position: absolute;
  inset: 0;
  background: url('assets/img/bg-starry-night.jpg') center/cover;
  opacity: 0.12;
  z-index: 0;
}
.origem-inner {
  position: relative;
  z-index: 2;
  max-width: 680px;
  margin: 0 auto;
}
.origem-header {
  text-align: center;
  margin-bottom: 40px;
}
.origem-eyebrow {
  font-size: 0.72rem;
  letter-spacing: 3px;
  font-weight: 700;
  color: var(--yellow);
  text-transform: uppercase;
  margin-bottom: 12px;
}
.origem-titulo {
  font-family: 'Playfair Display', serif;
  font-size: clamp(1.9rem, 4vw, 2.8rem);
  font-weight: 900;
  color: var(--white);
  margin-bottom: 14px;
  line-height: 1.2;
}
.origem-subtitulo {
  font-size: 1.05rem;
  color: var(--yellow);
  font-weight: 600;
  font-style: italic;
  line-height: 1.55;
}

/* Story com imagem */
.origem-story {
  display: flex;
  flex-direction: column;
  gap: 28px;
  margin-bottom: 40px;
}
.origem-story-img {
  border-radius: 16px;
  overflow: hidden;
  max-height: 220px;
  border: 1px solid rgba(245,197,24,0.2);
}
.origem-story-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  filter: brightness(0.82) saturate(0.8);
  display: block;
}
.origem-story-text p {
  font-size: 1.0rem;
  color: var(--white-80);
  line-height: 1.8;
  margin-bottom: 14px;
}

/* DESCOBERTA */
.origem-descoberta {
  background: rgba(245,197,24,0.06);
  border: 1px solid rgba(245,197,24,0.28);
  border-radius: 16px;
  padding: 22px 20px;
  margin-bottom: 40px;
  text-align: center;
  font-size: 0.93rem;
}
.descoberta-main {
  font-size: 1.0rem;
  font-weight: 700;
  color: var(--white);
  margin-bottom: 16px;
  line-height: 1.5;
}

/* POR QUE FUNCIONA */
.origem-porque {
  margin-bottom: 40px;
}
.porque-titulo {
  font-size: 1.15rem;
  font-weight: 900;
  color: var(--yellow);
  text-transform: uppercase;
  letter-spacing: 1.5px;
  margin-bottom: 16px;
}
.origem-porque > p {
  font-size: 1.0rem;
  color: var(--white-80);
  line-height: 1.75;
  margin-bottom: 10px;
}
.porque-label {
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--white);
  margin: 18px 0 16px !important;
}
.porque-items {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 8px;
}
.porque-item {
  display: flex;
  align-items: center;
  gap: 14px;
  background: rgba(255,255,255,0.04);
  border-left: 3px solid rgba(245,197,24,0.55);
  padding: 13px 18px;
  border-radius: 0 12px 12px 0;
  font-size: 0.97rem;
  color: var(--white-80);
}
.porque-item i {
  color: var(--yellow);
  font-size: 1.1rem;
  min-width: 22px;
}

/* VIRADA FINAL */
.origem-virada {
  background: linear-gradient(135deg, rgba(245,197,24,0.08), rgba(245,197,24,0.03));
  border: 2px solid rgba(245,197,24,0.4);
  border-radius: 16px;
  padding: 22px 20px;
  margin-bottom: 40px;
  font-size: 0.93rem;
}
.origem-virada > p {
  font-size: 0.93rem;
  color: var(--white-80);
  line-height: 1.7;
  margin-bottom: 10px;
}
.virada-sub {
  font-size: 1.0rem;
  font-weight: 700;
  color: var(--yellow);
  margin-bottom: 14px !important;
}

/* CONEXÃO COM DESEJO */
.origem-desejo {
  text-align: center;
  margin-bottom: 40px;
  padding: 30px 0;
  border-top: 1px solid rgba(255,255,255,0.08);
  border-bottom: 1px solid rgba(255,255,255,0.08);
}
.origem-desejo > p {
  font-size: 1.05rem;
  color: var(--white-80);
  line-height: 1.75;
  margin-bottom: 10px;
}
.desejo-items {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-top: 18px;
  align-items: center;
}
.desejo-items span {
  font-size: 1.25rem;
  font-weight: 800;
  color: var(--white);
  font-style: italic;
}

/* TRANSIÇÃO */
.origem-transicao {
  text-align: center;
  padding-top: 10px;
}
.transicao-text {
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--yellow);
  margin-bottom: 16px;
}
.transicao-arrow {
  color: var(--yellow);
  font-size: 1.5rem;
  animation: bounce 1.5s infinite;
}
