/* ====== Estilos públicos del plugin WP Competition Register ====== */

/* Contenedor general */
.wpcr-form-wrapper {
  max-width: 480px;
  margin: 0 auto;
  background: #fff;
  padding: 20px;
  border-radius: 10px;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.08);
}

/* Etiquetas */
.wpcr-public-form label {
  font-weight: 600;
  color: #333;
  display: block;
  margin-bottom: 5px;
}

/* Campos */
.wpcr-public-form input[type="text"],
.wpcr-public-form input[type="email"],
.wpcr-public-form input[type="date"],
.wpcr-public-form input[type="tel"],
.wpcr-public-form select {
  width: 100%;
  max-width: 420px;
  padding: 8px 10px;
  border: 1px solid #ccc;
  border-radius: 6px;
  font-size: 14px;
  transition: border-color 0.2s ease;
}

.wpcr-public-form input:focus,
.wpcr-public-form select:focus {
  border-color: #0073aa;
  outline: none;
}

/* Género */
.wpcr-gender-select {
  display: flex;
  gap: 10px;
  justify-content: center;
  margin-top: 8px;
}
.wpcr-gender-select label {
  flex: 1;
  text-align: center;
  background: #f5f5f5;
  border: 2px solid #ccc;
  border-radius: 8px;
  padding: 10px 0;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s ease;
}
.wpcr-gender-select input[type="radio"] {
  position: absolute;
  opacity: 0;
}
.wpcr-gender-select input[type="radio"]:checked + span {
  background-color: #0073aa;
  color: #fff;
  border-color: #0073aa;
}
.wpcr-gender-select span {
  display: block;
}

/* Botón */
.wpcr-public-form .button-primary {
  background-color: #0073aa;
  border-color: #006799;
  font-weight: 600;
  border-radius: 6px;
  padding: 8px 20px;
}
.wpcr-public-form .button-primary:hover {
  background-color: #005d8b;
}

/* =========================
   RESPONSIVE (CORREGIDO)
=========================== */
@media (max-width: 480px) {
  .wpcr-gender-select {
    flex-direction: column;
  }
  .wpcr-gender-select label {
    width: 100%;
  }

  /* Asegurar selects */
  .wpcr-public-form select,
  #provincia_select {
    display: block !important;
  }
}

/* ===========================
   TABLA PÚBLICA
=========================== */
.wpcr-public-table {
  width: 100%;
  border-collapse: collapse;
  margin: 25px 0;
  font-size: 16px;
  background: #fff;
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 0 2px 8px rgba(0,0,0,0.08);
}

.wpcr-public-table thead tr {
  background: #cfcfcf;
  color: white !important;
  text-align: left;
  font-weight: bold;
}

.wpcr-public-table th,
.wpcr-public-table td {
  padding: 12px 14px;
  border-bottom: 1px solid #e5e5e5;
}

.wpcr-public-table tbody tr:nth-child(even) {
  background: #f7f9fc;
}

.wpcr-public-table tbody tr:hover {
  background: #e8f3ff;
  transition: 0.2s ease-in-out;
}

/* ===========================
   LISTADO PÚBLICO (wpcr_list)
=========================== */
.wpcr-list-wrapper {
  margin-top: 25px;
  margin-bottom: 30px;
}

.wpcr-filters {
  display: flex;
  gap: 15px;
  margin-bottom: 15px;
}

.wpcr-filters select,
.wpcr-filters input {
  padding: 8px 10px;
  border-radius: 6px;
  border: 1px solid #ccc;
}
/* ============================================
   Barra superior: filtro + buscador
   ============================================ */
.wpcr-list-toolbar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    background: #f9f9f9;
    padding: 12px 15px;
    border-radius: 8px;
    margin-bottom: 18px;
    gap: 10px;
}

.wpcr-filter-left select {
    padding: 7px 10px;
    border: 1px solid #ccc;
    border-radius: 6px;
    font-size: 14px;
    width: 180px;
}

.wpcr-search-right input {
    padding: 7px 10px;
    border: 1px solid #ccc;
    border-radius: 6px;
    width: 220px;
    max-width: 100%;
    font-size: 14px;
}
	/* Asegurar que las flechas se vean */
.wpcr-public-table th {
    position: relative !important;
    padding-right: 28px !important; /* más espacio para la flecha */
    overflow: visible !important;   /* permite que la flecha sobresalga */
}
/* ===========================
   BOTÓN FINAL WPCR
   =========================== */

.wpcr-submit-btn{
    background:#0073aa;
    color:#fff !important;
    font-weight:600;
    padding:0px 28px 12px 28px;
    border:none;
    border-radius:6px;
    font-size:16px;
    cursor:pointer;
    transition:.2s;
}

.wpcr-submit-btn:hover{
    background:#005d87;
    transform:scale(1.03);
}
/* ==== CARD PRINCIPAL ==== */
.wpcr-card {
    background: #ffffff;
    padding: 30px;
    border-radius: 20px;
    box-shadow: 0 8px 24px rgba(0,0,0,0.08);
    margin-top: 25px;
    max-width: 520px;
    margin-left: auto;
    margin-right: auto;
}

/* ==== TÍTULOS ==== */
.wpcr-card-title {
    font-size: 28px;
    font-weight: 800;
    margin: 0 0 5px 0;
    text-align: left;
}

.wpcr-card-subtitle {
    font-size: 15px;
    color: #666;
    margin: 0 0 25px 0;
}

/* ==== PASO ==== */
.wpcr-step-title {
    font-size: 20px;
    margin-bottom: 20px;
    font-weight: 700;
    color: #1a1a1a;
}
/* ===========================================================
   LISTADO DE EVENTOS — estilos defensivos (independiente del tema)
   =========================================================== */

/* Reset selectivo para todo el componente */
.wpcr-event-list-container,
.wpcr-event-list-container *,
.wpcr-event-list-container *::before,
.wpcr-event-list-container *::after {
    box-sizing: border-box;
}

/* CONTENEDOR */
.wpcr-event-list-container {
    max-width: 1100px;
    margin: 0 auto;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
    font-size: 15px;
    font-weight: 400;
    line-height: 1.5;
    color: #333;
}

/* TABS PRÓXIMOS / PASADOS */
.wpcr-view-tabs {
    display: flex !important;
    gap: 0 !important;
    margin-bottom: 18px !important;
    border-bottom: 2px solid #e0e0e0 !important;
    flex-wrap: wrap;
}

.wpcr-view-tabs a {
    padding: 10px 22px !important;
    text-decoration: none !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    line-height: 1.4 !important;
}

/* FILTROS */
.wpcr-event-filters {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 10px;
    margin-bottom: 24px;
    padding: 14px 16px;
    background: #f7f8fa;
    border-radius: 10px;
    border: 1px solid #e8e8e8;
}

.wpcr-event-filters select {
    padding: 9px 12px;
    font-size: 14px;
    font-family: inherit;
    font-weight: 400;
    line-height: 1.4;
    color: #333;
    background: #fff;
    border: 1px solid #d1d5db;
    border-radius: 7px;
    cursor: pointer;
    flex: 1;
    min-width: 130px;
    max-width: 200px;
    height: auto;
    appearance: auto;
    -webkit-appearance: auto;
}

.wpcr-event-filters select:focus {
    outline: 2px solid #2271b1;
    outline-offset: 1px;
    border-color: #2271b1;
}

.wpcr-event-filters button {
    padding: 9px 20px;
    font-size: 14px;
    font-family: inherit;
    font-weight: 600;
    color: #fff;
    background: #2271b1;
    border: none;
    border-radius: 7px;
    cursor: pointer;
    transition: background 0.2s;
    line-height: 1.4;
    height: auto;
}

.wpcr-event-filters button:hover {
    background: #135e96;
}

/* GRID */
.wpcr-event-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: 24px;
    align-items: start;
}

/* CARD */
.wpcr-event-card {
    background: #fff;
    border-radius: 12px;
    box-shadow: 0 2px 12px rgba(0,0,0,0.09), 0 1px 3px rgba(0,0,0,0.06);
    overflow: hidden;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
    display: flex;
    flex-direction: column;
}

.wpcr-event-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 8px 28px rgba(0,0,0,0.13);
}

/* IMAGEN */
.wpcr-event-card > a:first-child {
    display: block;
    line-height: 0;
    border-bottom: none !important;
    text-decoration: none !important;
}

.wpcr-event-img {
    width: 100%;
    height: 220px;
    object-fit: cover;
    object-position: top;
    display: block;
    border-radius: 0;
}

/* INFO */
.wpcr-event-info {
    padding: 18px 20px 12px;
    flex: 1;
}

.wpcr-event-info h3 {
    font-size: 17px !important;
    font-weight: 700 !important;
    line-height: 1.3 !important;
    margin: 0 0 12px 0 !important;
    padding: 0 !important;
    color: #111 !important;
    letter-spacing: -0.01em;
}

.wpcr-event-info h3 a {
    color: inherit !important;
    text-decoration: none !important;
    border-bottom: none !important;
}

.wpcr-event-info h3 a:hover {
    color: #2271b1 !important;
    text-decoration: none !important;
}

/* META */
.wpcr-event-meta {
    font-size: 13.5px !important;
    font-weight: 400 !important;
    line-height: 1.75 !important;
    color: #444 !important;
    margin: 0 !important;
    padding: 0 !important;
}

.wpcr-event-meta strong {
    font-weight: 600 !important;
    color: #222 !important;
}

/* FOOTER DE LA CARD */
.wpcr-event-card-footer {
    padding: 14px 16px 16px;
    margin-top: auto;
}

/* BOTÓN DE ESTADO */
.wpcr-event-btn {
    display: block !important;
    width: 100% !important;
    text-align: center !important;
    padding: 13px 16px !important;
    border-radius: 8px !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    font-family: inherit !important;
    letter-spacing: 0.04em !important;
    text-transform: uppercase;
    line-height: 1.3 !important;
    border: none !important;
    cursor: default;
    transition: opacity 0.2s, transform 0.15s;
    text-decoration: none !important;
    box-shadow: none !important;
    margin: 0 !important;
}

.wpcr-event-btn.upcoming {
    background: #6c757d !important;
    color: #fff !important;
}

.wpcr-event-btn.active {
    background: #1a9e3f !important;
    color: #fff !important;
    cursor: pointer;
}

.wpcr-event-btn.active:hover {
    background: #157a32 !important;
    transform: translateY(-1px);
    opacity: 0.95;
    text-decoration: none !important;
}

.wpcr-event-btn.full {
    background: #c0392b !important;
    color: #fff !important;
}

.wpcr-event-btn.closed {
    background: #95a5a6 !important;
    color: #fff !important;
}

.wpcr-link-past-events {
    text-align: center;
    margin-top: 35px;
}

/* RESPONSIVE */
@media (max-width: 768px) {
    .wpcr-event-grid {
        grid-template-columns: 1fr;
    }

    .wpcr-event-filters {
        flex-direction: column;
        align-items: stretch;
    }

    .wpcr-event-filters select {
        max-width: 100%;
    }

    .wpcr-view-tabs a {
        font-size: 13px !important;
        padding: 8px 14px !important;
    }
}

@media (min-width: 769px) and (max-width: 1024px) {
    .wpcr-event-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}


/* PANTALLA TABS PRUEBAS */

.wpcr-event-wrapper{max-width:1100px;margin:0 auto;}
.wpcr-tabs{display:flex;gap:8px;border-bottom:2px solid #e0e0e0;margin-bottom:15px;margin-top:10px;flex-wrap:wrap;}
.wpcr-tab-btn{
    border:none;background:#f2f2f2;padding:8px 14px;border-radius:6px 6px 0 0;
    cursor:pointer;font-weight:600;color:#444;
}
.wpcr-tab-btn.active{background:#ffffff;border:1px solid #ddd;border-bottom:2px solid #fff;color:#000;}
.wpcr-tab-panel{display:none !important;padding:10px 0;}
.wpcr-tab-panel.active{display:block !important;}

/* Detalles */
.wpcr-event-box{background:#fff;padding:30px;border-radius:14px;box-shadow:0 10px 30px rgba(0,0,0,.08);}
.wpcr-event-title{font-size:34px;font-weight:800;margin-bottom:10px;color:#0F2B46;text-align:center;}
.wpcr-event-desc{font-size:18px;line-height:1.6;color:#333;margin-bottom:30px;text-align:center;}
.wpcr-cols{display:flex;gap:35px;flex-wrap:wrap;}
.wpcr-left,.wpcr-right{flex:1;min-width:320px;}
.wpcr-left p{font-size:17px;margin:6px 0;}
.wpcr-meta{font-weight:bold;color:#0A2540;}
.wpcr-poster{width:100%;border-radius:12px;box-shadow:0 8px 25px rgba(0,0,0,.25);object-fit:cover;}
.wpcr-btn-insc{
    display:block;margin-top:18px;padding:14px;text-align:center;font-size:20px;
    background:#28a745;color:#fff;border-radius:10px;font-weight:700;text-decoration:none;
    box-shadow:0 6px 16px rgba(20,121,255,.35);transition:.2s;
}
.wpcr-btn-insc:hover{background:#0059D1;transform:translateY(-2px);}
	.wpcr-prices-table{
    width:100%;
    border-collapse:collapse;
    margin-top:6px;
    font-size:15px;
}
.wpcr-prices-range{
    padding:4px 6px;
    color:#444;
}
.wpcr-prices-value{
    padding:4px 6px;
    text-align:right;
    font-weight:700;
    color:#0059D1;
    white-space:nowrap;
}
.wpcr-precio-text{
    font-weight:600;
    font-size:16px;
}
.wpcr-precio-empty{
    color:#888;
}
/* Pagos y corrreos */
.wpcr-bank-box{
    margin-top:25px;
    padding:22px;
    background:#f5f8ff;
    border-left:4px solid #0044cc;
    border-radius:10px;
    text-align:left;
}

.wpcr-bank-box h3{
    margin-top:0;
    color:#0044cc;
}

.wpcr-bank-list{
    margin:12px 0 0 18px;
    line-height:1.7;
}

.wpcr-payment-warning{
    margin-top:18px;
    padding:12px;
    background:#fff3cd;
    border-left:4px solid #ff9800;
    border-radius:6px;
    font-size:14px;
}
.wpcr-btn-download{
    display:inline-block;
    padding:8px 14px;
    background:#005cff;
    color:#fff;
    text-decoration:none;
    border-radius:6px;
    font-weight:600;
}
.wpcr-btn-download:hover{
    background:#003ea8;
}
.wpcr-download-btn{
    display:inline-block;
    padding:10px 18px;
    background:#4bb7f5;
    color:#fff !important;
    text-decoration:none;
    border-radius:6px;
    font-weight:600;
}
.wpcr-download-btn:hover{
    background:#2aa6e6;
}


/* Responsive */
@media (max-width: 600px) {
    .wpcr-list-toolbar {
        flex-direction: column;
        align-items: stretch;
    }

    .wpcr-filter-left select,
    .wpcr-search-right input {
        width: 100%;
    }
	.wpcr-public-table th {
    cursor: pointer;
}

.wpcr-public-table th:hover {
    background: #e0eefc;
}
	/* Asegurar que las flechas se vean */
.wpcr-public-table th {
    position: relative !important;
    padding-right: 28px !important; /* más espacio para la flecha */
    overflow: visible !important;   /* permite que la flecha sobresalga */
}
	}