/* PescApp — design system (light default per uso al sole; dark opzionale).
   Filosofia: una domanda, una risposta, leggibile in mezzo secondo con una mano.
   Sistema: scala spaziatura 8pt, scala tipografica modulare, card coerenti, gerarchia forte. */
:root{
  /* colore */
  --bg:#ECF1F6; --card:#FFFFFF; --txt:#0F1B2D; --dim:#54657A; --line:#dde5ec;
  --accent:#0C6BA8; --navy:#083B5C; --teal:#14A0A0; --cta:#FF6B35; --ring:#e6edf3;
  --scarso:#D55E00; --mediocre:#E69F00; --buono:#14A0A0; --ottimo:#009E73;
  /* spaziatura (8pt) */
  --s1:4px; --s2:8px; --s3:12px; --s4:16px; --s5:24px; --s6:32px;
  /* tipografia */
  --t-xs:12px; --t-sm:13px; --t-base:15px; --t-md:17px; --t-lg:20px; --t-xl:27px;
  /* forma */
  --r-sm:8px; --r:12px; --r-lg:16px; --r-pill:999px;
  --shadow:0 1px 2px rgba(15,27,45,.04),0 6px 18px rgba(15,27,45,.07);
  --shadow-sm:0 1px 2px rgba(15,27,45,.06);
}
[data-theme=dark]{
  --bg:#0B1622; --card:#14202E; --txt:#E8EEF2; --dim:#9fb0bf; --line:#26323f; --ring:#26323f;
  --shadow:0 1px 2px rgba(0,0,0,.3),0 6px 18px rgba(0,0,0,.4); --shadow-sm:0 1px 3px rgba(0,0,0,.4);
}
*{box-sizing:border-box}
:focus-visible{outline:3px solid var(--accent);outline-offset:2px;border-radius:6px}
@media (prefers-reduced-motion: reduce){*{animation-duration:.01ms!important;transition-duration:.01ms!important}}
body{margin:0;background:var(--bg);color:var(--txt);
  font:15px/1.55 -apple-system,BlinkMacSystemFont,"Segoe UI",Inter,Roboto,sans-serif;-webkit-font-smoothing:antialiased}

/* header */
header{padding:var(--s3) var(--s4) var(--s3);border-bottom:1px solid var(--line);background:var(--card);position:sticky;top:0;z-index:500}
.hbar{display:flex;align-items:center;justify-content:space-between;max-width:860px;margin:0 auto}
header h1{margin:0;font-size:var(--t-lg);font-weight:800;letter-spacing:-.3px}
#theme{background:transparent;border:1px solid var(--line);border-radius:50%;width:38px;height:38px;font-size:16px;cursor:pointer;line-height:1}
.nav{display:flex;gap:var(--s2);margin:var(--s3) auto 0;max-width:860px;flex-wrap:wrap}
.nav a{flex:1;text-align:center;color:var(--dim);text-decoration:none;font-size:var(--t-sm);font-weight:600;
  padding:9px 12px;border:1px solid var(--line);border-radius:var(--r-pill);background:var(--bg)}
.nav a.active{background:var(--accent);border-color:var(--accent);color:#fff}

main{max-width:860px;margin:0 auto;padding:var(--s4) var(--s4) 90px}
h2{font-size:var(--t-md);margin:0 0 var(--s3);font-weight:700;letter-spacing:-.2px}

/* pannello input (search+mappa+legenda+controlli) = un blocco coeso */
.panel{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:var(--s4);margin-bottom:var(--s4);box-shadow:var(--shadow)}
.search{display:flex;gap:var(--s2);margin-bottom:var(--s3)}
.search input{flex:1;background:var(--bg);border:1px solid var(--line);color:var(--txt);border-radius:var(--r);padding:12px 14px;font-size:var(--t-base)}
.search button{background:var(--accent);border:none;color:#fff;border-radius:var(--r);padding:0 18px;min-height:48px;font-size:var(--t-base);font-weight:600;cursor:pointer}
#gps.on{background:var(--ottimo)}

/* riga navigazione spot (coordinate + rotta + distanza) */
.spotnav{color:var(--dim);font-size:var(--t-sm);margin:var(--s3) 0 0;line-height:1.7}
.spotnav b{color:var(--txt);font-weight:600}
.spotnav a{color:var(--accent);font-weight:600}
#map{height:300px;border-radius:var(--r);border:1px solid var(--line);background:#0a0e14;z-index:0}
.maphint{color:var(--dim);font-size:var(--t-sm);margin:var(--s2) 0 var(--s3);text-align:center}
.leaflet-container{font:13px -apple-system,sans-serif}

/* legenda mappa: collassabile per non rubare spazio prima del click */
.maplegend-wrap{margin:0 0 var(--s3)}
.maplegend-wrap > summary{cursor:pointer;color:var(--accent);font-weight:600;font-size:var(--t-sm);
  padding:8px 10px;list-style:none;background:var(--bg);border:1px solid var(--line);border-radius:var(--r-sm)}
.maplegend-wrap > summary::-webkit-details-marker{display:none}
.maplegend-wrap > summary::before{content:'▸ '}
.maplegend-wrap[open] > summary::before{content:'▾ '}

/* controlli raggruppati ed etichettati (niente muro-di-chip) */
.controls{display:flex;flex-direction:column;gap:var(--s3);margin-top:var(--s2)}
.ctl{display:flex;flex-direction:column;gap:var(--s2)}
.ctl-l{font-size:var(--t-xs);font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--dim)}
.row{display:flex;gap:var(--s2);flex-wrap:wrap;align-items:center}
.chip{background:var(--bg);color:var(--txt);border:1px solid var(--line);border-radius:var(--r-pill);
  min-height:42px;padding:8px 15px;font-size:var(--t-sm);cursor:pointer}
.chip.active{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:600}
.chip.myspot{border-color:var(--mediocre)}
.chip .del{margin-left:6px;opacity:.6;font-size:12px}
.chip .del:hover{opacity:1;color:var(--scarso)}
.checks{gap:var(--s3)}
.bait{display:flex;align-items:center;gap:var(--s2);color:var(--txt);font-size:var(--t-sm);min-height:42px}
.bait input{width:20px;height:20px}
/* interruttore "tipo d'acqua" (fiume) ben visibile */
.watertoggle{display:flex;align-items:center;gap:var(--s2);cursor:pointer;background:var(--bg);
  border:1px solid var(--line);border-radius:var(--r);padding:11px 14px;font-size:var(--t-base);min-height:48px}
.watertoggle input{width:22px;height:22px}
.watertoggle span{color:var(--dim);font-size:var(--t-sm)}
.watertoggle:has(input:checked){border-color:var(--teal);background:rgba(20,160,160,.08)}
select{background:var(--bg);border:1px solid var(--line);color:var(--txt);border-radius:var(--r);padding:11px 13px;font-size:var(--t-base);min-height:48px}

/* VERDETTO eroe */
#verdict{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:var(--s5) var(--s4);margin-bottom:var(--s4);box-shadow:var(--shadow)}
.hero{display:flex;align-items:center;gap:var(--s5);border-radius:var(--r);padding:var(--s2);
  background:linear-gradient(135deg, color-mix(in srgb, var(--glow, transparent) 9%, transparent), transparent 65%)}
.gauge{width:104px;height:104px;flex:0 0 104px;border-radius:50%;display:grid;place-items:center;
  background:conic-gradient(var(--c) calc(var(--p)*3.6deg), var(--ring) 0)}
.gauge .score{width:82px;height:82px;border-radius:50%;background:var(--card);display:grid;place-items:center;
  font-size:36px;font-weight:800;color:var(--txt)}
.verdict-label{font-size:var(--t-xl);font-weight:800;letter-spacing:-.3px;line-height:1.05}
.ottimale{display:inline-block;background:var(--cta);color:#fff;font-size:11px;font-weight:700;
  border-radius:6px;padding:2px 7px;vertical-align:middle;margin-left:6px;animation:vai 1.6s ease-in-out infinite}
@keyframes vai{0%,100%{transform:scale(1)}50%{transform:scale(1.1)}}
.hero-sp{color:var(--dim);font-size:var(--t-sm);margin:var(--s1) 0 var(--s3)}
.hero-pills{display:flex;gap:var(--s2);flex-wrap:wrap}
.pill{display:inline-flex;align-items:center;border-radius:var(--r-pill);padding:7px 13px;font-size:var(--t-sm);font-weight:600;
  background:var(--bg);border:1px solid var(--line)}
.pill.teal{color:var(--teal);border-color:var(--teal)}
.pill.onshore{color:var(--ottimo);border-color:var(--ottimo)}
.pill.laterale{color:var(--accent);border-color:var(--accent)}
.pill.offshore{color:var(--mediocre);border-color:var(--mediocre)}
.technote{margin-top:var(--s3);background:#fff4e6;border:1px solid var(--cta);color:#8a3a10;border-radius:var(--r);padding:10px 13px;font-size:var(--t-sm)}
[data-theme=dark] .technote{background:#3a2410;color:#ffcaa0}
.drivers{display:flex;gap:var(--s2);margin-top:var(--s4)}
@media (max-width:480px){.drivers{display:grid;grid-template-columns:repeat(2,1fr)}}
.dchip{flex:1;background:var(--bg);border:1px solid var(--line);border-radius:var(--r);padding:10px 11px;text-align:center}
.dchip span{display:block;color:var(--dim);font-size:var(--t-xs);margin-bottom:2px}
.dchip b{font-size:var(--t-md)}

/* striscia meteo orario del giorno (sotto i driver del verdetto) */
.wxstrip{display:flex;gap:var(--s1);margin-top:var(--s2);overflow-x:auto}
.wxh{flex:1;min-width:44px;text-align:center;background:var(--bg);border:1px solid var(--line);border-radius:var(--r-sm);padding:5px 2px}
.wxh span{display:block;color:var(--dim);font-size:var(--t-xs)}
.wxh div{font-size:15px;line-height:1.3}
.wxh b{font-size:var(--t-xs);color:var(--txt)}
.wxh.now{border-color:var(--accent);box-shadow:inset 0 0 0 1px var(--accent)}

/* timeline oraria interattiva (score per ora nel verdetto) */
.tl{margin-top:var(--s3)}
.tlmarks{position:relative;height:18px;font-size:12px}
.tlmark{position:absolute;transform:translateX(-50%);line-height:18px}
.tlnow{position:absolute;bottom:0;width:2px;height:7px;background:var(--txt);transform:translateX(-50%);border-radius:1px}
.tlbar{display:flex;height:18px;border-radius:9px;overflow:hidden;gap:1px;background:var(--ring)}
.tlseg{flex:1;display:block;cursor:pointer;transition:opacity .12s,transform .12s;min-width:0}
.tlseg.win{box-shadow:inset 0 -4px 0 rgba(0,0,0,.35)}
.tlseg:hover{opacity:1!important;transform:scaleY(1.25)}
.tlaxis{display:flex;justify-content:space-between;color:var(--dim);font-size:var(--t-xs);margin-top:3px}
.tlout{color:var(--dim);font-size:var(--t-xs);margin-top:4px;min-height:16px}

/* skeleton di caricamento */
.skel{background:linear-gradient(90deg,var(--line) 25%,var(--ring) 50%,var(--line) 75%);background-size:200% 100%;
  animation:shimmer 1.1s linear infinite;border-radius:var(--r-sm)}
@keyframes shimmer{to{background-position:-200% 0}}
.skel-circle{width:104px;height:104px;flex:0 0 104px;border-radius:50%}
.skel-lines{flex:1;display:flex;flex-direction:column;gap:12px}
.skel-line{height:15px}.skel-line.w40{width:40%}.skel-line.w55{width:55%}.skel-line.w70{width:70%}
.skel-card{height:110px;border-radius:var(--r)}

/* micro-interazioni */
.chip,.pill,.cmprow,.preso,.save,.search button{transition:transform .08s ease,border-color .15s ease,box-shadow .15s ease}
.chip:hover{border-color:var(--accent)}
.chip:active,.pill:active,.cmprow:active,.preso:active,.save:active{transform:scale(.97)}
.cmprow:hover{border-color:var(--accent);box-shadow:var(--shadow-sm)}

/* ingresso morbido dei risultati */
@keyframes fadeUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.results>*{animation:fadeUp .28s ease both}
.results>*:nth-child(3){animation-delay:.03s}
.results>*:nth-child(4){animation-delay:.06s}
.results>*:nth-child(5){animation-delay:.09s}
.results>*:nth-child(6){animation-delay:.12s}
.results>*:nth-child(n+7){animation-delay:.15s}

/* confronto spot salvati */
#compare:not(:empty){background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:var(--s4);margin-bottom:var(--s4);box-shadow:var(--shadow)}
#compare h2{display:flex;justify-content:space-between;align-items:center}
#compare .mini,#side .spotnav .mini{font-size:var(--t-xs);padding:2px 8px;min-height:0;border:1px solid var(--line);border-radius:var(--r-pill);background:var(--bg);color:var(--txt);font-weight:600;cursor:pointer}
.cmprow{display:flex;align-items:center;gap:var(--s2);width:100%;text-align:left;background:var(--bg);border:1px solid var(--line);border-radius:var(--r);padding:9px 12px;margin-top:var(--s2);cursor:pointer;color:var(--txt);font-size:var(--t-sm);font-family:inherit}
.cmprow .rank{color:var(--dim);font-weight:700;min-width:14px}
.cmprow b{font-size:var(--t-base)}
.cmprow .cmpinfo{margin-left:auto;color:var(--dim);text-align:right;font-size:var(--t-xs)}
.chip.cmpbtn{border-style:dashed;color:var(--accent);font-weight:700}
.chip.tool{color:var(--dim);display:inline-flex;align-items:center;cursor:pointer}

/* card generiche (tutte le sezioni risultato) */
.card,#conditions,#side,#species,#diario,#solunar,#pressure,#week{background:var(--card);border:1px solid var(--line);
  border-radius:var(--r-lg);padding:var(--s4);margin-bottom:var(--s4);box-shadow:var(--shadow)}
.note{color:var(--dim);font-size:var(--t-xs);margin:var(--s3) 0 0;line-height:1.5}
#conditions .grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0 var(--s5)}
#conditions .grid div{display:flex;justify-content:space-between;border-bottom:1px solid var(--line);padding:9px 0}
#conditions .grid span{color:var(--dim)}
#conditions .grid b{font-weight:700}
#side p{margin:0 0 var(--s2);line-height:1.55}
#side .onshore{color:var(--ottimo)}#side .laterale{color:var(--accent)}#side .offshore{color:var(--mediocre)}
#side button{background:var(--cta);border:none;color:#fff;border-radius:var(--r);padding:11px 16px;
  min-height:48px;font-size:var(--t-sm);font-weight:600;cursor:pointer}
#pressure p,#solunar p{margin:var(--s2) 0}
.lvl{font-weight:700}
.lvl.alto{color:var(--scarso)}.lvl.medio{color:var(--mediocre)}.lvl.basso{color:var(--ottimo)}

/* accordion dettagli avanzati */
details#adv{margin-bottom:var(--s4)}
details#adv > summary{cursor:pointer;color:var(--accent);font-weight:600;font-size:var(--t-sm);
  padding:12px var(--s4);list-style:none;background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-sm)}
details#adv[open] > summary{border-radius:var(--r-lg) var(--r-lg) 0 0;margin-bottom:0}
details#adv > summary::-webkit-details-marker{display:none}
details#adv > summary::before{content:'▸ '}
details#adv[open] > summary::before{content:'▾ '}

/* lista specie */
.badge{display:inline-flex;align-items:center;justify-content:center;min-width:44px;height:44px;border-radius:var(--r);
  font-weight:800;font-size:var(--t-md);color:#fff;margin-right:var(--s3)}
.sp{border-top:1px solid var(--line);padding:var(--s3) 0}
.sp:first-of-type{border-top:none;padding-top:var(--s1)}
.sp-head{display:flex;align-items:center}
.sp-head strong{font-size:var(--t-base)}
.sp-head em{color:var(--dim);font-style:italic;font-size:var(--t-xs)}
.sp-body{margin:var(--s2) 0 0 56px;display:flex;flex-direction:column;gap:6px;font-size:var(--t-sm)}
.lures{display:flex;flex-direction:column;gap:6px}
.lure{padding:6px 0;border-bottom:1px solid var(--line)}
.lure:last-child{border-bottom:none}
.lure .why{color:var(--dim);font-size:var(--t-xs)}
.lure .mod{color:var(--accent);font-size:var(--t-xs);margin-top:1px}
.how{color:var(--navy);font-size:var(--t-xs);margin-top:var(--s1);background:var(--bg);border-radius:var(--r-sm);padding:7px 10px}
.tnote{color:var(--mediocre);font-size:var(--t-xs);margin-top:3px}
[data-theme=dark] .how{color:#9ecbff}
#safety{background:#fdeceb;border:1px solid var(--scarso);color:#7a2410;border-radius:var(--r-lg);padding:var(--s3) var(--s4);margin-bottom:var(--s4);font-size:var(--t-sm)}
[data-theme=dark] #safety{background:#3a1410;color:#ffb3a0}
#week a{color:var(--accent);font-weight:600}
.insight{background:var(--bg);border-left:3px solid var(--teal);border-radius:var(--r-sm);padding:9px 12px;font-size:var(--t-sm);margin:0 0 var(--s2)}
.cons{font-size:10px;border-radius:4px;padding:1px 6px;text-transform:uppercase;letter-spacing:.4px;vertical-align:middle;color:#fff}
.cons.alto{background:var(--ottimo)}.cons.medio{background:var(--mediocre)}.cons.basso{background:var(--dim)}
.off{background:#fbeccb;color:#8a5a00;border-radius:5px;padding:1px 6px;font-size:11px;margin-left:6px}
.ev{background:var(--bg);color:var(--dim);border:1px solid var(--line);border-radius:5px;padding:1px 6px;font-size:11px;margin-left:4px}
.zone{border-radius:5px;padding:1px 6px;font-size:11px;margin-left:4px}
.zone.ok{background:#e3f4e8;color:#1a7a3a}
.zone.weak{background:#fff4e0;color:#9a6b1a}
.zone.no{background:var(--bg);color:var(--dim);border:1px dashed var(--line)}
[data-theme=dark] .zone.ok{background:#16331f;color:#3fb950}
[data-theme=dark] .zone.weak{background:#3a2e16;color:#e3b341}
.region{background:var(--bg);border-left:3px solid var(--accent);border-radius:var(--r-sm);padding:9px 12px;font-size:var(--t-sm);margin:0 0 var(--s2)}
[data-theme=dark] .off{background:#3d2a00;color:#e3b341}
.spark{display:flex;align-items:flex-end;gap:2px;height:42px;margin-top:var(--s1)}
.spark i{flex:1;border-radius:2px 2px 0 0;display:block}

/* diario di validazione */
.stars{font-size:30px;letter-spacing:4px;cursor:pointer;user-select:none}
.stars i{color:var(--line);font-style:normal}
.stars i.on{color:var(--mediocre)}
.preso{width:100%;background:var(--ottimo);border:none;color:#fff;border-radius:var(--r);padding:14px;
  font-size:var(--t-md);font-weight:800;cursor:pointer;margin:var(--s2) 0;min-height:54px;letter-spacing:.3px}
.preso:active{transform:scale(.99)}
.stamps{font-size:var(--t-sm);color:var(--dim);margin:0 0 var(--s2)}
.stamp{display:inline-block;background:var(--bg);border:1px solid var(--line);border-radius:var(--r-pill);padding:3px 10px;margin:2px 4px 2px 0;color:var(--txt)}
.stamp i{cursor:pointer;color:var(--scarso);font-style:normal;margin-left:4px;opacity:.7}
.stamp i:hover{opacity:1}
.recap{display:flex;flex-direction:column;gap:var(--s1);margin-top:var(--s2)}
.rc-l{font-size:var(--t-xs);font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--dim);margin-top:var(--s2)}
.picks{gap:6px}
.pick{background:var(--bg);border:1px solid var(--line);color:var(--txt);border-radius:var(--r-pill);padding:8px 13px;font-size:var(--t-sm);cursor:pointer;min-height:40px}
.pick.on{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:600}
.recap input[type=text]{background:var(--bg);border:1px solid var(--line);color:var(--txt);border-radius:var(--r);padding:11px;font-size:var(--t-base)}
.photobtn{display:inline-flex;align-items:center;gap:6px;background:var(--bg);border:1px solid var(--line);border-radius:var(--r);
  padding:10px 14px;font-size:var(--t-sm);cursor:pointer;min-height:44px;width:fit-content}
.photoprev{max-width:120px;max-height:120px;border-radius:var(--r-sm);margin-top:var(--s2);display:block;border:1px solid var(--line)}
.save{background:var(--cta);border:none;color:#fff;border-radius:var(--r);padding:13px;font-size:var(--t-base);font-weight:700;cursor:pointer;min-height:50px;margin-top:var(--s3)}
.diario-tools{display:flex;gap:var(--s2);margin-top:var(--s3);flex-wrap:wrap}
.diario-tools button,.impbtn{background:var(--bg);border:1px solid var(--line);color:var(--accent);border-radius:var(--r);
  padding:9px 13px;font-size:var(--t-sm);font-weight:600;cursor:pointer;min-height:42px;display:inline-flex;align-items:center}
.log{margin-top:var(--s3);font-size:var(--t-sm)}
.log .e{border-top:1px solid var(--line);padding:9px 0;color:var(--dim);display:flex;gap:var(--s2);align-items:flex-start}
.log .e b{color:var(--txt)}
.logthumb{width:44px;height:44px;border-radius:var(--r-sm);object-fit:cover;flex:0 0 44px;background:var(--bg);border:1px solid var(--line)}

/* ranking esche */
.rk{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:12px 14px;margin-bottom:var(--s2);box-shadow:var(--shadow-sm)}
.rk-h{display:flex;align-items:center;gap:var(--s2)}
.rk-h b{font-size:var(--t-base)}
.pos{display:inline-flex;align-items:center;justify-content:center;min-width:26px;height:26px;border-radius:7px;background:var(--accent);color:#fff;font-weight:700;font-size:var(--t-sm)}
.rk-why{color:var(--dim);font-size:var(--t-sm);margin:5px 0 0}
.mod{color:var(--accent);font-size:var(--t-xs);margin-top:2px}

#status{color:var(--dim);font-size:var(--t-sm);padding:var(--s2) 0}
#status code{background:var(--card);padding:1px 5px;border-radius:4px}
#offbar{display:none;position:fixed;left:0;right:0;bottom:0;z-index:1000;background:var(--mediocre);color:#3a2400;
  text-align:center;padding:10px 14px;font-size:var(--t-sm);font-weight:600;box-shadow:0 -2px 8px rgba(0,0,0,.15)}
footer{color:var(--dim);font-size:11px;text-align:center;padding:var(--s4) var(--s4) var(--s6);line-height:1.6;max-width:860px;margin:0 auto}
footer a{color:var(--dim)}

/* etichette permanenti sulle linee della mappa */
.leaflet-tooltip.mtip{font-size:11px;font-weight:700;padding:2px 6px;border:none;border-radius:5px;
  box-shadow:0 1px 4px rgba(0,0,0,.35);opacity:.97;white-space:nowrap}
.leaflet-tooltip.mtip::before{display:none}
.leaflet-tooltip.mtip.cast{background:#06b6d4;color:#04222a}
.leaflet-tooltip.mtip.stand{background:#0b3a66;color:#fff}
.leaflet-tooltip.mtip.sea{background:#0b3a66;color:#fff}
.leaflet-tooltip.mtip.wind.laterale{background:#1fbf57;color:#06270f}
.leaflet-tooltip.mtip.wind.onshore{background:#ff7a2f;color:#371400}
.leaflet-tooltip.mtip.wind.offshore{background:#9aa7b4;color:#16202b}

/* legenda mappa: come leggere le linee */
.maplegend{display:flex;flex-wrap:wrap;gap:var(--s2) var(--s4);align-items:center;font-size:var(--t-xs);color:var(--dim);
  margin:var(--s2) 0 0;padding:10px 12px;background:var(--bg);border:1px solid var(--line);border-radius:var(--r-sm)}
.maplegend .it{display:inline-flex;align-items:center;gap:6px}
.maplegend b{color:var(--txt)}
.maplegend .sw{display:inline-block;width:20px;height:4px;border-radius:2px}
.maplegend .sw.cast{background:#06b6d4;height:5px}
.maplegend .sw.lat{background:#1fbf57}.maplegend .sw.on{background:#ff7a2f}.maplegend .sw.off{background:#9aa7b4}
.maplegend .sw.sea{height:0;border:0;border-top:2px dashed #6b8bbf}
.maplegend .dot.stand{display:inline-block;width:11px;height:11px;border-radius:50%;background:#0b3a66;border:2px solid #fff;box-shadow:0 0 0 1px #0b3a66;vertical-align:middle}
.maplegend small{flex-basis:100%;color:var(--dim);line-height:1.5}

/* desktop: due colonne (input a sinistra, risultati a destra) */
@media (min-width:780px){
  .two-col{display:grid;grid-template-columns:minmax(320px,1fr) minmax(360px,1.15fr);gap:var(--s4);align-items:start}
  .two-col .input-panel{position:sticky;top:84px;margin-bottom:0}
  #map{height:340px}
}

/* striscia settimanale a colpo d'occhio (02/07) */
.weekstrip{display:flex;gap:6px;flex-wrap:wrap;margin:6px 0}
.wk{display:flex;flex-direction:column;align-items:center;gap:1px;min-width:52px;padding:6px 8px;
    border-radius:10px;border:2px solid transparent;background:var(--card);cursor:pointer}
.wk{background:color-mix(in srgb, var(--c) 16%, var(--card))}
.wk b{color:var(--c);font-size:16px}
.wk span{font-size:11px;opacity:.75}
.wk.on{border-color:var(--c)}
.wk:hover{filter:brightness(1.1)}
