/* ============================================================
   Company Builder · Light theme + componentes editoriais
   Override do cb.css para subpáginas no padrão da landing principal
   ============================================================ */

/* ============== TOKENS LIGHT ============== */
:root {
  --bg-0: #FFFFFF;
  --bg-1: #F5F5F7;
  --bg-2: #FFFFFF;
  --paper: #1D1D1F;
  --paper-2: #424248;
  --paper-3: #6E6E73;
  --paper-4: #A1A1A6;
  --rule: rgba(29, 29, 31, 0.10);
  --rule-2: rgba(29, 29, 31, 0.14);
  --ink: #1D1D1F;
}
html, body { background: var(--bg-1); }
body { color: var(--paper); }
.ambient, .noise { display: none; }
::selection { background: var(--paper); color: var(--bg-1); }

/* ============== NAV (light) ============== */
.nav-inner { background: rgba(245, 245, 247, 0.78); border-color: rgba(29, 29, 31, 0.10); box-shadow: 0 1px 0 rgba(255,255,255,0.6) inset, 0 6px 24px rgba(29, 29, 31, 0.08); }
.nav-brand { color: var(--paper); }
.nav-list { color: var(--paper-2); }
.nav-list a:hover { color: var(--paper); }
.nav-cta { color: #FFFFFF; background: var(--paper); }
.nav-cta:hover { background: var(--paper-2); }

/* ============== BUTTONS (light) ============== */
.btn-primary { background: var(--paper); color: #FFFFFF; }
.btn-primary:hover { background: var(--paper-2); }
.btn-secondary, .btn-glass { background: rgba(29, 29, 31, 0.04); border: 1px solid rgba(29, 29, 31, 0.10); color: var(--paper); padding: 14px 26px; }
.btn-secondary:hover, .btn-glass:hover { background: rgba(29, 29, 31, 0.08); border-color: rgba(29, 29, 31, 0.18); }
.btn-secondary::after { display: none; }

/* ============== HERO PRODUTO ============== */
.hero-product { padding: clamp(140px, 18vh, 200px) var(--pad-x) clamp(60px, 8vh, 96px); position: relative; z-index: 2; }
.hero-product .container { max-width: 1100px; }
.hero-kicker { font-size: clamp(12px, 1vw, 13px); font-weight: 600; letter-spacing: 0.20em; text-transform: uppercase; color: var(--paper-3); margin-bottom: clamp(20px, 1.8vw, 26px); display: inline-block; }
.hero-product h1 { font-weight: 600; font-size: clamp(42px, 6.4vw, 88px); line-height: 1.02; letter-spacing: -0.032em; color: var(--paper); margin-bottom: clamp(20px, 2vw, 28px); max-width: 18ch; }
.hero-product h1 em, .hero-product h1 strong { font-style: normal; font-weight: 600; background: linear-gradient(180deg, #1d1d1f 0%, #6e6e73 100%); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
.hero-product .lede { font-size: clamp(18px, 1.8vw, 24px); color: var(--paper-2); max-width: 52ch; line-height: 1.42; font-weight: 400; }
.hero-actions { display: flex; gap: 14px; flex-wrap: wrap; margin-top: clamp(32px, 4vw, 44px); }
.proof-strip { display: flex; flex-wrap: wrap; gap: clamp(32px, 4vw, 56px); margin-top: clamp(48px, 6vw, 72px); padding-top: clamp(32px, 4vw, 44px); border-top: 1px solid var(--rule); }
.proof-strip .b { display: flex; flex-direction: column; gap: 6px; }
.proof-strip .b .when { font-size: clamp(11px, 1vw, 12px); font-weight: 600; color: var(--paper-3); letter-spacing: 0.10em; text-transform: uppercase; }
.proof-strip .b .what { font-size: clamp(15px, 1.4vw, 17px); color: var(--paper); font-weight: 500; letter-spacing: -0.008em; }

/* ============== SECTION BASE EDITORIAL ============== */
section.s-prod { padding: clamp(96px, 14vh, 160px) var(--pad-x); background: var(--bg-1); position: relative; z-index: 2; }
section.s-prod .container { max-width: 1100px; margin: 0 auto; }
.section-kicker { font-size: clamp(12px, 1vw, 13px); font-weight: 600; letter-spacing: 0.20em; text-transform: uppercase; color: var(--paper-3); margin-bottom: clamp(18px, 1.6vw, 22px); display: block; }
section.s-prod h2 { font-weight: 600; font-size: clamp(32px, 4.8vw, 60px); line-height: 1.04; letter-spacing: -0.028em; color: var(--paper); margin-bottom: clamp(20px, 2vw, 28px); max-width: 22ch; }
section.s-prod h2 em { font-style: normal; font-weight: 600; background: linear-gradient(180deg, #1d1d1f 0%, #6e6e73 100%); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
section.s-prod p.lede { font-size: clamp(17px, 1.6vw, 21px); color: var(--paper-2); max-width: 60ch; line-height: 1.5; margin: 0; }

/* ============== RUNNING GRID · cards informativos ============== */
.running-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: clamp(16px, 2vw, 22px); margin-top: clamp(48px, 6vw, 64px); }
@media (max-width: 760px) { .running-grid { grid-template-columns: 1fr; } }
.run-card { padding: clamp(28px, 3vw, 36px); background: #FFFFFF; border: 1px solid var(--rule); border-radius: clamp(20px, 2.2vw, 28px); display: flex; flex-direction: column; gap: 10px; box-shadow: 0 4px 24px rgba(29, 29, 31, 0.04); transition: transform 0.4s var(--ease), box-shadow 0.4s var(--ease); }
.run-card:hover { transform: translateY(-2px); box-shadow: 0 12px 32px rgba(29, 29, 31, 0.06); }
.run-card .num { font-size: clamp(12px, 1vw, 13px); font-weight: 600; letter-spacing: 0.10em; color: var(--paper-3); font-variant-numeric: tabular-nums; }
.run-card h3 { font-weight: 600; font-size: clamp(20px, 2vw, 24px); letter-spacing: -0.016em; color: var(--paper); line-height: 1.16; }
.run-card p { font-size: clamp(15px, 1.4vw, 16.5px); color: var(--paper-2); line-height: 1.5; margin: 0; }

/* ============== FOR WHOM · yes/no editorial ============== */
.for-whom { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(36px, 4vw, 56px); margin-top: clamp(40px, 5vw, 56px); }
@media (max-width: 760px) { .for-whom { grid-template-columns: 1fr; gap: 32px; } }
.for-whom h3 { font-weight: 600; font-size: clamp(17px, 1.6vw, 20px); color: var(--paper); margin-bottom: 18px; letter-spacing: -0.012em; }
.for-whom ul { list-style: none; padding: 0; margin: 0; }
.for-whom ul li { padding: clamp(12px, 1.2vw, 14px) 0 clamp(12px, 1.2vw, 14px) 28px; position: relative; font-size: clamp(15px, 1.4vw, 16.5px); color: var(--paper-2); line-height: 1.5; border-bottom: 1px solid var(--rule); }
.for-whom ul li:last-child { border-bottom: none; }
.for-whom .yes li::before { content: '✓'; position: absolute; left: 0; top: clamp(12px, 1.2vw, 14px); color: var(--paper); font-weight: 600; }
.for-whom .no li::before { content: '×'; position: absolute; left: 2px; top: clamp(10px, 1.1vw, 12px); color: var(--paper-4); font-weight: 600; font-size: 20px; line-height: 1; }

/* ============== FAQ editorial Apple HIG ============== */
.faq-list { width: 100%; border-top: 1px solid var(--rule); margin-top: clamp(40px, 5vw, 56px); }
.faq-item { border-bottom: 1px solid var(--rule); }
.faq-item summary { list-style: none; cursor: pointer; padding: clamp(22px, 2.4vw, 28px) clamp(6px, 0.8vw, 10px); display: flex; justify-content: space-between; align-items: center; gap: 20px; font-size: clamp(17px, 1.6vw, 21px); font-weight: 600; color: var(--paper); letter-spacing: -0.014em; line-height: 1.3; transition: color 0.25s var(--ease); }
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::marker { display: none; }
.faq-item summary:hover { color: var(--paper-2); }
.faq-icon { flex: none; width: 30px; height: 30px; display: inline-flex; align-items: center; justify-content: center; border-radius: 50%; background: rgba(29, 29, 31, 0.05); color: var(--paper-2); font-size: 20px; font-weight: 300; line-height: 1; transition: transform 0.42s var(--ease), background 0.25s var(--ease), color 0.25s var(--ease); }
.faq-item summary:hover .faq-icon { background: rgba(29, 29, 31, 0.09); color: var(--paper); }
.faq-item[open] summary .faq-icon { transform: rotate(45deg); background: var(--paper); color: #FFFFFF; }
.faq-item .answer { padding: 4px clamp(6px, 0.8vw, 10px) clamp(24px, 2.6vw, 32px); font-size: clamp(15px, 1.4vw, 17px); line-height: 1.6; color: var(--paper-2); max-width: 64ch; }
.faq-item .answer p { margin: 0; }
.faq-item .answer p + p { margin-top: 12px; }

/* ============== CTA FINAL ============== */
.cta-final { padding: clamp(96px, 14vh, 160px) var(--pad-x); background: var(--bg-1); border-top: 1px solid var(--rule); text-align: center; position: relative; z-index: 2; }
.cta-final .container { max-width: 800px; margin: 0 auto; }
.cta-final h2 { font-weight: 600; font-size: clamp(34px, 5.4vw, 64px); line-height: 1.04; letter-spacing: -0.028em; color: var(--paper); margin-bottom: clamp(18px, 1.8vw, 24px); }
.cta-final h2 em { font-style: normal; font-weight: 600; background: linear-gradient(180deg, #1d1d1f 0%, #6e6e73 100%); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
.cta-final p { font-size: clamp(17px, 1.6vw, 20px); color: var(--paper-2); line-height: 1.5; margin: 0 auto clamp(32px, 4vw, 44px); max-width: 48ch; }

/* ============== FOCUS VISIBLE · acessibilidade keyboard ============== */
:focus { outline: none; }
:focus-visible { outline: 2px solid var(--blue); outline-offset: 3px; border-radius: 4px; }
.nav-brand:focus-visible { outline-offset: 4px; border-radius: 999px; }
.legal-strip-inner a:focus-visible { outline-offset: 3px; }

/* ============== NAV bare (apenas logo centralizado, padrão landing) ============== */
.nav-inner-bare { justify-content: center; padding: 12px 32px; background: rgba(20, 22, 28, 0.55); backdrop-filter: blur(28px) saturate(180%); -webkit-backdrop-filter: blur(28px) saturate(180%); border: 1px solid rgba(255, 255, 255, 0.08); box-shadow: 0 1px 0 rgba(255,255,255,0.06) inset, 0 6px 24px rgba(0,0,0,0.20); }
.nav-inner-bare .nav-brand { color: #F5F5F7; }
@media (max-width: 600px) { .nav-inner-bare { padding: 10px 24px; } }

/* ============== LEGAL STRIP · faixa hairline mínima no fim (padrão landing) ============== */
.legal-strip { padding: 28px var(--pad-x); border-top: 1px solid var(--rule); background: var(--bg-1); position: relative; z-index: 2; }
.legal-strip-inner { max-width: 1280px; margin: 0 auto; display: flex; justify-content: center; align-items: center; gap: 14px; flex-wrap: wrap; font-size: 12px; color: var(--paper-3); letter-spacing: -0.005em; font-weight: 500; }
.legal-strip-inner a { color: var(--paper-3); text-decoration: none; transition: color 0.2s var(--ease); }
.legal-strip-inner a:hover { color: var(--paper); }
.legal-strip-inner .sep { color: rgba(29, 29, 31, 0.22); }
@media (max-width: 600px) { .legal-strip { padding: 22px 18px; } .legal-strip-inner { font-size: 11px; gap: 10px; flex-direction: column; } .legal-strip-inner .sep { display: none; } }

/* ============== FOOTER light (legacy, mantido pra compat) ============== */
.footer { padding: 64px 0 40px; border-top: 1px solid var(--rule); color: var(--paper-3); background: var(--bg-1); }
.footer-cols { border-bottom: 1px solid var(--rule); }
.footer-col h4 { color: var(--paper); }
.footer-col a, .footer-col span.line { color: var(--paper-3); }
.footer-col a:hover { color: var(--paper); }
.footer-bottom { color: var(--paper-4); }

/* ============== EDITORIAL TYPOGRAPHY ============== */
.editorial-content { padding: clamp(140px, 18vh, 200px) var(--pad-x) clamp(96px, 14vh, 140px); position: relative; z-index: 2; }
.editorial-content .container { max-width: 760px; margin: 0 auto; }
.editorial-content h1 { font-weight: 600; font-size: clamp(36px, 5.4vw, 64px); line-height: 1.04; letter-spacing: -0.028em; color: var(--paper); margin-bottom: clamp(40px, 5vw, 56px); }
.editorial-content h1 em { font-style: normal; font-weight: 600; background: linear-gradient(180deg, #1d1d1f 0%, #6e6e73 100%); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
.editorial-content h2 { font-weight: 600; font-size: clamp(22px, 2.4vw, 28px); letter-spacing: -0.018em; color: var(--paper); margin-top: clamp(40px, 5vw, 56px); margin-bottom: clamp(16px, 1.6vw, 20px); line-height: 1.16; }
.editorial-content h3 { font-weight: 600; font-size: clamp(17px, 1.6vw, 19px); letter-spacing: -0.012em; color: var(--paper); margin-top: clamp(24px, 2.6vw, 32px); margin-bottom: 10px; }
.editorial-content p { font-size: clamp(16px, 1.5vw, 18px); line-height: 1.6; color: var(--paper-2); margin: 0 0 14px; max-width: 64ch; }
.editorial-content ul, .editorial-content ol { margin: 0 0 16px 22px; padding: 0; }
.editorial-content li { font-size: clamp(15px, 1.4vw, 17px); line-height: 1.6; color: var(--paper-2); margin-bottom: 8px; }
.editorial-content a { color: var(--paper); text-decoration: underline; text-underline-offset: 3px; text-decoration-thickness: 1px; text-decoration-color: var(--paper-3); transition: text-decoration-color 0.25s var(--ease); }
.editorial-content a:hover { text-decoration-color: var(--paper); }
.editorial-content strong { font-weight: 600; color: var(--paper); }
.editorial-content .meta { font-size: clamp(12px, 1vw, 13px); font-weight: 600; letter-spacing: 0.20em; text-transform: uppercase; color: var(--paper-3); margin-bottom: 14px; display: block; }

/* ============== FOOTER lockup swap ============== */
.footer-col h4.brand img { content: url('/assets/cb-lockup-dark.svg'); }

/* ============== HERO RICO · ambient + glass card central + parallax ============== */
.hero-rich { position: relative; padding: clamp(140px, 18vh, 200px) var(--pad-x) clamp(80px, 10vh, 120px); overflow: hidden; min-height: clamp(560px, 80vh, 760px); display: flex; align-items: center; }
.hero-rich .hero-bg-layer { position: absolute; inset: 0; pointer-events: none; z-index: 0; will-change: transform; }
.hero-rich .hero-bg-gradient { background: radial-gradient(60% 50% at 50% 30%, rgba(29, 29, 31, 0.05) 0%, transparent 70%), radial-gradient(40% 35% at 80% 70%, rgba(10, 132, 255, 0.04) 0%, transparent 70%); }
.hero-rich .hero-bg-grid { background-image: linear-gradient(rgba(29, 29, 31, 0.03) 1px, transparent 1px), linear-gradient(90deg, rgba(29, 29, 31, 0.03) 1px, transparent 1px); background-size: 56px 56px; mask-image: radial-gradient(60% 60% at 50% 40%, #000 0%, transparent 80%); -webkit-mask-image: radial-gradient(60% 60% at 50% 40%, #000 0%, transparent 80%); }
.hero-rich .container { max-width: 1100px; margin: 0 auto; position: relative; z-index: 2; width: 100%; }
.hero-rich .hero-kicker { display: inline-flex; align-items: center; gap: 10px; padding: 6px 14px; border-radius: 999px; background: rgba(29, 29, 31, 0.04); border: 1px solid var(--rule); font-size: clamp(11px, 1vw, 12.5px); font-weight: 600; letter-spacing: 0.16em; text-transform: uppercase; color: var(--paper-2); margin-bottom: clamp(24px, 2.4vw, 32px); }
.hero-rich .hero-kicker .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--paper); }
.hero-rich h1 { font-weight: 600; font-size: clamp(44px, 6.8vw, 96px); line-height: 1.01; letter-spacing: -0.034em; color: var(--paper); margin-bottom: clamp(22px, 2.2vw, 32px); max-width: 16ch; }
.hero-rich h1 em { font-style: normal; font-weight: 600; background: linear-gradient(180deg, #1d1d1f 0%, #6e6e73 100%); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
.hero-rich .lede { font-size: clamp(18px, 1.9vw, 26px); color: var(--paper-2); max-width: 52ch; line-height: 1.4; font-weight: 400; }
.hero-rich .hero-actions { display: flex; gap: 14px; flex-wrap: wrap; margin-top: clamp(36px, 4.4vw, 52px); }

/* Stats strip sob o hero · 4 colunas com gradient subtle */
.hero-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--rule); border: 1px solid var(--rule); border-radius: clamp(20px, 2.2vw, 28px); overflow: hidden; margin-top: clamp(64px, 8vw, 96px); box-shadow: 0 8px 40px rgba(29, 29, 31, 0.05); }
@media (max-width: 760px) { .hero-stats { grid-template-columns: repeat(2, 1fr); } }
.hero-stats .stat { background: #FFFFFF; padding: clamp(28px, 3vw, 40px) clamp(22px, 2.4vw, 32px); display: flex; flex-direction: column; gap: 8px; }
.hero-stats .stat-label { font-size: clamp(11px, 1vw, 12.5px); font-weight: 600; letter-spacing: 0.16em; text-transform: uppercase; color: var(--paper-3); }
.hero-stats .stat-value { font-size: clamp(22px, 2.6vw, 36px); font-weight: 600; color: var(--paper); letter-spacing: -0.022em; line-height: 1.05; font-variant-numeric: tabular-nums; }
.hero-stats .stat-value em { font-style: normal; font-weight: 600; background: linear-gradient(180deg, #1d1d1f 0%, #6e6e73 100%); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }

/* ============== DEPTH CARDS · run-cards com inner shadow + hover tilt suave ============== */
.depth-card { position: relative; padding: clamp(32px, 3.2vw, 44px); background: #FFFFFF; border: 1px solid var(--rule); border-radius: clamp(22px, 2.4vw, 32px); display: flex; flex-direction: column; gap: clamp(12px, 1.2vw, 16px); box-shadow: inset 0 1px 0 rgba(255, 255, 255, 1), 0 1px 2px rgba(29, 29, 31, 0.04), 0 8px 28px -8px rgba(29, 29, 31, 0.08); transform-style: preserve-3d; transition: transform 0.5s var(--ease), box-shadow 0.5s var(--ease); will-change: transform; overflow: hidden; }
.depth-card::before { content: ''; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(255,255,255,0.6) 0%, transparent 30%); pointer-events: none; border-radius: inherit; }
.depth-card:hover { box-shadow: inset 0 1px 0 rgba(255, 255, 255, 1), 0 2px 4px rgba(29, 29, 31, 0.05), 0 18px 40px -10px rgba(29, 29, 31, 0.14); }
.depth-card .icon-bubble { width: clamp(44px, 4vw, 52px); height: clamp(44px, 4vw, 52px); border-radius: 50%; background: var(--paper); display: inline-flex; align-items: center; justify-content: center; color: #FFFFFF; font-size: clamp(16px, 1.4vw, 18px); font-weight: 600; letter-spacing: 0; font-variant-numeric: tabular-nums; margin-bottom: clamp(10px, 1vw, 14px); }
.depth-card h3 { font-weight: 600; font-size: clamp(20px, 2.2vw, 26px); letter-spacing: -0.018em; color: var(--paper); line-height: 1.14; position: relative; z-index: 1; }
.depth-card p { font-size: clamp(15px, 1.4vw, 17px); color: var(--paper-2); line-height: 1.5; margin: 0; position: relative; z-index: 1; }

/* Override do .run-card pra ganhar visual igual ao depth-card mas mantendo grid existente */
.run-card { padding: clamp(32px, 3.2vw, 44px); background: #FFFFFF; border: 1px solid var(--rule); border-radius: clamp(22px, 2.4vw, 32px); display: flex; flex-direction: column; gap: clamp(12px, 1.2vw, 16px); box-shadow: inset 0 1px 0 rgba(255, 255, 255, 1), 0 1px 2px rgba(29, 29, 31, 0.04), 0 8px 28px -8px rgba(29, 29, 31, 0.08); transition: transform 0.5s var(--ease), box-shadow 0.5s var(--ease); will-change: transform; position: relative; overflow: hidden; }
.run-card::before { content: ''; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(255,255,255,0.6) 0%, transparent 30%); pointer-events: none; border-radius: inherit; }
.run-card:hover { box-shadow: inset 0 1px 0 rgba(255, 255, 255, 1), 0 2px 4px rgba(29, 29, 31, 0.05), 0 18px 40px -10px rgba(29, 29, 31, 0.14); }
.run-card .num { display: inline-flex; align-items: center; justify-content: center; width: clamp(40px, 3.6vw, 48px); height: clamp(40px, 3.6vw, 48px); border-radius: 50%; background: var(--paper); color: #FFFFFF; font-size: clamp(13px, 1.2vw, 15px); font-weight: 600; letter-spacing: 0; font-variant-numeric: tabular-nums; margin-bottom: clamp(6px, 0.8vw, 10px); position: relative; z-index: 1; }
.run-card h3, .run-card p { position: relative; z-index: 1; }

/* ============== TIMELINE estágios do programa · numeração editorial ============== */
.timeline { position: relative; margin-top: clamp(56px, 6vw, 80px); padding-left: clamp(28px, 3vw, 40px); border-left: 1.5px solid var(--rule-2); display: flex; flex-direction: column; gap: clamp(36px, 4vw, 52px); }
.timeline-step { position: relative; }
.timeline-step::before { content: ''; position: absolute; left: calc(-1 * clamp(28px, 3vw, 40px) - 8px); top: 8px; width: 14px; height: 14px; border-radius: 50%; background: var(--paper); border: 3px solid var(--bg-1); box-shadow: 0 0 0 1px var(--paper); }
.timeline-step .step-label { font-size: clamp(11px, 1vw, 12px); font-weight: 600; letter-spacing: 0.16em; text-transform: uppercase; color: var(--paper-3); margin-bottom: 8px; font-variant-numeric: tabular-nums; }
.timeline-step h3 { font-weight: 600; font-size: clamp(20px, 2.2vw, 26px); letter-spacing: -0.018em; color: var(--paper); line-height: 1.16; margin-bottom: 8px; }
.timeline-step p { font-size: clamp(15px, 1.4vw, 17px); line-height: 1.55; color: var(--paper-2); margin: 0; max-width: 60ch; }

/* ============== REVEAL refinada (sobrescreve a do cb.css) ============== */
.reveal { opacity: 0; transform: translateY(28px); transition: opacity 1s var(--eo), transform 1s var(--eo); }
.reveal.in { opacity: 1; transform: translateY(0); }
.reveal-group > * { will-change: opacity, transform; }

/* ============== CTA FINAL · com glass card central ============== */
.cta-final { padding: clamp(96px, 14vh, 160px) var(--pad-x); background: var(--bg-1); position: relative; z-index: 2; overflow: hidden; }
.cta-final::before { content: ''; position: absolute; inset: 0; background: radial-gradient(50% 60% at 50% 50%, rgba(29, 29, 31, 0.04) 0%, transparent 70%); pointer-events: none; }
.cta-final .container { max-width: 820px; margin: 0 auto; text-align: center; position: relative; z-index: 1; }

/* ============== AMBIENT decorativo light theme ============== */
.ambient-light { position: fixed; inset: 0; z-index: 0; pointer-events: none; overflow: hidden; }
.ambient-light::before, .ambient-light::after { content: ''; position: absolute; border-radius: 50%; filter: blur(160px); will-change: transform; }
.ambient-light::before { width: 60vw; height: 60vw; left: -10vw; top: -20vw; background: radial-gradient(circle, rgba(10, 132, 255, 0.05), transparent 70%); opacity: 0.7; animation: drift1 26s ease-in-out infinite alternate; }
.ambient-light::after { width: 70vw; height: 70vw; right: -20vw; bottom: -30vw; background: radial-gradient(circle, rgba(29, 29, 31, 0.04), transparent 70%); opacity: 0.6; animation: drift2 32s ease-in-out infinite alternate; }

/* ============== RESPONSIVE COMPLEMENTAR cb-light ============== */
@media (max-width: 760px) {
  .editorial-content { padding: 100px 18px 64px; }
  .editorial-content h1 { font-size: clamp(28px, 7vw, 40px); margin-bottom: 32px; }
  .editorial-content h2 { font-size: clamp(19px, 4.8vw, 24px); margin-top: 36px; }
  .editorial-content h3 { font-size: 16px; }
  .editorial-content p, .editorial-content li { font-size: 15px; }
}
@media (max-width: 480px) {
  .editorial-content { padding: 90px 16px 56px; }
  .editorial-content h1 { font-size: clamp(26px, 8vw, 32px); }
}
