/* Identidade visual pública - consistente com a dashboard */
:root { color-scheme: light dark; }

.gradient-bg {
  /* Fundo global com iluminação muito sutil (sem divisões bruscas) */
  background:
    radial-gradient(1000px circle at 18% 0%, rgba(99,102,241,0.08) 0%, rgba(99,102,241,0.04) 50%, transparent 70%),
    radial-gradient(1000px circle at 82% 100%, rgba(14,165,233,0.07) 0%, rgba(14,165,233,0.035) 50%, transparent 70%),
    linear-gradient(180deg, #0b1220 0%, #0a0f1a 55%, #06090f 100%);
  background-attachment: fixed;
}

.glass {
  background: rgba(20,20,20,0.55);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border: 1px solid rgba(255,255,255,0.08);
}

/* Topbar tecnológico */
.topbar {
  position: sticky; top: 0; z-index: 50;
  background: rgba(10,12,16,0.55);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid rgba(255,255,255,0.08);
}

.nav-link { color: rgba(229,231,235,0.85); position: relative; }
.nav-link:hover { color: #e5e7eb; }
.nav-link::after {
  content: ""; position: absolute; left: 0; bottom: -6px; height: 2px; width: 0;
  background: linear-gradient(90deg, #8b5cf6 0%, #60a5fa 100%);
  transition: width .25s ease;
}
.nav-link:hover::after { width: 100%; }

.cta-gradient {
  background: linear-gradient(90deg, #111827 0%, #374151 50%, #4b5563 100%);
  color: #fff;
}
.cta-gradient:hover { opacity: .92; }

/* Mobile nav */
#mobileNav { display: none; }
#mobileNav.open { display: block; }

/* Hero decor */
.hero {
  position: relative;
  overflow: hidden;
}
.hero-video-wrap { position: relative; min-height: 540px; }
.hero-video {
  position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: cover; object-position: center;
  filter: brightness(0.55);
  z-index: 0;
}
.hero-tint {
  position: absolute; inset: 0;
  background: radial-gradient(1200px circle at 30% 10%, rgba(31,41,55,0.65) 0%, rgba(15,23,42,0.7) 40%, rgba(0,0,0,0.8) 100%),
              linear-gradient(90deg, rgba(99,102,241,0.12) 0%, rgba(14,165,233,0.12) 100%);
  z-index: 1;
}
.hero-content { position: relative; z-index: 3; padding-right: clamp(0px, 18vw, 320px); }
.hero-figure {
  position: absolute;
  right: clamp(72px, 9vw, 200px);
  bottom: 0;
  top: auto;
  transform: none;
  z-index: 2;
}
.hero-figure img {
  width: clamp(260px, 30vw, 520px);
  height: auto;
  filter: drop-shadow(0 18px 36px rgba(0,0,0,0.35));
}

/* Metrics cards */
.metrics {
  position: relative;
}
.metric-card {
  position: relative;
  overflow: hidden;
  backdrop-filter: blur(12px);
  background: linear-gradient(180deg, rgba(15,23,42,0.50) 0%, rgba(2,6,23,0.55) 100%);
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 20px;
  padding: 22px;
  box-shadow: 0 1px 0 rgba(255,255,255,0.06) inset, 0 18px 28px rgba(0,0,0,0.30);
  transition: transform .2s ease, box-shadow .2s ease, background .2s ease;
}
.metric-card::after {
  content: "";
  position: absolute;
  left: 0; right: 0; top: 0; height: 2px;
  background: linear-gradient(90deg, rgba(99,102,241,0.9), rgba(14,165,233,0.9));
  opacity: 0.65;
}
.metric-card:hover { 
  transform: translateY(-4px);
  background: linear-gradient(180deg, rgba(15,23,42,0.56) 0%, rgba(2,6,23,0.62) 100%);
  box-shadow: 0 1px 0 rgba(255,255,255,0.08) inset, 0 24px 36px rgba(0,0,0,0.35);
}
.metric-value { 
  font-family: "Inter", system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  font-weight: 800; 
  letter-spacing: -0.02em;
  color: #fff;
}
.metric-title {
  font-weight: 700;
  color: rgba(255,255,255,0.9);
}
.metric-sub { color: rgba(226,232,240,0.8); }

/* Always-visible icon + mini bars */
.metric-header { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.metric-icon {
  width: 42px; height: 42px; border-radius: 14px; display: grid; place-items: center;
  background: linear-gradient(180deg, rgba(99,102,241,0.18) 0%, rgba(14,165,233,0.18) 100%);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.18), 0 8px 16px rgba(0,0,0,0.25);
  transition: transform .2s ease, box-shadow .2s ease;
}
.metric-icon svg { width: 22px; height: 22px; color: #fff; opacity: 0.95; }
.metric-sparkline { margin-top: 14px; height: 36px; opacity: 0.95; }
.metric-sparkline svg { width: 100%; height: 100%; }
.metric-card:hover .metric-icon { transform: scale(1.06); box-shadow: inset 0 0 0 1px rgba(255,255,255,0.22), 0 12px 22px rgba(0,0,0,0.32); }
.metric-card:hover .metric-sparkline { filter: brightness(1.07); }

/* Icon badge ao lado do título (outline simples) */
.metric-head { display: flex; align-items: center; gap: 8px; }
.icon-badge {
  display: inline-flex; align-items: center; justify-content: center;
  width: 34px; height: 34px; border-radius: 10px;
  background: transparent;
  border: 1px solid rgba(255,255,255,0.35);
  box-shadow: none;
}
.icon-badge svg { width: 18px; height: 18px; stroke: #fff; opacity: 0.98; fill: none; }
.metric-card:hover .icon-badge { border-color: rgba(255,255,255,0.55); }

.mini-bars { display: flex; align-items: flex-end; gap: 10px; height: 56px; margin-top: 8px; }
.mini-bars .bar {
  width: 10px; border-radius: 8px 8px 0 0;
  height: var(--h, 14px);
  background: linear-gradient(180deg, rgba(99,102,241,0.9), rgba(14,165,233,0.9));
  opacity: 0.9; transition: height .3s ease, opacity .2s ease;
}
.metric-card:hover .mini-bars .bar { opacity: 1; }

@keyframes risePulse { 0%{ transform: translateY(0)} 50%{ transform: translateY(-2px)} 100%{ transform: translateY(0)} }
.metric-card:hover .mini-bars .bar { animation: risePulse 1.6s ease infinite; }
.hero::before {
  content: ""; position: absolute; inset: -20% -10% auto auto;
  width: 480px; height: 480px; border-radius: 50%;
  background: radial-gradient(circle, rgba(99,102,241,0.16) 0%, rgba(99,102,241,0.06) 60%, transparent 70%);
  filter: blur(6px);
}

/* Cards mais altos + faixa interativa inferior */
.metric-tall { min-height: 330px; padding-bottom: 62px; }

.metric-reveal{
  position:absolute; left:0; right:0; bottom:-3px;
  padding:12px 16px;
  background: linear-gradient(180deg, rgba(255,255,255,0) 0%, rgba(12,14,20,0.25) 16%, rgba(10,12,18,0.65) 100%);
  border-top: 1px solid rgba(255,255,255,0.06);
  transform: translateY(0);
  transition: transform .35s cubic-bezier(.22,1,.36,1), background .35s;
}

/* ======= Carrossel de imóveis ======= */
.props-section .section-head { margin-bottom: 14px; }
.props-section { position: relative; overflow: hidden; }
.props-section::before, .props-section::after {
  content:""; position:absolute; left:-10%; right:-10%; pointer-events:none; filter: blur(4px);
}
.props-section::before { top:-6%; height: 240px;
  background:
    radial-gradient(460px circle at 12% 0%, rgba(99,102,241,0.08), transparent 62%),
    radial-gradient(520px circle at 88% 6%, rgba(14,165,233,0.06), transparent 64%);
}
.props-section::after { bottom:-7%; height: 220px;
  background:
    radial-gradient(460px circle at 16% 100%, rgba(99,102,241,0.05), transparent 70%),
    radial-gradient(520px circle at 92% 100%, rgba(14,165,233,0.045), transparent 72%);
}
.props-carousel { position: relative; }
@media (min-width: 768px){
  /* Safe area lateral para não sobrepor imagens, igual ao banner */
  .props-carousel{ padding-left: clamp(56px, 6vw, 112px); padding-right: clamp(56px, 6vw, 112px); }
}
.props-viewport {
  overflow: hidden;
  /* ocultar scrollbar visualmente */
  scrollbar-width: none; /* Firefox */
  -ms-overflow-style: none; /* IE/Edge legacy */
  padding-bottom: 8px;
}

.py-16 {
    padding-top: -10px !important;
    padding-bottom: -10rem !important;
}
.props-viewport::-webkit-scrollbar { display: none; }
.props-track { display: flex; gap: 12px; will-change: transform; transition: transform .45s cubic-bezier(.22,1,.36,1); }
.prop-card {
  min-width: 320px; scroll-snap-align: start;
  border: 1px solid rgba(255,255,255,0.08);
  background: rgba(20,22,29,0.6);
  border-radius: 16px; overflow: hidden;
  transition: transform .2s ease, box-shadow .2s ease;
}
.prop-card:hover { transform: translateY(-4px); box-shadow: 0 10px 24px rgba(0,0,0,0.28); }
.prop-media { position: relative; }
.prop-media::before { content:""; display:block; padding-top:56.25%; }
.prop-media img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; border-top-left-radius:16px; border-top-right-radius:16px; }
.prop-badges { position:absolute; top:10px; left:10px; display:flex; gap:8px; }
.badge { font-size:12px; padding:4px 8px; border-radius:999px; border:1px solid rgba(255,255,255,0.2); background: rgba(255,255,255,0.08); }
.badge-ghost { background: transparent; }
.prop-content { padding: 12px 14px 14px; }
.prop-title { font-weight:600; }
.prop-price { margin-top: 4px; font-weight:700; font-size: 1.05rem; }
.prop-chips { display:flex; flex-wrap:wrap; gap:8px; margin-top:10px; }
.prop-chips li { font-size:12px; padding:4px 8px; border:1px solid rgba(255,255,255,0.12); border-radius:8px; background: rgba(255,255,255,0.05); }
.prop-location { margin-top:10px; color:#a3a3a3; }
.prop-actions { margin-top:12px; display:flex; gap:8px; }
.props-ctas { margin-top:16px; display:flex; gap:10px; justify-content:center; flex-wrap:wrap; }

.props-nav { position:absolute; top:50%; transform:translateY(-50%); z-index:2; width:44px; height:44px; border-radius:999px; border: none; background: #ffffff; color: #0f172a; display:flex; align-items:center; justify-content:center; box-shadow: 0 10px 15px -3px rgba(0,0,0,.1), 0 4px 6px -4px rgba(0,0,0,.1); }
.props-nav:hover { filter: brightness(0.95); }
.props-nav:active { transform: translateY(-50%) scale(0.97); }
.props-nav:focus { outline: 2px solid rgba(99,102,241,0.6); }
.props-nav.prev { left: 12px; }
.props-nav.next { right: 12px; }

.props-dots { margin-top: 10px; display:flex; gap:6px; justify-content:center; }
.props-dot { width:8px; height:8px; border-radius:999px; background: rgba(255,255,255,0.16); }
.props-dot.active { background: rgba(99,102,241,0.9); }

@media (min-width: 768px){
  .props-track { gap: 14px; }
  .prop-card { min-width: 360px; }
}
@media (min-width: 1024px){
  .props-track { gap: 16px; }
  .prop-card { min-width: 380px; }
}

/* ======= Por que escolher o Daniel ======= */

/* Interação com a imagem de pesquisa (Google) */
.porque-google { overflow: hidden; }
.porque-google-img { transition: transform .25s ease, box-shadow .25s ease; cursor: pointer; }
.porque-google-img:hover { transform: scale(1.03); box-shadow: 0 12px 28px rgba(0,0,0,0.35); }

/* Preview modal simples para imagens */
.img-preview-overlay { position: fixed; inset: 0; background: rgba(0,0,0,0.6); display: none; align-items: center; justify-content: center; z-index: 100; }
.img-preview-overlay.active { display: flex; }
.img-preview-content { max-width: 90vw; max-height: 85vh; border-radius: 12px; border: 1px solid rgba(255,255,255,0.12); }

.sobre-wrap { max-width: 88rem; margin: 0 auto; padding: 4rem 1.25rem; }
.sobre-head { text-align:center; }
.sobre-sub { color:#d1d5db; margin-top:.5rem; }
.sobre-grid { display:grid; gap:16px; margin-top: 1.5rem; }
@media(min-width:768px){ .sobre-grid { grid-template-columns: repeat(12, minmax(0,1fr)); } }
.sobre-card { grid-column: span 12 / span 12; border:1px solid rgba(255,255,255,0.08); border-radius:16px; background: rgba(20,22,29,0.6); backdrop-filter: blur(6px); padding: 16px; }
@media(min-width:768px){ .sobre-card { padding: 20px; } }
.sobre-card h3 { font-weight:600; font-size:1.1rem; display:flex; align-items:center; gap:8px; }
.sobre-card p { color:#e5e7eb; margin-top:.5rem; }
.sobre-values { display:grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap:10px; margin-top:.75rem; }
.sobre-values li { font-size:.9rem; padding:.45rem .6rem; border:1px solid rgba(255,255,255,0.12); border-radius:12px; background: rgba(255,255,255,0.05); }
.sobre-badges { display:flex; gap:8px; flex-wrap:wrap; margin-top:.5rem; }
.sobre-badge { font-size:12px; padding:6px 10px; border-radius:999px; border:1px solid rgba(255,255,255,0.2); background: rgba(255,255,255,0.08); }
.sobre-cta { margin-top:1rem; display:flex; gap:10px; justify-content:center; flex-wrap:wrap; }
.sobre-card.emphasis { grid-column: span 12 / span 12; background: linear-gradient(180deg, rgba(38,41,53,0.7), rgba(20,22,29,0.6)); border:1px solid rgba(255,255,255,0.1); }
@media(min-width:1024px){
  .sobre-card.col-4 { grid-column: span 4 / span 4; }
  .sobre-card.col-6 { grid-column: span 6 / span 6; }
}
.porque-left { position: relative; }
.porque-bullets { display: grid; gap: 10px; color: #d4d4d4; }
.porque-bullets li { padding-left: 10px; border-left: 2px solid rgba(99,102,241,0.6); }

.porque-left-inner { display:flex; flex-direction:column; align-items:center; gap:10px; }
.porque-left-inner p { max-width:48ch; }

.porque-viewport { position: relative; height: 78vh; overflow: hidden; scroll-snap-type: y mandatory; scroll-behavior: smooth; overscroll-behavior: contain; width: 100%; padding: 4px 2px; }
.porque-viewport { scrollbar-width: none; -ms-overflow-style: none; }
.porque-viewport::-webkit-scrollbar { display: none; }
.porque-viewport::before, .porque-viewport::after {
  content:""; position:absolute; left:0; right:0; height: 48px; pointer-events:none; z-index:2;
}
.porque-viewport::before { top:0; background: linear-gradient(180deg, rgba(10,12,18,0.85), rgba(10,12,18,0)); }
.porque-viewport::after { bottom:0; background: linear-gradient(0deg, rgba(10,12,18,0.85), rgba(10,12,18,0)); }
.porque-track { display: block; position: relative; will-change: transform; }
.porque-card {
  scroll-snap-align: start; border: 1px solid rgba(255,255,255,0.10);
  border-radius: 16px; backdrop-filter: blur(8px); background: linear-gradient(180deg, rgba(30,32,40,0.65), rgba(14,16,22,0.65));
  min-height: 24vh; padding: 12px; margin-bottom: 14px; transition: transform .2s ease, box-shadow .2s ease;
  max-width: 600px; margin-left: auto; margin-right: auto;
  position: relative;
}
.porque-card:hover, .porque-card:focus-within { transform: translateY(-4px); box-shadow: 0 12px 28px rgba(0,0,0,0.28); }
.porque-card::before{ content:""; position:absolute; inset:0; border-radius:16px; pointer-events:none; background: linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0)); }
.porque-badge { display:flex; align-items:center; gap:8px; margin-bottom: 6px; }
.porque-title-card { font-weight: 600; font-size: 1rem; }
.porque-desc { margin-top: 6px; color: #c9c9c9; font-size: 0.93rem; }
.porque-footer { margin-top: 8px; display:flex; align-items:center; gap:10px; justify-content: space-between; }

/* Melhor distribuição e credibilidade visual */
.porque-divider{ margin:10px 0; height:1px; background: linear-gradient(90deg, rgba(99,102,241,0.35), rgba(14,165,233,0.35)); border:0; }
.trust-row{ display:flex; align-items:center; flex-wrap:wrap; gap:8px; margin-top:8px; }
.trust-chip{ display:inline-flex; align-items:center; gap:6px; padding:6px 10px; border-radius:999px; font-size:12px; color:#e5e7eb;
  background: rgba(255,255,255,0.06); border:1px solid rgba(255,255,255,0.12);
}
.trust-chip .icon{ width:16px; height:16px; color:#a5b4fc; }
.stat-list{ display:flex; align-items:center; gap:10px; margin-top:8px; }
.stat-pill{ display:inline-flex; align-items:center; gap:6px; padding:6px 10px; border-radius:10px; font-size:12px;
  background: rgba(99,102,241,0.12); border:1px solid rgba(99,102,241,0.25); color:#e0e7ff;
}
.stat-pill .icon{ width:16px; height:16px; }

.status-dots { display:flex; gap:6px; }
.status-dots span { width:8px; height:8px; border-radius:999px; background: rgba(99,102,241,0.9); animation: blink 1.6s infinite ease-in-out; }
.status-dots span:nth-child(2){ animation-delay: .2s; }
.status-dots span:nth-child(3){ animation-delay: .4s; }
@keyframes blink { 0%,100%{ opacity:.35 } 50%{ opacity:1 } }

.porque-card .mini-bars { display:flex; align-items:flex-end; gap:8px; height:42px; }
.porque-card .mini-bars span { width:8px; border-radius:8px 8px 0 0; height: var(--h, 24px); background: linear-gradient(180deg, rgba(99,102,241,0.92), rgba(14,165,233,0.92)); opacity:.9; }
.porque-card.in-view .mini-bars span { animation: risePulse 1.6s ease infinite; }

/* Mobile / tablet: horizontal carrossel */
@media (max-width: 1023px){
  .porque-viewport { overflow-x: auto; overflow-y: hidden; height: auto; padding-bottom: 8px; scroll-snap-type: x mandatory; }
  .porque-track { display:flex; gap:12px; }
  .porque-card { min-width: 85vw; min-height: auto; max-width: none; }
}
@media (min-width: 768px){ .porque-card { min-height: 30vh; padding: 14px; max-width: 580px; } }
@media (min-width: 1024px){ .porque-card { min-height: 32vh; padding: 16px; max-width: 560px; } }

/* Sticky e centralização do bloco esquerdo apenas em telas grandes */
@media (min-width: 1024px){
  .porque-left { position: sticky; top: 0; height: 100vh; display: grid; place-items: center; text-align: center; }
  /* deslocamento solicitado: +50px direita e -45px cima em desktops */
  .porque-left-inner { transform: translate(50px, -45px); will-change: transform; }
}
.metric-card:hover .metric-reveal,
.metric-card:focus-within .metric-reveal{ background: linear-gradient(180deg, rgba(255,255,255,0) 0%, rgba(12,14,20,0.30) 16%, rgba(10,12,18,0.72) 100%); }

/* Pills interativas */
.pill{
  display:inline-flex; align-items:center; gap:.5rem;
  padding:.5rem .8rem; border-radius:999px;
  background: linear-gradient(90deg, rgba(99,102,241,.14), rgba(14,165,233,.14));
  border:1px solid rgba(255,255,255,.14);
  color:#fff; font-size:.875rem; line-height:1rem;
  transition: transform .2s ease, background .2s ease, border-color .2s ease;
}
.pill:hover{ transform: translateY(-2px); border-color:rgba(255,255,255,.22); }
.pill-ghost{ background: transparent; }

/* Mini gráfico de barras (VGV) */
.mini-bars{ display:flex; align-items:flex-end; gap:10px; height:56px; }
.mini-bars span{
  --h:60%;
  width:12px; height:var(--h);
  background: linear-gradient(180deg, rgba(99,102,241,.9), rgba(14,165,233,.9));
  border-radius:8px; opacity:.97;
  transform-origin: bottom; transform: scaleY(1);
  transition: transform .5s cubic-bezier(.22,1,.36,1), opacity .3s;
}
.metric-card:hover .mini-bars span{ transform: scaleY(1); opacity:1; animation: risePulse 1.6s ease infinite; }

/* Pontos/ícones dos bancos (placeholders redondos) */
.bank-dot{
  width:22px; height:22px; border-radius:999px;
  background: radial-gradient(circle at 30% 30%, #fff, #cbd5e1 40%, #64748b 100%);
  box-shadow: 0 0 0 2px rgba(255,255,255,.08) inset, 0 6px 14px rgba(0,0,0,.3);
  transition: transform .2s ease, box-shadow .2s ease;
}
.bank-dot:hover{ transform: translateY(-3px) scale(1.06); box-shadow: 0 0 0 2px rgba(255,255,255,.16) inset, 0 10px 18px rgba(0,0,0,.4); }

/* Acessibilidade no hover/keyboard */
.metric-card:focus-within { outline: none; }
.metric-card a:focus-visible{ outline:2px solid rgba(99,102,241,.7); outline-offset:2px; border-radius:10px; }


.hero::after {
  content: ""; position: absolute; inset: auto -10% -20% auto;
  width: 420px; height: 420px; border-radius: 50%;
  background: radial-gradient(circle, rgba(14,165,233,0.16) 0%, rgba(14,165,233,0.06) 60%, transparent 70%);
  filter: blur(6px);
}



/* Logo sizing utility */
.logo { height: 36px; }
@media (min-width: 768px) { .logo { height: 40px; } }
.metric-stars{ margin-top: 6px; display: flex; align-items: center; gap: 8px; }
.metric-stars svg{ width: 26px; height: 26px; }
.metric-banks{ margin-top: 6px; display:flex; align-items:center; gap:8px; }
.metric-center-icon{ display:flex; justify-content:center; margin: 10px 0 6px; }
/* Auras para seções âncora básicas (Empreendimentos, Portfólio, Contatos, Notícias) */
#empreendimentos, #portfolio, #contatos, #noticias { position: relative; overflow: hidden; }
#empreendimentos::before, #portfolio::before, #contatos::before, #noticias::before,
#empreendimentos::after, #portfolio::after, #contatos::after, #noticias::after {
  content:""; position:absolute; left:-10%; right:-10%; pointer-events:none; filter: blur(4px);
}
#empreendimentos::before, #portfolio::before, #contatos::before, #noticias::before { top:-6%; height:240px;
  background:
    radial-gradient(460px circle at 10% 0%, rgba(99,102,241,0.07), transparent 64%),
    radial-gradient(520px circle at 95% 6%, rgba(14,165,233,0.05), transparent 66%);
}
#empreendimentos::after, #portfolio::after, #contatos::after, #noticias::after { bottom:-7%; height:220px;
  background:
    radial-gradient(460px circle at 12% 100%, rgba(99,102,241,0.04), transparent 72%),
    radial-gradient(520px circle at 92% 100%, rgba(14,165,233,0.035), transparent 74%);
}

/* Continuity overrides: remove per-section overlays to avoid visible edges */
.props-section::before,
.props-section::after,
.porque-section::before,
.porque-section::after,
#empreendimentos::before,
#portfolio::before,
#noticias::before,
#empreendimentos::after,
#portfolio::after,
#noticias::after {
  display: none !important;
  content: none !important;
}

/* Keep a single continuous site background */
body.gradient-bg {
  background-attachment: fixed;
}

/* =====================
   Seção de Notícias
   ===================== */
.news-section { position: relative; }
.news-grid { display: grid; grid-template-columns: 1fr; gap: 20px; }
@media (min-width: 768px) {
  .news-grid { grid-template-columns: 1.6fr 1fr; gap: 20px; align-items: stretch; grid-auto-rows: 1fr; }
  .news-feature { grid-column: 1; grid-row: 1 / span 2; height: 100%; display: flex; flex-direction: column; }
}
.news-card {
  background: linear-gradient(180deg, rgba(255,255,255,0.06), rgba(255,255,255,0.03));
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 8px 24px rgba(0,0,0,0.25);
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
  height: 100%;
  display: flex; flex-direction: column;
}
.news-card:hover { transform: translateY(-3px); box-shadow: 0 12px 28px rgba(0,0,0,0.3); border-color: rgba(255,255,255,0.18); }
.news-media { aspect-ratio: 16 / 9; background: #0b0e15; overflow: hidden; }
.news-media img { width: 100%; height: 100%; object-fit: cover; object-position: center; display: block; }
.news-media img.face-top { object-position: top center; }
.news-feature .news-media { aspect-ratio: 3 / 2; flex-grow: 1; }
.news-body { padding: 12px 14px; }
.news-title { color: #fff; font-weight: 600; font-size: .98rem; line-height: 1.25; margin-bottom: 6px; }
.news-preview { color: #cbd5e1; font-size: .88rem; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.news-actions { padding: 0 14px 14px 14px; margin-top: auto; }
.news-feature .news-actions { margin-top: 12px; }
.news-actions .cta-gradient { font-size: .9rem; }

/* =====================
   Rodapé clássico
   ===================== */
.site-footer { border-top: 1px solid rgba(255,255,255,0.08); background: linear-gradient(180deg, rgba(12,14,20,0.9), rgba(10,12,18,0.95)); }
.footer-bar { padding: 26px 0; }
.footer-cols { display: grid; gap: 18px; grid-template-columns: 1fr; align-items: start; }
@media (min-width: 768px){ .footer-cols { grid-template-columns: 1.4fr 1fr 1fr; } }
.footer-brand { display:flex; align-items:center; gap:14px; }
.footer-logo { height: 48px; width: auto; opacity: .95; }
.footer-brand .brand-info { line-height: 1.25; }
.footer-brand .brand-name { font-weight: 700; color:#fff; }
.footer-contact h4, .footer-social h4 { font-weight: 600; color: #fff; font-size: 1rem; margin-bottom: 8px; }
.footer-contact ul { display: grid; gap: 8px; }
.contact-item { display:flex; align-items:center; gap:10px; }
.contact-icon { width:28px; height:28px; border-radius:999px; display:flex; align-items:center; justify-content:center; background: rgba(255,255,255,0.08); border:1px solid rgba(255,255,255,0.18); color:#fff; }
.footer-contact a { color: #e5e7eb; }
.footer-contact a:hover { color: #fff; text-decoration: underline; }
.social-list { display:grid; gap:8px; }
.social-item { display:flex; align-items:center; gap:10px; }
.footer-social .icon { width:34px; height:34px; border-radius:999px; display:flex; align-items:center; justify-content:center; background: rgba(255,255,255,0.08); border:1px solid rgba(255,255,255,0.18); color:#fff; transition: transform .15s ease, background .15s ease; }
.footer-social .icon:hover { transform: translateY(-2px); background: rgba(255,255,255,0.14); }
.social-item .handle { color:#e5e7eb; }
.social-item .handle:hover { color:#fff; text-decoration: underline; }
.footer-bottom { border-top: 1px solid rgba(255,255,255,0.08); }
.footer-bottom .dev-note { color: #a5b4fc; font-weight: 600; }

/* =====================
   Botão WhatsApp flutuante
   ===================== */
.whatsapp-fab {
  position: fixed;
  bottom: 18px;
  right: 18px;
  width: 56px;
  height: 56px;
  border-radius: 999px;
  background: #25D366;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 8px 20px rgba(37,211,102,0.35);
  z-index: 1000;
  transition: transform .15s ease, box-shadow .15s ease, background .15s ease;
}
.whatsapp-fab:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 24px rgba(37,211,102,0.45);
  background: #1ebe57;
}
.whatsapp-fab svg {
  width: 28px;
  height: 28px;
  fill: currentColor;
}
@media (max-width: 480px){
  .whatsapp-fab { width: 52px; height: 52px; bottom: 16px; right: 16px; }
}


