/* =========================================================
   IESP - CSS GLOBAL (LEGADO + SEJUS) + TRANSPARÊNCIA
   (LIMPO, SEM DUPLICAÇÕES, SEM QUEBRAR O RESTO)
========================================================= */

/* =========================
   RESET / BASE
========================= */
*{ margin:0; padding:0; box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  font-family:'Segoe UI', sans-serif;
  background:#fff;
  color:#1c1c1c;
  line-height:1.6;
}
img{ max-width:100%; height:auto; display:block; }
a{ color:inherit; }

/* =========================
   CONTAINER GLOBAL
========================= */
.container{
  max-width:1100px;
  margin:0 auto;
  padding:0 20px;
}

/* =========================
   TOPO (LEGADO + SEJUS)
========================= */
.topbar{
  background:#173A5E;
  color:#fff;
  padding:8px 20px;
  font-size:14px;
}

/* legado */
.topbar-content{
  display:flex;
  justify-content:space-between;
  align-items:center;
}

/* SEJUS */
.topbar__wrap{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:14px;
  flex-wrap:wrap;
}
.topbar__left span{ font-weight:600; opacity:.95; }
.topbar__right{
  display:flex;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;
}
.topbar__right a{
  color:#fff;
  text-decoration:none;
  opacity:.95;
  transition:.2s ease;
}
.topbar__right a:hover{
  opacity:1;
  transform:translateY(-1px);
}
.topbar-btn{
  background:#fff;
  color:#173A5E !important;
  border:none;
  padding:6px 12px;
  font-size:12px;
  border-radius:4px;
  cursor:pointer;
  font-weight:800;
  letter-spacing:.3px;
  text-transform:uppercase;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  height:30px;
}
.topbar-btn:hover{ background:#eaf0f8; }

/* legado extras */
.telefone i{ margin-right:5px; }
.webmail-btn{
  background:#fff;
  color:#173A5E;
  border:none;
  padding:4px 12px;
  font-size:14px;
  border-radius:3px;
  cursor:pointer;
}

/* =========================
   HEADER (LEGADO + SEJUS)
========================= */

/* legado */
.header{
  background:#fff;
  padding:15px 30px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  flex-wrap:wrap;
}
.logo img{ height:60px; }

/* legado nav (mantido) */
.nav a{
  color:#1c1c1c;
  text-decoration:none;
  margin-left:20px;
  font-weight:500;
  font-size:15px;
  transition:.3s;
}
.nav a:hover{ color:#23A455; }

/* SEJUS header */
.site-header{
  background:#fff;
  border-bottom:1px solid #eaeaea;
  position:sticky;
  top:0;
  z-index:999;
}
.header__wrap{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:18px;
  padding:14px 0;
  flex-wrap:wrap;
}
.header__logos img{
  height:58px;
  width:auto;
}

/* SEJUS nav list */
.nav__list{
  list-style:none;
  display:flex;
  align-items:center;
  gap:18px;
  flex-wrap:wrap;
}
.nav__link{
  text-decoration:none;
  color:#1c1c1c;
  font-weight:600;
  font-size:15px;
  padding:10px 8px;
  border-radius:6px;
  transition:.2s ease;
  margin-left:0; /* não herdar do legado */
}
.nav__link:hover{
  color:#23A455;
  background:rgba(35,164,85,.08);
}
.nav__link.active{
  color:#173A5E;
  background:rgba(23,58,94,.10);
}

/* burger */
.burger{
  display:none;
  width:44px;
  height:40px;
  border:0;
  background:transparent;
  cursor:pointer;
  border-radius:8px;
}
.burger span{
  display:block;
  height:3px;
  width:26px;
  margin:6px auto;
  background:#173A5E;
  border-radius:2px;
}

/* =========================
   ÍCONES / SEÇÕES LEGADO
========================= */
.icon-banner{
  display:flex;
  justify-content:center;
  align-items:center;
  background:#173A5E;
  padding:20px 0;
  flex-wrap:wrap;
}
.icon-box{
  display:flex;
  flex-direction:column;
  align-items:center;
  color:#fff;
  font-size:14px;
  margin:0 40px;
  text-align:center;
}
.icon-box i{
  font-size:28px;
  margin-bottom:10px;
}
.icon-box.selected{
  background:#23A455;
  padding:15px 25px;
  border-radius:4px;
  color:#fff;
}

/* CARROSSEL */
.carrossel img{
  width:100%;
  height:auto;
  display:block;
}

/* QUEM SOMOS */
.quem-somos{
  padding:60px 20px;
  max-width:1100px;
  margin:auto;
  text-align:left;
}
.quem-somos h4{
  color:#173A5E;
  font-size:14px;
  font-weight:700;
  text-transform:uppercase;
}
.quem-somos h2{
  color:#1c1c1c;
  font-size:28px;
  margin:10px 0;
}
.quem-somos p{
  margin-bottom:20px;
  max-width:600px;
}
.btn{
  background:#23A455;
  color:#fff;
  padding:10px 20px;
  text-decoration:none;
  border-radius:3px;
  font-size:14px;
}

/* MVV */
.mvv{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  padding:60px 20px;
  gap:20px;
}
.mvv .card{
  background:#fff;
  border-radius:10px;
  box-shadow:0 2px 10px rgba(0,0,0,0.1);
  padding:30px;
  flex:1;
  max-width:300px;
  text-align:center;
}
.mvv .card i{
  font-size:32px;
  color:#23A455;
  margin-bottom:10px;
}
.mvv .card ul{
  list-style:none;
  padding:0;
  text-align:center;
  font-size:14px;
  margin-top:10px;
}

/* MÉTRICAS */
.metricas{
  display:flex;
  justify-content:center;
  text-align:center;
  background:#f7f7f7;
  padding:40px 20px;
  flex-wrap:wrap;
}
.metricas .item{ margin:0 30px; }
.metricas h2{
  font-size:40px;
  color:#23A455;
}
.metricas p{ font-weight:bold; }

/* UNIDADES */
.unidades{
  padding:60px 20px;
  max-width:1100px;
  margin:auto;
}
.unidades h2{
  text-align:center;
  color:#1c1c1c;
  font-size:28px;
  margin-bottom:20px;
}
.unidades .tags{
  display:flex;
  justify-content:center;
  flex-wrap:wrap;
  gap:8px;
  margin-bottom:20px;
}
.unidades .tags span{
  background:#23A455;
  color:#fff;
  padding:6px 14px;
  border-radius:2px;
  font-size:14px;
}
.unidades .tags .ativo{ background:#173A5E; }
.unidades .descricao{
  background:#173A5E;
  color:#fff;
  padding:40px;
  border-radius:6px;
}
.unidades h3{
  background:#23A455;
  display:inline-block;
  padding:10px 20px;
  border-radius:20px;
  font-size:15px;
  margin-bottom:20px;
}
.unidades .unidades-box{
  display:flex;
  justify-content:space-between;
  flex-wrap:wrap;
  gap:18px;
}
.unidades-box ul{
  list-style:none;
  font-size:14px;
  padding-left:0;
}
.unidades-box .imagens img{
  width:120px;
  margin-left:10px;
  margin-top:10px;
  border-radius:5px;
}
.unidades-endereco{
  margin-top:20px;
  font-size:14px;
  color:#fff;
}

/* MUNICÍPIOS */
.municipios{
  padding:60px 20px;
  text-align:center;
  max-width:900px;
  margin:auto;
}
.municipios h2{
  font-size:26px;
  color:#1c1c1c;
}
.municipios p{
  font-size:14px;
  margin-top:10px;
}

/* NOTÍCIAS */
.noticias{
  padding:60px 20px;
  max-width:1100px;
  margin:auto;
}
.noticias h2{
  text-align:center;
  font-size:28px;
  margin-bottom:30px;
}
.grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(220px, 1fr));
  gap:20px;
}
.noticia{
  background:#fff;
  box-shadow:0 2px 8px rgba(0,0,0,0.1);
  border-radius:6px;
  overflow:hidden;
}
.noticia img{
  width:100%;
  height:150px;
  object-fit:cover;
}
.noticia p{
  padding:10px;
  font-size:14px;
}

/* =========================
   IMAGENS SCROLL / UNIDADES
========================= */
.imagens-scroll{
  display:flex;
  overflow-x:auto;
  gap:10px;
  padding-top:20px;
}
.imagens-scroll img{
  height:120px;
  border-radius:6px;
  flex:0 0 auto;
  object-fit:cover;
}
.imagens-scroll::-webkit-scrollbar{ height:8px; }
.imagens-scroll::-webkit-scrollbar-thumb{
  background:#23A455;
  border-radius:4px;
}

.unidade-titulo{
  background:#23A455;
  color:#fff;
  display:inline-block;
  padding:10px 20px;
  border-radius:20px;
  font-weight:bold;
  font-size:15px;
  margin-bottom:20px;
}
.unidade-texto{
  max-width:650px;
  margin:auto;
  font-size:14px;
  line-height:1.7;
  color:#fff;
  text-align:center;
}
.unidade-info{
  margin-top:20px;
  font-size:14px;
  text-align:center;
  color:#fff;
}
.unidade-info i{
  margin-right:6px;
  color:#23A455;
}
.unidade-verde{
  color:#23A455;
  font-weight:bold;
  margin-top:10px;
}
.unidade-atividades{
  margin-top:20px;
  font-size:14px;
  text-align:center;
  color:#fff;
}
.unidade-atividades h4{
  font-weight:bold;
  margin-bottom:10px;
}
.unidade-atividades ul{
  list-style:none;
  padding:0;
  margin:0;
}
.unidade-atividades li{ margin-bottom:5px; }

/* Imagens lado a lado fixas */
.imagens-scroll.fixo{
  display:flex;
  justify-content:center;
  margin-top:20px;
  gap:6px;
  overflow-x:auto;
}
.imagens-scroll.fixo img{
  height:80px;
  border-radius:4px;
  object-fit:cover;
}

.unidade-tabs{
  display:flex;
  justify-content:space-between;
  flex-wrap:nowrap;
  background:#23A455;
  color:#fff;
  font-weight:bold;
  font-size:14px;
}
.unidade-tabs span{
  flex:1;
  text-align:center;
  padding:12px 8px;
  cursor:pointer;
  position:relative;
}
.unidade-tabs span.active{ background:#173A5E; }
.unidade-tabs span.active::after{
  content:"";
  position:absolute;
  bottom:-6px;
  left:50%;
  transform:translateX(-50%);
  width:0; height:0;
  border-left:7px solid transparent;
  border-right:7px solid transparent;
  border-top:7px solid #173A5E;
}
.unidade-container{
  background:#173A5E;
  color:#fff;
  padding:40px 20px;
  text-align:center;
}

/* =========================
   FOOTER (LEGADO) + SEJUS
========================= */

/* legado */
.footer{
  background:#153a63;
  color:#fff;
  padding:40px 0;
}
.footer-container{
  max-width:1400px;
  margin:auto;
  display:flex;
  justify-content:space-between;
  gap:40px;
  padding:0 20px;
}
.footer-left{ width:40%; color:#fff; }
.footer-logo{
  width:225px;
  max-width:100%;
  margin-bottom:20px;
}
.footer-left p{
  margin:6px 0;
  font-size:15px;
  color:#fff;
}
.footer-right{ width:50%; }
.footer-right h3{
  font-size:22px;
  margin-bottom:10px;
}
.footer-right p{
  margin-bottom:15px;
  line-height:1.5;
  font-size:15px;
  color:#fff;
}
.footer-right iframe{
  width:100%;
  height:260px;
  border-radius:6px;
  border:0;
}

/* SEJUS footer */
.site-footer{
  background:#153a63;
  color:#fff;
  padding:42px 0 0;
}
.footer__content{
  display:grid;
  grid-template-columns:1fr 1.2fr 1.2fr;
  gap:30px;
  align-items:start;
  padding-bottom:26px;
}
.footer__brand img{ width:240px; max-width:100%; }
.footer__info p{ margin:6px 0; font-size:15px; color:#fff; }
.footer__map iframe{
  width:100%;
  height:190px;
  border:0;
  border-radius:8px;
}
.footer__bottom{
  margin-top:8px;
  padding:14px 20px;
  background:#0f2f52;
  text-align:center;
  font-size:13px;
  opacity:.95;
}

/* =========================
   RESPONSIVO (GLOBAL)
========================= */
@media (max-width:1200px){
  .menu{ gap:20px; }
  .hero-unidades-subtitle{ font-size:40px; }
  .hero-unidades-pill span{ font-size:44px; }
}

@media (max-width:992px){
  .header-content{
    flex-direction:column;
    align-items:flex-start;
    gap:10px;
  }
  .menu{
    justify-content:flex-start;
    row-gap:8px;
  }
  .banner-content{ flex-direction:column; }
  .texto, .imagem{ width:100%; }

  .hero-unidades-content{
    flex-direction:column;
    align-items:flex-start;
    padding-top:50px;
    padding-bottom:50px;
  }
  .hero-unidades-medica{
    justify-content:center;
    width:100%;
  }
  .hero-unidades-medica img{ max-height:320px; }
  .unidades-grid-container{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }

  .footer-container{ flex-direction:column; }
  .footer-left, .footer-right{ width:100%; }

  .footer__content{ grid-template-columns:1fr; }
}

@media (max-width:768px){
  /* legado nav */
  .nav a{
    display:block;
    margin:10px 0;
  }

  .topbar-content{
    flex-direction:column;
    gap:6px;
    align-items:flex-start;
  }

  .metricas .item{ margin:20px; }
  .unidades-box{ flex-direction:column; }

  .unidades-box .imagens{
    display:flex;
    justify-content:center;
    margin-top:20px;
    gap:10px;
  }

  .mvv{ flex-direction:column; align-items:center; }
  .icon-banner{ flex-direction:column; }

  .hero-unidades-subtitle{ font-size:32px; }
  .hero-unidades-pill{ padding:14px 26px; }
  .hero-unidades-pill span{ font-size:34px; }
  .unidade-card{ height:140px; }

  /* SEJUS nav drawer */
  .burger{ display:inline-block; }
  .nav{
    position:fixed;
    top:0;
    right:-100%;
    width:min(360px, 88vw);
    height:100vh;
    background:#fff;
    box-shadow:-12px 0 24px rgba(0,0,0,.12);
    padding:88px 18px 18px;
    transition:right .25s ease;
    z-index:1000;
  }
  .nav.open{ right:0; }

  .nav__list{
    flex-direction:column;
    align-items:stretch;
    gap:10px;
  }
  .nav__link{
    background:#f7f7f7;
    padding:12px 12px;
  }
}

@media (max-width:576px){
  .menu{ gap:14px; font-size:14px; }
  .texto h1{ font-size:32px; }
  .banner{ padding:40px 0; }
  .hero-unidades-content{ padding:40px 20px 50px; }
  .hero-unidades-medica img{ max-height:260px; }
  .unidades-grid-container{ grid-template-columns:1fr; }
  .footer{ padding:30px 0; }
}

/* =========================
   UNDER CONSTRUCTION (GLOBAL)
========================= */
body.em-construcao{
  background:#5c5c5c;
  font-family:'Montserrat', sans-serif;
  margin:0;
  padding:0;
}
.container-construcao{
  display:flex;
  justify-content:center;
  align-items:center;
  min-height:50vh;
  padding:2rem;
}
.construcao-box{
  background:#fff;
  padding:2rem;
  border-radius:8px;
  border:8px solid;
  border-image:repeating-linear-gradient(
    45deg,
    #000,
    #000 10px,
    #ff0 10px,
    #ff0 20px
  ) 8;
  text-align:center;
  max-width:600px;
  box-shadow:0 4px 16px rgba(0,0,0,0.1);
}
.logo-construcao{
  max-width:180px;
  margin-bottom:1rem;
  animation:flutuar 2s ease-in-out infinite alternate;
}
.construcao-box h1{ color:#1d3557; margin-bottom:.5rem; }
.construcao-box p{ color:#333; margin-bottom:1.5rem; }
.loader{
  width:40px;
  height:40px;
  border:4px solid #ccc;
  border-top:4px solid #4CAF50;
  border-radius:50%;
  animation:spin360 1s linear infinite;
  margin:1rem auto;
}
.mensagem{ font-size:.95rem; color:#555; }

@keyframes spin360{ to{ transform:rotate(360deg); } }
@keyframes flutuar{
  0%{ transform:translateY(0); }
  100%{ transform:translateY(-10px); }
}

/* Fade-in animation */
.fade-in{
  animation:fadeIn ease 1.5s;
  -webkit-animation:fadeIn ease 1.5s;
  -moz-animation:fadeIn ease 1.5s;
  -o-animation:fadeIn ease 1.5s;
  -ms-animation:fadeIn ease 1.5s;
}
@keyframes fadeIn{
  0%{ opacity:0; transform:translateY(20px); }
  100%{ opacity:1; transform:translateY(0); }
}

/* Subtabs */
.subtabs{
  margin:1rem 0;
  display:flex;
  gap:10px;
  justify-content:center;
  flex-wrap:wrap;
}
.subtab{
  background:#fff;
  color:#003366;
  border:none;
  padding:10px 20px;
  border-radius:12px;
  font-weight:500;
  cursor:pointer;
  transition:background-color .3s ease;
  box-shadow:0 2px 4px rgba(0,0,0,0.1);
}
.subtab.active{
  background:#28a745;
  color:#fff;
}
#subunidade-tabs{
  display:none;
  gap:.5rem;
  margin:1rem 0;
}

/* =========================
   ACCORDION (GLOBAL)
========================= */
.accordion-container{
  max-width:968px;
  margin:0 auto;
  padding:0 15px;
}
.accordion{
  max-width:968px;
  max-height:62.72px;
  overflow:hidden;
  transition:max-height .3s ease;
  border:1px solid #ccc;
  border-radius:8px;
  margin-bottom:20px;
  background:#f9f9f9;
}
.accordion[open]{
  max-height:none;
  overflow:visible;
}
.accordion summary{
  background:#2e5077;
  color:#fff;
  padding:16px 20px;
  font-size:1.2rem;
  font-weight:bold;
  cursor:pointer;
  position:relative;
  list-style:none;
  user-select:none;
}
.accordion summary::-webkit-details-marker{ display:none; }
.accordion summary::after{
  content:"+";
  position:absolute;
  right:20px;
  font-size:1.5rem;
}
.accordion[open] summary::after{ content:"–"; }
.accordion-content{
  padding:20px;
  background:#fff;
  max-height:400px;
  overflow-y:auto;
  animation:fadeIn .3s ease-in-out;
}

/* =========================================================
   PORTAL DA TRANSPARÊNCIA (INSTITUTO IESP) - FIX FINAL
   (Flip cards / grid legado)
========================================================= */

/* HERO */
.hero-transp{
  position:relative;
  width:100%;
  min-height:320px;
  background:url("assets/img/Banner-1-v3.webp") center/cover no-repeat;
  display:flex;
  align-items:center;
}
.hero-transp__overlay{
  position:absolute;
  inset:0;
  background:rgba(0,0,0,.35);
}
.hero-transp__content{
  position:relative;
  z-index:1;
  padding:40px 0;
  color:#fff;
}

/* INTRO */
.intro-transp{ padding:36px 0 10px; }
.brand-row__wrap{
  display:flex;
  justify-content:center;
  align-items:center;
  padding:18px 0 10px;
}
.brand-row__wrap img{
  max-width:360px;
  width:100%;
  height:auto;
}
.intro-transp h2{
  text-align:center;
  font-size:16px;
  font-weight:600;
  color:#1c1c1c;
  line-height:1.6;
  max-width:980px;
  margin:0 auto 18px;
}

/* GRID */
.grid-flip{
  display:grid;
  gap:18px;
  padding:22px 0 60px;
}
.grid-transp--4cols{
  grid-template-columns:repeat(4, minmax(0, 1fr));
}
.card--wide{ grid-column:span 2; }

/* FLIP */
.flip-card{
  display:block;
  width:100%;
  height:150px;
  text-decoration:none;
  perspective:1000px;
}
.flip-card.card--wide{ height:160px; }

.flip-card-inner{
  width:100%;
  height:100%;
  position:relative;
  transform-style:preserve-3d !important;
  -webkit-transform-style:preserve-3d !important;
  transition:transform .55s ease;
  border-radius:6px;
  overflow:hidden;
  box-shadow:0 10px 18px rgba(0,0,0,.10);
}

@media (hover:hover) and (pointer:fine){
  .flip-card:hover .flip-card-inner{ transform:rotateY(180deg); }
}

.flip-card-front,
.flip-card-back{
  position:absolute;
  inset:0;
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  gap:12px;
  padding:16px;
  backface-visibility:hidden !important;
  -webkit-backface-visibility:hidden !important;
}
.front--green,
.back--green{
  background:#0b5f3a;
  color:#fff;
}
.flip-card-front i{
  font-size:30px;
  color:#fff;
  opacity:.95;
}
.flip-card-front h3{
  text-align:center;
  font-size:14px;
  font-weight:800;
  letter-spacing:.4px;
  text-transform:uppercase;
  line-height:1.15;
  margin:0;
}

/* verso */
.flip-card-back{
  transform:rotateY(180deg) !important;
  text-align:center;
  padding:18px !important;
}
.flip-card-back p{
  margin:0 !important;
  font-size:13px;
  line-height:1.35;
  color:rgba(255,255,255,.92) !important;
  max-width:92% !important;
}

/* botão (acessar) */
.flip-card-back .btn--outline,
.flip-card-back .flip-btn,
.flip-card-back .flip-cta{
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  margin-top:6px !important;
  padding:9px 16px !important;
  border-radius:6px !important;
  border:2px solid rgba(255,255,255,.25) !important;
  background:#0a2f55 !important;
  color:#fff !important;
  font-size:12px !important;
  font-weight:800 !important;
  letter-spacing:.4px !important;
  text-transform:uppercase !important;
  line-height:1 !important;
  min-height:34px !important;
  visibility:visible !important;
  opacity:1 !important;
}

/* Responsivo */
@media (max-width:1100px){
  .grid-transp--4cols{ grid-template-columns:repeat(2, minmax(0, 1fr)); }
  .card--wide{ grid-column:span 2; }
}
@media (max-width:640px){
  .grid-transp--4cols{ grid-template-columns:1fr; }
  .card--wide{ grid-column:span 1; }
  .flip-card{ height:130px; perspective:none; }
  .flip-card-inner{ transform:none !important; }
  .flip-card-back{ display:none !important; }
}

/* =========================================================
   TRANSPARÊNCIA (ISOLADO / NÃO CONFLITA COM O RESTO)
========================================================= */
.transp{ padding:0 0 60px; }

.transp-grid{
  display:grid;
  gap:18px;
  padding:22px 0 10px;
  grid-template-columns:repeat(4, minmax(0, 1fr));
}
.transp-card{
  height:150px;
  border-radius:6px;
  overflow:hidden;
  background:#0b5f3a;
  box-shadow:0 10px 18px rgba(0,0,0,.10);
  cursor:pointer;
  user-select:none;
  position:relative;
}
.transp-card--wide{
  grid-column:span 2;
  height:160px;
}
.transp-inner{ width:100%; height:100%; position:relative; }

.transp-front,
.transp-back{
  position:absolute;
  inset:0;
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  gap:12px;
  padding:18px;
  text-align:center;
  background:transparent;
  transition:opacity .18s ease, visibility .18s ease;
}
.transp-front{ opacity:1; visibility:visible; z-index:1; }
.transp-front i{
  font-size:30px;
  color:#fff;
  opacity:.95;
}
.transp-front h3{
  margin:0;
  color:#fff;
  font-size:14px;
  font-weight:800;
  letter-spacing:.4px;
  text-transform:uppercase;
  line-height:1.15;
}

.transp-back{ opacity:0; visibility:hidden; z-index:2; }
.transp-back p{
  margin:0;
  font-size:13px;
  line-height:1.35;
  color:rgba(255,255,255,.92);
  max-width:92%;
}

.transp-cta{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  margin-top:6px;
  padding:10px 18px;
  border-radius:6px;
  border:2px solid rgba(255,255,255,.35);
  background:#0a2f55;
  color:#fff !important;
  font-size:12px;
  font-weight:900;
  letter-spacing:.4px;
  text-transform:uppercase;
  text-decoration:none;
  min-height:36px;
}

.transp-card.is-flipped .transp-front{ opacity:0; visibility:hidden; }
.transp-card.is-flipped .transp-back{ opacity:1; visibility:visible; }

@media (hover:hover) and (pointer:fine){
  .transp-card:hover .transp-front{ opacity:0; visibility:hidden; }
  .transp-card:hover .transp-back{ opacity:1; visibility:visible; }
  .transp-cta:hover{
    transform:translateY(-1px);
    background:rgba(10,47,85,.85);
    border-color:rgba(255,255,255,.55);
  }
}
@media (max-width:1100px){
  .transp-grid{ grid-template-columns:repeat(2, minmax(0, 1fr)); }
  .transp-card--wide{ grid-column:span 2; }
}
@media (max-width:640px){
  .transp-grid{ grid-template-columns:1fr; }
  .transp-card--wide{ grid-column:span 1; }
  .transp-card{ height:140px; }
}

/* =========================================================
   TRANSPARÊNCIA - SELEÇÃO (VERSÃO PREMIUM)
========================================================= */
body.transp-select-page{
  font-family:'Montserrat','Segoe UI', sans-serif;
}

.transp-select{ padding:44px 0 78px; }

.transp-select__top{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:12px;
  padding:6px 0 22px;
}
.transp-select__logo{
  width:min(360px, 92vw);
  height:auto;
  display:block;
}
.transp-select__hint{
  display:flex;
  align-items:center;
  gap:10px;
  color:#173A5E;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.35px;
  font-size:12px;
}

.transp-select__grid{
  max-width:980px;
  margin:0 auto;
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:14px;
}

/* CARD */
.tcard{
  background:#0b5f3a;
  color:#fff;
  text-decoration:none;
  border-radius:10px;
  padding:16px 18px 14px;
  min-height:96px;
  display:grid;
  grid-template-columns:46px 1fr;
  grid-template-rows:auto auto;
  column-gap:14px;
  row-gap:8px;
  align-items:center;
  box-shadow:0 10px 18px rgba(0,0,0,.12);
  border:1px solid rgba(255,255,255,.10);
  transition:transform .16s ease, box-shadow .22s ease, background .2s ease, border-color .22s ease;
  position:relative;
  overflow:hidden;
}

/* brilho sutil */
.tcard::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(600px 140px at 20% 0%, rgba(255,255,255,.14), transparent 55%),
    radial-gradient(420px 180px at 100% 100%, rgba(0,0,0,.18), transparent 55%);
  pointer-events:none;
  opacity:.9;
}

.tcard__icon{
  width:40px;
  height:40px;
  border-radius:10px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(255,255,255,.14);
  border:1px solid rgba(255,255,255,.14);
  grid-row:1 / span 2;
  position:relative;
  z-index:1;
}
.tcard__icon i{ font-size:16px; opacity:.98; }

.tcard__title{
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.25px;
  font-size:13px;
  line-height:1.15;
  position:relative;
  z-index:1;
}
.tcard__cta{
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.35px;
  font-size:11px;
  opacity:.96;
  display:flex;
  align-items:center;
  gap:8px;
  position:relative;
  z-index:1;
}

/* hover */
@media (hover:hover) and (pointer:fine){
  .tcard:hover{
    transform:translateY(-2px);
    box-shadow:0 16px 26px rgba(0,0,0,.16);
    background:#0a6a41;
    border-color:rgba(255,255,255,.18);
  }
  .tcard:hover .tcard__cta i{
    transform:translateX(2px);
    transition:transform .16s ease;
  }
}

/* note */
.transp-select__note{
  text-align:center;
  margin-top:18px;
  font-size:12px;
  color:#3a3a3a;
  opacity:.95;
}

/* responsivo */
@media (max-width:980px){
  .transp-select__grid{ grid-template-columns:repeat(2, minmax(0, 1fr)); }
}
@media (max-width:600px){
  .transp-select__grid{ grid-template-columns:1fr; }
  .tcard{ padding:16px 16px 14px; }
}

/* =========================================================
   FIX DO SEJUS (NÃO DEIXA VIRAR CARD GIGANTE)
========================================================= */
body.transp-select-page .transp-select__grid > a.tcard{
  grid-column:auto !important;
  grid-column-start:auto !important;
  grid-column-end:auto !important;
  width:auto !important;
  justify-self:stretch !important;
}

/* Centraliza o SEJUS no desktop (3 colunas) */
@media (min-width:981px){
  body.transp-select-page .transp-select__grid > a.tcard[data-projeto="SEJUS"]{
    grid-column:2 / 3 !important;
  }
}

/* Em 2 colunas / 1 coluna, volta ao fluxo normal */
@media (max-width:980px){
  body.transp-select-page .transp-select__grid > a.tcard[data-projeto="SEJUS"]{
    grid-column:auto !important;
  }
}

/* deixa a grade centralizada quando a última linha não completa 3 cards */
.transp-select__grid{
  justify-content: center;
}

/* ===== FIX ULTRA: nenhum card pode span/coluna forçada ===== */
body.transp-select-page .transp-select__grid{
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 14px !important;
  grid-auto-flow: row dense !important; /* preenche buracos */
}

body.transp-select-page .transp-select__grid > a.tcard{
  grid-column: auto !important;         /* mata span/1/-1/2-3 */
  grid-row: auto !important;
  justify-self: stretch !important;
  width: 100% !important;
  min-width: 0 !important;
}

/* responsivo */
@media (max-width: 980px){
  body.transp-select-page .transp-select__grid{
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}
@media (max-width: 600px){
  body.transp-select-page .transp-select__grid{
    grid-template-columns: 1fr !important;
  }
}