/* =========================================================
   Globais & Utilitários
   ========================================================= */

:root{
  /* Bordas e tons usados nos cards/contornos */
  --card-bd: rgba(255,255,255,.08);
  /* Em alguns trechos você usa --lp-border; deixo default aqui */
  --lp-border: rgba(255,255,255,.12);
  /* Espaçamento padrão para grids utilitários */
  --gap: .75rem;
  /* Cor do subtítulo do herói */
  --hero-sub: #bfd6ff;
}

.section-padding { padding: 4rem 0; }

.hero-title{
  font-size: clamp(1.8rem, 3.6vw, 3rem);
  font-weight: 700;
  line-height: 1.2;
  color: var(--bs-body-color);
}

.hero-sub{
  color: var(--hero-sub);
  font-size: 1.1rem;
}

/* ====== Marca na navbar ====== */
:root{
  --brand-size: 32px;   /* ajuste único do tamanho da marca */
}

/* Logo quadrado com gradiente (fallback quando não há logo imagem) */
.brand-logo{
  width: var(--brand-size);
  height: var(--brand-size);
  border-radius: .6rem;
  background: linear-gradient(135deg, var(--bs-primary), #183e9b);
  display: inline-grid;
  place-items: center;
  font-weight: 800;
  color: #fff;
  line-height: 1;               /* evita “descer” na linha */
  flex: 0 0 auto;               /* não estica em flex containers */
  box-shadow: 0 2px 6px rgba(0,0,0,.15);
}

/* Logo imagem */
.brand-logo-img{
  height: calc(var(--brand-size) - 4px); /* leve margem interna */
  width: auto;
  display: inline-block;
  vertical-align: middle;       /* alinha com o texto “Empresa” */
  object-fit: contain;          /* mantém proporção correta */
  border-radius: .5rem;         /* opcional */
}

/* Espaçamento entre ícone/logo e o nome */
.navbar-brand{
  display: flex;
  align-items: center;
  gap: .5rem;
}

/* Ajuste sutil para telas maiores */
@media (min-width: 992px){
  :root{ --brand-size: 36px; }
}


/* ===== Footer ultra-slim (override) ===== */
:root{ --brand-size: 32px; }
.brand-logo{
  width: var(--brand-size);
  height: var(--brand-size);
  border-radius: .6rem;
  background: linear-gradient(135deg, var(--bs-primary), #183e9b);
  display: inline-grid;
  place-items: center;
  font-weight: 800;
  color: #fff;
  line-height: 1;
  flex: 0 0 auto;
  box-shadow: 0 2px 6px rgba(0,0,0,.15);
}
.brand-logo-img{
  height: calc(var(--brand-size) - 4px);
  width: auto;
  display: inline-block;
  vertical-align: middle;
  object-fit: contain;
  border-radius: .5rem;
}
@media (min-width: 992px){
  :root{ --brand-size: 36px; }
}

/* =========================================================
   Botão flutuante WhatsApp
   ========================================================= */
.wa-fab{
  position: fixed;
  right: 18px;
  bottom: 18px;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  color: #fff;
  background: #25D366;
  box-shadow: 0 10px 20px rgba(0,0,0,.25);
  z-index: 1030;
  transition: transform .15s ease, box-shadow .15s ease;
}
.wa-fab:hover{
  transform: translateY(-2px);
  box-shadow: 0 14px 28px rgba(0,0,0,.30);
}

/* =========================================================
   Portfólio / Galeria Pro
   ========================================================= */
.pf-filter{
  display:flex;
  flex-wrap:wrap;
  gap:.5rem;
}
.pf-filter .btn{
  border-radius:999px;
  padding:.4rem .9rem;
  font-size:.9rem;
}

.pf-grid{
  display:grid;
  gap: var(--gap);
}
@media (min-width:768px){
  .pf-grid{ gap: 1rem; }
}

.pf-card{
  position:relative;
  overflow:hidden;
  border-radius:1rem;
  background:#0d1528;
  border:1px solid var(--lp-border, var(--card-bd));
  transition: transform .3s ease;
}
.pf-card img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transition: transform .5s ease;
}
.pf-card:hover img{ transform:scale(1.06); }

.pf-overlay{
  position:absolute;
  inset:0;
  display:flex;
  align-items:flex-end;
  background:linear-gradient(180deg, transparent 30%, rgba(0,0,0,.65));
  opacity:0;
  padding:1rem;
  transition: opacity .25s ease;
}
.pf-card:hover .pf-overlay{ opacity:1; }

.pf-badge{
  display:inline-block;
  font-size:.75rem;
  color:#fff;
  background:rgba(255,255,255,.08);
  border:1px solid var(--lp-border, rgba(255,255,255,.12));
  border-radius:999px;
  padding:.3rem .7rem;
}

/* Aspect ratios utilitários */
.pf-1x1{ aspect-ratio:1/1; }
.pf-4x3{ aspect-ratio:4/3; }
.pf-3x4{ aspect-ratio:3/4; }
.pf-16x9{ aspect-ratio:16/9; }

/* =========================================================
   Lightbox (Imagem Ampliada)
   ========================================================= */
.lb-backdrop{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.85);
  display:none;
  align-items:center;
  justify-content:center;
  z-index:1055;
}
.lb-backdrop.show{ display:flex; }

.lb-img{
  max-width:min(92vw,1200px);
  max-height:86vh;
  border-radius:1rem;
  box-shadow:0 20px 50px rgba(0,0,0,.5);
}
.lb-close{
  position:absolute;
  top:14px;
  right:14px;
  width:38px;
  height:38px;
  display:grid;
  place-items:center;
  background:#000;
  color:#fff;
  border:1px solid rgba(255,255,255,.2);
  border-radius:50%;
  cursor:pointer;
}

/* =========================================================
   Serviços (visual refinado)
   ========================================================= */

/* Miniatura compacta (quando usada em listas) */
.service-thumb{
  width:48px;height:48px;flex:0 0 auto;object-fit:cover;
  border-radius:12px;
  box-shadow:0 2px 10px rgba(0,0,0,.15);
}
@media (min-width:768px){
  .service-thumb{ width:56px;height:56px; }
}

/* Card base */
.service-card{
  overflow:hidden;border-radius:1rem;
  background:#0f172a;border:1px solid rgba(255,255,255,.06);
  box-shadow:0 8px 24px rgba(0,0,0,.25);
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.service-card:hover{
  transform:translateY(-2px);
  box-shadow:0 14px 36px rgba(0,0,0,.32);
  border-color:rgba(255,255,255,.10);
}

/* Capa quadrada (thumb principal do serviço) */
.service-cover{
  width:100%;height:auto;display:block;
  aspect-ratio:1 / 1 !important;      /* força 1:1 */
  object-fit:cover;                    /* corta sem distorcer */
  border-bottom:1px solid rgba(255,255,255,.06);
}
.service-cover.placeholder{
  aspect-ratio:1 / 1 !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02)),
    radial-gradient(900px 360px at -10% -10%, rgba(43,110,255,.20), transparent 60%),
    #0e162f;
}

/* Limite “confortável” no desktop (enviar 1100x1100 para retina) */
@media (min-width:1200px){
  .service-cover{ max-height:550px; }
}

/* Conteúdo do card */
.service-title{
  color:#eaf2ff;font-weight:700;line-height:1.25;margin:0 0 .25rem;
}
.service-text{
  color:#b5c6e8;font-size:.97rem;line-height:1.55;margin:0;
}

/* Acessibilidade & preferências do usuário */
.service-card:focus-within{ outline:2px solid rgba(46,131,255,.5); outline-offset:2px; }
@media (prefers-reduced-motion: reduce){
  .service-card{ transition:none; }
}


/* =========================================================
   Ajustes finos de cards genéricos (opcional)
   ========================================================= */
.card{
  border:1px solid var(--lp-border, var(--card-bd));
  border-radius: .75rem;
  transition: transform .15s ease, box-shadow .2s ease, border-color .2s ease;
}
.card:hover{
  transform: translateY(-2px);
  box-shadow: 0 10px 30px rgba(0,0,0,.25);
}
/* =========================================================
   #depoimentos
   ========================================================= */
    #depoimentos .t-card{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.08);border-radius:1rem;box-shadow:0 10px 30px rgba(0,0,0,.25);}
    #depoimentos .t-quote{width:36px;height:36px;border-radius:.6rem;display:grid;place-items:center;background:linear-gradient(135deg,var(--bs-primary),#183e9b);color:#0b1220;font-weight:800;}
    #depoimentos .t-name{color:#eaf2ff;font-weight:700;}
    #depoimentos .t-text{color:#b5c6e8;line-height:1.6;}
    #depoimentos .t-avatar{width:64px;height:64px;border-radius:50%;object-fit:cover;border:2px solid rgba(255,255,255,.12);background:#0f172a;}
    #depoimentos .t-ctrl{--bd:rgba(255,255,255,.25);border:1px solid var(--bd);color:#e9eefb;}
    /* remove altura/gap extra do carrossel */
    #depoimentos .carousel { margin-bottom: 0; }
    #depoimentos .carousel-inner { padding: 0; }
    #depoimentos .carousel-item { padding: 0; }
    
    /* Depoimentos (texto dentro do card) */
    #depoimentos .t-text{ color:#cfe0ff !important; }
    #depoimentos .t-name{ color:#eaf2ff !important; }
    
/* =========================================================
   #sobre — ajustes visuais + imagem 16:9 (1920×1080)
   ========================================================= */

/* Imagem do bloco "Sobre": 1920x1080 responsiva */
#sobre .about-cover{
  display:block;
  width:100%;
  height:auto;            /* mantém proporção */
  aspect-ratio:16 / 9;    /* 1920×1080 */
  object-fit:cover;       /* preenche sem distorcer; pode cortar bordas */
  border-radius:1rem;     /* combina com seu tema */
  border:1px solid rgba(255,255,255,.10);
  background:#0f172a;     /* fallback se a imagem ainda não carregou */
}

/* (Opcional) Se quiser zero corte nas bordas, troque cover por contain:
   #sobre .about-cover{ object-fit:contain; background:#0b1220; }
*/

/* Texto principal: já com bom contraste, só garantimos consistência */
#sobre .about-text{
  color:#e9eefb;
  line-height:1.7;
  opacity:1;
}

/* Bullet com “check” */
#sobre .check-dot{
  width:28px;
  height:28px;
  display:inline-grid;
  place-items:center;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.10);
  border-radius:.5rem;
}
#sobre .check-dot svg{
  display:block;
  color:#cfe3ff;              /* ícone mais visível no escuro */
}

/* KPI cards */
#sobre .kpi-box{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.10);
  border-radius:.75rem;
  box-shadow:0 10px 30px rgba(0,0,0,.25); /* leve profundidade */
}

/* Título dos parceiros */
#sobre .partners-title{
  margin-top:28px;
  margin-bottom:10px;
  color:#9fb1d6;
}

/* Textos secundários no tema escuro */
.text-secondary{ color: rgba(255,255,255,.75) !important; }
.text-light-50{ color: rgba(255,255,255,.70) !important; }
.text-muted, .form-text{ color: rgba(255,255,255,.60) !important; }

/* Links claros em fundos escuros */
a.link-light{ color:#cfe3ff !important; }
a.link-light:hover{ color:#ffffff !important; }

/* Parágrafos das seções principais */
#sobre p, .hero-sub, .hero-overlay p{ color: rgba(255,255,255,.86) !important; }

/* Cards de métricas/estatísticas */
.stats .stat-value{ color:#eaf2ff !important; }
.stats .stat-label{ color: rgba(255,255,255,.70) !important; }

/* Toques finos do bloco de portfólio (mantém seu tema) */
.pf-filter .btn{ border-color: rgba(255,255,255,.25); color:#dbe7ff; }
.pf-filter .btn.active, .pf-filter .btn:hover{
  color:#0b1220; background: var(--bs-primary); border-color: var(--bs-primary);
}
.pf-card{ cursor: zoom-in; }
.pf-card .pf-overlay{ padding: 1rem; }

/* Responsividade sutil para telas menores */
@media (max-width: 575.98px){
  #sobre .about-cover{ border-radius:.75rem; }
  #sobre .check-dot{ width:26px; height:26px; }
}


/* =========================================================
   #portfolio
   ========================================================= */ 
    #portfolio .pf-card{
      position:relative; overflow:hidden; border-radius:1rem;
      background:#0f172a; border:1px solid rgba(255,255,255,.08);
      box-shadow:0 10px 30px rgba(0,0,0,.25); transition:transform .18s ease;
    }
    #portfolio .pf-card:hover{ transform:translateY(-2px); }
    #portfolio .pf-cover{ width:100%; aspect-ratio:16/10; object-fit:cover; display:block; }
    #portfolio .pf-overlay{
      position:absolute; inset:0; display:flex; flex-direction:column; justify-content:flex-end;
      padding:1rem; background:linear-gradient(180deg,rgba(2,6,23,0) 35%, rgba(2,6,23,.85) 100%);
    }
    #portfolio .pf-badge{
      display:inline-block; font-size:.75rem; color:#fff; opacity:.9;
      border:1px solid rgba(255,255,255,.25); border-radius:999px; padding:.25rem .6rem;
      margin-bottom:.4rem;
    }
    #portfolio .pf-title{ color:#fff; font-weight:800; line-height:1.25; margin:0; }
    #portfolio .pf-sub{ color:#c7d2fe; font-size:.9rem; margin:.25rem 0 .6rem; }
    #portfolio .pf-actions{ display:flex; gap:.5rem; }
    #portfolio .pf-actions .btn{
      border-radius:.6rem; padding:.45rem .85rem; font-weight:700;
      border:1px solid rgba(255,255,255,.25); color:#e9eefb; background:transparent;
    }
    #portfolio .pf-actions .btn-primary{
      background:var(--bs-primary); border-color:var(--bs-primary); color:#0b1220;
    }
    #portfolio .pf-actions .btn[disabled]{
      opacity:.6; cursor:not-allowed;
    }
    /* botão e detalhes */
#portfolio .pf-title{
  color:#fff; font-weight:700; line-height:1.25; margin:0 0 .6rem;
  max-width:100%;
}
#portfolio .pf-actions{ margin-top:.25rem; }

#portfolio .pf-btn{
  display:inline-block; padding:.45rem .95rem; border-radius:.7rem;
  background:var(--bs-primary); color:#0b1220; font-weight:700;
  border:0; text-decoration:none;
  box-shadow:0 6px 18px rgba(30,94,255,.35);
  transition:transform .12s ease, filter .12s ease;
}
#portfolio .pf-btn:hover{ filter:brightness(1.06); transform:translateY(-1px); }

/* garante que o stretched-link funcione sem “vazar” */
#portfolio .pf-card{ position:relative; }
#portfolio .pf-card .stretched-link{ position: static; }

/* evita títulos longos estourarem a área */
#portfolio .pf-title.text-truncate{
  overflow:hidden; text-overflow:ellipsis; white-space:nowrap;
}


/* =========================================================
   #
   ========================================================= */ 
   
   /* Modal — garante que avisos fiquem legíveis no tema escuro */
.modal .form-text{
  color:#e9eefb !important;
  opacity:1 !important;
}
