/* ============================================================
   Mon GR20 — Planificateur v3 — direction "Granite clair" (hybride)
   Structure de la v2 claire (gagnante en lisibilite terrain)
   + typo de marque (Fraunces / Archivo) + palette sable mineral & ember
   + contraste durci AA (texte secondaire, deniveles/accents en ember profond).
   Shell statique : desktop = sidebar, mobile = barre d'onglets.
   ============================================================ */
:root{
  --ink:#1a1714; --ink2:#574d43; --ink3:#695e51;
  --accent:#e2683c; --accent-deep:#9e3e1b; --accent-soft:#f4e1d4;
  --cream:#e9e2d4; --sand:#f0eadd; --surface:#f8f4ec; --white:#fffdf9;
  --line:rgba(26,23,20,.12); --line-soft:rgba(26,23,20,.07);
  --diff-mod:#6f6657; --diff-sou:#94621a; --diff-dif:#b3462a; --diff-tres:#8f3d2a;
  --alert-bg:#f3e6cf; --alert-ink:#7a5310;
  --r-xs:8px; --r-sm:12px; --r:16px; --r-lg:22px; --r-xl:30px;
  --sh-sm:0 1px 2px rgba(26,23,20,.05);
  --sh:0 6px 22px -10px rgba(26,23,20,.18),0 1px 3px rgba(26,23,20,.05);
  --sh-lg:0 34px 70px -34px rgba(26,23,20,.40),0 2px 8px rgba(26,23,20,.06);
  --disp:'Fraunces',Georgia,serif;
  --body:'Archivo',system-ui,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,monospace;
  --tabh:66px;
}
*{box-sizing:border-box}
html,body{margin:0}
body{background:var(--sand);font-family:var(--body);color:var(--ink);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
::selection{background:var(--accent-soft)}
svg{display:block}
button{font-family:inherit;cursor:pointer;border:0;background:none;color:inherit}
a{color:inherit;text-decoration:none}

/* ---------- App shell ---------- */
.pl{min-height:100dvh;display:flex}
.pl-aside{width:240px;flex:0 0 auto;background:var(--cream);border-right:1px solid var(--line);display:flex;flex-direction:column;padding:26px 18px;position:sticky;top:0;height:100dvh}
.pl-brand{display:flex;align-items:center;gap:11px;padding:0 8px 26px}
.pl-brand .mark{width:34px;height:34px;border-radius:10px;background:var(--ink);display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.pl-brand .name{font:700 17px/1 var(--disp)}
.pl-nav{display:flex;flex-direction:column;gap:4px}
.pl-navitem{display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:12px;color:var(--ink2);font:500 14px/1 var(--body);width:100%;text-align:left;transition:background .18s,color .18s}
.pl-navitem:hover{color:var(--ink)}
.pl-navitem.is-active{background:var(--white);box-shadow:var(--sh-sm);color:var(--accent-deep);font-weight:600}
.pl-navitem svg{width:19px;height:19px;flex:0 0 auto}
.pl-aside .grow{flex:1}
.pl-asidecard{display:flex;align-items:center;gap:11px;padding:11px 12px;border-radius:12px;border:1px solid var(--line)}
.pl-asidecard .av{width:28px;height:28px;border-radius:50%;background:var(--accent-soft);color:var(--accent-deep);font:600 12px/1 var(--body);display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.pl-asidecard .t{font:500 12.5px/1.3 var(--body)} .pl-asidecard .t span{color:var(--ink3);font-size:11px}
/* Selecteur de langue dans l'outil (conserve l'itineraire en cours) */
.pl-lang{align-items:center;gap:5px;font:600 12px/1 var(--mono);letter-spacing:.04em}
.pl-lang b{color:var(--accent-deep)}
.pl-lang a{color:var(--ink3);text-decoration:none;padding:4px 7px;border-radius:7px;transition:color .15s,background .15s}
.pl-lang a:hover{color:var(--accent-deep);background:var(--accent-soft)}
.pl-lang a:focus-visible{outline:2px solid var(--accent-deep);outline-offset:2px}
.pl-lang--d{display:inline-flex;margin:-8px 8px 16px}
.pl-lang--m{display:none}
/* Aide contextuelle : pastille info (popover natif) + disclosure "comment c'est calcule" */
.pl-info{display:inline-flex;align-items:center;justify-content:center;width:17px;height:17px;margin-left:5px;border:1px solid var(--accent);color:var(--accent-deep);background:var(--accent-soft);border-radius:50%;font:700 10px/1 var(--mono);cursor:pointer;vertical-align:middle;flex:0 0 auto;transition:background .15s,color .15s}
.pl-info:hover{background:var(--accent);color:var(--ink)}
.pl-info:focus-visible{outline:2px solid var(--accent-deep);outline-offset:2px}
.pl-pop{position:fixed;left:50%;top:50%;transform:translate(-50%,-50%);width:min(320px,calc(100vw - 32px));max-width:none;margin:0;padding:16px 18px;background:var(--white);color:var(--ink2);border:1px solid var(--line);border-radius:14px;box-shadow:0 24px 60px -20px rgba(26,23,20,.5);font:400 13.5px/1.6 var(--body)}
.pl-pop b{color:var(--ink);font-weight:600}
.pl-pop p{margin:0 0 10px}.pl-pop p:last-child{margin:0}
.pl-pop::backdrop{background:rgba(26,23,20,.18)}
.pl-help{margin:0 0 18px;border:1px solid var(--line);border-radius:12px;background:var(--surface);overflow:hidden}
.pl-help>summary{cursor:pointer;list-style:none;padding:11px 15px;font:600 13px/1 var(--body);color:var(--accent-deep);display:flex;align-items:center;gap:8px}
.pl-help>summary::-webkit-details-marker{display:none}
.pl-help>summary::before{content:"i";display:inline-flex;align-items:center;justify-content:center;width:17px;height:17px;border:1px solid var(--accent);border-radius:50%;background:var(--accent-soft);font:700 10px/1 var(--mono);color:var(--accent-deep);flex:0 0 auto}
.pl-help[open]>summary{border-bottom:1px solid var(--line)}
.pl-help__body{padding:13px 16px;font:400 13px/1.55 var(--body);color:var(--ink2)}
.pl-help__body p{margin:0 0 8px}.pl-help__body p:last-child{margin:0}
.pl-help__body b{color:var(--ink);font-weight:600}

.pl-main{flex:1;min-width:0;display:flex;flex-direction:column;background:var(--surface)}

/* bottom tabs (mobile) */
.pl-tabs{display:none}

/* ---------- View header (desktop) ---------- */
.pv{display:none;flex:1;min-height:0;flex-direction:column}
.pv.is-active{display:flex}
.pv-head{padding:28px 40px 22px;border-bottom:1px solid var(--line-soft);display:flex;justify-content:space-between;align-items:flex-end;gap:24px}
.pv-eyebrow{font:500 12px/1 var(--mono);letter-spacing:.06em;color:var(--ink3);margin-bottom:10px}
.pv-h1{font:600 32px/1.02 var(--disp);letter-spacing:-.015em;margin:0}
.pv-head p{font:400 14px/1.5 var(--body);color:var(--ink2);margin:0;max-width:34ch;text-align:right}

/* ---------- Components ---------- */
.label{font:600 13px/1 var(--body);color:var(--ink2);margin-bottom:12px}
.seg{display:flex;gap:5px;background:var(--cream);border-radius:14px;padding:5px}
.seg button{flex:1;text-align:center;padding:12px 0;border-radius:11px;font:500 14px/1 var(--body);color:var(--ink2);transition:background .15s,box-shadow .15s,color .15s}
.seg button.is-active{background:var(--white);box-shadow:var(--sh-sm);color:var(--ink);font-weight:600}
.stepper{display:inline-flex;align-items:center;gap:16px;background:var(--cream);border-radius:14px;padding:7px 10px}
.stepper button{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;font:500 22px/1 var(--body)}
.stepper .minus{background:var(--white);border:1px solid var(--line);color:var(--ink2)}
.stepper .plus{background:var(--ink);color:#fff}
.stepper .val{font:600 24px/1 var(--mono);min-width:40px;text-align:center}
.slider{position:relative;height:6px;background:var(--cream);border-radius:99px}
.slider .fill{position:absolute;left:0;top:0;height:6px;background:var(--accent);border-radius:99px}
.slider .knob{position:absolute;top:50%;transform:translate(-50%,-50%);width:24px;height:24px;border-radius:50%;background:#fff;border:1px solid var(--line);box-shadow:var(--sh)}
.slider-scale{display:flex;justify-content:space-between;margin-top:10px;font:400 12px/1 var(--body);color:var(--ink3)}
.slider-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:14px}
.slider-head .v{font:500 13px/1 var(--mono);color:var(--accent-deep)}

.badge{display:inline-flex;align-items:center;gap:8px;padding:8px 13px;border-radius:999px;background:var(--white);border:1px solid var(--line);font:500 13px/1 var(--body);white-space:nowrap}
.badge .dot{width:9px;height:9px;border-radius:50%;background:var(--ink3)}
.dot-mod{background:var(--diff-mod)!important}.dot-sou{background:var(--diff-sou)!important}.dot-dif{background:var(--diff-dif)!important}.dot-tres{background:var(--diff-tres)!important}

.cta{width:100%;background:var(--accent);color:var(--ink);font:600 15px/1 var(--body);padding:17px 0;border-radius:14px;box-shadow:0 10px 24px -10px rgba(226,104,60,.55)}
.cta.ghost{background:var(--white);border:1px solid var(--line);color:var(--ink);box-shadow:none;font-weight:600;padding:14px 0;border-radius:13px}
.cta.dark{background:var(--ink);color:#fff;box-shadow:none;border-radius:13px;padding:15px 0}

.summary-dark{background:var(--ink);border-radius:18px;padding:22px;color:#fff}
.summary-dark .name{font:600 17px/1.2 var(--body);margin-bottom:4px}
.summary-dark .meta{font:500 13px/1 var(--mono);color:rgba(255,255,255,.6)}
.summary-dark .stats{display:flex;gap:22px;margin-top:20px}
.summary-dark .stats b{font:600 22px/1 var(--mono);color:#fff;display:block}
.summary-dark .stats b small{font-size:12px;color:rgba(255,255,255,.5)}
.summary-dark .stats .accent{color:var(--accent)}
.summary-dark .stats span{font:400 11px/1 var(--body);color:rgba(255,255,255,.5);margin-top:5px;display:block}

.statline{display:flex;align-items:center;gap:9px;font:400 13px/1.4 var(--body);color:var(--ink2);margin-bottom:8px}

/* stat group (étapes summary) */
.statgrp{display:flex;gap:34px}
.statgrp .s b{font:600 24px/1 var(--mono);display:block}
.statgrp .s b small{font-size:13px;color:var(--ink3)}
.statgrp .s .accent{color:var(--accent-deep)}
.statgrp .s span{font:400 11px/1 var(--body);color:var(--ink3);margin-top:5px;display:block}

/* day card (mobile étapes) */
.daycard{background:var(--white);border:1px solid var(--line);border-radius:16px;padding:14px;box-shadow:var(--sh-sm)}
.daycard .top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:10px}
.daycard .jr{width:30px;height:30px;border-radius:9px;background:var(--ink);color:#fff;font:600 13px/1 var(--mono);display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.daycard .route{font:600 13.5px/1.2 var(--body)}
.daycard .nums{display:flex;gap:16px;font:500 12px/1 var(--mono);color:var(--ink2)}
.daycard .nums .up{color:var(--accent-deep)}
.daycard .pt{width:9px;height:9px;border-radius:50%;margin-top:5px;flex:0 0 auto}
.alert-soft{display:flex;align-items:center;gap:8px;background:var(--alert-bg);border-radius:10px;padding:8px 11px;margin-top:11px}
.alert-soft span{font:500 11.5px/1.3 var(--body);color:var(--alert-ink)}

/* premium table (desktop étapes) */
.ptable{flex:1;overflow:auto;padding:0 24px}
.ptable .row{display:grid;grid-template-columns:54px 1fr 92px 92px 92px 80px 140px 56px;align-items:center;padding:15px 16px;border-bottom:1px solid var(--line-soft)}
.ptable .head{font:600 11px/1 var(--mono);letter-spacing:.1em;text-transform:uppercase;color:var(--ink3);padding:16px}
.ptable .head .r{text-align:right}
.ptable .row .jr{font:600 13px/1 var(--mono);color:var(--ink2)}
.ptable .row .et{font:600 14px/1.2 var(--body)}
.ptable .row .n{text-align:right;font:500 13px/1 var(--mono)}
.ptable .row .n.up{color:var(--accent-deep)} .ptable .row .n.t{color:var(--ink2)}
.ptable .row.alert{background:var(--alert-bg);border-radius:12px}
.ptable .row .warn{display:inline-flex;align-items:center;gap:5px;margin-left:8px;font:500 11.5px/1 var(--body);color:var(--alert-ink)}
.ptable .dl{justify-self:end;opacity:.6}
.ptable .more{text-align:center;font:500 13px/1 var(--body);color:var(--ink3);padding:18px 0}

/* nuit item */
.nuit{display:flex;align-items:center;gap:13px;background:var(--white);border:1.5px solid var(--accent);border-radius:13px;padding:12px 14px}
.nuit.off{background:var(--sand);border:1px solid var(--line-soft);opacity:.78}
.nuit .chk{width:22px;height:22px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.nuit.off .chk{background:transparent;border:1.5px solid var(--line)}
.nuit .nm{font:600 13.5px/1.2 var(--body)} .nuit.off .nm{color:var(--ink2)}
.nuit .sub{font:400 11.5px/1 var(--body);color:var(--ink3);margin-top:3px}
.nuit .jr{font:500 11px/1 var(--mono);color:var(--ink3)}
.nuit-counter{background:var(--accent-soft);border-radius:14px;padding:13px 16px;display:flex;align-items:center;justify-content:space-between}
.nuit-counter .l{font:500 13px/1.3 var(--body);color:var(--accent-deep)}
.nuit-counter .n{font:600 16px/1 var(--mono);color:var(--accent-deep)}

/* export card */
.export-card{display:flex;align-items:center;gap:13px;background:var(--white);border:1px solid var(--line);border-radius:15px;padding:14px;box-shadow:var(--sh-sm);width:100%;text-align:left}
.export-card .ic{width:40px;height:40px;border-radius:11px;background:var(--cream);display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.export-card.primary .ic{background:var(--accent-soft)}
.export-card .t{flex:1} .export-card .t b{font:600 14px/1.2 var(--body);display:block} .export-card .t span{font:400 11.5px/1.3 var(--body);color:var(--ink3);margin-top:2px;display:block}
.export-card .ext{font:500 11px/1 var(--mono);color:var(--ink3)}
.note-soft{display:flex;align-items:center;gap:10px;background:var(--accent-soft);border-radius:13px;padding:12px 14px}
.note-soft span{font:500 11.5px/1.4 var(--body);color:var(--accent-deep)}

/* map */
.map-wrap{flex:1;position:relative;background:linear-gradient(155deg,#e8e0d0,#efe8d8 55%,#e3dbc9);min-width:0;overflow:hidden}
.map-wrap>svg{position:absolute;inset:0;width:100%;height:100%}
.map-toggle{display:flex;gap:3px;background:rgba(248,244,236,.92);backdrop-filter:blur(8px);border:1px solid var(--line);border-radius:13px;padding:5px;box-shadow:var(--sh)}
.map-toggle button{padding:9px 18px;border-radius:9px;font:500 13px/1 var(--body);color:var(--ink2)}
.map-toggle button.is-active{background:var(--ink);color:#fff;font-weight:600}
.map-recenter{width:46px;height:46px;border-radius:13px;background:var(--surface);border:1px solid var(--line);box-shadow:var(--sh);display:flex;align-items:center;justify-content:center}

/* desktop carte detail panel */
.detail{width:340px;flex:0 0 auto;border-left:1px solid var(--line);display:flex;flex-direction:column;padding:28px 26px;background:var(--surface)}
.detail .jr{width:38px;height:38px;border-radius:11px;background:var(--accent);color:#fff;font:600 14px/1 var(--mono);display:flex;align-items:center;justify-content:center}
.detail-stats{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.detail-stats .c{background:var(--sand);border-radius:13px;padding:14px}
.detail-stats .c b{font:600 20px/1 var(--mono)} .detail-stats .c b small{font-size:11px;color:var(--ink3)} .detail-stats .c .accent{color:var(--accent-deep)}
.detail-stats .c span{font:400 11px/1 var(--body);color:var(--ink3);margin-top:6px;display:block}
.elev{width:100%;height:92px;display:block}

/* generic section title helper inside views */
.field+.field{margin-top:28px}

/* ============================================================
   RESPONSIVE — < 900px : layout mobile (app), barre d'onglets
   ============================================================ */
@media (max-width:900px){
  body{background:var(--surface)}
  .pl{display:block}
  .pl-aside{display:none}
  .pl-main{min-height:100dvh;padding-bottom:calc(var(--tabh) + env(safe-area-inset-bottom,0px))}
  .pv-head{flex-direction:column;align-items:flex-start;gap:8px;padding:18px 20px 14px}
  .pv-head p{text-align:left;max-width:none}
  .pv-h1{font-size:25px}
  .pl-tabs{display:flex;position:fixed;left:0;right:0;bottom:0;z-index:50;justify-content:space-around;
    padding:8px 8px calc(8px + env(safe-area-inset-bottom,0px));border-top:1px solid var(--line-soft);
    background:var(--surface)}
  .pl-tab{display:flex;flex-direction:column;align-items:center;gap:4px;color:var(--ink3);font:500 10px/1 var(--body);padding:4px 10px}
  .pl-tab svg{width:22px;height:22px}
  .pl-tab.is-active{color:var(--accent-deep);font-weight:600}
  .pl-lang--m{display:inline-flex;align-self:flex-end;margin:0 0 2px}
  .pl-lang--m a,.pl-lang--m b{min-height:44px;padding:0 13px;display:inline-flex;align-items:center}
}
@media (min-width:901px){
  .only-mobile{display:none!important}
}
@media (max-width:900px){
  .only-desktop{display:none!important}
}

/* ============================================================
   LAYOUTS DES VUES
   ============================================================ */
/* Configurer : form | résumé */
.cfg{flex:1;display:flex;min-height:0}
.cfg-form{flex:1.5;padding:34px 40px;display:flex;flex-direction:column;gap:28px;border-right:1px solid var(--line-soft);min-width:0}
.cfg-row{display:flex;gap:40px;align-items:flex-end}
.cfg-sens{flex:1}.cfg-dur{flex:0 0 auto}
.cfg-narrow{max-width:440px}
.cfg-summary{flex:1;padding:34px 36px;display:flex;flex-direction:column;background:var(--sand)}
.cfg-summary .summary-dark{margin:16px 0 16px}

/* Étapes */
.et-summary{padding:26px 40px;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;gap:24px;background:var(--sand)}
.et-summary-right{display:flex;align-items:center;gap:34px}
.et-foot{padding:18px 40px;border-top:1px solid var(--line-soft)}
.et-foot .cta{max-width:280px;margin-left:auto;display:block}
.et-cards{padding:14px 22px 4px;display:flex;flex-direction:column;gap:11px;overflow:auto}

/* Nuits */
.nuit-back{width:32px;height:32px;border-radius:50%;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;background:var(--white);flex:0 0 auto}
.nuit-body{flex:1;display:flex;flex-direction:column;min-height:0;padding:0 40px 22px;max-width:700px;width:100%}
.nuit-counter{margin-bottom:14px}
.nuit-list{flex:1;display:flex;flex-direction:column;gap:9px;overflow:auto;padding-bottom:4px}
.nuit-foot{padding-top:16px}.nuit-foot .cta{max-width:360px}

/* Export */
.export-body{flex:1;display:flex;flex-direction:column;gap:11px;min-height:0;overflow:auto;padding:24px 40px 0;max-width:560px;width:100%}
.export-foot{padding:18px 40px}.export-foot .cta{max-width:320px}

/* Carte */
.pv-carte.is-active{display:flex;flex-direction:row}
.pv-carte .map-wrap{flex:1.55}
.detail .grow{flex:1}
.sheet{position:relative;background:var(--surface);border-top-left-radius:24px;border-top-right-radius:24px;box-shadow:0 -16px 40px -20px rgba(26,23,20,.3);padding:10px 22px 16px}
.sheet-grab{width:38px;height:4px;border-radius:99px;background:var(--line);margin:0 auto 14px}

@media (max-width:900px){
  .cfg{flex-direction:column}
  .cfg-form{border-right:0;padding:16px 20px;gap:22px;order:1}
  .cfg-summary{order:2;background:var(--surface);padding:4px 20px 20px}
  .cfg-row{flex-direction:column;gap:22px;align-items:stretch}
  .cfg-narrow{max-width:none}
  .et-summary{flex-direction:column;align-items:flex-start;gap:14px;padding:16px 20px}
  .et-summary .pv-h1{font-size:21px!important}
  .et-summary-right{flex-direction:column;align-items:flex-start;gap:14px;width:100%}
  .et-summary .statgrp{justify-content:space-between;width:100%;gap:0}
  .et-summary .statgrp .s b{font-size:19px}
  .et-foot{padding:14px 20px}.et-foot .cta{max-width:none;margin:0}
  .nuit-body,.export-body{padding-left:20px;padding-right:20px;max-width:none}
  .nuit-foot .cta,.export-foot .cta{max-width:none}
  .export-body{padding-top:16px}.export-foot{padding:14px 20px}
  .pv-carte.is-active{flex-direction:column}
  .pv-carte .map-wrap{flex:1}
}

/* ---------- Carte Leaflet (lot 3) ---------- */
.leaflet-container{background:#e8e0d0;font-family:var(--body)}
.leaflet-popup-content{font-family:var(--body);margin:9px 12px;font-size:13px;line-height:1.5;color:var(--ink)}
.leaflet-popup-content b{color:var(--accent-deep)}
.map-toggle,.map-recenter{z-index:1000}
.mk{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font:700 12px/1 var(--mono);border:2px solid #fffdf9;box-shadow:0 2px 6px rgba(26,23,20,.35)}

/* ---------- Reservations (sous-ecran Export) ---------- */
.resa{background:var(--white);border:1px solid var(--line);border-radius:14px;padding:14px 16px;box-shadow:var(--sh-sm)}
.resa-nm{font:600 14px/1.25 var(--body);color:var(--ink)}
.resa-sub{font:400 11.5px/1 var(--mono);color:var(--ink3);margin-top:4px}
.resa-links{display:flex;flex-wrap:wrap;gap:8px;margin-top:11px}
.resa-link{display:inline-flex;align-items:center;gap:6px;padding:8px 13px;border-radius:999px;font:600 12.5px/1 var(--body);border:1px solid var(--line);white-space:nowrap}
.resa-link.parc{background:var(--accent);color:var(--ink);border-color:transparent}
.resa-link.ext{background:var(--white);color:var(--ink)}

/* CTA secondaire actionnable : contour ember + texte ember profond (AA) */
.cta.line{background:var(--white);border:1.5px solid var(--accent);color:var(--accent-deep);box-shadow:none;font-weight:600;padding:14px 0;border-radius:13px}

/* Duree : saisie directe + presets (flexibilite expert/novice) */
.stepper input.val{border:0;background:none;color:inherit;width:50px;text-align:center;font:700 24px/1 var(--mono);-moz-appearance:textfield}
.stepper input.val::-webkit-outer-spin-button,.stepper input.val::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.stepper input.val:focus-visible{outline:2px solid var(--accent-deep);outline-offset:3px;border-radius:6px}
.dur-presets{display:flex;gap:6px;margin-top:9px}
.dur-preset{flex:1;background:none;border:1px solid var(--line);border-radius:10px;padding:8px 4px;font:500 11.5px/1 var(--body);color:var(--ink3);cursor:pointer;transition:border-color .15s,color .15s,background .15s}
.dur-preset:hover{border-color:var(--accent);color:var(--accent-deep)}
.dur-preset:focus-visible{outline:2px solid var(--accent-deep);outline-offset:2px}

/* Aide contextuelle sous un segment (allure) */
.seg-hint{margin:9px 0 0;font:400 12px/1.45 var(--body);color:var(--ink3)}

/* ---------- Focus clavier visible (audit a11y) ---------- */
:focus-visible{outline:2px solid var(--accent-deep);outline-offset:2px;border-radius:6px}
.slider:focus-visible{outline:none}
.slider:focus-visible .knob{box-shadow:0 0 0 4px var(--accent-soft),var(--sh)}
/* zone tactile elargie du slider : visuel 6px, hit ~44px */
.slider::before{content:"";position:absolute;left:0;right:0;top:-19px;bottom:-19px}

/* ---------- Retours survol / clic (audit theming) ---------- */
.seg button:hover{color:var(--ink)}
.export-card:hover,.nuit:hover{box-shadow:var(--sh);border-color:rgba(26,23,20,.2)}
.stepper .minus:hover{border-color:rgba(26,23,20,.2)}
.resa-link:hover{border-color:var(--accent)}
.cta:active,.cta.line:active,.cta.ghost:active,.cta.dark:active{transform:translateY(1px)}

/* ---------- Bouton GPX par jour dans le tableau (audit clarify) ---------- */
.ptable .dlbtn{justify-self:end;display:inline-flex;align-items:center;justify-content:center;background:none;border:0;padding:5px;border-radius:8px;opacity:.6;cursor:pointer;transition:opacity .15s,background .15s}
.ptable .dlbtn:hover{opacity:1;background:var(--cream)}

/* ---------- Cibles tactiles >= 44px sur mobile (audit responsive) ---------- */
@media (max-width:900px){
  .stepper button{width:44px;height:44px}
  .seg button{padding:15px 0}
  .resa-link{min-height:44px}
  .nuit-back{width:40px;height:40px}
  .pl-tab{flex:1;min-height:48px;justify-content:center}
}
