/* ============================================================
   SportPass — Design system (thème clair, mobile-first)
   Lime de marque #D4F040 en aplats · olive profond pour le texte
   Inter · icônes Lucide · cibles tactiles ≥44px
   ============================================================ */
:root{
  --bg:#F3F5EF; --surface:#FFFFFF; --card:#FFFFFF; --card-2:#EFF1EA;
  --ink:#15170F; --near:#3C3F35; --subtle:#6C7064; --muted:#9DA194;
  --border:#E6E8DF; --border-2:#D7DACE;
  --accent:#D4F040; --accent-dk:#C2E024; --accent-ink:#1A1C12;
  --accent-deep:#5C7A00; --accent-soft:#F1F8CF;
  --gold:#B9860B; --danger:#C9333E; --ok:#157347;
  --r-sm:11px; --r-md:14px; --r-lg:20px; --r-pill:999px;
  --sh-1:0 1px 2px rgba(20,22,15,.04),0 10px 26px rgba(20,22,15,.07);
  --sh-2:0 16px 44px rgba(20,22,15,.14);
  --nav-h:58px;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;height:100%}
body{
  font-family:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
  background:#E7EAE1;color:var(--ink);-webkit-font-smoothing:antialiased;
  font-size:14px;line-height:1.5;display:grid;place-items:center;
}
a{color:inherit;text-decoration:none}
button{font:inherit}
svg{display:block}
[data-lucide]{width:20px;height:20px}

/* App shell (cadre type device) */
.device{position:relative;width:100%;max-width:420px;height:100dvh;max-height:920px;
  background:var(--bg);overflow:hidden;display:flex;flex-direction:column}
@media(min-width:480px){
  .device{border-radius:38px;box-shadow:0 30px 70px rgba(20,22,15,.18);border:1px solid var(--border)}
}
.scroll{flex:1;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch}
.pad{padding:0 16px}

/* ── Top bar ───────────────────────────────── */
.top{display:flex;align-items:center;justify-content:space-between;
  padding:max(13px,env(safe-area-inset-top)) 16px 8px;flex:none}
.brand{display:flex;align-items:center;gap:9px}
.brand-mark{width:29px;height:29px;border-radius:9px;display:grid;place-items:center;
  background:var(--accent);color:var(--accent-ink);font-weight:800;font-size:12.5px;letter-spacing:-.5px}
.brand-name{font-size:16.5px;font-weight:600;letter-spacing:-.3px}
.brand-name b{font-weight:800;color:var(--accent-deep)}
.top-actions{display:flex;align-items:center;gap:9px}
.icon-btn{position:relative;width:40px;height:40px;border-radius:11px;border:1px solid var(--border);
  background:var(--card);color:var(--near);display:grid;place-items:center;cursor:pointer;box-shadow:var(--sh-1)}
.icon-btn svg{width:20px;height:20px}
.icon-btn .badge{position:absolute;top:-4px;right:-4px;min-width:17px;height:17px;padding:0 4px;
  background:var(--danger);color:#fff;font-size:10px;font-weight:800;border-radius:99px;
  display:grid;place-items:center;border:2px solid var(--bg)}
.pass-chip{display:flex;align-items:center;gap:7px;border:1px solid var(--border-2);
  background:var(--accent-soft);color:var(--accent-deep);font-size:12px;font-weight:700;
  padding:7px 12px;border-radius:var(--r-pill);cursor:pointer}
.pass-chip .dot{width:7px;height:7px;border-radius:50%;background:var(--accent-deep);animation:led 2s infinite}
@keyframes led{0%{box-shadow:0 0 0 0 rgba(92,122,0,.45)}70%{box-shadow:0 0 0 6px rgba(92,122,0,0)}100%{box-shadow:0 0 0 0 rgba(92,122,0,0)}}

/* ── Search ────────────────────────────────── */
.searchwrap{padding:6px 16px 0;flex:none}
.search{width:100%;display:flex;align-items:center;gap:11px;
  background:var(--card);border:1px solid var(--border);border-radius:var(--r-md);padding:12px 14px;
  color:var(--ink);font-size:14px;cursor:pointer;text-align:left;box-shadow:var(--sh-1)}
.search .lead{color:var(--accent-deep);flex:none}
.search span{flex:1;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--subtle)}
.search .trail{color:var(--muted);flex:none}

.valuestrip{padding:11px 16px 4px;font-size:12.5px;color:var(--subtle);font-weight:500;flex:none}
.valuestrip b{color:var(--accent-deep);font-weight:800}

/* ── Category pills ────────────────────────── */
.cats{display:flex;gap:8px;overflow-x:auto;padding:9px 16px 11px;scrollbar-width:none;flex:none}
.cats::-webkit-scrollbar{display:none}
.chip{flex:none;display:flex;align-items:center;gap:7px;background:var(--card);
  border:1px solid var(--border);color:var(--near);font-size:12.5px;font-weight:600;
  padding:8px 13px;border-radius:var(--r-pill);cursor:pointer;transition:.15s;box-shadow:var(--sh-1)}
.chip svg{width:15px;height:15px}
.chip.on{background:var(--accent);border-color:var(--accent);color:var(--accent-ink);box-shadow:none}
.chip.on span,.chip.on svg{color:var(--accent-ink)!important}

/* ── Map ───────────────────────────────────── */
.mapwrap{position:relative;flex:1;min-height:0}
#map{position:absolute;inset:0;background:#E8EBE4}
.leaflet-container{background:#E8EBE4;font-family:inherit}
.leaflet-control-attribution{background:rgba(255,255,255,.7)!important;color:#9298a0!important;font-size:9px!important}
.leaflet-control-attribution a{color:#6b7280!important}

.vmark{position:relative;width:44px;display:flex;flex-direction:column;align-items:center;
  transform:scale(.3);opacity:0;transition:transform .42s cubic-bezier(.34,1.56,.64,1),opacity .3s}
.vmark.in{transform:scale(1);opacity:1}
.vmark-pin{width:38px;height:38px;border-radius:50% 50% 50% 4px;transform:rotate(45deg);
  background:#fff;border:2px solid var(--c);display:grid;place-items:center;box-shadow:0 4px 12px rgba(20,22,15,.22)}
.vmark-ico{transform:rotate(-45deg);color:var(--c);display:grid;place-items:center}
.vmark-ico svg{width:18px;height:18px}
.vmark-badge{position:absolute;top:-9px;right:-13px;background:var(--c);color:#15170F;
  font-size:10px;font-weight:800;padding:2px 6px;border-radius:var(--r-pill);box-shadow:0 2px 7px rgba(20,22,15,.25);white-space:nowrap;letter-spacing:-.2px}
.vmark.sel{transform:scale(1.18);z-index:1000}
.vmark.sel .vmark-pin{background:var(--accent);border-color:var(--accent)}
.vmark.sel .vmark-ico{color:var(--accent-ink)}
.vmark.sel .vmark-badge{background:var(--accent-ink);color:var(--accent)}

.umark{position:relative;width:24px;height:24px}
.umark-dot{position:absolute;inset:6px;border-radius:50%;background:var(--accent-deep);
  border:2px solid #fff;box-shadow:0 1px 6px rgba(20,22,15,.3)}
.umark-pulse{position:absolute;inset:0;border-radius:50%;background:rgba(92,122,0,.28);animation:upulse 2.2s ease-out infinite}
@keyframes upulse{0%{transform:scale(.5);opacity:.8}100%{transform:scale(2.6);opacity:0}}

.fab{position:absolute;right:14px;bottom:200px;z-index:600;width:46px;height:46px;border-radius:14px;
  background:#fff;border:1px solid var(--border);color:var(--accent-deep);display:grid;place-items:center;cursor:pointer;box-shadow:var(--sh-1)}
.fab:active{transform:scale(.94)}
.fab.loading svg{animation:spin .9s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── Venue cards (bottom rail) ─────────────── */
.cards{position:absolute;left:0;right:0;bottom:12px;z-index:500;display:flex;gap:11px;
  overflow-x:auto;padding:0 16px 4px;scroll-snap-type:x mandatory;scrollbar-width:none}
.cards::-webkit-scrollbar{display:none}
.vcard{flex:none;width:174px;scroll-snap-align:start;cursor:pointer;
  background:#fff;border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden;box-shadow:var(--sh-1);transition:.15s}
.vcard.sel{border-color:var(--accent-deep);transform:translateY(-3px)}
.vcard-top{height:80px;position:relative;background-size:cover;background-position:center;
  background-color:var(--card-2)}
.vcard-top::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(20,22,15,0),rgba(20,22,15,.28))}
.vcard-fallback{position:absolute;inset:0;display:grid;place-items:center;color:var(--c);
  background:linear-gradient(135deg,color-mix(in srgb,var(--c) 18%,#fff),#fff)}
.vcard-fallback svg{width:28px;height:28px}
.vcard-disc{position:absolute;top:8px;right:8px;z-index:2;background:var(--c);color:#15170F;
  font-size:11px;font-weight:800;padding:3px 8px;border-radius:var(--r-pill);box-shadow:0 2px 7px rgba(20,22,15,.2)}
.vcard-disc.inc{background:var(--accent);color:var(--accent-ink)}
.vcard-body{padding:10px 12px 12px}
.vcard-name{font-size:13.5px;font-weight:700;letter-spacing:-.2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.vcard-meta{font-size:11.5px;color:var(--subtle);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.vcard-row{display:flex;align-items:baseline;justify-content:space-between;margin-top:8px}
.vcard-price{font-size:14px;font-weight:800}
.vcard-price small{font-size:11px;font-weight:600;color:var(--muted);text-decoration:line-through;margin-right:5px}
.vcard-price .inc{color:var(--accent-deep);font-size:12.5px}
.vcard-rate{font-size:11.5px;color:var(--gold);font-weight:700}

/* ── Bottom nav ────────────────────────────── */
.nav{display:flex;justify-content:space-around;align-items:center;flex:none;height:var(--nav-h);
  padding-bottom:env(safe-area-inset-bottom);border-top:1px solid var(--border);
  background:rgba(255,255,255,.94);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px)}
.nav-item{display:flex;flex-direction:column;align-items:center;gap:3px;background:none;border:0;
  color:var(--subtle);font-size:10px;font-weight:600;cursor:pointer;padding:4px 10px;text-decoration:none}
.nav-item svg,.nav-item [data-lucide]{width:21px;height:21px}
.nav-item.on{color:var(--accent-deep)}

/* ── Bottom sheet ──────────────────────────── */
.scrim{position:absolute;inset:0;z-index:800;background:rgba(20,22,15,.42);opacity:0;pointer-events:none;transition:opacity .25s}
.scrim.show{opacity:1;pointer-events:auto}
.sheet{position:absolute;left:0;right:0;bottom:0;z-index:900;background:var(--surface);
  border-top:1px solid var(--border);border-radius:22px 22px 0 0;
  padding:8px 18px max(20px,env(safe-area-inset-bottom));transform:translateY(110%);
  transition:transform .32s cubic-bezier(.4,0,.2,1);box-shadow:var(--sh-2);max-height:84%;overflow-y:auto}
.sheet.show{transform:translateY(0)}
.sheet-grab{width:36px;height:4px;border-radius:99px;background:var(--border-2);margin:6px auto 16px}
.sh-head{display:flex;align-items:flex-start;gap:13px;margin-bottom:14px}
.sh-ico{width:48px;height:48px;border-radius:14px;display:grid;place-items:center;flex:none;color:var(--c);
  background:linear-gradient(135deg,color-mix(in srgb,var(--c) 20%,#fff),#fff);border:1px solid var(--border)}
.sh-ico svg{width:23px;height:23px}
.sh-title{flex:1;min-width:0}
.sh-name{font-size:18px;font-weight:800;letter-spacing:-.4px}
.sh-sub{font-size:12.5px;color:var(--subtle);margin-top:3px}
.sh-rate{font-size:13px;color:var(--gold);font-weight:700;flex:none}
.sh-chips{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}
.sh-tag{font-size:12px;font-weight:600;color:var(--near);background:var(--card-2);border:1px solid var(--border);padding:6px 11px;border-radius:var(--r-pill)}
.sh-tag.sport{color:var(--c)}
.priceblk{background:var(--card-2);border:1px solid var(--border);border-radius:var(--r-md);padding:14px 16px;margin-bottom:16px}
.pb-row{display:flex;justify-content:space-between;align-items:center;font-size:13.5px;color:var(--near)}
.pb-row+.pb-row{margin-top:9px}
.pb-row .strike{color:var(--muted);text-decoration:line-through}
.pb-save{margin-top:12px;padding-top:12px;border-top:1px dashed var(--border-2);display:flex;justify-content:space-between;align-items:center}
.pb-save .lbl{font-size:13px;font-weight:600;color:var(--subtle)}
.pb-save .amt{font-size:18px;font-weight:800;color:var(--accent-deep)}
.pb-save .amt.inc{font-size:15px}

/* ── Buttons / forms ───────────────────────── */
.btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;border:0;
  font-size:14.5px;font-weight:700;padding:13px;border-radius:var(--r-md);cursor:pointer;
  min-height:46px;transition:.15s;touch-action:manipulation}
.btn-primary{background:var(--accent);color:var(--accent-ink);box-shadow:0 4px 14px rgba(170,200,30,.32)}
.btn-primary:active{background:var(--accent-dk)}
.btn-ghost{background:var(--card);border:1px solid var(--border-2);color:var(--near);box-shadow:var(--sh-1)}
.btn-ghost:active{background:var(--card-2)}
.btn+.btn{margin-top:11px}
.btn-row{display:flex;gap:11px}
.btn-row .btn{flex:1}
.btn-row .btn.square{flex:none;width:52px}

.field{margin-bottom:14px}
.field label{display:block;font-size:12.5px;font-weight:600;color:var(--subtle);margin-bottom:6px}
.field input,.field select,.field textarea{width:100%;background:var(--card);border:1px solid var(--border-2);
  border-radius:var(--r-sm);padding:12px 13px;color:var(--ink);font-size:14px}
.field input::placeholder,.field textarea::placeholder{color:var(--muted)}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--accent-deep);
  box-shadow:0 0 0 3px rgba(92,122,0,.12)}
.field textarea{resize:vertical;min-height:86px}

/* ── Generic page bits ─────────────────────── */
.page-header{padding:max(15px,env(safe-area-inset-top)) 16px 10px;flex:none;display:flex;align-items:center;gap:11px}
.page-header h1{font-size:19px;font-weight:800;letter-spacing:-.5px;margin:0}
.back-link{width:40px;height:40px;border-radius:11px;border:1px solid var(--border);background:var(--card);
  color:var(--near);display:grid;place-items:center;flex:none;box-shadow:var(--sh-1)}
.lead-copy{font-size:14px;color:var(--subtle);line-height:1.55;margin:0 0 18px}
.sec-hd{font-size:11px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;color:var(--muted);margin:20px 0 10px}

.card{background:var(--card);border:1px solid var(--border);border-radius:var(--r-md);padding:14px;box-shadow:var(--sh-1)}
.card+.card{margin-top:11px}

/* plan cards */
.plan{position:relative;background:var(--card);border:1px solid var(--border);border-radius:var(--r-lg);padding:18px;margin-bottom:14px;box-shadow:var(--sh-1)}
.plan.populaire{border-color:var(--accent-deep);box-shadow:0 0 0 1px var(--accent-deep),var(--sh-1)}
.plan-tag{position:absolute;top:-10px;left:18px;background:var(--accent);color:var(--accent-ink);font-size:11px;font-weight:800;padding:3px 10px;border-radius:var(--r-pill)}
.plan-nom{font-size:16px;font-weight:800}
.plan-prix{font-size:26px;font-weight:800;letter-spacing:-.8px;margin:5px 0 2px}
.plan-prix small{font-size:13.5px;font-weight:600;color:var(--subtle)}
.plan-desc{font-size:13px;color:var(--subtle);margin-bottom:14px}
.plan ul{list-style:none;padding:0;margin:0 0 16px}
.plan li{display:flex;align-items:center;gap:9px;font-size:13.5px;color:var(--near);padding:5px 0}
.plan li svg{width:17px;height:17px;color:var(--accent-deep);flex:none}

/* list rows */
.row-item{display:flex;align-items:center;gap:12px;background:var(--card);border:1px solid var(--border);
  border-radius:var(--r-md);padding:12px 13px;margin-bottom:10px;box-shadow:var(--sh-1)}
.row-ico{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;flex:none;color:var(--c);
  background:linear-gradient(135deg,color-mix(in srgb,var(--c) 18%,#fff),#fff)}
.row-ico svg{width:20px;height:20px}
.row-main{flex:1;min-width:0}
.row-title{font-size:14px;font-weight:700}
.row-sub{font-size:11.5px;color:var(--subtle);margin-top:2px}
.row-end{text-align:right;flex:none}
.row-amt{font-size:14px;font-weight:800;color:var(--accent-deep)}
.tag{display:inline-block;font-size:11px;font-weight:700;padding:3px 9px;border-radius:var(--r-pill);
  background:var(--card-2);color:var(--near)}
.tag.ok{background:#E8F5EC;color:var(--ok)}
.tag.warn{background:#FBF3DE;color:#8A6300}

/* hero stat (mon pass) */
.passcard{background:linear-gradient(135deg,var(--accent-soft),#fff);border:1px solid var(--accent-deep);
  border-radius:var(--r-lg);padding:18px;margin-bottom:18px;box-shadow:var(--sh-1)}
.passcard .lbl{font-size:11.5px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:var(--accent-deep)}
.passcard .nom{font-size:20px;font-weight:800;letter-spacing:-.5px;margin:6px 0}
.passcard .meta{font-size:13px;color:var(--near)}
.stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:11px;margin-bottom:18px}
.stat{background:var(--card);border:1px solid var(--border);border-radius:var(--r-md);padding:14px;box-shadow:var(--sh-1)}
.stat .v{font-size:20px;font-weight:800;letter-spacing:-.4px}
.stat .k{font-size:11.5px;color:var(--subtle);margin-top:3px}

.empty{text-align:center;color:var(--subtle);padding:48px 20px}
.empty svg{width:38px;height:38px;margin:0 auto 12px;color:var(--border-2)}

/* messages */
.messages{padding:0 16px;flex:none}
.msg{font-size:13.5px;font-weight:600;padding:11px 14px;border-radius:var(--r-sm);margin-top:10px;border:1px solid transparent}
.msg.success{background:#E8F5EC;color:var(--ok);border-color:#BFE3CC}
.msg.error{background:#FBE9EA;color:var(--danger);border-color:#F1C9CD}
.msg.warning{background:#FBF3DE;color:#8A6300;border-color:#EEDFAE}
.msg.info{background:var(--card-2);color:var(--near);border-color:var(--border)}

.toast{position:absolute;left:50%;bottom:calc(var(--nav-h) + 22px);transform:translate(-50%,20px);z-index:1100;
  background:var(--ink);color:#fff;font-size:13.5px;font-weight:700;padding:11px 18px;
  border-radius:var(--r-pill);box-shadow:var(--sh-2);opacity:0;pointer-events:none;transition:.25s;white-space:nowrap}
.toast.show{opacity:1;transform:translate(-50%,0)}

:focus-visible{outline:2px solid var(--accent-deep);outline-offset:2px;border-radius:6px}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}.vmark{transform:scale(1);opacity:1}}

/* Confort tactile : pas de délai 300ms sur les éléments cliquables */
.chip,.nav-item,.icon-btn,.fab,.back-link,.vcard,.row-item,.btn,.plan,.search,.pass-chip{touch-action:manipulation}
