/* ===================================
    fadesp brasil
====================================== */
/* font */
@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@200;300;400;500;600;700;800&display=swap');
/* variable */
:root {     
    --base-color: #f50824; 
    --dark-gray:#464646;
    --black:#05060a;
    --medium-gray:#7d8087;
    --very-light-gray: #f0f2f8;
    --primary-font: 'Plus Jakarta Sans', sans-serif;
    --modal-offset-mobile: 6vh;   /* antes: 6vh */
    --modal-offset-desktop: 10vh;  /* antes: 8vh */
    --ar-r: 245;   /* #f50824 */
    --ar-g: 8;
    --ar-b: 36;
    --list-accent: #2946f3; /* cor do marcador */
    --brand-accent: #2946f3; 
}
/* reset */
body{
    line-height: 29px;
}
/* header */
header .navbar-brand img {
    max-height: 32px;
} 
.navbar .navbar-nav .nav-link {
    font-size: 17px;
}
header .btn.btn-rounded.btn-large {
    padding:10px 26px;
    font-size: 13px;
    font-weight: 500;
}
.sticky .header-transparent .header-button .btn {
    color: var(--dark-gray);
    border-color: var(--extra-medium-gray);
}
.sticky .header-transparent .header-button .btn:hover {
    border-color: var(--dark-gray);
    color: var(--white);
    background:  var(--dark-gray);
}
header.sticky.sticky-active [data-header-hover="light"] .widget-text i {
    color: var(--white);
}
/* accordion style 02 */
.navbar .navbar-nav .dropdown.dropdown-with-icon-style02 .dropdown-menu {
    background-color: var(--dark-gray);
}
.navbar .navbar-nav .dropdown.dropdown-with-icon-style02 .dropdown-menu li a {
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
    color: var(--white);
}
.navbar .navbar-nav .dropdown.dropdown-with-icon-style02 .dropdown-menu li:hover a,
.navbar .navbar-nav .dropdown.dropdown-with-icon-style02 .dropdown-menu li.active a{
    opacity: .5;
}
/* btn */
[class*=btn-transparent], [class*=" btn-transparent"] {
    font-weight: 500;
}
.btn {
    text-transform: none;
    font-family: var(--primary-font);
}
.btn.btn-switch-text.btn-extra-large > span {
    padding: 19px 40px;
}
.btn-gradient-purple-pink {
    background-image: linear-gradient(to right, #0b58cb, #e94037, #0b58cb);
    background-size: 200% auto;
    color: var(--white);
}
/* bg gradient color */
.bg-gradient-dark-gray { 
    background: -webkit-linear-gradient(right, rgba(24, 25, 28, .5), rgba(255, 255, 255, 0.0));
    background: linear-gradient(to right, rgba(24, 25, 28, .5), rgba(255, 255, 255, 0.0));
}

/* Botão com gradiente cinza-vermelho */
.btn-gradient-gray-red {
  /* mais cinza, menos vermelho */
  background-image: linear-gradient(
  to right,
  #3a3a3a 0%,
  #c94f4f 50%,
  #3a3a3a 80%
);
  background-size: 200% auto;
  color: var(--white);
  transition: background-position 0.4s ease;
}

/* Animação no hover */
.btn-gradient-gray-red:hover {
  background-position: right center;
}


.bg-gradient-very-light-gray-transparent {
    background: -webkit-linear-gradient(right, rgba(240, 244, 253, 1.0), rgba(255, 255, 255, 0.0));
    background: linear-gradient(to right, rgba(240, 244, 253, 1.0), rgba(255, 255, 255, 0.0));
}
.bg-gradient-flamingo-red-transparent {
    background: -webkit-linear-gradient(right, rgba(243, 69, 59, 1.0), rgba(255, 255, 255, 0.0));
    background: linear-gradient(to right, rgba(243, 69, 59, 1.0) 10%, rgba(255, 255, 255, 0.0) 95%);
}
.bg-gradient-base-color-transparent {
    background: -webkit-linear-gradient(right, rgba(15, 89, 201, 1.0), rgba(255, 255, 255, 0.0));
    background: linear-gradient(to right, rgba(15, 89, 201, 1.0) 10%, rgba(255, 255, 255, 0.0) 95%);
}
.bg-gradient-light-gray-transparent {
    background: -webkit-linear-gradient(right, rgba(222, 230, 244, 1.0), rgba(255, 255, 255, 0.0));
    background: linear-gradient(to right, rgba(222, 230, 244, 1.0), rgba(255, 255, 255, 0.0));
}
.bg-midnight-blue {
    background-color: #1e2033;
}
/* text */
.text-flamingo {
    color: #e55b53;
}
.text-gradient-orange-sky-blue {
    background-image: linear-gradient(to right, #5e70f3, #6170f1, #8074dc, #b87bb6, #ec8192);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}
.h1, .h2, .h3, .h4, .h5, .h6, h1, h2, h3, h4, h5, h6 {
    margin-bottom: 25px;
}
/* portfolio filter */
.portfolio-filter li {
    padding: 0 18px;
    line-height: 24px;
}
/* blog */ 
.categories-btn {
    font-size: 11px;
}
/* page title */
.page-title-extra-large h1 {
    font-size: 4rem;
    line-height: 4rem;
}
.page-title-extra-large h2 {
    font-size: 17px;
    line-height: 28px;
    margin: 0 auto;
}
.process-step-style-05 .progress-step-separator {
    bottom: -10px;
    height: 100%;
    z-index: -1;
}
/* height */
.h-72px {
    height: 72px !important;
}
#map {
    height: 650px;
    border-radius: 6px 0 0 6px;
}
/* margin top */
.mt-minus-50px {
    margin-top: -50px;
}
/* line-height */
.lh-200 {
    line-height: 12.5rem;
}
/* bottom */
.bottom-auto {
    bottom: auto;
}
/* footer */
footer .footer-logo img {
    max-height: 35px;
}
footer ul li {
    margin-bottom: 0;
}
.footer-light a:hover, .footer-navbar li a:hover {
    color: var(--dark-gray);
}
@media (max-width: 1299px) {
    .navbar .navbar-nav .nav-link {
        font-size: 16px;
    }
    header .btn.btn-rounded.btn-large {
        padding: 10px 15px;
        font-size: 12px; 
    }
}
@media (max-width: 1199px) {
    .navbar .navbar-nav .nav-link {
        font-size: 15px;
    }
    header .btn.btn-rounded.btn-large {
        padding: 10px 10px;
        font-size: 11px; 
    }
}
@media (max-width: 991px) {
    .navbar .navbar-nav .dropdown.dropdown-with-icon-style02 .dropdown-menu {
        width: calc(100% + 30px) !important;
        margin-left: -15px;
        padding: 10px 45px;
        margin-bottom: 0;
        margin-right: -15px;
    }
    .navbar .navbar-nav .dropdown.dropdown-with-icon-style02 .dropdown-menu li:last-child a {
        padding-bottom: 17px;
    }
    [data-mobile-nav-style=full-screen-menu] .navbar-full-screen-menu-inner .navbar-nav .dropdown.dropdown-with-icon-style02 .dropdown-menu li a i {
        font-size: 19px;
    }
    header .btn.btn-rounded.btn-large {
        color: var(--dark-gray);
        border-color: var(--extra-medium-gray);
        padding: 10px 15px;
        font-size: 13px;
    }
}
@media (max-width: 767px) {
    .portfolio-filter li {
        padding: 0;
    }
}

/* Estilo base */
.floating-access{
  position: fixed; /* já tem no seu CSS */
  overflow: hidden;                 /* p/ o brilho ::after */
  background: transparent !important;
  /* degradê vertical com transparência */
  background-image:
    linear-gradient(
      180deg,
      rgba(var(--ar-r),var(--ar-g),var(--ar-b), .95) 0%,
      rgba(var(--ar-r),var(--ar-g),var(--ar-b), .88) 55%,
      rgba(var(--ar-r),var(--ar-g),var(--ar-b), .82) 100%
    ) !important;
  color: #fff !important;
  border: 1px solid rgba(245,8,36,.40);
  box-shadow: 0 10px 24px rgba(245,8,36,.25);
}

/* brilho suave no canto – opcional */
.floating-access::after{
  content:"";
  position:absolute; inset:0;
  background:
    linear-gradient(90deg, rgba(255,255,255,.20) 0%, rgba(255,255,255,0) 40%),
    radial-gradient(120% 60% at 120% 0%, rgba(255,255,255,.10) 0%, rgba(255,255,255,0) 60%);
  pointer-events:none;
}

/* hover um pouco mais sólido */
.floating-access:hover{
  background-image:
    linear-gradient(
      180deg,
      rgba(var(--ar-r),var(--ar-g),var(--ar-b), 1) 0%,
      rgba(var(--ar-r),var(--ar-g),var(--ar-b), .94) 60%,
      rgba(var(--ar-r),var(--ar-g),var(--ar-b), .90) 100%
    ) !important;
}

/* mobile mantém o degradê */
@media (max-width: 991.98px){
  .floating-access{
    background-image:
      linear-gradient(
        180deg,
        rgba(var(--ar-r),var(--ar-g),var(--ar-b), .96) 0%,
        rgba(var(--ar-r),var(--ar-g),var(--ar-b), .88) 100%
      ) !important;
  }
}

/* hover: sombra mais forte e leve “empurrão” para dentro */
#btn-area-restrita:hover{
  box-shadow:
    0 16px 32px rgba(245,8,36,.45),
    0 10px 24px rgba(0,0,0,.30),
    inset 0 1px 0 rgba(255,255,255,.35);
  transform: translateY(-50%) translateX(-2px);
}
/* mobile: mantém o empurrão apenas no eixo X */
@media (max-width: 991.98px){
  #btn-area-restrita:hover{ transform: translateX(-2px); }
}

/* Modal acima de tudo (inclui backdrop) */
.modal-backdrop { z-index: 2199 !important; }
.modal           { z-index: 2200 !important; }

/* Quando a modal abrir, esconda/disable o botão flutuante */
.modal-open #btn-area-restrita {
  display: none !important;         /* some totalmente */
  /* ou, se preferir ver o botão apagado:
  opacity: 0 !important; pointer-events: none !important;
  */
}

/* Animação: “subir” ao abrir */
.modal.slide-up .modal-dialog {
  transform: translateY(28px);
  transition: transform .22s ease-out;
}
.modal.slide-up.show .modal-dialog {
  transform: translateY(0);
}

/* Abas responsivas dentro da modal Área Restrita */
#areaRestritaModal .nav-tabs,
#areaRestritaModal .nav-pills{
  border: 0 !important;
  display: flex !important;
  flex-wrap: nowrap !important;
  gap: .5rem !important;
}

#areaRestritaModal .nav-item{
  flex: 1 1 0% !important;
}

#areaRestritaModal .nav-link{
  width: 100% !important;
  text-align: center !important;
  border: 1px solid rgba(0,0,0,.12) !important;
  background: #f8f9fa !important;
  color: #222 !important;
  border-radius: .6rem !important;
  padding: .6rem .75rem !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.5);
}

#areaRestritaModal .nav-link.active{
  background: #f50824 !important;
  color: #fff !important;
  border-color: #f50824 !important;
  box-shadow: 0 6px 16px rgba(245,8,36,.35);
}

/* Mobile: garante 2 botões lado a lado, sem quebrar linha */
@media (max-width: 575.98px){
  #areaRestritaModal .nav-pills,
  #areaRestritaModal .nav-tabs{
    gap: .5rem !important;
  }
  #areaRestritaModal .nav-link{ padding: .55rem .5rem !important; }
}

/* Tira o centro vertical e ancora no topo */
#areaRestritaModal .modal-dialog-centered{
  align-items: flex-start !important;
  min-height: calc(100% - var(--bs-modal-margin) * 2) !important;
}

/* Aplica o offset (sobe) */
@media (max-width: 991.98px){
  #areaRestritaModal .modal-content{
    margin-top: var(--modal-offset-mobile) !important;
  }
}
@media (min-width: 992px){
  #areaRestritaModal .modal-content{
    margin-top: var(--modal-offset-desktop) !important;
  }
}
@media (max-width: 575.98px){
  #areaRestritaModal .modal-content{ margin-top: 8vh !important; }
}

/* desktop: vertical, lado direito, meio da tela */
.floating-access{
  top: 42%;
  right: 0;
  transform: translateY(-50%);
  writing-mode: vertical-rl;
  text-orientation: mixed;
  z-index: 2001;
}

/* empurra para fora da área do container (se usar container-xxl=1320px) */
:root{ --container-max: 1320px; }
@media (min-width: 992px){
  .floating-access{
    right: max(0px, (100vw - var(--container-max)) / 2 - 6px);
  }
}

/* mobile: pílula no canto inferior direito, acima do scroll */
@media (max-width: 991.98px){
  .floating-access{
    top: auto;
    bottom: 120px;   /* ajuste se tiver WhatsApp flutuante */
    right: 12px;
    transform: none;
    writing-mode: horizontal-tb;
    border-radius: 9999px;
    padding: 10px 16px;
  }
}


/*logo*/

/* + espaço acima do logo quando o header fica scrolled (desktop) */
.navbar.scrolled .navbar-brand { padding-top: 18px !important; }
.navbar.scrolled .navbar-brand .logo-scroll { margin-top: 6px !important; display:block; }

/* + espaço no desktop mesmo sem scroll (se quiser) */
@media (min-width: 992px){
  .navbar .navbar-brand { padding-top: 14px !important; }
  .navbar .navbar-brand .logo-scroll { margin-top: 10px !important; }
}

/* + espaço no mobile (override do seu CSS que zera padding/margin) */
@media (max-width: 576px){
  .navbar { padding-top: 8px !important; }
  .navbar-brand { padding-top: 20px !important; margin-top: 6px !important; }
  .navbar-brand .logo-scroll { margin-top: 20px !important; }
}

/* ==== Thumbs harmonizadas nos cards de notícias ==== */
/* caixa da imagem com proporção fixa */
.grid-item .card .blog-image{
  position: relative !important;
  aspect-ratio: 4 / 3;          /* escolha: 16/9, 4/3, 1/1... */
  overflow: hidden !important;
}

/* a imagem preenche toda a caixa, sem distorcer */
.grid-item .card .blog-image img{
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;     /* corta o excesso */
  object-position: center !important;
  display: block !important;
}

/* o badge “FADESP” fica preso dentro da imagem */
.grid-item .card .blog-categories{
  position: absolute !important;
  top: 10px; right: 10px;
  z-index: 2;
}

/* 1) Zera padding do CARD quando tiver o bloco de parceiros no topo */
.card > .parceiros{
  margin-top: 0 !important;              /* remove margem acidental */
}

/* Se o tema aplica padding no .card, zera só no topo */
.card:has(> .parceiros){
  padding-top: 0 !important;             /* Safari/Firefox antigos ignoram :has */
}

/* Fallback quando :has não pegar: "come" o padding do card nas laterais/topo */
.card > .parceiros{
  margin-left: 0px !important;         /* ajuste para o valor real do padding do card */
  margin-right: 0px !important;
  margin-top: -30px !important;
}
@media (max-width: 991px){
  .card > .parceiros{ margin-left:-16px; margin-right:-16px; margin-top:-16px; }
}

/* 2) Garante que o bloco não tenha padding no topo */
.parceiros{
  padding-top: 0 !important;
  margin-top: 0 !important;
  align-items: flex-start;                /* gruda a imagem no topo do bloco */
}

/* 3) Se houver utilitários de espaçamento do tema antes do card, neutraliza */
.grid .grid-item > .card{ margin-top: 0 !important; }

@media (max-width: 575.98px){
  /* Grid em fluxo normal (desliga Masonry no mobile) */
  ul.grid{ display:block !important; height:auto !important; margin-top:0 !important; padding:0 12px !important; }
  ul.grid > li.grid-item{
    position:static !important; left:auto !important; top:auto !important; transform:none !important;
    width:100% !important; margin:0 !important; padding:12px 0 !important;
  }
  ul.grid > li.grid-sizer,
  ul.grid > li.gutter-sizer{ display:none !important; width:0 !important; height:0 !important; padding:0 !important; margin:0 !important; }

  /* Card não reintroduz espaço */
  .grid .grid-item .card{ padding-top:0 !important; margin-top:0 !important; overflow:hidden; }

  /* Banner do parceiro padronizado e colado no topo */
  .grid .grid-item .card > .parceiros{
    height: clamp(140px, 45vw, 200px); /* responsivo: 140–200px */
    padding:0 !important; margin:0 !important;
    display:flex; align-items:flex-start; justify-content:center; background:#fff;
  }
  .parceiros > a{ display:flex; width:100%; height:100%; align-items:flex-start; justify-content:center; }
  .parceiros img{
    max-width:100%; max-height:100%; width:auto; height:auto;
    object-fit:contain; object-position:top center; display:block; margin:0;
  } 
/* Alvo: listas de conteúdo gerais, evitando menus/nav/breadcrumb/paginação */
body ul:not([class*="nav"]):not([class*="menu"]):not(.navbar-nav):not(.dropdown-menu)
       :not(.breadcrumb):not(.pagination):not(.list-unstyled),
body ol:not([class*="nav"]):not([class*="menu"]):not(.navbar-nav):not(.dropdown-menu)
       :not(.breadcrumb):not(.pagination):not(.list-unstyled) {
  /* zera os bullets nativos e criaremos os nossos */
  list-style: none !important;
  margin: 1rem 0;
  padding-left: 0; /* vamos controlar o recuo no li */
}

/* Itens da lista */
body ul:not([class*="nav"]):not([class*="menu"]):not(.navbar-nav):not(.dropdown-menu)
       :not(.breadcrumb):not(.pagination):not(.list-unstyled) > li,
body ol:not([class*="nav"]):not([class*="menu"]):not(.navbar-nav):not(.dropdown-menu)
       :not(.breadcrumb):not(.pagination):not(.list-unstyled) > li {
  position: relative;
  display: list-item;           /* garante semântica */
  margin: .45rem 0;
  padding-left: 1.25rem;        /* espaço para o marcador */
  line-height: 1.6;
}

/* Marcador custom (bolinha) para UL */
body ul:not([class*="nav"]):not([class*="menu"]):not(.navbar-nav):not(.dropdown-menu)
       :not(.breadcrumb):not(.pagination):not(.list-unstyled) > li::before {
  content: "";
  position: absolute;
  left: 0;
  top: .72em;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--brand-accent);
}

/* OL numerada elegante (se houver) */
body ol:not([class*="nav"]):not([class*="menu"]):not(.navbar-nav):not(.dropdown-menu)
       :not(.breadcrumb):not(.pagination):not(.list-unstyled) {
  counter-reset: item;
}
body ol:not([class*="nav"]):not([class*="menu"]):not(.navbar-nav):not(.dropdown-menu)
       :not(.breadcrumb):not(.pagination):not(.list-unstyled) > li::before {
  counter-increment: item;
  content: counter(item) ".";
  position: absolute;
  left: 0;
  top: 0;
  transform: translateY(.1em);
  font-weight: 700;
  color: var(--brand-accent);
}

/* Listas aninhadas: recuo e marcador menor */
body ul ul > li, body ol ol > li { padding-left: 1.1rem; }
body ul ul > li::before {
  width: 6px; height: 6px; top: .76em; opacity: .9;
}

/* Dark mode opcional */
@media (prefers-color-scheme: dark) {
  :root { --brand-accent: #7d95ff; }
}

:root{
  --search-border: #e5e7eb;
  --search-bg: #fff;
  --search-text: #1f2937;
  --search-accent: #2946f3;
}

.search-form{
  position: relative;
  display: flex;
  align-items: center;
  width: 100%;
  margin: 0 0 1.25rem 0; /* igual ao mb-44 do seu layout */
}

.search-form input{
  flex: 1;
  height: 44px;
  border: 1px solid var(--search-border);
  border-radius: 10px;
  background: var(--search-bg);
  color: var(--search-text);
  font-size: 15px;
  padding: 0 46px 0 14px; /* espaço pro botão */
  outline: none;
}

.search-form input::placeholder{ color:#9aa3af; }

.search-form input:focus{
  border-color: var(--search-accent);
  box-shadow: 0 0 0 3px rgba(41,70,243,.15);
}

.search-form .btn-search{
  position: absolute;
  right: 6px;
  width: 36px;
  height: 36px;
  border: 0;
  padding: 0;
  border-radius: 8px;
  background: transparent;
  display: grid;
  place-items: center;
  cursor: pointer;
  color: #6b7280;
}

.search-form .btn-search:hover{ color: var(--search-accent); }

/* acessibilidade: classe utilitária para label invisível */
.sr-only{
  position:absolute!important;
  width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;
  clip:rect(0,0,0,0);white-space:nowrap;border:0;
}

/* Dark mode opcional */
@media (prefers-color-scheme: dark){
  :root{
    --search-border:#2a2f3a;
    --search-bg:#0f1116;
    --search-text:#e6e8ee;
  }
}


