/*
Theme Name:  Neurolove da Conquista
Theme URI:   https://neurolove.com.br
Author:      Neurolove
Description: Tema de página de vendas para infoprodutos de relacionamento. 15 seções editáveis, múltiplas fontes, sistema de quiz e integração Google Sheets.
Version:     1.0
License:     Proprietary
Text Domain: nlc
*/

/* ════════════════════════════════════════════════════════════
   VARIÁVEIS & RESET
════════════════════════════════════════════════════════════ */
:root {
    --wine:       #4a0e2a;
    --wine-d:     #350a1e;
    --wine-l:     #6b1a40;
    --gold:       #c9a84c;
    --gold-l:     #e8c96a;
    --gold-d:     #a88836;
    --rose:       #e8a598;
    --rose-d:     #c07060;
    --midnight:   #0d0610;
    --midnight-2: #140d18;
    --midnight-3: #1d1424;
    --midnight-4: #261b30;
    --midnight-5: #2e2038;
    --cream:      #f2e8d8;
    --cream-d:    #d8c8b4;
    --muted:      #9a8090;
    --border-d:    rgba(255,255,255,0.08);
    --border-gold: rgba(201,168,76,0.30);
    --border-wine: rgba(74,14,42,0.50);
    --sh-card:  0 8px 32px rgba(0,0,0,0.40);
    --sh-float: 0 20px 60px rgba(0,0,0,0.55);
    --sh-glow:  0 0 40px rgba(201,168,76,0.18);
    --r:    10px;
    --r-lg: 18px;
    --r-xl: 28px;
    --font-title:   'Cormorant Garamond', Georgia, serif;
    --font-body:    'Nunito', 'Helvetica Neue', sans-serif;
    --font-accent:  'Josefin Sans', sans-serif;
    --font-display: 'Cinzel', Georgia, serif;
    --ease: cubic-bezier(0.25,0.46,0.45,0.94);
}
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; }
body {
    background: var(--midnight); color: var(--cream);
    font-family: var(--font-body); line-height: 1.65;
    -webkit-font-smoothing: antialiased; overflow-x: hidden;
}
img { max-width: 100%; height: auto; display: block; }
a { color: var(--gold); text-decoration: none; }
button { cursor: pointer; font-family: inherit; border: none; background: none; }
p { margin-bottom: 0.75em; } p:last-child { margin-bottom: 0; }
::-webkit-scrollbar { width: 5px; }
::-webkit-scrollbar-track { background: var(--midnight-2); }
::-webkit-scrollbar-thumb { background: var(--wine-l); border-radius: 99px; }

/* ════ HEADER FIXO ════ */
#nlc-header {
    position: fixed; top: 0; left: 0; right: 0; z-index: 1000;
    background: rgba(13,6,16,0.92); backdrop-filter: blur(18px);
    border-bottom: 1px solid var(--border-gold);
    padding: 10px clamp(16px,4vw,32px);
    display: flex; align-items: center; justify-content: space-between; gap: 16px;
    transition: box-shadow 0.3s;
}
#nlc-header.scrolled { box-shadow: 0 4px 30px rgba(0,0,0,0.50); }
.nlc-header-logo { font-family: var(--font-display); font-size: clamp(0.9rem,2.5vw,1.15rem); font-weight: 700; color: var(--gold); letter-spacing: 0.05em; white-space: nowrap; }
.nlc-header-cd { display: flex; align-items: center; gap: 8px; font-family: var(--font-accent); font-size: 0.73rem; color: rgba(242,232,216,0.65); letter-spacing: 0.04em; }
.nlc-header-cd span { background: var(--wine); border-radius: 4px; padding: 3px 8px; font-weight: 700; font-size: 0.85rem; color: var(--cream); letter-spacing: 0.06em; min-width: 32px; text-align: center; border: 1px solid var(--border-wine); }
.nlc-header-cta { background: linear-gradient(135deg, var(--gold), var(--gold-d)); color: var(--midnight); font-family: var(--font-accent); font-size: 0.73rem; font-weight: 700; letter-spacing: 0.07em; text-transform: uppercase; padding: 8px 20px; border-radius: 6px; white-space: nowrap; transition: transform 0.2s, box-shadow 0.2s; box-shadow: 0 4px 14px rgba(201,168,76,0.35); }
.nlc-header-cta:hover { transform: translateY(-1px); box-shadow: 0 6px 20px rgba(201,168,76,0.50); }

/* ════ PROGRESS BAR ════ */
#nlc-progress-bar { position: fixed; top: 0; left: 0; height: 2px; z-index: 1001; width: 0%; background: linear-gradient(90deg, var(--wine), var(--gold)); transition: width 0.1s linear; }

/* ════ SEÇÕES BASE ════ */
.nlc-section { position: relative; overflow: hidden; padding: clamp(64px,9vw,120px) clamp(18px,5vw,40px); }
.nlc-inner { position: relative; z-index: 2; max-width: 980px; margin: 0 auto; }
.nlc-inner-wide { max-width: 1100px; }
.nlc-inner-narrow { max-width: 680px; margin: 0 auto; }
.nlc-bg-img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: center; z-index: 0; pointer-events: none; }
.nlc-bg-overlay { position: absolute; inset: 0; z-index: 1; pointer-events: none; }
.nlc-section::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px; background: linear-gradient(90deg, transparent, var(--border-gold), transparent); z-index: 3; }

/* ════ TIPOGRAFIA ════ */
.nlc-eyebrow { display: inline-block; font-family: var(--font-accent); font-size: clamp(0.66rem,1.4vw,0.78rem); font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; color: var(--gold); background: rgba(201,168,76,0.12); border: 1px solid var(--border-gold); border-radius: 99px; padding: 5px 18px; margin-bottom: 20px; }
.nlc-title { font-family: var(--font-title); font-size: clamp(2.2rem, 5.5vw, 4rem); font-weight: 700; line-height: 1.15; color: var(--cream); margin-bottom: 16px; }
.nlc-title .gold { color: var(--gold); font-style: italic; }
.nlc-title .rose { color: var(--rose); }
.nlc-subtitle { font-family: var(--font-body); font-size: clamp(1rem, 2.2vw, 1.2rem); color: rgba(242,232,216,0.72); line-height: 1.7; margin-bottom: 32px; max-width: 640px; }
.nlc-divider { width: 64px; height: 3px; background: linear-gradient(90deg, var(--gold), var(--rose)); border-radius: 99px; margin: 20px 0 28px; }
.nlc-divider-center { margin-left: auto; margin-right: auto; }
.nlc-center { text-align: center; }
.nlc-center .nlc-subtitle, .nlc-center .nlc-divider { margin-left: auto; margin-right: auto; }

/* ════ BOTÕES ════ */
.nlc-btn { display: inline-flex; align-items: center; justify-content: center; gap: 10px; font-family: var(--font-accent); font-weight: 700; font-size: clamp(0.85rem, 2vw, 1rem); letter-spacing: 0.06em; text-transform: uppercase; padding: 18px 42px; border-radius: var(--r); transition: transform 0.25s var(--ease), box-shadow 0.25s var(--ease); cursor: pointer; border: none; text-decoration: none; position: relative; overflow: hidden; white-space: nowrap; }
.nlc-btn:hover { transform: translateY(-3px); }
.nlc-btn-gold { background: linear-gradient(135deg, var(--gold-l) 0%, var(--gold) 50%, var(--gold-d) 100%); color: var(--midnight); box-shadow: 0 6px 28px rgba(201,168,76,0.45); }
.nlc-btn-gold:hover { box-shadow: 0 10px 40px rgba(201,168,76,0.65); }
.nlc-btn-wine { background: linear-gradient(135deg, var(--wine-l), var(--wine), var(--wine-d)); color: var(--cream); box-shadow: 0 6px 28px rgba(74,14,42,0.55); border: 1px solid rgba(232,165,152,0.25); }
.nlc-btn-ghost { background: transparent; color: var(--gold); border: 1.5px solid var(--border-gold); padding: 14px 32px; }
.nlc-btn-ghost:hover { background: rgba(201,168,76,0.08); }
.nlc-btn-full { width: 100%; }
.nlc-btn-xl { padding: 22px 56px; font-size: clamp(0.95rem,2.2vw,1.15rem); border-radius: 12px; }
.nlc-btn-pulse { animation: pulse-cta 2.4s infinite; }
@keyframes pulse-cta { 0%,100%{box-shadow:0 6px 28px rgba(201,168,76,0.45)} 50%{box-shadow:0 10px 55px rgba(201,168,76,0.80)} }
.nlc-btn-note { font-size: 0.73rem; color: rgba(242,232,216,0.38); font-family: var(--font-body); letter-spacing: 0.03em; display: flex; align-items: center; justify-content: center; gap: 6px; margin-top: 10px; }
.nlc-btn-note::before { content: '🔒'; font-size: 0.8rem; }

/* ════ REVEAL ════ */
.reveal { opacity: 0; transform: translateY(40px); transition: opacity 0.75s var(--ease), transform 0.75s var(--ease); }
.reveal.visible { opacity: 1; transform: none; }
.reveal-left { opacity: 0; transform: translateX(-40px); transition: opacity 0.75s var(--ease), transform 0.75s var(--ease); }
.reveal-right { opacity: 0; transform: translateX(40px); transition: opacity 0.75s var(--ease), transform 0.75s var(--ease); }
.reveal-left.visible, .reveal-right.visible { opacity: 1; transform: none; }
.reveal-d1{transition-delay:0.1s} .reveal-d2{transition-delay:0.2s} .reveal-d3{transition-delay:0.3s} .reveal-d4{transition-delay:0.4s} .reveal-d5{transition-delay:0.5s}

/* ════ 1. HERO ════ */
#nlc-hero { background: var(--midnight); padding-top: clamp(100px,14vw,140px); padding-bottom: clamp(60px,8vw,100px); text-align: center; }
.hero-badge { display: inline-flex; align-items: center; gap: 8px; font-family: var(--font-accent); font-size: 0.72rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--rose); background: rgba(232,165,152,0.10); border: 1px solid rgba(232,165,152,0.25); border-radius: 99px; padding: 5px 18px; margin-bottom: 22px; }
.hero-headline { font-family: var(--font-title); font-size: clamp(2.6rem, 7vw, 5.5rem); font-weight: 800; line-height: 1.05; color: var(--cream); margin-bottom: 20px; }
.hero-headline .accent { color: var(--gold); font-style: italic; text-shadow: 0 0 60px rgba(201,168,76,0.35); }
.hero-sub { font-family: var(--font-body); font-size: clamp(1.05rem,2.5vw,1.35rem); color: rgba(242,232,216,0.68); line-height: 1.72; max-width: 620px; margin: 0 auto 38px; }
.hero-vsl-wrap { max-width: 720px; margin: 0 auto 44px; border-radius: var(--r-lg); overflow: hidden; box-shadow: var(--sh-float), 0 0 0 1px var(--border-gold); background: var(--midnight-3); }
.hero-vsl-inner { position: relative; padding-bottom: 56.25%; background: var(--midnight-2); }
.hero-vsl-inner iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: none; }
.hero-vsl-placeholder { position: absolute; inset: 0; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 16px; background: radial-gradient(ellipse at center, var(--midnight-3), var(--midnight)); }
.hero-vsl-play { width: 72px; height: 72px; border-radius: 50%; background: rgba(201,168,76,0.15); border: 2px solid var(--gold); display: flex; align-items: center; justify-content: center; font-size: 1.6rem; color: var(--gold); transition: all 0.3s; cursor: pointer; }
.hero-vsl-play:hover { background: var(--gold); color: var(--midnight); transform: scale(1.08); }
.hero-vsl-label { font-family: var(--font-accent); font-size: 0.75rem; color: var(--muted); letter-spacing: 0.08em; text-transform: uppercase; }
.hero-cta-group { display: flex; flex-direction: column; align-items: center; gap: 12px; margin-bottom: 50px; }
.hero-stats-bar { display: flex; justify-content: center; flex-wrap: wrap; border: 1px solid var(--border-d); border-radius: var(--r); overflow: hidden; max-width: 640px; margin: 0 auto; background: rgba(255,255,255,0.025); }
.hero-stat { padding: 20px 36px; border-right: 1px solid var(--border-d); text-align: center; flex: 1; min-width: 140px; }
.hero-stat:last-child { border-right: none; }
.hero-stat-num { font-family: var(--font-display); font-size: 2rem; font-weight: 700; color: var(--gold); line-height: 1; margin-bottom: 4px; }
.hero-stat-label { font-family: var(--font-accent); font-size: 0.68rem; letter-spacing: 0.08em; text-transform: uppercase; color: var(--muted); }

/* ════ 2. DOR ════ */
#nlc-dor { background: var(--midnight-2); }
.dor-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 16px; margin-top: 40px; }
.dor-card { background: var(--midnight-3); border: 1px solid var(--border-d); border-radius: var(--r); padding: 24px 28px; display: flex; align-items: flex-start; gap: 16px; transition: border-color 0.3s, transform 0.3s; position: relative; overflow: hidden; }
.dor-card::before { content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 3px; background: linear-gradient(180deg, var(--wine-l), var(--rose)); transform: scaleY(0); transform-origin: bottom; transition: transform 0.3s; }
.dor-card:hover { border-color: rgba(232,165,152,0.30); transform: translateX(5px); }
.dor-card:hover::before { transform: scaleY(1); }
.dor-card-icon { font-size: 1.5rem; flex-shrink: 0; margin-top: 2px; }
.dor-card-text { font-family: var(--font-body); font-size: clamp(0.9rem,1.8vw,1rem); color: rgba(242,232,216,0.80); line-height: 1.6; }
.dor-card-text strong { color: var(--cream); font-weight: 600; }
.dor-empatia { margin-top: 40px; background: rgba(74,14,42,0.25); border: 1px solid rgba(232,165,152,0.25); border-radius: var(--r-lg); padding: clamp(28px,4vw,48px); text-align: center; }
.dor-empatia p { font-family: var(--font-title); font-size: clamp(1.2rem,3vw,1.7rem); color: var(--cream); line-height: 1.55; font-style: italic; }
.dor-empatia strong { color: var(--gold); font-style: normal; }

/* ════ 3. AGITAÇÃO ════ */
#nlc-agitacao { background: linear-gradient(180deg, var(--midnight-3) 0%, var(--wine-d) 50%, var(--midnight-3) 100%); }
.agit-list { display: flex; flex-direction: column; gap: 10px; margin-bottom: 40px; }
.agit-item { display: flex; align-items: flex-start; gap: 16px; background: rgba(13,6,16,0.55); border: 1px solid rgba(232,165,152,0.15); border-radius: var(--r); padding: 18px 24px; transition: background 0.3s, border-color 0.3s; }
.agit-item:hover { background: rgba(74,14,42,0.30); border-color: rgba(232,165,152,0.30); }
.agit-bullet { width: 24px; height: 24px; border-radius: 50%; flex-shrink: 0; background: linear-gradient(135deg, var(--wine-l), var(--rose-d)); display: flex; align-items: center; justify-content: center; font-size: 0.75rem; color: white; font-weight: 700; margin-top: 1px; }
.agit-text { font-family: var(--font-body); font-size: clamp(0.9rem,2vw,1rem); color: rgba(242,232,216,0.78); line-height: 1.6; }
.agit-text strong { color: var(--rose); }
.agit-impacto { background: rgba(74,14,42,0.40); border: 2px solid rgba(232,165,152,0.35); border-radius: var(--r-lg); padding: clamp(28px,4vw,48px); text-align: center; }
.agit-impacto p { font-family: var(--font-title); font-size: clamp(1.3rem,3vw,1.9rem); color: var(--rose); line-height: 1.5; font-weight: 700; }
.agit-impacto span { color: var(--cream); font-style: italic; }

/* ════ 4. PROMESSA ════ */
#nlc-promessa { background: var(--midnight); }
.promessa-wrap { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(32px,5vw,72px); align-items: center; }
.promessa-img-wrap { border-radius: var(--r-lg); overflow: hidden; box-shadow: var(--sh-float), 0 0 0 1px var(--border-gold); background: var(--midnight-3); aspect-ratio: 3/4; }
.promessa-img-wrap img { width: 100%; height: 100%; object-fit: cover; }
.promessa-img-placeholder { width: 100%; height: 100%; min-height: 360px; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 12px; color: var(--muted); font-size: 0.8rem; font-family: var(--font-accent); letter-spacing: 0.06em; text-transform: uppercase; }
.promessa-check-list { margin: 24px 0; display: flex; flex-direction: column; gap: 14px; }
.promessa-check { display: flex; align-items: center; gap: 14px; font-family: var(--font-body); font-size: clamp(0.92rem,1.8vw,1.02rem); color: rgba(242,232,216,0.82); line-height: 1.55; }
.promessa-check::before { content: '✓'; flex-shrink: 0; width: 26px; height: 26px; border-radius: 50%; background: linear-gradient(135deg, var(--gold), var(--gold-d)); color: var(--midnight); font-weight: 900; font-size: 0.8rem; display: flex; align-items: center; justify-content: center; box-shadow: 0 4px 12px rgba(201,168,76,0.30); }

/* ════ 5. PRODUTO ════ */
#nlc-produto { background: var(--midnight-2); }
.produto-showcase { background: linear-gradient(135deg, var(--midnight-3), rgba(74,14,42,0.30)); border: 1px solid var(--border-gold); border-radius: var(--r-xl); padding: clamp(32px,5vw,64px); display: grid; grid-template-columns: auto 1fr; gap: clamp(28px,4vw,56px); align-items: center; }
.produto-mockup { width: clamp(160px,20vw,260px); border-radius: var(--r-lg); overflow: hidden; box-shadow: var(--sh-float), 0 0 50px rgba(201,168,76,0.20); flex-shrink: 0; }
.produto-mockup img { width: 100%; display: block; }
.produto-mockup-ph { aspect-ratio: 3/4; background: var(--midnight-4); display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 10px; color: var(--muted); font-size: 0.76rem; font-family: var(--font-accent); letter-spacing: 0.06em; text-transform: uppercase; padding: 20px; }
.produto-badge { display: inline-flex; align-items: center; gap: 8px; font-family: var(--font-accent); font-size: 0.72rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--rose); background: rgba(232,165,152,0.12); border: 1px solid rgba(232,165,152,0.28); border-radius: 99px; padding: 5px 16px; margin-bottom: 14px; }
.produto-name { font-family: var(--font-display); font-size: clamp(1.8rem,4vw,3rem); font-weight: 700; color: var(--gold); line-height: 1.1; margin-bottom: 12px; text-shadow: 0 0 40px rgba(201,168,76,0.25); }
.produto-desc { font-family: var(--font-body); font-size: clamp(0.92rem,2vw,1.05rem); color: rgba(242,232,216,0.72); line-height: 1.7; margin-bottom: 24px; }
.produto-seals { display: flex; flex-wrap: wrap; gap: 10px; }
.produto-seal { display: flex; align-items: center; gap: 7px; font-family: var(--font-accent); font-size: 0.7rem; letter-spacing: 0.06em; text-transform: uppercase; color: var(--muted); background: rgba(255,255,255,0.04); border: 1px solid var(--border-d); border-radius: 99px; padding: 5px 12px; }

/* ════ 6. MÓDULOS ════ */
#nlc-modulos { background: var(--midnight-3); }
.modulos-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 18px; margin-top: 44px; }
.modulo-card { background: var(--midnight-4); border: 1px solid var(--border-d); border-radius: var(--r-lg); padding: 28px 26px; transition: border-color 0.3s, transform 0.3s, box-shadow 0.3s; position: relative; overflow: hidden; }
.modulo-card::after { content: ''; position: absolute; inset: 0; background: radial-gradient(ellipse at top left, rgba(201,168,76,0.07), transparent 70%); opacity: 0; transition: opacity 0.3s; }
.modulo-card:hover { border-color: var(--border-gold); transform: translateY(-5px); box-shadow: var(--sh-card); }
.modulo-card:hover::after { opacity: 1; }
.modulo-num { font-family: var(--font-display); font-size: 0.7rem; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: var(--gold); margin-bottom: 10px; opacity: 0.8; }
.modulo-icon { font-size: 2rem; margin-bottom: 12px; }
.modulo-title { font-family: var(--font-title); font-size: clamp(1.05rem,2.2vw,1.25rem); font-weight: 700; color: var(--cream); margin-bottom: 8px; line-height: 1.3; }
.modulo-desc { font-family: var(--font-body); font-size: 0.88rem; color: rgba(242,232,216,0.60); line-height: 1.6; }

/* ════ 7. DEPOIMENTOS ════ */
#nlc-depoimentos { background: var(--midnight-2); }
.depo-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 18px; margin-top: 44px; }
.depo-card { background: var(--midnight-4); border: 1px solid var(--border-d); border-radius: var(--r-lg); padding: 28px 26px; position: relative; transition: border-color 0.3s, box-shadow 0.3s; }
.depo-card:hover { border-color: var(--border-gold); box-shadow: var(--sh-card); }
.depo-quote { font-size: 3rem; color: var(--gold); opacity: 0.2; font-family: Georgia,serif; line-height: 1; position: absolute; top: 20px; right: 24px; }
.depo-stars { display: flex; gap: 3px; margin-bottom: 14px; font-size: 0.85rem; color: var(--gold); }
.depo-text { font-family: var(--font-body); font-size: clamp(0.88rem,1.8vw,0.98rem); color: rgba(242,232,216,0.78); line-height: 1.68; margin-bottom: 20px; font-style: italic; }
.depo-author { display: flex; align-items: center; gap: 12px; }
.depo-photo { width: 46px; height: 46px; border-radius: 50%; object-fit: cover; border: 2px solid var(--border-gold); flex-shrink: 0; }
.depo-photo-ph { width: 46px; height: 46px; border-radius: 50%; background: var(--midnight-5); border: 2px solid var(--border-gold); display: flex; align-items: center; justify-content: center; font-size: 1.2rem; flex-shrink: 0; }
.depo-name { font-family: var(--font-accent); font-size: 0.88rem; font-weight: 700; color: var(--cream); }
.depo-loc { font-size: 0.73rem; color: var(--muted); margin-top: 2px; }

/* ════ 8. ESPECIALISTA ════ */
#nlc-especialista { background: var(--midnight); }
.especialista-wrap { display: grid; grid-template-columns: auto 1fr; gap: clamp(32px,5vw,72px); align-items: center; }
.esp-photo-col { display: flex; flex-direction: column; align-items: center; gap: 16px; }
.esp-frame { width: clamp(200px,24vw,300px); position: relative; }
.esp-frame::before { content: ''; position: absolute; inset: -8px; border-radius: 50%; background: conic-gradient(var(--gold), var(--wine-l), var(--rose-d), var(--gold)); z-index: 0; animation: spin-slow 8s linear infinite; }
.esp-frame::after { content: ''; position: absolute; inset: -4px; border-radius: 50%; background: var(--midnight); z-index: 1; }
@keyframes spin-slow { to { transform: rotate(360deg); } }
.esp-frame img, .esp-frame .esp-ph { width: 100%; aspect-ratio: 1/1; border-radius: 50%; object-fit: cover; position: relative; z-index: 2; }
.esp-ph { background: var(--midnight-4); display: flex; align-items: center; justify-content: center; font-size: 4rem; color: var(--muted); }
.esp-credencial { font-family: var(--font-accent); font-size: 0.7rem; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: var(--gold); background: rgba(201,168,76,0.12); border: 1px solid var(--border-gold); border-radius: 99px; padding: 5px 16px; }
.esp-name { font-family: var(--font-display); font-size: clamp(1.8rem,4vw,2.8rem); font-weight: 700; color: var(--cream); margin-bottom: 6px; }
.esp-role { font-family: var(--font-accent); font-size: clamp(0.85rem,1.8vw,1rem); color: var(--gold); letter-spacing: 0.06em; margin-bottom: 20px; }
.esp-bio { font-family: var(--font-body); font-size: clamp(0.9rem,2vw,1.02rem); color: rgba(242,232,216,0.72); line-height: 1.75; margin-bottom: 20px; }
.esp-achievements { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 20px; }
.esp-item { display: flex; align-items: center; gap: 8px; font-family: var(--font-accent); font-size: 0.75rem; letter-spacing: 0.05em; color: var(--muted); background: var(--midnight-3); border: 1px solid var(--border-d); border-radius: var(--r); padding: 8px 14px; }

/* ════ 9. BÔNUS ════ */
#nlc-bonus { background: var(--midnight-3); }
.bonus-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 18px; margin-top: 44px; }
.bonus-card { background: var(--midnight-4); border: 1px solid var(--border-d); border-radius: var(--r-lg); padding: 28px 24px; position: relative; overflow: hidden; transition: border-color 0.3s, transform 0.3s; }
.bonus-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px; background: linear-gradient(90deg, var(--gold), var(--rose), var(--gold)); transform: scaleX(0); transform-origin: left; transition: transform 0.4s; }
.bonus-card:hover { border-color: var(--border-gold); transform: translateY(-4px); }
.bonus-card:hover::before { transform: scaleX(1); }
.bonus-img-wrap { width: 100%; aspect-ratio: 4/3; border-radius: var(--r); overflow: hidden; background: var(--midnight-5); margin-bottom: 18px; position: relative; }
.bonus-img-wrap img { width: 100%; height: 100%; object-fit: cover; }
.bonus-img-ph { width: 100%; height: 100%; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 8px; color: var(--muted); font-size: 0.72rem; font-family: var(--font-accent); letter-spacing: 0.08em; text-transform: uppercase; padding: 20px; }
.bonus-val-badge { position: absolute; top: 10px; right: 10px; background: var(--wine); color: var(--cream); font-family: var(--font-accent); font-size: 0.65rem; font-weight: 700; letter-spacing: 0.06em; padding: 4px 10px; border-radius: 99px; border: 1px solid rgba(232,165,152,0.25); }
.bonus-title { font-family: var(--font-title); font-size: clamp(1rem,2.2vw,1.18rem); font-weight: 700; color: var(--cream); margin-bottom: 8px; line-height: 1.3; }
.bonus-desc { font-family: var(--font-body); font-size: 0.85rem; color: rgba(242,232,216,0.58); line-height: 1.6; }
.bonus-value { margin-top: 14px; font-family: var(--font-accent); font-size: 0.72rem; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase; color: var(--gold); display: flex; align-items: center; gap: 6px; }
.bonus-value::before { content: '🎁'; }

/* ════ 10. QUALIFICAÇÃO ════ */
#nlc-qualificacao { background: var(--midnight-2); }
.qual-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; margin-top: 44px; }
.qual-col { border-radius: var(--r-lg); padding: clamp(24px,3vw,40px); }
.qual-sim { background: rgba(16,50,30,0.30); border: 1.5px solid rgba(80,180,100,0.30); }
.qual-nao { background: rgba(70,16,30,0.30); border: 1.5px solid rgba(180,60,80,0.30); }
.qual-header { font-family: var(--font-accent); font-size: 0.78rem; font-weight: 700; letter-spacing: 0.10em; text-transform: uppercase; margin-bottom: 20px; display: flex; align-items: center; gap: 10px; }
.qual-sim .qual-header { color: #6fcf97; }
.qual-nao .qual-header { color: #e87474; }
.qual-items { display: flex; flex-direction: column; gap: 10px; }
.qual-item { display: flex; align-items: flex-start; gap: 12px; font-family: var(--font-body); font-size: 0.92rem; color: rgba(242,232,216,0.75); line-height: 1.55; }
.qual-icon { flex-shrink: 0; font-size: 0.9rem; margin-top: 2px; }

/* ════ 11. FAQ ════ */
#nlc-faq { background: var(--midnight-3); }
.faq-list { display: flex; flex-direction: column; gap: 8px; margin-top: 44px; }
.faq-item { background: var(--midnight-4); border: 1px solid var(--border-d); border-radius: var(--r); overflow: hidden; transition: border-color 0.3s; }
.faq-item.open { border-color: var(--border-gold); }
.faq-q { width: 100%; display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: 20px 24px; text-align: left; font-family: var(--font-title); font-size: clamp(0.95rem,2vw,1.1rem); font-weight: 600; color: var(--cream); line-height: 1.4; cursor: pointer; background: none; border: none; transition: color 0.3s; }
.faq-q:hover { color: var(--gold); }
.faq-item.open .faq-q { color: var(--gold); }
.faq-chevron { flex-shrink: 0; width: 28px; height: 28px; border-radius: 50%; background: rgba(255,255,255,0.06); border: 1px solid var(--border-d); display: flex; align-items: center; justify-content: center; font-size: 0.75rem; color: var(--muted); transition: transform 0.35s, background 0.3s; }
.faq-item.open .faq-chevron { transform: rotate(180deg); background: var(--gold); color: var(--midnight); border-color: var(--gold); }
.faq-a { max-height: 0; overflow: hidden; transition: max-height 0.4s var(--ease); font-family: var(--font-body); font-size: clamp(0.88rem,1.8vw,0.98rem); color: rgba(242,232,216,0.68); line-height: 1.72; }
.faq-a-inner { padding: 0 24px 22px; }
.faq-item.open .faq-a { max-height: 500px; }

/* ════ 12. OFERTA ════ */
#nlc-oferta { background: radial-gradient(ellipse at 50% 0%, rgba(74,14,42,0.60), var(--midnight) 65%); }
.oferta-box { background: linear-gradient(135deg, var(--midnight-3), rgba(74,14,42,0.25)); border: 1.5px solid var(--border-gold); border-radius: var(--r-xl); padding: clamp(36px,5vw,64px); text-align: center; box-shadow: var(--sh-glow); max-width: 680px; margin: 0 auto; position: relative; overflow: hidden; }
.oferta-box::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px; background: linear-gradient(90deg, var(--wine-l), var(--gold), var(--rose-d), var(--gold), var(--wine-l)); }
.oferta-urg { background: rgba(232,165,152,0.12); border: 1px solid rgba(232,165,152,0.30); border-radius: 99px; display: inline-block; padding: 6px 20px; margin-bottom: 24px; font-family: var(--font-accent); font-size: 0.75rem; font-weight: 700; letter-spacing: 0.10em; text-transform: uppercase; color: var(--rose); }
.oferta-de { font-family: var(--font-body); font-size: 0.92rem; color: var(--muted); text-decoration: line-through; margin-bottom: 4px; }
.oferta-por { font-family: var(--font-display); font-size: clamp(3rem,8vw,5.5rem); font-weight: 700; color: var(--gold); line-height: 1; text-shadow: 0 0 60px rgba(201,168,76,0.35); margin-bottom: 8px; }
.oferta-parcelas { font-family: var(--font-body); font-size: clamp(0.9rem,2vw,1.05rem); color: rgba(242,232,216,0.55); margin-bottom: 32px; }
.oferta-parcelas strong { color: var(--cream); }
.oferta-seals { display: flex; justify-content: center; flex-wrap: wrap; gap: 12px; margin: 28px 0; }
.oferta-seal { display: flex; align-items: center; gap: 8px; font-family: var(--font-accent); font-size: 0.7rem; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase; color: var(--muted); background: rgba(255,255,255,0.04); border: 1px solid var(--border-d); border-radius: var(--r); padding: 8px 16px; }
.oferta-cd { display: flex; justify-content: center; align-items: center; gap: 12px; margin: 24px 0; font-family: var(--font-accent); }
.oferta-cd-block { display: flex; flex-direction: column; align-items: center; gap: 4px; }
.oferta-cd-num { font-family: var(--font-display); font-size: clamp(1.8rem,4vw,2.8rem); font-weight: 700; color: var(--cream); background: rgba(255,255,255,0.06); border: 1px solid var(--border-d); border-radius: var(--r); padding: 8px 18px; min-width: 68px; text-align: center; line-height: 1; }
.oferta-cd-label { font-size: 0.62rem; color: var(--muted); letter-spacing: 0.08em; text-transform: uppercase; }
.oferta-cd-sep { font-family: var(--font-display); font-size: 2rem; color: var(--gold); opacity: 0.5; margin-bottom: 18px; }

/* ════ 13. GARANTIA ════ */
#nlc-garantia { background: var(--midnight-2); }
.garantia-wrap { display: flex; align-items: center; justify-content: center; gap: clamp(28px,5vw,64px); flex-wrap: wrap; }
.garantia-seal { flex-shrink: 0; width: clamp(140px,18vw,200px); height: clamp(140px,18vw,200px); border-radius: 50%; border: 3px solid var(--gold); background: radial-gradient(ellipse at center, rgba(74,14,42,0.30), var(--midnight-3)); display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 4px; text-align: center; padding: 20px; animation: seal-glow 3s ease-in-out infinite; }
@keyframes seal-glow { 0%,100%{box-shadow:0 0 0 8px rgba(201,168,76,0.08), 0 0 50px rgba(201,168,76,0.15)} 50%{box-shadow:0 0 0 12px rgba(201,168,76,0.12), 0 0 70px rgba(201,168,76,0.28)} }
.garantia-days { font-family: var(--font-display); font-size: clamp(2rem,5vw,3rem); font-weight: 700; color: var(--gold); line-height: 1; }
.garantia-lbl { font-family: var(--font-accent); font-size: 0.65rem; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--cream); }
.garantia-sub { font-family: var(--font-body); font-size: 0.7rem; color: var(--muted); }
.garantia-text { max-width: 520px; }
.garantia-text .nlc-title { font-size: clamp(1.5rem,3.5vw,2.3rem); }
.garantia-text p { font-family: var(--font-body); font-size: clamp(0.9rem,1.9vw,1.02rem); color: rgba(242,232,216,0.70); line-height: 1.72; }

/* ════ 14. CTA FINAL ════ */
#nlc-cta-final { background: radial-gradient(ellipse at 50% 50%, rgba(74,14,42,0.80), var(--midnight) 70%); text-align: center; }
.cta-final-hl { font-family: var(--font-title); font-size: clamp(2rem,5.5vw,4rem); font-weight: 800; color: var(--cream); line-height: 1.15; margin-bottom: 18px; }
.cta-final-hl .accent { color: var(--gold); font-style: italic; }

/* ════ 15. RODAPÉ ════ */
#nlc-footer { background: var(--midnight); border-top: 1px solid var(--border-d); padding: 40px clamp(18px,5vw,40px); text-align: center; position: relative; z-index: 2; }
.footer-logo { font-family: var(--font-display); font-size: 1.2rem; color: var(--gold); letter-spacing: 0.06em; margin-bottom: 12px; }
.footer-links { display: flex; justify-content: center; flex-wrap: wrap; gap: 20px; margin: 14px 0; }
.footer-links a { font-family: var(--font-accent); font-size: 0.75rem; letter-spacing: 0.07em; color: var(--muted); text-transform: uppercase; transition: color 0.2s; }
.footer-links a:hover { color: var(--gold); }
.footer-copy { font-family: var(--font-body); font-size: 0.75rem; color: var(--muted); margin-top: 10px; }
.footer-disclaimer { font-size: 0.7rem; color: rgba(154,128,144,0.55); margin-top: 10px; max-width: 700px; margin-left: auto; margin-right: auto; line-height: 1.7; }

/* ════ MODAIS ════ */
.nlc-modal-overlay { display: none; position: fixed; inset: 0; z-index: 9000; background: rgba(13,6,16,0.88); backdrop-filter: blur(12px); align-items: center; justify-content: center; padding: 24px; }
.nlc-modal-overlay.active { display: flex; animation: fadeIn 0.25s var(--ease); }
@keyframes fadeIn { from { opacity: 0; } }
.nlc-modal { background: var(--midnight-3); border: 1px solid var(--border-gold); border-radius: var(--r-xl); max-width: 640px; width: 100%; max-height: 85vh; display: flex; flex-direction: column; animation: slideUp 0.3s var(--ease); overflow: hidden; }
@keyframes slideUp { from { transform: translateY(30px); opacity: 0; } }
.nlc-modal-header { padding: 20px 28px; display: flex; align-items: center; justify-content: space-between; border-bottom: 1px solid var(--border-d); flex-shrink: 0; }
.nlc-modal-title { font-family: var(--font-title); font-size: 1.3rem; font-weight: 700; color: var(--cream); }
.nlc-modal-close { width: 34px; height: 34px; border-radius: 50%; background: rgba(255,255,255,0.06); border: 1px solid var(--border-d); color: var(--muted); font-size: 1rem; display: flex; align-items: center; justify-content: center; cursor: pointer; transition: all 0.2s; }
.nlc-modal-close:hover { background: var(--wine-l); color: white; border-color: var(--wine-l); }
.nlc-modal-body { overflow-y: auto; padding: 24px 28px; flex: 1; font-family: var(--font-body); font-size: 0.9rem; color: rgba(242,232,216,0.70); line-height: 1.75; }
.nlc-modal-body h2 { font-family: var(--font-title); font-size: 1.05rem; color: var(--cream); margin: 18px 0 8px; }
.nlc-modal-body strong { color: var(--cream); }
.nlc-modal-footer { padding: 16px 28px; border-top: 1px solid var(--border-d); flex-shrink: 0; display: flex; justify-content: flex-end; }
.nlc-modal-btn { font-family: var(--font-accent); font-size: 0.8rem; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; background: linear-gradient(135deg, var(--gold), var(--gold-d)); color: var(--midnight); padding: 10px 28px; border-radius: var(--r); cursor: pointer; border: none; transition: transform 0.2s; }
.nlc-modal-btn:hover { transform: translateY(-1px); }

/* ════ DEFERRED ════ */
.nlc-deferred { display: none !important; }
.nlc-deferred.nlc-unlocked { display: block !important; animation: nlc-reveal 0.65s var(--ease) both; }
@keyframes nlc-reveal { from { opacity: 0; transform: translateY(24px); } to { opacity: 1; transform: none; } }

/* ════ RESPONSIVO ════ */
@media(max-width:900px){
    .promessa-wrap { grid-template-columns: 1fr; }
    .promessa-img-wrap { max-width: 380px; margin: 0 auto; order: -1; }
    .produto-showcase { grid-template-columns: 1fr; text-align: center; }
    .produto-mockup { margin: 0 auto; }
    .produto-seals { justify-content: center; }
    .especialista-wrap { grid-template-columns: 1fr; text-align: center; }
    .esp-photo-col { align-items: center; }
    .esp-frame { width: 200px; }
    .esp-achievements { justify-content: center; }
    .qual-grid { grid-template-columns: 1fr; }
}
@media(max-width:640px){
    .depo-grid, .modulos-grid, .bonus-grid { grid-template-columns: 1fr; }
    .hero-stats-bar { flex-direction: column; }
    .hero-stat { border-right: none; border-bottom: 1px solid var(--border-d); }
    .hero-stat:last-child { border-bottom: none; }
    .oferta-cd { gap: 8px; }
    .oferta-cd-num { min-width: 54px; font-size: 1.8rem; padding: 6px 12px; }
    .garantia-wrap { flex-direction: column; text-align: center; }
    #nlc-header { gap: 10px; }
    .nlc-header-cd { display: none; }
}
@media(max-width:420px){
    .nlc-btn-xl { padding: 16px 28px; }
    .dor-grid { grid-template-columns: 1fr; }
}
