/* Medici BA/BAT — stile. Mobile-first, estetica medicale petrolio/health.
   Firma visiva: il sistema-orari (pill "aperto ora" + tabellone settimanale). */

/* ---------- font self-hosted ---------- */
@font-face{font-family:'Inter';font-style:normal;font-weight:400;font-display:swap;src:url('fonts/inter-400.woff2') format('woff2')}
@font-face{font-family:'Inter';font-style:normal;font-weight:500;font-display:swap;src:url('fonts/inter-500.woff2') format('woff2')}
@font-face{font-family:'Inter';font-style:normal;font-weight:600;font-display:swap;src:url('fonts/inter-600.woff2') format('woff2')}
@font-face{font-family:'Inter';font-style:normal;font-weight:700;font-display:swap;src:url('fonts/inter-700.woff2') format('woff2')}
@font-face{font-family:'Space Grotesk';font-style:normal;font-weight:500;font-display:swap;src:url('fonts/grotesk-500.woff2') format('woff2')}
@font-face{font-family:'Space Grotesk';font-style:normal;font-weight:600;font-display:swap;src:url('fonts/grotesk-600.woff2') format('woff2')}
@font-face{font-family:'Space Grotesk';font-style:normal;font-weight:700;font-display:swap;src:url('fonts/grotesk-700.woff2') format('woff2')}

:root{
  --paper:#F4F7F6; --surface:#FFFFFF; --surface-2:#EAF2F0; --mint:#E2EEEB;
  --ink:#0F231F; --ink-soft:#516460; --ink-faint:#8A9A96;
  --primary:#0E6F6C; --primary-ink:#0A5754; --primary-tint:#DCEBE9;
  --line:#DCE6E3; --line-soft:#E9F0EE;
  --open:#1E9D58; --open-bg:#E4F5EB;
  --soon:#C77A12; --soon-bg:#FBEFDC;
  --closed:#C24537; --closed-bg:#F9E6E3;
  --unknown:#75837F; --unknown-bg:#EDF1F0;
  --sans:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --display:'Space Grotesk','Inter',system-ui,sans-serif;
  --r-lg:16px; --r-md:12px; --r-sm:9px;
  --sh-1:0 1px 2px rgba(15,35,31,.05),0 1px 3px rgba(15,35,31,.04);
  --sh-2:0 4px 14px rgba(15,35,31,.08);
  --tap:44px; --maxw:640px;
  --safe-b:env(safe-area-inset-bottom,0px);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans); color:var(--ink); background:var(--paper);
  font-size:16px; line-height:1.45; -webkit-font-smoothing:antialiased;
  font-feature-settings:"cv05" 1; overscroll-behavior-y:none;
}
button{font-family:inherit;cursor:pointer}
a{color:var(--primary-ink);text-decoration:none}
:focus-visible{outline:2.5px solid var(--primary);outline-offset:2px;border-radius:6px}
.tnum{font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1}
.sr{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0)}

/* ---------- app shell ---------- */
#app{max-width:var(--maxw);margin:0 auto;min-height:100vh;min-height:100dvh;display:flex;flex-direction:column}
.appbar{
  position:sticky;top:0;z-index:30;background:rgba(244,247,246,.86);
  backdrop-filter:saturate(1.4) blur(10px);-webkit-backdrop-filter:saturate(1.4) blur(10px);
  border-bottom:1px solid var(--line);
}
.appbar__in{max-width:var(--maxw);margin:0 auto;padding:12px 16px 10px}
.brand{display:flex;align-items:center;gap:10px}
.brand__mark{width:30px;height:30px;flex:0 0 auto}
.brand__txt{display:flex;flex-direction:column;line-height:1.05}
.brand__name{font-family:var(--display);font-weight:700;font-size:19px;letter-spacing:-.02em;color:var(--ink)}
.brand__sub{font-size:11.5px;color:var(--ink-soft);font-weight:500;letter-spacing:.01em}
.brand__count{margin-left:auto;font-size:11px;color:var(--primary-ink);background:var(--primary-tint);
  padding:4px 9px;border-radius:20px;font-weight:600;white-space:nowrap}

/* ---------- search + filtri ---------- */
.controls{padding:12px 16px 6px}
.search{position:relative;display:flex;align-items:center}
.search svg{position:absolute;left:14px;width:19px;height:19px;color:var(--ink-faint);pointer-events:none}
.search input{
  width:100%;height:50px;padding:0 44px 0 42px;border:1.5px solid var(--line);
  border-radius:var(--r-md);background:var(--surface);font-size:16px;color:var(--ink);
  box-shadow:var(--sh-1);transition:border-color .15s,box-shadow .15s;
}
.search input::placeholder{color:var(--ink-faint)}
.search input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-tint)}
.search__clear{position:absolute;right:8px;width:34px;height:34px;border:0;background:transparent;
  color:var(--ink-faint);border-radius:8px;display:none;align-items:center;justify-content:center}
.search__clear.on{display:flex}

.chips{display:flex;gap:8px;overflow-x:auto;padding:12px 16px 12px;scrollbar-width:none;-webkit-overflow-scrolling:touch}
.chips::-webkit-scrollbar{display:none}
.chip{
  flex:0 0 auto;display:inline-flex;align-items:center;gap:6px;height:38px;padding:0 14px;
  border:1.5px solid var(--line);background:var(--surface);border-radius:20px;
  font-size:14px;font-weight:600;color:var(--ink-soft);white-space:nowrap;box-shadow:var(--sh-1);
}
.chip svg{width:16px;height:16px}
.chip.on{background:var(--primary);border-color:var(--primary);color:#fff}
.chip.on .chip__x{opacity:.85}
.chip__dot{width:7px;height:7px;border-radius:50%;background:var(--open)}
.chip select{appearance:none;border:0;background:transparent;font:inherit;color:inherit;padding:0;max-width:46vw}
.chip.sel{padding-right:12px}
.chip.sel::after{content:'';width:9px;height:9px;margin-left:2px;
  background:no-repeat center/contain url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'%3E%3Cpath d='M2 4l4 4 4-4' stroke='%23516460' stroke-width='2' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E")}
.chip.sel.on::after{filter:brightness(3)}

/* ---------- segmented Elenco | Mappa ---------- */
.seg{display:flex;gap:4px;margin:0 16px 8px;background:var(--surface-2);padding:4px;border-radius:12px}
.seg button{flex:1;height:40px;border:0;background:transparent;border-radius:9px;font-size:14.5px;
  font-weight:600;color:var(--ink-soft);display:flex;align-items:center;justify-content:center;gap:7px}
.seg button svg{width:17px;height:17px}
.seg button.on{background:var(--surface);color:var(--primary-ink);box-shadow:var(--sh-1)}

/* ---------- main / lista ---------- */
main{flex:1 1 auto;position:relative}
.view{padding:6px 16px calc(28px + var(--safe-b))}
.resline{font-size:12.5px;color:var(--ink-soft);font-weight:500;padding:4px 2px 10px}
.list{display:flex;flex-direction:column;gap:10px}

.card{
  display:block;width:100%;text-align:left;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--r-lg);padding:14px 14px;box-shadow:var(--sh-1);
  transition:transform .08s ease,box-shadow .15s;color:inherit;
}
.card:active{transform:scale(.988)}
.card__top{display:flex;align-items:flex-start;gap:10px}
.card__name{font-family:var(--display);font-weight:600;font-size:17px;letter-spacing:-.01em;line-height:1.2;color:var(--ink)}
.card__meta{margin-top:3px;font-size:13px;color:var(--ink-soft);display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.card__addr{margin-top:9px;font-size:13px;color:var(--ink-soft);display:flex;gap:7px;align-items:flex-start}
.card__addr svg{width:15px;height:15px;flex:0 0 auto;margin-top:2px;color:var(--ink-faint)}
.card__dist{margin-left:auto;flex:0 0 auto;font-size:12.5px;font-weight:700;color:var(--primary-ink);
  background:var(--primary-tint);padding:3px 8px;border-radius:8px;white-space:nowrap}
.prov{font-size:10.5px;font-weight:700;letter-spacing:.03em;color:var(--ink-faint);
  border:1px solid var(--line);border-radius:5px;padding:1px 5px}

/* ---------- pill orari (firma) ---------- */
.pill{display:inline-flex;align-items:center;gap:7px;padding:5px 11px 5px 9px;border-radius:20px;
  font-size:12.5px;font-weight:600;white-space:nowrap;line-height:1.1}
.pill__dot{width:8px;height:8px;border-radius:50%;flex:0 0 auto;position:relative}
.pill b{font-weight:700}
.pill .sub{font-weight:500;opacity:.9}
.pill--open{background:var(--open-bg);color:#0d6b38}
.pill--open .pill__dot{background:var(--open)}
.pill--open .pill__dot::after{content:'';position:absolute;inset:-4px;border-radius:50%;
  background:var(--open);opacity:.35;animation:ping 1.8s ease-out infinite}
.pill--soon{background:var(--soon-bg);color:#8a530a}
.pill--soon .pill__dot{background:var(--soon)}
.pill--closed{background:var(--closed-bg);color:#96271b}
.pill--closed .pill__dot{background:var(--closed)}
.pill--unknown{background:var(--unknown-bg);color:var(--unknown)}
.pill--unknown .pill__dot{background:var(--unknown)}
.card .pill{margin-top:11px}
@keyframes ping{0%{transform:scale(1);opacity:.35}80%,100%{transform:scale(2.1);opacity:0}}

/* ---------- empty / loading ---------- */
.empty{text-align:center;padding:60px 24px;color:var(--ink-soft)}
.empty svg{width:46px;height:46px;color:var(--ink-faint);margin-bottom:12px}
.empty h3{font-family:var(--display);font-weight:600;font-size:18px;color:var(--ink);margin:0 0 6px}
.empty p{margin:0;font-size:14px}
.skel{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);height:104px;
  box-shadow:var(--sh-1);overflow:hidden;position:relative}
.skel::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(14,111,108,.06),transparent);
  transform:translateX(-100%);animation:shimmer 1.3s infinite}
@keyframes shimmer{100%{transform:translateX(100%)}}

/* ---------- dettaglio ---------- */
.detail{padding-bottom:calc(32px + var(--safe-b))}
.dhead{padding:8px 16px 16px}
.back{display:inline-flex;align-items:center;gap:6px;height:38px;padding:0 12px 0 8px;margin:6px 0 10px;
  border:1px solid var(--line);background:var(--surface);border-radius:20px;font-size:14px;font-weight:600;color:var(--ink-soft);box-shadow:var(--sh-1)}
.back svg{width:18px;height:18px}
.dname{font-family:var(--display);font-weight:700;font-size:25px;letter-spacing:-.02em;line-height:1.12;color:var(--ink);margin:2px 0 8px}
.dmeta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:13.5px;color:var(--ink-soft)}
.dmeta svg{width:15px;height:15px;flex:0 0 auto}
.dmeta .prov{font-size:11px}

.section{margin:16px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-1);overflow:hidden}
.section__h{font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-faint);padding:14px 16px 0}
.rows{padding:8px 16px 14px}
.row{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--line-soft)}
.row:last-child{border-bottom:0}
.row__ic{width:38px;height:38px;flex:0 0 auto;border-radius:10px;background:var(--mint);color:var(--primary-ink);display:flex;align-items:center;justify-content:center}
.row__ic svg{width:19px;height:19px}
.row__main{min-width:0;flex:1}
.row__k{font-size:11.5px;color:var(--ink-faint);font-weight:600}
.row__v{font-size:15px;color:var(--ink);font-weight:500;word-break:break-word}
.row a.row__v{color:var(--primary-ink);font-weight:600}
.row__go{margin-left:auto;color:var(--primary);flex:0 0 auto}
.row__go svg{width:20px;height:20px}

.callbtn{display:inline-flex;align-items:center;gap:8px;height:42px;padding:0 16px;border-radius:11px;
  background:var(--primary);color:#fff;font-weight:600;font-size:15px;border:0;box-shadow:var(--sh-1)}
.callbtn svg{width:18px;height:18px}
.callrow{display:flex;gap:8px;flex-wrap:wrap;padding:6px 16px 16px}
.callbtn--ghost{background:var(--surface);color:var(--primary-ink);border:1.5px solid var(--primary-tint)}

/* status grande nel dettaglio */
.dstatus{margin:16px 16px 0;border-radius:var(--r-lg);padding:16px;display:flex;align-items:center;gap:14px;border:1px solid transparent}
.dstatus--open{background:var(--open-bg);border-color:#bfe6cd}
.dstatus--soon{background:var(--soon-bg);border-color:#f0dcb4}
.dstatus--closed{background:var(--closed-bg);border-color:#f0cdc7}
.dstatus--unknown{background:var(--unknown-bg);border-color:var(--line)}
.dstatus__big{width:46px;height:46px;border-radius:50%;flex:0 0 auto;display:flex;align-items:center;justify-content:center}
.dstatus__big svg{width:24px;height:24px;color:#fff}
.dstatus--open .dstatus__big{background:var(--open)} .dstatus--soon .dstatus__big{background:var(--soon)}
.dstatus--closed .dstatus__big{background:var(--closed)} .dstatus--unknown .dstatus__big{background:var(--unknown)}
.dstatus__t{font-family:var(--display);font-weight:700;font-size:18px;line-height:1.1;color:var(--ink)}
.dstatus__s{font-size:13.5px;color:var(--ink-soft);margin-top:2px}

/* ---------- tabellone settimanale (griglia) ---------- */
.week{padding:6px 12px 14px}
.wday{display:flex;align-items:center;gap:10px;padding:9px 6px;border-radius:10px}
.wday--today{background:var(--mint)}
.wday__d{width:42px;flex:0 0 auto;font-size:13px;font-weight:700;color:var(--ink-soft)}
.wday--today .wday__d{color:var(--primary-ink)}
.wday__slots{display:flex;gap:6px;flex-wrap:wrap;flex:1}
.slot{font-size:12.5px;font-weight:600;color:var(--primary-ink);background:var(--primary-tint);
  border-radius:7px;padding:3px 9px}
.slot--am{background:#eaf3f2}
.wclosed{font-size:12.5px;color:var(--ink-faint);font-weight:500}
.wtoday-tag{margin-left:auto;font-size:10px;font-weight:700;letter-spacing:.04em;color:var(--primary-ink);text-transform:uppercase}

/* ---------- timeline giornaliera ---------- */
.timeline{padding:4px 16px 18px}
.tl-legend{display:flex;justify-content:space-between;font-size:10px;color:var(--ink-faint);font-weight:600;
  padding:0 2px 4px;font-variant-numeric:tabular-nums}
.tl-row{display:flex;align-items:center;gap:8px;margin:5px 0}
.tl-row__d{width:34px;flex:0 0 auto;font-size:11.5px;font-weight:700;color:var(--ink-soft)}
.tl-track{position:relative;flex:1;height:16px;background:var(--surface-2);border-radius:5px;overflow:hidden}
.tl-seg{position:absolute;top:0;bottom:0;background:var(--primary);border-radius:4px;opacity:.9}
.tl-seg--am{background:#4F9E9B}
.tl-now{position:absolute;top:-2px;bottom:-2px;width:2px;background:var(--closed);z-index:2}
.tl-now::after{content:'';position:absolute;top:-3px;left:-2px;width:6px;height:6px;border-radius:50%;background:var(--closed)}
.tl-row--today .tl-track{box-shadow:0 0 0 1.5px var(--primary-tint)}

/* ---------- note / avvisi ---------- */
.note{margin:14px 16px 0;font-size:13px;color:var(--ink-soft);background:var(--surface-2);border-radius:10px;padding:11px 13px;display:flex;gap:9px}
.note svg{width:17px;height:17px;flex:0 0 auto;color:var(--soon);margin-top:1px}
.note--geo svg{color:var(--soon)}

/* mini-mappa dettaglio */
.minimap{height:180px;margin:0;border-top:1px solid var(--line)}

/* ---------- mappa full ---------- */
.mapwrap{position:relative;width:100%;min-height:320px}
#leafmap{position:absolute;inset:0}
.map-fab{position:absolute;right:14px;bottom:calc(20px + var(--safe-b));z-index:500;width:52px;height:52px;border-radius:50%;
  background:var(--surface);border:1px solid var(--line);box-shadow:var(--sh-2);display:flex;align-items:center;justify-content:center;color:var(--primary)}
.map-fab svg{width:24px;height:24px}
.map-fab.loading{color:var(--ink-faint)}
.leaflet-popup-content-wrapper{border-radius:12px;box-shadow:var(--sh-2)}
.leaflet-popup-content{margin:12px 14px;font-family:var(--sans)}
.pop__name{font-family:var(--display);font-weight:600;font-size:15px;color:var(--ink);line-height:1.2}
.pop__meta{font-size:12.5px;color:var(--ink-soft);margin:3px 0 8px}
.pop__go{display:inline-flex;align-items:center;gap:5px;font-weight:700;font-size:13px;color:var(--primary-ink)}
.pop__go svg{width:14px;height:14px;flex:0 0 auto}
.marker-dot{border-radius:50%;border:2.5px solid #fff;box-shadow:0 1px 4px rgba(0,0,0,.35)}

/* ---------- toast ---------- */
.toast{position:fixed;left:50%;transform:translateX(-50%) translateY(20px);bottom:calc(22px + var(--safe-b));
  z-index:900;background:var(--ink);color:#fff;padding:11px 16px;border-radius:22px;font-size:13.5px;font-weight:500;
  box-shadow:var(--sh-2);opacity:0;pointer-events:none;transition:opacity .25s,transform .25s;max-width:88vw;display:flex;align-items:center;gap:9px}
.toast.on{opacity:1;transform:translateX(-50%) translateY(0)}
.toast svg{width:17px;height:17px;color:#68d99a}

/* ---------- responsive: tablet / foldable / desktop ---------- */
/* la lista diventa una griglia auto-riempita: 1 col su telefono, fino a più colonne
   su schermi ampi (foldable aperto, tablet). La shell si allarga progressivamente. */
@media (min-width:560px){
  .list{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px}
  .card__addr{min-height:0}
  .minimap{height:220px}
}
@media (min-width:820px){
  :root{--maxw:1120px}
  #app{box-shadow:0 0 0 1px var(--line)}
  /* i controlli restano a misura leggibile, la lista/mappa usano tutta la larghezza */
  .controls,.chips{max-width:860px}
  .seg{max-width:360px}
  .search input{max-width:640px}
  .view{padding-left:20px;padding-right:20px}
  .minimap{height:300px}
  /* dettaglio: colonna di lettura comoda + posizione a piena larghezza */
  .detail{max-width:1120px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;
    column-gap:20px;align-items:start;padding:0 20px}
  .detail>.dhead,.detail>.dstatus,.detail>.callrow,.detail>.note{grid-column:1 / -1}
  .detail>.section:last-child{grid-column:1 / -1}
  .detail>.section{margin-left:0;margin-right:0}
  .detail>.dstatus{margin-left:0;margin-right:0}
  .detail>.note{margin-left:0;margin-right:0}
  .dhead{padding-left:0;padding-right:0}
  .callrow{padding-left:0;padding-right:0}
}
@media (min-width:1180px){
  :root{--maxw:1280px}
}
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;transition-duration:.001ms!important}
  .pill--open .pill__dot::after{display:none}
}
