/* =====================================================
   concours-style.css
   IdentitÃ© visuelle â€” concours.liegenord.be
   Projet : Ma Borne Ã  Moi
   Base : Twenty Twenty-Five Child â€” Concours Photo
   ===================================================== */

/* -----------------------------------------------------
   1. Variables globales
----------------------------------------------------- */

:root {
  --concours-bg: #ffffff;
  --concours-bg-soft: #fbfaf3;

  --concours-yellow: #ffc928;
  --concours-yellow-soft: #ffee8a;
  --concours-blue: #45aee0;
  --concours-pink: #ec3f92;
  --concours-green: #46a64a;
  --concours-orange: #f47a22;

  --concours-dark: #111111;
  --concours-text: #232323;
  --concours-muted: #667085;
  --concours-border: rgba(17, 17, 17, 0.12);

  --concours-radius-sm: 14px;
  --concours-radius: 28px;
  --concours-radius-lg: 42px;
  --concours-pill: 999px;

  --concours-shadow: 0 10px 28px rgba(0, 0, 0, 0.10);
  --concours-shadow-strong: 0 18px 44px rgba(0, 0, 0, 0.16);

  --concours-title-font: "Baloo 2", system-ui, sans-serif;
  --concours-body-font: "Nunito Sans", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

/* -----------------------------------------------------
   2. Base gÃ©nÃ©rale
----------------------------------------------------- */

.theme-concours-photo {
  background: var(--concours-bg);
  color: var(--concours-text);
  font-family: var(--concours-body-font);
}

.theme-concours-photo .wp-site-blocks {
  background:
    radial-gradient(circle at 8% 8%, rgba(255, 201, 40, 0.18), transparent 28%),
    radial-gradient(circle at 92% 18%, rgba(69, 174, 224, 0.16), transparent 30%),
    radial-gradient(circle at 8% 90%, rgba(236, 63, 146, 0.10), transparent 24%),
    var(--concours-bg);
}

.theme-concours-photo p {
  line-height: 1.65;
}

.theme-concours-photo a {
  color: var(--concours-pink);
  font-weight: 750;
  text-decoration-thickness: 0.08em;
  text-underline-offset: 0.18em;
}

.theme-concours-photo a:hover {
  color: var(--concours-blue);
}

/* -----------------------------------------------------
   3. Titres
----------------------------------------------------- */

.theme-concours-photo h1,
.theme-concours-photo .wp-block-post-title,
.theme-concours-photo .wp-block-query-title {
  font-family: var(--concours-title-font);
  font-weight: 800;
  font-size: clamp(3rem, 7vw, 6.2rem);
  line-height: 0.9;
  letter-spacing: -0.04em;
  color: var(--concours-yellow);
  text-wrap: balance;
}

.theme-concours-photo h2 {
  font-family: var(--concours-title-font);
  font-weight: 800;
  font-size: clamp(2.1rem, 4.8vw, 4rem);
  line-height: 0.95;
  letter-spacing: -0.03em;
  color: var(--concours-blue);
  text-wrap: balance;
}

.theme-concours-photo h3 {
  font-family: var(--concours-title-font);
  font-weight: 800;
  font-size: clamp(1.45rem, 3vw, 2.15rem);
  line-height: 1.05;
  color: var(--concours-pink);
}

.theme-concours-photo .titre-pop {
  font-family: var(--concours-title-font);
  font-weight: 800;
  color: var(--concours-green);
  text-shadow:
    3px 3px 0 rgba(0, 0, 0, 0.10),
    7px 7px 0 rgba(255, 201, 40, 0.35);
}

.theme-concours-photo .titre-pop strong {
  color: var(--concours-orange);
}

/* -----------------------------------------------------
   4. Header
----------------------------------------------------- */

.theme-concours-photo .concours-header {
  border-bottom: 1px solid var(--concours-border);
  background: rgba(255, 255, 255, 0.92);
  backdrop-filter: blur(10px);
  position: relative;
  z-index: 20;
}

.theme-concours-photo .concours-header-inner {
  max-width: 1180px;
  margin: 0 auto;
  padding: 18px clamp(18px, 4vw, 36px);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
}

.theme-concours-photo .concours-brand {
  display: flex;
  align-items: center;
  gap: 14px;
  text-decoration: none;
  color: var(--concours-dark);
}

.theme-concours-photo .concours-brand-mark {
  width: 58px;
  height: 58px;
  border-radius: 18px;
  display: grid;
  place-items: center;
  background:
    linear-gradient(135deg, var(--concours-yellow), var(--concours-orange));
  box-shadow: 0 5px 0 rgba(0, 0, 0, 0.12);
  font-size: 28px;
}

.theme-concours-photo .concours-brand-title {
  display: block;
  font-family: var(--concours-title-font);
  font-size: clamp(1.55rem, 3vw, 2.1rem);
  font-weight: 800;
  line-height: 0.92;
  color: var(--concours-pink);
  letter-spacing: -0.03em;
}

.theme-concours-photo .concours-brand-subtitle {
  display: block;
  margin-top: 4px;
  color: var(--concours-muted);
  font-size: 0.88rem;
  font-weight: 700;
}

.theme-concours-photo .concours-nav {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.theme-concours-photo .concours-nav a {
  color: var(--concours-dark);
  text-decoration: none;
  font-weight: 800;
  font-size: 0.96rem;
  padding: 0.62em 0.88em;
  border-radius: var(--concours-pill);
}

.theme-concours-photo .concours-nav a:hover {
  color: #ffffff;
  background: var(--concours-blue);
}

.theme-concours-photo .concours-nav a.concours-nav-cta {
  color: #ffffff;
  background: var(--concours-pink);
  box-shadow: 0 5px 0 rgba(0, 0, 0, 0.13);
}

.theme-concours-photo .concours-nav a.concours-nav-cta:hover {
  background: var(--concours-green);
  transform: translateY(-1px);
}

/* -----------------------------------------------------
   5. Hero / sections
----------------------------------------------------- */

.theme-concours-photo .concours-hero {
  max-width: 1180px;
  margin: 0 auto;
  padding: clamp(44px, 8vw, 90px) clamp(18px, 4vw, 36px);
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(260px, 0.9fr);
  gap: clamp(28px, 6vw, 70px);
  align-items: center;
}

.theme-concours-photo .concours-kicker {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  width: fit-content;
  margin-bottom: 16px;
  padding: 0.5em 0.9em;
  border-radius: var(--concours-pill);
  background: rgba(69, 174, 224, 0.14);
  color: var(--concours-blue);
  font-weight: 900;
}

.theme-concours-photo .concours-lead {
  font-size: clamp(1.1rem, 2vw, 1.35rem);
  color: var(--concours-text);
  max-width: 62ch;
}

.theme-concours-photo .concours-actions {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  margin-top: 26px;
}

.theme-concours-photo .concours-visual-card {
  border-radius: var(--concours-radius-lg);
  background:
    linear-gradient(135deg, rgba(255, 201, 40, 0.95), rgba(236, 63, 146, 0.86)),
    #fff;
  padding: clamp(18px, 4vw, 32px);
  box-shadow: var(--concours-shadow-strong);
  transform: rotate(1.2deg);
}

.theme-concours-photo .concours-visual-card img {
  border-radius: var(--concours-radius);
  box-shadow: 0 10px 0 rgba(0, 0, 0, 0.12);
}

/* -----------------------------------------------------
   6. Boutons
----------------------------------------------------- */

.theme-concours-photo .wp-block-button__link,
.theme-concours-photo .wp-element-button,
.theme-concours-photo button,
.theme-concours-photo input[type="submit"],
.theme-concours-photo .concours-button {
  font-family: var(--concours-body-font);
  font-weight: 900;
  font-size: 1.04rem;
  color: #ffffff;
  background: var(--concours-pink);
  border: 0;
  border-radius: var(--concours-pill);
  padding: 0.88em 1.55em;
  box-shadow: 0 6px 0 rgba(0, 0, 0, 0.14);
  transition:
    transform 0.18s ease,
    box-shadow 0.18s ease,
    background-color 0.18s ease,
    color 0.18s ease;
}

.theme-concours-photo .wp-block-button__link:hover,
.theme-concours-photo .wp-element-button:hover,
.theme-concours-photo button:hover,
.theme-concours-photo input[type="submit"]:hover,
.theme-concours-photo .concours-button:hover {
  background: var(--concours-blue);
  color: #ffffff;
  transform: translateY(-2px);
  box-shadow: 0 9px 0 rgba(0, 0, 0, 0.16);
}

.theme-concours-photo .is-style-outline .wp-block-button__link,
.theme-concours-photo .concours-button-secondary {
  background: #ffffff;
  color: var(--concours-pink);
  border: 2px solid var(--concours-pink);
  box-shadow: none;
}

.theme-concours-photo .is-style-outline .wp-block-button__link:hover,
.theme-concours-photo .concours-button-secondary:hover {
  background: var(--concours-pink);
  color: #ffffff;
}

/* -----------------------------------------------------
   7. Cartes et blocs
----------------------------------------------------- */

.theme-concours-photo .concours-card,
.theme-concours-photo .wp-block-group.is-style-concours-card {
  background: #ffffff;
  border: 1px solid var(--concours-border);
  border-radius: var(--concours-radius);
  box-shadow: var(--concours-shadow);
  padding: clamp(20px, 4vw, 34px);
}

.theme-concours-photo .concours-step-number {
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: var(--concours-yellow);
  color: var(--concours-dark);
  font-family: var(--concours-title-font);
  font-size: 1.45rem;
  font-weight: 800;
}

/* -----------------------------------------------------
   8. Galerie concours
----------------------------------------------------- */

.theme-concours-photo #concours-galerie {
  font-family: var(--concours-body-font);
}

.theme-concours-photo .cg-grid {
  gap: 26px !important;
}

.theme-concours-photo .cg-card {
  border-radius: var(--concours-radius) !important;
  box-shadow: var(--concours-shadow) !important;
  border: 1px solid var(--concours-border);
}

.theme-concours-photo .cg-card:hover {
  transform: translateY(-5px) rotate(-0.4deg) !important;
  box-shadow: var(--concours-shadow-strong) !important;
}

.theme-concours-photo .cg-participant {
  font-family: var(--concours-title-font) !important;
  font-size: 1.25rem !important;
  color: var(--concours-dark) !important;
}

.theme-concours-photo .cg-address,
.theme-concours-photo .cg-modal-addr {
  color: var(--concours-muted) !important;
}

.theme-concours-photo .cg-votes,
.theme-concours-photo .cg-modal-votes,
.theme-concours-photo a.cg-artist-name,
.theme-concours-photo a.cg-modal-artist-name {
  color: var(--concours-pink) !important;
}

.theme-concours-photo .cg-vote-btn,
.theme-concours-photo .cg-modal-vote-btn {
  background: var(--concours-pink) !important;
  border-radius: var(--concours-pill) !important;
  font-weight: 900 !important;
  box-shadow: 0 5px 0 rgba(0, 0, 0, 0.12);
}

.theme-concours-photo .cg-vote-btn:hover:not(.voted),
.theme-concours-photo .cg-modal-vote-btn:hover:not(.voted) {
  background: var(--concours-blue) !important;
}

.theme-concours-photo .cg-vote-btn.voted,
.theme-concours-photo .cg-modal-vote-btn.voted {
  background: #98a2b3 !important;
  box-shadow: none;
}

/* -----------------------------------------------------
   9. Fiches artistes
----------------------------------------------------- */

.theme-concours-photo .concours-artiste-card {
  background: #ffffff;
  border-radius: var(--concours-radius-lg);
  box-shadow: var(--concours-shadow);
  overflow: hidden;
}

.theme-concours-photo .concours-artiste-photo img {
  border-radius: var(--concours-radius);
  object-fit: cover;
}

.theme-concours-photo .concours-artiste-meta {
  color: var(--concours-muted);
  font-weight: 700;
}

/* -----------------------------------------------------
   10. Carte Leaflet â€” prÃ©paration
----------------------------------------------------- */

.theme-concours-photo .concours-map {
  height: min(72vh, 560px);
  min-height: 420px;
  width: 100%;
  border-radius: var(--concours-radius-lg);
  overflow: hidden;
  box-shadow: var(--concours-shadow-strong);
  border: 4px solid #ffffff;
}

.theme-concours-photo .leaflet-container {
  font-family: var(--concours-body-font);
}

.theme-concours-photo .leaflet-popup-content-wrapper {
  border-radius: 20px;
  box-shadow: var(--concours-shadow);
}

.theme-concours-photo .leaflet-popup-content {
  margin: 16px 18px;
  font-size: 0.95rem;
}

.theme-concours-photo .leaflet-popup-content strong {
  color: var(--concours-pink);
  font-family: var(--concours-title-font);
  font-size: 1.2rem;
}

.theme-concours-photo .leaflet-popup-content a {
  color: var(--concours-blue);
  font-weight: 900;
}

.theme-concours-photo .concours-map-legend {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 14px;
  color: var(--concours-muted);
  font-size: 0.94rem;
}

.theme-concours-photo .concours-map-legend span {
  padding: 0.45em 0.8em;
  border-radius: var(--concours-pill);
  background: var(--concours-bg-soft);
  font-weight: 800;
}
.concours-borne-prefill-info {
    margin-top: 8px;
    padding: 8px 10px;
    border-radius: 8px;
    background: #f3f4f6;
    color: #374151;
    font-size: 14px;
    line-height: 1.4;
}
.popup-borne {
    font-family: inherit;
    max-width: 280px;
}

.popup-borne-bio {
    margin: 0 0 8px;
    font-size: 13px;
    line-height: 1.35;
    color: #374151;

    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.popup-borne-artiste {
    display: block;
    margin: 0 0 8px;
    font-size: 15px;
    font-weight: 800;
    color: #e6007e;
    text-decoration: none;
    line-height: 1.25;
}

.popup-borne-artiste:hover {
    text-decoration: underline;
}

.popup-borne-photo {
    margin: 0 0 8px;
}

.popup-borne-photo img {
    display: block;
    width: 100%;
    max-height: 155px;
    object-fit: cover;
    border-radius: 12px;
}

.popup-borne-adresse {
    margin: 0 0 12px;
    font-size: 12px;
    line-height: 1.35;
    color: #6b7280;
}

.popup-borne-actions {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
}

.btn-carte {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 36px;
    padding: 8px 10px;
    border-radius: 999px;
    text-align: center;
    font-size: 13px;
    font-weight: 800;
    line-height: 1.1;
    text-decoration: none;
    transition: transform .15s ease, background .15s ease;
}

.btn-carte:hover {
    transform: translateY(-1px);
    text-decoration: none;
}

.btn-carte-photos {
    background: #0077c8;
    color: #fff;
}

.btn-carte-photos:hover {
    background: #005f9f;
    color: #fff;
}

.btn-carte-participer {
    background: #e6007e;
    color: #fff;
}

.btn-carte-participer:hover {
    background: #c4006b;
    color: #fff;
}

/* -----------------------------------------------------
   11. Footer
----------------------------------------------------- */

.theme-concours-photo .concours-footer {
  margin-top: clamp(44px, 7vw, 80px);
  background:
    radial-gradient(circle at 10% 20%, rgba(255, 201, 40, 0.32), transparent 30%),
    radial-gradient(circle at 90% 15%, rgba(69, 174, 224, 0.30), transparent 28%),
    var(--concours-dark);
  color: #ffffff;
}

.theme-concours-photo .concours-footer-inner {
  max-width: 1180px;
  margin: 0 auto;
  padding: clamp(34px, 6vw, 64px) clamp(18px, 4vw, 36px);
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(240px, 0.8fr);
  gap: 32px;
}

.theme-concours-photo .concours-footer-title {
  font-family: var(--concours-title-font);
  font-size: clamp(2rem, 4vw, 3.2rem);
  font-weight: 800;
  line-height: 0.95;
  color: var(--concours-yellow);
  margin: 0;
}

.theme-concours-photo .concours-footer p {
  color: rgba(255, 255, 255, 0.82);
  margin: 12px 0 0;
}

.theme-concours-photo .concours-footer a {
  color: #ffffff;
  text-decoration: none;
  font-weight: 850;
}

.theme-concours-photo .concours-footer a:hover {
  color: var(--concours-yellow);
}

.theme-concours-photo .concours-footer-links {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-content: start;
}

.theme-concours-photo .concours-footer-links a {
  padding: 0.55em 0.85em;
  border-radius: var(--concours-pill);
  background: rgba(255, 255, 255, 0.12);
}

.theme-concours-photo .concours-footer-links a:hover {
  background: var(--concours-pink);
  color: #ffffff;
}

.theme-concours-photo .concours-footer-bottom {
  border-top: 1px solid rgba(255, 255, 255, 0.14);
  padding-top: 20px;
  margin-top: 26px;
  font-size: 0.92rem;
  color: rgba(255, 255, 255, 0.72);
}

/* Masque les Ã©lÃ©ments footer par dÃ©faut si un ancien footer TT5 subsiste */
.theme-concours-photo footer .wp-block-site-title + .wp-block-navigation {
  display: none;
}

/* -----------------------------------------------------
   12. Responsive
----------------------------------------------------- */

@media (max-width: 880px) {
  .theme-concours-photo .concours-header-inner {
    align-items: flex-start;
    flex-direction: column;
  }

  .theme-concours-photo .concours-nav {
    justify-content: flex-start;
  }

  .theme-concours-photo .concours-hero {
    grid-template-columns: 1fr;
  }

  .theme-concours-photo .concours-footer-inner {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 620px) {
  .theme-concours-photo .concours-brand-mark {
    width: 50px;
    height: 50px;
    border-radius: 16px;
    font-size: 24px;
  }

  .theme-concours-photo .concours-nav {
    gap: 6px;
  }

  .theme-concours-photo .concours-nav a {
    font-size: 0.9rem;
    padding: 0.5em 0.68em;
  }

  .theme-concours-photo h1,
  .theme-concours-photo .wp-block-post-title {
    font-size: clamp(2.6rem, 14vw, 4rem);
  }

  .theme-concours-photo h2 {
    font-size: clamp(2rem, 11vw, 3rem);
  }

  .theme-concours-photo .concours-map {
    min-height: 360px;
    height: 62vh;
  }
/* -----------------------------------------------------
   Footer logos partenaires
----------------------------------------------------- */

.theme-concours-photo .concours-footer-inner {
  grid-template-columns:
    minmax(280px, 1.1fr)
    minmax(220px, 0.9fr)
    minmax(260px, 0.9fr);
}

.theme-concours-photo .concours-footer-logos {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: clamp(18px, 2vw, 28px);
  flex-wrap: nowrap;
}

.theme-concours-photo .concours-footer-logos a {
  display: flex;
  align-items: center;
  justify-content: center;
  transition:
    transform .18s ease,
    opacity .18s ease;
}

.theme-concours-photo .concours-footer-logos a:hover {
  transform: translateY(-2px);
  opacity: .92;
}

/* Uniformisation des hauteurs */
.theme-concours-photo .concours-footer-logos img {
  height: 62px;
  width: auto;
  max-width: 180px;
  object-fit: contain;
  display: block;
  filter: brightness(1);
}

/* Logo comité plus horizontal */
.theme-concours-photo .concours-footer-logos img[alt*="Comité"] {
  max-width: 220px;
}

/* Responsive */
@media (max-width: 900px) {

  .theme-concours-photo .concours-footer-inner {
    grid-template-columns: 1fr;
  }

  .theme-concours-photo .concours-footer-logos {
    justify-content: center;
    flex-wrap: wrap;
    margin-top: 14px;
  }

  .theme-concours-photo .concours-footer-logos img {
    height: 52px;
  }
 /* =========================================================
   FORMINATOR — correction forte champs trop petits
   À placer tout en bas du CSS
   ========================================================= */

/* Champs texte, email, select, textarea */
body .forminator-ui.forminator-custom-form[data-design="default"] 
.forminator-field input.forminator-input,
body .forminator-ui.forminator-custom-form[data-design="default"] 
.forminator-field textarea.forminator-textarea,
body .forminator-ui.forminator-custom-form[data-design="default"] 
.forminator-field select.forminator-select--field {
  display: block !important;
  width: 100% !important;
  min-height: 50px !important;
  height: auto !important;
  padding: 12px 14px !important;
  font-size: 16px !important;
  line-height: 1.4 !important;
  box-sizing: border-box !important;
}

/* Cas où Forminator utilise un faux select */
body .forminator-ui.forminator-custom-form[data-design="default"] 
.forminator-select2 + .select2-container .select2-selection {
  min-height: 50px !important;
  height: 50px !important;
  padding: 10px 14px !important;
  font-size: 16px !important;
  line-height: 28px !important;
  box-sizing: border-box !important;
}

body .forminator-ui.forminator-custom-form[data-design="default"] 
.select2-container .select2-selection__rendered {
  line-height: 28px !important;
  font-size: 16px !important;
}

/* Labels */
body .forminator-ui.forminator-custom-form[data-design="default"] 
.forminator-label {
  font-size: 18px !important;
  line-height: 1.35 !important;
  margin-bottom: 8px !important;
}

/* Bouton upload */
body .forminator-ui.forminator-custom-form[data-design="default"] 
.forminator-button-upload {
  min-height: 50px !important;
  padding: 12px 24px !important;
  font-size: 16px !important;
  line-height: 1.3 !important;
  border-radius: 999px !important;
}

/* Checkbox native */
body .forminator-ui.forminator-custom-form[data-design="default"] 
input[type="checkbox"] {
  appearance: auto !important;
  -webkit-appearance: checkbox !important;
  width: 20px !important;
  height: 20px !important;
  min-width: 20px !important;
  min-height: 20px !important;
  margin: 4px 10px 0 0 !important;
  padding: 0 !important;
  transform: none !important;
  accent-color: #e6007e !important;
}

/* Ligne de consentement */
body .forminator-ui.forminator-custom-form[data-design="default"] 
.forminator-checkbox,
body .forminator-ui.forminator-custom-form[data-design="default"] 
.forminator-consent {
  display: flex !important;
  align-items: flex-start !important;
  gap: 10px !important;
}

/* Texte consentement */
body .forminator-ui.forminator-custom-form[data-design="default"] 
.forminator-checkbox-label,
body .forminator-ui.forminator-custom-form[data-design="default"] 
.forminator-checkbox-label p,
body .forminator-ui.forminator-custom-form[data-design="default"] 
.forminator-consent__label {
  font-size: 18px !important;
  line-height: 1.55 !important;
}