/* =========================================================
   Nando Cardoso — Portfólio / Consultoria
   Tema: Clean corporativo claro
   ========================================================= */

:root{
  --azul:        #0d3b66;
  --azul-700:    #0a2e50;
  --azul-300:    #2e6fb0;
  --verde:       #1d9d74;
  --verde-700:   #157a59;
  --ciano:       #16b8c8;
  --tinta:       #0f1b2d;
  --texto:       #324158;
  --suave:       #5b6b80;
  --linha:       #e4e9f0;
  --fundo:       #ffffff;
  --fundo-alt:   #f5f8fc;
  --branco:      #ffffff;
  --whats:       #25d366;
  --raio:        16px;
  --raio-sm:     10px;
  --sombra:      0 10px 30px rgba(13,59,102,.08);
  --sombra-fwd:  0 18px 50px rgba(13,59,102,.16);
  --container:   1140px;
  --fonte:       'Inter', system-ui, -apple-system, sans-serif;
  --titulo:      'Sora', 'Inter', sans-serif;
}

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

html{ scroll-behavior:smooth; scroll-padding-top:84px; }

body{
  font-family:var(--fonte);
  color:var(--texto);
  background:var(--fundo);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }

.container{
  width:100%;
  max-width:var(--container);
  margin-inline:auto;
  padding-inline:24px;
}

h1,h2,h3,h4{ font-family:var(--titulo); color:var(--tinta); line-height:1.15; font-weight:700; }

.eyebrow{
  text-transform:uppercase;
  letter-spacing:.14em;
  font-size:.78rem;
  font-weight:700;
  color:var(--azul-300);
  margin-bottom:14px;
}
.eyebrow-light{ color:#9fd0ff; }

.grad{
  background:linear-gradient(100deg,var(--azul-300),var(--verde));
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}

.muted{ color:var(--suave); }
.reg{ font-size:.5em; vertical-align:super; font-weight:600; opacity:.85; margin-left:1px; }
.small{ font-size:.88rem; }

/* ===== Botões ===== */
.btn{
  display:inline-flex;
  align-items:center;
  gap:9px;
  font-weight:600;
  font-family:var(--fonte);
  border:1.6px solid transparent;
  border-radius:50px;
  padding:13px 26px;
  cursor:pointer;
  transition:transform .18s ease, box-shadow .18s ease, background .18s ease, color .18s ease;
  font-size:.98rem;
  white-space:nowrap;
}
.btn:hover{ transform:translateY(-2px); }
.btn-sm{ padding:9px 18px; font-size:.9rem; }
.btn-lg{ padding:16px 32px; font-size:1.05rem; }

.btn-primary{ background:var(--azul); color:#fff; box-shadow:var(--sombra); }
.btn-primary:hover{ background:var(--azul-700); box-shadow:var(--sombra-fwd); }

.btn-ghost{ background:transparent; color:var(--azul); border-color:var(--linha); }
.btn-ghost:hover{ border-color:var(--azul-300); background:var(--fundo-alt); }

.btn-outline{ background:transparent; color:var(--azul); border-color:var(--azul); font-size:.92rem; padding:11px 22px; }
.btn-outline:hover{ background:var(--azul); color:#fff; }

.btn-whatsapp{ background:var(--whats); color:#fff; box-shadow:0 12px 30px rgba(37,211,102,.32); }
.btn-whatsapp:hover{ background:#1eb957; }

/* ===== Header ===== */
.site-header{
  position:sticky; top:0; z-index:100;
  background:rgba(255,255,255,.85);
  backdrop-filter:saturate(180%) blur(12px);
  border-bottom:1px solid var(--linha);
}
.nav{ display:flex; align-items:center; justify-content:space-between; height:72px; }

.brand{ display:flex; align-items:center; gap:12px; }
.brand-mark{
  width:42px; height:42px; flex:none;
  border-radius:12px; display:block; object-fit:contain;
}
/* Logo principal (PNG oficial do usuário; cai p/ ícone se o arquivo não existir) */
.brand-logo-img{ height:40px; width:auto; display:block; }
.brand-footer .brand-logo-img{ height:60px; }
.brand-text{ display:flex; flex-direction:column; font-family:var(--titulo); font-weight:700; color:var(--tinta); line-height:1.1; }
.brand-text small{ font-family:var(--fonte); font-weight:500; font-size:.72rem; color:var(--suave); letter-spacing:.02em; }

.nav-links{ display:flex; align-items:center; gap:30px; }
.nav-links a{ font-weight:500; color:var(--texto); font-size:.96rem; transition:color .15s; }
.nav-links a:hover{ color:var(--azul); }
.nav-links a.btn{ color:#fff; }
.nav-links a.btn-primary:hover{ color:#fff; }

.nav-toggle{ display:none; flex-direction:column; gap:5px; background:none; border:0; cursor:pointer; padding:8px; }
.nav-toggle span{ width:24px; height:2.5px; background:var(--tinta); border-radius:2px; transition:.25s; }
.nav-toggle[aria-expanded="true"] span:nth-child(1){ transform:translateY(7.5px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.nav-toggle[aria-expanded="true"] span:nth-child(3){ transform:translateY(-7.5px) rotate(-45deg); }

/* ===== Hero ===== */
.hero{
  position:relative;
  padding:90px 0 80px;
  background:
    radial-gradient(900px 500px at 85% -10%, rgba(46,111,176,.10), transparent 60%),
    radial-gradient(700px 500px at -5% 30%, rgba(29,157,116,.08), transparent 55%),
    var(--fundo);
}
.hero-grid{ display:grid; grid-template-columns:1.1fr .9fr; gap:56px; align-items:center; }
.hero h1{ font-size:clamp(2.1rem, 4.3vw, 3.4rem); font-weight:800; margin-bottom:22px; }
.lead{ font-size:1.12rem; color:var(--texto); max-width:560px; margin-bottom:30px; }
.hero-actions{ display:flex; gap:14px; flex-wrap:wrap; margin-bottom:34px; }
.hero-badges{ display:flex; gap:26px; flex-wrap:wrap; list-style:none; }
.hero-badges li{ font-size:.92rem; color:var(--suave); position:relative; padding-left:20px; }
.hero-badges li::before{ content:"✓"; position:absolute; left:0; color:var(--verde); font-weight:800; }
.hero-badges strong{ color:var(--tinta); }

/* Hero card (mock de código) */
.hero-card{
  position:relative;
  background:var(--tinta);
  border-radius:var(--raio);
  padding:26px;
  box-shadow:var(--sombra-fwd);
  overflow:hidden;
}
.hc-glow{ position:absolute; inset:-60px -60px auto auto; width:220px; height:220px; background:radial-gradient(circle,rgba(29,157,116,.5),transparent 70%); filter:blur(20px); }
.hc-row{ display:flex; gap:8px; margin-bottom:18px; position:relative; }
.dot{ width:12px; height:12px; border-radius:50%; }
.dot-r{ background:#ff5f57; } .dot-y{ background:#febc2e; } .dot-g{ background:#28c840; }
.hc-code{ position:relative; font-family:'SFMono-Regular',ui-monospace,Menlo,Consolas,monospace; font-size:.92rem; line-height:1.8; color:#cbd6e6; margin-bottom:24px; }
.c-key{ color:#7aa2ff; } .c-var{ color:#9be7c4; } .c-prop{ color:#8fd0ff; } .c-str{ color:#f0c987; } .c-fn{ color:#ff9ec4; }
.hc-stat{ position:relative; display:grid; grid-template-columns:repeat(3,1fr); gap:12px; padding-top:20px; border-top:1px solid rgba(255,255,255,.1); }
.hc-stat div{ display:flex; flex-direction:column; }
.hc-num{ font-family:var(--titulo); font-weight:800; font-size:1.5rem; color:#fff; }
.hc-lbl{ font-size:.72rem; color:#8ea0ba; }

/* ===== Seções ===== */
.section{ padding:84px 0; }
.section-alt{ background:var(--fundo-alt); }
.section-head{ text-align:center; max-width:680px; margin:0 auto 52px; }
.section-head h2{ font-size:clamp(1.7rem,3vw,2.4rem); margin-bottom:14px; }
.section-sub{ color:var(--suave); font-size:1.06rem; }

.grid{ display:grid; gap:26px; }
.grid-2{ grid-template-columns:repeat(2,1fr); }
.grid-3{ grid-template-columns:repeat(3,1fr); }

.card{
  background:var(--branco);
  border:1px solid var(--linha);
  border-radius:var(--raio);
  padding:32px;
  box-shadow:var(--sombra);
  transition:transform .2s ease, box-shadow .2s ease;
}
.card:hover{ transform:translateY(-4px); box-shadow:var(--sombra-fwd); }

/* Feature cards */
.feature{ text-align:left; }
.feature .ico{
  width:54px; height:54px; border-radius:14px; font-size:1.5rem;
  display:grid; place-items:center; margin-bottom:18px;
  background:linear-gradient(135deg,rgba(13,59,102,.1),rgba(29,157,116,.12));
}
.feature h3{ font-size:1.22rem; margin-bottom:10px; }
.feature p{ color:var(--suave); }

/* Brand cards */
.brand{ display:flex; flex-direction:column; }
.brand-wide{ grid-column:1 / -1; }
.brand-wide .btn{ align-self:center; }
.brand-wide .legal{ text-align:center; }
.brand-head{
  display:flex; align-items:center; justify-content:space-between;
  padding:16px 20px; border-radius:var(--raio-sm); margin-bottom:20px; color:#fff;
}
.brand-head.elyxa{ background:linear-gradient(120deg,#0d3b66,#2e6fb0); }
.brand-head.connect{ background:linear-gradient(120deg,#1d9d74,#16b8c8); }
.brand-head.fh{ background:#f5f8fc; border:1px solid var(--linha); color:var(--tinta); }
.brand-img{ height:64px; width:auto; }
.tag-outline{ background:transparent; color:var(--azul); border:1.5px solid var(--azul-300); }
.legal{ margin-top:14px; font-size:.82rem; color:var(--suave); letter-spacing:.02em; }
.gambling{ margin-top:16px; padding:12px 14px; background:#fff7ed; border:1px solid #fde2c0; border-radius:10px; font-size:.78rem; line-height:1.5; color:#8a5a23; }
.gambling strong{ color:#b4540a; }
.gambling a{ color:#b4540a; text-decoration:underline; }
.brand-logo{ font-family:var(--titulo); font-weight:700; font-size:1.25rem; }
.brand-logo b{ font-weight:800; opacity:.92; }
.tag{ font-size:.74rem; font-weight:600; background:rgba(255,255,255,.2); padding:5px 12px; border-radius:50px; }
.brand h3{ font-size:1.3rem; margin-bottom:10px; }
.brand p{ color:var(--suave); margin-bottom:18px; }
.brand .btn{ margin-top:auto; align-self:flex-start; }

.ticks{ list-style:none; margin-bottom:22px; display:grid; gap:8px; }
.ticks li{ position:relative; padding-left:26px; color:var(--texto); }
.ticks li::before{ content:"✓"; position:absolute; left:0; top:0; color:var(--verde); font-weight:800; }
.ticks-light li{ color:#dfeaf5; }
.ticks-light li::before{ color:#7ee6bf; }

/* Preços FH */
.price-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:16px; margin-bottom:22px; }
.price{ background:var(--fundo-alt); border:1px solid var(--linha); border-radius:var(--raio-sm); padding:20px; }
.price-val{ display:block; font-family:var(--titulo); font-weight:800; font-size:1.7rem; color:var(--azul); margin-bottom:6px; }
.price-val small{ font-size:.9rem; font-weight:600; color:var(--suave); }
.price-desc{ font-size:.92rem; color:var(--suave); }

/* ===== CTA band (consultoria) ===== */
.cta-band{
  background:linear-gradient(120deg,var(--azul-700),var(--azul) 55%,#114a7d);
  border-radius:24px;
  padding:54px;
  display:grid; grid-template-columns:1.5fr .8fr; gap:40px; align-items:center;
  color:#eaf2fb;
  position:relative; overflow:hidden;
  box-shadow:var(--sombra-fwd);
}
.cta-band::after{ content:""; position:absolute; inset:auto -80px -120px auto; width:320px; height:320px; background:radial-gradient(circle,rgba(29,157,116,.4),transparent 70%); }
.cta-band h2{ color:#fff; font-size:clamp(1.6rem,2.6vw,2.2rem); margin-bottom:16px; position:relative; }
.cta-band > div{ position:relative; }
.cta-band p{ color:#cfe0f2; margin-bottom:18px; }
.cta-band-action{ text-align:center; }
.cta-band-action .muted{ color:#9fc0e0; margin-top:12px; font-size:.88rem; }

/* ===== Partners ===== */
.partner{ position:relative; }
.partner-tag{ display:inline-block; font-size:.74rem; font-weight:700; letter-spacing:.06em; text-transform:uppercase; color:var(--verde-700); background:rgba(29,157,116,.1); padding:5px 12px; border-radius:50px; margin-bottom:14px; }
.partner h3{ font-size:1.3rem; margin-bottom:10px; }
/* Logo oficial do parceiro (PNG); se faltar, mostra o nome em texto */
.partner-logo-wrap{ display:block; margin-bottom:14px; min-height:48px; }
.partner-logo{ height:46px; width:auto; max-width:100%; display:block; }
.partner-name{ display:none; }
.partner-logo-wrap.img-failed .partner-logo{ display:none; }
.partner-logo-wrap.img-failed .partner-name{ display:block; }
.partner p{ color:var(--suave); margin-bottom:16px; }
.partner-prices{ display:flex; gap:14px 26px; flex-wrap:wrap; margin:2px 0 18px; }
.partner-prices > span{ display:flex; flex-direction:column; }
.partner-prices small{ font-size:.7rem; color:var(--suave); text-transform:uppercase; letter-spacing:.05em; font-weight:600; }
.partner-prices b{ font-family:var(--titulo); color:var(--azul); font-size:1.18rem; font-weight:800; }
.partner-prices b i{ font-style:normal; font-size:.78rem; color:var(--suave); font-weight:600; }
.partner-prices .from{ font-family:var(--fonte); font-weight:600; font-size:.74rem; color:var(--suave); }
.link-arrow{ font-weight:600; color:var(--azul); }
.link-arrow:hover{ color:var(--verde); }

/* ===== Contato ===== */
.section-contact{ background:var(--fundo-alt); }
.contact-grid{ display:grid; grid-template-columns:1.1fr .9fr; gap:48px; align-items:start; }
.contact-text h2{ font-size:clamp(1.7rem,3vw,2.4rem); margin-bottom:14px; }
.contact-text .btn-whatsapp{ margin:26px 0 14px; }
.contact-links h3{ font-size:1.15rem; margin-bottom:18px; }
.link-card{
  display:grid; grid-template-columns:1fr auto; align-items:center; row-gap:2px;
  padding:16px 18px; border:1px solid var(--linha); border-radius:var(--raio-sm);
  margin-bottom:12px; transition:.18s; background:var(--branco);
}
.link-card:hover{ border-color:var(--azul-300); transform:translateX(3px); }
.lc-name{ font-weight:700; color:var(--tinta); grid-column:1; }
.lc-desc{ font-size:.86rem; color:var(--suave); grid-column:1; }
.lc-arrow{ grid-row:1 / 3; grid-column:2; font-size:1.3rem; color:var(--azul-300); }

/* ===== Footer ===== */
.site-footer{ background:var(--tinta); color:#aebcce; padding:56px 0 28px; }
.footer-grid{ display:grid; grid-template-columns:1.6fr 1fr 1fr; gap:36px; padding-bottom:36px; border-bottom:1px solid rgba(255,255,255,.08); }
.brand-footer .brand-text{ color:#fff; }
.brand-footer .brand-text small{ color:#8ea0ba; }
.site-footer .muted{ color:#8294aa; margin-top:14px; }
.footer-col h4{ color:#fff; font-size:1rem; margin-bottom:14px; }
.footer-col a{ display:block; color:#aebcce; padding:5px 0; font-size:.94rem; transition:color .15s; }
.footer-col a:hover{ color:#fff; }
.footer-bottom{ display:flex; justify-content:space-between; flex-wrap:wrap; gap:10px; padding-top:22px; font-size:.86rem; }
.footer-bottom .muted{ margin:0; }

/* ===== WhatsApp flutuante ===== */
.wa-float{
  position:fixed; right:22px; bottom:22px; z-index:200;
  width:60px; height:60px; border-radius:50%;
  background:var(--whats); color:#fff;
  display:grid; place-items:center;
  box-shadow:0 10px 30px rgba(37,211,102,.45);
  transition:transform .2s ease;
  animation:wa-pulse 2.6s infinite;
}
.wa-float:hover{ transform:scale(1.08); }
@keyframes wa-pulse{
  0%{ box-shadow:0 10px 30px rgba(37,211,102,.45), 0 0 0 0 rgba(37,211,102,.4); }
  70%{ box-shadow:0 10px 30px rgba(37,211,102,.45), 0 0 0 16px rgba(37,211,102,0); }
  100%{ box-shadow:0 10px 30px rgba(37,211,102,.45), 0 0 0 0 rgba(37,211,102,0); }
}

/* ===== Animação de entrada ===== */
.reveal{ opacity:0; transform:translateY(24px); transition:opacity .6s ease, transform .6s ease; }
.reveal.in{ opacity:1; transform:none; }

/* ===== Página Contabilidade (FH) ===== */
.hero-fh{
  background:
    radial-gradient(800px 460px at 80% -10%, rgba(46,111,176,.12), transparent 60%),
    var(--fundo);
  padding:72px 0 56px;
  text-align:center;
}
.hero-fh .brand-img{ height:80px; margin:0 auto 26px; }
.hero-fh h1{ font-size:clamp(2rem,4vw,3rem); font-weight:800; max-width:880px; margin:0 auto 18px; }
.hero-fh .lead{ margin:0 auto 28px; }
.hero-fh .hero-actions{ justify-content:center; }

.plan{ display:flex; flex-direction:column; position:relative; }
.plan-featured{ border-color:var(--azul); box-shadow:var(--sombra-fwd); }
.plan-badge{ position:absolute; top:-13px; left:50%; transform:translateX(-50%); background:var(--azul); color:#fff; font-size:.74rem; font-weight:700; letter-spacing:.04em; text-transform:uppercase; padding:5px 16px; border-radius:50px; }
.plan h3{ font-size:1.25rem; margin-bottom:6px; }
.plan .plan-for{ color:var(--suave); font-size:.92rem; margin-bottom:18px; }
.plan .plan-price{ font-family:var(--titulo); font-weight:800; font-size:2.2rem; color:var(--azul); margin-bottom:4px; }
.plan .plan-price small{ font-size:1rem; font-weight:600; color:var(--suave); }
.plan .ticks{ margin:20px 0 24px; }
.plan .btn{ margin-top:auto; align-self:stretch; justify-content:center; }

.steps{ counter-reset:step; }
.step{ position:relative; padding-left:64px; }
.step::before{
  counter-increment:step; content:counter(step);
  position:absolute; left:0; top:0;
  width:44px; height:44px; border-radius:12px;
  display:grid; place-items:center;
  background:linear-gradient(135deg,var(--azul),var(--verde));
  color:#fff; font-family:var(--titulo); font-weight:800; font-size:1.2rem;
}
.step h3{ font-size:1.12rem; margin-bottom:6px; }
.step p{ color:var(--suave); }

.faq{ max-width:760px; margin:0 auto; display:grid; gap:14px; }
.faq details{ background:var(--branco); border:1px solid var(--linha); border-radius:var(--raio-sm); padding:4px 22px; box-shadow:var(--sombra); }
.faq summary{ cursor:pointer; font-family:var(--titulo); font-weight:700; color:var(--tinta); padding:16px 0; list-style:none; display:flex; justify-content:space-between; align-items:center; gap:16px; }
.faq summary::-webkit-details-marker{ display:none; }
.faq summary::after{ content:"+"; font-size:1.5rem; color:var(--azul-300); font-weight:400; transition:transform .2s; }
.faq details[open] summary::after{ transform:rotate(45deg); }
.faq details p{ color:var(--suave); padding:0 0 18px; margin:0; }

/* ===== Responsivo ===== */
@media (max-width:920px){
  .hero-grid{ grid-template-columns:1fr; gap:42px; }
  .hero-card{ order:-1; max-width:480px; }
  .cta-band{ grid-template-columns:1fr; padding:40px 28px; }
  .cta-band-action{ text-align:left; }
  .contact-grid{ grid-template-columns:1fr; gap:34px; }
  .footer-grid{ grid-template-columns:1fr 1fr; }
}

@media (max-width:760px){
  .nav-links{
    position:fixed; inset:72px 0 auto 0;
    flex-direction:column; align-items:stretch; gap:0;
    background:#fff; border-bottom:1px solid var(--linha);
    padding:10px 24px 22px;
    transform:translateY(-120%); transition:transform .3s ease;
    box-shadow:var(--sombra);
  }
  .nav-links.open{ transform:translateY(0); }
  .nav-links a{ padding:14px 4px; border-bottom:1px solid var(--linha); }
  .nav-links a.btn{ margin-top:14px; justify-content:center; border-bottom:0; }
  .nav-toggle{ display:flex; }

  .grid-2,.grid-3,.price-grid{ grid-template-columns:1fr; }
  .section{ padding:60px 0; }
  .hero{ padding:60px 0 50px; }
  .footer-grid{ grid-template-columns:1fr; }
}
