/* ============================================================
   RS Assessoria Contábil — CSS Principal
   Design: moderno, profissional, confiável
   ============================================================ */

/* ── Variáveis ─────────────────────────────────────────────── */
:root {
  --azul:        #1B3C5D;
  --azul-escuro: #122740;
  --azul-claro:  #2A5F8F;
  --ouro:        #C9A84C;
  --ouro-claro:  #E8C96A;
  --branco:      #FFFFFF;
  --cinza-claro: #F5F7FA;
  --cinza-medio: #E9ECEF;
  --cinza-texto: #6C757D;
  --preto-texto: #1A1A2E;
  --whatsapp:    #25D366;
  --whatsapp-dk: #1da851;
  --sombra:      0 4px 24px rgba(27,60,93,.10);
  --sombra-hover:0 8px 32px rgba(27,60,93,.18);
  --raio:        12px;
  --raio-sm:     8px;
  --transicao:   all .25s ease;
}

/* ── Reset e base ──────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  font-family: 'Segoe UI', system-ui, -apple-system, sans-serif;
  color: var(--preto-texto);
  background: var(--branco);
  line-height: 1.65;
}

h1,h2,h3,h4,h5 {
  font-weight: 700;
  line-height: 1.25;
  color: var(--azul-escuro);
}

a { color: var(--azul); text-decoration: none; transition: var(--transicao); }
a:hover { color: var(--ouro); }

img { max-width: 100%; height: auto; }

/* ── Navbar ────────────────────────────────────────────────── */
.rs-navbar {
  background: var(--branco);
  box-shadow: 0 2px 12px rgba(27,60,93,.08);
  padding: .75rem 0;
  position: sticky;
  top: 0;
  z-index: 1000;
}

.rs-navbar .navbar-brand {
  font-size: 1.3rem;
  font-weight: 800;
  color: var(--azul);
  letter-spacing: -.3px;
}

.rs-navbar .navbar-brand span { color: var(--ouro); }

.logo-header {
  height: auto;
  max-height: 100px;
  width: auto;
  max-width: 320px;
  display: block;
  object-fit: contain;
}

.logo-footer {
  height: auto;
  max-height: 90px;
  width: auto;
  max-width: 300px;
  display: block;
  object-fit: contain;
  margin-bottom: 1rem;
}

.rs-navbar .nav-link {
  color: var(--azul) !important;
  font-weight: 500;
  padding: .4rem .85rem !important;
  border-radius: var(--raio-sm);
  transition: var(--transicao);
}

.rs-navbar .nav-link:hover,
.rs-navbar .nav-link.active {
  background: var(--cinza-claro);
  color: var(--azul-claro) !important;
}

.rs-navbar .dropdown-menu {
  border: none;
  box-shadow: var(--sombra);
  border-radius: var(--raio);
  padding: .5rem;
}

.rs-navbar .dropdown-item {
  border-radius: var(--raio-sm);
  padding: .5rem .85rem;
  font-size: .92rem;
  color: var(--azul);
  transition: var(--transicao);
}

.rs-navbar .dropdown-item:hover {
  background: var(--cinza-claro);
  color: var(--azul-claro);
}

.btn-wa-nav {
  background: var(--whatsapp);
  color: var(--branco) !important;
  border-radius: 50px !important;
  padding: .4rem 1.1rem !important;
  font-weight: 600 !important;
  font-size: .88rem;
  transition: var(--transicao);
}

.btn-wa-nav:hover {
  background: var(--whatsapp-dk) !important;
  transform: translateY(-1px);
}

/* ── Botões ────────────────────────────────────────────────── */
.btn-rs-primario {
  background: var(--azul);
  color: var(--branco);
  padding: .75rem 2rem;
  border-radius: 50px;
  font-weight: 600;
  font-size: .95rem;
  border: none;
  transition: var(--transicao);
  display: inline-flex;
  align-items: center;
  gap: .5rem;
}

.btn-rs-primario:hover {
  background: var(--azul-claro);
  color: var(--branco);
  transform: translateY(-2px);
  box-shadow: var(--sombra-hover);
}

.btn-rs-wa {
  background: var(--whatsapp);
  color: var(--branco);
  padding: .75rem 2rem;
  border-radius: 50px;
  font-weight: 600;
  font-size: .95rem;
  border: none;
  transition: var(--transicao);
  display: inline-flex;
  align-items: center;
  gap: .5rem;
}

.btn-rs-wa:hover {
  background: var(--whatsapp-dk);
  color: var(--branco);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(37,211,102,.3);
}

.btn-rs-outline {
  background: transparent;
  color: var(--azul);
  padding: .72rem 2rem;
  border-radius: 50px;
  font-weight: 600;
  font-size: .95rem;
  border: 2px solid var(--azul);
  transition: var(--transicao);
  display: inline-flex;
  align-items: center;
  gap: .5rem;
}

.btn-rs-outline:hover {
  background: var(--azul);
  color: var(--branco);
  transform: translateY(-2px);
}

.btn-rs-outline-branco {
  background: transparent;
  color: var(--branco);
  padding: .72rem 2rem;
  border-radius: 50px;
  font-weight: 600;
  font-size: .95rem;
  border: 2px solid rgba(255,255,255,.6);
  transition: var(--transicao);
  display: inline-flex;
  align-items: center;
  gap: .5rem;
}

.btn-rs-outline-branco:hover {
  background: rgba(255,255,255,.15);
  color: var(--branco);
  border-color: var(--branco);
}

/* ── Hero ──────────────────────────────────────────────────── */
.rs-hero {
  background: linear-gradient(135deg, var(--azul-escuro) 0%, var(--azul-claro) 100%);
  color: var(--branco);
  padding: 6rem 0 5rem;
  position: relative;
  overflow: hidden;
}

.rs-hero::before {
  content: '';
  position: absolute;
  width: 600px; height: 600px;
  background: rgba(201,168,76,.07);
  border-radius: 50%;
  top: -200px; right: -150px;
}

.rs-hero::after {
  content: '';
  position: absolute;
  width: 400px; height: 400px;
  background: rgba(255,255,255,.04);
  border-radius: 50%;
  bottom: -150px; left: -100px;
}

.rs-hero .badge-destaque {
  background: rgba(201,168,76,.2);
  color: var(--ouro-claro);
  border: 1px solid rgba(201,168,76,.3);
  padding: .35rem .85rem;
  border-radius: 50px;
  font-size: .82rem;
  font-weight: 600;
  letter-spacing: .5px;
  text-transform: uppercase;
  display: inline-block;
  margin-bottom: 1.25rem;
}

.rs-hero h1 {
  font-size: clamp(2rem, 5vw, 3.2rem);
  color: var(--branco);
  margin-bottom: 1.25rem;
  font-weight: 800;
}

.rs-hero h1 em {
  color: var(--ouro-claro);
  font-style: normal;
}

.rs-hero p {
  font-size: 1.1rem;
  opacity: .88;
  max-width: 540px;
  margin-bottom: 2rem;
  line-height: 1.75;
}

.rs-hero-card {
  background: rgba(255,255,255,.1);
  backdrop-filter: blur(12px);
  border: 1px solid rgba(255,255,255,.15);
  border-radius: var(--raio);
  padding: 2rem;
  color: var(--branco);
}

.rs-hero-card .card-stat {
  text-align: center;
  padding: .75rem;
  border-right: 1px solid rgba(255,255,255,.15);
}

.rs-hero-card .card-stat:last-child { border-right: none; }

.rs-hero-card .stat-num {
  font-size: 1.8rem;
  font-weight: 800;
  color: var(--ouro-claro);
  display: block;
}

.rs-hero-card .stat-label {
  font-size: .78rem;
  opacity: .8;
  text-transform: uppercase;
  letter-spacing: .5px;
}

/* ── Seções genéricas ──────────────────────────────────────── */
.rs-secao { padding: 5rem 0; }
.rs-secao-cinza { background: var(--cinza-claro); }
.rs-secao-azul {
  background: linear-gradient(135deg, var(--azul-escuro), var(--azul-claro));
  color: var(--branco);
}

.rs-titulo-secao {
  font-size: clamp(1.6rem, 3.5vw, 2.2rem);
  font-weight: 800;
  margin-bottom: .75rem;
}

.rs-titulo-secao .destaque { color: var(--ouro); }

.rs-subtitulo-secao {
  font-size: 1.05rem;
  color: var(--cinza-texto);
  max-width: 600px;
  margin: 0 auto 3rem;
}

.rs-linha-ouro {
  width: 48px; height: 4px;
  background: var(--ouro);
  border-radius: 4px;
  margin: .75rem 0 1.5rem;
}

.rs-linha-ouro.centro { margin: .75rem auto 1.5rem; }

/* ── Cards de serviço ──────────────────────────────────────── */
.rs-card-servico {
  background: var(--branco);
  border: 1px solid var(--cinza-medio);
  border-radius: var(--raio);
  padding: 2rem 1.75rem;
  height: 100%;
  transition: var(--transicao);
  position: relative;
  overflow: hidden;
}

.rs-card-servico::before {
  content: '';
  position: absolute;
  bottom: 0; left: 0;
  width: 100%; height: 3px;
  background: linear-gradient(90deg, var(--azul), var(--ouro));
  transform: scaleX(0);
  transition: var(--transicao);
  transform-origin: left;
}

.rs-card-servico:hover {
  box-shadow: var(--sombra-hover);
  transform: translateY(-5px);
  border-color: transparent;
}

.rs-card-servico:hover::before { transform: scaleX(1); }

.rs-card-servico .icone {
  width: 56px; height: 56px;
  background: var(--cinza-claro);
  border-radius: var(--raio-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.6rem;
  margin-bottom: 1.25rem;
  transition: var(--transicao);
}

.rs-card-servico:hover .icone {
  background: var(--azul);
}

.rs-card-servico h3 {
  font-size: 1.05rem;
  font-weight: 700;
  margin-bottom: .6rem;
  color: var(--azul-escuro);
}

.rs-card-servico p {
  font-size: .9rem;
  color: var(--cinza-texto);
  line-height: 1.6;
  margin-bottom: 1.25rem;
}

.rs-card-servico .link-mais {
  font-size: .88rem;
  font-weight: 600;
  color: var(--azul);
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  transition: var(--transicao);
}

.rs-card-servico .link-mais:hover { gap: .6rem; color: var(--ouro); }

/* ── Sobre / Diferenciais ──────────────────────────────────── */
.rs-foto-rosana {
  border-radius: var(--raio);
  box-shadow: var(--sombra-hover);
  width: 100%;
  object-fit: cover;
  aspect-ratio: 4/5;
  background: var(--cinza-medio);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 5rem;
  color: var(--cinza-texto);
}

.rs-item-diferencial {
  display: flex;
  gap: 1rem;
  margin-bottom: 1.5rem;
  align-items: flex-start;
}

.rs-item-diferencial .icone-check {
  width: 40px; height: 40px;
  min-width: 40px;
  background: rgba(27,60,93,.08);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  color: var(--azul);
}

.rs-item-diferencial h4 {
  font-size: .97rem;
  font-weight: 700;
  margin-bottom: .25rem;
  color: var(--azul-escuro);
}

.rs-item-diferencial p {
  font-size: .88rem;
  color: var(--cinza-texto);
  margin: 0;
}

/* ── Cards de nicho ────────────────────────────────────────── */
.rs-card-nicho {
  background: var(--branco);
  border-radius: var(--raio);
  padding: 1.75rem;
  height: 100%;
  border: 1px solid var(--cinza-medio);
  transition: var(--transicao);
  text-decoration: none;
  color: inherit;
  display: block;
}

.rs-card-nicho:hover {
  box-shadow: var(--sombra-hover);
  transform: translateY(-4px);
  border-color: var(--azul);
  color: inherit;
}

.rs-card-nicho .emoji { font-size: 2rem; margin-bottom: .75rem; display: block; }
.rs-card-nicho h3 { font-size: 1rem; font-weight: 700; margin-bottom: .5rem; }
.rs-card-nicho p { font-size: .875rem; color: var(--cinza-texto); margin: 0; }

/* ── Depoimentos ───────────────────────────────────────────── */
.rs-card-depoimento {
  background: var(--branco);
  border-radius: var(--raio);
  padding: 2rem;
  box-shadow: var(--sombra);
  height: 100%;
  position: relative;
}

.rs-card-depoimento::before {
  content: '"';
  position: absolute;
  top: 1rem; left: 1.5rem;
  font-size: 4rem;
  color: var(--ouro);
  opacity: .3;
  font-family: Georgia, serif;
  line-height: 1;
}

.rs-card-depoimento p {
  font-size: .95rem;
  color: var(--cinza-texto);
  font-style: italic;
  margin-bottom: 1.25rem;
  line-height: 1.7;
}

.rs-card-depoimento .cliente-nome {
  font-weight: 700;
  color: var(--azul-escuro);
  font-size: .92rem;
}

.rs-card-depoimento .cliente-empresa {
  font-size: .82rem;
  color: var(--cinza-texto);
}

.rs-estrelas { color: var(--ouro); font-size: .9rem; margin-bottom: .75rem; }

/* ── FAQ ───────────────────────────────────────────────────── */
.rs-faq .accordion-item {
  border: 1px solid var(--cinza-medio);
  border-radius: var(--raio) !important;
  margin-bottom: .75rem;
  overflow: hidden;
}

.rs-faq .accordion-button {
  font-weight: 600;
  font-size: .97rem;
  color: var(--azul-escuro);
  background: var(--branco);
  padding: 1.1rem 1.5rem;
  box-shadow: none !important;
}

.rs-faq .accordion-button:not(.collapsed) {
  color: var(--azul-claro);
  background: var(--cinza-claro);
}

.rs-faq .accordion-button::after {
  filter: hue-rotate(180deg);
}

.rs-faq .accordion-body {
  color: var(--cinza-texto);
  font-size: .93rem;
  line-height: 1.75;
  padding: 1rem 1.5rem 1.25rem;
}

/* ── CTA banner ────────────────────────────────────────────── */
.rs-cta-banner {
  background: linear-gradient(135deg, var(--azul-escuro), var(--azul-claro));
  padding: 4.5rem 0;
  color: var(--branco);
  text-align: center;
}

.rs-cta-banner h2 {
  color: var(--branco);
  font-size: clamp(1.6rem,4vw,2.4rem);
  margin-bottom: .75rem;
}

.rs-cta-banner p {
  opacity: .85;
  font-size: 1.05rem;
  margin-bottom: 2rem;
  max-width: 560px;
  margin-left: auto;
  margin-right: auto;
}

/* ── Página interna (nicho/blog) ───────────────────────────── */
.rs-hero-pagina {
  background: linear-gradient(135deg, var(--azul-escuro), var(--azul-claro));
  color: var(--branco);
  padding: 4rem 0 3.5rem;
}

.rs-hero-pagina .breadcrumb-item,
.rs-hero-pagina .breadcrumb-item a { color: rgba(255,255,255,.7); font-size: .85rem; }
.rs-hero-pagina .breadcrumb-item.active { color: var(--ouro-claro); }
.rs-hero-pagina .breadcrumb-divider { color: rgba(255,255,255,.4); }

.rs-hero-pagina h1 {
  color: var(--branco);
  font-size: clamp(1.6rem,4vw,2.6rem);
  margin: .75rem 0 1rem;
}

.rs-hero-pagina .subtitulo {
  font-size: 1.05rem;
  opacity: .85;
  max-width: 680px;
}

.rs-conteudo-pagina {
  padding: 4rem 0;
}

.rs-conteudo-pagina h2 {
  font-size: 1.4rem;
  color: var(--azul-escuro);
  margin: 2.5rem 0 1rem;
  padding-bottom: .5rem;
  border-bottom: 2px solid var(--cinza-medio);
}

.rs-conteudo-pagina h2:first-child { margin-top: 0; }

.rs-conteudo-pagina h3 {
  font-size: 1.05rem;
  color: var(--azul-claro);
  margin: 1.75rem 0 .5rem;
}

.rs-conteudo-pagina p { color: #444; line-height: 1.8; margin-bottom: 1rem; }

.rs-conteudo-pagina ul {
  padding-left: 1.25rem;
  color: #444;
  line-height: 1.8;
}

.rs-conteudo-pagina ul li { margin-bottom: .35rem; }

.rs-sidebar {
  position: sticky;
  top: 90px;
}

.rs-card-contato-sidebar {
  background: var(--azul-escuro);
  color: var(--branco);
  border-radius: var(--raio);
  padding: 2rem;
  text-align: center;
}

.rs-card-contato-sidebar h4 {
  color: var(--ouro-claro);
  font-size: 1.1rem;
  margin-bottom: .75rem;
}

.rs-card-contato-sidebar p {
  font-size: .88rem;
  opacity: .85;
  margin-bottom: 1.5rem;
  color: var(--branco) !important;
}

.rs-card-outros-servicos {
  background: var(--cinza-claro);
  border-radius: var(--raio);
  padding: 1.5rem;
  margin-top: 1.5rem;
}

.rs-card-outros-servicos h5 {
  font-size: .9rem;
  text-transform: uppercase;
  letter-spacing: .5px;
  color: var(--cinza-texto);
  margin-bottom: 1rem;
}

.rs-card-outros-servicos a {
  display: block;
  font-size: .9rem;
  color: var(--azul);
  padding: .4rem 0;
  border-bottom: 1px solid var(--cinza-medio);
  transition: var(--transicao);
}

.rs-card-outros-servicos a:last-child { border-bottom: none; }
.rs-card-outros-servicos a:hover { color: var(--ouro); padding-left: .35rem; }

/* ── Blog ──────────────────────────────────────────────────── */
.rs-card-post {
  background: var(--branco);
  border: 1px solid var(--cinza-medio);
  border-radius: var(--raio);
  overflow: hidden;
  height: 100%;
  transition: var(--transicao);
}

.rs-card-post:hover {
  box-shadow: var(--sombra-hover);
  transform: translateY(-4px);
  border-color: transparent;
}

.rs-card-post .post-imagem {
  background: linear-gradient(135deg, var(--azul) 0%, var(--azul-claro) 100%);
  height: 160px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 3rem;
}

.rs-card-post .post-corpo { padding: 1.5rem; }

.rs-card-post .post-categoria {
  font-size: .75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .5px;
  color: var(--azul-claro);
  margin-bottom: .6rem;
  display: block;
}

.rs-card-post h3 {
  font-size: 1rem;
  font-weight: 700;
  margin-bottom: .5rem;
  line-height: 1.4;
}

.rs-card-post h3 a {
  color: var(--azul-escuro);
  text-decoration: none;
}

.rs-card-post h3 a:hover { color: var(--azul-claro); }

.rs-card-post p {
  font-size: .875rem;
  color: var(--cinza-texto);
  line-height: 1.6;
  margin-bottom: 1rem;
}

.rs-card-post .ler-mais {
  font-size: .85rem;
  font-weight: 600;
  color: var(--azul);
  display: inline-flex;
  align-items: center;
  gap: .3rem;
  transition: var(--transicao);
}

.rs-card-post .ler-mais:hover { gap: .5rem; color: var(--ouro); }

/* ── Footer ────────────────────────────────────────────────── */
.rs-footer {
  background: var(--azul-escuro);
  color: rgba(255,255,255,.75);
  padding: 4rem 0 0;
}

.rs-footer h5 {
  color: var(--branco);
  font-size: .95rem;
  font-weight: 700;
  margin-bottom: 1.25rem;
  text-transform: uppercase;
  letter-spacing: .5px;
}

.rs-footer p, .rs-footer a {
  font-size: .88rem;
  color: rgba(255,255,255,.65);
  line-height: 1.8;
}

.rs-footer a:hover { color: var(--ouro-claro); }

.rs-footer ul { list-style: none; padding: 0; margin: 0; }
.rs-footer ul li { margin-bottom: .4rem; }

.rs-footer .footer-bottom {
  border-top: 1px solid rgba(255,255,255,.1);
  padding: 1.25rem 0;
  margin-top: 3rem;
  font-size: .82rem;
  color: rgba(255,255,255,.45);
}

.rs-footer .social-link {
  width: 36px; height: 36px;
  background: rgba(255,255,255,.08);
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: rgba(255,255,255,.7) !important;
  font-size: .95rem;
  transition: var(--transicao);
  margin-right: .5rem;
}

.rs-footer .social-link:hover {
  background: var(--ouro);
  color: var(--branco) !important;
}

/* ── WhatsApp flutuante ────────────────────────────────────── */
.btn-wa-flutuante {
  position: fixed;
  bottom: 2rem;
  right: 2rem;
  width: 58px; height: 58px;
  background: var(--whatsapp);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.7rem;
  color: var(--branco);
  box-shadow: 0 4px 20px rgba(37,211,102,.45);
  z-index: 999;
  transition: var(--transicao);
  text-decoration: none;
}

.btn-wa-flutuante:hover {
  transform: scale(1.1) translateY(-2px);
  color: var(--branco);
  box-shadow: 0 8px 28px rgba(37,211,102,.55);
}

.btn-wa-flutuante .pulsar {
  position: absolute;
  width: 100%; height: 100%;
  border-radius: 50%;
  background: var(--whatsapp);
  animation: pulsar 2s infinite;
  z-index: -1;
}

@keyframes pulsar {
  0%   { transform: scale(1);   opacity: .6; }
  70%  { transform: scale(1.5); opacity: 0;  }
  100% { transform: scale(1.5); opacity: 0;  }
}

/* ── Badge de categoria ────────────────────────────────────── */
.rs-badge-categoria {
  background: rgba(27,60,93,.08);
  color: var(--azul-claro);
  font-size: .75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .5px;
  padding: .3rem .8rem;
  border-radius: 50px;
  display: inline-block;
}

/* ── Utilitários ───────────────────────────────────────────── */
.text-azul    { color: var(--azul) !important; }
.text-ouro    { color: var(--ouro) !important; }
.bg-azul      { background: var(--azul) !important; }
.bg-azul-esc  { background: var(--azul-escuro) !important; }

/* ── Responsivo ────────────────────────────────────────────── */
@media (max-width: 768px) {
  .rs-hero { padding: 4rem 0 3.5rem; }
  .rs-secao { padding: 3.5rem 0; }
  .rs-hero-card .card-stat { border-right: none; border-bottom: 1px solid rgba(255,255,255,.15); }
  .rs-hero-card .card-stat:last-child { border-bottom: none; }
  .btn-wa-flutuante { bottom: 1.25rem; right: 1.25rem; }
}
