/* =====================================================================
   ERIC CARMINATI — Home
   Réplica fiel da linguagem visual de arialdo.com.br
   Preto editorial · tipografia fina enorme · painéis arredondados · arejado
   ===================================================================== */

:root{
  --black:#000000;
  --bg:#0c0c0c;
  --panel:#151515;
  --panel-2:#191919;
  --light:#ecebe4;          /* seção clara final */
  --ink:#0e0e0e;            /* texto sobre claro */
  --txt:#f3f2ee;            /* texto principal sobre escuro */
  --muted:#8c8c8c;
  --muted-2:#5a5a5a;
  --ghost:#1b1b1b;          /* nome gigante fantasma */
  --line:rgba(255,255,255,.12);
  --line-soft:rgba(255,255,255,.07);
  --line-dark:rgba(0,0,0,.16);
  --accent:#cda74e;         /* acento quente — cor de comando */
  --gold:#c9a24b;
  --gold-soft:#e3c373;
  --gold-deep:#a9842f;
  --wa:#25d366;
  --maxw:1320px;
  --radius:34px;
  --pad:clamp(20px,5vw,70px);
  --display:'Plus Jakarta Sans',system-ui,sans-serif;
  --ui:'Manrope',system-ui,sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;background:var(--black)}
body{
  font-family:var(--ui);
  background:var(--bg);
  color:var(--txt);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--display);font-weight:300;line-height:1;letter-spacing:-.02em}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad)}

/* tiny uppercase label */
.label{
  display:inline-flex;align-items:center;gap:11px;
  font-family:var(--ui);font-size:.72rem;font-weight:600;
  letter-spacing:.18em;text-transform:uppercase;color:var(--muted);
}
.label .dot{width:18px;height:18px;border-radius:5px;border:1px solid var(--line);display:inline-flex;align-items:center;justify-content:center;color:var(--accent)}
.label .dot svg{width:10px;height:10px}

.accent{color:var(--accent)}
.thin{font-weight:200}

/* ---------- Buttons (outlined pill) ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:11px;
  font-family:var(--ui);font-weight:600;font-size:.78rem;
  letter-spacing:.14em;text-transform:uppercase;
  padding:16px 28px;border-radius:100px;cursor:pointer;
  border:1px solid var(--line);background:transparent;color:var(--txt);
  transition:background .3s ease,color .3s ease,border-color .3s ease,transform .25s ease;
}
.btn svg{width:17px;height:17px;flex:none}
.btn:hover{background:#fff;color:#0c0c0c;border-color:#fff;transform:translateY(-2px)}
.btn-solid{background:#fff;color:#0c0c0c;border-color:#fff}
.btn-solid:hover{background:transparent;color:var(--txt);border-color:var(--line)}
.btn-gold{background:linear-gradient(180deg,var(--gold-soft),var(--gold));color:#1c1403;border-color:transparent;font-weight:700;box-shadow:0 16px 40px -14px rgba(201,162,75,.55)}
.btn-gold:hover{background:#fff;color:#1c1403;border-color:#fff}
.btn-wa:hover{background:var(--wa);color:#04210f;border-color:var(--wa)}
/* botões em fundo claro */
.on-light .btn{border-color:var(--line-dark);color:var(--ink)}
.on-light .btn:hover{background:var(--ink);color:#fff;border-color:var(--ink)}

/* ---------- Header / nav pílula flutuante ---------- */
header{position:sticky;top:0;z-index:70;pointer-events:none}
.nav{display:flex;align-items:center;justify-content:space-between;padding:22px var(--pad);gap:20px}
.nav>*{pointer-events:auto}
.brand{display:flex;align-items:baseline;gap:9px;font-family:var(--display)}
.brand b{font-weight:600;font-size:1.05rem;letter-spacing:-.01em;color:var(--txt)}
.brand span{font-size:.62rem;letter-spacing:.24em;text-transform:uppercase;color:var(--muted);font-family:var(--ui);font-weight:600}
.nav-pill{
  display:flex;align-items:center;gap:4px;
  background:rgba(22,22,22,.7);backdrop-filter:blur(16px);
  border:1px solid var(--line-soft);border-radius:100px;padding:7px 8px;
}
.nav-pill a{
  font-family:var(--ui);font-size:.74rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;
  color:var(--muted);padding:9px 16px;border-radius:100px;transition:color .25s,background .25s;
}
.nav-pill a:hover{color:var(--txt);background:rgba(255,255,255,.06)}
.nav .btn{padding:12px 22px;font-size:.7rem}
.nav-cta-mini{display:none}
@media(max-width:860px){.nav-pill{display:none}.nav{padding:16px var(--pad)}}
@media(max-width:520px){.nav-cta-text{display:none}.nav-cta-mini{display:inline}}

/* ---------- Curtain (animação de entrada) ---------- */
.curtain{position:fixed;inset:0;z-index:200;background:var(--light);transform:translateY(0);
  animation:curtain-up 1s cubic-bezier(.76,0,.24,1) forwards;animation-delay:.25s;pointer-events:none}
@keyframes curtain-up{to{transform:translateY(-101%)}}

/* ---------- Hero (réplica arialdo: nome à esquerda, foto à direita por cima) ---------- */
.hero{position:relative;min-height:100vh;background:#080808;overflow:hidden;margin-top:-92px;padding-top:92px}
.hero-portrait{position:absolute;top:0;right:0;width:46%;height:100%;z-index:3;opacity:0;
  animation:hero-photo 1.4s cubic-bezier(.2,.7,.2,1) forwards;animation-delay:.55s}
.hero-portrait img{width:100%;height:100%;object-fit:cover;object-position:50% 16%;filter:grayscale(1) contrast(1.08)}
.hero-portrait::before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,#080808 0%,rgba(8,8,8,.55) 16%,rgba(8,8,8,0) 46%)}
.hero-portrait::after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,#080808 1%,rgba(8,8,8,0) 22%),linear-gradient(180deg,rgba(8,8,8,.55) 0%,rgba(8,8,8,0) 16%)}
@keyframes hero-photo{from{opacity:0;transform:translateX(40px)}to{opacity:1;transform:none}}
.hero-inner{position:relative;z-index:2;min-height:calc(100vh - 92px);display:flex;flex-direction:column;justify-content:center;padding:60px 0}
.hero-name{font-family:var(--ui);line-height:.92;letter-spacing:-.025em;color:#dedede;user-select:none}
.hero-name .l1,.hero-name .l2{display:block;opacity:0;animation:name-in 1s cubic-bezier(.2,.7,.2,1) forwards}
.hero-name .l1{font-weight:500;font-size:clamp(4rem,12.5vw,10.5rem);animation-delay:.85s}
.hero-name .l2{font-weight:200;font-size:clamp(3.1rem,9.6vw,8rem);margin-left:.46em;margin-top:.02em;animation-delay:1.0s}
@keyframes name-in{from{opacity:0;transform:translateY(46px)}to{opacity:1;transform:none}}
@media(max-width:860px){
  .hero{min-height:auto}
  .hero-portrait{position:relative;width:100%;height:60vh}
  .hero-portrait img{object-position:50% 10%}
  .hero-portrait::before{background:linear-gradient(0deg,#080808 3%,rgba(8,8,8,0) 60%)}
  .hero-inner{min-height:auto;padding:34px 0 54px}
  .hero-name .l2{margin-left:.3em}
}

/* ---------- Roles (seção pinned: cada palavra surge grande+transparente e se forma diminuindo) ---------- */
.roles-scroll{position:relative;background:#080808;border-top:1px solid var(--line-soft);height:175vh}
.roles-pin{position:sticky;top:0;height:100vh;display:flex;align-items:center;overflow:hidden}
.roles-pin .wrap{display:flex;flex-direction:column;gap:clamp(8px,1.6vw,24px);width:100%}
.roles-pin .rword{display:block;font-family:var(--ui);font-weight:300;
  font-size:clamp(1.9rem,5vw,4.2rem);line-height:1.2;letter-spacing:-.025em;color:#dedede;
  transform-origin:left top;will-change:transform,opacity;opacity:0}
@media(max-width:680px){.roles-scroll{height:150vh}}

/* ---------- Story (Sobre em storytelling editorial) ---------- */
.story{background:var(--bg);padding:clamp(70px,10vw,150px) 0}
.story-lead{font-family:var(--display);font-weight:300;font-size:clamp(2rem,5vw,4rem);line-height:1.06;letter-spacing:-.025em;max-width:22ch;margin:22px 0 clamp(42px,6vw,76px);color:var(--txt)}
.story-lead .accent{font-weight:400}
.story-body{display:grid;grid-template-columns:1.32fr .68fr;gap:clamp(36px,5vw,76px);align-items:start}
.story-text p{font-family:var(--display);font-weight:300;font-size:clamp(1.12rem,1.6vw,1.42rem);line-height:1.62;color:#b6b6b6;margin-bottom:24px;max-width:58ch}
.story-text p b{color:#fff;font-weight:600}
.story-text .story-quote{font-style:italic;color:var(--txt);font-size:clamp(1.4rem,2.4vw,1.9rem);margin-top:34px}
.story-side{position:sticky;top:110px}
.story-side img{width:100%;aspect-ratio:4/5;object-fit:cover;filter:grayscale(1) contrast(1.05);border-radius:14px;margin-bottom:30px}
.marcos{list-style:none;border-top:1px solid var(--line)}
.marcos li{display:flex;gap:18px;align-items:baseline;padding:15px 0;border-bottom:1px solid var(--line-soft);font-family:var(--ui);font-size:.96rem;color:var(--muted)}
.marcos li b{color:var(--accent);font-family:var(--display);font-weight:600;min-width:78px;font-size:1.04rem}
@media(max-width:820px){.story-body{grid-template-columns:1fr;gap:42px}.story-side{position:static}.story-side img{max-width:380px}}

/* ---------- Mission (frase grande fina) ---------- */
.mission{background:var(--bg);padding:clamp(80px,12vw,180px) 0}
.mission p{font-family:var(--display);font-weight:200;font-size:clamp(1.9rem,5vw,4.2rem);line-height:1.08;letter-spacing:-.02em;color:var(--txt);max-width:20ch}
.mission p .dim{color:var(--muted-2)}
.mission .em{color:var(--accent)}
.mission-cta{display:flex;gap:13px;flex-wrap:wrap;margin-top:clamp(34px,5vw,54px)}

/* ---------- Stats (números inline entre hairlines) ---------- */
.stats{background:var(--bg);padding:clamp(20px,4vw,40px) 0 clamp(60px,9vw,120px)}
.stats-row{display:flex;flex-wrap:wrap;gap:clamp(28px,5vw,70px);align-items:flex-start;padding:clamp(34px,5vw,54px) 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.stat{display:flex;align-items:baseline;gap:16px;flex:1 1 200px}
.stat b{font-family:var(--display);font-weight:700;font-size:clamp(2.6rem,6vw,4.6rem);line-height:.85;letter-spacing:-.03em;color:var(--txt)}
.stat b .accent{color:var(--accent)}
.stat small{font-family:var(--ui);font-size:.74rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);line-height:1.4;max-width:14ch}
.chips-label{font-family:var(--ui);font-size:.7rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--muted-2);margin:clamp(40px,5vw,60px) 0 18px}
.chips{display:flex;flex-wrap:wrap;gap:12px}
.chip{font-family:var(--ui);font-size:.82rem;font-weight:600;letter-spacing:.06em;color:var(--muted);border:1px solid var(--line-soft);border-radius:12px;padding:18px 28px;background:var(--panel);transition:border-color .3s,color .3s,transform .3s,background .3s;filter:grayscale(1);opacity:.78}
.chip:hover{border-color:var(--gold);color:#fff;transform:translateY(-3px);filter:grayscale(0);opacity:1;background:var(--panel-2)}

/* ---------- Painel arredondado genérico ---------- */
.panel{background:var(--panel);border-radius:var(--radius);margin:14px auto;max-width:calc(var(--maxw) + 0px);}
.panel-pad{padding:clamp(40px,6vw,96px) clamp(26px,5vw,80px)}
.section{padding:clamp(50px,7vw,90px) 0}

/* ---------- Sobre ---------- */
.about .panel-pad{display:grid;grid-template-columns:1fr;gap:0}
.about .head{display:flex;align-items:center;gap:14px;margin-bottom:clamp(40px,7vw,90px)}
.about-grid{display:grid;grid-template-columns:1.25fr .75fr;gap:clamp(36px,5vw,72px);align-items:end}
.about h2{font-size:clamp(2.2rem,5vw,4rem);font-weight:200;line-height:1.05;letter-spacing:-.02em;margin-bottom:34px;max-width:18ch}
.about h2 .accent{font-weight:300}
.about .copy p{color:#bcbcbc;font-size:1.06rem;font-weight:300;margin-bottom:18px;max-width:60ch;font-family:var(--display)}
.about .copy p b{color:#fff;font-weight:500}
.about-photo{position:relative}
.about-photo img{width:100%;aspect-ratio:3/4;object-fit:cover;filter:grayscale(1) contrast(1.04) brightness(.95);border-radius:20px}
.about-sign{margin-top:30px;font-family:var(--display);font-weight:300;font-style:italic;font-size:1.5rem;color:var(--txt)}
@media(max-width:820px){.about-grid{grid-template-columns:1fr;gap:36px;align-items:start}.about-photo{max-width:340px}}

/* ---------- Trajetória ---------- */
.path{padding:clamp(60px,9vw,130px) 0}
.path .head{margin-bottom:clamp(36px,5vw,60px)}
.path .head h2{font-size:clamp(2rem,4.6vw,3.4rem);font-weight:200;margin-top:18px;letter-spacing:-.02em}
.path-list{display:flex;flex-direction:column}
.path-item{display:grid;grid-template-columns:120px 1fr auto;gap:clamp(18px,4vw,60px);padding:clamp(22px,3vw,34px) 0;border-top:1px solid var(--line-soft);align-items:baseline}
.path-item:last-child{border-bottom:1px solid var(--line-soft)}
.path-item .yr{font-family:var(--display);font-weight:300;font-size:1.35rem;color:var(--muted)}
.path-item .desc h4{font-family:var(--display);font-weight:400;font-size:1.4rem;letter-spacing:-.01em;color:var(--txt);margin-bottom:7px}
.path-item .desc p{color:var(--muted);font-size:1rem;font-weight:300;margin:0;max-width:62ch;font-family:var(--display)}
.path-item .n{font-family:var(--ui);font-size:.72rem;font-weight:600;letter-spacing:.12em;color:var(--muted-2)}
.path-item:hover .yr,.path-item:hover .desc h4{color:#fff;transition:color .3s}
@media(max-width:680px){.path-item{grid-template-columns:74px 1fr;gap:16px}.path-item .n{display:none}.path-item .desc h4{font-size:1.15rem}}

/* ---------- Programas (painéis stack estilo Negócios) ---------- */
.offers{padding-bottom:clamp(20px,4vw,40px)}
.offers .head{padding:0 var(--pad);max-width:var(--maxw);margin:0 auto clamp(20px,3vw,30px)}
.offers .head h2{font-size:clamp(2rem,4.6vw,3.4rem);font-weight:200;margin-top:18px;letter-spacing:-.02em}
.offer{position:relative;min-height:clamp(360px,42vw,520px);display:flex;flex-direction:column;justify-content:space-between;overflow:hidden}
.offer .top{display:flex;justify-content:space-between;align-items:flex-start;gap:24px}
.offer .idx{font-family:var(--ui);font-size:.72rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--muted-2)}
.offer h3{font-size:clamp(2.4rem,6vw,5rem);font-weight:200;letter-spacing:-.03em;line-height:.92;margin-top:auto;color:var(--txt)}
.offer .row{display:flex;justify-content:space-between;align-items:flex-end;gap:30px;margin-top:30px;flex-wrap:wrap}
.offer .desc{color:var(--muted);font-size:1.04rem;font-weight:300;max-width:46ch;font-family:var(--display)}
.offer:hover h3{color:#fff;transition:color .35s}
/* marquee interno */
.mq{overflow:hidden;border-top:1px solid var(--line-soft);margin-top:34px;padding-top:26px}
.mq-track{display:flex;width:max-content;align-items:center;animation:scroll-x 28s linear infinite;will-change:transform}
.offer:hover .mq-track{animation-play-state:paused}
.mq-track span{font-family:var(--ui);font-size:.82rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);padding:0 22px}
.mq-track span.s{color:var(--accent)}
@keyframes scroll-x{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media(max-width:680px){.offer h3{font-size:clamp(2.2rem,11vw,3.2rem)}.offer .row{flex-direction:column;align-items:flex-start;gap:22px}}

/* ---------- Audience ---------- */
.audience{padding:clamp(60px,9vw,130px) 0}
.audience .head{margin-bottom:clamp(40px,5vw,64px)}
.audience .head h2{font-size:clamp(2rem,4.6vw,3.4rem);font-weight:200;margin-top:18px}
.aud-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,64px)}
.aud-col{border-top:1px solid var(--line);padding-top:30px}
.aud-col h3{font-family:var(--display);font-weight:300;font-size:1.9rem;letter-spacing:-.01em;margin-bottom:8px}
.aud-col .who{font-family:var(--ui);font-size:.74rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);margin-bottom:26px}
.aud-col ul{list-style:none;display:flex;flex-direction:column;gap:16px}
.aud-col li{display:flex;gap:14px;align-items:flex-start;color:#bcbcbc;font-size:1.04rem;font-weight:300;font-family:var(--display)}
.aud-col li svg{width:18px;height:18px;color:var(--accent);flex:none;margin-top:5px}
@media(max-width:760px){.aud-grid{grid-template-columns:1fr;gap:40px}}

/* ---------- Manifesto ---------- */
.band .panel{background:var(--panel-2)}
.band .panel-pad{padding:clamp(64px,10vw,140px) clamp(26px,5vw,90px)}
.band .quote{font-family:var(--display);font-weight:200;font-size:clamp(1.9rem,4.6vw,3.6rem);line-height:1.12;letter-spacing:-.02em;color:var(--txt);max-width:24ch}
.band .quote .accent{font-style:italic;font-weight:300}
.band .by{margin-top:32px;font-family:var(--ui);font-size:.78rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}

/* ---------- FAQ ---------- */
.faq-wrap{padding:clamp(60px,9vw,130px) 0}
.faq-wrap .head{margin-bottom:clamp(30px,4vw,50px)}
.faq-wrap .head h2{font-size:clamp(2rem,4.6vw,3.4rem);font-weight:200;margin-top:18px}
.faq-list{display:flex;flex-direction:column;border-top:1px solid var(--line)}
.faq{border-bottom:1px solid var(--line)}
.faq summary{list-style:none;cursor:pointer;padding:30px 4px;font-family:var(--display);font-weight:300;font-size:clamp(1.2rem,2.4vw,1.7rem);letter-spacing:-.01em;display:flex;justify-content:space-between;align-items:center;gap:20px;color:var(--txt)}
.faq summary::-webkit-details-marker{display:none}
.faq summary .ic{transition:transform .3s;flex:none;color:var(--accent);font-size:1.6rem;line-height:1;font-weight:200}
.faq[open] summary .ic{transform:rotate(45deg)}
.faq .ans{padding:0 4px 32px;color:var(--muted);font-size:1.06rem;font-weight:300;max-width:80ch;font-family:var(--display)}
.faq .ans b{color:#cfcfcf;font-weight:500}

/* ---------- Final CTA + Footer (seção clara) ---------- */
.close{background:var(--light);color:var(--ink);border-radius:var(--radius) var(--radius) 0 0;margin-top:14px}
.close-pad{padding:clamp(60px,9vw,130px) clamp(26px,5vw,80px) clamp(36px,5vw,60px)}
.close .kicker b{font-family:var(--display);font-weight:600;font-size:1.05rem;color:var(--ink)}
.close .kicker span{display:block;font-family:var(--ui);font-size:.9rem;color:#5a584f;margin-top:4px}
.close-grid{display:grid;grid-template-columns:1fr auto;gap:clamp(30px,5vw,60px);align-items:center;margin:clamp(40px,6vw,70px) 0}
.close h2{font-family:var(--display);font-weight:200;font-size:clamp(2.8rem,9vw,7rem);line-height:.95;letter-spacing:-.03em;color:var(--ink)}
.close h2 .accent{color:#a9842f;font-weight:300}
.close-lead{font-family:var(--ui);font-size:1.04rem;color:#4a483f;max-width:54ch;margin-top:-10px}
.close .cta-line{margin-top:26px;display:flex;gap:13px;flex-wrap:wrap}
.on-light .btn-gold{color:#1c1403;border-color:transparent}
.on-light .btn-gold:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.close-avatar{width:clamp(150px,20vw,280px);height:clamp(150px,20vw,280px);border-radius:50%;overflow:hidden;flex:none}
.close-avatar img{width:100%;height:100%;object-fit:cover;filter:grayscale(1) contrast(1.05)}
.foot-rule{border:0;border-top:1px solid var(--line-dark);margin:clamp(30px,4vw,46px) 0 26px}
.foot-bottom{display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;align-items:center;font-family:var(--ui);font-size:.84rem;color:#6a685e}
.foot-social{display:flex;gap:24px}
.foot-social a{display:inline-flex;align-items:center;gap:8px;color:var(--ink);font-weight:600;font-size:.84rem;transition:opacity .2s}
.foot-social a:hover{opacity:.55}
.foot-social svg{width:17px;height:17px}
.foot-nav{display:flex;gap:22px;flex-wrap:wrap;margin-top:14px}
.foot-nav a{font-family:var(--ui);font-size:.82rem;color:#6a685e;transition:color .2s}
.foot-nav a:hover{color:var(--ink)}
@media(max-width:680px){.close-grid{grid-template-columns:1fr}.close-avatar{display:none}}

/* ---------- Float WhatsApp ---------- */
.float-wa{position:fixed;right:20px;bottom:20px;z-index:80;width:56px;height:56px;border-radius:50%;
  background:var(--wa);display:flex;align-items:center;justify-content:center;
  box-shadow:0 18px 40px -12px rgba(37,211,102,.55);transition:transform .25s}
.float-wa:hover{transform:scale(1.07)}
.float-wa svg{width:29px;height:29px}

/* ---------- Reveal (scroll-triggered: fadeInUp / fadeInDown) ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity 1s cubic-bezier(.2,.7,.2,1),transform 1s cubic-bezier(.2,.7,.2,1)}
.reveal.down{transform:translateY(-22px)}
.reveal.in{opacity:1;transform:none}

@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .reveal{opacity:1;transform:none}
  .mq-track,.rm-track{animation:none!important}
  .curtain{display:none!important}
  .hero-portrait,.hero-name .l1,.hero-name .l2{opacity:1!important;animation:none!important;transform:none!important}
  html{scroll-behavior:auto}
}
