/* ===== PARC-EX CARTE — Playful / Ludique ===== */
@import url('https://fonts.googleapis.com/css2?family=Nunito:wght@400;600;700;800;900&display=swap');

:root {
  --bg: #fef6ee;
  --surface: #ffffff;
  --header-bg: #2d1b4e;
  --header-text: #ffffff;
  --text-1: #2d1b4e;
  --text-2: #6b5a7e;
  --text-3: #a99bbe;
  --border: #ede4d9;
  --accent: #f97316;
  --accent-light: #fff3e6;
  --danger: #ef4444;
  --success: #22c55e;
  --r-sm: 12px;
  --r-md: 16px;
  --r-pill: 100px;
  --font: 'Nunito', system-ui, sans-serif;
  --shadow-s: 0 2px 4px rgba(45,27,78,.06);
  --shadow-m: 0 4px 16px rgba(45,27,78,.1);
  --shadow-l: 0 8px 32px rgba(45,27,78,.14);
}

*{margin:0;padding:0;box-sizing:border-box}
html{height:100%}
body{font-family:var(--font);background:var(--bg);color:var(--text-1);
  -webkit-text-size-adjust:100%;line-height:1.5;height:100%;text-wrap:pretty}

/* subtle bg pattern */
body::before{content:'';position:fixed;inset:0;z-index:-1;opacity:.35;
  background-image:
    radial-gradient(circle at 20% 30%, #fde68a 0, transparent 40%),
    radial-gradient(circle at 80% 70%, #fbcfe8 0, transparent 40%),
    radial-gradient(circle at 50% 90%, #bfdbfe 0, transparent 35%);
  pointer-events:none}

#root{display:flex;flex-direction:column;min-height:100%}
@media(min-width:768px){#root{height:100vh;overflow:hidden}}

/* ---------- HEADER ---------- */
.hdr{background:var(--header-bg);padding:12px 16px 0;position:sticky;top:0;z-index:1000;color:var(--header-text);flex-shrink:0;
  background-image:linear-gradient(135deg, #2d1b4e 0%, #4c1d95 50%, #7c3aed 100%)}
.hdr-top{display:flex;justify-content:space-between;align-items:center;gap:12px}
.hdr-title{font-size:22px;font-weight:900;letter-spacing:.02em;line-height:1}
.hdr-sub{font-size:11.5px;color:rgba(255,255,255,.5);font-weight:600;margin-top:2px}
.hdr-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}

/* language toggle */
.lang-tog{display:flex;border-radius:var(--r-sm);overflow:hidden;border:1.5px solid rgba(255,255,255,.2)}
.lang-btn{font-size:12px;font-weight:800;padding:3px 10px;border:none;
  cursor:pointer;background:transparent;color:rgba(255,255,255,.4);transition:.15s;font-family:var(--font)}
.lang-btn.on{background:rgba(255,255,255,.15);color:#fff}

/* edit toggle */
.edit-btn{font-size:13px;font-weight:800;padding:5px 16px;border-radius:var(--r-sm);
  border:1.5px solid rgba(255,255,255,.2);cursor:pointer;background:transparent;color:rgba(255,255,255,.6);
  transition:.15s;font-family:var(--font)}
.edit-btn:hover{background:rgba(255,255,255,.1)}
.edit-btn.on{background:var(--accent);color:#fff;border-color:var(--accent)}

/* search */
.search-row{margin-top:10px}
.search-in{width:100%;padding:8px 14px;border-radius:var(--r-sm);border:none;font-size:14px;
  font-family:var(--font);background:rgba(255,255,255,.12);color:#fff;outline:none;transition:.15s;font-weight:600}
.search-in::placeholder{color:rgba(255,255,255,.3)}
.search-in:focus{background:rgba(255,255,255,.2)}

/* filters */
.filters{display:flex;gap:6px;padding:10px 0 12px;overflow-x:auto;scrollbar-width:none}
.filters::-webkit-scrollbar{display:none}
.pill{font-size:12px;font-weight:700;padding:5px 12px;border-radius:var(--r-pill);
  border:1.5px solid rgba(255,255,255,.12);cursor:pointer;white-space:nowrap;flex-shrink:0;
  background:transparent;color:rgba(255,255,255,.45);transition:all .2s;display:flex;align-items:center;gap:5px;
  font-family:var(--font)}
.pill-icon{width:16px;height:16px;flex-shrink:0;display:flex;align-items:center;justify-content:center}
.pill-icon svg{width:14px;height:14px}
.pill.on{color:#fff;background:rgba(255,255,255,.15);border-color:rgba(255,255,255,.3)}
.pill-add{border-style:dashed;color:rgba(255,255,255,.28)}
.pill-add:hover{color:rgba(255,255,255,.55);border-color:rgba(255,255,255,.3)}

/* ---------- MAIN LAYOUT ---------- */
.main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-height:0}
@media(min-width:768px){
  .main{display:grid;grid-template-columns:1fr 1fr;min-height:0}
  .main.no-map{grid-template-columns:1fr}
}

/* map panel */
.map-panel{position:relative;min-height:0}
.map-ct{width:100%;height:38vh;min-height:200px}
@media(min-width:768px){.map-ct{height:100%;min-height:unset}}
.leaflet-container.pick-mode{cursor:crosshair!important}

/* list panel */
.list-panel{display:flex;flex-direction:column;overflow-y:auto;min-height:0}
.list-inner{padding:0 14px 100px;max-width:600px;width:100%;margin:0 auto}
@media(min-width:768px){.list-inner{padding:0 20px 100px;max-width:none}}

/* controls strip */
.ctrl-strip{display:flex;align-items:center;gap:6px;padding:6px 12px;background:var(--surface);
  border-bottom:1px solid var(--border);position:sticky;top:0;z-index:10;flex-shrink:0;flex-wrap:wrap}
@media(min-width:768px){.ctrl-strip{padding:8px 14px}}
.rad-ctl{display:flex;align-items:center;gap:6px;flex:1;min-width:140px}
.rad-lbl{font-weight:800;font-size:10px;color:var(--text-2);letter-spacing:.03em;
  text-transform:uppercase;white-space:nowrap}
.rad-val{font-weight:800;font-size:12px;color:var(--accent);min-width:40px;text-align:right;white-space:nowrap}
.rad-slider{-webkit-appearance:none;appearance:none;flex:1;height:5px;background:var(--border);border-radius:3px;outline:none;min-width:60px}
.rad-slider::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;
  background:var(--accent);cursor:pointer;border:3px solid #fff;box-shadow:var(--shadow-m)}
.rad-slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--accent);cursor:pointer;border:3px solid #fff}
.map-tog{font-size:11px;font-weight:800;padding:5px 14px;border-radius:var(--r-sm);
  border:1.5px solid var(--border);cursor:pointer;background:var(--surface);color:var(--text-2);white-space:nowrap;
  text-transform:uppercase;font-family:var(--font)}

/* ---------- CARDS ---------- */
.cat-hdr{font-size:13px;font-weight:900;text-transform:uppercase;letter-spacing:.04em;
  padding:18px 0 8px;display:flex;align-items:center;gap:8px;color:var(--text-2)}
.cat-icon{width:22px;height:22px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.cat-icon svg{width:14px;height:14px}

.card{background:var(--surface);border-radius:var(--r-md);padding:12px 14px;
  margin-bottom:8px;cursor:pointer;transition:box-shadow .2s,transform .1s;position:relative;
  border:1.5px solid var(--border);overflow:hidden}
.card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:5px;background:var(--cc,#ccc);border-radius:var(--r-md) 0 0 var(--r-md)}
.card:hover{box-shadow:var(--shadow-m)}
.card:active{transform:scale(.985)}
.card.active{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent),var(--shadow-m)}
.card.visited{opacity:.5}
.card.visited .card-name{text-decoration:line-through;text-decoration-color:var(--text-3)}
.card-top{display:flex;justify-content:space-between;align-items:flex-start;gap:8px}
.card-icon-wrap{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;
  flex-shrink:0;margin-right:8px}
.card-icon-wrap svg{width:20px;height:20px}
.card-name{font-weight:800;font-size:15px}
.card-walk{font-weight:800;font-size:15px;color:var(--cc,var(--accent));margin-top:1px;
  display:flex;align-items:baseline;gap:3px}
.card-walk-unit{font-weight:600;font-size:11px;color:var(--text-3)}
.card-meta{display:flex;align-items:baseline;gap:8px;margin-top:2px;flex-wrap:wrap}
.card-addr{font-size:12px;color:var(--accent);text-decoration:none;font-weight:600}
.card-addr:hover{text-decoration:underline}
.card-hours{font-size:11.5px;color:var(--text-3);margin-top:2px;font-weight:600}
.card-note{font-size:12.5px;color:var(--success);font-style:italic;margin-top:4px;line-height:1.35;font-weight:600}

/* card actions */
.card-acts{display:flex;gap:4px;flex-shrink:0}
.c-act{font-size:11px;font-weight:700;padding:4px 10px;border-radius:var(--r-sm);
  border:1.5px solid var(--border);cursor:pointer;background:var(--surface);color:var(--text-2);transition:.15s;font-family:var(--font)}
.c-act:hover{background:var(--bg)}
.c-act.danger{color:var(--danger);border-color:#fecaca}
.c-act.danger:hover{background:#fef2f2}

/* visited btn */
.vis-btn{width:26px;height:26px;border-radius:50%;border:2.5px solid var(--border);background:transparent;
  cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:.2s;padding:0}
.vis-btn:hover{border-color:var(--text-3);transform:scale(1.1)}
.vis-btn.on{background:var(--success);border-color:var(--success);color:#fff}
.vis-btn svg{width:14px;height:14px}

/* add btn */
.add-btn{width:100%;padding:13px;border-radius:var(--r-md);border:2.5px dashed var(--border);background:transparent;
  color:var(--accent);font-weight:800;font-size:14px;cursor:pointer;transition:.15s;
  margin:14px 0;font-family:var(--font)}
.add-btn:hover{border-color:var(--accent);background:var(--accent-light)}

/* reset */
.reset-btn{width:100%;padding:10px;border-radius:var(--r-md);border:1.5px solid var(--border);background:var(--surface);
  color:var(--danger);font-weight:700;font-size:12px;cursor:pointer;margin-top:18px;
  text-transform:uppercase;font-family:var(--font)}

/* ---------- FORM OVERLAY ---------- */
.form-ov{position:fixed;inset:0;background:rgba(45,27,78,.5);z-index:2000;display:flex;align-items:flex-end;
  justify-content:center;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .3s,visibility .3s;
  backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}
.form-ov.open{opacity:1;visibility:visible;pointer-events:auto}
.form-sheet{background:var(--surface);border-radius:20px 20px 0 0;padding:22px 20px 36px;width:100%;
  max-width:520px;max-height:85vh;overflow-y:auto;transform:translateY(100%);
  transition:transform .3s cubic-bezier(.32,.72,0,1)}
.form-ov.open .form-sheet{transform:translateY(0)}
@media(min-width:768px){.form-ov{align-items:center}.form-sheet{border-radius:20px;max-height:90vh}}
.form-title{font-size:18px;font-weight:900;margin-bottom:14px}
.form-lbl{font-size:11px;font-weight:800;color:var(--text-3);letter-spacing:.03em;
  text-transform:uppercase;display:block;margin-top:12px;margin-bottom:4px}
.form-in,.form-sel,.form-ta{width:100%;padding:10px 14px;border-radius:var(--r-sm);border:1.5px solid var(--border);
  font-size:14px;font-family:var(--font);background:var(--bg);outline:none;transition:border-color .15s;color:var(--text-1);font-weight:600}
.form-in:focus,.form-sel:focus,.form-ta:focus{border-color:var(--accent)}
.form-ta{min-height:60px;resize:vertical}
.form-hint{font-size:11px;color:var(--text-3);margin-top:4px;font-weight:600}
.form-row{display:flex;gap:8px}
.form-btns{display:flex;gap:8px;margin-top:18px}
.btn-p{padding:11px 20px;border-radius:var(--r-sm);border:none;font-weight:800;
  font-size:14px;cursor:pointer;background:var(--accent);color:#fff;flex:1;font-family:var(--font)}
.btn-s{padding:11px 20px;border-radius:var(--r-sm);border:1.5px solid var(--border);
  font-weight:800;font-size:14px;cursor:pointer;background:var(--surface);color:var(--text-2);font-family:var(--font)}

/* color swatches */
.swatches{display:flex;gap:8px;flex-wrap:wrap;margin-top:4px}
.swatch{width:30px;height:30px;border-radius:50%;border:3px solid transparent;cursor:pointer;padding:0;transition:.2s}
.swatch.on{border-color:var(--text-1);box-shadow:0 0 0 2px #fff,0 0 0 4px var(--text-1)}
.swatch:hover{transform:scale(1.1)}

/* ---------- LEAFLET POPUP ---------- */
.leaflet-popup-content-wrapper{border-radius:var(--r-md)!important;box-shadow:var(--shadow-l)!important;font-family:var(--font)!important}
.leaflet-popup-content{margin:10px 14px!important;font-size:13px;line-height:1.4}
.pu-name{font-weight:800;font-size:14px}
.pu-cat{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.05em;margin-top:2px}
.pu-addr{font-size:11px;color:var(--text-3);margin-top:4px}
.pu-hours{font-size:11px;color:var(--text-3);margin-top:2px}
.pu-note{font-size:12px;color:var(--success);font-style:italic;margin-top:4px}
.pu-dir{display:inline-block;margin-top:6px;font-size:12px;font-weight:800;
  color:var(--accent);text-decoration:none}
.pu-dir:hover{text-decoration:underline}

/* ---------- HOME MARKER ---------- */
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(249,115,22,.5)}50%{box-shadow:0 0 0 14px rgba(249,115,22,0)}}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-3px)}}
.home-mk{width:28px;height:28px;background:var(--accent);border-radius:50%;border:3px solid #fff;
  box-shadow:0 2px 8px rgba(0,0,0,.3);animation:pulse 2s ease-in-out infinite;
  display:flex;align-items:center;justify-content:center;font-size:14px;line-height:1}

/* geocoding */
.geo-ov{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--surface);
  padding:16px 28px;border-radius:var(--r-md);box-shadow:var(--shadow-l);
  font-size:14px;font-weight:800;z-index:3000}

/* empty / footer */
.empty-st{text-align:center;color:var(--text-3);padding:40px;font-size:14px;font-weight:600}
.footer{text-align:center;margin-top:28px;font-size:11px;font-weight:700;
  color:var(--text-3);letter-spacing:.03em;opacity:.4;padding-bottom:20px}

/* ---------- SYNC BADGE ---------- */
.sync-badge{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;
  background:rgba(34,197,94,.15);font-size:13px;border:1px solid rgba(34,197,94,.3);transition:.2s}
.sync-badge.err{background:rgba(239,68,68,.15);border-color:rgba(239,68,68,.3)}

/* ---------- OPEN NOW BADGE ---------- */
.open-badge{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:800;
  padding:2px 8px;border-radius:var(--r-pill);text-transform:uppercase;letter-spacing:.03em}
.open-badge.open{background:rgba(34,197,94,.12);color:#16a34a}
.open-badge.closed{background:rgba(239,68,68,.1);color:#ef4444}
.open-dot{width:6px;height:6px;border-radius:50%}
.open-badge.open .open-dot{background:#22c55e;box-shadow:0 0 4px rgba(34,197,94,.5)}
.open-badge.closed .open-dot{background:#ef4444}
.card-hours-row{display:flex;align-items:center;gap:8px;margin-top:2px}

/* ---------- SORT TOGGLE ---------- */
.sort-tog{display:flex;border-radius:var(--r-sm);overflow:hidden;border:1.5px solid var(--border);flex-shrink:0}
.sort-btn{font-family:var(--font);font-size:10px;font-weight:800;padding:3px 10px;border:none;
  cursor:pointer;background:transparent;color:var(--text-3);transition:.15s;text-transform:uppercase;letter-spacing:.02em}
.sort-btn.on{background:var(--accent);color:#fff}

/* ---------- DARK MODE TOGGLE ---------- */
.dark-tog{height:32px;padding:0 12px;border-radius:var(--r-pill);border:1.5px solid var(--border);background:var(--surface);
  cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:11.5px;font-weight:700;
  color:var(--text-2);transition:.2s;flex-shrink:0;white-space:nowrap}
.dark-tog:hover{border-color:var(--text-3)}

/* ---------- DEVICE BADGE ---------- */
.device-badge{display:flex;align-items:center;gap:4px;padding:3px 10px;border-radius:var(--r-pill);
  background:rgba(255,255,255,.1);color:rgba(255,255,255,.6);font-size:11px;font-weight:700;
  border:1px solid rgba(255,255,255,.12);white-space:nowrap;transition:.2s}
.device-label{font-size:10px;letter-spacing:.02em}

/* ---------- DEVICE-SPECIFIC LAYOUTS ---------- */
/* Phone: stacked, map on top, compact cards */
.main.device-phone{display:flex;flex-direction:column}
.device-phone .map-ct{height:32vh;min-height:180px}
.device-phone .card{padding:10px 12px;margin-bottom:6px}
.device-phone .card-icon-wrap{width:32px;height:32px;border-radius:8px}
.device-phone .card-icon-wrap svg{width:16px;height:16px}
.device-phone .card-name{font-size:14px}
.device-phone .card-walk{font-size:13px}
.device-phone .ctrl-strip{padding:6px 12px}
.device-phone .list-inner{padding:0 12px 80px}
.device-phone .hdr{padding:10px 12px 0}
.device-phone .hdr-title{font-size:19px}

/* Tablet: side-by-side, auto-collapse */
.main.device-tablet{display:grid;grid-template-columns:1fr 380px;min-height:0;transition:grid-template-columns .3s ease}
.main.device-tablet.panel-col{grid-template-columns:1fr 52px}
.main.device-tablet.no-map{grid-template-columns:1fr}
.device-tablet .map-ct{height:100%;min-height:unset}
.device-tablet .card{padding:11px 13px}
.device-tablet .list-inner{padding:0 16px 100px}

/* Desktop: side-by-side, auto-collapse */
.main.device-desktop{display:grid;grid-template-columns:1fr 380px;min-height:0;transition:grid-template-columns .3s ease}
.main.device-desktop.panel-col{grid-template-columns:1fr 52px}
.main.device-desktop.no-map{grid-template-columns:1fr}
.device-desktop .map-ct{height:100%;min-height:unset}
.device-desktop .card{padding:12px 14px}
.device-desktop .card:hover{transform:translateY(-1px)}
.device-desktop .list-inner{padding:0 20px 100px}

/* ---- Auto-collapse panel ---- */
.list-panel{transition:all .3s ease;overflow:hidden;position:relative}

.collapse-btn{width:28px;height:28px;border-radius:50%;
  background:var(--accent);border:2px solid #fff;cursor:pointer;
  display:flex;align-items:center;justify-content:center;font-size:11px;padding:0;
  box-shadow:var(--shadow-m);transition:.2s;color:#fff;font-weight:800;flex-shrink:0}
.collapse-btn:hover{transform:scale(1.15)}
.device-phone .collapse-btn{display:none}

/* Collapsed state: show only icons */
.panel-col .ctrl-strip{padding:4px;justify-content:center;display:flex!important}
.panel-col .ctrl-strip>*:not(.collapse-btn){display:none!important}
.panel-col .cat-hdr,
.panel-col .card-meta,
.panel-col .card-hours-row,
.panel-col .card-note,
.panel-col .card-acts,
.panel-col .vis-btn,
.panel-col .add-btn,
.panel-col .reset-btn,
.panel-col .footer,
.panel-col .empty-st,
.panel-col .card-name,
.panel-col .card-walk{display:none!important}
.panel-col .list-inner{padding:6px 4px 60px}
.panel-col .card{padding:8px 4px;margin-bottom:4px;border-left:none;display:flex;justify-content:center}
.panel-col .card::before{display:none}
.panel-col .card-top{justify-content:center;gap:0}
.panel-col .card-top>div:nth-child(2){display:none}
.panel-col .card-icon-wrap{margin-right:0;width:32px;height:32px;display:flex!important}

/* ========== DARK MODE ========== */
html.dark{
  --bg: #0f0d1a;
  --surface: #1a1726;
  --header-bg: #0a0816;
  --text-1: #e8e4f0;
  --text-2: #a99bbe;
  --text-3: #6b5a7e;
  --border: #2d2640;
  --accent: #f97316;
  --accent-light: rgba(249,115,22,.12);
  --danger: #ef4444;
  --success: #22c55e;
  --shadow-s: 0 2px 4px rgba(0,0,0,.2);
  --shadow-m: 0 4px 16px rgba(0,0,0,.3);
  --shadow-l: 0 8px 32px rgba(0,0,0,.4);
}
html.dark body{background:var(--bg)}
html.dark body::before{opacity:.12}
html.dark .hdr{background-image:linear-gradient(135deg, #0a0816 0%, #1a1040 50%, #2d1b4e 100%)}
html.dark .search-in{background:rgba(255,255,255,.06)}
html.dark .search-in:focus{background:rgba(255,255,255,.1)}
html.dark .card{border-color:var(--border)}
html.dark .form-in,html.dark .form-sel,html.dark .form-ta{background:var(--bg);border-color:var(--border);color:var(--text-1)}
html.dark .ctrl-strip{background:var(--surface);border-color:var(--border)}
html.dark .map-tog{background:var(--surface);border-color:var(--border);color:var(--text-2)}
html.dark .dark-tog{background:var(--surface);border-color:var(--border)}
html.dark .sort-tog{border-color:var(--border)}
html.dark .sort-btn{color:var(--text-3)}
html.dark .form-sheet{background:var(--surface)}
html.dark .leaflet-popup-content-wrapper{background:var(--surface)!important;color:var(--text-1)!important}
html.dark .open-badge.open{background:rgba(34,197,94,.15)}
html.dark .open-badge.closed{background:rgba(239,68,68,.15)}

/* ========== PRINT ========== */
@media print {
  .hdr,.ctrl-strip,.map-panel,.map-tog,.dark-tog,.sort-tog,.edit-btn,.vis-btn,.form-ov,.geo-ov,
  .add-btn,.reset-btn,.rad-ctl,.device-badge,.sync-badge,.lang-tog{display:none!important}
  #root{height:auto;overflow:visible}
  .main{display:block!important}
  .list-panel{overflow:visible!important}
  .list-inner{padding:0!important;max-width:none!important}
  .card{break-inside:avoid;border:1px solid #ccc!important;margin-bottom:4px!important;box-shadow:none!important;page-break-inside:avoid}
  .card::before{display:none}
  .card-icon-wrap{print-color-adjust:exact;-webkit-print-color-adjust:exact}
  .cat-hdr{break-after:avoid;page-break-after:avoid}
  body::before{display:none}
  body{background:#fff!important;color:#000!important}
  .footer{margin-top:10px}
}
