@charset "UTF-8";
/* ============================================================
   Proyecto Laguna Merín - CSS Master (substitui o original)
   Paleta: azul-profundo, azul-médio, turquesa, verde-água
   Mantém todos os seletores, responsividades e overrides originais
   ============================================================ */
/* ---------------------------
   Variáveis de cor
   --------------------------- */
:root {
  --azul-profundo: #1779ba;
  --azul-medio: #1779ba;
  /* mantive referência */
  --turquesa: #76D1DF;
  --verde-agua: #2EB4A7;
  --amarelo-alert: #ffef00;
  --cinza-claro: #92b5cd;
  --cinza: #ddd;
  --texto: #333;
  --branco: #fff; }

/* ---------------------------
   Base / reset mínimo
   --------------------------- */
html {
  height: 100.1%; }

body, html {
  margin: 0;
  padding: 0;
  font-family: Arial, sans-serif;
  font-size: 90%;
  color: var(--texto);
  background: #fff;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale; }

.hidden {
  display: none !important; }

/* Imagem de logo (arquivo enviado pelo usuário) */
.img_logos {
  width: 100%;
  max-width: 100%;
  display: block;
  background-image: url("/mnt/data/9946c4c6-f9f3-4266-9caf-074ca4e13f3c.jpg");
  background-repeat: no-repeat;
  background-position: center left;
  background-size: contain; }

/* centralização geral de textos de slides */
.rky-slide-text {
  text-align: center !important; }

.rky-slide-text span {
  display: block;
  text-align: center; }

/* ---------------------------
   Header 1 e Header 2
   --------------------------- */
.header1 {
  background-color: var(--azul-medio);
  color: var(--branco);
  font-size: 80%;
  text-transform: uppercase;
  padding: 3px 10px;
  height: 28px;
  line-height: 22px;
  box-sizing: border-box; }

.header1 .tagline a {
  color: #fff;
  font-size: 110%; }

.header1 .links {
  text-align: right;
  color: #8096CB;
  font-weight: 900; }

.header1 .links a {
  color: #8096CB;
  margin: 0 5px; }

.header1 .links a:hover {
  color: #fff; }

.header2 {
  padding-top: 10px;
  background-color: #fff;
  overflow: hidden; }

.header2 .logo {
  border: 1px solid var(--cinza);
  padding: 0 10px;
  display: inline-block;
  vertical-align: middle;
  background: var(--cinza-claro);
  border-radius: 6px; }

/* opção: logo como imagem direta */
.header2 .logo img {
  max-height: 64px;
  display: block; }

/* ---------------------------
   RKY / content wrappers
   --------------------------- */
.rky-body {
  position: relative; }

.rky-content-top-toolbar {
  float: none;
  padding: 0;
  margin: 0; }

/* ---------------------------
   Tabs e navegação horizontal
   --------------------------- */
.rky-tabs {
  background-color: var(--cinza-claro);
  padding: 15px 0 0 0;
  color: var(--texto);
  margin-bottom: 30px;
  border-bottom: 1px solid rgba(0, 0, 0, 0.05); }

.rky-tabs ul li {
  display: inline; }

.rky-tabs .item a {
  padding: 15px 15px 2px 5px;
  font-size: 100%;
  color: var(--azul-medio);
  font-weight: 500;
  text-decoration: none; }

.rky-tabs .item.active a {
  color: var(--texto);
  font-weight: 700;
  text-decoration: underline; }

/* ---------------------------
   Breadcrumbs
   --------------------------- */
.crumbs-bar {
  background-color: var(--cinza-claro);
  font-size: 14px;
  padding: 15px 0;
  height: 55px !important;
  color: var(--texto);
  margin-bottom: 30px; }

.crumbs-bar a {
  color: var(--texto);
  text-decoration: none; }

.crumbs-bar i {
  display: inline-block;
  font-size: 80%;
  padding-left: 10px;
  padding-right: 5px; }

/* ---------------------------
   News list / article list
   --------------------------- */
.rky-news-list .item {
  margin-bottom: 20px; }

.rky-news-list .item .date {
  font-size: 90%;
  color: gray;
  font-style: italic; }

/* ---------------------------
   Filters
   --------------------------- */
.filter {
  background-color: var(--branco);
  border: 1px solid var(--cinza);
  border-radius: 6px; }

.filter h3 {
  background-color: var(--azul-medio);
  color: var(--branco);
  padding: 10px 15px;
  font-size: 130%;
  font-weight: bold;
  margin: 0;
  border-radius: 6px 6px 0 0; }

.filter .inner {
  padding: 10px; }

/* yellow filter row in main table */
.filterHead td {
  background-color: var(--amarelo-alert) !important; }

.filterHead td span {
  margin-left: 10px; }

.filterHead td .close {
  float: right;
  margin-left: 10px; }

/* ---------------------------
   Data-box / tables
   --------------------------- */
.data-box {
  background-color: var(--branco);
  border: 1px solid var(--cinza);
  border-radius: 6px;
  overflow: hidden; }

.data-box th {
  background-color: var(--azul-medio);
  color: var(--branco);
  padding: 10px 15px;
  font-size: 130%;
  font-weight: bold;
  text-align: left; }

.data-box tr:nth-child(odd) {
  background-color: #fff; }

.data-box tr:nth-child(even) {
  background-color: #fafafa; }

.data-box .item {
  margin-bottom: 5px; }

.data-box .item a {
  display: block;
  text-decoration: none;
  color: var(--texto); }

.data-box .item i {
  font-size: 80%;
  color: rgba(0, 0, 0, 0.6); }

/* ---------------------------
   Nav lateral / lists
   --------------------------- */
.nav .item a {
  display: block;
  padding: 8px;
  color: var(--texto);
  text-decoration: none; }

.nav .item a:before {
  font-family: FontAwesome;
  font-size: 10px;
  content: "\f054";
  color: inherit;
  padding-right: 5px; }

.nav .item.active a {
  background-color: #8096CB;
  color: #fff;
  border-radius: 4px; }

.nav .item a:hover {
  background-color: #bac3da;
  color: #fff; }

/* ---------------------------
   Subnav
   --------------------------- */
.subnav {
  background-color: var(--turquesa);
  padding: 4px; }

.subnav a {
  display: inline-block;
  padding: 2px 8px;
  color: #fff;
  background-color: var(--turquesa);
  border-radius: 4px;
  text-decoration: none; }

.subnav a.active {
  color: #fff;
  background-color: var(--verde-agua); }

/* ---------------------------
   Page/Article styles
   --------------------------- */
#main .item {
  margin-bottom: 30px;
  clear: both;
  min-height: 100px; }

#main .item .thumb {
  float: left;
  margin-right: 20px;
  max-height: 120px;
  overflow: hidden;
  margin-top: 5px;
  border: 1px solid #ccc;
  border-radius: 4px; }

#main .item .title {
  font-weight: 900; }

/* article detail */
#main .rky-article-detail .thumb {
  float: right;
  margin-left: 20px;
  margin-bottom: 20px; }

.rky-article-detail img {
  background-color: #fff; }

/* news list thumbs */
.news-list .thumb {
  float: left;
  margin-right: 20px; }

.news-list .item {
  margin-bottom: 30px; }

.news-list .item .rky-bg-thumb {
  display: inline-block;
  background-repeat: no-repeat;
  width: 140px;
  height: 96px;
  float: left;
  background-size: cover;
  margin-right: 20px;
  margin-top: 5px; }

/* news detail */
.news-detail .rky-blurb {
  font-weight: bold; }

.news-detail .rky-thumb {
  float: right;
  margin-left: 20px; }

/* photo-list */
.photo-list .item {
  border: 1px solid #ccc;
  text-align: center;
  padding: 5px;
  border-radius: 4px; }

.photo-list .item img {
  margin-left: auto;
  margin-right: auto;
  width: 100%;
  display: block;
  border: 1px solid #666; }

/* ---------------------------
   Off-canvas / foundation overrides
   --------------------------- */
.off-canvas {
  height: 100%;
  background-color: var(--azul-medio);
  color: #fff; }

.off-canvas label {
  background-color: #13255a;
  color: #fff;
  padding: 2px 15px;
  border-top: 1px solid #1d2227;
  border-bottom: 1px solid #2671ce;
  display: block; }

.off-canvas .menu a {
  color: #ddd;
  border-bottom: 1px solid #093b79;
  padding: 10px;
  display: block;
  text-decoration: none; }

.off-canvas .menu .active a {
  background-color: #a0b0d8;
  color: #fff; }

/* Foundation / Title bar / top bar overrides kept and adapted */
#widemenu {
  margin-bottom: 15px; }

#widemenu .title-bar {
  background: #fff;
  padding: 0.9rem;
  border-radius: 4px; }

.top-bar {
  background: #fff;
  padding: 0;
  box-shadow: none; }

.top-bar ul {
  background: #fff;
  padding: 5px;
  margin: 0;
  list-style: none; }

.top-bar ul li {
  display: inline-block; }

.title-bar {
  background-color: var(--azul-medio); }

.title-bar a {
  color: #fff;
  text-decoration: none; }

.top-bar .menu a {
  display: inline-block;
  border: 1px solid var(--cinza);
  padding: 3px 10px;
  margin: 0 13px;
  font-weight: 900;
  font-size: 14.54px;
  border-radius: 6px;
  color: var(--azul-profundo) !important; }

.top-bar .menu .active a {
  background-color: var(--azul-medio);
  color: #fff !important; }

.top-bar .menu a:hover {
  background-color: var(--cinza-claro);
  color: var(--azul-profundo) !important; }

.menu-text {
  color: #fff; }

/* ---------------------------
   Footer
   --------------------------- */
footer {
  padding: 30px 10px;
  position: relative;
  text-align: center;
  background: linear-gradient(180deg, var(--azul-medio), var(--azul-profundo));
  color: #fff;
  width: 100%; }

footer .promos {
  padding: 20px;
  margin-top: -83px; }

footer .promos a {
  display: inline-block;
  margin: 0 10px; }

footer .logos {
  margin-top: 10px;
  margin-bottom: 20px; }

footer .text {
  font-size: 90%;
  color: rgba(255, 255, 255, 0.95); }

/* footer lists */
.footer {
  opacity: 1;
  background-color: #234C98;
  color: #fff;
  padding: 30px 10px;
  width: 100%; }

.footer ul {
  margin: 10px 0;
  list-style: none;
  font-size: 120%;
  font-weight: 400;
  padding: 0; }

.footer ul li {
  border-bottom: 1px solid #8096CB;
  padding: 5px; }

.footer a {
  color: #fff;
  text-decoration: none; }

.footer ul li:before {
  font-family: FontAwesome;
  font-size: 10px;
  content: "\f054";
  color: #fff;
  padding-right: 5px; }

.footer .back-to-top button {
  background-color: #8A9CCF;
  float: right;
  color: #fff;
  border: none;
  padding: 6px 10px;
  border-radius: 4px; }

/* ---------------------------
   Utilitários / botões
   --------------------------- */
.button, button {
  background-color: var(--cinza-claro);
  color: #fff;
  padding: 8px 16px;
  border-radius: 4px;
  border: none;
  cursor: pointer;
  font-weight: 700; }

.button.active {
  color: #fff !important;
  font-weight: bold;
  border-bottom: 3px solid #fff; }

.button:hover, button:hover {
  opacity: 0.95;
  transform: translateY(-1px);
  transition: all .18s ease; }

/* ---------------------------
   small layout helpers
   --------------------------- */
.rky-body .container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 15px;
  box-sizing: border-box; }

.clearfix::after {
  content: "";
  display: block;
  clear: both; }

/* ---------------------------
   Breakpoints / Responsividade
   replicando os breakpoints originais
   --------------------------- */
/* small screens only */
@media only screen and (max-width: 40em) {
  h1 {
    font-size: 160%; }
  h2 {
    font-size: 140%; }
  h3 {
    font-size: 130%; }
  .rky-tabs {
    padding: 10px 0; }
  .rky-tabs a {
    font-size: 100%; }
  .top-bar .menu a {
    display: block;
    margin: 6px 0; }
  .title-bar {
    display: block; }
  .header1 {
    height: auto;
    line-height: normal;
    padding: 8px 10px; }
  .img_logos {
    width: 100% !important;
    background-size: contain;
    background-position: center; } }

/* Medium only */
@media screen and (min-width: 40em) and (max-width: 63.9375em) {
  .rky-tabs a {
    font-size: 90%; }
  .top-bar .menu a {
    font-size: 14px;
    margin-right: 8px; }
  .img_logos {
    width: 90% !important; } }

/* <= 1060px */
@media only screen and (max-width: 1060px) {
  .top-bar-right {
    display: none; }
  .top-bar .menu a {
    font-size: 100%;
    margin-right: 5px;
    padding: 7px 10px; }
  .header2 {
    padding-top: 12px; } }

/* medium and up */
@media only screen and (min-width: 40em) {
  .menu {
    margin-top: 20px; }
  .menu a {
    color: var(--azul-medio) !important; }
  .title-bar {
    display: none; }
  .page-main-content {
    margin-top: 0; }
  .header1 {
    background-color: var(--azul-medio);
    color: var(--branco);
    font-size: 80%;
    text-transform: uppercase;
    padding: 3px;
    opacity: 1;
    z-index: 1000;
    height: 38px;
    line-height: 32px; }
  .header1 .tagline a {
    font-size: 110%;
    color: #fff; }
  .header1 .links {
    text-align: right;
    color: #8096CB;
    font-weight: 900; }
  .header1 .links a {
    color: #8096CB;
    margin: 0 5px; }
  .header1 .links a:hover {
    color: #fff; }
  .header2 {
    background-color: #fff;
    top: 28px;
    z-index: 999;
    padding-top: 12px;
    overflow: hidden; }
  .header1 .search {
    margin-top: 2px;
    border: 0; }
  .header1 .search input {
    height: 28px;
    background-image: url("/_cms/img/search.png");
    background-repeat: no-repeat;
    background-position: 3px;
    padding-left: 25px; }
  .img_logos {
    width: 85% !important;
    background-size: contain; } }

/* ---------------------------
   Misc specific original selectors kept
   --------------------------- */
.rky-news-list .item .date {
  color: gray;
  font-style: italic; }

.rky-article-detail img {
  max-width: 100%;
  height: auto;
  display: block; }

/* off-canvas wrapper (keeps original min-height behaviour) */
.off-canvas-wrapper {
  min-height: 60vh;
  padding-bottom: 100px; }

/* footer hidden state in original and override */
.footer {
  opacity: 1;
  background-color: #234C98;
  color: #fff;
  padding: 30px 10px;
  width: 100%; }

/* tabs general */
.tabs a {
  padding: 12px 12px; }

/* small improvements for thumbs and images */
#main .item .thumb img,
.news-list .rky-bg-thumb,
.photo-list img {
  max-width: 100%;
  display: block;
  height: auto; }

/* ensure icons from fontawesome keep size / spacing */
.nav .item a:before,
.footer ul li:before {
  font-family: FontAwesome;
  font-size: 10px; }

/* ensure consistent spacing for lists */
.news-list .item,
.photo-list .item,
.rky-news-list .item {
  margin-bottom: 20px; }

/* keep legacy classes in place to avoid regressões */
.filterHead td .close,
.data-box .item i,
.rky-slide-text span {
  /* no-op but kept for compatibility */ }

/* End of CSS master */
.tab-container {
  overflow-x: auto;
  /* rolagem horizontal */
  overflow-y: hidden;
  /* evita barra vertical */
  white-space: nowrap;
  /* impede quebra das tabs */
  height: 40px; }
