:root,[data-theme=nuit]{--marque-orange:#ec6a2b;--marque-orange-clair:#ff8a4d;--marque-marine:#1e2b45;--marque-sauge:#a6c795;--strava:#fc4c02;--fond:#0a0f1a;--panneau-bg:#141c2ed1;--enfonce:#ffffff0d;--enfonce-doux:#ffffff08;--texte:#e8ecf4;--texte-attenue:#94a1b8;--bord:#ffffff17;--accent:var(--marque-orange);--accent-contraste:#fff;--vert-fort:#8bd17c;--ombre:0 12px 40px #00000080;--rayon:14px;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif}[data-theme=clair]{--fond:#e9eef5;--panneau-bg:#fffc;--enfonce:#1e2b450f;--enfonce-doux:#1e2b4509;--texte:#1e2b45;--texte-attenue:#5a6680;--bord:#1e2b4524;--vert-fort:#4d9a4d;--ombre:0 12px 40px #1e2b452e}*{box-sizing:border-box}html,body,#root{background:var(--fond);width:100%;height:100%;color:var(--texte);margin:0}.app{width:100vw;height:100vh;position:relative;overflow:hidden}.carte{position:absolute;inset:0}.panneau{background:var(--panneau-bg);-webkit-backdrop-filter:blur(16px)saturate(1.3);backdrop-filter:blur(16px)saturate(1.3);border:1px solid var(--bord);box-shadow:var(--ombre);color:var(--texte)}.panneau--desktop{border-radius:var(--rayon);z-index:10;flex-direction:column;width:344px;max-height:calc(100dvh - 32px);display:flex;position:absolute;top:16px;left:16px;overflow:hidden}.panneau__fixe{flex-direction:column;flex-shrink:0;gap:14px;padding:16px 16px 12px;display:flex}.panneau__fixe .panneau__modes{padding:0}.panneau__corps--desktop{overscroll-behavior:contain;min-height:0;padding:6px 16px calc(16px + env(safe-area-inset-bottom));flex:auto;display:block;overflow-y:auto}.panneau__corps--desktop>*+*{margin-top:14px}.panneau__corps,.panneau__corps--desktop{scrollbar-width:none;-ms-overflow-style:none}.panneau__corps::-webkit-scrollbar{display:none}.panneau__corps--desktop::-webkit-scrollbar{display:none}.panneau__entete{justify-content:space-between;align-items:center;gap:10px;display:flex}.panneau__entete-actions{gap:8px;display:flex}.panneau__logo{background:#fff;border-radius:8px;width:auto;height:38px;padding:5px 8px;display:block}.panneau__sous-titre{color:var(--texte-attenue);margin:0;font-size:12px}.panneau-ouvrir{z-index:10;border:1px solid var(--bord);background:var(--panneau-bg);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);width:46px;height:46px;box-shadow:var(--ombre);color:var(--texte);cursor:pointer;border-radius:12px;justify-content:center;align-items:center;display:inline-flex;position:absolute;top:16px;left:16px}.panneau--mobile{z-index:30;border-radius:20px 20px 0 0;flex-direction:column;height:90dvh;transition:transform .28s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;bottom:0;left:0;right:0;overflow:hidden}.poignee,.panneau__haut,.panneau__modes{flex-shrink:0}.panneau--plein{transform:translateY(0)}.panneau--demi{transform:translateY(40dvh)}.panneau--peek{transform:translateY(calc(90dvh - 176px))}.poignee{cursor:grab;touch-action:none;justify-content:center;align-items:center;padding:12px 0 6px;display:flex}.poignee__barre{background:var(--texte-attenue);opacity:.6;border-radius:3px;width:46px;height:5px}.panneau__haut{align-items:center;gap:12px;padding:0 16px 8px;display:flex}.logo-mini{background:#fff;border-radius:6px;width:auto;height:30px;padding:3px 6px}.compteur-traces{color:var(--texte-attenue);font-size:13px}.compteur-traces strong{color:var(--texte);font-size:15px}.panneau__haut .compteur-traces{margin-left:auto;margin-right:auto}.panneau__modes{padding:0 16px 10px}.panneau__corps{overscroll-behavior:contain;-webkit-overflow-scrolling:touch;touch-action:pan-y;min-height:0;padding:4px 16px calc(24px + env(safe-area-inset-bottom));flex:auto;display:block;overflow-y:auto}.panneau__corps>*+*{margin-top:14px}.compte{border-bottom:1px solid var(--bord);justify-content:space-between;align-items:center;gap:8px;padding-bottom:12px;display:flex}.compte__nom{text-overflow:ellipsis;white-space:nowrap;font-size:13px;font-weight:600;overflow:hidden}.bouton-icone{border:1px solid var(--bord);background:var(--enfonce);min-width:44px;min-height:44px;color:var(--texte);cursor:pointer;border-radius:10px;justify-content:center;align-items:center;gap:6px;transition:background .15s,border-color .15s;display:inline-flex}.bouton-icone:hover{background:color-mix(in srgb, var(--texte) 8%, transparent)}.bouton-icone:disabled{opacity:.5;cursor:not-allowed}.bouton-icone--texte{min-width:auto;padding:6px 10px;font-size:12px;font-weight:600}.theme-toggle{border:1px solid var(--bord);background:var(--enfonce);min-width:44px;min-height:44px;color:var(--texte);cursor:pointer;border-radius:10px;justify-content:center;align-items:center;display:inline-flex}.theme-toggle:hover{background:color-mix(in srgb, var(--texte) 8%, transparent)}.segmented{background:var(--enfonce);border-radius:12px;gap:4px;padding:4px;display:flex}.segmented__option{min-height:48px;color:var(--texte-attenue);cursor:pointer;background:0 0;border:none;border-radius:9px;flex-direction:column;flex:1;align-items:center;gap:3px;padding:9px 4px;font-size:11px;font-weight:600;transition:background .15s,color .15s;display:flex}.segmented__option:hover{color:var(--texte)}.segmented__option--actif{background:var(--accent);color:var(--accent-contraste);box-shadow:0 4px 12px color-mix(in srgb, var(--accent) 45%, transparent)}.bloc-mode{flex-direction:column;gap:10px;display:flex}label{margin-bottom:6px;font-size:13px;display:block}.champ{margin-bottom:4px}.valeur{color:var(--marque-orange-clair);font-variant-numeric:tabular-nums}input[type=range]{width:100%;accent-color:var(--accent);min-height:24px}select{background:var(--enfonce);width:100%;color:var(--texte);border:1px solid var(--bord);border-radius:9px;min-height:44px;padding:10px;font-size:13px}button:focus-visible,select:focus-visible,a:focus-visible,input:focus-visible,[role=button]:focus-visible,[role=tab]:focus-visible,[role=combobox]:focus-visible,[role=option]:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.select{width:100%;position:relative}.select__bouton{background:var(--enfonce);width:100%;min-height:44px;color:var(--texte);border:1px solid var(--bord);cursor:pointer;border-radius:9px;justify-content:space-between;align-items:center;gap:8px;padding:10px 12px;font-size:13px;font-weight:600;transition:border-color .15s,background .15s;display:flex}.select__bouton:hover{border-color:color-mix(in srgb, var(--accent) 55%, var(--bord))}.select__valeur{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.select__chevron{color:var(--texte-attenue);flex:none;transition:transform .2s}.select__chevron--ouvert{transform:rotate(180deg)}.select__menu{background:var(--panneau-bg);-webkit-backdrop-filter:blur(16px)saturate(1.3);backdrop-filter:blur(16px)saturate(1.3);border:1px solid var(--bord);box-shadow:var(--ombre);scrollbar-width:none;-ms-overflow-style:none;border-radius:12px;margin:0;padding:6px;list-style:none;animation:.14s select-apparition;overflow-y:auto}.select__menu--portal{z-index:1000}.select__menu::-webkit-scrollbar{display:none}@keyframes select-apparition{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}.select__option{min-height:44px;color:var(--texte);cursor:pointer;border-radius:8px;justify-content:space-between;align-items:center;gap:8px;padding:9px 10px;font-size:13px;display:flex}.select__option--survol{background:var(--enfonce)}.select__option--actif{color:var(--accent);font-weight:700}.select__option--actif.select__option--survol{background:color-mix(in srgb, var(--accent) 16%, transparent)}.select__option svg{color:var(--accent);flex:none}.btn{cursor:pointer;border:none;border-radius:10px;justify-content:center;align-items:center;gap:8px;width:100%;min-height:44px;padding:12px 14px;font-size:14px;font-weight:700;transition:filter .15s,opacity .15s;display:inline-flex}.btn:hover{filter:brightness(1.08)}.btn:disabled{opacity:.55;cursor:not-allowed}.btn--accent{background:var(--accent);color:var(--accent-contraste)}.btn--secondaire{background:var(--enfonce);color:var(--texte);border:1px solid var(--bord)}.btn--strava{background:var(--strava);color:#fff}.bloc-resync{flex-direction:column;gap:6px;display:flex}.tourne{animation:1s linear infinite tourner}.sport-toggles{flex-wrap:wrap;gap:8px;display:flex}.sport-toggle{border:1px solid var(--bord);background:var(--enfonce);min-height:44px;color:var(--texte-attenue);cursor:pointer;border-radius:999px;align-items:center;gap:6px;padding:8px 14px;font-size:12px;font-weight:600;transition:background .15s,border-color .15s,color .15s;display:inline-flex}.sport-toggle[aria-pressed=true]{background:color-mix(in srgb, var(--c-sport) 20%, transparent);border-color:var(--c-sport);color:var(--texte)}.sport-toggle[aria-pressed=true] svg{color:var(--c-sport)}.sports-actions{gap:12px;margin-top:10px;display:flex}.lien-action{color:var(--marque-orange-clair);cursor:pointer;background:0 0;border:none;padding:2px 0;font-size:12px;font-weight:600}.acc{border:1px solid var(--bord);background:var(--enfonce-doux);border-radius:12px;width:100%;position:relative;overflow:hidden}.acc__corps{display:block}.acc__tete{z-index:2;width:100%;min-height:46px;color:var(--texte);cursor:pointer;background:0 0;border:none;justify-content:space-between;align-items:center;padding:12px 14px;font-size:13px;font-weight:600;display:flex;position:relative}.acc__titre{align-items:center;gap:8px;display:flex}.acc__icone{color:var(--texte-attenue);display:inline-flex}.acc__chevron{color:var(--texte-attenue);transition:transform .2s}.acc--ouvert .acc__chevron{transform:rotate(180deg)}.acc__contenu{padding:2px 14px 14px}.hero-communes{text-align:center;border:1px solid var(--bord);background:var(--enfonce);border-radius:14px;padding:16px 14px}.hero-communes--charge{color:var(--texte-attenue);justify-content:center;align-items:center;gap:10px;font-size:13px;display:flex}.hero-communes__chiffres{justify-content:center;align-items:baseline;gap:6px;display:flex}.hero-communes__valeur{color:var(--vert-fort);font-variant-numeric:tabular-nums;font-size:30px;font-weight:800}.hero-communes__total{color:var(--texte-attenue);font-size:15px;font-weight:600}.hero-communes__label{text-transform:uppercase;letter-spacing:.07em;color:var(--texte-attenue);margin-top:2px;font-size:11px}.hero-communes__barre{background:var(--enfonce-doux);border:1px solid var(--bord);border-radius:6px;height:10px;margin:12px 0 6px;overflow:hidden}.hero-communes__jauge{background:linear-gradient(90deg, var(--marque-sauge), var(--vert-fort));border-radius:6px;height:100%;transition:width .45s;display:block}.hero-communes__pourcent{font-size:13px;font-weight:700}.legende{background:var(--panneau-bg);-webkit-backdrop-filter:blur(16px)saturate(1.3);backdrop-filter:blur(16px)saturate(1.3);border:1px solid var(--bord);border-radius:var(--rayon);z-index:10;width:220px;box-shadow:var(--ombre);color:var(--texte);padding:12px 14px;position:absolute;bottom:20px;right:20px}.legende--inline{width:auto;box-shadow:none;background:var(--enfonce-doux);position:static}.legende__titre{margin-bottom:8px;font-size:12px;font-weight:600}.legende__barre{border-radius:6px;height:12px;margin-bottom:6px}.legende__labels{color:var(--texte-attenue);justify-content:space-between;font-size:11px;display:flex}.legende__communes{flex-direction:column;gap:6px;font-size:12px;display:flex}.legende__case{align-items:center;gap:8px;display:flex}.legende__pastille{box-sizing:border-box;border-radius:4px;width:16px;height:16px;display:inline-block}.info-aide,.info-synchro{color:var(--texte-attenue);margin:6px 0 0;font-size:11px;line-height:1.45}.overlay{z-index:20;background:radial-gradient(circle at 50% 30%, color-mix(in srgb, var(--marque-marine) 60%, var(--fond)), var(--fond));justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.carte-etat{text-align:center;background:var(--panneau-bg);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid var(--bord);max-width:420px;box-shadow:var(--ombre);border-radius:18px;padding:36px}.carte-etat h1{margin:0 0 8px;font-size:26px}.carte-etat p{color:var(--texte-attenue);margin:0 0 22px;font-size:14px;line-height:1.5}.spinner{border:4px solid var(--bord);border-top-color:var(--accent);border-radius:50%;width:38px;height:38px;margin:0 auto 16px;animation:.9s linear infinite tourner}.spinner--mini{border-width:3px;width:18px;height:18px;margin:0}@keyframes tourner{to{transform:rotate(360deg)}}.message-erreur{color:#fca5a5;background:#b91c1c26;border:1px solid #b91c1c66;border-radius:8px;margin-top:12px;padding:10px 12px;font-size:13px}.mapboxgl-ctrl-bottom-left{z-index:5}@media (prefers-reduced-motion:reduce){.panneau--mobile,.hero-communes__jauge,.acc__chevron,.select__chevron{transition:none}.tourne,.spinner,.select__menu{animation:none}}
