:root,
[data-theme="calcaire"]{
  --bg:#f5f3ee;
  --bg-alt:#ffffff;
  --bg-soft:#fafaf3;
  --text:#2d3a4a;
  --text-muted:#5c6b7a;
  --text-faint:#94a3b8;
  --accent:#4a7c9f;
  --accent-hover:#3a6685;
  --accent-contrast:#ffffff;
  --highlight:#e9a23b;
  --highlight-hover:#d4912f;
  --border:#e3ddcf;
  --border-soft:#f0ead9;
  --header-bg:#2d3a4a;
  --header-text:#ffffff;
  --header-accent:#4a7c9f;
  --footer-bg:#1f2937;
  --footer-text:#94a3b8;
  --section-title-bg:#5c6b7a;
  --section-title-text:#ffffff;
  --label:#4a7c9f;
  --shadow:0 2px 8px rgba(45,58,74,.08);
  --shadow-strong:0 4px 16px rgba(45,58,74,.18);
  --link:#3a6685;
  --link-hover:#2c5068;
  --broken-bg:repeating-linear-gradient(45deg,#e3ddcf,#e3ddcf 8px,#d8cfb8 8px,#d8cfb8 16px);
  --broken-text:#3a2a18;
  color-scheme:light;
}
[data-theme="nuit"]{
  --bg:#131720;
  --bg-alt:#1e2330;
  --bg-soft:#252b3a;
  --text:#e8eaed;
  --text-muted:#a8b0bc;
  --text-faint:#6b7280;
  --accent:#4dd0e1;
  --accent-hover:#26c6da;
  --accent-contrast:#0a0d12;
  --highlight:#ffb74d;
  --highlight-hover:#ffa726;
  --border:#2d3340;
  --border-soft:#1e2330;
  --header-bg:#0f1419;
  --header-text:#e8eaed;
  --header-accent:#4dd0e1;
  --footer-bg:#0a0d12;
  --footer-text:#6b7280;
  --section-title-bg:#252b3a;
  --section-title-text:#e8eaed;
  --label:#4dd0e1;
  --shadow:0 2px 8px rgba(0,0,0,.4);
  --shadow-strong:0 4px 16px rgba(0,0,0,.6);
  --link:#4dd0e1;
  --link-hover:#80deea;
  --broken-bg:repeating-linear-gradient(45deg,#2d3340,#2d3340 8px,#252b3a 8px,#252b3a 16px);
  --broken-text:#a8b0bc;
  color-scheme:dark;
}
@media (prefers-color-scheme:dark){
  :root:not([data-theme]){
    --bg:#131720;
    --bg-alt:#1e2330;
    --bg-soft:#252b3a;
    --text:#e8eaed;
    --text-muted:#a8b0bc;
    --text-faint:#6b7280;
    --accent:#4dd0e1;
    --accent-hover:#26c6da;
    --accent-contrast:#0a0d12;
    --highlight:#ffb74d;
    --highlight-hover:#ffa726;
    --border:#2d3340;
    --border-soft:#1e2330;
    --header-bg:#0f1419;
    --header-text:#e8eaed;
    --header-accent:#4dd0e1;
    --footer-bg:#0a0d12;
    --footer-text:#6b7280;
    --section-title-bg:#252b3a;
    --section-title-text:#e8eaed;
    --label:#4dd0e1;
    --shadow:0 2px 8px rgba(0,0,0,.4);
    --shadow-strong:0 4px 16px rgba(0,0,0,.6);
    --link:#4dd0e1;
    --link-hover:#80deea;
    --broken-bg:repeating-linear-gradient(45deg,#2d3340,#2d3340 8px,#252b3a 8px,#252b3a 16px);
    --broken-text:#a8b0bc;
    color-scheme:dark;
  }
}
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
html{-webkit-text-size-adjust:100%;transition:background-color .25s ease,color .25s ease}
body{font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;color:var(--text);background:var(--bg);line-height:1.5}
a{color:var(--link);text-decoration:none}
a:hover{color:var(--link-hover);text-decoration:underline}
.wrap{max-width:1100px;margin:0 auto;padding:0 1rem}
.site-header{background:var(--header-bg);color:var(--header-text);border-bottom:3px solid var(--header-accent)}
.site-header .wrap{display:flex;align-items:center;justify-content:space-between;padding:1rem;gap:1rem;flex-wrap:wrap}
.site-header .brand{color:var(--header-text);text-decoration:none;display:inline-flex;flex-direction:column;line-height:1.1;gap:.15rem}
.site-header .brand:hover{text-decoration:none}
.site-header .brand-line{font-family:Georgia,'Iowan Old Style','Times New Roman',serif;font-size:1.5rem;font-weight:400;letter-spacing:.02em}
.site-header .brand-line em{font-style:italic;font-weight:500;color:var(--header-accent);padding:0 .05em}
.site-header .brand-sub{font-size:.7rem;text-transform:uppercase;letter-spacing:.18em;opacity:.7;font-weight:500}
.site-header .main-nav{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}
.site-header .main-nav a{color:var(--header-text)}
.theme-toggle{appearance:none;background:transparent;color:var(--header-text);border:1px solid var(--header-text);padding:.3rem .6rem;border-radius:4px;font:inherit;font-size:.85rem;cursor:pointer;display:inline-flex;align-items:center;gap:.3rem;opacity:.85}
.theme-toggle:hover{opacity:1;background:rgba(255,255,255,.08)}
.theme-toggle-footer{color:var(--footer-text);border-color:var(--footer-text)}
.theme-toggle-footer:hover{background:rgba(255,255,255,.06);color:#fff}
.header-search{position:relative;flex:1 1 280px;max-width:380px;min-width:200px}
.header-search-input{width:100%;padding:.4rem .7rem;border:1px solid rgba(255,255,255,.3);background:rgba(255,255,255,.08);color:var(--header-text);border-radius:4px;font:inherit;font-size:.9rem;-webkit-appearance:none}
.header-search-input::placeholder{color:rgba(255,255,255,.55)}
.header-search-input::-webkit-search-cancel-button{filter:invert(1) opacity(.6)}
.header-search-input:focus{outline:none;border-color:var(--header-accent);background:rgba(255,255,255,.18)}
.header-search-results{position:absolute;top:calc(100% + 4px);left:0;right:0;margin:0;padding:0;list-style:none;background:var(--bg-alt);border:1px solid var(--border);border-radius:4px;box-shadow:var(--shadow-strong);display:none;z-index:1000;max-height:60vh;overflow-y:auto}
.header-search-results.is-open{display:block}
.header-search-results li{margin:0}
.header-search-results a{display:block;padding:.5rem .8rem;color:var(--text);border-bottom:1px solid var(--border-soft);font-size:.92rem;line-height:1.3;text-decoration:none}
.header-search-results li:last-child a{border-bottom:none}
.header-search-results a:hover,.header-search-results a.is-active{background:var(--bg-soft);color:var(--accent);text-decoration:none}
.search-empty{padding:.55rem .8rem;color:var(--text-muted);font-size:.85rem;font-style:italic}
@media (max-width:680px){
  .header-search{order:3;flex-basis:100%;max-width:none}
}
.site-main{min-height:60vh}
.site-footer{background:var(--footer-bg);color:var(--footer-text);padding:1.2rem 0;margin-top:2rem;font-size:.85rem}
.site-footer .wrap{text-align:center}
.breadcrumb{padding:.8rem 1rem .2rem;font-size:.88rem;color:var(--text-muted)}
.breadcrumb a{color:var(--link)}
.breadcrumb .sep{margin:0 .35rem;color:var(--text-faint)}
.breadcrumb .current{color:var(--text);font-weight:600}
.breadcrumb .bc-cat{color:var(--link)}
.breadcrumb .bc-cat:hover{color:var(--link-hover)}
.lieu-head{padding:1.5rem 1rem 0}
.lieu-head h1{margin:0 0 .25rem;font-size:1.6rem;color:var(--text)}
.lieu-meta{margin:0;color:var(--text-muted)}
.lieu-list{padding:1rem}
.lieu-list h2{margin:.5rem 0 .6rem;font-size:1.15rem;color:var(--text)}
.lieu-cavites{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.4rem .8rem}
.lieu-cavites li{padding:.25rem 0}
.cavite-grid{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.85rem}
.cavite-card{background:var(--bg-alt);border:1px solid var(--border);border-radius:6px;overflow:hidden;box-shadow:var(--shadow);transition:transform .15s ease,box-shadow .15s ease}
.cavite-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-strong)}
.cavite-card-link{display:flex;flex-direction:column;height:100%;color:var(--text);text-decoration:none}
.cavite-card-link:hover{text-decoration:none;color:var(--text)}
.cavite-card-photo{aspect-ratio:16/10;background:var(--bg-soft);overflow:hidden;position:relative;display:flex;align-items:center;justify-content:center}
.cavite-card-photo img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .35s ease}
.cavite-card:hover .cavite-card-photo img{transform:scale(1.06)}
.cavite-card-photo.is-empty,.cavite-card-photo.is-broken{background:var(--bg-soft)}
.cavite-card-photo.is-broken img{display:none}
.cavite-card-body{padding:.6rem .8rem;flex:1 1 auto;display:flex;flex-direction:column;gap:.15rem}
.cavite-card-title{margin:0;font-size:.95rem;font-weight:600;color:var(--text);line-height:1.3}
.cavite-card-massif{margin:0;font-size:.8rem;color:var(--text-muted);line-height:1.3;font-style:italic}
.cavite-card-stats{margin:.15rem 0 0;font-size:.78rem;color:var(--text);display:flex;gap:.6rem;flex-wrap:wrap;font-variant-numeric:tabular-nums}
.cavite-card-stats strong{color:var(--label);font-weight:600}
.lieu-children{padding:0 1rem 2rem}
.lieu-children h2{margin:.5rem 0 .6rem;font-size:1.05rem;color:var(--text)}
.lieu-children-list{list-style:none;padding:0;margin:0;display:flex;flex-wrap:wrap;gap:.4rem .6rem}
.lieu-children-list li a{display:inline-block;background:var(--bg-alt);border:1px solid var(--border);padding:.35rem .7rem;border-radius:4px;color:var(--text);font-size:.9rem}
.lieu-children-list li a:hover{background:var(--bg-soft);text-decoration:none}
.fiche-head-row{display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:space-between;gap:1rem}
.fiche-head-titles{flex:1 1 auto;min-width:0}
.fiche-head-actions{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}
.btn-share{appearance:none;border:0;cursor:pointer;background:var(--accent);color:var(--accent-contrast);font-weight:700;padding:.5rem .85rem;border-radius:4px;font-size:.92rem;display:inline-flex;align-items:center;gap:.3rem}
.btn-share:hover{background:var(--accent-hover)}
.btn-share:focus{outline:2px solid var(--accent);outline-offset:2px}
.share-ico{font-size:1rem}
.share-status{font-size:.82rem;color:var(--text-muted);min-height:1em}
.gallery-section{padding:1rem}
.gallery-section h2{margin:.5rem 0 .6rem;font-size:1.15rem;color:var(--text)}
.gallery-section .count{color:var(--text-muted);font-weight:400;font-size:.92rem}
.gallery{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.5rem}
.gallery li{margin:0}
.gallery-item{display:block;background:var(--bg-alt);border-radius:4px;overflow:hidden;aspect-ratio:4/3;position:relative;border:1px solid var(--border)}
.gallery-item img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .25s ease,opacity .15s ease}
.gallery-item:hover img{transform:scale(1.04);opacity:.92}
.gallery-item.is-broken{background:var(--broken-bg)}
.gallery-item.is-broken img{display:none}
.gallery-item.is-broken::before{content:'\1F5BC';position:absolute;top:30%;left:0;right:0;text-align:center;font-size:2.4rem;color:var(--text-faint);line-height:1}
.gallery-item.is-broken::after{content:attr(data-label);position:absolute;bottom:.4rem;left:.4rem;right:.4rem;text-align:center;font-size:.72rem;color:var(--broken-text);background:rgba(255,255,255,.85);padding:.15rem .35rem;border-radius:3px;line-height:1.25;max-height:2.5em;overflow:hidden}
[data-theme="nuit"] .gallery-item.is-broken::after,
:root:not([data-theme]) .gallery-item.is-broken::after{background:rgba(30,35,48,.9);color:var(--text)}
.lightbox{display:none;position:fixed;inset:0;z-index:9998;background:rgba(0,0,0,.92);align-items:center;justify-content:center;flex-direction:column;padding:1rem}
.lightbox.is-open{display:flex}
.lb-figure{margin:0;max-width:96vw;max-height:90vh;display:flex;flex-direction:column;align-items:center;gap:.5rem}
.lb-img{max-width:96vw;max-height:80vh;object-fit:contain;background:#000;border-radius:2px;box-shadow:0 6px 24px rgba(0,0,0,.5)}
.lb-caption{color:#fff;font-size:.95rem;text-align:center;max-width:96vw}
.lb-close,.lb-prev,.lb-next{position:absolute;background:rgba(0,0,0,.5);border:0;color:#fff;cursor:pointer;font-size:2rem;line-height:1;width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center}
.lb-close{top:1rem;right:1rem}
.lb-prev{left:1rem;top:50%;transform:translateY(-50%)}
.lb-next{right:1rem;top:50%;transform:translateY(-50%)}
.lb-close:hover,.lb-prev:hover,.lb-next:hover{background:rgba(0,0,0,.8)}
.hero{padding:1.5rem 0 .5rem}
.hero h1{margin:0 0 .25rem;font-size:1.6rem;color:var(--text)}
.hero .lead{margin:0;color:var(--text-muted)}
.hero-filters{display:flex;flex-wrap:wrap;align-items:center;gap:.6rem;margin-top:.9rem}
.filter-label{font-weight:600;color:var(--text);font-size:.92rem}
.filter-select{font:inherit;padding:.4rem .6rem;border:1px solid var(--accent);border-radius:4px;background:var(--bg-alt);color:var(--text);min-width:200px;max-width:100%}
.filter-select:focus{outline:2px solid var(--accent);outline-offset:1px}
.filter-fav{appearance:none;border:1px solid var(--accent);background:var(--bg-alt);color:var(--text);font:inherit;font-weight:600;padding:.4rem .75rem;border-radius:4px;cursor:pointer;display:inline-flex;align-items:center;gap:.4rem}
.filter-fav:hover{background:var(--bg-soft)}
.filter-fav.is-on{background:var(--highlight);color:var(--accent-contrast);border-color:var(--highlight-hover)}
.filter-fav .fav-ico{font-size:1.05rem;line-height:1}
.filter-fav .fav-count{background:var(--text);color:var(--bg-alt);font-size:.78rem;padding:.05rem .4rem;border-radius:8px;min-width:1.5em;text-align:center;font-variant-numeric:tabular-nums}
.filter-fav.is-on .fav-count{background:var(--accent-contrast);color:var(--highlight)}
.btn-fav{appearance:none;border:0;cursor:pointer;background:var(--bg-alt);color:var(--text);font-weight:700;padding:.5rem .85rem;border-radius:4px;font-size:.92rem;display:inline-flex;align-items:center;gap:.3rem;border:1px solid var(--accent)}
.btn-fav:hover{background:var(--bg-soft)}
.btn-fav:focus{outline:2px solid var(--accent);outline-offset:2px}
.btn-fav.is-on{background:var(--highlight);color:var(--accent-contrast);border-color:var(--highlight-hover)}
.btn-fav .fav-ico{font-size:1.05rem;line-height:1}
.map-section{margin:1rem 0 .25rem}
.map{width:100%;background:var(--border);touch-action:none}
.map-full{height:70vh;min-height:380px}
.map-fiche{height:50vh;min-height:320px}
.fiche-head{padding:1.2rem 0 .2rem}
.fiche-head h1{margin:0;font-size:1.5rem;color:var(--text)}
.fiche-meta{margin:.25rem 0 0;color:var(--text-muted)}
.coords-box{padding:1rem 1rem 0}
.coords-box h2{margin:.5rem 0 .6rem;font-size:1.15rem;color:var(--text)}
.coords-table{width:100%;border-collapse:collapse;background:var(--bg-alt);border:1px solid var(--border);border-radius:6px;overflow:hidden}
.coords-table th,.coords-table td{padding:.45rem .75rem;text-align:left;font-size:.9rem;border-bottom:1px solid var(--border-soft);vertical-align:top}
.coords-table tr:last-child th,.coords-table tr:last-child td{border-bottom:none}
.coords-table th{color:var(--label);font-weight:600;width:38%;background:var(--bg-soft)}
.coords-table td{color:var(--text);font-variant-numeric:tabular-nums;width:31%}
.coords-table small{color:var(--text-muted);font-weight:400}
.coords-note{margin:.4rem .25rem 0;color:var(--text-muted)}
.coords-links{margin:.6rem 0 .25rem;display:flex;gap:.6rem;flex-wrap:wrap}
.btn-coords{display:inline-block;background:var(--accent);color:var(--accent-contrast);font-weight:700;padding:.45rem .85rem;border-radius:4px;font-size:.9rem}
.btn-coords:hover{background:var(--accent-hover);text-decoration:none;color:var(--accent-contrast)}
.btn-coords-alt{background:var(--highlight);color:var(--accent-contrast)}
.btn-coords-alt:hover{background:var(--highlight-hover);color:var(--accent-contrast)}
@media (max-width:560px){
  .coords-table th,.coords-table td{display:block;width:100%}
  .coords-table th{background:var(--border-soft);font-size:.85rem}
}
.fiche-data{padding:1rem 1rem 0}
.bloc-data{margin:0 0 1.25rem;background:var(--bg-alt);border:1px solid var(--border);border-radius:6px;overflow:hidden;box-shadow:var(--shadow)}
.bloc-data-title{margin:0;background:var(--section-title-bg);color:var(--section-title-text);padding:.55rem 1rem;font-size:1.05rem;font-weight:600;letter-spacing:.01em}
.bloc-data-empty{margin:0;padding:.7rem 1rem;font-size:.9rem}
.bloc-data-list{margin:0;padding:.4rem 1rem .6rem;display:grid;grid-template-columns:minmax(160px,200px) 1fr;column-gap:1rem;row-gap:.45rem;align-items:baseline}
.bloc-data-list dt{color:var(--label);font-weight:600;font-size:.95rem}
.bloc-data-list dd{margin:0;color:var(--text);font-size:.95rem}
.bloc-data-list dd.empty{color:var(--text-faint)}
.bloc-data-list dd.multiline{white-space:normal;line-height:1.5}
@media (max-width:560px){
  .bloc-data-list{grid-template-columns:1fr;row-gap:.15rem}
  .bloc-data-list dd{margin:0 0 .5rem;padding-left:.5rem;border-left:2px solid var(--border)}
}
.sorties{padding:1rem 1rem .5rem}
.sorties h2{margin:1rem 0 .5rem;font-size:1.15rem;color:var(--text)}
.sorties h2 .count{color:var(--text-muted);font-weight:400;font-size:.92rem}
.sorties-list{list-style:none;padding:0;margin:0;display:grid;gap:.6rem}
.sortie{background:var(--bg-alt);border:1px solid var(--border);border-left:4px solid var(--accent);border-radius:6px;padding:.7rem .9rem}
.sortie-head{display:flex;flex-wrap:wrap;align-items:baseline;justify-content:space-between;gap:.5rem;margin-bottom:.25rem}
.sortie-nom{margin:0;font-size:1rem;color:var(--text)}
.sortie-meta{display:flex;align-items:center;gap:.6rem;font-size:.85rem;color:var(--text-muted);font-variant-numeric:tabular-nums}
.sortie-duree::before{content:"\2022\00a0"}
.sortie-desc{margin:.25rem 0 0;color:var(--text);font-size:.92rem;line-height:1.45}
.sortie-desc-long{margin:.5rem 0 0;color:var(--text);font-size:.95rem;line-height:1.55;white-space:normal}
.nearby{padding:1rem 1rem 2rem}
.nearby h2{margin:1rem 0 .5rem;font-size:1.15rem;color:var(--text)}
.nearby-list{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:.5rem}
.nearby-list li{background:var(--bg-alt);border:1px solid var(--border);padding:.6rem .75rem;border-radius:6px;display:flex;align-items:center;justify-content:space-between;gap:.5rem}
.nearby-list .dist{font-variant-numeric:tabular-nums;color:var(--text-muted);font-size:.9rem}
.nearby-list .dir{background:var(--highlight);color:var(--accent-contrast);border-radius:4px;padding:.05rem .35rem;font-size:.78rem;font-weight:700}
.muted{color:var(--text-faint)}
.p404{padding:3rem 1rem;text-align:center}
.p404 h1{color:var(--text)}
.leaflet-container{font:inherit}
.leaflet-popup-content-wrapper{background:var(--bg-alt);color:var(--text);box-shadow:var(--shadow-strong);border:1px solid var(--border)}
.leaflet-popup-tip{background:var(--bg-alt);box-shadow:var(--shadow)}
.leaflet-popup-close-button{color:var(--text-muted)!important}
.leaflet-popup-close-button:hover{color:var(--text)!important;background:transparent!important}
.leaflet-popup-content{margin:.5rem .75rem;font-size:.92rem;color:var(--text)}
.leaflet-popup-content a{color:var(--link);font-weight:600}
.opacity-control{background:var(--bg-alt);padding:.4rem .55rem;border-radius:4px;font-size:.78rem;color:var(--text);max-width:200px;line-height:1.3;border:1px solid var(--border)}
.opacity-title{font-weight:700;margin-bottom:.25rem;color:var(--text)}
.opacity-row{margin-bottom:.35rem}
.opacity-row:last-child{margin-bottom:0}
.opacity-row label{display:block;font-size:.75rem;color:var(--text-muted);margin-bottom:2px}
.opacity-row input[type=range]{width:100%;margin:0;accent-color:var(--accent)}
.fullscreen-control a{display:flex;align-items:center;justify-content:center;width:30px;height:30px;font-size:18px;color:var(--text);text-decoration:none;background:var(--bg-alt)}
.fullscreen-control a:hover{background:var(--bg-soft);text-decoration:none}
.measure-control a{display:flex;align-items:center;justify-content:center;width:30px;height:30px;font-size:18px;color:var(--text);text-decoration:none;background:var(--bg-alt)}
.measure-control a:hover{background:var(--bg-soft);text-decoration:none}
.measure-control.is-on a{background:var(--highlight);color:var(--accent-contrast)}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.nav-extra{font-size:.9rem;opacity:.85}
.nav-extra:hover{opacity:1}
.filter-num{font:inherit;padding:.4rem .5rem;border:1px solid var(--accent);border-radius:4px;background:var(--bg-alt);color:var(--text);width:80px}
.filter-num:focus{outline:2px solid var(--accent);outline-offset:1px}
.filter-status{margin:.5rem 0 0;color:var(--text-muted);font-size:.85rem;min-height:1.2em}
.disclaimer{position:fixed;inset:0;background:rgba(0,0,0,.75);display:flex;align-items:center;justify-content:center;z-index:10000;padding:1rem}
.disclaimer[hidden]{display:none}
.disclaimer-box{background:var(--bg-alt);color:var(--text);border-radius:8px;padding:1.5rem;max-width:520px;width:100%;border:1px solid var(--border);box-shadow:0 10px 40px rgba(0,0,0,.5)}
.disclaimer-box h2{margin:0 0 .6rem;color:var(--text);font-size:1.2rem}
.disclaimer-box p{margin:0 0 .8rem;color:var(--text);line-height:1.5;font-size:.95rem}
.disclaimer-box .btn-coords{margin-top:.5rem;display:inline-block}
.boussole-page,.trace-page,.favoris-page,.compare-page{padding:1.5rem 1rem 2rem}
.boussole-page h1,.trace-page h1,.favoris-page h1,.compare-page h1{margin:0 0 .5rem;color:var(--text)}
.boussole-controls,.trace-controls,.favoris-actions{display:flex;flex-wrap:wrap;gap:.6rem;align-items:center;margin:1rem 0}
.boussole{display:grid;grid-template-columns:minmax(220px,300px) 1fr;gap:1.5rem;align-items:center;margin-top:1.5rem}
.boussole[hidden]{display:none}
.boussole-disc{position:relative;width:280px;max-width:100%;aspect-ratio:1;border:3px solid var(--accent);border-radius:50%;margin:0 auto;background:var(--bg-alt);box-shadow:var(--shadow-strong)}
.boussole-needle{position:absolute;top:50%;left:50%;width:0;height:0;transform-origin:0 0;transition:transform .15s ease}
.bous-arrow{display:block;font-size:90px;color:var(--highlight);line-height:1;transform:translate(-50%,-95%) rotate(-90deg);position:absolute;top:0;left:0}
.boussole-N,.boussole-S,.boussole-E,.boussole-O{position:absolute;font-weight:700;color:var(--text);font-size:1.1rem}
.boussole-N{top:6px;left:50%;transform:translateX(-50%)}
.boussole-S{bottom:6px;left:50%;transform:translateX(-50%)}
.boussole-E{right:10px;top:50%;transform:translateY(-50%)}
.boussole-O{left:10px;top:50%;transform:translateY(-50%)}
.boussole-info{display:grid;gap:.6rem}
.bous-line{display:flex;justify-content:space-between;padding:.5rem .8rem;background:var(--bg-alt);border:1px solid var(--border);border-radius:6px;font-variant-numeric:tabular-nums}
.bous-label{color:var(--text-muted);font-size:.9rem}
.bous-val{color:var(--text);font-weight:700}
@media (max-width:560px){.boussole{grid-template-columns:1fr}}
.trace-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:.6rem;margin:1rem 0}
.trace-stats > div{background:var(--bg-alt);border:1px solid var(--border);border-radius:6px;padding:.6rem .8rem;display:flex;flex-direction:column;gap:.15rem}
.trace-label{color:var(--text-muted);font-size:.78rem;text-transform:uppercase;letter-spacing:.05em}
.trace-val{color:var(--text);font-size:1.15rem;font-weight:700;font-variant-numeric:tabular-nums}
.trace-page #map{margin-top:1rem}
.favoris-list .cavite-card{cursor:grab;user-select:none}
.favoris-list .cavite-card:active{cursor:grabbing}
.favoris-list .cavite-card.is-dragging{opacity:.4}
.favoris-list .cavite-card.is-over{outline:2px dashed var(--accent);outline-offset:-4px}
.favoris-list .cavite-card.is-selected{outline:3px solid var(--highlight);outline-offset:-2px}
.favoris-empty{padding:2rem 1rem;text-align:center;font-size:1.05rem}
.compare-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem;margin-top:1rem}
@media (max-width:680px){.compare-grid{grid-template-columns:1fr}}
.compare-card{background:var(--bg-alt);border:1px solid var(--border);border-radius:6px;overflow:hidden;box-shadow:var(--shadow)}
.compare-card-photo{display:block;aspect-ratio:16/10;overflow:hidden;background:var(--bg-soft)}
.compare-card-photo img{width:100%;height:100%;object-fit:cover;display:block}
.compare-card-title{margin:0;padding:.7rem 1rem;font-size:1.1rem;background:var(--section-title-bg);color:var(--section-title-text)}
.compare-card-title a{color:var(--section-title-text)}
.compare-card-data{margin:0;padding:.8rem 1rem;display:grid;grid-template-columns:max-content 1fr;gap:.4rem .8rem;font-size:.95rem}
.compare-card-data dt{color:var(--label);font-weight:600}
.compare-card-data dd{margin:0;color:var(--text);font-variant-numeric:tabular-nums}
.compare-dist{font-size:1.1rem;color:var(--text);margin:.5rem 0 1rem}
.gallery-album-title{margin:1.2rem 0 .5rem;font-size:1rem;color:var(--text);display:flex;gap:.5rem;align-items:baseline}
.gallery-album-date{font-size:.85rem;color:var(--text-muted);font-weight:400}
.geoloc-control a{display:flex;align-items:center;justify-content:center;width:30px;height:30px;font-size:19px;color:var(--text);text-decoration:none;background:var(--bg-alt);line-height:1}
.geoloc-control a:hover{background:var(--bg-soft);text-decoration:none}
.geoloc-control.is-on a{background:var(--accent);color:var(--accent-contrast)}
.geoloc-control.is-on a:hover{background:var(--accent-hover)}
.distance-label{background:var(--highlight)!important;color:var(--accent-contrast)!important;border:0!important;font-weight:700;font-size:.82rem;padding:.15rem .5rem!important;border-radius:3px;box-shadow:0 1px 3px rgba(0,0,0,.25);white-space:nowrap}
.distance-label::before{display:none!important}
.user-distance-label{background:#1e6bff!important;color:#fff!important;border:0!important;font-weight:700;font-size:.82rem;padding:.15rem .5rem!important;border-radius:10px;box-shadow:0 1px 4px rgba(0,0,0,.35);white-space:nowrap}
.user-distance-label::before{display:none!important}
.user-marker-icon{background:transparent!important;border:0!important}
.um-pin{position:relative;width:44px;height:44px}
.um-dot{position:absolute;top:50%;left:50%;width:16px;height:16px;border-radius:50%;background:#1e6bff;border:3px solid #fff;box-shadow:0 0 0 1px #1e6bff,0 2px 6px rgba(0,0,0,.35);transform:translate(-50%,-50%);z-index:2}
.um-arrow{position:absolute;top:50%;left:50%;width:0;height:0;border-left:9px solid transparent;border-right:9px solid transparent;border-bottom:18px solid #1e6bff;transition:transform .12s linear;transform-origin:50% 100%;z-index:1;filter:drop-shadow(0 1px 2px rgba(0,0,0,.4))}
.mouse-coords{background:var(--bg-alt);color:var(--text);font-family:ui-monospace,Menlo,monospace;font-size:.78rem;padding:.25rem .55rem;border-radius:3px;box-shadow:0 1px 3px rgba(0,0,0,.18);font-variant-numeric:tabular-nums;border:1px solid var(--border);min-width:200px;text-align:center}
.popup-photo{display:block;margin:-.5rem -.75rem .5rem;overflow:hidden;line-height:0}
.popup-photo img{width:100%;height:120px;object-fit:cover;display:block;transition:opacity .15s ease}
.popup-photo:hover img{opacity:.92}
.popup-title{font-weight:600}
.popup-link{color:var(--link);font-weight:600}
.popup-massif{margin-top:.2rem;font-size:.82rem;color:var(--text-muted);font-style:italic}
.popup-stats{margin-top:.3rem;font-size:.82rem;color:var(--text);display:flex;gap:.6rem;flex-wrap:wrap;font-variant-numeric:tabular-nums}
.popup-stats strong{color:var(--label);font-weight:600}
.export-section{padding:1rem;text-align:center}
.export-section h2{margin:.5rem 0 .35rem;font-size:1.05rem;color:var(--text)}
.export-section .muted{margin:.25rem 0 .8rem;font-size:.88rem}
.export-links{margin:0;display:flex;gap:.6rem;justify-content:center;flex-wrap:wrap}
.contact-page{padding:1.5rem 1rem 2rem}
.contact-page h1{margin:0 0 .25rem;color:var(--text);font-size:1.6rem}
.contact-sub{margin:0 0 1.5rem;color:var(--text-muted);font-size:1.05rem;font-style:italic}
.contact-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1rem}
.contact-card{background:var(--bg-alt);border:1px solid var(--border);border-left:4px solid var(--accent);border-radius:6px;padding:1rem 1.2rem;box-shadow:var(--shadow)}
.contact-card h2{margin:0 0 .5rem;font-size:1rem;color:var(--label);text-transform:uppercase;letter-spacing:.04em}
.contact-card address{font-style:normal;line-height:1.6;color:var(--text)}
.contact-email{margin:0;font-size:1.05rem;font-weight:600;word-break:break-all}
.email-link{color:var(--text);user-select:text}
.email-built{color:var(--accent);font-weight:600;text-decoration:none}
.email-built:hover{text-decoration:underline}
.contact-hint{margin:.5rem 0 0;font-size:.82rem}
.map-pseudo-fullscreen{position:fixed!important;top:0!important;left:0!important;width:100vw!important;height:100vh!important;z-index:99999!important;max-width:none!important;max-height:none!important;margin:0!important;border-radius:0!important}
#map:fullscreen,#map:-webkit-full-screen{width:100%!important;height:100%!important}
@media (max-width:560px){
  .hero h1{font-size:1.35rem}
  .map-full{height:60vh}
  .nearby-list{grid-template-columns:1fr}
}
.btn-reveal{appearance:none;cursor:pointer;background:var(--bg-soft);color:var(--text);border:1px solid var(--border);border-radius:4px;padding:.4rem .8rem;font-size:.88rem;font-weight:600;font-family:inherit;transition:background .15s ease,border-color .15s ease}
.btn-reveal:hover{background:var(--bg-alt);border-color:var(--accent)}
.btn-reveal:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.btn-reveal[aria-expanded="true"]{background:var(--accent);color:var(--accent-contrast);border-color:var(--accent)}
.coords-extra{display:none}
.coords-table.is-revealed .coords-extra{display:table-row}
.coords-more{margin:.6rem 0 0;display:flex;justify-content:flex-end}
.champ-extra{display:none}
.bloc-data-list.is-revealed .champ-extra{display:block}
.bloc-data-more{margin:0 1rem .7rem;display:flex;justify-content:flex-start}
.sortie-recit{margin:.5rem 0 0;border-top:1px dashed var(--border-soft);padding-top:.4rem}
.sortie-recit > summary{cursor:pointer;list-style:none;display:inline-flex;align-items:center;gap:.4rem;background:var(--bg-soft);color:var(--text);border:1px solid var(--border);border-radius:4px;padding:.3rem .7rem;font-size:.85rem;font-weight:600;user-select:none;transition:background .15s ease,border-color .15s ease}
.sortie-recit > summary::-webkit-details-marker{display:none}
.sortie-recit > summary::before{content:"\25B8";display:inline-block;font-size:.85em;transition:transform .15s ease}
.sortie-recit[open] > summary::before{transform:rotate(90deg)}
.sortie-recit > summary:hover{background:var(--bg-alt);border-color:var(--accent)}
.sortie-recit > summary:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.sortie-recit[open] > summary{background:var(--accent);color:var(--accent-contrast);border-color:var(--accent)}
.sortie-recit > .sortie-desc-long{margin-top:.5rem}
.topo-block{display:flex;gap:1rem;align-items:flex-start;background:var(--bg-alt);border:1px solid var(--border);border-left:4px solid var(--accent);border-radius:6px;padding:.7rem .85rem;margin:0 0 1rem}
.topo-block-image .topo-thumb{flex:0 0 auto;width:140px;max-width:35%;display:block;border-radius:4px;overflow:hidden;background:var(--bg-soft);border:1px solid var(--border-soft)}
.topo-block-image .topo-thumb img{width:100%;height:auto;display:block;aspect-ratio:1/1;object-fit:cover}
.topo-info{flex:1 1 auto;min-width:0}
.topo-ext{color:var(--text-muted);font-weight:400;font-size:.85em}
.topo-label{margin:0 0 .4rem;color:var(--text);font-size:1rem}
.topo-actions{margin:0 0 .3rem;display:flex;flex-wrap:wrap;gap:.4rem}
.topo-actions .btn-coords{padding:.35rem .7rem;font-size:.85rem}
.topo-copy{margin:.2rem 0 0;color:var(--text-muted)}
.topo-stat{margin:.25rem 0 0;color:var(--text-muted)}
.gallery-section .topo-block + h2,
.gallery-section .topo-block + .gallery-h2{margin-top:1.4rem;padding-top:.9rem;border-top:1px dashed var(--border-soft)}
.populaires-section{padding:0 1rem 1.5rem}
.populaires-section-title{margin:1rem 0 .7rem;font-size:1.15rem;color:var(--text)}
.populaires-topo-ext{font-weight:700;font-size:1.4rem;color:var(--text-muted);letter-spacing:.05em}
.topos-section{padding:0 1rem 2rem}
.topos-grid{list-style:none;padding:0;margin:1rem 0 0;display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:.8rem}
.topo-item{background:var(--bg-alt);border:1px solid var(--border);border-radius:6px;overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow)}
.topo-item-thumb{aspect-ratio:16/10;background:var(--bg-soft);overflow:hidden;display:flex;align-items:center;justify-content:center}
.topo-item-thumb a{display:flex;align-items:center;justify-content:center;width:100%;height:100%;color:var(--text-muted);text-decoration:none}
.topo-item-thumb img{width:100%;height:100%;object-fit:contain;display:block;background:#fff}
.topo-item-thumb-pdf a{background:var(--bg-soft);font-weight:700;letter-spacing:.05em}
.topo-item-ext{font-size:2rem;color:var(--text-muted);font-weight:700;letter-spacing:.05em}
.topo-item-body{padding:.6rem .8rem .7rem;display:flex;flex-direction:column;gap:.2rem;flex:1 1 auto}
.topo-item-title{margin:0;font-size:1rem;font-weight:600;line-height:1.3}
.topo-item-title a{color:var(--text);text-decoration:none}
.topo-item-title a:hover{color:var(--accent);text-decoration:underline}
.topo-item-massif{margin:0;font-size:.85rem;color:var(--text-muted);font-style:italic}
.topo-item-stats{margin:.15rem 0 0;font-size:.8rem;color:var(--text);display:flex;gap:.6rem;flex-wrap:wrap;font-variant-numeric:tabular-nums}
.topo-item-stats strong{color:var(--label);font-weight:600}
.topo-item-actions{margin:.4rem 0 0;display:flex;flex-wrap:wrap;gap:.35rem}
.topo-item-actions .btn-coords{padding:.3rem .65rem;font-size:.82rem}
.topo-item-copy{margin:.2rem 0 0;color:var(--text-muted)}
.propose-page{padding:.5rem 1rem 2rem;max-width:780px}
.propose-page h1{margin:.5rem 0 .25rem;color:var(--text)}
.propose-form fieldset{margin:1.2rem 0 0;padding:1rem 1.1rem;border:1px solid var(--border);border-radius:6px;background:var(--bg-alt)}
.propose-form legend{padding:0 .5rem;font-weight:600;color:var(--text);font-size:.95rem}
.propose-field{display:flex;flex-direction:column;gap:.25rem;margin:.6rem 0 0}
.propose-field:first-of-type{margin-top:0}
.propose-label{font-size:.88rem;color:var(--label,#666);font-weight:600}
.propose-field input,.propose-field textarea{font:inherit;font-size:.95rem;padding:.5rem .65rem;border:1px solid var(--border);border-radius:4px;background:var(--bg-soft);color:var(--text);width:100%;box-sizing:border-box}
.propose-field input:focus,.propose-field textarea:focus{outline:2px solid var(--accent);outline-offset:0;border-color:var(--accent)}
.propose-field textarea{resize:vertical;min-height:6rem}
.propose-row{display:grid;grid-template-columns:1fr 1fr;gap:.6rem}
.propose-hint{margin:0 0 .5rem;color:var(--text-muted);font-size:.85rem}
.propose-hint code{background:var(--bg-soft);padding:.05rem .35rem;border-radius:3px;font-size:.9em}
.propose-err{color:#c0392b;font-size:.82rem}
.propose-error{margin:1rem 0;padding:.7rem 1rem;background:#fde2e2;border:1px solid #f5b5b5;color:#7a1818;border-radius:4px}
.propose-actions{margin:1.2rem 0 0;display:flex;justify-content:flex-end}
.propose-field select{font:inherit;font-size:.95rem;padding:.5rem .65rem;border:1px solid var(--border);border-radius:4px;background:var(--bg-soft);color:var(--text);width:100%;box-sizing:border-box}
.propose-field select[multiple]{padding:.35rem .5rem;min-height:6rem}
.propose-field select:focus{outline:2px solid var(--accent);outline-offset:0;border-color:var(--accent)}
.propose-map-block{margin:.8rem 0 0}
.propose-map-tools{display:flex;justify-content:space-between;align-items:center;gap:.6rem;margin-bottom:.4rem;flex-wrap:wrap}
#propose-map{width:100%;height:360px;border:1px solid var(--border);border-radius:6px;background:var(--bg-soft);touch-action:none}
@media (max-width:560px){
  #propose-map{height:280px}
}
.propose-success{margin:1.5rem 0;padding:1.2rem 1.4rem;background:#d8f5d3;border:1px solid #8dcc7e;color:#2c5f1c;border-radius:6px}
.propose-success h2{margin:0 0 .5rem;color:#2c5f1c}
.req{color:#c0392b;font-weight:700}
@media (max-width:560px){
  .propose-row{grid-template-columns:1fr}
}
@media (max-width:560px){
  .topo-block{flex-direction:column;gap:.6rem}
  .topo-block-image .topo-thumb{width:100%;max-width:none}
  .topo-block-image .topo-thumb img{aspect-ratio:16/9}
}
.populaires-filter{margin:.6rem 0 0;display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;font-size:.92rem;color:var(--text)}
.populaires-filter select{padding:.35rem .5rem;border:1px solid var(--border);background:var(--bg-alt);color:var(--text);border-radius:4px;font:inherit}
.populaires-grid{counter-reset:populaires}
.populaires-card{position:relative}
.populaires-rang{position:absolute;top:.4rem;left:.4rem;z-index:2;background:rgba(0,0,0,.65);color:#fff;font-weight:700;font-size:.78rem;padding:.18rem .42rem;border-radius:3px;font-variant-numeric:tabular-nums;letter-spacing:.02em}
.populaires-card.is-podium .populaires-rang{background:var(--accent,#b87333);color:var(--accent-contrast,#fff)}
.populaires-card.rang-1 .populaires-rang{background:#d4a017;color:#1a1200}
.populaires-card.rang-2 .populaires-rang{background:#b0b0b0;color:#1a1a1a}
.populaires-card.rang-3 .populaires-rang{background:#a06a3c;color:#fff}
.populaires-vues{margin:.3rem 0 0;font-size:.78rem;color:var(--text-muted);font-variant-numeric:tabular-nums}
.populaires-vues strong{color:var(--text);font-weight:700}
.footer-nav{margin:0 0 .4rem;display:flex;justify-content:center;gap:1rem;flex-wrap:wrap}
.footer-nav a{color:var(--footer-text);text-decoration:none;font-size:.88rem}
.footer-nav a:hover{color:#fff;text-decoration:underline}
.photos-section{padding:0 1rem 2rem}
.photos-grid{list-style:none;padding:0;margin:1rem 0 0;display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.6rem}
.photo-card{position:relative;background:var(--bg-soft);border:1px solid var(--border);border-radius:6px;overflow:hidden;aspect-ratio:1/1}
.photo-link{display:block;width:100%;height:100%;color:inherit;text-decoration:none;position:relative}
.photo-thumb{width:100%;height:100%;overflow:hidden;background:var(--bg-soft)}
.photo-thumb img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .35s ease}
.photo-card:hover .photo-thumb img{transform:scale(1.08)}
.photo-overlay{position:absolute;left:0;right:0;bottom:0;display:flex;flex-direction:column;gap:.05rem;padding:.4rem .5rem .45rem;color:#fff;background:linear-gradient(to top,rgba(0,0,0,.82) 0%,rgba(0,0,0,.55) 60%,rgba(0,0,0,0) 100%);pointer-events:none;font-size:.78rem;line-height:1.25}
.photo-cavite{font-weight:700;font-size:.88rem;text-shadow:0 1px 2px rgba(0,0,0,.6)}
.photo-massif{font-style:italic;opacity:.92}
.photo-desc{opacity:.85;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.photo-copy{opacity:.7;font-size:.7rem;margin-top:.15rem}
.photos-status{margin:1rem 0;text-align:center;min-height:1.2em;font-size:.88rem}
.photos-error{color:#c44}
.photos-sentinel{height:1px;width:100%}
@media (max-width:560px){
  .photos-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.4rem}
  .photo-overlay{font-size:.72rem;padding:.3rem .4rem}
  .photo-cavite{font-size:.8rem}
}
