/* =====================================================

   Las Estrellas Brand Check — CSS Global

   Paleta: Negro profundo + Dorado + Blanco

   Fuentes: Pacifico (global) | Double Bubble 3D (countdown) | Cinzel + Raleway (contenido agenda y reglamento)

   NOTA: Reemplaza las variables de color y fuente

         cuando el cliente entregue los assets.

   ===================================================== */



/* ─── FUENTES LOCALES ────────────────────────────── */

@font-face {

  font-family: 'Pacifico';

  src: url('../fonts/Pacifico-Regular.ttf') format('truetype');

  font-weight: normal;

  font-style: normal;

  font-display: swap;

}

@font-face {

  font-family: 'Double Bubble 3D';

  src: url('../fonts/Double Bubble 3D.ttf') format('truetype');

  font-weight: normal;

  font-style: normal;

  font-display: swap;

}

@font-face {

  font-family: 'Montserrat';

  src: url('../fonts/Montserrat-Regular.ttf') format('truetype');

  font-weight: 400;

  font-style: normal;

  font-display: swap;

}

@font-face {

  font-family: 'Montserrat';

  src: url('../fonts/Montserrat-Medium.ttf') format('truetype');

  font-weight: 500;

  font-style: normal;

  font-display: swap;

}

@font-face {

  font-family: 'Montserrat';

  src: url('../fonts/Montserrat-SemiBold.ttf') format('truetype');

  font-weight: 600;

  font-style: normal;

  font-display: swap;

}

@font-face {

  font-family: 'Montserrat';

  src: url('../fonts/Montserrat-Bold.ttf') format('truetype');

  font-weight: 700;

  font-style: normal;

  font-display: swap;

}



/* ─── VARIABLES ─────────────────────────────────── */

:root {

  --c-bg:         #0d0618;

  --c-bg-card:    #1a0f2e;

  --c-bg-card2:   #231545;

  --c-primary:    #4CB400;

  --c-primary-l:  #5fd400;

  --c-primary-d:  #368200;

  --c-accent:     #7b2d8b;

  --c-gold:       #C6941A;

  --c-gold-l:     #E0AD2C;

  --c-gold-d:     #A17815;

  --c-text:       #f0eaf8;

  --c-text-muted: #a89ec0;

  --c-border:     rgba(201,162,39,.25);

  --c-danger:     #e53e3e;

  --c-success:    #38a169;

  --c-warning:    #d97706;

  --c-info:       #3182ce;



  --font-title:   'Pacifico',  Georgia, serif;

  --font-body:    'Pacifico',  'Segoe UI', sans-serif;



  /* Fuentes de respaldo para páginas excluidas */

  --font-title-alt: 'Cinzel',    Georgia, serif;

  --font-body-alt:  'Raleway',   'Segoe UI', sans-serif;



  --radius:       12px;

  --radius-sm:    6px;

  --shadow:       0 4px 24px rgba(0,0,0,.55);

  --transition:   .25s ease;

  --nav-h:        70px;

}



/* ─── EXCLUSIONES DE FUENTE (solo contenido de agenda y reglamento) ── */

/* El resto de la página (nav, hero, footer…) sigue con Pacifico.      */

/* Solo los divs de contenido real usan Cinzel + Raleway.              */

.agenda-lista,

.agenda-lista *,

.reglamento-content,

.reglamento-content * {

  font-family: var(--font-body-alt);

}

.agenda-lista h1, .agenda-lista h2,

.agenda-lista h3, .agenda-lista h4,

.agenda-lista .hora-inicio,

.agenda-lista .agenda-titulo,

.reglamento-content h1, .reglamento-content h2,

.reglamento-content h3, .reglamento-content h4,

.reglamento-content .accordion-header {

  font-family: var(--font-title-alt);

}



/* ─── RESET / BASE ───────────────────────────────── */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; }

body {

  font-family: var(--font-body);

  background: linear-gradient(135deg, #0d0618 0%, #1a0f3a 50%, #0d0618 100%);

  background-attachment: fixed;

  color: var(--c-text);

  font-size: 16px;

  line-height: 1.65;

  min-height: 100vh;

  position: relative;

  overflow-x: hidden;

}

body::before {

  content: '';

  position: fixed;

  inset: 0;

  background-image: 

    radial-gradient(2px 2px at 20% 30%, #eee, rgba(0,0,0,0)),

    radial-gradient(2px 2px at 60% 70%, #fff, rgba(0,0,0,0)),

    radial-gradient(1px 1px at 50% 50%, #ddd, rgba(0,0,0,0)),

    radial-gradient(1px 1px at 80% 10%, #fff, rgba(0,0,0,0)),

    radial-gradient(2px 2px at 90% 60%, #eee, rgba(0,0,0,0)),

    radial-gradient(1px 1px at 30% 80%, #fff, rgba(0,0,0,0)),

    radial-gradient(1px 1px at 70% 40%, #ddd, rgba(0,0,0,0)),

    radial-gradient(2px 2px at 10% 90%, #eee, rgba(0,0,0,0));

  background-size: 

    200% 200%,

    150% 150%,

    180% 180%,

    160% 160%,

    220% 220%,

    190% 190%,

    170% 170%,

    210% 210%;

  background-position: 

    0% 0%,

    40% 60%,

    50% 50%,

    80% 20%,

    90% 70%,

    30% 80%,

    70% 40%,

    10% 90%;

  background-repeat: repeat;

  opacity: 0.6;

  animation: twinkle 8s ease-in-out infinite alternate;

  pointer-events: none;

  z-index: 0;

  mix-blend-mode: screen;

}

body > * {

  position: relative;

  z-index: 1;

}

@keyframes twinkle {

  0%, 100% { opacity: 0.6; }

  50% { opacity: 0.9; }

}

a { color: var(--c-gold-l); text-decoration: none; transition: color var(--transition); }

a:hover { color: #fff; }

img { max-width: 100%; display: block; }

h1,h2,h3,h4 { font-family: var(--font-title); line-height: 1.25; }

input,select,textarea,button { font-family: var(--font-body); }

.container { max-width: 1400px; margin: 0 auto; padding: 0 20px; }



/* ─── NAVBAR ─────────────────────────────────────── */

.navbar {

  position: fixed; top: 0; left: 0; right: 0; z-index: 2000;

  height: var(--nav-h);

  background: rgba(13,6,24,.92);

  backdrop-filter: blur(14px);

  border-bottom: 1px solid var(--c-border);

  display: flex; align-items: center; justify-content: space-between;

  padding: 0 24px;

  transition: background var(--transition);

}

.navbar.scrolled { background: rgba(13,6,24,.98); }



.nav-brand a { display: flex; align-items: center; gap: 10px; }

.nav-logo    { height: 42px; object-fit: contain; }

.nav-logo-1  { height: 42px; }

.nav-brand-right { display: flex; align-items: center; margin-left: auto; margin-right: 16px; }

.nav-logo-2  { height: 42px; }

@media (max-width: 640px) { .nav-brand-right { display: none; } }



/* Hamburger — visible siempre */

.nav-toggle {

  display: flex; flex-direction: column; justify-content: space-between;

  width: 28px; height: 20px; background: none; border: none; cursor: pointer;

}

.nav-toggle span { display: block; width: 100%; height: 2px; background: var(--c-gold); border-radius: 2px; transition: all var(--transition); }



/* Menú — panel lateral en todos los dispositivos */

.nav-menu {

  list-style: none;

  position: fixed;

  top: 0; left: 0; right: auto; bottom: 0;

  height: auto;

  width: 280px; max-width: 85vw;

  flex-direction: column; align-items: flex-start; gap: 0;

  display: flex;

  background: #0d0618;

  padding: 80px 12px 20px;

  overflow-y: auto;

  transform: translateX(-100%);

  transition: transform .3s ease;

  z-index: 2100;

  box-shadow: 4px 0 24px rgba(0,0,0,.6);

}

.nav-menu.open { transform: translateX(0); }

.nav-menu a {

  display: flex; align-items: center; gap: 8px;

  padding: 14px 16px; border-radius: var(--radius-sm);

  color: var(--c-text-muted); font-size: 1rem; font-weight: 500;

  width: 100%;

  transition: background var(--transition), color var(--transition);

}

.nav-menu a:hover, .nav-menu a.active {

  background: rgba(198,148,26,.12);

  color: var(--c-gold-l);

}

.nav-logout { color: var(--c-text-muted) !important; }

.nav-logout:hover { color: var(--c-danger) !important; background: rgba(229,62,62,.1) !important; }

.nav-sep { width: 100%; height: 1px; background: var(--c-border); margin: 8px 0; }

.nav-user-info { display: flex; align-items: center; gap: 8px; padding: 14px 16px; color: var(--c-text-muted); font-size: .9rem; }

.nav-avatar { font-size: 1.3rem; color: var(--c-gold); }



/* Overlay oscuro detrás del menú */

.nav-overlay {

  display: none;

  position: fixed; inset: 0;

  background: rgba(0,0,0,.5);

  z-index: 2099;

}

.nav-overlay.open { display: block; }



/* ─── MAIN CONTENT ───────────────────────────────── */

.main-content { padding-top: var(--nav-h); min-height: calc(100vh - 60px); }



/* ─── HERO / PAGE HERO ───────────────────────────── */

.hero-section {

  position: relative;

  min-height: 100vh;

  display: flex; align-items: center; justify-content: center;

  background: url('../img/Fondo%20portada.png') center/cover no-repeat;

  background-attachment: fixed;

  text-align: center;

}

.hero-overlay {

  position: absolute; inset: 0;

  background: linear-gradient(160deg, rgba(13,6,24,.82) 0%, rgba(123,45,139,.4) 100%);

}

.hero-content {

  position: relative; z-index: 1;

  padding: 40px 20px;

  max-width: 800px;

}

.hero-eyebrow { font-size: .9rem; letter-spacing: .3em; color: var(--c-gold); text-transform: uppercase; margin-bottom: 12px; }

.hero-titulo  { font-size: clamp(2rem, 6vw, 4.5rem); color: #fff; margin-bottom: 20px; text-shadow: 0 2px 20px rgba(0,0,0,.6); }

.hero-subtitulo { color: var(--c-text-muted); margin-bottom: 28px; font-size: 24px; }



.hero-logo-portada {

  max-width: min(560px, 90%);

  width: 100%;

  margin: 0 auto 20px;

  filter: drop-shadow(0 4px 24px rgba(0,0,0,.6));

}



/* PAGE HERO (secciones internas) */

.page-hero {

  position: relative; padding: 80px 0 50px;

  background: url('../img/Fondo%20portada.png') center/cover no-repeat;

  text-align: center;

}

.page-hero--admin   { background-position: center top; }

.page-hero-overlay  { position: absolute; inset: 0; background: rgba(13,6,24,.78); backdrop-filter: blur(2px); }

.page-hero-content  { position: relative; z-index: 1; }

.page-hero-content h1 { font-size: clamp(1.8rem, 4vw, 3rem); color: var(--c-gold-l); }

.page-hero-content p  { color: var(--c-text-muted); margin-top: 8px; }

.breadcrumb-link    { color: var(--c-text-muted) !important; font-size: .85rem; }

.breadcrumb-link:hover { color: var(--c-gold-l) !important; }



/* ─── COUNTDOWN ──────────────────────────────────── */

.countdown {

  display: flex; justify-content: center; align-items: center; gap: 8px;

  margin: 20px 0 32px;

}

.countdown-item {

  display: flex; flex-direction: column; align-items: center;

  background: rgba(255,255,255,.06);

  border: 1px solid var(--c-border);

  border-radius: var(--radius);

  padding: 16px 24px;

  min-width: 90px;

  backdrop-filter: blur(8px);

}

.countdown-num {

  font-family: 'Double Bubble 3D', var(--font-title);

  font-size: clamp(2.2rem, 10vw, 7rem);

  color: var(--c-gold-l);

  line-height: 1;

  text-shadow: 0 0 20px rgba(198,148,26,.4);

}

.countdown-label { font-size: .72rem; letter-spacing: .15em; color: var(--c-text-muted); text-transform: uppercase; margin-top: 6px; }

.countdown-sep   { font-size: 2.5rem; color: var(--c-gold); line-height: 1; padding-bottom: 20px; }



/* ─── HERO ACCESS BUTTONS ────────────────────────── */

.hero-accesos { display: flex; flex-wrap: wrap; justify-content: center; gap: 12px; margin-top: 8px; }

.hero-btn {

  display: inline-flex; align-items: center; gap: 8px;

  padding: 12px 28px; border-radius: 50px;

  background: rgba(198,148,26,.12);

  border: 1px solid var(--c-gold);

  color: var(--c-gold-l);

  font-size: .92rem; font-weight: 600; letter-spacing: .05em;

  transition: all var(--transition);

}

.hero-btn:hover { background: var(--c-gold); color: #0d0618; transform: translateY(-2px); }



/* ─── GRID DE SECCIONES (HOME) ───────────────────── */

.grid-secciones {

  display: grid;

  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));

  gap: 20px;

  padding: 50px 20px;

}

.seccion-card {

  background: var(--c-bg-card);

  border: 1px solid var(--c-border);

  border-radius: var(--radius);

  padding: 32px 24px;

  text-align: center;

  transition: all var(--transition);

  cursor: pointer;

  color: var(--c-text);

}

.seccion-card i  { font-size: 2.5rem; color: var(--c-gold); margin-bottom: 16px; display: block; }

.seccion-card h3 { font-size: 1.1rem; margin-bottom: 8px; color: #fff; }

.seccion-card p  { font-size: .85rem; color: var(--c-text-muted); }

.seccion-card:hover {

  border-color: var(--c-gold);

  transform: translateY(-4px);

  box-shadow: 0 8px 30px rgba(198,148,26,.2);

  color: var(--c-gold-l);

}

.seccion-card--admin { border-color: var(--c-accent); }

.seccion-card--admin i { color: var(--c-accent); }

.seccion-card--admin:hover { border-color: var(--c-accent); box-shadow: 0 8px 30px rgba(123,45,139,.25); }



/* ─── POPUP BIENVENIDA ───────────────────────────── */

.popup-overlay {

  position: fixed; inset: 0; z-index: 9999;

  background: rgba(0,0,0,.8);

  backdrop-filter: blur(6px);

  display: flex; align-items: center; justify-content: center;

  padding: 20px;

  animation: popupIn .4s ease;

}

.popup-overlay.popup-closing { animation: popupOut .4s ease forwards; }

@keyframes popupIn  { from { opacity:0; transform: scale(.85); } to { opacity:1; transform: scale(1); } }

@keyframes popupOut { from { opacity:1; transform: scale(1); } to { opacity:0; transform: scale(.85); } }



.popup-bienvenida {

  background: linear-gradient(145deg, #1a0f2e, #2e1060);

  border: 2px solid var(--c-gold);

  border-radius: 24px;

  padding: 48px 40px 40px;

  text-align: center;

  max-width: 600px; width: 100%;

  box-shadow: 0 0 60px rgba(198,148,26,.3), 0 20px 60px rgba(0,0,0,.6);

  position: relative;

}

.popup-estrellas { display: flex; justify-content: center; gap: 12px; margin-bottom: 20px; }

.popup-estrellas i { color: var(--c-gold); font-size: 1.6rem; animation: starPulse 2s ease infinite; }

.popup-estrellas i:nth-child(2) { animation-delay: .3s; font-size: 2.2rem; }

.popup-estrellas i:nth-child(3) { animation-delay: .6s; }

@keyframes starPulse { 0%,100%{opacity:.7;transform:scale(1)} 50%{opacity:1;transform:scale(1.2)} }



.popup-mensaje {

  font-family: var(--font-title);

  font-size: clamp(1.5rem, 4vw, 2.6rem);

  color: var(--c-gold-l);

  line-height: 1.3;

  margin-bottom: 16px;

  text-shadow: 0 0 30px rgba(198,148,26,.4);

}

.popup-subtexto  { font-size: 1rem; color: var(--c-text-muted); margin-bottom: 24px; }

.popup-nombre    { color: var(--c-gold-l); font-weight: 700; font-size: 1.15rem; }



.popup-timer     { margin-bottom: 24px; }

.popup-timer-barra { background: rgba(255,255,255,.1); border-radius: 10px; height: 6px; overflow: hidden; margin-bottom: 8px; }

.popup-timer-fill  {

  display: block; height: 100%; width: 100%;

  background: linear-gradient(90deg, var(--c-gold), var(--c-gold-l));

  border-radius: 10px;

  animation: timerShrink linear forwards;

}

@keyframes timerShrink { from { width: 100%; } to { width: 0%; } }

.popup-timer-text  { font-size: .85rem; color: var(--c-text-muted); }



.popup-close-btn {

  background: rgba(198,148,26,.12);

  border: 1px solid var(--c-gold);

  color: var(--c-gold-l);

  padding: 10px 28px; border-radius: 50px;

  cursor: pointer; font-size: .9rem;

  transition: all var(--transition);

}

.popup-close-btn:hover { background: var(--c-gold); color: #0d0618; }



/* ─── SECTION CONTENT ────────────────────────────── */

.section-content { padding: 40px 20px 60px; }

.section-intro   { color: var(--c-text-muted); text-align: center; margin-bottom: 32px; font-size: 1.05rem; }

.empty-state {

  text-align: center; padding: 60px 20px; color: var(--c-text-muted);

}

.empty-state i   { font-size: 3rem; margin-bottom: 16px; color: var(--c-border); display: block; }



/* ─── TABS ───────────────────────────────────────── */

.tabs { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 28px; }

.tab-btn {

  padding: 10px 22px; border-radius: 50px;

  background: rgba(255,255,255,.05);

  border: 1px solid var(--c-border);

  color: var(--c-text-muted); font-size: .88rem; cursor: pointer;

  transition: all var(--transition);

}

.tab-btn.active, .tab-btn:hover { background: var(--c-gold); color: #0d0618; border-color: var(--c-gold); font-weight: 600; }

.tab-panel { display: none; }

.tab-panel.active { display: block; }



/* ─── ACCORDION ──────────────────────────────────── */

.accordion { display: flex; flex-direction: column; gap: 12px; }

.accordion-item { background: var(--c-bg-card); border: 1px solid var(--c-border); border-radius: var(--radius); overflow: hidden; }

.accordion-header {

  width: 100%; text-align: left; padding: 18px 20px;

  background: none; border: none; cursor: pointer;

  color: var(--c-gold-l); font-family: var(--font-title); font-size: 1rem;

  display: flex; align-items: center; justify-content: space-between;

  transition: background var(--transition);

}

.accordion-header:hover { background: rgba(198,148,26,.07); }

.accordion-icon { margin-right: 10px; transition: transform var(--transition); }

.accordion-item.open .accordion-icon { transform: rotate(90deg); }

.accordion-body { display: none; padding: 0 20px 20px; color: var(--c-text-muted); font-size: .95rem; }

.accordion-item.open .accordion-body { display: block; }



/* ─── AGENDA ─────────────────────────────────────── */

.agenda-lista { display: flex; flex-direction: column; gap: 2px; }

.agenda-item {

  display: flex; gap: 20px; align-items: flex-start;

  padding: 20px; border-radius: var(--radius);

  background: var(--c-bg-card); border-left: 3px solid var(--c-gold);

  transition: all var(--transition);

  position: relative;

}

.agenda-item:hover { background: var(--c-bg-card2); transform: translateX(4px); }



/* Actividad en curso */

.agenda-item--en-curso {

  background: linear-gradient(135deg, rgba(76, 180, 0, 0.15) 0%, rgba(76, 180, 0, 0.08) 100%);

  border-left: 4px solid #4CB400;

  border-right: 1px solid rgba(76, 180, 0, 0.3);

  box-shadow: 0 0 20px rgba(76, 180, 0, 0.2), inset 0 0 20px rgba(76, 180, 0, 0.05);

}

.agenda-item--en-curso:hover {

  background: linear-gradient(135deg, rgba(76, 180, 0, 0.25) 0%, rgba(76, 180, 0, 0.15) 100%);

  box-shadow: 0 0 30px rgba(76, 180, 0, 0.3), inset 0 0 20px rgba(76, 180, 0, 0.08);

}



/* Actividad pasada */

.agenda-item--pasada {

  opacity: 0.6;

  background: var(--c-bg-card);

}

.agenda-item--pasada .hora-inicio,

.agenda-item--pasada .hora-fin,

.agenda-item--pasada .agenda-titulo {

  color: var(--c-text-muted);

}



.agenda-indicador-en-curso {

  position: absolute;

  top: 12px;

  right: 16px;

  font-size: 0.75rem;

  font-weight: 700;

  color: #4CB400;

  display: flex;

  align-items: center;

  gap: 6px;

  letter-spacing: 0.5px;

}



.hora-actual-widget {

  display: inline-flex;

  align-items: center;

  gap: 10px;

  background: rgba(198, 148, 26, 0.15);

  border: 1px solid #C6941A;

  border-radius: 8px;

  padding: 12px 18px;

  margin-bottom: 20px;

  font-family: 'Montserrat', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;

}



.hora-label {

  color: var(--c-text-muted);

  font-size: 0.9rem;

  font-weight: 500;

}



.hora-valor {

  color: #E0AD2C;

  font-size: 1.3rem;

  font-weight: 700;

  font-family: 'Courier New', monospace;

  letter-spacing: 1px;

}



.agenda-hora  { min-width: 90px; text-align: right; }

.hora-inicio  { font-family: var(--font-title); font-size: 1.2rem; color: var(--c-gold-l); display: block; }

.hora-sep     { color: var(--c-text-muted); font-size: .8rem; }

.hora-fin     { color: var(--c-text-muted); font-size: .85rem; }

.agenda-titulo { font-size: 1.05rem; font-weight: 600; color: #fff; margin-bottom: 4px; }

.agenda-desc  { font-size: .88rem; color: var(--c-text-muted); }



/* ─── DRESSCODE ACCORDION ────────────────────────────── */

.dresscode-intro {

  background: linear-gradient(135deg, rgba(198, 148, 26, 0.1) 0%, rgba(198, 148, 26, 0.05) 100%);

  border: 1px solid rgba(198, 148, 26, 0.3);

  border-radius: var(--radius);

  padding: 24px 20px;

  margin-bottom: 32px;

  text-align: center;

  color: var(--c-text-muted);

  font-size: 1.05rem;

  line-height: 1.6;

  font-family: 'Montserrat', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;

  font-weight: 400;

}



.dresscode-accordion {

  display: flex;

  flex-direction: column;

  gap: 16px;

  padding: 2rem 0;

  max-width: 100%;

}



.dresscode-accordion-item {

  background: var(--c-bg-card);

  border: 2px solid var(--c-border);

  border-radius: var(--radius);

  overflow: hidden;

  transition: all var(--transition);

}



.dresscode-accordion-item[open] .dresscode-accordion-header,

.dresscode-accordion-item.open .dresscode-accordion-header {

  background: rgba(198, 148, 26, 0.12);

  border-bottom: 2px solid var(--c-gold);

}



.dresscode-accordion-header {

  width: 100%;

  text-align: left;

  padding: 20px 24px;

  background: none;

  border: none;

  cursor: pointer;

  color: var(--c-gold-l);

  font-family: var(--font-title);

  font-size: 1.15rem;

  font-weight: 600;

  display: flex;

  align-items: center;

  justify-content: space-between;

  gap: 12px;

  transition: all var(--transition);

}



.dresscode-accordion-header:hover {

  padding-left: 28px;

  background: rgba(198, 148, 26, 0.08);

}



.dc-header-title {

  text-transform: uppercase;

  letter-spacing: 0.5px;

  flex: 1;

  font-family: 'Montserrat', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;

  font-weight: 600;

  font-size: 1.35rem;

}



.dc-header-icon {

  transition: transform var(--transition);

  font-size: 1.2rem;

}



.dresscode-accordion-item.open .dc-header-icon {

  transform: rotate(90deg);

}



.dresscode-accordion-body {

  display: none;

  padding: 24px;

  border-top: 1px solid var(--c-border);

}



.dresscode-accordion-item.open .dresscode-accordion-body {

  display: block;

  animation: slideDown var(--transition) ease;

}



.dresscode-item-content {

  display: grid;

  grid-template-columns: 1fr 1fr;

  gap: 32px;

  align-items: start;

  margin-bottom: 24px;

}



.dresscode-item-content:last-child {

  margin-bottom: 0;

}



.dc-text-section {

  display: flex;

  flex-direction: column;

  gap: 12px;

}



.dc-item-title {

  color: var(--c-gold-l);

  font-size: 1.4rem;

  margin: 0;

  text-transform: uppercase;

  letter-spacing: 0.3px;

  font-family: 'Montserrat', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;

  font-weight: 700;

}



.dc-item-description {

  color: var(--c-text-muted);

  font-size: 1.05rem;

  line-height: 1.8;

  white-space: pre-wrap;

  font-family: 'Montserrat', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;

  font-weight: 400;

}



.dc-item-description strong {

  color: var(--c-gold);

}



.dc-image-section {

  display: flex;

  align-items: center;

  justify-content: center;

}



.dc-item-image {

  width: 100%;

  max-width: 100%;

  height: auto;

  border-radius: var(--radius);

  border: 2px solid var(--c-border);

  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.4);

  object-fit: cover;

  transition: transform var(--transition);

}



.dc-item-image:hover {

  transform: scale(1.02);

}



/* Responsive Dresscode */

@media (max-width: 900px) {

  .dresscode-item-content {

    grid-template-columns: 1fr;

    gap: 20px;

  }

  

  .dc-image-section {

    order: -1;

  }

}



@media (max-width: 640px) {

  .dresscode-intro {

    padding: 16px 12px;

    font-size: 0.95rem;

  }

  

  .dresscode-accordion-header {

    padding: 16px 20px;

    font-size: 1rem;

  }

  

  .dc-item-title {

    font-size: 1rem;

  }

  

  .dc-item-description {

    font-size: 0.9rem;

  }

}



/* ─── GALERÍA MASONRY ─────────────────────────────── */

.album-toolbar { margin-bottom: 24px; display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 12px; }

.album-count   { font-size: .9rem; color: var(--c-text-muted); }



.tab-badge {

  display: inline-flex; align-items: center; justify-content: center;

  background: rgba(255,255,255,.12); color: var(--c-gold);

  font-size: .7rem; min-width: 22px; height: 20px; padding: 0 6px;

  border-radius: 10px; margin-left: 6px; font-weight: 600;

}

.tab-btn.active .tab-badge { background: var(--c-gold); color: #1a0a2e; }



/* Masonry con CSS Grid (mejor compatibilidad con lazy loading) */

.masonry-grid {

  display: grid;

  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));

  gap: 16px;

  grid-auto-rows: auto;

}

@media (max-width: 900px)  { 

  .masonry-grid { 

    grid-template-columns: repeat(auto-fill, minmax(250px, 1fr)); 

  } 

}

@media (max-width: 520px)  { 

  .masonry-grid { 

    grid-template-columns: 1fr; 

    gap: 8px;

  } 

}



.masonry-item {

  break-inside: avoid;

  margin-bottom: 16px;

  border-radius: var(--radius);

  overflow: hidden;

  background: var(--c-bg-card);

  border: 1px solid var(--c-border);

  /* Animation - comenzar visible */

  opacity: 1;

  transform: translateY(0) scale(1);

  transition: opacity .5s ease, transform .5s ease;

}

.masonry-item.revealed {

  opacity: 1;

  transform: translateY(0) scale(1);

}



.masonry-img-wrap {

  position: relative;

  overflow: hidden;

  cursor: pointer;

  line-height: 0;

  width: 100%;

  min-height: 250px;

  background: var(--c-bg-card);

}

.masonry-img-wrap img {

  width: 100%;

  height: 100%;

  display: block;

  object-fit: cover;

  transition: transform .4s ease;

}

.masonry-img-wrap:hover img { transform: scale(1.05); }



/* Overlay con info al hover */

.masonry-hover {

  position: absolute; inset: 0;

  background: linear-gradient(180deg, rgba(0,0,0,.1) 0%, rgba(0,0,0,.0) 40%, rgba(0,0,0,.7) 100%);

  display: flex; flex-direction: column;

  justify-content: space-between;

  padding: 12px;

  opacity: 0;

  pointer-events: none;

  transition: opacity .3s ease;

}

.masonry-img-wrap:hover .masonry-hover {

  opacity: 1;

  pointer-events: auto;

}

.masonry-hover-top { display: flex; justify-content: flex-end; }

.masonry-hover-bottom { display: flex; justify-content: space-between; align-items: flex-end; }



.masonry-info-left { display: flex; flex-direction: column; gap: 2px; max-width: 70%; }

.masonry-autor { color: #fff; font-size: .78rem; font-weight: 600; text-shadow: 0 1px 4px rgba(0,0,0,.6); }

.masonry-desc  { color: rgba(255,255,255,.85); font-size: .72rem; font-style: italic; text-shadow: 0 1px 3px rgba(0,0,0,.7);

                 overflow: hidden; text-overflow: ellipsis; white-space: nowrap; max-width: 100%; }



.btn-descargar-m {

  background: rgba(255,255,255,.85); color: #222;

  border: none; width: 34px; height: 34px; border-radius: 50%;

  cursor: pointer; font-size: .85rem;

  display: flex; align-items: center; justify-content: center;

  transition: background .2s, transform .2s;

  backdrop-filter: blur(4px);

}

.btn-descargar-m:hover { background: #fff; transform: scale(1.1); }



.btn-like-m {

  background: rgba(0,0,0,.4); border: none; cursor: pointer;

  color: #fff; display: flex; align-items: center; gap: 5px;

  font-size: .85rem; padding: 6px 10px; border-radius: 20px;

  backdrop-filter: blur(4px);

  transition: background .2s, transform .2s;

}

.btn-like-m:hover { background: rgba(0,0,0,.6); transform: scale(1.05); }

.btn-like-m.liked { color: #ff3366; }

.btn-like-m.liked i { animation: likePop .3s ease; }

@keyframes likePop { 0%{transform:scale(1)} 50%{transform:scale(1.4)} 100%{transform:scale(1)} }



/* Animación en mobile: mostrar info siempre debajo */

@media (max-width: 520px) {

  .masonry-item { margin-bottom: 8px; }

  .masonry-hover {

    position: relative; inset: auto;

    opacity: 1; pointer-events: auto;

    background: var(--c-bg-card);

    padding: 8px 10px;

    flex-direction: row; justify-content: space-between; align-items: center;

  }

  .masonry-hover-top { display: none; }

  .masonry-hover-bottom { width: 100%; }

  .masonry-autor { color: var(--c-text-muted); text-shadow: none; font-size: .75rem; }

  .masonry-desc  { color: var(--c-text-muted); text-shadow: none; }

  .btn-like-m { background: none; padding: 4px 8px; color: var(--c-text-muted); backdrop-filter: none; }

  .btn-like-m.liked { color: #ff3366; }

}



/* ─── LIGHTBOX MEJORADO ──────────────────────────── */

.lb-overlay {

  display: none; position: fixed; inset: 0; z-index: 9998;

  background: rgba(0,0,0,.96);

  align-items: center; justify-content: center;

  flex-direction: column;

}

.lb-overlay.open { display: flex; }



.lb-close {

  position: absolute; top: 16px; right: 16px; z-index: 10;

  background: rgba(255,255,255,.12); border: none; color: #fff;

  width: 44px; height: 44px; border-radius: 50%; cursor: pointer;

  font-size: 1.2rem; transition: background .2s;

  display: flex; align-items: center; justify-content: center;

}

.lb-close:hover { background: rgba(255,255,255,.25); }



.lb-nav {

  position: absolute; top: 50%; transform: translateY(-50%); z-index: 10;

  background: rgba(255,255,255,.1); border: none; color: #fff;

  width: 48px; height: 48px; border-radius: 50%; cursor: pointer;

  font-size: 1.1rem; transition: background .2s, transform .2s;

  display: flex; align-items: center; justify-content: center;

}

.lb-nav:hover { background: rgba(255,255,255,.25); transform: translateY(-50%) scale(1.1); }

.lb-prev { left: 16px; }

.lb-next { right: 16px; }

.lb-nav.lb-hidden { opacity: .2; pointer-events: none; }



.lb-content {

  display: flex; flex-direction: column; align-items: center;

  max-width: 90vw; max-height: 90vh;

}

.lb-content img {

  max-width: 88vw; max-height: 76vh;

  border-radius: var(--radius);

  box-shadow: 0 8px 40px rgba(0,0,0,.6);

  object-fit: contain;

  transition: opacity .3s ease;

}

.lb-details {

  color: #fff; text-align: center; padding: 14px 20px; max-width: 600px;

}

.lb-meta {

  display: flex; justify-content: center; align-items: center; gap: 16px;

  margin-bottom: 6px;

}

.lb-autor   { font-size: .85rem; opacity: .65; }

.lb-counter { font-size: .8rem; opacity: .45; font-variant-numeric: tabular-nums; }

.lb-desc    { font-size: .95rem; font-style: italic; opacity: .8; margin: 0; }



@media (max-width: 640px) {

  .lb-nav { width: 38px; height: 38px; font-size: .9rem; }

  .lb-prev { left: 8px; }

  .lb-next { right: 8px; }

  .lb-content img { max-width: 95vw; max-height: 70vh; }

}



/* ─── UPLOAD ─────────────────────────────────────── */

.upload-area { display: block; cursor: pointer; }

.upload-area input[type=file] { display: none; }

.upload-source-actions {

  display: grid;

  grid-template-columns: repeat(2, minmax(0, 1fr));

  gap: 10px;

  margin-bottom: 12px;

}

.btn-upload-source {

  -webkit-appearance: none;

  appearance: none;

  border: 1px solid var(--c-border);

  background: rgba(198,148,26,.10);

  color: var(--c-gold-l);

  border-radius: var(--radius-sm);

  padding: 11px 14px;

  font-size: .9rem;

  font-weight: 600;

  font-family: var(--font-body);

  cursor: pointer;

  transition: all var(--transition), transform .15s ease;

  display: inline-flex;

  align-items: center;

  justify-content: center;

  gap: 8px;

  min-height: 44px;

  box-shadow: 0 2px 10px rgba(0,0,0,.25);

}

.btn-upload-source i { color: var(--c-gold); }

.btn-upload-source:hover {

  border-color: var(--c-gold);

  background: rgba(198,148,26,.22);

  transform: translateY(-1px);

}

.btn-upload-source:active {

  transform: translateY(0);

}

.btn-upload-source:focus-visible {

  outline: none;

  border-color: var(--c-gold-l);

  box-shadow: 0 0 0 3px rgba(198,148,26,.22);

}

.btn-upload-source.is-active {

  background: var(--c-primary);

  border-color: var(--c-primary-l);

  color: #0d0618;

}

.btn-upload-source.is-active i {

  color: #0d0618;

}

.upload-placeholder {

  border: 2px dashed var(--c-border);

  border-radius: var(--radius);

  padding: 48px 20px;

  text-align: center;

  color: var(--c-text-muted);

  transition: all var(--transition);

  display: flex; flex-direction: column; align-items: center; gap: 8px;

}

.upload-placeholder i { font-size: 2.5rem; color: var(--c-gold); }

.upload-placeholder:hover { border-color: var(--c-gold); background: rgba(198,148,26,.05); }

.upload-preview { width: 100%; max-height: 300px; object-fit: contain; border-radius: var(--radius); }

/* Grilla de miniaturas para selección múltiple */
.upload-thumb-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(90px, 1fr));
  gap: 8px;
  padding: 10px 0;
}
.upload-thumb-item {
  position: relative;
  aspect-ratio: 1;
  border-radius: var(--radius);
  overflow: hidden;
  background: var(--c-bg-card);
}
.upload-thumb-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.upload-thumb-remove {
  position: absolute;
  top: 4px;
  right: 4px;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: rgba(0,0,0,.65);
  border: none;
  color: #fff;
  font-size: 0.7rem;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  padding: 0;
  transition: background var(--transition);
}
.upload-thumb-remove:hover { background: rgba(200,40,40,.85); }



@media (max-width: 520px) {

  .upload-source-actions { grid-template-columns: 1fr; }

}



/* ─── VOTACIÓN ───────────────────────────────────── */

.candidatos-grid {

  display: grid; grid-template-columns: repeat(auto-fill,minmax(200px,1fr)); gap: 20px; margin-bottom: 32px;

}

.candidato-card input[type=radio] { display: none; }

.candidato-inner {

  background: var(--c-bg-card); border: 2px solid var(--c-border); border-radius: var(--radius);

  overflow: hidden; cursor: pointer; transition: all var(--transition); position: relative;

}

.candidato-card input:checked + .candidato-inner {

  border-color: var(--c-gold);

  box-shadow: 0 0 20px rgba(198,148,26,.35);

}

.candidato-foto { aspect-ratio: 1; overflow: hidden; background: var(--c-bg-card2); }

.candidato-foto img { width: 100%; height: 100%; object-fit: cover; }

.candidato-foto--empty {

  display: flex; align-items: center; justify-content: center;

  font-size: 3rem; color: var(--c-text-muted);

}

.candidato-info { padding: 14px; }

.candidato-info h3 { font-size: .95rem; color: var(--c-gold-l); margin-bottom: 4px; }

.candidato-region { font-size: .8rem; color: var(--c-primary); margin-bottom: 4px; font-weight: 500; }

.candidato-desc { font-size: .8rem; color: var(--c-text-muted); margin-top: 4px; }

.candidato-check {

  position: absolute; top: 10px; right: 10px;

  color: var(--c-gold); font-size: 1.4rem;

  opacity: 0; transition: opacity var(--transition);

}

.candidato-card input:checked + .candidato-inner .candidato-check { opacity: 1; }

.votacion-actions { text-align: center; }

.voto-confirmado { text-align: center; padding: 60px 20px; font-family: 'Montserrat', sans-serif; }

.voto-confirmado i  { font-size: 3rem; color: var(--c-success); margin-bottom: 16px; display: block; }

.voto-confirmado h2 { color: #fff; margin-bottom: 12px; font-weight: 700; font-family: 'Montserrat', sans-serif; }

.voto-candidata { color: var(--c-gold-l); font-size: 1.1rem; margin-top: 8px; font-weight: 600; font-family: 'Montserrat', sans-serif; }



/* ─── LISTA DE CANDIDATAS ─────────────────────────── */

.candidatos-lista { 

  max-width: 600px; margin: 40px auto; display: flex; flex-direction: column; gap: 12px;

}



.candidata-item {

  display: flex; align-items: center; gap: 16px;

  padding: 16px 20px; border-radius: var(--radius);

  background: var(--c-bg-card); border: 2px solid var(--c-border);

  cursor: pointer; transition: all var(--transition);

}



.candidata-item:hover { transform: translateX(4px); }



.candidata-item.votado { background: rgba(40,167,69,.1); border-color: #28a745; }



.candidata-text { 

  flex: 1;

  font-family: 'Montserrat', sans-serif;

}



.candidata-text h3 { 

  font-size: 1.15rem; 

  margin: 0 0 4px 0; 

  font-weight: 700; 

  letter-spacing: 0.5px;

  font-family: 'Montserrat', sans-serif;

}



.candidata-region { 

  font-size: .85rem; 

  margin: 0; 

  font-weight: 500;

  font-family: 'Montserrat', sans-serif;

}



.candidata-action,

.candidata-check {

  display: flex; align-items: center; justify-content: center;

  width: 40px; height: 40px; border-radius: 50%;

  flex-shrink: 0;

}



.btn-votar {

  width: 100%; height: 100%;

  background: none; border: none;

  font-size: 1.2rem;

  cursor: pointer; transition: all var(--transition);

  display: flex; align-items: center; justify-content: center;

}



.btn-votar:hover { transform: scale(1.1); }



.candidata-check {

  color: #28a745; font-size: 1.4rem;

}



/* COLORES POR CANDIDATA */

.candidata-item--1 { border-color: #d63031; }

.candidata-item--1:hover { background: rgba(214, 48, 49, 0.1); }

.candidata-item--1 .candidata-text h3 { color: #ff6b6b; }

.candidata-item--1 .candidata-action { background: rgba(214, 48, 49, 0.2); color: #d63031; }

.candidata-item--1 .btn-votar { color: #d63031; }



.candidata-item--2 { border-color: #e67e22; }

.candidata-item--2:hover { background: rgba(230, 126, 34, 0.1); }

.candidata-item--2 .candidata-text h3 { color: #ffb366; }

.candidata-item--2 .candidata-action { background: rgba(230, 126, 34, 0.2); color: #e67e22; }

.candidata-item--2 .btn-votar { color: #e67e22; }



.candidata-item--3 { border-color: #e24a6d; }

.candidata-item--3:hover { background: rgba(226, 74, 109, 0.1); }

.candidata-item--3 .candidata-text h3 { color: #ff7a9e; }

.candidata-item--3 .candidata-action { background: rgba(226, 74, 109, 0.2); color: #e24a6d; }

.candidata-item--3 .btn-votar { color: #e24a6d; }



.candidata-item--4 { border-color: #9b59b6; }

.candidata-item--4:hover { background: rgba(155, 89, 182, 0.1); }

.candidata-item--4 .candidata-text h3 { color: #d4a5e8; }

.candidata-item--4 .candidata-action { background: rgba(155, 89, 182, 0.2); color: #9b59b6; }

.candidata-item--4 .btn-votar { color: #9b59b6; }



.candidata-item--5 { border-color: #3498db; }

.candidata-item--5:hover { background: rgba(52, 152, 219, 0.1); }

.candidata-item--5 .candidata-text h3 { color: #74c0fc; }

.candidata-item--5 .candidata-action { background: rgba(52, 152, 219, 0.2); color: #3498db; }

.candidata-item--5 .btn-votar { color: #3498db; }



.candidata-item--6 { border-color: #27ae60; }

.candidata-item--6:hover { background: rgba(39, 174, 96, 0.1); }

.candidata-item--6 .candidata-text h3 { color: #55efc4; }

.candidata-item--6 .candidata-action { background: rgba(39, 174, 96, 0.2); color: #27ae60; }

.candidata-item--6 .btn-votar { color: #27ae60; }



.candidata-item--7 { border-color: #17a2b8; }

.candidata-item--7:hover { background: rgba(23, 162, 184, 0.1); }

.candidata-item--7 .candidata-text h3 { color: #5cd4e8; }

.candidata-item--7 .candidata-action { background: rgba(23, 162, 184, 0.2); color: #17a2b8; }

.candidata-item--7 .btn-votar { color: #17a2b8; }



.candidata-item--8 { border-color: #C6941A; }

.candidata-item--8:hover { background: rgba(198, 148, 26, 0.1); }

.candidata-item--8 .candidata-text h3 { color: #E0AD2C; }

.candidata-item--8 .candidata-action { background: rgba(198, 148, 26, 0.2); color: #C6941A; }

.candidata-item--8 .btn-votar { color: #C6941A; }



/* ─── RESULTADOS ─────────────────────────────────── */

.resultados-meta { text-align: center; margin-bottom: 36px; color: var(--c-text-muted); font-size: 1rem; font-family: 'Montserrat', sans-serif; font-weight: 500; }

.resultados-meta strong { color: var(--c-gold-l); font-size: 1.4rem; font-weight: 700; font-family: 'Montserrat', sans-serif; }



/* Podio */

.podio {

  display: flex; justify-content: center; align-items: flex-end; gap: 12px;

  margin-bottom: 48px; padding: 0 20px;

}

.podio-lugar { text-align: center; flex: 0 0 auto; width: 150px; }

.podio-foto  {

  width: 100px; height: 100px; border-radius: 50%;

  overflow: hidden; margin: 0 auto 8px;

  border: 3px solid var(--c-border);

  background: var(--c-bg-card);

  display: flex; align-items: center; justify-content: center; font-size: 2rem; color: var(--c-text-muted);

}

.podio-foto--1 { width: 130px; height: 130px; border-color: var(--c-gold); box-shadow: 0 0 30px rgba(198,148,26,.4); }

.podio-foto img { width:100%; height:100%; object-fit:cover; }

.podio-medalla { font-size: 1.8rem; display: block; margin-bottom: 6px; }

.podio-lugar h3 { font-size: .9rem; color: #fff; margin-bottom: 8px; font-weight: 700; font-family: 'Montserrat', sans-serif; }

.podio-region { font-size: .75rem; color: var(--c-text-muted); margin-bottom: 8px; font-family: 'Montserrat', sans-serif; font-weight: 500; }

.podio-barra {

  height: 60px; border-radius: var(--radius-sm) var(--radius-sm) 0 0;

  display: flex; align-items: flex-end; justify-content: center;

  padding-bottom: 6px; font-size: .78rem; color: #0d0618; font-weight: 700;

}

.podio-barra--1 { background: var(--c-primary); height: 90px; }

.podio-barra--2 { background: #a8a9ad; height: 70px; }

.podio-barra--3 { background: #cd7f32; height: 55px; }



.resultados-tabla { max-width: 700px; margin: 0 auto; }

.tabla-titulo { margin-bottom: 20px; color: var(--c-gold-l); font-weight: 700; font-family: 'Montserrat', sans-serif; }

.resultado-row {

  display: flex; align-items: center; gap: 12px;

  padding: 12px 16px; border-radius: var(--radius);

  background: var(--c-bg-card); border: 1px solid var(--c-border);

  margin-bottom: 8px; transition: all var(--transition);

}

.resultado-top { border-color: rgba(198,148,26,.4); }

.resultado-pos   { font-size: 1.4rem; min-width: 36px; text-align: center; font-weight: 700; font-family: 'Montserrat', sans-serif; }

.resultado-avatar{ width: 44px; height: 44px; border-radius: 50%; overflow: hidden; background: var(--c-bg-card2); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }

.resultado-avatar img { width:100%; height:100%; object-fit:cover; }

.resultado-info { flex: 1; }

.resultado-nombre { font-weight: 700; color: #fff; font-family: 'Montserrat', sans-serif; }

.resultado-region { font-size: .75rem; color: var(--c-text-muted); margin-top: 2px; font-family: 'Montserrat', sans-serif; font-weight: 500; }

.resultado-barra-wrap { width: 120px; }

.resultado-barra { background: rgba(255,255,255,.08); height: 8px; border-radius: 4px; overflow: hidden; }

.resultado-barra-fill { display: block; height: 100%; background: linear-gradient(90deg, var(--c-gold-d), var(--c-gold-l)); border-radius: 4px; transition: width 1s ease; }

.resultado-votos { color: var(--c-text-muted); font-size: .85rem; min-width: 60px; text-align: right; font-family: 'Montserrat', sans-serif; font-weight: 500; }

.resultado-pct   { color: var(--c-gold); font-size: .85rem; font-weight: 700; min-width: 38px; text-align: right; font-family: 'Montserrat', sans-serif; }



/* ─── MODAL ──────────────────────────────────────── */

.modal-overlay {

  position: fixed; inset: 0; z-index: 9997;

  background: rgba(0,0,0,.7); backdrop-filter: blur(4px);

  display: flex; align-items: center; justify-content: center; padding: 20px;

}

.modal-card {

  background: var(--c-bg-card); border: 1px solid var(--c-border); border-radius: var(--radius);

  padding: 32px; max-width: 420px; width: 100%; text-align: center;

  box-shadow: var(--shadow);

  font-family: 'Montserrat', sans-serif;

}

.modal-card h3 { color: var(--c-gold-l); margin-bottom: 12px; font-weight: 700; font-family: 'Montserrat', sans-serif; }

.modal-card p  { color: var(--c-text-muted); margin-bottom: 8px; font-family: 'Montserrat', sans-serif; font-weight: 500; }

.modal-actions { display: flex; gap: 12px; justify-content: center; margin-top: 24px; }



/* ─── FORMS ──────────────────────────────────────── */

.form-card { background: var(--c-bg-card); border: 1px solid var(--c-border); border-radius: var(--radius); padding: 32px; margin-bottom: 24px; }

.form-card h3 { color: var(--c-gold-l); margin-bottom: 24px; }

.form-group { margin-bottom: 18px; }

.form-group label { display: block; font-size: .85rem; color: var(--c-text-muted); margin-bottom: 7px; font-weight: 500; }

.form-group input[type=text],

.form-group input[type=email],

.form-group input[type=password],

.form-group input[type=datetime-local],

.form-group input[type=number],

.form-group input[type=time],

.form-group input[type=file],

.form-group select,

.form-group textarea {

  width: 100%; padding: 11px 14px; border-radius: var(--radius-sm);

  background: rgba(255,255,255,.1);

  border: 1px solid var(--c-border);

  color: #fff; font-size: .95rem;

  transition: border-color var(--transition), box-shadow var(--transition);

  -webkit-appearance: none;

  appearance: none;

}

.form-group select option { background: var(--c-bg-card); }

.form-group input:focus,

.form-group select:focus,

.form-group textarea:focus { outline: none; border-color: var(--c-gold); box-shadow: 0 0 0 3px rgba(198,148,26,.15); }

.form-group textarea { resize: vertical; min-height: 90px; }

.form-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }

.form-group small { display: block; color: var(--c-text-muted); font-size: .78rem; margin-top: 5px; }

.form-actions { display: flex; gap: 12px; align-items: center; margin-top: 8px; }

.form-divider { border: none; border-top: 1px solid var(--c-border); margin: 28px 0; }

.form-group--check { display: flex; align-items: center; }

.check-label { display: flex; align-items: center; gap: 10px; cursor: pointer; }

.check-label input[type=checkbox] { width: 18px; height: 18px; accent-color: var(--c-gold); }

.check-label--large span { font-size: 1rem; color: #fff; }

.input-password-wrap { position: relative; }

.input-password-wrap input { padding-right: 44px; }

.toggle-password { position: absolute; right: 12px; top: 50%; transform: translateY(-50%); background: none; border: none; color: var(--c-text-muted); cursor: pointer; font-size: 1rem; }



/* ─── BUTTONS ────────────────────────────────────── */

.btn {

  display: inline-flex; align-items: center; gap: 8px;

  padding: 11px 22px; border-radius: var(--radius-sm);

  font-size: .9rem; font-weight: 600; cursor: pointer;

  border: none; transition: all var(--transition); text-decoration: none;

}

.btn-primary  { background: var(--c-primary); color: #0d0618; }

.btn-primary:hover { background: var(--c-primary-l); color: #0d0618; }

.btn-outline  { background: transparent; border: 1px solid var(--c-border); color: var(--c-text-muted); }

.btn-outline:hover { border-color: var(--c-gold); color: var(--c-gold-l); }

.btn-danger   { background: var(--c-danger); color: #fff; }

.btn-danger:hover { filter: brightness(1.15); }

.btn-success  { background: var(--c-success); color: #fff; }

.btn-warning  { background: var(--c-warning); color: #fff; }

.btn-full     { width: 100%; justify-content: center; }

.btn-sm       { padding: 6px 12px; font-size: .8rem; }

.btn-lg       { padding: 14px 32px; font-size: 1rem; }

.btn-xl       { padding: 16px 40px; font-size: 1.05rem; border-radius: 50px; }

.mt-2         { margin-top: 16px; }

.ml-2         { margin-left: 8px; }

.mb-4         { margin-bottom: 32px; }



/* ─── ALERTS ─────────────────────────────────────── */

.alert {

  padding: 14px 18px; border-radius: var(--radius-sm);

  margin-bottom: 20px; display: flex; align-items: flex-start; gap: 10px; font-size: .9rem;

}

.alert-success { background: rgba(56,161,105,.15); border: 1px solid var(--c-success); color: #9fdfc2; }

.alert-error   { background: rgba(229,62,62,.15);  border: 1px solid var(--c-danger);  color: #fca5a5; }

.alert-warning { background: rgba(217,119,6,.15);  border: 1px solid var(--c-warning); color: #fcd34d; }

.alert-info    { background: rgba(49,130,206,.15); border: 1px solid var(--c-info);    color: #93c5fd; }



/* ─── BADGES ─────────────────────────────────────── */

.badge {

  display: inline-flex; align-items: center; padding: 3px 10px;

  border-radius: 50px; font-size: .75rem; font-weight: 600;

}

.badge-activo  { background: rgba(56,161,105,.2);  color: #9fdfc2; }

.badge-inactivo{ background: rgba(229,62,62,.2);   color: #fca5a5; }

.badge-admin   { background: rgba(123,45,139,.3);  color: #d8b4fe; }

.badge-usuario { background: rgba(198,148,26,.15); color: var(--c-gold-l); }

.badge-online  { background: rgba(56,161,105,.2);  color: #9fdfc2; }

.badge-offline { background: rgba(255,255,255,.05);color: var(--c-text-muted); }

.badge-seccion { background: rgba(198,148,26,.15); color: var(--c-gold-l); padding: 2px 8px; border-radius: 50px; font-size: .72rem; }



/* ─── LOGIN ──────────────────────────────────────── */

.login-body { display: flex; align-items: center; justify-content: center; min-height: 100vh; }

.login-bg   { position: fixed; inset: 0; overflow: hidden; }

.login-bg::before {

  content: ''; position: absolute; inset: 0;

  background: url('../img/Fondo%20portada.png') center/cover no-repeat;

  filter: brightness(.85);

}

.login-stars { position: absolute; inset: 0; } /* JS añade puntos */

.login-container { position: relative; z-index: 1; width: 100%; max-width: 440px; padding: 24px; }

.login-card {

  background: rgba(26,15,46,.92); backdrop-filter: blur(20px);

  border: 1px solid var(--c-border); border-radius: 20px;

  padding: 44px 40px;

  box-shadow: 0 20px 60px rgba(0,0,0,.6), 0 0 60px rgba(198,148,26,.08);

}

.login-logo { text-align: center; margin-bottom: 32px; }

.login-logo img { height: 80px; margin: 0 auto 12px; }

.login-titulo { font-size: 1.8rem; color: var(--c-gold-l); }

.login-subtitulo { color: var(--c-text-muted); font-size: .9rem; margin-top: 4px; }

.login-form .btn { margin-top: 8px; }



/* ─── ADMIN PANEL ────────────────────────────────── */

.admin-nav-grid {

  display: grid; grid-template-columns: repeat(auto-fill, minmax(170px,1fr)); gap: 16px; margin-bottom: 36px;

}

.admin-nav-card {

  background: var(--c-bg-card); border: 1px solid var(--c-border); border-radius: var(--radius);

  padding: 24px 16px; text-align: center; color: var(--c-text);

  transition: all var(--transition);

}

.admin-nav-card i  { font-size: 2rem; color: var(--c-gold); margin-bottom: 10px; display: block; }

.admin-nav-card h3 { font-size: .9rem; color: #fff; margin-bottom: 4px; }

.admin-nav-card p  { font-size: .75rem; color: var(--c-text-muted); }

.admin-nav-card:hover { border-color: var(--c-gold); transform: translateY(-3px); }

.admin-nav-card--config { border-color: rgba(123,45,139,.4); }

.admin-nav-card--config i { color: var(--c-accent); }



.metrics-grid {

  display: flex; flex-wrap: wrap; gap: 14px; margin-bottom: 32px;

}

.metric-card {

  flex: 1 1 140px;

  background: var(--c-bg-card2); border: 1px solid var(--c-border); border-radius: var(--radius);

  padding: 20px 16px; text-align: center;

}

.metric-card i    { font-size: 1.5rem; color: var(--c-gold); margin-bottom: 8px; display: block; }

.metric-num       { font-family: var(--font-title); font-size: 2rem; color: var(--c-gold-l); }

.metric-label     { font-size: .78rem; color: var(--c-text-muted); margin-top: 4px; }



/* Table */

.table-card { background: var(--c-bg-card); border: 1px solid var(--c-border); border-radius: var(--radius); padding: 24px; }

.table-card h3 { color: var(--c-gold-l); margin-bottom: 18px; }

.table-responsive { overflow-x: auto; }

.admin-table { width: 100%; border-collapse: collapse; font-size: .88rem; }

.admin-table th { padding: 10px 12px; text-align: left; color: var(--c-text-muted); border-bottom: 1px solid var(--c-border); font-weight: 500; }

.admin-table td { padding: 11px 12px; border-bottom: 1px solid rgba(255,255,255,.05); vertical-align: middle; color: var(--c-text); }

.admin-table tr:last-child td { border-bottom: none; }

.admin-table tr:hover td { background: rgba(255,255,255,.03); }

.row-inactivo { opacity: .5; }

.table-actions { display: flex; gap: 6px; flex-wrap: wrap; }



/* Admin fotos grid */

.admin-fotos-mini { display: flex; flex-wrap: wrap; gap: 10px; }

.admin-foto-mini  { width: 90px; text-align: center; }

.admin-foto-mini img { width: 90px; height: 90px; object-fit: cover; border-radius: var(--radius-sm); border: 1px solid var(--c-border); }

.admin-foto-mini small { display: block; font-size: .7rem; color: var(--c-text-muted); margin-top: 4px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

.admin-section-block { background: var(--c-bg-card); border: 1px solid var(--c-border); border-radius: var(--radius); padding: 24px; }

.admin-section-block h3 { color: var(--c-gold-l); margin-bottom: 16px; }

.admin-fotos-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px,1fr)); gap: 14px; }

.admin-foto-card { background: var(--c-bg-card); border: 1px solid var(--c-border); border-radius: var(--radius); overflow: hidden; }

.admin-foto-card.foto-oculta { opacity: .5; }

.admin-foto-card img { width: 100%; height: 160px; object-fit: cover; }

.admin-foto-meta { padding: 8px 10px; display: flex; flex-wrap: wrap; gap: 6px; align-items: center; font-size: .78rem; color: var(--c-text-muted); }

.admin-foto-acciones { padding: 8px 10px; display: flex; gap: 6px; }



/* ─── FOOTER ─────────────────────────────────────── */

.site-footer { background: rgba(0,0,0,.4); border-top: 1px solid var(--c-border); padding: 20px; text-align: center; font-size: .8rem; color: var(--c-text-muted); }

.footer-user   { margin-top: 4px; }

.footer-credit { margin-top: 6px; font-size: .75rem; color: var(--c-gold); letter-spacing: .04em; }

.footer-credit { margin-top: 6px; font-size: .75rem; color: var(--c-gold); letter-spacing: .04em; }



/* ─── EVENTO VIVO ────────────────────────────────── */

.hero-evento-vivo { font-size: 1.3rem; color: var(--c-gold-l); margin: 20px 0 32px; font-family: var(--font-title); }



/* ─── RESULTADOS: INDICADOR LIVE ─────────────────── */

.resultados-live {

  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;

  background: rgba(56,161,105,.1);

  border: 1px solid rgba(56,161,105,.3);

  border-radius: var(--radius-sm);

  padding: 10px 16px;

  margin-bottom: 28px;

  font-size: .85rem; color: var(--c-text-muted);

}

.live-dot {

  width: 10px; height: 10px; border-radius: 50%;

  background: var(--c-success);

  flex-shrink: 0;

  animation: livePulse 1.5s ease-in-out infinite;

}

@keyframes livePulse {

  0%,100% { box-shadow: 0 0 0 0 rgba(56,161,105,.6); }

  50%      { box-shadow: 0 0 0 6px rgba(56,161,105,0); }

}

.live-dot + span strong { color: var(--c-gold-l); font-size: 1rem; }

.resultados-ts { margin-left: auto; font-size: .78rem; opacity: .7; }



/* ─── REGLAMENTO ────────────────────────────────── */

.reglamento-container {

  display: grid;

  grid-template-columns: repeat(3, 1fr);

  gap: 2.5rem;

  padding: 2rem 0;

}



.reglamento-section {

  display: none;

}



/* ─── REGLAMENTO ACCORDION ────────────────────────────── */

.reglamento-accordion {

  display: flex;

  flex-direction: column;

  gap: 16px;

  padding: 2rem 0;

  max-width: 900px;

  margin: 0 auto;

}



.reglamento-accordion-item {

  background: var(--c-bg-card);

  border: 2px solid var(--c-border);

  border-radius: var(--radius);

  overflow: hidden;

  transition: all var(--transition);

}



.reglamento-accordion-item--mandatorios {

  border-color: #d63031;

}

.reglamento-accordion-item--mandatorios .reglamento-accordion-header {

  background: linear-gradient(135deg, rgba(214, 48, 49, 0.15) 0%, rgba(192, 57, 43, 0.1) 100%);

}

.reglamento-accordion-item--mandatorios .reglamento-accordion-header:hover {

  background: linear-gradient(135deg, rgba(214, 48, 49, 0.25) 0%, rgba(192, 57, 43, 0.15) 100%);

}

.reglamento-accordion-item--mandatorios .accordion-title {

  color: #ff6b6b;

}



.reglamento-accordion-item--prohibiciones {

  border-color: #d63031;

}

.reglamento-accordion-item--prohibiciones .reglamento-accordion-header {

  background: linear-gradient(135deg, rgba(192, 57, 43, 0.15) 0%, rgba(169, 50, 38, 0.1) 100%);

}

.reglamento-accordion-item--prohibiciones .reglamento-accordion-header:hover {

  background: linear-gradient(135deg, rgba(192, 57, 43, 0.25) 0%, rgba(169, 50, 38, 0.15) 100%);

}

.reglamento-accordion-item--prohibiciones .accordion-title {

  color: #ff8787;

}



.reglamento-accordion-item--tu-responsabilidad {

  border-color: #e67e22;

}

.reglamento-accordion-item--tu-responsabilidad .reglamento-accordion-header {

  background: linear-gradient(135deg, rgba(230, 126, 34, 0.15) 0%, rgba(211, 84, 0, 0.1) 100%);

}

.reglamento-accordion-item--tu-responsabilidad .reglamento-accordion-header:hover {

  background: linear-gradient(135deg, rgba(230, 126, 34, 0.25) 0%, rgba(211, 84, 0, 0.15) 100%);

}

.reglamento-accordion-item--tu-responsabilidad .accordion-title {

  color: #ffb366;

}



.reglamento-accordion-item--recomendaciones {

  border-color: #27ae60;

}

.reglamento-accordion-item--recomendaciones .reglamento-accordion-header {

  background: linear-gradient(135deg, rgba(39, 174, 96, 0.15) 0%, rgba(52, 152, 219, 0.1) 100%);

}

.reglamento-accordion-item--recomendaciones .reglamento-accordion-header:hover {

  background: linear-gradient(135deg, rgba(39, 174, 96, 0.25) 0%, rgba(52, 152, 219, 0.15) 100%);

}

.reglamento-accordion-item--recomendaciones .accordion-title {

  color: #55efc4;

}



.reglamento-accordion-header {

  width: 100%;

  text-align: left;

  padding: 20px 24px;

  background: none;

  border: none;

  cursor: pointer;

  color: var(--c-gold-l);

  font-family: var(--font-title);

  font-size: 1.15rem;

  font-weight: 600;

  display: flex;

  align-items: center;

  justify-content: space-between;

  gap: 12px;

  transition: all var(--transition);

}



.reglamento-accordion-header:hover {

  padding-left: 28px;

}



.accordion-title {

  flex: 1;

  text-transform: uppercase;

  letter-spacing: 0.5px;

}



.accordion-icon {

  transition: transform var(--transition);

  font-size: 1.2rem;

}



.reglamento-accordion-item.open .accordion-icon {

  transform: rotate(90deg);

}



.reglamento-accordion-body {

  display: none;

  padding: 0 24px 24px;

  color: var(--c-text-muted);

  font-size: 0.95rem;

  border-top: 1px solid var(--c-border);

}



.reglamento-accordion-item.open .reglamento-accordion-body {

  display: block;

  animation: slideDown var(--transition) ease;

}



@keyframes slideDown {

  from {

    opacity: 0;

    transform: translateY(-10px);

  }

  to {

    opacity: 1;

    transform: translateY(0);

  }

}



.reglamento-section-content {

  font-family: var(--font-body);

  color: #f0eaf8;

  line-height: 1.8;

}



.reglamento-section-content p {

  font-size: 1rem;

  font-weight: 500;

  margin: 0 0 1.2rem 0;

  color: #d4c5e8;

  line-height: 1.7;

}



.reglamento-section-content ul {

  list-style: none;

  padding: 0;

  margin: 1rem 0 1.5rem 0;

}



.reglamento-section-content li {

  font-size: 1rem;

  font-weight: 500;

  color: #d4c5e8;

  margin-bottom: 1rem;

  padding-left: 2rem;

  position: relative;

  line-height: 1.65;

}



.reglamento-section-content li:before {

  content: "•";

  position: absolute;

  left: 0.5rem;

  font-weight: bold;

  font-size: 1.1rem;

  color: #E0AD2C;

}



.reglamento-section-content h4 {

  font-family: var(--font-title);

  font-size: 1.1rem;

  font-weight: 700;

  color: #FFFFFF;

  margin: 1.8rem 0 1rem 0;

  text-transform: uppercase;

  letter-spacing: 0.5px;

}



.reglamento-section-content h4:first-of-type {

  margin-top: 0;

}



/* ─── TIPS PARA EL VUELO ────────────────────────── */

.tips-container {

  padding: 2rem 0;

  display: flex;

  flex-direction: column;

  gap: 2rem;

}



.tips-section {

  background: linear-gradient(135deg, #1a0f2e 0%, #231545 100%);

  border: 2px solid #C6941A;

  border-radius: 16px;

  padding: 2.5rem;

  box-shadow: 0 8px 32px rgba(198, 148, 26, 0.2);

  backdrop-filter: blur(10px);

}



.tips-section-title {

  font-family: 'Montserrat', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;

  font-size: 1.4rem;

  font-weight: 700;

  color: #E0AD2C;

  margin: 0 0 1.8rem 0;

  text-transform: uppercase;

  letter-spacing: 1px;

  border-bottom: 2px solid #C6941A;

  padding-bottom: 1rem;

}



.tips-section-content {

  font-family: 'Montserrat', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;

  color: #f0eaf8;

  line-height: 1.8;

}



.tips-section-content p {

  font-size: 1rem;

  font-weight: 500;

  margin: 0 0 1.2rem 0;

  color: #d4c5e8;

  line-height: 1.7;

}



.tips-section-content ul {

  list-style: none;

  padding: 0;

  margin: 1rem 0 1.5rem 0;

}



.tips-section-content li {

  font-size: 1rem;

  font-weight: 500;

  color: #d4c5e8;

  margin-bottom: 0.9rem;

  padding-left: 2rem;

  position: relative;

  line-height: 1.6;

}



.tips-section-content li:before {

  content: "→";

  position: absolute;

  left: 0.5rem;

  font-weight: bold;

  font-size: 1.1rem;

  color: #E0AD2C;

}



.tips-section-content h4 {

  font-family: 'Montserrat', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;

  font-size: 1.1rem;

  font-weight: 700;

  color: #E0AD2C;

  margin: 1.8rem 0 1rem 0;

  text-transform: uppercase;

  letter-spacing: 0.5px;

}



.tips-section-content h4:first-of-type {

  margin-top: 0;

}



/* ─── RESPONSIVE ─────────────────────────────────── */

@media (max-width: 900px) {

  .nav-toggle { display: flex; }

}

@media (max-width: 768px) {

  .reglamento-accordion {

    gap: 12px;

    padding: 1.5rem 0;

  }



  .reglamento-accordion-header {

    padding: 16px 20px;

    font-size: 1rem;

  }



  .reglamento-section-content p {

    font-size: 0.95rem;

  }



  .reglamento-section-content li {

    font-size: 0.95rem;

    padding-left: 1.8rem;

    margin-bottom: 0.7rem;

  }



  .reglamento-section-content h4 {

    font-size: 1rem;

    margin: 1.3rem 0 0.8rem 0;

  }



  .tips-section {

    padding: 2rem 1.5rem;

    border-radius: 12px;

  }



  .tips-section-title {

    font-size: 1.2rem;

    margin-bottom: 1.3rem;

  }



  .tips-section-content p {

    font-size: 0.95rem;

  }



  .tips-section-content li {

    font-size: 0.95rem;

    padding-left: 1.8rem;

    margin-bottom: 0.7rem;

  }



  .tips-section-content h4 {

    font-size: 1rem;

    margin: 1.3rem 0 0.8rem 0;

  }

}

@media (max-width: 640px) {

  .form-grid-2 { grid-template-columns: 1fr; }

  .countdown         { gap: 4px; margin: 16px 0 24px; }

  .countdown-item    { padding: 8px 10px; min-width: 0; flex: 1 1 0; }

  .countdown-num     { font-size: clamp(1.4rem, 9vw, 2.8rem); }

  .countdown-sep     { font-size: 1.2rem; padding-bottom: 14px; }

  .countdown-label   { font-size: .6rem; letter-spacing: .05em; }

  .hero-logo-portada { max-width: 95%; }

  .hero-subtitulo    { font-size: 16px; margin-bottom: 12px; }

  .login-card     { padding: 30px 24px; }

  .podio          { gap: 6px; }

  .podio-lugar    { width: 100px; }

  .podio-foto     { width: 70px; height: 70px; }

  .podio-foto--1  { width: 90px; height: 90px; }

  .popup-bienvenida { padding: 32px 20px 28px; }

  .popup-mensaje  { font-size: 1.5rem; }

  .resultado-barra-wrap { display: none; }

  .admin-layout .form-grid-2 { grid-template-columns: 1fr; }

  

  .reglamento-section {

    padding: 1.5rem 1.2rem;

    border-radius: 10px;

  }

  

  .reglamento-section-title {

    font-size: 1.1rem;

    margin-bottom: 1rem;

  }



  .reglamento-section-content p {

    font-size: 0.9rem;

  }



  .reglamento-section-content li {

    font-size: 0.9rem;

    padding-left: 1.6rem;

    margin-bottom: 0.6rem;

  }



  .reglamento-section-content h4 {

    font-size: 0.95rem;

    margin: 1rem 0 0.7rem 0;

  }



  .tips-section {

    padding: 1.5rem 1.2rem;

  }

  

  .tips-section-title {

    font-size: 1.1rem;

    margin-bottom: 1rem;

  }



  .tips-section-content p {

    font-size: 0.9rem;

  }



  .tips-section-content li {

    font-size: 0.9rem;

    padding-left: 1.6rem;

    margin-bottom: 0.6rem;

  }



  .tips-section-content h4 {

    font-size: 0.95rem;

    margin: 1rem 0 0.7rem 0;

  }

}



/* ─── PERSONALIZACIÓN POR PÁGINA: HOME ─────────────────────── */

body.page-home {

  background-image: url('../img/Fondo_CR.png');

  background-size: cover;

  background-position: center;

  background-attachment: fixed;

  background-color: var(--c-bg);

}



/* ─── CLÍNICA DE VENTAS ──────────────────────────────────────── */

.clinica-intro {

  background: var(--c-bg-card);

  border: 1px solid var(--c-border);

  border-radius: var(--radius);

  padding: 32px;

  margin-bottom: 40px;

  text-align: center;

}



.clinica-intro h2 {

  color: var(--c-gold-l);

  margin-bottom: 16px;

  font-size: 1.8rem;

}



.clinica-intro p {

  font-size: 1rem;

  line-height: 1.6;

  color: var(--c-text-muted);

}



.clinica-escenarios {

  max-width: 900px;

  margin: 0 auto 48px;

}



.clinica-item {

  background: var(--c-bg-card);

  border: 2px solid var(--c-border);

  border-radius: var(--radius);

  margin-bottom: 16px;

  overflow: hidden;

  transition: all var(--transition);

}



.clinica-item:hover {

  border-color: var(--c-gold);

  box-shadow: 0 4px 12px rgba(198, 148, 26, 0.2);

}



.clinica-toggle {

  display: none;

}



.clinica-header {

  display: flex;

  align-items: center;

  justify-content: space-between;

  padding: 18px 24px;

  cursor: pointer;

  background: linear-gradient(135deg, rgba(198,148,26,0.1), transparent);

  border-bottom: 1px solid var(--c-border);

  transition: all var(--transition);

  font-family: 'Montserrat', sans-serif;

}



.clinica-header:hover {

  background: linear-gradient(135deg, rgba(198,148,26,0.15), transparent);

}



.clinica-numero {

  font-weight: 700;

  color: var(--c-gold);

  min-width: 100px;

  font-size: 0.9rem;

}



.clinica-titulo {

  flex: 1;

  margin-left: 16px;

  color: #fff;

  font-weight: 600;

  font-family: 'Montserrat', sans-serif;

}



.clinica-expand {

  display: flex;

  align-items: center;

  justify-content: center;

  width: 32px;

  height: 32px;

  color: var(--c-gold);

  transition: transform var(--transition);

}



.clinica-toggle:checked ~ .clinica-header .clinica-expand {

  transform: rotate(180deg);

}



.clinica-content {

  max-height: 0;

  overflow: hidden;

  transition: max-height 0.3s ease;

  background: rgba(0,0,0,0.2);

}



.clinica-toggle:checked ~ .clinica-content {

  max-height: 1000px;

}



.clinica-descripcion,

.clinica-productos,

.clinica-asignacion {

  padding: 18px 24px;

  border-bottom: 1px solid var(--c-border);

  font-family: 'Montserrat', sans-serif;

}



.clinica-descripcion:last-child,

.clinica-asignacion:last-child {

  border-bottom: none;

}



.clinica-descripcion p {

  margin: 0;

  line-height: 1.6;

  color: var(--c-text-muted);

}



.clinica-productos h4,

.clinica-asignacion h4 {

  margin: 0 0 12px 0;

  color: var(--c-gold-l);

  font-weight: 700;

  font-size: 0.95rem;

  font-family: 'Montserrat', sans-serif;

}



.clinica-productos p {

  margin: 0;

  color: #fff;

  font-weight: 500;

}



.clinica-asignacion {

  background: rgba(198, 148, 26, 0.1);

}



.clinica-candidata {

  background: var(--c-bg-secondary);

  border-left: 4px solid var(--c-gold);

  padding: 12px 16px;

  border-radius: var(--radius-sm);

}



.clinica-candidata-name {

  font-weight: 700;

  color: var(--c-gold-l);

  font-size: 1.05rem;

  font-family: 'Montserrat', sans-serif;

}



.clinica-candidata-region {

  font-size: 0.85rem;

  color: var(--c-text-muted);

  margin-top: 6px;

  font-family: 'Montserrat', sans-serif;

}



/* Colores por escenario */

.clinica-item--1 .clinica-header { border-left: 4px solid #d63031; }

.clinica-item--2 .clinica-header { border-left: 4px solid #e67e22; }

.clinica-item--3 .clinica-header { border-left: 4px solid #e24a6d; }

.clinica-item--4 .clinica-header { border-left: 4px solid #9b59b6; }

.clinica-item--5 .clinica-header { border-left: 4px solid #3498db; }

.clinica-item--6 .clinica-header { border-left: 4px solid #27ae60; }

.clinica-item--7 .clinica-header { border-left: 4px solid #17a2b8; }

.clinica-item--8 .clinica-header { border-left: 4px solid #C6941A; }