/* ============================================================
   RANDOGUIDE PAGES — Extracted from Sentières prototypes
   Article (itinéraire), Destination (région), Bivouac
   ============================================================ */

/* --- Shared: Breadcrumb --- */
.breadcrumb{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft);padding:16px 48px 0}
.breadcrumb a{color:inherit;text-decoration:none;border-bottom:1px dashed rgba(30,42,29,.35)}

/* --- Shared: Prose --- */
.prose{max-width:68ch}
.prose h2{font-size:30px;font-weight:400;letter-spacing:-.02em;margin:40px 0 12px}
.prose h3{font-size:20px;font-weight:500;margin:24px 0 8px}
.prose p{font-size:17px;line-height:1.65;margin-bottom:16px;color:var(--ink-2)}
.prose p:first-of-type::first-letter{font-family:var(--display);font-size:68px;font-weight:400;float:left;line-height:.85;margin:6px 8px 0 0;color:var(--terra)}
.prose a{color:var(--ink);border-bottom:1px solid var(--ink);text-decoration:none}
.prose img{width:100%;max-height:400px;object-fit:cover;border-radius:var(--rad-md);border:var(--hairline);margin:1.5rem 0}
.prose ul,.prose ol{margin:1rem 0 1.5rem 1.5rem}
.prose li{margin-bottom:.4rem}
.prose blockquote{border-left:3px solid var(--terra);padding:4px 0 4px 20px;margin:28px 0;font-family:var(--display);font-style:italic;font-weight:300;font-size:20px;line-height:1.35;color:var(--ink-2)}
.prose strong{font-weight:600;color:var(--ink)}
.prose div,.prose section{background:var(--paper-2);border:var(--hairline);border-radius:var(--rad-md);padding:16px;margin:1rem 0;font-size:15px}
.prose div h2,.prose div h3,.prose div h4{font-size:18px;margin:0 0 8px}
.prose div p{font-size:14px;line-height:1.5;margin:0 0 8px}

/* --- Shared: Right Rail / Fact Card --- */
.rail{position:sticky;top:24px}
.fact-card{background:var(--paper-2);border:var(--hairline);border-radius:var(--rad-md);padding:20px;margin-bottom:16px;box-shadow:var(--press)}
.fact-card h4{font-family:var(--mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-soft);border-bottom:1px solid rgba(30,42,29,.3);padding-bottom:10px;margin:0 0 14px}
.fact-card .row-fact{display:flex;justify-content:space-between;padding:7px 0;border-bottom:1px dashed rgba(30,42,29,.14);font-size:13px}
.fact-card .row-fact:last-child{border-bottom:0}
.fact-card .row-fact .k{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);padding-top:2px}
.fact-card .row-fact .v{font-family:var(--display);font-weight:500;font-size:15px;text-align:right}
.fact-card .row-fact .v small{font-family:var(--mono);font-size:10px;font-weight:400;color:var(--ink-soft);letter-spacing:.1em}

/* --- Shared: TOC --- */
.toc{position:sticky;top:24px;font-family:var(--mono);font-size:11px}
.toc h5{font-family:var(--mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-soft);margin:0 0 12px;padding-bottom:8px;border-bottom:1px solid rgba(30,42,29,.3)}
.toc a{display:flex;padding:7px 0;color:var(--ink-2);text-decoration:none;border-bottom:1px dashed rgba(30,42,29,.14);gap:8px}
.toc a:hover,.toc a.active{color:var(--terra)}
.toc .num{color:var(--ink-faint);min-width:22px}

/* --- Shared: Callouts --- */
.callout{margin:20px 0;padding:14px 18px;background:var(--paper-2);border-left:3px solid var(--terra);border-radius:2px;font-size:14px;color:var(--ink-2)}
.callout.moss{border-color:var(--moss)}
.callout.stream{border-color:var(--stream)}
.callout .k{font-family:var(--mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--terra);margin-bottom:6px;display:block}
.callout.moss .k{color:var(--moss)}
.callout.stream .k{color:var(--stream)}

/* --- Shared: Pull quote --- */
.pull-quote{border-left:3px solid var(--terra);padding:4px 0 4px 20px;margin:28px 0;font-family:var(--display);font-style:italic;font-weight:300;font-size:22px;line-height:1.35}
.quote-pull{border-left:3px solid var(--terra);margin:28px 0;padding:4px 0 4px 20px;font-family:var(--display);font-style:italic;font-weight:300;font-size:22px;color:var(--ink);line-height:1.35}

/* ============================================================
   ARTICLE (Itinéraire) page
   ============================================================ */
.article-hero{padding:32px 48px 40px;display:grid;grid-template-columns:1.1fr 1fr;gap:48px;align-items:end}
.article-hero h1{font-size:clamp(52px,6vw,92px);line-height:.95;font-weight:400;letter-spacing:-.03em;margin:16px 0 24px}
.article-hero h1 em{font-style:italic;font-weight:300;color:var(--moss)}
.hero-side .topo{aspect-ratio:4/3;border:var(--hairline);position:relative;overflow:hidden;border-radius:var(--rad-md)}
.hero-side .topo img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}
.article-body{padding:0 48px;display:grid;grid-template-columns:240px 1fr 300px;gap:48px;margin-top:48px}

/* Stages */
.stage{display:grid;grid-template-columns:50px 60px 1fr 100px 100px;gap:16px;align-items:center;padding:16px 0;border-bottom:1px dashed rgba(30,42,29,.25)}
.stage .day{font-family:var(--display);font-size:34px;font-weight:400;line-height:1;color:var(--terra)}
.stage .day small{display:block;font-family:var(--mono);font-size:9px;color:var(--ink-soft);letter-spacing:.14em;text-transform:uppercase;margin-top:2px}
.stage .time{font-family:var(--mono);font-size:11px;color:var(--ink-soft);letter-spacing:.1em;text-align:center}
.stage .name{font-family:var(--display);font-size:18px;font-weight:500}
.stage .name small{display:block;font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);font-weight:400;margin-top:3px}
.stage .dist,.stage .elev{font-family:var(--mono);font-size:13px;text-align:right}

/* Profile chart */
.profile-big{height:220px;background:var(--paper-2);border:var(--hairline);border-radius:var(--rad-md);position:relative;padding:20px;margin-top:24px}
.profile-big svg{width:100%;height:100%}
.profile-big .y-axis{position:absolute;left:8px;top:20px;bottom:20px;display:flex;flex-direction:column;justify-content:space-between;font-family:var(--mono);font-size:9px;letter-spacing:.12em;color:var(--ink-soft)}
.profile-big .x-axis{position:absolute;left:40px;right:20px;bottom:4px;display:flex;justify-content:space-between;font-family:var(--mono);font-size:9px;letter-spacing:.12em;color:var(--ink-soft)}

/* Water points */
.water-point{display:grid;grid-template-columns:40px 1fr auto auto;gap:12px;align-items:center;padding:10px 0;border-bottom:1px dashed rgba(30,42,29,.14)}
.water-point:last-child{border-bottom:0}
.water-point .km{font-family:var(--display);font-size:20px;font-weight:500;color:var(--stream)}
.water-point .nm{font-family:var(--display);font-size:14px;font-weight:500}
.water-point .nm small{display:block;font-family:var(--mono);font-size:9px;color:var(--ink-soft);letter-spacing:.14em;text-transform:uppercase;margin-top:2px}
.water-point .st{font-family:var(--mono);font-size:10px;letter-spacing:.15em;text-transform:uppercase;padding:3px 8px;border-radius:2px;border:1px solid currentColor}
.water-point .st.ok{color:var(--moss)}
.water-point .st.wrn{color:var(--ochre)}
.water-point .st.ko{color:var(--terra)}

/* Edit history */
.history{margin-top:36px;padding:20px 0;border-top:2px solid var(--ink);font-size:13px}
.history .h-row{display:grid;grid-template-columns:110px 120px 1fr 60px;gap:12px;padding:8px 0;border-bottom:1px dashed rgba(30,42,29,.14);font-family:var(--mono);font-size:11px}
.history .h-row:last-child{border-bottom:0}
.history .date{color:var(--ink-soft);letter-spacing:.1em}

/* Gallery */
.gallery{display:grid;grid-template-columns:2fr 1fr 1fr;gap:8px;margin:24px 0}
.gallery .ph{aspect-ratio:auto;border-radius:0;border:var(--hairline)}
.gallery .ph:first-child{aspect-ratio:3/2;grid-row:span 2}
.gallery img{width:100%;height:100%;object-fit:cover;border-radius:var(--rad-sm);border:var(--hairline)}
.gallery img:first-child{grid-row:span 2;aspect-ratio:3/2}

/* ============================================================
   DESTINATION (Région) page
   ============================================================ */
.region-hero{display:grid;grid-template-columns:1.1fr 1fr;gap:48px;padding:48px 48px 40px;align-items:end}
.region-hero h1{font-size:clamp(64px,8vw,128px);line-height:.9;font-weight:400;letter-spacing:-.035em;margin:8px 0 20px}
.region-hero h1 em{font-style:italic;font-weight:300;color:var(--terra)}
.region-hero .kicker{font-family:var(--display);font-style:italic;font-weight:300;font-size:22px;color:var(--ink-2);max-width:48ch;line-height:1.4}
.region-map{background:var(--paper-2);border:var(--hairline);border-radius:var(--rad-md);padding:20px;aspect-ratio:4/3;position:relative;overflow:hidden}
.region-map svg{width:100%;height:100%}

/* Infobox (wiki-style) */
.infobox{padding:0 48px;display:grid;grid-template-columns:320px 1fr;gap:48px;margin-top:48px}
.info-card{background:var(--paper-2);border:var(--hairline);border-radius:var(--rad-md);padding:20px;box-shadow:var(--press)}
.info-card h4{font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-soft);border-bottom:1px solid rgba(30,42,29,.25);padding-bottom:10px;margin:0 0 12px}

/* Region stats strip */
.region-stats{margin:0 48px;display:grid;grid-template-columns:repeat(6,1fr);border-top:2px solid var(--ink);border-bottom:1px solid rgba(30,42,29,.3);padding:16px 0;gap:8px}
.region-stats .s{padding:0 14px;border-right:var(--hairline)}
.region-stats .s:last-child{border-right:0}
.region-stats .s .big{font-family:var(--display);font-size:32px;font-weight:500;letter-spacing:-.02em;line-height:1}
.region-stats .s .label{margin-top:6px;display:block}

/* Massif cards */
.massifs{margin:32px 0;display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.massif{background:var(--paper);border:var(--hairline);border-radius:var(--rad-sm);padding:14px}
.massif .num{font-family:var(--display);font-size:30px;font-weight:400;color:var(--terra);line-height:1}
.massif .ttl{font-family:var(--display);font-size:17px;font-weight:500;margin-top:4px}
.massif .sub{font-family:var(--mono);font-size:10px;letter-spacing:.1em;color:var(--ink-soft);margin-top:4px}

/* Trail list */
.region-trails{padding:0 48px;margin-top:96px}
.trail-row{display:grid;grid-template-columns:50px 2fr 1fr 1fr 1fr 1fr 80px;gap:16px;align-items:center;padding:16px 0;border-bottom:1px dashed rgba(30,42,29,.28);text-decoration:none;color:var(--ink)}
.trail-row:hover{background:var(--paper-2);padding-left:8px;padding-right:8px}
.trail-row .idx{font-family:var(--mono);font-size:10px;color:var(--ink-faint);letter-spacing:.1em}
.trail-row .name{font-family:var(--display);font-size:18px;font-weight:500}
.trail-row .name small{display:block;font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);font-weight:400;margin-top:2px}
.trail-row .col{font-family:var(--mono);font-size:12px;color:var(--ink-2)}
.trail-row .arrow{text-align:right;font-family:var(--mono);font-size:16px;color:var(--terra)}
.trail-header{display:grid;grid-template-columns:50px 2fr 1fr 1fr 1fr 1fr 80px;gap:16px;font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft);padding-bottom:10px;border-bottom:2px solid var(--ink)}

/* Filters */
.filters{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:24px;padding:12px 0}
.filter-chip{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;padding:6px 12px;background:transparent;border:1px solid var(--ink);border-radius:2px;cursor:pointer;color:var(--ink)}
.filter-chip.on{background:var(--ink);color:var(--paper)}
.filter-chip.terra.on{background:var(--terra);border-color:var(--terra)}

/* Season calendar */
.seasons{margin:48px 48px 0;padding:28px 32px;border:var(--rule);border-radius:var(--rad-md);background:var(--paper-2)}
.season-grid{display:grid;grid-template-columns:140px repeat(12,1fr);gap:4px;align-items:center;margin-top:18px}
.season-grid .row-label{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-2)}
.season-grid .cell{height:26px;border-radius:2px;background:rgba(30,42,29,.08);border:1px solid rgba(30,42,29,.14)}
.season-grid .cell.ok{background:var(--moss-2);border-color:var(--moss)}
.season-grid .cell.best{background:var(--moss);border-color:var(--moss-deep)}
.season-grid .cell.caution{background:var(--ochre);border-color:#A17D3A}
.season-grid .cell.closed{background:var(--terra);border-color:var(--terra-deep);opacity:.5}
.season-grid .month-label{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-align:center;color:var(--ink-soft);padding:6px 0}
.season-legend{display:flex;gap:22px;margin-top:16px;font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft)}
.season-legend .dot{width:12px;height:12px;border-radius:2px;display:inline-block;margin-right:6px;vertical-align:middle}

/* ============================================================
   BIVOUAC page
   ============================================================ */
.biv-hero{padding:24px 48px 32px;display:grid;grid-template-columns:1fr 380px;gap:48px;align-items:end}
.biv-hero h1{font-size:clamp(48px,6vw,88px);line-height:.95;letter-spacing:-.03em;margin:10px 0 20px;font-weight:400}
.biv-hero h1 em{font-style:italic;font-weight:300;color:var(--stream)}
.hero-fig{aspect-ratio:3/4;border:var(--hairline);position:relative}

/* Bivouac gallery */
.biv-gallery{padding:0 48px;display:grid;grid-template-columns:2fr 1fr 1fr;grid-template-rows:240px 240px;gap:8px;margin-top:24px}
.biv-gallery .ph{aspect-ratio:auto;border-radius:0;border:var(--hairline);height:100%}
.biv-gallery .ph.big{grid-row:span 2}

/* Bivouac body */
.biv-body{padding:48px;display:grid;grid-template-columns:2fr 1fr;gap:48px}

/* Bivouac-specific prose first-letter override */
.biv-body .prose p:first-of-type::first-letter{color:var(--stream)}

/* Rules block */
.rules{margin:20px 0;padding:20px;background:var(--paper-2);border:1.5px solid var(--ink);border-radius:var(--rad-md)}
.rules h3{font-family:var(--mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;margin:0 0 14px;color:var(--ink-soft)}
.rules .rule-row{display:grid;grid-template-columns:32px 1fr;gap:12px;padding:10px 0;border-bottom:1px dashed rgba(30,42,29,.2);font-size:14px}
.rules .rule-row:last-child{border:0}
.rules .rule-row .sym{font-family:var(--display);font-size:20px;font-weight:500;color:var(--terra);line-height:1}
.rules .rule-row.ok .sym{color:var(--moss)}
.rules .rule-row b{font-family:var(--display);font-weight:500;font-size:16px}
.rules .rule-row .small{font-family:var(--mono);font-size:10px;color:var(--ink-soft);letter-spacing:.1em;text-transform:uppercase;margin-top:2px;display:block}

/* Sun/Moon mini cards */
.sun-moon{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:10px}
.sun-moon .mini{background:var(--paper);border:var(--hairline);border-radius:2px;padding:10px;text-align:center}
.sun-moon .mini .lbl{font-family:var(--mono);font-size:9px;letter-spacing:.2em;color:var(--ink-soft);text-transform:uppercase}
.sun-moon .mini .val{font-family:var(--display);font-size:18px;font-weight:500;margin-top:4px}

/* Nearby spots */
.nearby{padding:0 48px}
.nearby-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.nearby-card{background:var(--paper-2);border:var(--hairline);border-radius:var(--rad-md);overflow:hidden;text-decoration:none;color:var(--ink)}
.nearby-card .ph{aspect-ratio:3/2;border:0;border-bottom:var(--hairline);border-radius:0}
.nearby-card .body{padding:14px}
.nearby-card .n{font-family:var(--display);font-size:17px;font-weight:500;margin-bottom:4px}
.nearby-card .d{font-family:var(--mono);font-size:10px;letter-spacing:.15em;text-transform:uppercase;color:var(--ink-soft)}

/* Carbon warning strip */
.cd-strip{padding:24px 32px;margin:0 48px;border:2px solid var(--terra);border-radius:var(--rad-md);display:grid;grid-template-columns:1fr 2fr;gap:24px;background:rgba(181,83,60,.04)}
.cd-strip h3{margin:0 0 6px;font-size:22px;color:var(--terra)}
.cd-strip .num{font-family:var(--display);font-size:64px;font-weight:400;line-height:1;color:var(--terra)}
.cd-strip .num small{font-family:var(--mono);font-size:11px;letter-spacing:.2em;display:block;color:var(--ink-soft)}

.tag-row{display:flex;gap:8px;flex-wrap:wrap;margin:14px 0}

/* ============================================================
   Responsive — Article
   ============================================================ */
@media(max-width:1000px){
  .article-body{grid-template-columns:1fr 260px;gap:32px;padding:0 24px}
  .article-body .toc{display:none}
  .article-hero{grid-template-columns:1fr;gap:24px;padding:24px}
}
@media(max-width:700px){
  .article-body{grid-template-columns:1fr;padding:0 16px}
  .rail{position:static;order:-1}
  .article-hero{padding:16px}
  .article-hero h1{font-size:32px}
  .stage{grid-template-columns:40px 1fr 60px;gap:8px}
  .stage .time,.stage .elev{display:none}
  .gallery{grid-template-columns:1fr 1fr;gap:6px}
  .gallery img:first-child,.gallery .ph:first-child{grid-row:span 1}
}

/* ============================================================
   Responsive — Destination
   ============================================================ */
@media(max-width:1000px){
  .region-hero{grid-template-columns:1fr;gap:24px;padding:24px}
  .infobox{grid-template-columns:1fr;padding:0 24px}
  .region-stats{grid-template-columns:repeat(3,1fr);margin:0 24px}
  .region-trails{padding:0 24px}
  .trail-row{grid-template-columns:40px 2fr 1fr 80px}
  .trail-row .col:nth-child(n+4){display:none}
  .trail-header{grid-template-columns:40px 2fr 1fr 80px}
  .trail-header span:nth-child(n+4){display:none}
  .seasons{margin:48px 24px 0}
  .massifs{grid-template-columns:1fr 1fr}
}
@media(max-width:700px){
  .region-hero{padding:16px}
  .region-hero h1{font-size:clamp(40px,10vw,64px)}
  .region-stats{grid-template-columns:repeat(2,1fr);margin:0 16px}
  .infobox{padding:0 16px}
  .region-trails{padding:0 16px;margin-top:48px}
  .trail-row{grid-template-columns:1fr 80px}
  .trail-row .idx,.trail-row .col{display:none}
  .trail-header{display:none}
  .seasons{margin:32px 16px 0;padding:16px}
  .season-grid{grid-template-columns:80px repeat(12,1fr);gap:2px}
  .season-grid .row-label{font-size:9px}
  .massifs{grid-template-columns:1fr}
}

/* ============================================================
   Responsive — Bivouac
   ============================================================ */
@media(max-width:1000px){
  .biv-hero{grid-template-columns:1fr;gap:24px;padding:24px}
  .biv-body{grid-template-columns:1fr;padding:24px}
  .biv-gallery{grid-template-columns:1fr 1fr;grid-template-rows:auto;padding:0 24px}
  .biv-gallery .ph.big{grid-row:span 1;grid-column:span 2}
  .nearby-grid{grid-template-columns:repeat(2,1fr)}
  .nearby{padding:0 24px}
  .cd-strip{margin:0 24px;grid-template-columns:1fr}
}
@media(max-width:700px){
  .biv-hero{padding:16px}
  .biv-hero h1{font-size:36px}
  .biv-body{padding:16px}
  .biv-gallery{grid-template-columns:1fr;padding:0 16px}
  .biv-gallery .ph.big{grid-column:span 1}
  .nearby-grid{grid-template-columns:1fr}
  .nearby{padding:0 16px}
  .cd-strip{margin:0 16px;padding:16px}
  .cd-strip .num{font-size:40px}
}
