@charset "UTF-8";
/*
Theme Name: concursoue
Theme URI: https://opencollective.com/blankslate
Template: blankslate
Author: Web Pedro y Mario
Description: Donate: https://opencollective.com/blankslate. Learn: https://blankslate.me/. BlankSlate is the definitive WordPress boilerplate starter theme. I've carefully constructed the most clean and minimalist theme possible for designers and developers to use as a base to build websites for clients or to build completely custom themes from scratch. Clean, simple, unstyled, semi-minified, unformatted, and valid code, SEO-friendly, jQuery-enabled, no programmer comments, standardized and as white label as possible, and most importantly, the CSS is reset for cross-browser-compatability, with no intrusive visual CSS styles added whatsoever. A perfect skeleton theme. For support and suggestions, go to: https://github.com/webguyio/blankslate/issues. Thank you.
Tags: accessibility-ready, one-column, two-columns, custom-menu, featured-images, microformats, sticky-post, threaded-comments, translation-ready
Version: 2025
License: GNU General Public License v3 or Later
License URI: https://www.gnu.org/licenses/gpl.html
Text Domain: blankslate
*/
@import url(https://fonts.googleapis.com/css?family=Roboto:400,700);
.hero-overlay,
.donde-overlay,
.reto-section .reto-overlay,
.formulario-hero .formulario-hero-content .formulario-overlay,
.formulario-section .formulario-form-overlay {
  z-index: 0;
}

.en-que-consiste-image-frame,
.coming-soon-banner::before,
.donde-featured-image,
.obra-modal-close {
  z-index: 2;
}

.jury-section .image-2 {
  z-index: 2;
}

.jury-section .image-1,
.jury-section .jury-image {
  z-index: 3;
}

.hero-section {
  z-index: 5;
}

.formulario-hero .back-arrow {
  z-index: 6;
}

.hero-text,
.description-box {
  z-index: 10;
}

.visual-accent,
.visual-asterisk,
.visual-sparkle {
  z-index: 20;
}

.en-que-consiste-decorative-svg {
  z-index: 25;
}

.rectangle-overlay {
  z-index: 22;
}

.jury-section .jury-content {
  z-index: 15;
}

.scroll-to-top {
  z-index: 100;
}

.sidebar-overlay,
.main-header,
.jury-section .jury-overlay {
  z-index: 50;
}

.sidebar-menu {
  z-index: 60;
}

.sidebar-menu .sidebar-close-button {
  z-index: 61;
}

.vote-popup-overlay,
.obra-dialog[open],
.popup-overlay {
  z-index: 200;
}

.vote-popup__close {
  z-index: 210;
}

.grecaptcha-badge {
  z-index: 300 !important;
  /* Puedes probar con un valor alto */
}

/**
 * GSAP Animation Performance Optimizations
 * Añade will-change para mejorar rendimiento de animaciones
 */
.hero-section .main-logo,
.hero-section .hero-tagline,
.hero-section .about-main-heading,
.hero-section .en-que-consiste-title,
.hero-section .prizes-main-heading,
.hero-section .jury-main-heading,
.hero-section .donde-main-heading,
.hero-section img,
.hero-section .prize-box,
.hero-section .voting-method,
.hero-section .jury-image,
.hero-section .marquee-image-item,
.hero-section .participate-blue-button,
.hero-section .star-icon img,
.hero-section .en-que-consiste-decorative-svg,
.hero-section .overlay-image,
.about-section .main-logo,
.about-section .hero-tagline,
.about-section .about-main-heading,
.about-section .en-que-consiste-title,
.about-section .prizes-main-heading,
.about-section .jury-main-heading,
.about-section .donde-main-heading,
.about-section img,
.about-section .prize-box,
.about-section .voting-method,
.about-section .jury-image,
.about-section .marquee-image-item,
.about-section .participate-blue-button,
.about-section .star-icon img,
.about-section .en-que-consiste-decorative-svg,
.about-section .overlay-image,
.en-que-consiste-container .main-logo,
.en-que-consiste-container .hero-tagline,
.en-que-consiste-container .about-main-heading,
.en-que-consiste-container .en-que-consiste-title,
.en-que-consiste-container .prizes-main-heading,
.en-que-consiste-container .jury-main-heading,
.en-que-consiste-container .donde-main-heading,
.en-que-consiste-container img,
.en-que-consiste-container .prize-box,
.en-que-consiste-container .voting-method,
.en-que-consiste-container .jury-image,
.en-que-consiste-container .marquee-image-item,
.en-que-consiste-container .participate-blue-button,
.en-que-consiste-container .star-icon img,
.en-que-consiste-container .en-que-consiste-decorative-svg,
.en-que-consiste-container .overlay-image,
.prizes-section .main-logo,
.prizes-section .hero-tagline,
.prizes-section .about-main-heading,
.prizes-section .en-que-consiste-title,
.prizes-section .prizes-main-heading,
.prizes-section .jury-main-heading,
.prizes-section .donde-main-heading,
.prizes-section img,
.prizes-section .prize-box,
.prizes-section .voting-method,
.prizes-section .jury-image,
.prizes-section .marquee-image-item,
.prizes-section .participate-blue-button,
.prizes-section .star-icon img,
.prizes-section .en-que-consiste-decorative-svg,
.prizes-section .overlay-image,
.jury-section .main-logo,
.jury-section .hero-tagline,
.jury-section .about-main-heading,
.jury-section .en-que-consiste-title,
.jury-section .prizes-main-heading,
.jury-section .jury-main-heading,
.jury-section .donde-main-heading,
.jury-section img,
.jury-section .prize-box,
.jury-section .voting-method,
.jury-section .jury-image,
.jury-section .marquee-image-item,
.jury-section .participate-blue-button,
.jury-section .star-icon img,
.jury-section .en-que-consiste-decorative-svg,
.jury-section .overlay-image,
.marquee-banner .main-logo,
.marquee-banner .hero-tagline,
.marquee-banner .about-main-heading,
.marquee-banner .en-que-consiste-title,
.marquee-banner .prizes-main-heading,
.marquee-banner .jury-main-heading,
.marquee-banner .donde-main-heading,
.marquee-banner img,
.marquee-banner .prize-box,
.marquee-banner .voting-method,
.marquee-banner .jury-image,
.marquee-banner .marquee-image-item,
.marquee-banner .participate-blue-button,
.marquee-banner .star-icon img,
.marquee-banner .en-que-consiste-decorative-svg,
.marquee-banner .overlay-image,
.donde-section .main-logo,
.donde-section .hero-tagline,
.donde-section .about-main-heading,
.donde-section .en-que-consiste-title,
.donde-section .prizes-main-heading,
.donde-section .jury-main-heading,
.donde-section .donde-main-heading,
.donde-section img,
.donde-section .prize-box,
.donde-section .voting-method,
.donde-section .jury-image,
.donde-section .marquee-image-item,
.donde-section .participate-blue-button,
.donde-section .star-icon img,
.donde-section .en-que-consiste-decorative-svg,
.donde-section .overlay-image,
.form-section .main-logo,
.form-section .hero-tagline,
.form-section .about-main-heading,
.form-section .en-que-consiste-title,
.form-section .prizes-main-heading,
.form-section .jury-main-heading,
.form-section .donde-main-heading,
.form-section img,
.form-section .prize-box,
.form-section .voting-method,
.form-section .jury-image,
.form-section .marquee-image-item,
.form-section .participate-blue-button,
.form-section .star-icon img,
.form-section .en-que-consiste-decorative-svg,
.form-section .overlay-image {
  will-change: transform, opacity;
}

.prize-box,
.jury-image,
.voting-method {
  transition: transform 0.3s ease;
}

.overlay-image,
.hero-section .overlay-image,
.jury-overlay img,
.donde-overlay img {
  will-change: transform;
  backface-visibility: hidden;
  perspective: 1000px;
}

.prize-box:hover,
.jury-image:hover,
button:hover,
.participate-blue-button:hover {
  backface-visibility: hidden;
}

@media (prefers-reduced-motion: reduce) {
  * {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}
@media (max-width: 768px) {
  .hero-section img,
  .hero-section .overlay-image,
  .about-section img,
  .about-section .overlay-image,
  .en-que-consiste-container img,
  .en-que-consiste-container .overlay-image,
  .prizes-section img,
  .prizes-section .overlay-image,
  .jury-section img,
  .jury-section .overlay-image,
  .marquee-banner img,
  .marquee-banner .overlay-image,
  .donde-section img,
  .donde-section .overlay-image {
    transform: none !important;
  }
}
.prizes-featured-image,
.about-featured-image,
.donde-featured-image,
.jury-image img {
  position: relative;
}

/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */
/* Document
 ========================================================================== */
html {
  line-height: 1.15;
  -webkit-text-size-adjust: 100%;
}

/* Sections
 ========================================================================== */
body {
  margin: 0;
}

main {
  display: block;
}

h1 {
  font-size: 2em;
  margin: 0.67em 0;
}

/* Grouping content
 ========================================================================== */
hr {
  box-sizing: content-box;
  height: 0;
  overflow: visible;
}

pre {
  font-family: monospace, monospace;
  font-size: 1em;
}

/* Text-level semantics
 ========================================================================== */
a {
  background-color: transparent;
}

abbr[title] {
  border-bottom: none;
  text-decoration: underline;
  text-decoration: underline dotted;
}

b,
strong {
  font-weight: bolder;
}

code,
kbd,
samp {
  font-family: monospace, monospace;
  font-size: 1em;
}

small {
  font-size: 80%;
}

sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

/* Embedded content
 ========================================================================== */
img {
  border-style: none;
}

/* Forms
 ========================================================================== */
button,
input,
optgroup,
select,
textarea {
  font-family: inherit;
  font-size: 100%;
  line-height: 1.15;
  margin: 0;
}

button,
input {
  overflow: visible;
}

button,
select {
  text-transform: none;
}

button,
[type=button],
[type=reset],
[type=submit] {
  -webkit-appearance: button;
}

button::-moz-focus-inner,
[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

button:-moz-focusring,
[type=button]:-moz-focusring,
[type=reset]:-moz-focusring,
[type=submit]:-moz-focusring {
  outline: 1px dotted ButtonText;
}

fieldset {
  padding: 0.35em 0.75em 0.625em;
}

legend {
  box-sizing: border-box;
  color: inherit;
  display: table;
  max-width: 100%;
  padding: 0;
  white-space: normal;
}

progress {
  vertical-align: baseline;
}

textarea {
  overflow: auto;
}

[type=checkbox],
[type=radio] {
  box-sizing: border-box;
  padding: 0;
}

[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button {
  height: auto;
}

[type=search] {
  -webkit-appearance: textfield;
  outline-offset: -2px;
}

[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}

::-webkit-file-upload-button {
  -webkit-appearance: button;
  font: inherit;
}

/* Interactive
 ========================================================================== */
details {
  display: block;
}

summary {
  display: list-item;
}

/* Misc
 ========================================================================== */
template {
  display: none;
}

[hidden] {
  display: none;
}

/* Additional Custom Reset Styles
 ========================================================================== */
*,
*::before,
*::after {
  box-sizing: border-box;
}

h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
dl,
dd,
ol,
ul,
figure,
hr,
fieldset,
legend {
  margin: 0;
  padding: 0;
}

ul[role=list],
ol[role=list] {
  list-style: none;
}

/* ❌ COMMENTED OUT — This was causing double scroll with JS
html:focus-within {
scroll-behavior: smooth;
}
*/
/* ✅ If you want browser-wide smooth scroll without JS, uncomment this:
html {
scroll-behavior: smooth;
}
*/
body {
  min-height: 10vh;
  text-rendering: optimizeSpeed;
  line-height: 1.5;
}

a:not([class]) {
  text-decoration-skip-ink: auto;
}

img,
picture {
  max-width: 100%;
  display: block;
}

input,
button,
textarea,
select {
  font: inherit;
}

@media (prefers-reduced-motion: reduce) {
  /* html:focus-within {
    scroll-behavior: auto;
  } */
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}
.screen-reader-text,
.sr-only {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}

.skip-link {
  position: absolute;
  left: -9999px;
  z-index: 9999;
  padding: 8px 16px;
  background: #000;
  color: #fff;
  text-decoration: none;
}
.skip-link:focus {
  left: 6px;
  top: 7px;
}

*:focus-visible {
  outline: 2px solid #005fcc;
  outline-offset: 2px;
}

button:focus-visible,
.btn:focus-visible,
a:focus-visible {
  outline: 3px solid #005fcc;
  outline-offset: 2px;
}

input:focus-visible,
select:focus-visible,
textarea:focus-visible {
  outline: 2px solid #005fcc;
  outline-offset: 1px;
  border-color: #005fcc;
}

.focus-trap:focus-within {
  outline: 2px solid #005fcc;
  outline-offset: 2px;
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
  .marquee-text {
    animation: none !important;
  }
}
@media (prefers-contrast: high) {
  .btn {
    border: 2px solid currentColor;
  }
  .form-input,
  .form-select {
    border: 2px solid #000;
  }
  .error-message {
    border: 1px solid currentColor;
    padding: 8px;
    margin-top: 4px;
  }
}
.form-help-text {
  font-size: 0.9rem;
  color: #666;
  margin-top: 4px;
  margin-bottom: 8px;
}

.error-message {
  margin-top: 4px;
  padding: 4px 8px;
  border-radius: 4px;
  font-size: 0.9rem;
}
.error-message.show {
  background-color: #fee;
  color: #c33;
  border: 1px solid #fcc;
}

.form-input[aria-invalid=true],
.form-select[aria-invalid=true] {
  border-color: #c33;
  background-color: #fef7f7;
}
.form-input[aria-invalid=false]:valid,
.form-select[aria-invalid=false]:valid {
  border-color: #5c5;
  background-color: #f7fef7;
}

.required {
  color: #d32f2f;
  font-weight: bold;
  font-size: 1.1em;
}

[aria-hidden=true] {
  pointer-events: none;
}

.sidebar-menu[aria-hidden=true] {
  visibility: hidden;
  opacity: 0;
  pointer-events: none;
}
.sidebar-menu[aria-hidden=false] {
  visibility: visible;
  opacity: 1;
  pointer-events: auto;
}

.loading-indicator {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  padding: 40px 20px;
}
.loading-indicator .loading-spinner {
  width: 32px;
  height: 32px;
  border: 3px solid rgba(255, 255, 255, 0.3);
  border-top: 3px solid #fff;
  border-radius: 50%;
  animation: spin 1s linear infinite;
}
.loading-indicator .loading-text {
  color: #fff;
  font-size: 16px;
  font-weight: 500;
}
.loading-indicator.hidden {
  display: none;
}

@keyframes spin {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
@media (prefers-reduced-motion: reduce) {
  .loading-spinner {
    animation: none !important;
    border: 3px solid rgba(255, 255, 255, 0.5);
    border-top: 3px solid #fff;
  }
}
.scroll-locked {
  overflow: hidden;
  padding-right: var(--scrollbar-width, 0px);
  position: fixed;
  width: 100%;
}

.participate-blue-button {
  display: inline-block;
  background-color: #2121CF;
  color: white;
  padding: 12px 25px;
  text-decoration: none;
  font-family: "Helvetica Neue";
  font-weight: 400;
  font-size: 16px;
  transition: background-color 0.3s ease;
  width: fit-content;
  align-self: flex-start;
}
.participate-blue-button:hover {
  background-color: #212176;
  color: white;
  text-decoration: none;
}
@media (max-width: 768px) {
  .participate-blue-button {
    display: block;
    width: 100%;
    text-align: center;
    margin-bottom: 20px;
  }
}

.yellow-button {
  background-color: #F8DE49;
  color: #000000;
}
.yellow-button:hover {
  background-color: #F7D83F;
  color: #000000;
}
@media (max-width: 768px) {
  .yellow-button {
    display: block;
    width: 100%;
    text-align: center;
    margin-bottom: 20px;
  }
}

.scroll-to-top {
  position: fixed;
  bottom: 90px;
  right: 70px;
  width: 50px;
  height: 50px;
  background-color: #2F3083;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: white;
  cursor: pointer;
  opacity: 0;
  visibility: hidden;
  transition: all 0.3s ease;
  border: none;
  outline: none;
  box-shadow: none;
  -webkit-appearance: none;
  -moz-appearance: none;
}
.scroll-to-top.visible {
  opacity: 1;
  visibility: visible;
}
.scroll-to-top:hover {
  transform: translateY(-3px);
}
.scroll-to-top.blue {
  background-color: #2121CF;
  color: white;
}
.scroll-to-top.blue:hover {
  background-color: #212176;
}
.scroll-to-top.yellow {
  background-color: #F8DE49;
  color: #000000;
}
.scroll-to-top.yellow:hover {
  background-color: #F7D83F;
}
.scroll-to-top svg {
  width: 20px;
  height: 20px;
}
@media (max-width: 768px) {
  .scroll-to-top {
    width: 44px;
    height: 44px;
    right: 20px;
  }
  .scroll-to-top svg {
    width: 18px;
    height: 18px;
  }
}

.marquee-banner {
  background-color: #2121CF;
  overflow: hidden;
  width: 100%;
  position: relative;
}
.marquee-banner.paused .marquee-text-inner {
  animation-play-state: paused;
}
.marquee-banner:focus-visible {
  outline: 2px solid white;
  outline-offset: -4px;
  background-color: black;
}
.marquee-banner .marquee-text-inner {
  display: flex;
  white-space: nowrap;
  padding: 16px 0;
  pointer-events: none;
  animation: marquee-scroll 20s linear infinite;
  width: max-content;
}
.marquee-banner .marquee-text-inner .marquee-text {
  display: flex;
  align-items: center;
  flex-shrink: 0;
}
.marquee-banner .marquee-text-inner .marquee-text .marquee-image-item {
  display: block;
  height: 27px;
  width: auto;
  margin: 0 18px;
  pointer-events: none;
}

@keyframes marquee-scroll {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-50%);
  }
}
@media (prefers-reduced-motion: reduce) {
  .marquee-banner .marquee-text-inner {
    animation-duration: 60s;
  }
}
.popup-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.4);
  display: flex;
  justify-content: center;
  align-items: center;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease, visibility 0.3s ease;
}
.popup-overlay.active {
  opacity: 1;
  visibility: visible;
}

.popup-container {
  background-color: #2121CF;
  width: 90%;
  max-width: 600px;
  position: relative;
  padding: 40px;
  text-align: center;
}

.popup-close {
  position: absolute;
  top: 20px;
  right: 20px;
  background: transparent;
  border: none;
  cursor: pointer;
  padding: 0;
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.popup-close:hover {
  transform: scale(1.1);
}

.popup-title {
  font-family: "Helvetica Neue";
  font-size: 2.5rem;
  font-weight: 700;
  color: #F8DE49;
  margin-bottom: 30px;
  line-height: 1.2;
  text-transform: uppercase;
}

.popup-text {
  font-family: "Helvetica Neue";
  font-size: 1.1rem;
  color: white;
  line-height: 1.5;
  margin-bottom: 20px;
}
.popup-text a {
  color: #F8DE49;
  text-decoration: none;
  transition: opacity 0.3s ease;
}
.popup-text a:hover {
  text-decoration: underline;
  opacity: 0.8;
}

@media (max-width: 768px) {
  .popup-container {
    padding: 30px 20px;
  }
  .popup-title {
    font-size: 2rem;
  }
  .popup-text {
    font-size: 1rem;
  }
}
@media (max-width: 480px) {
  .popup-title {
    font-size: 1.8rem;
  }
}
@media (max-width: 768px) {
  .participantes-grid {
    display: block !important;
    padding-bottom: 80px;
  }
  .participantes-grid .participante-card {
    background: white;
    border: 1px solid #eee;
    border-radius: 4px;
    overflow: hidden;
    transition: transform 0.3s ease, opacity 0.3s ease;
  }
  .slick-list {
    overflow: visible !important;
  }
  .slick-slide {
    transform: scale(0.9);
    opacity: 0.6;
    pointer-events: auto !important;
  }
  .slick-slide .card-image,
  .slick-slide .vote-btn,
  .slick-slide .obra-modal-close,
  .slick-slide .obra-accordion-toggle,
  .slick-slide dialog[open] {
    pointer-events: auto !important;
  }
  .slick-slide * {
    pointer-events: auto !important;
  }
  .slick-current {
    transform: scale(1);
    opacity: 1;
  }
  .obra-dialog[open] {
    pointer-events: auto !important;
  }
  .slider-bottom-bar {
    position: relative;
    margin-top: 20px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
  }
  .custom-slick-pagination {
    font-family: "Helvetica Neue";
    font-size: 20px;
    font-weight: 400;
    color: #2121CF;
    display: flex;
    justify-content: center;
    align-items: center;
  }
  .custom-slick-pagination .current-slide {
    font-weight: 700;
    font-size: 24px;
    margin-right: 5px;
  }
  .custom-slick-pagination .total-slides {
    color: #666;
    margin-left: 5px;
  }
  .slick-progress-container {
    height: 3px;
    background-color: #F8DE49;
    width: 80%;
    max-width: 400px;
    position: relative;
  }
  .progress-handle {
    position: absolute;
    top: 50%;
    transform: translate(-50%, -50%);
    width: 24px;
    height: 14px;
    background-color: #2121CF;
    border-radius: 50px;
    cursor: grab;
    transition: background-color 0.2s ease;
  }
  .progress-handle:active {
    cursor: grabbing;
    background-color: rgb(25.9875, 25.9875, 163.0125);
  }
}
.participante-card {
  background-color: white;
  border-radius: 0;
  overflow: hidden;
  position: relative;
}

.card-image {
  width: 100%;
  height: 250px;
  background-color: #D1D1D1;
  position: relative;
  overflow: hidden;
  cursor: zoom-in;
}
.card-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  transition: transform 0.3s ease;
  display: block;
}
.card-image .card-hover-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  transition: opacity 0.3s ease;
  pointer-events: none;
}
.card-image .card-hover-overlay img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.card-image:hover img.obra-imagen {
  transform: scale(1.05);
}
.card-image:hover .card-hover-overlay {
  opacity: 0.3;
}
.card-image:focus img.obra-imagen {
  transform: scale(1.05);
}
.card-image:focus .card-hover-overlay {
  opacity: 0.3;
}

.card-info {
  padding: 20px;
  background-color: white;
}

.card-votes {
  margin-bottom: 15px;
}
.card-votes .votes-count {
  font-size: 14px;
  font-family: "Helvetica Neue";
  font-weight: 400;
  color: #2121CF;
}

.card-category {
  margin-bottom: 15px;
}
.card-category .category-tag {
  display: block;
  width: 100%;
  background-color: #F8DE49;
  color: #2121CF;
  padding: 6px 12px;
  font-size: 12px;
  font-family: "Helvetica Neue";
  font-weight: 400;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  text-align: left;
}

.card-details {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 5px;
  min-height: 60px;
  hyphens: auto;
}
.card-details .card-text {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.card-details .card-text .artist-name {
  font-size: 18px;
  font-family: "Helvetica Neue";
  font-weight: 700;
  color: #2121CF;
  margin-bottom: 5px;
  text-transform: uppercase;
  line-height: 1.2;
}
.card-details .card-text .artwork-title {
  font-size: 13px;
  font-family: "Helvetica Neue";
  font-weight: 400;
  color: #2121CF;
  margin: 0;
  line-height: 1.3;
}
.card-details .vote-btn {
  background-color: white;
  color: #000000;
  border: 2px solid #F8DE49;
  padding: 12px 28px;
  font-family: "Helvetica Neue";
  font-weight: 400;
  font-size: 13px;
  text-transform: uppercase;
  cursor: pointer;
  transition: all 0.3s ease;
  letter-spacing: 0.3px;
  white-space: nowrap;
  flex-shrink: 0;
  align-self: flex-start;
  display: flex;
  align-items: center;
  justify-content: center;
}
.card-details .vote-btn:hover {
  background-color: #F8DE49;
  color: #000000;
}
.card-details .vote-btn:focus {
  outline: 2px solid #2121CF;
  outline-offset: 2px;
}

.obra-dialog {
  padding: 0;
  border: none;
  border-radius: 0;
  max-width: 90vw;
  max-height: 90vh;
  width: auto;
  height: auto;
  background-color: transparent;
}
.obra-dialog::backdrop {
  background-color: rgba(0, 0, 0, 0.4);
}
.obra-dialog[open] {
  display: flex;
  align-items: center;
  justify-content: center;
}

.obra-modal-container {
  position: relative;
  background-color: transparent;
  max-width: 100%;
  max-height: 100%;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.obra-modal-close {
  position: absolute;
  top: 15px;
  right: 15px;
  width: 30px;
  height: 30px;
  background-color: transparent;
  border: none;
  color: #2121CF;
  font-size: 24px;
  line-height: 1;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
}
.obra-modal-close:hover {
  color: #F8DE49;
}
.obra-modal-close:focus {
  outline: none;
  color: #F8DE49;
}

.obra-imagen-container {
  width: 100%;
  max-height: 80vh;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: transparent;
  overflow: hidden;
}
.obra-imagen-container img {
  max-width: 100%;
  max-height: 80vh;
  object-fit: contain;
}

.obra-accordion {
  position: relative;
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.obra-accordion-toggle {
  position: absolute;
  top: -30px;
  left: 50%;
  transform: translateX(-50%);
  width: 60px;
  height: 30px;
  border-radius: 30px 30px 0 0;
  background-color: #222;
  color: white;
  border: none;
  font-size: 20px;
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  padding: 0;
  transition: background-color 0.3s ease;
}
.obra-accordion-toggle:hover {
  background-color: #333;
}
.obra-accordion-toggle:focus {
  outline: none;
  background-color: #333;
}

.obra-accordion-content {
  width: 100%;
  max-width: 100%;
  padding: 20px;
  background-color: #222;
  color: white;
  font-size: 14px;
  font-family: "Helvetica Neue";
  line-height: 1.6;
  display: none;
  box-sizing: border-box;
}

.obra-modal-container {
  position: relative;
  background-color: transparent;
  max-width: 100%;
  max-height: 100%;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  align-items: center;
}

.obra-imagen-container {
  width: auto;
  max-width: 100%;
  max-height: 80vh;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: transparent;
  overflow: hidden;
}
.obra-imagen-container img {
  max-width: 100%;
  max-height: 80vh;
  object-fit: contain;
}

.obra-accordion {
  width: auto;
  max-width: 100%;
}

.file-type-icon {
  position: absolute;
  top: 10px;
  right: 10px;
  width: 40px;
  height: 40px;
  background-color: rgba(0, 0, 0, 0.7);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: white;
  font-size: 20px;
  z-index: 2;
}

.dashicons-pdf {
  color: #F8DE49;
}

.dashicons-video-alt3 {
  color: #F8DE49;
}

.dashicons-text-page {
  color: #F8DE49;
}

.vote-popup-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.7);
  display: flex;
  justify-content: center;
  align-items: center;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s, visibility 0.3s;
}
.vote-popup-overlay.active {
  opacity: 1;
  visibility: visible;
}

.vote-popup {
  display: flex;
  width: 90%;
  max-width: 800px;
  background-color: #fff;
  box-shadow: 0 5px 15px rgba(0, 0, 0, 0.3);
  position: relative;
  overflow: hidden;
}
@media (max-width: 768px) {
  .vote-popup {
    flex-direction: column;
    max-height: 90vh;
    overflow-y: auto;
    width: 95%;
    margin: 20px;
    border-radius: 8px;
  }
}
.vote-popup__selection {
  flex: 1;
  padding: 40px;
  background-color: #fff;
  display: flex;
  flex-direction: column;
  align-items: center;
}
@media (max-width: 768px) {
  .vote-popup__selection {
    padding: 20px;
  }
}
.vote-popup__selection h2 {
  font-size: 24px;
  margin-bottom: 30px;
  color: #212176;
}
.vote-popup__image-container {
  width: 100%;
  max-width: 300px;
  height: 300px;
  border: 2px solid #F8DE49;
  margin-bottom: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
.vote-popup__image-container img {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
}
.vote-popup__details {
  text-align: center;
  width: 100%;
}
.vote-popup__details .category {
  display: inline-block;
  padding: 5px 15px;
  background-color: #212176;
  color: white;
  font-size: 14px;
  margin-bottom: 10px;
}
.vote-popup__details .title {
  font-size: 22px;
  font-weight: bold;
  color: #2d3377;
  margin-bottom: 5px;
}
.vote-popup__details .author {
  font-size: 18px;
  color: #555;
}
.vote-popup__form {
  flex: 1;
  padding: 40px;
  background-color: #212176;
  color: white;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
@media (max-width: 768px) {
  .vote-popup__form {
    padding: 20px;
    border-radius: 0 0 8px 8px;
  }
}
.vote-popup__form h3 {
  font-size: 22px;
  margin-bottom: 10px;
  font-weight: normal;
}
.vote-popup__form p {
  margin-bottom: 30px;
  font-size: 16px;
  line-height: 1.5;
}
.vote-popup__form input[type=email] {
  padding: 15px;
  border: none;
  margin-bottom: 20px;
  font-size: 16px;
  width: 100%;
}
.vote-popup__form input[type=email]::placeholder {
  color: #999;
  font-style: italic;
}
.vote-popup__form button {
  background-color: #F8DE49;
  border: none;
  padding: 15px 20px;
  font-size: 16px;
  font-weight: bold;
  cursor: pointer;
  color: #2d3377;
  transition: background-color 0.3s;
  align-self: flex-start;
}
.vote-popup__form button:hover {
  background-color: rgb(246.1111111111, 213.0952380952, 23.8888888889);
}
.vote-popup__close {
  position: absolute;
  top: 15px;
  right: 15px;
  font-size: 28px;
  color: #fff;
  background: none;
  border: none;
  cursor: pointer;
  transition: color 0.3s ease;
}
@media (max-width: 768px) {
  .vote-popup__close {
    color: #2121CF;
    font-size: 32px;
    top: 10px;
    right: 10px;
    padding: 10px;
  }
}
.vote-popup__close:hover {
  color: #F8DE49;
}
@media (max-width: 768px) {
  .vote-popup__close:hover {
    color: #212176;
  }
}

body.modal-open {
  overflow: hidden;
  position: fixed;
  width: 100%;
  top: 0;
  left: 0;
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border-width: 0;
}

.site-footer {
  background-color: #ffffff;
  font-family: "Arial";
  font-weight: 300;
  color: #2121CF;
  position: relative;
  justify-content: center;
  display: flex;
  width: 100%;
}
.site-footer .container {
  margin: 30px 0;
  width: 100%;
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 24px;
  padding: 0 100px;
}
@media (max-width: 1024px) {
  .site-footer .container {
    padding: 0 60px;
  }
}
@media (max-width: 768px) {
  .site-footer .container {
    padding: 0 40px;
  }
}
@media (max-width: 480px) {
  .site-footer .container {
    padding: 0 20px;
  }
}
@media (max-width: 992px) {
  .site-footer .container {
    grid-template-columns: 1fr;
    justify-items: center;
    text-align: center;
  }
}
.site-footer .footer-content {
  display: flex;
  align-items: center;
  justify-content: flex-start;
}
@media (max-width: 992px) {
  .site-footer .footer-content {
    justify-content: center;
  }
}
.site-footer .footer-logo {
  max-width: 265px;
  max-height: 85px;
  margin-left: 5px;
  height: auto;
}
.site-footer .footer-logo img {
  width: auto;
  height: 60px;
  max-width: 100%;
}
@media (max-width: 768px) {
  .site-footer .footer-logo img {
    height: 50px;
  }
}
@media (max-width: 480px) {
  .site-footer .footer-logo img {
    height: 40px;
  }
}
@media (max-width: 992px) {
  .site-footer .footer-logo {
    align-items: center;
  }
}

.footer-right-section {
  display: flex;
  flex-direction: column;
  align-items: left;
  gap: 24px;
  grid-column: 2/4;
  justify-self: end;
}
@media (max-width: 992px) {
  .footer-right-section {
    grid-column: 1/2;
    align-items: center;
    width: 100%;
  }
}

.footer-nav .footer-menu {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: nowrap;
  justify-content: center;
  gap: 1rem;
  font-family: "Arial";
  white-space: nowrap;
  overflow-x: auto;
}
@media (max-width: 768px) {
  .footer-nav .footer-menu {
    flex-direction: column;
    gap: 0.5rem;
  }
}
.footer-nav .footer-menu li {
  display: inline-block;
}
.footer-nav .footer-menu li:not(:last-child)::after {
  content: "/";
  margin-left: 1rem;
  color: #999;
}
@media (max-width: 768px) {
  .footer-nav .footer-menu li:not(:last-child)::after {
    content: none;
  }
}
.footer-nav .footer-menu a {
  text-decoration: none;
  color: #2121CF;
  font-size: 0.9rem;
  transition: color 0.3s ease;
}
.footer-nav .footer-menu a:hover {
  color: #2121CF;
}

.footer-copyright p {
  margin: 0;
  font-size: 0.8rem;
  color: #2121CF;
  text-align: right;
}
@media (max-width: 768px) {
  .footer-copyright p {
    text-align: center;
  }
}

.main-header {
  background-color: #2121CF;
  padding: 5px 0;
  width: 100%;
  height: 12vh;
  min-height: 60px;
  position: sticky;
  top: 0;
  margin: 0;
  box-sizing: border-box;
  display: flex;
  align-items: center;
}

#wrapper {
  margin: 0;
  padding: 0;
  max-width: 100%;
  overflow-x: hidden;
}

.header-container {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 90%;
  margin: 0 80px;
  box-sizing: border-box;
  height: 100%;
}
@media (max-width: 1200px) {
  .header-container {
    margin: 0 40px;
  }
}
@media (max-width: 992px) {
  .header-container {
    margin: 0 20px;
  }
}
@media (max-width: 768px) {
  .header-container {
    margin: 0 15px;
  }
}

#site-logo a {
  display: flex;
  height: 100%;
  align-items: center;
}
#site-logo .header-logo {
  max-height: min(12vh - 10px, 50px);
  min-height: 30px;
  height: auto;
  width: auto;
  max-width: 100%;
  display: block;
  margin: 0;
  object-fit: contain;
}

.nav-buttons-wrapper {
  display: flex;
  align-items: center;
}

#menu ul {
  display: flex;
  list-style: none;
  margin: 0;
  padding: 0;
}
#menu ul li {
  margin: 0 15px;
}
#menu ul li a {
  color: white;
  text-decoration: none;
  font-size: 16px;
  font-family: "Helvetica Neue";
  font-weight: 300;
}
@media (max-width: 1200px) {
  #menu ul li a {
    font-size: 15px;
  }
}
@media (max-width: 992px) {
  #menu ul li a {
    font-size: 14px;
  }
}
#menu ul li a:hover {
  text-decoration: underline;
}
@media (max-width: 992px) {
  #menu {
    display: none;
  }
}

#search {
  display: none;
}

.participate-button {
  margin-left: 20px;
}
.participate-button .btn-participate {
  background-color: #F8DE49;
  color: #212176;
  padding: 10px 20px;
  gap: 10px;
  border-radius: 0px;
  text-decoration: none;
  font-weight: bold;
  display: inline-block;
  font-family: "Helvetica Neue";
  font-weight: 300;
  font-size: 16px;
}
.participate-button .btn-participate:hover {
  background-color: #F7D83F;
}
@media (max-width: 992px) {
  .participate-button {
    display: none;
  }
}

.hamburger-menu-button {
  display: none;
}
@media (max-width: 992px) {
  .hamburger-menu-button {
    display: flex;
    flex-direction: column;
    justify-content: space-around;
    width: 30px;
    height: 25px;
    background: transparent;
    border: none;
    cursor: pointer;
    padding: 0;
    margin-left: 20px;
  }
  .hamburger-menu-button .hamburger-icon {
    display: block;
    width: 100%;
    height: 3px;
    background-color: #F8DE49;
    border-radius: 2px;
    transition: all 0.3s ease-in-out;
  }
}

.sidebar-menu {
  position: fixed;
  top: 0;
  right: -300px;
  width: 300px;
  height: 100vh;
  max-height: 100vh;
  background-color: #2121CF;
  box-shadow: -5px 0 15px rgba(0, 0, 0, 0.3);
  transition: right 0.3s ease-in-out, visibility 0s linear 0.3s, opacity 0.3s ease-in-out;
  visibility: hidden;
  opacity: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 20px;
  box-sizing: border-box;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  /* Smooth scrolling on iOS */
}
.sidebar-menu.open {
  right: 0;
  visibility: visible;
  opacity: 1;
  transition: right 0.3s ease-in-out, visibility 0s linear 0s, opacity 0.3s ease-in-out;
}
@media (max-width: 768px) {
  .sidebar-menu {
    right: -100%;
    width: 100%;
    height: 100vh;
    max-height: 100vh;
    padding-bottom: 50px;
  }
  .sidebar-menu.open {
    right: 0;
  }
}
.sidebar-menu .sidebar-close-button {
  position: absolute;
  top: 20px;
  right: 20px;
  background: transparent;
  border: none;
  color: #F8DE49;
  font-size: 2rem;
  cursor: pointer;
}
.sidebar-menu .sidebar-navigation {
  margin-top: 60px;
  width: 100%;
}
.sidebar-menu .sidebar-navigation .sidebar-menu-ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.sidebar-menu .sidebar-navigation .sidebar-menu-ul li {
  margin-bottom: 15px;
  width: 100%;
  text-align: left;
  border-bottom: 2px solid #F8DE49;
}
.sidebar-menu .sidebar-navigation .sidebar-menu-ul li a {
  color: white;
  text-decoration: none;
  font-size: 1.2rem;
  font-family: "Helvetica Neue";
  font-weight: 300;
  display: block;
  padding: 10px 0;
}
.sidebar-menu .sidebar-navigation .sidebar-menu-ul li a:hover {
  color: #F8DE49;
}
.sidebar-menu .sidebar-participate-button {
  margin-top: 30px;
  width: 100%;
  text-align: center;
}
.sidebar-menu .sidebar-participate-button .btn-participate {
  background-color: #F8DE49;
  color: #2121CF;
  padding: 10px 20px;
  border-radius: 0px;
  text-decoration: none;
  display: inline-block;
  font-family: "Helvetica Neue";
  font-weight: 500;
  font-size: 16px;
  width: 100%;
}
.sidebar-menu .sidebar-logo {
  margin-top: auto;
  padding-top: 20px;
}
.sidebar-menu .sidebar-logo img {
  max-width: 150px;
  height: auto;
}

.sidebar-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.5);
  display: none;
}
.sidebar-overlay.active {
  display: block;
}

.hero-wrapper {
  background: #2121CF;
  padding: 50px 0 50px 0;
  margin: 0;
}
@media (max-width: 768px) {
  .hero-wrapper {
    padding-bottom: 30px;
  }
}
@media (max-width: 480px) {
  .hero-wrapper {
    padding-bottom: 20px;
  }
}

.hero-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
}
.hero-overlay .overlay-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 1;
  transform: rotate(180deg);
}

.hero-section {
  background: #2121CF;
  margin: -40px 40px 48px 40px;
  border: 33px solid #F8DE49;
  height: 80vh;
  min-height: 500px;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
@media (max-width: 768px) {
  .hero-section {
    margin: -20px 20px 20px 20px;
    min-height: 400px;
    border: 25px solid #F8DE49;
    height: 80vh;
  }
}

.hero-container {
  width: 100%;
  height: 100%;
  position: relative;
  max-width: 1500px;
  margin: 0 auto;
  padding: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media (max-width: 480px) {
  .hero-container {
    padding: 10px 20px 20px 20px;
  }
}

.hero-logo {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 80vh;
  flex-direction: column;
  gap: 70px;
}
.hero-logo .main-logo {
  width: 100%;
  height: auto;
}
@media (max-width: 768px) {
  .hero-logo .main-logo {
    max-width: 450px;
  }
}
@media (max-width: 480px) {
  .hero-logo .main-logo {
    max-width: 250px;
  }
}

.hero-cta {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-top: 0;
}
@media (min-width: 769px) {
  .hero-cta {
    display: none;
  }
}

.hero-participate-btn {
  display: inline-block;
  background-color: #F8DE49;
  color: #2121CF;
  border: 3px solid #F8DE49;
  padding: 12px 100px;
  font-size: 20px;
  font-weight: 500;
  text-decoration: none;
  text-align: center;
  letter-spacing: 1px;
  transition: all 0.3s ease;
  border-radius: 0;
}
@media (min-width: 769px) {
  .hero-participate-btn {
    display: none;
  }
}
.hero-participate-btn:hover {
  background-color: transparent;
  color: #F8DE49;
  border-color: #F8DE49;
  transform: translateY(-2px);
  box-shadow: 0 5px 15px rgba(248, 222, 73, 0.3);
}
.hero-participate-btn:focus {
  outline: 2px solid #F8DE49;
  outline-offset: 2px;
}
@media (max-width: 768px) {
  .hero-participate-btn {
    padding: 12px 100px;
    font-size: 16px;
  }
}
@media (max-width: 480px) {
  .hero-participate-btn {
    padding: 12px 50px;
    font-size: 14px;
    text-align: center;
    display: block;
    width: 100%;
    max-width: 280px;
  }
}

.hero-text {
  position: absolute;
  bottom: 0;
  left: 0;
  background: #F8DE49;
  padding: 30px 40px;
  width: 550px;
}
.hero-text .hero-tagline {
  margin: 0;
  font-size: 25px;
  font-weight: 400;
  color: #2121CF;
  line-height: 150%;
}
.hero-text .hero-tagline:first-child {
  margin-bottom: 4px;
}
@media (max-width: 768px) {
  .hero-text {
    padding: 15px 20px;
    max-width: 250px;
  }
  .hero-text .hero-tagline {
    font-size: 14px;
    white-space: nowrap;
  }
}
@media (max-width: 480px) {
  .hero-text {
    padding: 12px 15px;
    max-width: none;
    width: calc(100% + 30px);
    left: -15px;
    right: -15px;
  }
  .hero-text .hero-tagline {
    font-weight: 400;
    padding-left: 15px;
    padding-right: 15px;
  }
}

.reto-section {
  background-color: #F8DE49;
  padding: clamp(60px, 8vw, 120px) clamp(20px, 6vw, 80px);
  min-height: 80vh;
  display: flex;
  align-items: center;
  font-family: "Helvetica Neue", sans-serif;
  position: relative;
  overflow: hidden;
}
.reto-section .reto-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
}
.reto-section .reto-overlay .overlay-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0.25;
  opacity: 0.25;
  transform: rotate(180deg);
}
.reto-section .reto-container {
  max-width: none;
  max-width: none;
  margin: 0 auto;
  padding: 0 clamp(10px, 3vw, 20px);
  width: 100%;
}
@media (max-width: 768px) {
  .reto-section .reto-container {
    max-width: 500px;
    max-width: 500px;
  }
}
@media (max-width: 480px) {
  .reto-section .reto-container {
    padding: 0 15px;
    max-width: none;
    max-width: none;
  }
}
.reto-section .reto-content {
  display: grid;
  grid-template-columns: 59.3% 32.3%;
  gap: 8.4%;
  align-items: start;
}
@media (max-width: 768px) {
  .reto-section .reto-content {
    grid-template-columns: 1fr;
    gap: clamp(25px, 5vw, 40px);
  }
}
.reto-section .reto-info h2 {
  font-size: clamp(1.4rem, 2.5vw, 1.8rem);
  font-weight: 600;
  color: #000;
  margin-bottom: clamp(20px, 3vw, 30px);
  position: relative;
}
.reto-section .reto-info h2:after {
  content: "";
  display: block;
  width: clamp(120px, 15vw, 180px);
  height: 2px;
  background-color: #2121CF;
  margin-top: clamp(20px, 3vw, 30px);
}
.reto-section .reto-description p {
  font-size: clamp(0.85rem, 1.5vw, 1rem);
  line-height: 150%;
  color: #000;
  margin-bottom: clamp(10px, 1.5vw, 15px);
  font-weight: 300;
}
.reto-section .reto-description p strong {
  font-weight: 500;
  font-style: italic;
}
.reto-section .reto-question {
  background-color: #2121CF;
  color: #FFF;
  padding: clamp(8px, 1vw, 12px) clamp(12px, 2vw, 18px);
  margin: clamp(10px, 1.5vw, 15px) 0;
  display: inline-block;
  width: auto;
  flex-shrink: 0;
  text-align: center;
  width: auto;
  flex-shrink: 0;
  text-align: center;
}
.reto-section .reto-question h3 {
  font-family: "Helvetica Neue", sans-serif;
  font-size: clamp(0.9rem, 1.8vw, 1.1rem);
  font-weight: 700;
  line-height: 150%;
  margin: 0;
}
.reto-section .reto-link {
  margin-top: clamp(15px, 2vw, 20px);
}
.reto-section .reto-link a {
  color: #2121CF;
  text-decoration: underline;
  font-family: "Helvetica Neue", sans-serif;
  font-size: clamp(0.75rem, 1.2vw, 0.9rem);
  font-weight: 300;
  display: inline-flex;
  align-items: center;
  transition: color 0.3s ease;
  white-space: nowrap;
}
.reto-section .reto-link a .arrow-icon {
  margin-right: clamp(10px, 2vw, 15px);
}
.reto-section .reto-link a:hover {
  color: #333;
  text-decoration: underline;
}
.reto-section .reto-link a:focus {
  outline: 2px solid #2121CF;
  outline-offset: 2px;
}
.reto-section .reto-form {
  background-color: transparent;
}
.reto-section #participation-form {
  display: flex;
  flex-direction: column;
  gap: clamp(20px, 3vw, 25px);
}
.reto-section .form-group {
  display: flex;
  flex-direction: column;
  gap: clamp(6px, 1vw, 8px);
}
.reto-section .form-group.checkbox-group {
  flex-direction: row;
  align-items: flex-start;
  gap: clamp(10px, 1.5vw, 12px);
}
.reto-section .form-label {
  font-family: "Helvetica Neue", sans-serif;
  font-size: clamp(0.8rem, 1.2vw, 0.9rem);
  font-weight: 400;
  color: #000;
  margin-bottom: 4px;
}
.reto-section .form-label .required {
  color: #d32f2f;
  margin-left: 4px;
}
.reto-section .checkbox-label {
  font-family: "Helvetica Neue", sans-serif;
  font-size: clamp(0.75rem, 1.1vw, 0.85rem);
  color: #000;
  line-height: 1.4;
  cursor: pointer;
  font-weight: 400;
}
.reto-section .checkbox-label a {
  color: #000;
  text-decoration: underline;
  font-weight: 600;
}
.reto-section .checkbox-label a:hover {
  color: #333;
}
.reto-section .checkbox-label a:focus {
  outline: 2px solid #2121CF;
  outline-offset: 2px;
}
.reto-section .checkbox-label .required {
  color: #d32f2f;
  margin-left: 4px;
}
.reto-section .form-select,
.reto-section .form-input {
  font-family: "Helvetica Neue", sans-serif;
  font-size: clamp(0.8rem, 1.2vw, 0.9rem);
  font-style: italic;
  font-weight: 200;
  line-height: 150%;
  color: #000;
  padding: clamp(8px, 1.5vw, 12px) clamp(12px, 2vw, 16px);
  border: 0 solid #000;
  border-radius: 0;
  background-color: white;
  transition: none;
}
.reto-section .form-select:focus,
.reto-section .form-input:focus {
  outline: none;
  border-color: #2121CF;
  box-shadow: none;
}
.reto-section .form-select::placeholder,
.reto-section .form-input::placeholder {
  color: #000;
  font-style: italic;
  font-weight: 200;
}
.reto-section .form-select {
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  background-image: url('data:image/svg+xml;charset=US-ASCII,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 12 8" fill="none"><path d="M1 1L6 6L11 1" stroke="%23000" stroke-width="0.5" stroke-linecap="round" stroke-linejoin="round"/></svg>');
  background-repeat: no-repeat;
  background-position: right clamp(15px, 2vw, 20px) center;
  background-size: clamp(16px, 2vw, 20px);
  padding-right: clamp(35px, 4vw, 50px);
}
.reto-section .form-select option {
  padding: 8px;
  color: #000;
  font-style: normal;
  font-weight: 200;
}
.reto-section .form-checkbox {
  width: 18px;
  height: 18px;
  margin-top: 2px;
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  background-color: transparent;
  border: 1px solid #2121CF;
  border-radius: 0;
  position: relative;
}
.reto-section .form-checkbox:focus {
  outline: 2px solid #2121CF;
  outline-offset: 2px;
}
.reto-section .form-checkbox:checked {
  background-color: transparent;
  border-color: #2121CF;
}
.reto-section .form-checkbox:checked::after {
  content: "✓";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  color: #2121CF;
  font-size: 12px;
  font-weight: bold;
}
.reto-section .form-checkbox:hover {
  border-color: #2121CF;
}
.reto-section .form-submit {
  background-color: #2121CF;
  color: white;
  font-family: "Helvetica Neue", sans-serif;
  font-size: clamp(0.8rem, 1.2vw, 0.9rem);
  padding: clamp(10px, 1.5vw, 14px) clamp(16px, 3vw, 22px);
  border: none;
  cursor: pointer;
  transition: background-color 0.3s ease, transform 0.2s ease;
  align-self: flex-start;
}
.reto-section .form-submit:hover {
  background-color: #212176;
  transform: translateY(-1px);
}
.reto-section .form-submit:focus {
  outline: 3px solid #F8DE49;
  outline-offset: 2px;
}
.reto-section .form-submit:active {
  transform: translateY(0);
}
.reto-section .form-submit:disabled {
  background-color: #ccc;
  cursor: not-allowed;
  transform: none;
}
.reto-section .form-help {
  font-family: "Helvetica Neue", sans-serif;
  font-size: clamp(0.7rem, 1vw, 0.8rem);
  color: #666;
  line-height: 1.4;
  margin-top: 4px;
}
.reto-section .form-select.error,
.reto-section .form-input.error {
  border-color: #d32f2f;
  box-shadow: 0 0 0 2px rgba(211, 47, 47, 0.2);
}
.reto-section .form-checkbox.error {
  border-color: #d32f2f;
}
.reto-section .error-message {
  font-family: "Helvetica Neue", sans-serif;
  font-size: clamp(0.7rem, 1vw, 0.8rem);
  color: #d32f2f;
  margin-top: 4px;
  display: none;
}
.reto-section .error-message.show {
  display: block;
}
.reto-section .form-note {
  font-family: "Helvetica Neue", sans-serif;
  font-size: clamp(0.7rem, 1vw, 0.8rem);
  color: #000;
  font-style: normal;
  font-weight: 300;
  line-height: 150%;
  letter-spacing: 0.3px;
  margin-top: 5px;
}
.reto-section .sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
@media (max-width: 480px) {
  .reto-section .reto-section {
    padding: clamp(30px, 6vw, 40px) 0;
  }
  .reto-section .reto-container {
    padding: 0 15px;
    max-width: none;
  }
  .reto-section .reto-content {
    gap: clamp(20px, 4vw, 30px);
  }
  .reto-section .reto-info h2 {
    font-size: clamp(1.2rem, 4vw, 1.4rem);
  }
  .reto-section .reto-question {
    padding: clamp(10px, 2vw, 12px) clamp(12px, 3vw, 16px);
    display: block;
    width: 100%;
  }
  .reto-section .reto-question h3 {
    font-size: clamp(0.85rem, 3vw, 1rem);
  }
  .reto-section .form-group.checkbox-group {
    gap: clamp(6px, 2vw, 8px);
  }
  .reto-section .form-group.checkbox-group .form-checkbox {
    margin-top: 0;
  }
  .reto-section .form-submit {
    width: 100%;
    align-self: stretch;
  }
}
@media (prefers-contrast: high) {
  .reto-section .form-select,
  .reto-section .form-input {
    border-width: 3px;
  }
  .reto-section .form-submit {
    border: 2px solid white;
  }
}
@media (prefers-reduced-motion: reduce) {
  .reto-section .form-select,
  .reto-section .form-input,
  .reto-section .form-submit,
  .reto-section .reto-link a {
    transition: none;
  }
}
.reto-section .form-select:focus-visible,
.reto-section .form-input:focus-visible,
.reto-section .form-checkbox:focus-visible,
.reto-section .form-submit:focus-visible,
.reto-section .reto-link a:focus-visible,
.reto-section .checkbox-label a:focus-visible {
  outline: 3px solid #2121CF;
  outline-offset: 2px;
}

.coming-soon-page {
  background-image: url("assets/comingsoon.jpg");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  min-height: 90vh;
  padding: 50px 50px 20px 50px;
  margin: 0;
  position: relative;
  font-family: "Helvetica Neue", Arial, sans-serif;
}
@media (max-width: 768px) {
  .coming-soon-page {
    padding: 30px 30px 15px 30px;
  }
}
@media (max-width: 480px) {
  .coming-soon-page {
    padding: 20px 20px 10px 20px;
  }
}

.coming-soon-banner {
  margin: 0;
  min-height: 75vh;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  max-width: 75dvw;
  margin: 0 auto;
}
.coming-soon-banner::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(33, 33, 207, 0.9);
  pointer-events: none;
}
@media (max-width: 768px) {
  .coming-soon-banner {
    border-width: 20px;
    margin: 0;
    min-height: 70vh;
    max-width: 90dvw;
  }
}
@media (max-width: 480px) {
  .coming-soon-banner {
    border-width: 17px;
    margin: 0;
    min-height: 85dvh;
    max-width: 95dvw;
    display: flex;
    align-items: center;
    justify-content: center;
  }
}

.coming-soon-wrapper {
  width: 100%;
  height: 100%;
  position: relative;
  max-width: 900px;
  margin: 0 auto;
  padding: 40px 20px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  font-family: "Helvetica Neue", Arial, sans-serif;
}
@media (max-width: 480px) {
  .coming-soon-wrapper {
    padding: 20px;
  }
}

.coming-soon-main-content {
  color: white;
  position: relative;
  font-family: "Helvetica Neue", Arial, sans-serif;
  text-align: center;
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

.coming-soon-main-title {
  font-size: 3.5rem;
  font-weight: 700;
  color: #F8DE49;
  margin: 0 0 20px 0;
  line-height: 1.1;
  text-transform: uppercase;
  letter-spacing: 2px;
  font-family: "Helvetica Neue", Arial, sans-serif;
  text-shadow: none;
  text-align: center;
  width: 100%;
}
@media (max-width: 768px) {
  .coming-soon-main-title {
    font-size: 2.5rem;
  }
}
@media (max-width: 480px) {
  .coming-soon-main-title {
    font-size: 2.2rem;
    letter-spacing: 1px;
  }
}

.coming-soon-main-subtitle {
  font-size: 1.2rem;
  color: white;
  margin: 0 0 40px 0;
  line-height: 1.4;
  max-width: 600px;
  font-family: "Helvetica Neue", Arial, sans-serif;
  text-shadow: none;
  text-align: center;
  width: 100%;
}
@media (max-width: 768px) {
  .coming-soon-main-subtitle {
    font-size: 1.1rem;
    margin-bottom: 30px;
  }
}
@media (max-width: 480px) {
  .coming-soon-main-subtitle {
    font-size: 1.1rem;
    margin-bottom: 25px;
  }
}

.timer-countdown {
  display: flex;
  justify-content: center;
  gap: 5px;
  background: transparent;
  padding: 50px 45px;
  border-radius: 0;
  margin: 20px 0;
  border: none;
  backdrop-filter: none;
  font-family: "Helvetica Neue", Arial, sans-serif;
}
@media (max-width: 768px) {
  .timer-countdown {
    gap: 4px;
    padding: 40px 35px;
    flex-wrap: nowrap;
  }
}
@media (max-width: 480px) {
  .timer-countdown {
    gap: 2px;
    padding: 20px 10px;
    flex-wrap: nowrap;
    justify-content: space-between;
    width: 100%;
    max-width: 100%;
  }
}

.timer-unit {
  display: flex;
  flex-direction: column;
  align-items: center;
  min-width: auto;
  font-family: "Helvetica Neue", Arial, sans-serif;
  position: relative;
}
@media (max-width: 480px) {
  .timer-unit {
    min-width: auto;
    flex: 1;
    max-width: 25%;
  }
}

.timer-digit {
  background: #F8DE49;
  padding: 25px 30px;
  border-radius: 0;
  min-width: 90px;
  text-align: center;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
}
.timer-digit .timer-number {
  font-size: 3.2rem;
  font-weight: 700;
  color: #2121CF;
  line-height: 1;
  margin: 0;
}
.timer-digit .timer-text {
  font-size: 0.8rem;
  color: #2121CF;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 1px;
  line-height: 1;
  margin: 0;
}
@media (max-width: 768px) {
  .timer-digit {
    padding: 22px 26px;
    min-width: 80px;
    gap: 6px;
  }
  .timer-digit .timer-number {
    font-size: 2.7rem;
  }
  .timer-digit .timer-text {
    font-size: 0.7rem;
  }
}
@media (max-width: 480px) {
  .timer-digit {
    padding: 12px 4px;
    min-width: 45px;
    gap: 2px;
    width: 100%;
  }
  .timer-digit .timer-number {
    font-size: 1.8rem;
  }
  .timer-digit .timer-text {
    font-size: 0.5rem;
    letter-spacing: 0.3px;
  }
}

.timer-text {
  font-size: 0.8rem;
  color: #2121CF;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 1px;
  font-family: "Helvetica Neue", Arial, sans-serif;
  text-shadow: none;
  margin-top: 5px;
  line-height: 1;
}
@media (max-width: 480px) {
  .timer-text {
    font-size: 0.7rem;
    margin-top: 3px;
  }
}

.description-area {
  background: #2121CF;
  padding: 80px 50px;
  position: relative;
  margin: 0;
  font-family: "Helvetica Neue", Arial, sans-serif;
}
@media (max-width: 768px) {
  .description-area {
    padding: 50px 30px;
  }
}
@media (max-width: 480px) {
  .description-area {
    padding: 80px 20px;
  }
}

.description-wrapper {
  max-width: 1400px;
  margin: 0 auto;
  position: relative;
  display: flex;
  align-items: flex-start;
  min-height: auto;
  font-family: "Helvetica Neue", Arial, sans-serif;
  padding: 0 50px;
}
@media (max-width: 768px) {
  .description-wrapper {
    flex-direction: column;
    text-align: left;
    min-height: auto;
    padding: 0 20px;
  }
}
@media (max-width: 480px) {
  .description-wrapper {
    padding: 0 10px;
  }
}

.description-box {
  background: transparent;
  padding: 0;
  max-width: 800px;
  position: relative;
  font-family: "Helvetica Neue", Arial, sans-serif;
  width: 100%;
}
@media (max-width: 768px) {
  .description-box {
    max-width: none;
    width: 100%;
    padding: 0;
  }
}

.description-tag {
  font-size: 0.9rem;
  color: white;
  font-weight: 400;
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-bottom: 15px;
  display: block;
  font-family: "Helvetica Neue", Arial, sans-serif;
}

.description-heading {
  font-size: 3rem;
  font-weight: 700;
  color: white;
  margin: 0 0 30px 0;
  line-height: 1.1;
  text-transform: uppercase;
  font-family: "Helvetica Neue", Arial, sans-serif;
}
@media (max-width: 768px) {
  .description-heading {
    font-size: 2.5rem;
  }
}
@media (max-width: 480px) {
  .description-heading {
    font-size: 2.2rem;
  }
}

.description-divider {
  border: none;
  height: 2px;
  background-color: white;
  width: 120px;
  margin: 0 0 30px 0;
}
@media (max-width: 480px) {
  .description-divider {
    width: 90px;
    margin-bottom: 25px;
  }
}

.description-text {
  font-size: 1.2rem;
  color: white;
  line-height: 1.6;
  margin: 0 0 40px 0;
  font-family: "Helvetica Neue", Arial, sans-serif;
  font-weight: 300;
}
@media (max-width: 480px) {
  .description-text {
    font-size: 1.2rem;
    margin-bottom: 30px;
  }
}

.action-button {
  display: inline-block;
  background: #F8DE49;
  color: #2121CF;
  padding: 15px 30px;
  font-size: 1rem;
  font-weight: 400;
  text-decoration: none;
  text-transform: none;
  letter-spacing: 0;
  border: none;
  border-radius: 0;
  transition: all 0.3s ease;
  font-family: "Helvetica Neue", Arial, sans-serif;
}
.action-button:hover {
  background: white;
  color: #2121CF;
}
@media (max-width: 480px) {
  .action-button {
    padding: 12px 25px;
    font-size: 0.9rem;
  }
}

.visual-accent {
  position: absolute;
  right: 50px;
  top: -150px;
  width: 220px;
  height: 220px;
  background-image: url("assets/iconsecond.svg");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  display: block;
}
.visual-accent::before {
  display: none;
}
@media (max-width: 768px) {
  .visual-accent {
    width: 150px;
    height: 150px;
    right: 30px;
    top: -65px;
  }
}
@media (max-width: 480px) {
  .visual-accent {
    width: 120px;
    height: 120px;
    right: 20px;
    top: -100px;
  }
}

.participantes-page {
  width: 100%;
  min-height: 100vh;
  position: relative;
}

.hero-participantes {
  position: relative;
  width: 100%;
  height: 82vh;
  min-height: calc(500px + 12vh);
  overflow: visible;
  display: flex;
  align-items: center;
  font-family: "Helvetica Neue", Arial, sans-serif;
  margin-top: 0;
}
.hero-participantes .hero-background {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-image: url("assets/montanasbg.jpg");
  background-size: cover;
  background-position: center bottom;
  background-repeat: no-repeat;
}
.hero-participantes .hero-content {
  position: relative;
  width: 100%;
  max-width: 1600px;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px 60px;
  margin: 0 auto;
  gap: 24px;
  padding-top: 12vh;
}
@media (max-width: 1024px) {
  .hero-participantes .hero-content {
    flex-direction: column;
    justify-content: center;
    gap: 40px;
  }
}
@media (max-width: 768px) {
  .hero-participantes .hero-content {
    padding: 0 10px;
    gap: 30px;
  }
}

.logo-section {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
}
.logo-section img {
  width: 600px;
  height: auto;
}
@media (max-width: 1024px) {
  .logo-section {
    margin-top: calc(12vh + 80px);
    align-items: flex-start;
  }
}
@media (max-width: 480px) {
  .logo-section {
    margin-top: calc(12vh + 100px);
  }
}

.info-section {
  flex: 1;
  display: flex;
  align-items: flex-end;
  justify-content: flex-end;
  position: relative;
  margin-bottom: 30px;
}
@media (max-width: 1024px) {
  .info-section {
    justify-content: center;
    align-items: center;
  }
}
.info-section .info-box {
  background-color: #F8DE49;
  padding: 20px 60px;
  max-width: 650px;
  width: 100%;
  min-height: 400px;
  transform: translateY(30vh);
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
@media (max-width: 1024px) {
  .info-section .info-box {
    padding: 15px 50px;
    transform: translateY(0);
    min-height: 350px;
  }
}
@media (max-width: 768px) {
  .info-section .info-box {
    padding: 10px 40px;
    max-width: 580px;
    min-height: 320px;
  }
}
@media (max-width: 480px) {
  .info-section .info-box {
    padding: 60px 45px;
    max-width: 520px;
    min-height: 280px;
  }
}
.info-section .info-box .info-header {
  margin-bottom: 25px;
}
.info-section .info-box .info-header .info-subtitle {
  display: block;
  color: #000000;
  font-family: "Helvetica Neue";
  font-size: 0.9rem;
  font-weight: 300;
  margin-bottom: 10px;
  letter-spacing: 1px;
}
@media (max-width: 480px) {
  .info-section .info-box .info-header .info-subtitle {
    font-size: 0.8rem;
  }
}
.info-section .info-box .info-header .info-title {
  color: #000000;
  font-family: "Helvetica Neue";
  font-size: 2.2rem;
  font-weight: 700;
  margin: 0;
  line-height: 1.1;
}
@media (max-width: 768px) {
  .info-section .info-box .info-header .info-title {
    font-size: 1.9rem;
  }
}
@media (max-width: 480px) {
  .info-section .info-box .info-header .info-title {
    font-size: 1.6rem;
  }
}
.info-section .info-box .info-header::after {
  content: "";
  display: block;
  width: 200px;
  height: 2px;
  background-color: #2121CF;
  margin-top: 15px;
}
.info-section .info-box .info-content .info-description {
  color: #000000;
  font-family: "Helvetica Neue";
  font-size: 1rem;
  font-weight: 300;
  line-height: 1.6;
  margin: 0;
}
@media (max-width: 480px) {
  .info-section .info-box .info-content .info-description {
    font-size: 0.9rem;
    line-height: 1.5;
  }
}

.participantes-content {
  padding: 120px 0;
  background-color: white;
  width: 100%;
}
@media (max-width: 768px) {
  .participantes-content {
    padding: 80px 0;
  }
}

@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(30px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.logo-section,
.info-section {
  animation: fadeInUp 1s ease-out;
}

.info-section {
  animation-delay: 0.3s;
}

.container {
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 20px;
}

.participantes-header {
  text-align: left;
  margin-bottom: 60px;
}
@media (max-width: 768px) {
  .participantes-header {
    margin-bottom: 40px;
  }
}

.participantes-subtitle {
  font-size: 16px;
  font-family: "Helvetica Neue";
  font-weight: 400;
  color: #000000;
  text-transform: uppercase;
  margin-bottom: 20px;
  letter-spacing: 1px;
}

.participantes-title {
  font-size: clamp(32px, 5vw, 48px);
  font-family: "Helvetica Neue";
  font-weight: 700;
  color: #000000;
  text-transform: uppercase;
  margin-bottom: 20px;
  line-height: 1.2;
}

.title-underline {
  width: 200px;
  height: 2px;
  background-color: #000000;
  margin: 0 0 40px 0;
}
@media (max-width: 768px) {
  .title-underline {
    margin: 0 0 40px 0;
  }
}

.participantes-filters {
  text-align: left;
  margin-bottom: 50px;
}
@media (max-width: 768px) {
  .participantes-filters {
    margin-bottom: 40px;
  }
}

.filter-label {
  font-size: 14px;
  font-family: "Helvetica Neue";
  font-weight: 400;
  color: #000000;
  text-transform: uppercase;
  margin-bottom: 20px;
  letter-spacing: 1px;
}

.filter-buttons {
  display: flex;
  justify-content: flex-start;
  gap: 20px;
  flex-wrap: wrap;
}
@media (max-width: 768px) {
  .filter-buttons {
    gap: 15px;
    overflow-x: auto;
    padding-bottom: 10px;
  }
  .filter-buttons::-webkit-scrollbar {
    height: 4px;
  }
  .filter-buttons::-webkit-scrollbar-track {
    background: #f1f1f1;
  }
  .filter-buttons::-webkit-scrollbar-thumb {
    background: #2121CF;
    border-radius: 2px;
  }
}

.filter-btn {
  background-color: transparent;
  border: 2px solid #2121CF;
  color: #2121CF;
  padding: 12px 24px;
  font-family: "Helvetica Neue";
  font-weight: 400;
  font-size: 14px;
  text-transform: uppercase;
  cursor: pointer;
  transition: all 0.3s ease;
  border-radius: 0;
  letter-spacing: 0.5px;
  white-space: nowrap;
  flex-shrink: 0;
}
.filter-btn:hover, .filter-btn.active {
  background-color: #2121CF;
  color: white;
}
@media (max-width: 768px) {
  .filter-btn {
    padding: 10px 20px;
    font-size: 13px;
  }
}

.participantes-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 30px;
}
@media (max-width: 1300px) {
  .participantes-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 25px;
  }
}
@media (max-width: 900px) {
  .participantes-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
  }
}
@media (max-width: 480px) {
  .participantes-grid {
    grid-template-columns: 1fr;
    gap: 20px;
  }
}

@media (max-width: 768px) {
  .participantes-grid.slick-initialized {
    position: relative;
  }
  .participantes-grid.slick-initialized .participante-card {
    width: calc(100% - 20px);
    margin: 0 10px;
  }
  .participantes-grid.slick-initialized .participante-card .card-info {
    padding: 20px;
    background-color: white;
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
  }
  .participantes-grid.slick-initialized .participante-card .card-votes,
  .participantes-grid.slick-initialized .participante-card .card-category,
  .participantes-grid.slick-initialized .participante-card .card-details {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
  }
}
.formulario-page {
  font-family: "Helvetica Neue";
  margin: 0;
  padding: 0;
}

.formulario-hero {
  background-color: #F8DE49;
  height: 85vh;
  position: relative;
}
@media (max-width: 480px) {
  .formulario-hero {
    height: 88vh;
  }
}
.formulario-hero .formulario-hero-container {
  height: 100%;
  margin: 0;
  padding: 0;
  max-width: none;
}
.formulario-hero .formulario-hero-columns {
  display: flex;
  height: 100%;
}
@media (max-width: 768px) {
  .formulario-hero .formulario-hero-columns {
    flex-direction: column;
  }
}
.formulario-hero .formulario-hero-image {
  flex: 0 0 50%;
  background-image: url("./assets/imgheroform.jpg");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}
.formulario-hero .formulario-hero-image .logo-overlay {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  pointer-events: none;
}
.formulario-hero .formulario-hero-image .logo-overlay img {
  width: 568px;
  height: auto;
  opacity: 1;
  display: block;
}
@media (max-width: 768px) {
  .formulario-hero .formulario-hero-image {
    flex: 0 0 40%;
    min-height: 300px;
  }
  .formulario-hero .formulario-hero-image .logo-overlay img {
    width: 220px;
  }
}
@media (max-width: 480px) {
  .formulario-hero .formulario-hero-image {
    flex: 0 0 35%;
    min-height: 250px;
  }
  .formulario-hero .formulario-hero-image .logo-overlay img {
    width: 180px;
  }
}
.formulario-hero .formulario-hero-content {
  flex: 0 0 50%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  padding: 60px 80px;
  background-color: #F8DE49;
  position: relative;
  overflow: hidden;
}
.formulario-hero .formulario-hero-content .formulario-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
}
.formulario-hero .formulario-hero-content .formulario-overlay .formulario-overlay-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: rotate(180deg);
}
.formulario-hero .formulario-hero-content .formulario-overlay.success-overlay .formulario-overlay-image {
  opacity: 0.45;
}
.formulario-hero .formulario-hero-content .formulario-overlay.failure-overlay .formulario-overlay-image {
  opacity: 1;
}
.formulario-hero .formulario-hero-content * {
  position: relative;
}
@media (max-width: 1200px) {
  .formulario-hero .formulario-hero-content {
    padding: 50px 60px;
  }
}
@media (max-width: 768px) {
  .formulario-hero .formulario-hero-content {
    flex: 1;
    padding: 40px 30px;
    text-align: center;
    align-items: center;
  }
}
@media (max-width: 480px) {
  .formulario-hero .formulario-hero-content {
    padding: 30px 20px;
  }
}
.formulario-hero .back-arrow {
  position: absolute;
  top: 30px;
  left: 30px;
  width: 50px;
  height: 50px;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: transparent;
  color: #2121CF;
  text-decoration: none;
  transition: all 0.3s ease;
}
.formulario-hero .back-arrow:hover {
  background-color: #2121CF;
  color: #F8DE49;
  transform: translateX(-3px);
}
.formulario-hero .back-arrow svg {
  width: 24px;
  height: 24px;
}
@media (max-width: 768px) {
  .formulario-hero .back-arrow {
    top: 20px;
    left: 20px;
    width: 45px;
    height: 45px;
  }
  .formulario-hero .back-arrow svg {
    width: 20px;
    height: 20px;
  }
}
@media (max-width: 480px) {
  .formulario-hero .back-arrow {
    top: 15px;
    left: 15px;
    width: 40px;
    height: 40px;
  }
  .formulario-hero .back-arrow svg {
    width: 18px;
    height: 18px;
  }
}
.formulario-hero .formulario-hero-title {
  font-size: clamp(28px, 4vw, 48px);
  font-weight: 700;
  color: #2121CF;
  margin: 0 0 30px 0;
  line-height: 1.1;
  text-transform: uppercase;
  text-align: center;
}
@media (max-width: 768px) {
  .formulario-hero .formulario-hero-title {
    text-align: center;
    margin-top: 50px;
  }
}
.formulario-hero .formulario-hero-subtitle {
  font-size: 18px;
  font-weight: 300;
  color: #000000;
  margin: 0 0 40px 0;
  line-height: 1.5;
  text-align: center;
}
@media (max-width: 768px) {
  .formulario-hero .formulario-hero-subtitle {
    font-size: 16px;
    text-align: center;
  }
}
.formulario-hero .formulario-hero-link {
  display: inline-block;
  background-color: transparent;
  color: #2121CF;
  border: 3px solid #2121CF;
  padding: 18px 35px;
  font-size: 18px;
  line-height: 150%;
  font-weight: 400;
  border-radius: 0;
  text-decoration: none;
  text-transform: uppercase;
  text-align: center;
  margin: 0 0 30px 0;
  width: auto;
  max-width: 100%;
}
.formulario-hero .formulario-hero-link:hover {
  background-color: #2121CF;
  color: white;
}
@media (max-width: 768px) {
  .formulario-hero .formulario-hero-link {
    padding: 15px 30px;
    font-size: 14px;
    margin: 0 0 20px 0;
  }
}
@media (max-width: 480px) {
  .formulario-hero .formulario-hero-link {
    padding: 12px 25px;
    font-size: 13px;
    margin: 0 0 15px 0;
  }
}
.formulario-hero .formulario-hero-button {
  background-color: #2121CF;
  color: white;
  border: none;
  padding: 18px 35px;
  font-size: 16px;
  font-weight: 500;
  border-radius: 5px;
  cursor: pointer;
  transition: all 0.3s ease;
  text-transform: uppercase;
  text-decoration: none;
}
.formulario-hero .formulario-hero-button:hover {
  background-color: #212176;
  transform: translateY(-2px);
  box-shadow: 0 5px 15px rgba(47, 48, 131, 0.3);
}
@media (max-width: 768px) {
  .formulario-hero .formulario-hero-button {
    padding: 15px 30px;
    font-size: 14px;
  }
}

.formulario-section {
  background-color: #2121CF;
  padding: 80px 0;
  min-height: 100vh;
  position: relative;
  overflow: hidden;
}
.formulario-section .formulario-form-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
}
.formulario-section .formulario-form-overlay .formulario-form-overlay-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 1;
  transform: rotate(180deg);
}
.formulario-section .formulario-container {
  max-width: 800px;
  margin: 0 auto;
  padding: 0 20px;
  position: relative;
}

.formulario-registro {
  background-color: transparent;
  padding: 40px;
  border-radius: 0;
  box-shadow: none;
}
@media (max-width: 768px) {
  .formulario-registro {
    padding: 30px 20px;
  }
}

.formulario-group-section {
  margin-bottom: 40px;
}
.formulario-group-section:last-child {
  margin-bottom: 0;
}

.formulario-section-title {
  font-size: 24px;
  font-weight: 700;
  color: white;
  margin: 0 0 30px 0;
  text-transform: none;
  border-bottom: 0 !important;
  padding-bottom: 10px;
}

.formulario-row {
  display: flex;
  gap: 20px;
  margin-bottom: 20px;
}
@media (max-width: 768px) {
  .formulario-row {
    flex-direction: column;
    gap: 0;
  }
}
.formulario-row .form-group {
  flex: 1;
}
.formulario-row .form-group.full-width {
  flex: 1 1 100%;
}

.formulario-registro .form-label {
  color: white;
  font-weight: 500;
  font-size: 14px;
  margin-bottom: 8px;
  display: block;
}
.formulario-registro .form-input,
.formulario-registro .form-select {
  border: 2px solid #e0e0e0;
  border-radius: 0;
  padding: 12px 15px;
  font-size: 14px;
  width: 100%;
  background-color: white;
  color: #000000;
  transition: border-color 0.3s ease;
  box-shadow: none;
}
.formulario-registro .form-input:focus,
.formulario-registro .form-select:focus {
  outline: none;
  border-color: white;
  box-shadow: 0 0 0 3px rgba(255, 255, 255, 0.3);
}
.formulario-registro .form-input.error,
.formulario-registro .form-select.error {
  border-color: #e74c3c;
}
.formulario-registro textarea.form-input {
  resize: vertical;
  min-height: 100px;
}

.file-upload-wrapper {
  position: relative;
}
.file-upload-wrapper .file-input {
  position: absolute;
  opacity: 0;
  width: 100%;
  height: 100%;
  cursor: pointer;
}
.file-upload-wrapper .file-upload-button {
  display: flex;
  align-items: center;
  justify-content: space-between;
  border: 2px dashed white;
  border-radius: 0;
  padding: 20px;
  background-color: rgba(255, 255, 255, 0.1);
  cursor: pointer;
  transition: all 0.3s ease;
}
.file-upload-wrapper .file-upload-button:hover {
  border-color: white;
  background-color: rgba(255, 255, 255, 0.2);
}
.file-upload-wrapper .file-upload-button .file-upload-text {
  color: white;
  font-weight: 500;
}
.file-upload-wrapper .file-upload-button .file-upload-icon {
  background-color: #F8DE49;
  color: #2121CF;
  width: 30px;
  height: 30px;
  border-radius: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: bold;
  font-size: 18px;
}

.form-checkbox-wrapper {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  cursor: pointer;
}
.form-checkbox-wrapper .form-checkbox {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
}
.form-checkbox-wrapper .checkbox-custom {
  width: 20px;
  height: 20px;
  border: 2px solid white;
  border-radius: 0;
  background-color: transparent;
  position: relative;
  flex-shrink: 0;
  transition: all 0.3s ease;
}
.form-checkbox-wrapper .checkbox-custom::after {
  content: "";
  position: absolute;
  top: 2px;
  left: 6px;
  width: 6px;
  height: 10px;
  border: solid white;
  border-width: 0 2px 2px 0;
  transform: rotate(45deg);
  opacity: 0;
  transition: opacity 0.3s ease;
}
.form-checkbox-wrapper .form-checkbox:checked + .checkbox-custom {
  background-color: white;
  border-color: white;
}
.form-checkbox-wrapper .form-checkbox:checked + .checkbox-custom::after {
  opacity: 1;
  border-color: #2121CF;
}
.form-checkbox-wrapper .checkbox-text {
  color: white;
  font-size: 14px;
  line-height: 1.4;
}
.form-checkbox-wrapper .checkbox-link {
  color: white;
  text-decoration: underline;
  text-underline-offset: 2px;
  transition: all 0.3s ease;
}
.form-checkbox-wrapper .checkbox-link:hover {
  color: #F8DE49;
  text-decoration: underline;
}

.formulario-submit-section {
  text-align: center;
  margin-top: 40px;
}

.formulario-submit-btn {
  background-color: #F8DE49;
  color: #2121CF;
  border: none;
  padding: 20px 80px;
  font-size: 20px;
  font-weight: 700;
  border-radius: 0;
  cursor: pointer;
  transition: all 0.3s ease;
  text-transform: uppercase;
  min-width: 250px;
}
.formulario-submit-btn:hover {
  background-color: #F7D83F;
  transform: translateY(-2px);
  box-shadow: 0 5px 15px rgba(248, 222, 73, 0.4);
}
.formulario-submit-btn:active {
  transform: translateY(0);
}
@media (max-width: 768px) {
  .formulario-submit-btn {
    padding: 18px 60px;
    font-size: 18px;
    min-width: 200px;
  }
}

.formulario-section-title {
  font-size: 24px;
  font-weight: 700;
  color: white;
  margin: 0 0 30px 0;
  text-transform: uppercase;
  border-bottom: 2px solid #F8DE49;
  padding-bottom: 10px;
}

.form-help {
  color: rgba(255, 255, 255, 0.8);
  font-size: 12px;
  margin-top: 5px;
}

@media (max-width: 768px) {
  .formulario-hero {
    min-height: 600px;
  }
  .formulario-hero .formulario-hero-title {
    font-size: 24px;
  }
  .formulario-hero .formulario-hero-subtitle {
    font-size: 14px;
  }
  .formulario-section {
    padding: 40px 0;
  }
  .formulario-section-title {
    font-size: 20px;
  }
}
.fecha-nacimiento-row {
  display: flex;
  gap: 20px;
}
@media (max-width: 768px) {
  .fecha-nacimiento-row {
    flex-direction: column;
    gap: 10px;
  }
}

.fecha-input-group {
  flex: 1;
  display: flex;
  flex-direction: column;
  min-width: 0;
}

.form-label-small {
  color: white;
  font-weight: 500;
  font-size: 12px;
  margin-bottom: 5px;
  display: block;
}

.fecha-input-group .form-select {
  width: 100%;
  min-width: 0;
}

.formulario-hero-rechazado .formulario-hero-content {
  background-color: #2121CF;
}
.formulario-hero-rechazado .formulario-hero-title {
  color: #F8DE49;
}
.formulario-hero-rechazado .formulario-hero-subtitle {
  color: white;
}
.formulario-hero-rechazado .back-arrow {
  border-color: #F8DE49;
  color: #F8DE49;
}
.formulario-hero-rechazado .back-arrow:hover {
  background-color: #F8DE49;
  color: #2121CF;
}

.formulario-hero-button.failure {
  background-color: #F8DE49;
  color: #2121CF;
  text-decoration: none;
}
.formulario-hero-button.failure:hover {
  background-color: #F7D83F;
  color: #2121CF;
  transform: translateY(-2px);
  box-shadow: 0 5px 15px rgba(248, 222, 73, 0.4);
}

.formulario-hero-link.failure {
  background-color: #F8DE49;
  color: #2121CF;
}
.formulario-hero-link.failure:hover {
  background-color: #F7D83F;
  color: #212176;
}

.mail-link {
  color: #F8DE49;
  text-decoration: none;
  transition: all 0.3s ease;
  word-break: keep-all;
  white-space: nowrap;
  display: inline-block;
}
.mail-link:hover {
  color: #F7D83F;
  text-decoration: none;
}
.mail-link:focus {
  outline: 2px solid #F8DE49;
  outline-offset: 2px;
}

.politicas-privacidad .hero-politicas {
  width: 100%;
  height: 85vh;
  overflow: hidden;
  position: relative;
}
.politicas-privacidad .hero-politicas .hero-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}
.politicas-privacidad .underline-title {
  width: 20%;
  height: 3px;
  background-color: #F8DE49;
  margin-bottom: 1.5rem;
}
.politicas-privacidad .container-politicas {
  max-width: 1200px;
  margin: 0 auto;
  padding: 2rem;
  background: #fff;
}
.politicas-privacidad .container-politicas .header-politicas {
  margin-bottom: 3rem;
}
.politicas-privacidad .container-politicas .header-politicas h1 {
  color: #000000;
  font-size: 2rem;
  font-weight: 700;
  margin-bottom: 1rem;
  text-transform: uppercase;
  letter-spacing: 1px;
}
.politicas-privacidad .container-politicas .content-politicas .seccion-politica {
  margin-bottom: 2rem;
}
.politicas-privacidad .container-politicas .content-politicas .seccion-politica h2 {
  color: #000000;
  font-size: 1.2rem;
  font-weight: 700;
  margin-bottom: 1rem;
  text-transform: uppercase;
}
.politicas-privacidad .container-politicas .content-politicas .seccion-politica p {
  color: #000000;
  font-size: 0.95rem;
  line-height: 1.6;
  margin-bottom: 1.5rem;
  text-align: justify;
}
.politicas-privacidad .container-politicas .content-politicas .seccion-politica ul,
.politicas-privacidad .container-politicas .content-politicas .seccion-politica ol {
  margin: 0 0 1.5rem 1.5rem;
  padding-left: 1.5rem;
  color: #000000;
  font-size: 0.95rem;
  line-height: 1.6;
}
.politicas-privacidad .container-politicas .content-politicas .seccion-politica ul {
  list-style-type: disc;
}
.politicas-privacidad .container-politicas .content-politicas .seccion-politica ul ul {
  list-style-type: circle;
}
.politicas-privacidad .container-politicas .content-politicas .seccion-politica ol {
  list-style-type: decimal;
}
.politicas-privacidad .container-politicas .content-politicas .seccion-politica li {
  margin-bottom: 1rem;
}
.politicas-privacidad .container-politicas .content-politicas .seccion-politica .separador-seccion {
  width: 100%;
  height: 1px;
  background-color: #A2A2A2;
  margin: 1.5rem 0 2rem 0;
}
.politicas-privacidad .container-politicas .logos-footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 3rem;
  padding-top: 2rem;
  border-top: 1px solid #e0e0e0;
}
.politicas-privacidad .container-politicas .logos-footer .logo-item img {
  max-height: 60px;
  width: auto;
}
@media (max-width: 768px) {
  .politicas-privacidad .hero-politicas {
    height: calc(100vh - 60px);
  }
  .politicas-privacidad .container-politicas {
    padding: 1rem;
  }
  .politicas-privacidad .container-politicas .header-politicas h1 {
    font-size: 1.5rem;
  }
  .politicas-privacidad .container-politicas .content-politicas .seccion-politica h2 {
    font-size: 1rem;
  }
  .politicas-privacidad .container-politicas .logos-footer {
    flex-direction: column;
    gap: 1rem;
    text-align: center;
  }
}

html * {
  font-family: "Helvetica Neue";
}

body {
  overflow-x: hidden;
}

.about-section {
  width: 100%;
  background-color: white;
  position: relative;
  overflow: hidden;
  justify-content: space-between;
}

.about-container {
  display: flex;
  width: 100vw;
  margin: 0 auto;
  position: relative;
  height: 100vh;
  min-height: 700px;
  max-height: 845px;
}
@media (max-width: 992px) {
  .about-container {
    height: 80vh;
  }
}
@media (max-width: 768px) {
  .about-container {
    flex-direction: column;
    height: auto;
    max-height: none;
  }
}

.about-content {
  flex: 0 0 50%;
  padding: 180px 100px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
@media (max-width: 1200px) {
  .about-content {
    padding: 120px 60px;
  }
}
@media (max-width: 992px) {
  .about-content {
    padding: 80px 40px;
  }
}
@media (max-width: 768px) {
  .about-content {
    flex: 0 0 100%;
    padding: 60px 20px;
    margin-bottom: 0;
  }
}

.about-section-subtitle {
  font-size: 14px;
  font-family: "Helvetica Neue";
  font-weight: 400;
  line-height: 150%;
  margin-bottom: 10px;
  color: #000000;
}

.about-main-heading {
  font-size: clamp(28px, 4vw, 40px);
  font-family: "Helvetica Neue";
  font-weight: 700;
  line-height: 150%;
  margin-bottom: 10px;
  color: #000000;
  text-transform: uppercase;
}

.about-heading-underline {
  width: 200px;
  height: 2px;
  margin: 20px;
  margin: 20px 0px 30px;
  background-color: #2121CF;
}
@media (max-width: 768px) {
  .about-heading-underline {
    width: 150px;
    margin: 15px 0 25px;
  }
}

.about-description {
  font-size: clamp(16px, 2vw, 20px);
  font-family: "Helvetica Neue";
  font-weight: 300;
  line-height: 150%;
  color: #000000;
}
.about-description p {
  margin-bottom: 20px;
}
.about-description p:last-child {
  margin-bottom: 0;
}

.about-image {
  flex: 0 0 50%;
  position: relative;
  height: 100%;
}
@media (max-width: 768px) {
  .about-image {
    flex: 0 0 100%;
    height: auto;
    aspect-ratio: 16/9;
    min-height: unset;
  }
}

.about-featured-image {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
}

.en-que-consiste-container {
  display: flex;
  padding: 240px 100px;
  background-color: white;
  max-width: 1500px;
  margin: 0 auto;
  position: relative;
  line-height: 150%;
  overflow: visible;
}
@media (max-width: 768px) {
  .en-que-consiste-container {
    padding: 80px 40px;
  }
}
@media (max-width: 480px) {
  .en-que-consiste-container {
    padding: 60px 20px;
  }
}
@media (max-width: 768px) {
  .en-que-consiste-container {
    flex-direction: column;
    padding: 40px 20px;
    max-width: 500px;
  }
}
@media (max-width: 480px) {
  .en-que-consiste-container {
    padding: 30px 15px;
  }
}

.en-que-consiste-content {
  flex: 1;
  padding-right: 40px;
  gap: 24px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-height: 100%;
}
@media (max-width: 768px) {
  .en-que-consiste-content {
    padding-right: 0;
    margin-bottom: 80px;
    width: 100%;
  }
}

.en-que-consiste-subtitle {
  font-size: 14px;
  font-family: "Helvetica Neue";
  font-weight: 400;
  line-height: 150%;
  margin-bottom: 24px;
  color: #000000;
}

.en-que-consiste-title {
  padding-right: 20px;
  font-size: 40px;
  font-family: "Helvetica Neue";
  font-weight: 700;
  line-height: 150%;
  margin-bottom: 25px;
  position: relative;
  color: #000000;
  text-transform: uppercase;
}
.en-que-consiste-title:after {
  content: "";
  display: block;
  width: 200px;
  height: 2px;
  background-color: #2121CF;
  margin-top: 48px;
}
@media (max-width: 768px) {
  .en-que-consiste-title {
    padding-right: 0;
  }
}

.en-que-consiste-description {
  font-size: 20px;
  font-family: "Helvetica Neue";
  font-weight: 300;
  line-height: 150%;
  padding-right: 20px;
  margin-bottom: 30px;
  color: #000000;
}
@media (max-width: 768px) {
  .en-que-consiste-description {
    padding-right: 0;
  }
}

.en-que-consiste-image-container {
  flex: 1;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: visible;
  margin-right: 40px;
}
@media (max-width: 768px) {
  .en-que-consiste-image-container {
    margin: 40px;
    width: 90%;
    overflow: visible;
  }
}

.en-que-consiste-image-wrapper {
  position: relative;
  width: 100%;
  max-width: 100%;
}

.en-que-consiste-image-frame {
  position: relative;
  max-width: 100%;
}
.en-que-consiste-image-frame .featured-image {
  display: block;
  width: 100%;
  height: auto;
}

.rectangle-overlay {
  position: absolute;
  top: -48px;
  left: -48px;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
@media (max-width: 768px) {
  .rectangle-overlay {
    top: -34px;
    left: -34px;
  }
}

.en-que-consiste-decorative-svg {
  position: absolute;
  top: -135px;
  right: -106px;
  width: 279px;
  height: 265px;
  pointer-events: none;
  overflow: visible;
}
.en-que-consiste-decorative-svg svg {
  width: 100%;
  height: 100%;
  overflow: visible;
}
@media (max-width: 1200px) {
  .en-que-consiste-decorative-svg svg {
    scale: 0.9;
  }
}
@media (max-width: 1100px) {
  .en-que-consiste-decorative-svg svg {
    scale: 0.8;
  }
}
@media (max-width: 1000px) {
  .en-que-consiste-decorative-svg svg {
    scale: 0.7;
  }
}
@media (max-width: 768px) {
  .en-que-consiste-decorative-svg {
    top: -144px;
    scale: 0.8;
    right: 65px;
    width: 120px;
    height: 120px;
    overflow: visible;
  }
}

.visual-asterisk {
  position: absolute;
  right: 112px;
  top: 85px;
  width: 77px;
  height: 71px;
  background-image: url("assets/icons/visual-asterisk.svg");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  display: block;
}
.visual-asterisk::before {
  display: none;
}
@media (max-width: 768px) {
  .visual-asterisk {
    width: 45px;
    height: 42px;
    right: -25px;
    top: 97px;
  }
}
.visual-sparkle {
  position: absolute;
  right: 33px;
  width: 101px;
  height: 140px;
  background-image: url("assets/icons/visual-sparkle.svg");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  display: block;
}
.visual-sparkle::before {
  display: none;
}
@media (max-width: 768px) {
  .visual-sparkle {
    width: 59px;
    height: 82px;
    right: -71px;
    top: 50px;
  }
}
.jury-section {
  width: 100%;
  padding: 0;
  overflow: visible;
  position: relative;
}
.jury-section .jury-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  overflow: hidden;
}
.jury-section .jury-overlay img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0.75;
}
.jury-section .jury-container {
  margin: 0 auto;
  padding: 200px 100px;
  background-color: #2121CF;
  color: white;
  display: flex;
  position: relative;
  overflow: visible;
  gap: 10px;
  background-image: radial-gradient(circle, rgba(69, 69, 153, 0.7) 0%, #2121CF 70%);
  align-items: center;
  min-height: 800px;
}
@media (max-width: 1600px) {
  .jury-section .jury-container {
    max-width: 100%;
  }
}
@media (max-width: 992px) {
  .jury-section .jury-container {
    flex-direction: column;
    padding: 100px 50px 500px;
    align-items: flex-start;
    min-height: 1000px;
  }
}
@media (max-width: 576px) {
  .jury-section .jury-container {
    padding: 80px 30px 450px;
  }
}
.jury-section .jury-content {
  flex: 1;
  max-width: 50%;
  padding-right: 40px;
}
@media (max-width: 992px) {
  .jury-section .jury-content {
    max-width: 100%;
    padding-right: 0;
    margin-bottom: 60px;
    text-align: left;
  }
}
.jury-section .jury-section-title {
  font-family: "Helvetica Neue";
  font-size: 14px;
  line-height: 150%;
  font-weight: 400;
  margin-bottom: 10px;
  color: white;
  opacity: 1;
}
.jury-section .jury-main-heading {
  font-family: "Helvetica Neue";
  font-size: 40px;
  line-height: 150%;
  font-weight: 700;
  margin-bottom: 20px;
  color: white;
  position: relative;
  text-transform: uppercase;
  opacity: 1;
}
@media (max-width: 576px) {
  .jury-section .jury-main-heading {
    font-size: 32px;
  }
}
.jury-section .heading-underline {
  width: 200px;
  height: 2px;
  background-color: #F8DE49;
  margin: 20px 0 30px;
  opacity: 1;
}
.jury-section .jury-description {
  font-family: "Helvetica Neue";
  font-size: 20px;
  line-height: 150%;
  font-weight: 300;
  margin-bottom: 30px;
  max-width: 600px;
  padding-right: 20px;
  opacity: 1;
}
@media (max-width: 576px) {
  .jury-section .jury-description {
    font-size: 18px;
  }
}
.jury-section .jury-description p {
  margin-bottom: 20px;
}
.jury-section .jury-voting-methods {
  margin-top: 30px;
}
.jury-section .voting-method {
  display: flex;
  align-items: center;
  margin-bottom: 15px;
  font-family: "Helvetica Neue";
  font-size: 30px;
  line-height: 150%;
  font-style: italic;
  text-transform: uppercase;
  font-weight: 700;
  opacity: 1;
}
@media (max-width: 576px) {
  .jury-section .voting-method {
    font-size: 22px;
  }
}
.jury-section .voting-method .arrow-icon {
  margin-right: 15px;
  font-size: 24px;
}
@media (max-width: 576px) {
  .jury-section .voting-method .arrow-icon {
    font-size: 18px;
  }
}
.jury-section .voting-method .method-name {
  font-style: italic;
  font-weight: bold;
  text-transform: uppercase;
  font-size: 30px;
}
@media (max-width: 576px) {
  .jury-section .voting-method .method-name {
    font-size: 22px;
  }
}
.jury-section .jury-images {
  flex: 1;
  position: relative;
  display: flex;
  justify-content: flex-end;
  align-items: center;
  height: 500px;
  width: 100%;
}
@media (max-width: 992px) {
  .jury-section .jury-images {
    height: 400px;
    justify-content: center;
    margin-top: 20px;
    position: relative;
    width: 100%;
  }
}
@media (max-width: 576px) {
  .jury-section .jury-images {
    height: 350px;
  }
}
.jury-section .jury-image {
  position: absolute;
}
.jury-section .jury-image img {
  display: block;
  max-width: 100%;
  height: auto;
  border-radius: 0;
  opacity: 1;
}
.jury-section .image-1 {
  width: 309px;
  height: 484px;
  right: 240px;
}
@media (max-width: 1200px) {
  .jury-section .image-1 {
    width: 250px;
    right: 200px;
  }
}
@media (max-width: 992px) {
  .jury-section .image-1 {
    width: 220px;
    height: auto;
    right: auto;
    left: calc(50% - 220px - 20px);
    top: 0;
    transform: none;
    position: absolute;
  }
}
@media (max-width: 576px) {
  .jury-section .image-1 {
    width: 180px;
    left: calc(50% - 180px - 10px);
  }
}
.jury-section .image-2 {
  width: 202px;
  height: 398px;
  top: 80%;
  right: 0;
  transform: translateY(-50%);
}
@media (max-width: 1200px) {
  .jury-section .image-2 {
    width: 160px;
  }
}
@media (max-width: 992px) {
  .jury-section .image-2 {
    width: 160px;
    height: auto;
    right: auto;
    left: calc(50% + 20px);
    top: 40px;
    transform: none;
    position: absolute;
  }
}
@media (max-width: 576px) {
  .jury-section .image-2 {
    width: 140px;
    left: calc(50% + 10px);
  }
}

.prizes-section {
  width: 100%;
  position: relative;
  display: flex;
  flex-direction: column;
}

.prizes-image-container {
  width: 100%;
  height: 40vh;
  min-height: 300px;
  overflow: hidden;
  position: relative;
}
@media (max-width: 768px) {
  .prizes-image-container {
    height: 30vh;
    min-height: 200px;
  }
}

.prizes-featured-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

.prizes-content-wrapper {
  width: 100%;
  background-color: white;
  padding: 60px 0;
  display: flex;
  justify-content: center;
  align-items: center;
}
@media (max-width: 768px) {
  .prizes-content-wrapper {
    padding: 40px 20px;
  }
}

.prizes-content {
  width: 100%;
  text-align: center;
  padding: 0 20px;
  gap: 24px;
}

.prizes-section-subtitle {
  font-size: 16px;
  font-family: "Helvetica Neue";
  font-weight: 400;
  line-height: 150%;
  margin-bottom: 20px;
  color: #000000;
  text-transform: uppercase;
}

.star-icon {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 20px auto;
}
.star-icon img {
  width: 63px;
  height: 54px;
  height: auto;
  display: block;
}

.prizes-main-heading {
  font-size: 40px;
  font-family: "Helvetica Neue";
  font-weight: 700;
  line-height: 150%;
  margin-bottom: 10px;
  color: #000000;
  text-transform: uppercase;
}

.heading-underline {
  width: 200px;
  height: 2px;
  background-color: #2121CF;
  margin: 20px auto 30px;
}

.prizes-description {
  font-size: 20px;
  font-family: "Helvetica Neue";
  font-weight: 300;
  line-height: 150%;
  color: #000000;
  margin-bottom: 50px;
  margin-left: auto;
  margin-right: auto;
}

.prizes-boxes {
  display: flex;
  justify-content: center;
  align-items: flex-end;
  gap: 24px;
  margin-top: 40px;
  padding-bottom: 20px;
}
@media (max-width: 992px) {
  .prizes-boxes {
    flex-direction: column;
    align-items: center;
    gap: 20px;
  }
}

.prize-box {
  background-color: #2121CF;
  color: white;
  padding: 44px 60px;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: center;
  width: 417px;
  height: 262px;
}
@media (max-width: 992px) {
  .prize-box {
    width: 100%;
    max-width: 400px;
    height: auto;
    min-height: 220px;
    padding: 30px 20px;
  }
}

.prize-first {
  height: 295px;
  padding: 50px 60px;
}
@media (max-width: 992px) {
  .prize-first {
    order: -1;
    height: auto;
    min-height: 240px;
  }
}

.prize-amount {
  font-size: 68px;
  font-weight: 700;
  color: #F8DE49;
  margin-bottom: 20px;
  line-height: 125%;
}
.prize-first .prize-amount {
  font-size: 80px;
}

.prize-details {
  font-size: 18px;
  font-weight: 300;
  line-height: 125%;
  text-align: center;
}

.prizes-button-container {
  margin-top: 50px;
}

.donde-section {
  width: 100%;
  position: relative;
  display: flex;
  flex-direction: column;
}

.donde-image-container {
  width: 100%;
  height: 50vh;
  min-height: 400px;
  overflow: hidden;
  position: relative;
}
@media (max-width: 768px) {
  .donde-image-container {
    height: auto;
    min-height: unset;
    aspect-ratio: 16/9;
  }
}

.donde-featured-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  position: relative;
}

.donde-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
}
.donde-overlay img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0.25;
  transform: rotate(180deg);
}

.donde-content-wrapper {
  width: 100%;
  background-color: #F8DE49;
  padding: 130px 0;
  display: flex;
  justify-content: center;
  align-items: center;
}
@media (max-width: 768px) {
  .donde-content-wrapper {
    padding: 60px 0;
  }
}
@media (max-width: 480px) {
  .donde-content-wrapper {
    padding: 40px 0;
  }
}

.donde-content {
  max-width: 1500px;
  text-align: center;
  padding: 0 209px;
}
@media (max-width: 1024px) {
  .donde-content {
    padding: 0 100px;
  }
}
@media (max-width: 768px) {
  .donde-content {
    padding: 0 40px;
  }
}
@media (max-width: 480px) {
  .donde-content {
    padding: 0 20px;
  }
}

.donde-section-subtitle {
  font-size: 16px;
  font-family: "Helvetica Neue";
  font-weight: 400;
  line-height: 150%;
  margin-bottom: 10px;
  color: #000000;
}

.donde-main-heading {
  font-size: clamp(32px, 5vw, 48px);
  font-family: "Helvetica Neue";
  font-weight: 700;
  line-height: 120%;
  margin-bottom: 10px;
  color: #000000;
  text-transform: uppercase;
}

.heading-underline {
  width: 200px;
  height: 2px;
  background-color: #2121CF;
  margin: 20px auto 30px;
}

.donde-description {
  font-size: 20px;
  font-family: "Helvetica Neue";
  font-weight: 300;
  line-height: 150%;
  color: #000000;
  margin-bottom: 30px;
  max-width: 1500px;
  margin-left: auto;
  margin-right: auto;
}

.donde-button-container {
  margin-top: 30px;
}

.ganadoras-section .ganadoras-header {
  background-color: #2121CF;
  padding-top: 180px;
  padding-bottom: 40px;
  padding-left: 40px;
  padding-right: 80px;
  gap: 10px;
  margin-bottom: 0;
  justify-content: left;
}
.ganadoras-section .ganadoras-header-inner {
  width: 100%;
}
.ganadoras-section .ganadoras-header h2 {
  color: #F8DE49;
  font-size: 90px;
  font-weight: 700;
  font-style: bold;
  line-height: 111%;
  text-transform: uppercase;
  margin: 0;
}
.ganadoras-section .ganadoras-content-wrapper {
  width: 100%;
  padding: 0;
}
.ganadoras-section .ganadoras-content {
  display: flex;
  margin-top: 0;
  background-color: #fff;
  max-width: 100%;
  border: 1px solid #e0e0e0;
}
.ganadoras-section .ganadoras-tabs {
  display: flex;
  flex-direction: column;
  padding: 20px;
  justify-content: center;
  background-color: #fff;
}
.ganadoras-section .ganadoras-tab {
  width: 60px;
  height: 60px;
  background-color: #F8DE49;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 28px;
  font-weight: bold;
  margin-bottom: 20px;
  color: #2121CF;
  cursor: pointer;
  transition: all 0.2s ease;
  opacity: 0.2;
  border: none;
  padding: 0;
}
.ganadoras-section .ganadoras-tab:hover {
  transform: scale(1.05);
}
.ganadoras-section .ganadoras-tab.active {
  opacity: 1;
}
.ganadoras-section .ganadoras-tab:last-child {
  margin-bottom: 0;
}
.ganadoras-section .ganadoras-tab:focus {
  outline: none;
  opacity: 1;
  box-shadow: 0 0 0 3px rgba(33, 33, 207, 0.5);
}
.ganadoras-section .ganadoras-tab.active:focus {
  box-shadow: none;
}
.ganadoras-section .ganadoras-panels {
  flex: 1;
  display: flex;
  width: 100%;
}
.ganadoras-section .ganadoras-imagen-container {
  flex: 0 0 50%;
  max-width: 50%;
  overflow: hidden;
  height: 500px;
  transition: opacity 0.3s ease;
  display: flex;
}
@media (min-width: 769px) {
  .ganadoras-section .ganadoras-imagen-container {
    position: relative;
  }
}
.ganadoras-section .ganadoras-imagen-container .ganadoras-imagen {
  width: 100%;
  height: 100%;
  opacity: 1;
  object-fit: cover;
  object-position: center;
  display: block;
}
@media (min-width: 769px) {
  .ganadoras-section .ganadoras-imagen-container .ganadoras-imagen {
    position: absolute;
    top: 0;
    left: 0;
    min-height: 500px;
  }
}
.ganadoras-section .ganadoras-info {
  flex: 0 0 50%;
  max-width: 50%;
  display: flex;
  align-items: center;
  background-color: #fff;
  padding: 20px;
}
.ganadoras-section .ganadoras-info-inner {
  background-color: #fff9d6;
  padding: 20px;
  border-radius: 0;
  display: flex;
  flex-direction: column;
  transition: opacity 0.3s ease;
  width: 80%;
}
.ganadoras-section .ganadoras-categoria {
  background-color: #F8DE49;
  display: block;
  padding: 8px 15px;
  margin: -20px -20px 15px -20px;
  font-size: 16px;
  font-weight: bold;
}
.ganadoras-section .ganadoras-titulo {
  color: #2121CF;
  font-size: 28px;
  margin: 0 0 10px;
  font-weight: bold;
}
.ganadoras-section .ganadoras-autor {
  color: #2121CF;
  font-size: 18px;
  margin-bottom: 10px;
}
.ganadoras-section .ganadoras-description {
  font-size: 14px;
  line-height: 1.4;
  margin-bottom: 15px;
  color: #333;
}
.ganadoras-section .ganadoras-votos {
  color: #666;
  font-size: 16px;
  margin-top: auto;
}
.ganadoras-section .ganadoras-no-content {
  width: 100%;
  padding: 50px;
  text-align: center;
  background-color: #f9f9f9;
}
.ganadoras-section .ganadoras-no-content p {
  font-size: 18px;
  color: #666;
}
@keyframes fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@media (max-width: 1024px) {
  .ganadoras-section .ganadoras-header {
    padding: 120px 40px 40px;
  }
  .ganadoras-section .ganadoras-header h2 {
    font-size: 72px;
  }
  .ganadoras-section .ganadoras-info-inner {
    width: 90%;
    margin: 0 auto;
  }
  .ganadoras-section .ganadoras-tabs {
    padding: 30px 20px;
  }
}
@media (max-width: 768px) {
  .ganadoras-section .ganadoras-header {
    padding: 80px 20px 30px;
  }
  .ganadoras-section .ganadoras-header h2 {
    font-size: 48px;
    line-height: 1.2;
  }
  .ganadoras-section .ganadoras-content {
    flex-direction: column;
  }
  .ganadoras-section .ganadoras-panels {
    flex-direction: column;
    width: 100%;
  }
  .ganadoras-section .ganadoras-imagen-container {
    order: 1;
    width: 100%;
    max-width: 100%;
    height: 300px;
    display: flex;
    flex-direction: column;
    position: static;
  }
  .ganadoras-section .ganadoras-imagen-container .ganadoras-imagen {
    width: 100%;
    height: 100%;
    position: static;
    display: block;
    object-fit: cover;
  }
  .ganadoras-section .ganadoras-tabs {
    order: 2;
    flex-direction: row;
    justify-content: center;
    padding: 15px;
    background-color: transparent;
    position: static;
    gap: 10px;
  }
  .ganadoras-section .ganadoras-tab {
    width: 45px;
    height: 45px;
    font-size: 20px;
    margin: 0;
    background-color: white;
    color: #2121CF;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: bold;
    opacity: 0.5;
    border: none;
    transition: all 0.2s ease;
  }
  .ganadoras-section .ganadoras-tab.active {
    background-color: #F8DE49;
    opacity: 1;
  }
  .ganadoras-section .ganadoras-info {
    order: 3;
    flex: 0 0 auto;
    max-width: 100%;
    padding: 20px 15px;
  }
  .ganadoras-section .ganadoras-info-inner {
    width: 100%;
    padding: 15px;
  }
  .ganadoras-section .ganadoras-categoria {
    font-size: 14px;
    padding: 6px 12px;
    margin: -15px -15px 12px -15px;
  }
  .ganadoras-section .ganadoras-titulo {
    font-size: 24px;
    margin-bottom: 8px;
  }
  .ganadoras-section .ganadoras-autor {
    font-size: 16px;
    margin-bottom: 12px;
  }
  .ganadoras-section .ganadoras-description {
    font-size: 14px;
    line-height: 1.5;
    margin-bottom: 12px;
  }
  .ganadoras-section .ganadoras-votos {
    font-size: 14px;
  }
}
@media (max-width: 480px) {
  .ganadoras-section .ganadoras-header {
    padding: 60px 15px 25px;
  }
  .ganadoras-section .ganadoras-header h2 {
    font-size: 36px;
  }
  .ganadoras-section .ganadoras-imagen-container {
    height: auto;
  }
  .ganadoras-section .ganadoras-tab {
    width: 40px;
    height: 40px;
    font-size: 18px;
  }
  .ganadoras-section .ganadoras-info {
    padding: 15px 10px;
  }
  .ganadoras-section .ganadoras-info-inner {
    padding: 12px;
  }
  .ganadoras-section .ganadoras-titulo {
    font-size: 20px;
  }
}

body,
html {
  margin: 0;
  padding: 0;
  overflow-x: hidden;
}

/*# sourceMappingURL=style.css.map */
