@import url('../variables.css');

/* =========================
   RESET
========================= */

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
}

body {

    font-family: 'Roboto', sans-serif;
    font-size: var(--fuente-size);

    background: var(--gris-claro);

    color: var(--texto);

    overflow-x: hidden;

    transition: .3s;
}

/* =========================
   MAIN
========================= */

main {

    width: min(100%, 1200px);

    margin: 0 auto;

    padding: 30px;
}

main .container {

    width: 100%;
    max-width: 100%;

    padding-left: 0;
    padding-right: 0;
}

main .row {

    --bs-gutter-x: 1.5rem;

    margin-left: 0 !important;
    margin-right: 0 !important;
}

main section {

    width: 100%;
}

main img {

    max-width: 100%;
    height: auto;

    display: block;
}

/* =========================
   TITULOS
========================= */

h1,
h2,
h3,
.cesac-title,
.titulo-institucional {

    font-family: 'Cabin', sans-serif;

    color: var(--guinda);
}

/* =========================
   SOMBRAS
========================= */

.shadow-institucional {

    box-shadow:
        0 10px 30px rgba(0, 0, 0, .08);
}

/* =========================
   TRÁMITES
========================= */

.tramites-info {

    background: var(--gris-claro);

    border-left:
        6px solid var(--guinda);

    padding: 25px;

    margin: 20px 0;

    border-radius: 8px;

    box-shadow:
        0 4px 15px rgba(0, 0, 0, .05);
}

.tramites-info h2 {

    font-size: 1.4rem;

    margin-bottom: 15px;
}

.tramite-item {

    margin-bottom: 20px;

    line-height: 1.6;
}

.tramite-item a {

    color: var(--guinda);

    text-decoration: underline;

    transition: .3s;
}

.tramite-item a:hover {

    color: var(--dorado);

    text-decoration: none;
}

/* =========================
   MODULO
========================= */

.barra-institucional {

    height: 6px;

    background: var(--guinda);

    border-radius:
        4px 4px 0 0;
}

.linea-dorada {

    width: 50px;
    height: 3px;

    background: var(--dorado);

    margin: 15px 0;
}

/* =========================
   BOTONES
========================= */

.btn-institucional {

    background: var(--guinda);

    color: var(--blanco);

    border-radius: 30px;

    padding: 12px 30px;

    display: inline-block;

    text-decoration: none;

    font-weight: 500;

    transition: .3s;
}

.btn-institucional:hover {

    background: var(--guinda);

    color: var(--blanco);

    transform: translateY(-3px);
}

/* =========================
   PERSONAJE
========================= */

.character-card {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.character-img {

  width: 180px;
  height: 180px;
  border-radius: 50%;
  object-fit: cover;
  border: 5px solid var(--guinda);
  background: #fff;
  transition: .3s;

}

.character-card:hover .character-img {
  transform: scale(1.05);
}

.speech-bubble {

  position: absolute;
  bottom: 115%;
  left: 50%;
  transform: translateX(-50%);
  width: 220px;
  padding: 15px;
  background: var(--negro);
  color: #fff;
  border-radius: 15px;
  display: none;
  z-index: 100;

}

.speech-bubble.active {

  display: block;

}

.speech-bubble::after {

  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: -10px;
  border: 10px solid transparent;
  border-top-color: var(--negro);

}

.avatar-play-btn{
    margin-top: 15px;
    padding: 12px 24px;
    background: #7A003C;
    color: #fff;
    border: 2px solid #7A003C;
    border-radius: 50px;
    font-weight: 700;
    letter-spacing: .3px;
    transition: all .3s ease;
}

.avatar-play-btn:hover{
    background: #5E002E;
    border-color: #5E002E;
}

/* =========================
   BURBUJA
========================= */

.speech-bubble {

    position: absolute;

    bottom: 115%;
    left: 50%;

    transform: translateX(-50%);

    width: 220px;

    padding: 15px;

    border-radius: 15px;

    background: var(--negro);

    color: var(--blanco);

    display: none;

    z-index: 2;
}

.speech-bubble.active {

    display: block;
}

.speech-bubble::after {

    content: "";

    position: absolute;

    top: 100%;
    left: 50%;

    margin-left: -10px;

    border: 10px solid transparent;

    border-top-color: var(--negro);
}

/* =========================
   CONTACTO
========================= */

.contacto-card {

    border-radius: 1rem;

    background: var(--blanco);

    transition: .3s;

    cursor: pointer;

    box-shadow:
        0 3px 10px rgba(0, 0, 0, .05);
}

.contacto-card:hover {

    transform: translateY(-5px);

    background:
        rgba(157, 33, 72, .05);

    box-shadow:
        0 10px 25px rgba(0, 0, 0, .15);
}

/* =========================
   ENLACES
========================= */

.enlace-card {

    transition: .3s;
}

.enlace-card:hover {

    transform: scale(1.03);

    box-shadow:
        0 4px 12px rgba(0, 0, 0, .15);
}

/* =========================
   BANNER
========================= */

.denuncia-banner {

    background: var(--guinda);

    color: var(--blanco);

    text-align: center;

    padding: 15px;

    margin: 20px 0;

    border-radius: 8px;

    font-weight: 600;
}

/* =========================
   WHATSAPP
========================= */

.whatsapp-float {

    position: fixed;

    bottom: 25px;
    right: 25px;

    width: 60px;
    height: 60px;

    display: flex;

    align-items: center;
    justify-content: center;

    border-radius: 50%;

    background: var(--verde_whatsapp);

    z-index: 1000;
}

.whatsapp-float i {

    font-size: 2rem;

    color: var(--blanco);
}

/* =========================
   RESPONSIVE
========================= */

@media(max-width:768px) {

    main {

        padding: 20px 15px;

    }

    .character-img {

        width: 140px;
        height: 140px;

    }

    .speech-bubble {

        width: 180px;
        font-size: .8rem;

    }

    .btn-institucional {

        width: 100%;
        margin-bottom: 10px;

    }

    .tramites-info {

        padding: 20px 15px;

    }

    .denuncia-banner {

        font-size: .9rem;

    }

}