/* =========================================================
   S1 TRAIL CSS — v2.0.0
   CSS Globale per eventi Trail Running
   SentieroUNO — Trieste, Italy
   
   Palette:
   --nv-primary-accent  = rosso  → bordi, fondi pieni, accent
   --nv-text-color      = scuro  → testo base
   --s1-text-dark       = blu    → testo secondario / etichette
   ========================================================= */

/* =========================================================
   Custom Properties locali
   ========================================================= */
:root {
  --s1-text-dark: #01206B;
  --s1-border-light: #e6eaf2;
  --s1-shadow: rgba(11, 31, 68, .06);
  --s1-muted: rgba(15, 23, 42, .50);
  --s1-muted-light: rgba(15, 23, 42, .75);
  --s1-separator: rgba(15, 23, 42, .06);
  --s1-separator-md: rgba(15, 23, 42, .10);
}

/* =========================================================
   Generali — Nascondimenti specifici di pagina
   ========================================================= */

/* Distanza e dislivello dal profilo Waymark */
.elevation-summary {
  display: none;
}

/* Bottone "Più info" su pagine specifiche */
body.page-id-1832 #wp-block-themeisle-blocks-advanced-column-4956dbc0 .wp-block-button,
body.page-id-95316 #wp-block-themeisle-blocks-advanced-column-7c705a1c .wp-block-button,
body.page-id-2524 #wp-block-themeisle-blocks-advanced-column-725f10a7 .wp-block-button {
  display: none;
}

/* "Ordina per" WooCommerce */
.nv-woo-filters {
  display: none;
}

/* Fix Gutenberg: blocchi con bordo colore ma senza style/width */
.wp-block-group.has-border-color {
  border-style: solid;
  border-width: 1px;
}

/* Link dalle mappe Waymark */
.waymark-description-link .waymark-map-link,
.waymark-description-link .waymark-collection-link {
  display: none !important;
}

/* =========================================================
   Bora — Grid 4 colonne
   ========================================================= */
.bora-tech-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
  align-items: start;
}
@media (max-width: 1200px) {
  .bora-tech-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 720px) {
  .bora-tech-grid { grid-template-columns: 1fr; }
}

/* =========================================================
   Bora — Mattonelle (colonne)
   ========================================================= */
.bora-tech-col {
  min-width: 0;
  background: var(--nv-light-bg);
  border: 1px solid var(--s1-border-light);
  border-radius: 18px;
  padding: 14px 14px 12px;
  box-shadow: 0 10px 24px var(--s1-shadow);
}

/* =========================================================
   Bora — Headings
   ========================================================= */
.bora-tech-h {
  margin: 0 0 14px;
  padding-bottom: 10px;
  font-size: 16px;
  letter-spacing: .06em;
  text-transform: uppercase;
  font-weight: 900;
  color: var(--nv-primary-accent);
  border-bottom: 2px solid var(--nv-primary-accent);
}

.bora-tech-sub {
  margin: 16px 0 8px;
  padding-top: 8px;
  font-size: 14px;
  letter-spacing: .06em;
  text-transform: uppercase;
  font-weight: 900;
  color: var(--nv-primary-accent);
  border-top: 1px solid var(--s1-separator);
}

/* =========================================================
   Bora — Key / Value
   ========================================================= */
.bora-item {
  padding: 6px 0;
  border-bottom: 1px solid var(--s1-separator);
}
.bora-tech-col .bora-item:last-of-type { border-bottom: none; }

.bora-k {
  display: block;
  font-size: .78em;
  font-weight: 700;
  letter-spacing: .03em;
  text-transform: uppercase;
  color: var(--s1-muted);
  margin: 0 0 2px;
}

.bora-v {
  display: block;
  font-size: .95em;
  font-weight: 600;
  color: var(--nv-text-color);
  line-height: 1.45;
}

/* =========================================================
   Bora — Liste
   ========================================================= */
.bora-list li {
  margin: 4px 0;
  line-height: 1.45;
  font-size: .93em;
  color: var(--s1-text-dark) !important;
}
/* =========================================================
   Bora — Punti (Ristori / Cancelli / Controlli)
   ========================================================= */
.bora-points { list-style: none; margin: 0; padding: 0; }

.bora-point {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 10px;
  align-items: start;
  padding: 8px 0;
  border-bottom: 1px solid var(--s1-separator-md);
}
.bora-tech-col .bora-point:last-of-type { border-bottom: none; }

.bora-icos { white-space: nowrap; }

.bora-point-line {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: baseline;
}

.bora-point-title {
  font-weight: 700;
  font-size: .93em;
  color: var(--nv-text-color);
}

.bora-point-time {
  font-weight: 900;
  color: var(--nv-primary-accent);
  white-space: nowrap;
}
.bora-point-time::before {
  content: "⏱ ";
  font-weight: 900;
  color: var(--nv-primary-accent);
}

.bora-point-meta {
  display: block;
  margin-top: 2px;
  color: var(--s1-muted-light);
  line-height: 1.32;
}

/* =========================================================
   Bora — Legenda
   ========================================================= */
.bora-legend {
  margin-top: 14px;
  padding-top: 8px;
  border-top: 1px solid var(--s1-separator);
  font-size: 12px;
  color: var(--s1-muted-light);
  line-height: 1.42;
}

/* =========================================================
   Bora — CTA Pills
   ========================================================= */
.bora-pills { display: flex; gap: 8px; flex-wrap: wrap; margin: 10px 0 0; }

.bora-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  gap: 8px;
  padding: 8px 10px;
  border-radius: 12px;
  border: 2px solid var(--nv-primary-accent);
  color: var(--nv-primary-accent);
  font-size: .85em;
  font-weight: 900;
  text-decoration: none;
  white-space: nowrap;
  line-height: 1.1;
  transition: background .2s, color .2s;
}
.bora-pill:hover {
  background: var(--nv-primary-accent);
  color: #fff;
}

.bora-pill-wide { flex: 1 1 100%; }

/* =========================================================
   Bora — Certificato medico
   ========================================================= */
.bora-cert .bora-item { padding: 8px 0; }
.bora-cert .bora-tech-sub { margin-top: 12px; }
.bora-cert .bora-cert-list { margin-top: 8px; }

.bora-note {
  margin-top: 10px;
  padding: 10px 12px;
  border-radius: 14px;
  border: 1px dashed var(--nv-primary-accent);
  background: rgba(255, 0, 0, .04);
  color: var(--nv-text-color);
  line-height: 1.42;
}
.bora-note strong { color: var(--nv-primary-accent); }

/* =========================================================
   Bora — Info Tecniche Short (Otter Icon List)
   ========================================================= */
.bora-tech-shortbar,
.bora-tech-short,
.bora-tech-short-svg-wrap {
  background: transparent !important;
  box-shadow: none !important;
  border: 0 !important;
}

.bora-tech-short { width: 100%; }

.bora-tech-short .wp-block-themeisle-blocks-icon-list.is-style-horizontal {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  align-items: center;
  justify-content: center;
  margin: 0;
}

.bora-tech-short .wp-block-themeisle-blocks-icon-list-item {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 0;
}

.bora-tech-short .wp-block-themeisle-blocks-icon-list-item-content-custom {
  margin: 0;
  line-height: 1.15;
}

.bora-tech-short a {
  text-decoration: underline;
  text-underline-offset: 2px;
  text-decoration-thickness: 2px;
}

@media (max-width: 720px) {
  .bora-tech-short .wp-block-themeisle-blocks-icon-list.is-style-horizontal { gap: 12px; }
}

/* =========================================================
   Bora — Info Tecniche Short (SVG Custom)
   Bordini rossi, testo blu scuro
   ========================================================= */
.bora-tech-short-svg {
  display: flex !important;
  flex-wrap: wrap !important;
  justify-content: center !important;
  align-items: center !important;
  gap: 12px 18px !important;
  margin: 14px auto 22px !important;
  background: transparent !important;
  box-shadow: none !important;
  border: 0 !important;
  padding: 0 !important;
}

.bora-tech-short-svg .bora-short-item {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  padding: 7px 10px !important;
  border-radius: 999px !important;
  border: 1.5px solid var(--nv-primary-accent) !important;
  background: transparent !important;
  color: var(--s1-text-dark) !important;
  line-height: 1.1 !important;
  white-space: nowrap !important;
}

.bora-tech-short-svg .bora-short-item svg {
  flex: 0 0 18px !important;
  color: var(--nv-primary-accent) !important;
  opacity: .95 !important;
}

.bora-tech-short-svg .bora-short-item strong {
  font-weight: 900 !important;
  font-size: 14px !important;
  color: var(--s1-text-dark) !important;
  letter-spacing: .01em !important;
}

@media (max-width: 720px) {
  .bora-tech-short-svg { gap: 10px 12px !important; margin: 12px auto 18px !important; }
  .bora-tech-short-svg .bora-short-item { padding: 6px 9px !important; }
  .bora-tech-short-svg .bora-short-item strong { font-size: 13.5px !important; }
}

/* =========================================================
   SARDON RUN — Gare Cards
   ========================================================= */
.sardon-gare {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  max-width: 1200px;
  margin: 30px auto;
  padding: 0 12px;
  box-sizing: border-box;
}

.sardon-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: 16px 10px 20px;
}

.sardon-icon {
  width: 68px;
  height: auto;
  margin-bottom: 8px;
}

.sardon-title {
  font-size: 1.2rem;
  font-weight: 700;
  margin: 0 0 2px;
  line-height: 1.25;
}

.sardon-t1 { color: #e87461; }
.sardon-t2 { color: #2563a0; }
.sardon-t3 { color: #1a7a5c; }
.sardon-t4 { color: #1e2a4a; }

.sardon-dist {
  font-size: 0.85rem;
  font-weight: 600;
  margin: 0 0 6px;
  color: #333;
  letter-spacing: 0.02em;
}

.sardon-desc {
  font-size: 0.85rem;
  line-height: 1.4;
  margin: 0 0 12px;
  color: #555;
  flex-grow: 1;
}

.sardon-btn {
  display: inline-block;
  padding: 8px 22px;
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--s1-text-dark);
  border: 2.5px solid var(--s1-text-dark);
  border-radius: 12px;
  text-decoration: none;
  transition: background .2s, color .2s;
  margin-top: auto;
}
.sardon-btn:hover {
  background: var(--s1-text-dark);
  color: #fff;
}

@media (max-width: 900px) {
  .sardon-gare {
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
  }
}

@media (max-width: 540px) {
  .sardon-gare {
    grid-template-columns: 1fr;
    gap: 6px;
    padding: 0 8px;
  }
  .sardon-card {
    display: grid;
    grid-template-columns: 50px 1fr;
    grid-template-rows: auto auto auto auto;
    text-align: left;
    align-items: center;
    padding: 12px 10px;
    gap: 12px;
  }
  .sardon-icon {
    grid-row: 1 / -1;
    align-self: start;
    width: 50px;
    flex-shrink: 0;
    margin: 2px 0 0;
  }
  .sardon-title { font-size: 1.05rem; margin: 0; }
  .sardon-dist  { font-size: 0.8rem;  margin: 0; }
  .sardon-desc  { font-size: 0.8rem;  margin: 2px 0 6px; }
  .sardon-btn   { justify-self: start; padding: 6px 16px; font-size: 0.78rem; }
}


/* =========================================================
   Sardon Run — Layout Uniformity
   Uniforma sezioni full-width al contenitore standard (1170px)
   Gallery, mappa Waymark, griglie root-level
   ========================================================= */

/* Max-width su tutte le bora-tech-grid (safe: le nested
   sono già più strette del loro parent Themeisle) */
.bora-tech-grid {
  max-width: 1170px;
  margin-left: auto;
  margin-right: auto;
}

/* Padding laterale solo su griglie root-level
   (quelle con inline style, senza wrapper Themeisle) */
.bora-tech-grid[style] {
  padding-left: clamp(20px, 3vw, 40px);
  padding-right: clamp(20px, 3vw, 40px);
}

/* Mappa Waymark */
.waymark-shortcode {
  max-width: 1170px;
  margin-left: auto;
  margin-right: auto;
  padding-left: clamp(20px, 3vw, 40px);
  padding-right: clamp(20px, 3vw, 40px);
  box-sizing: border-box;
}

/* Gallery full-width: foto centrate in 1170px su tutti gli schermi.
   Il background dark rimane edge-to-edge (alignfull sul wrapper),
   il masonry viene contenuto come il resto del layout */
.wp-block-migb-masonry-gallery {
  max-width: 1170px;
  margin-left: auto;
  margin-right: auto;
  padding-left: clamp(16px, 3vw, 40px);
  padding-right: clamp(16px, 3vw, 40px);
  box-sizing: border-box;
}

/* Cover block root-level (sfondo pieno ma contenuto centrato):
   certificato medico, newsletter, sezioni con sfondo */
.entry-content > .wp-block-cover .wp-block-cover__inner-container,
.entry-content > .wp-block-cover .innerblocks-wrap {
  max-width: 1170px;
  margin-left: auto;
  margin-right: auto;
  padding-left: clamp(20px, 3vw, 40px);
  padding-right: clamp(20px, 3vw, 40px);
  box-sizing: border-box;
}

/* =========================================================
   Sardon Run — Homepage intro: larghezza testo
   Rimuove doppio padding (inner-container + innerblocks-wrap)
   per allineare visivamente al .sardon-gare sotto
   ========================================================= */
#wp-block-themeisle-blocks-advanced-columns-9b1d4842 {
  max-width: 100% !important;
}

#wp-block-themeisle-blocks-advanced-columns-9b1d4842 > .innerblocks-wrap {
  padding-left: 0 !important;
  padding-right: 0 !important;
}

/* =========================================================
   Sardon Run — Gare Preview Cards (.s1-card)
   Adattamento da s1trail.com, palette --s1-text-dark
   ========================================================= */
.s1-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;max-width:1170px;margin:40px auto;padding:0 16px;box-sizing:border-box}
.s1-card{position:relative;border-radius:14px;overflow:hidden;background:#fff;box-shadow:0 10px 24px var(--s1-shadow);transition:transform .25s,box-shadow .25s;display:flex;flex-direction:column;border:1px solid var(--s1-border-light)}
.s1-card:hover{transform:translateY(-4px);box-shadow:0 8px 30px rgba(0,0,0,.14)}
.s1-card-img{position:relative;aspect-ratio:4/3;overflow:hidden}
.s1-card-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s}
.s1-card:hover .s1-card-img img{transform:scale(1.04)}
.s1-card-badge{position:absolute;top:12px;left:12px;background:var(--s1-text-dark);color:#fff;font-weight:800;font-size:13px;padding:4px 12px;border-radius:20px;letter-spacing:.3px;text-transform:uppercase;line-height:1.3}
.s1-card-body{padding:18px 20px 20px;display:flex;flex-direction:column;flex:1}
.s1-card-name{margin:0 0 6px;font-size:22px;font-weight:900;line-height:1.2;color:var(--s1-text-dark)}
.s1-card-stats{display:flex;gap:12px;flex-wrap:wrap;margin:0 0 10px;font-size:13.5px;font-weight:600;color:var(--s1-muted-light)}
.s1-card-stats span{display:flex;align-items:center;gap:4px;white-space:nowrap}
.s1-card-desc{margin:0 0 16px;font-size:14px;line-height:1.55;color:#555;flex:1;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.s1-card-foot{display:flex;align-items:center;justify-content:flex-end;gap:12px;margin-top:auto}
.s1-card-cta{display:inline-block;padding:8px 22px;font-size:0.82rem;font-weight:600;color:var(--s1-text-dark);border:2.5px solid var(--s1-text-dark);border-radius:12px;text-decoration:none;transition:background .2s,color .2s}
.s1-card-cta:hover{background:var(--s1-text-dark);color:#fff}
@media(max-width:680px){.s1-cards{grid-template-columns:1fr;gap:16px;padding:0 12px}.s1-card-name{font-size:20px}}
@media(min-width:681px) and (max-width:960px){.s1-cards{grid-template-columns:repeat(2,1fr)}}