/* ============================================================
   Fiche lieu — Les Alvéoles-Portails  (scopé .sp-fiche)
   Hero immersif + 2 colonnes (récit | infos & actions).
   Mobile -> tablette -> ordinateur.
   ============================================================ */

.sp-fiche{
  --parchemin:#F5EEE0; --creme:#FBF6EA; --kraft:#E9D8B6;
  --ecorce:#2A2017; --noyer:#553A22; --ambre:#E8A83A; --ambre-clair:#F2C766;
  --ambre-texte:#8A5712; --chene:#2D5A27; --granit:#6B7079; --granit-clair:#9097A0;
  --trait:#D8C8A6;
  --serif:'Playfair Display',Georgia,serif; --sans:'Montserrat',system-ui,sans-serif;
  background:var(--parchemin);color:var(--ecorce);font-family:var(--sans);line-height:1.66;
}
.sp-fiche *{box-sizing:border-box}
.sp-fiche a{text-decoration:none}
.sp-fiche .mk{display:inline-block;width:13px;height:12px;background:var(--ambre);clip-path:polygon(25% 0,75% 0,100% 50%,75% 100%,25% 100%,0 50%);margin-right:4px}

/* ---------- HERO ---------- */
.sp-hero{position:relative;width:100vw;left:50%;right:50%;margin-left:-50vw;margin-right:-50vw;
  min-height:clamp(320px,42vw,480px);display:flex;align-items:flex-end;justify-content:center;
  background-size:cover;background-position:center;color:#FBF6EA}
.sp-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(42,32,23,.28),rgba(42,32,23,.84))}
.sp-hero__inner{position:relative;z-index:2;width:100%;max-width:1080px;padding:30px 24px 34px;text-align:center}
.sp-bread{font-size:.78rem;letter-spacing:.04em;color:#EAD9B6;opacity:.92;margin-bottom:12px}
.sp-bread .sep{opacity:.6;margin:0 2px}
.sp-chip{display:inline-flex;align-items:center;font-size:.74rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;
  background:rgba(251,246,234,.16);border:1px solid rgba(251,246,234,.5);color:#FBF6EA;padding:6px 13px;border-radius:30px}
.sp-fiche .sp-hero__title{font-family:var(--serif);font-weight:800;font-size:clamp(2rem,5.5vw,3.4rem);line-height:1.05;margin:14px 0 14px;color:#FBF6EA !important;text-shadow:0 2px 22px rgba(0,0,0,.6),0 1px 4px rgba(0,0,0,.55)}
.sp-badge{display:inline-block;font-size:.8rem;font-weight:700;padding:8px 16px;border-radius:30px}
.sp-badge.is-owned{background:var(--chene);color:#F0F7ED}
.sp-badge.is-todo{background:var(--ambre);color:#3a2906}

/* ---------- CONTENEUR ---------- */
.sp-wrap{max-width:760px;margin:0 auto;padding:30px 18px 48px}
.sp-layout{display:block}

.sp-section{background:var(--creme);border:1px solid var(--trait);border-radius:16px;padding:20px 20px;margin-top:18px}
.sp-section:first-child{margin-top:0}
.sp-title{font-family:var(--serif);font-weight:700;font-size:1.2rem;color:var(--ecorce);margin:0 0 12px;display:flex;align-items:center}
.sp-lead{color:#4a4034;font-size:.92rem;margin:0 0 12px}
.sp-muted{color:var(--granit)}

/* récit */
.sp-rich{color:#3c352b;font-size:1rem}
.sp-rich p{margin:0 0 12px}
.sp-rich a{color:var(--ambre-texte);font-weight:600}

/* mot du guide */
.sp-guidewrap{background:linear-gradient(160deg,#FBF6EA,#EFE2C6);border-color:#E0CFA6}
.sp-guide{display:flex;gap:15px;align-items:center}
.sp-guide__av{width:62px;height:62px;flex:none;border-radius:14px;overflow:hidden;background:linear-gradient(165deg,#6A4A2C,#3C2716);
  display:flex;align-items:center;justify-content:center;color:var(--ambre-clair);font-size:1.7rem}
.sp-guide__av img{width:100%;height:100%;object-fit:cover}
.sp-guide__name{font-family:var(--serif);font-weight:700;font-size:1.05rem;color:var(--ecorce)}
.sp-guide__role{color:var(--ambre-texte);font-weight:600;font-size:.82rem;margin-left:4px}
.sp-guide__txt{font-style:italic;color:var(--noyer);margin-top:5px;font-size:.95rem}

/* compagnons */
.sp-comps{display:flex;flex-direction:column;gap:9px}
.sp-comp{display:flex;align-items:center;gap:12px;background:var(--parchemin);border:1px solid var(--trait);border-radius:13px;padding:10px 12px;color:var(--ecorce)}
a.sp-comp{transition:border-color .15s}
a.sp-comp:hover{border-color:var(--ambre)}
.sp-comp__hex{width:42px;height:38px;flex:none;display:flex;align-items:center;justify-content:center;font-size:1.05rem;
  clip-path:polygon(25% 0,75% 0,100% 50%,75% 100%,25% 100%,0 50%);background:linear-gradient(165deg,#7A5430,#553A22);color:var(--ambre-clair)}
.sp-comp__info{flex:1;min-width:0}
.sp-comp__name{font-family:var(--serif);font-weight:600;font-size:.98rem;line-height:1.15;display:block}
.sp-comp__addr{font-size:.78rem;color:var(--granit);margin-top:2px;display:block}
.sp-comp__chev{color:var(--granit-clair);font-size:1.2rem}

/* étapes */
.sp-steps{display:flex;flex-direction:column;gap:11px}
.sp-step{display:flex;gap:12px;align-items:center}
.sp-step__num{width:30px;height:30px;flex:none;border-radius:50%;background:var(--ambre);color:#3a2906;font-weight:800;display:flex;align-items:center;justify-content:center;font-size:.9rem}
.sp-step__txt{font-size:.94rem;color:#3c352b}

/* à proximité */
.sp-near{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
@media(max-width:520px){.sp-near{grid-template-columns:repeat(2,1fr)}}
.sp-near__item{text-align:center;color:var(--ecorce)}
.sp-near__hex{width:78px;height:70px;margin:0 auto 7px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;
  clip-path:polygon(25% 0,75% 0,100% 50%,75% 100%,25% 100%,0 50%);background:var(--kraft);background-size:cover;background-position:center;color:var(--granit);
  border:1px solid #C9B488;transition:transform .15s}
.sp-near__hex.is-owned{background:linear-gradient(165deg,#4E8245,#2D5A27);color:#EAF6E6;border:none}
.sp-near__item:hover .sp-near__hex{transform:translateY(-3px)}
.sp-near__name{font-size:.82rem;font-weight:600;line-height:1.2}

/* infos pratiques */
.sp-info{display:flex;flex-direction:column}
.sp-info__row{display:flex;flex-direction:column;padding:10px 0;border-bottom:1px solid var(--trait)}
.sp-info__row:last-child{border-bottom:none}
.sp-info__k{font-size:.7rem;letter-spacing:.06em;text-transform:uppercase;color:var(--granit);font-weight:700;margin-bottom:3px}
.sp-info__v{font-size:.95rem;color:var(--ecorce)}
.sp-info__v a{color:var(--ambre-texte);font-weight:600}
.sp-ref{font-family:var(--sans);letter-spacing:.04em;color:var(--noyer);font-weight:600}

/* mini-carte */
.sp-map{height:200px;border-radius:13px;overflow:hidden;border:1px solid var(--trait);background:var(--kraft);margin-bottom:12px}
.sp-fiche .leaflet-tile-pane{filter:sepia(.42) saturate(.78) brightness(1.06) contrast(.92) hue-rotate(-8deg)}
.sp-fiche .mk-hex{width:30px;height:27px;display:flex;align-items:center;justify-content:center;font-size:.75rem;
  clip-path:polygon(25% 0,75% 0,100% 50%,75% 100%,25% 100%,0 50%);box-shadow:0 3px 7px rgba(42,32,23,.45)}
.sp-fiche .mk-hex.is-owned{background:linear-gradient(165deg,#4E8245,#2D5A27);color:#EAF6E6}
.sp-fiche .mk-hex.is-todo{background:radial-gradient(circle at 50% 40%,var(--ambre-clair),var(--ambre) 62%,#B97F1E);color:#4a3408}

/* progression */
.sp-prog__top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:8px}
.sp-prog__grade{font-family:var(--serif);font-weight:700;font-size:1rem;color:var(--ecorce)}
.sp-prog__count{font-size:.82rem;font-weight:700;color:var(--ambre-texte)}
.sp-bar{height:11px;border-radius:30px;background:#E4D6B6;overflow:hidden;border:1px solid #D2BE92}
.sp-bar>span{display:block;height:100%;background:linear-gradient(90deg,var(--ambre),var(--ambre-clair));border-radius:30px}
.sp-prog__next{font-size:.8rem;color:var(--granit);margin-top:8px}
.sp-prog__next b{color:var(--noyer)}

/* actions */
.sp-ctas{display:flex;flex-direction:column;gap:10px;margin-top:18px}
.sp-cta{display:flex;align-items:center;justify-content:center;gap:8px;font-weight:700;font-size:.98rem;padding:14px;border-radius:12px;transition:transform .15s}
.sp-cta:hover{transform:translateY(-2px)}
.sp-cta--primary{background:var(--ambre);color:#3a2906;box-shadow:0 8px 20px -8px rgba(138,87,18,.55)}
.sp-cta--green{background:var(--chene);color:#F0F7ED}
.sp-cta--ghost{background:var(--parchemin);border:1px solid var(--trait);color:var(--noyer)}

/* signature */
.sp-sign{text-align:center;margin-top:26px;padding-top:18px;border-top:1px solid var(--trait)}
.sp-sign span{font-family:var(--serif);font-size:.78rem;color:var(--noyer);font-style:italic}
.sp-sign b{font-style:normal;letter-spacing:.1em}

/* ---------- TABLETTE & ORDINATEUR ---------- */
@media (min-width:768px){
  .sp-wrap{max-width:820px}
}
@media (min-width:1024px){
  .sp-wrap{max-width:1100px;padding-top:36px}
  .sp-layout{display:grid;grid-template-columns:minmax(0,1.7fr) minmax(0,1fr);gap:38px;align-items:start}
  .sp-main .sp-section:first-child,.sp-aside .sp-section:first-child{margin-top:0}
  .sp-aside{position:sticky;top:24px}
  .sp-aside .sp-ctas{margin-top:18px}
}

/* ---------- Audio-guide / récit narratif (module narratif, §4.2 CDC) ---------- */
.sp-narr-audio{display:flex;align-items:center;gap:12px;background:var(--parchemin);border:1px solid var(--trait);border-radius:13px;padding:12px 14px}
.sp-narr-ico{width:42px;height:38px;flex:none;display:flex;align-items:center;justify-content:center;font-size:1rem;
  clip-path:polygon(25% 0,75% 0,100% 50%,75% 100%,25% 100%,0 50%);background:radial-gradient(circle at 50% 40%,var(--ambre-clair),var(--ambre) 62%,#B97F1E);color:#4a3408}
.sp-narr-audio audio{flex:1;min-width:0;height:40px}
.sp-narr-video{width:100%;border-radius:13px;overflow:hidden;border:1px solid var(--trait);display:block;background:#241710}
.sp-narr-meta{font-size:.8rem;color:var(--granit);margin-top:8px}
.sp-narr-trans{color:var(--ambre-texte);font-weight:600}
.sp-narr-locked{color:#4a4034;font-size:.95rem;margin:0 0 12px}
.sp-narr-teaser{margin-top:14px;background:linear-gradient(160deg,#FBF6EA,#EFE2C6);border:1px solid #E0CFA6;border-radius:13px;padding:13px 15px}
.sp-narr-teaser__t{font-size:.88rem;color:var(--noyer);margin-bottom:9px}
.sp-narr-teaser__t b{color:var(--ambre-texte)}
.sp-narr-teaser__n{font-size:.76rem;color:var(--granit);margin-top:7px;font-weight:600}

.sp-info__row--stack{display:flex;flex-direction:column;align-items:flex-start;gap:6px}
.sp-tags{display:flex;flex-wrap:wrap;gap:6px}
.sp-tag{display:inline-block;font-size:.72rem;font-weight:600;padding:3px 9px;border-radius:999px;background:var(--kraft);color:var(--noyer);border:1px solid var(--trait)}
