/* ═══════════════════════════════════════════════════════
   CANTIERANDO — Stylesheet
   Separato da index.html per manutenibilità.
   ═══════════════════════════════════════════════════════ */

/* ══ VARIABILI — MODALITÀ GIORNO ══════════════════════════ */
:root{
  --amber:#C97B08;
  --amber-dark:#7C3F00;
  --amber-light:#FEF3C7;
  --amber-mid:#B86A00;
  --red:#B91C1C;
  --red-light:#FEE2E2;
  --green:#15803D;
  --green-light:#DCFCE7;
  --blue:#1D4ED8;
  --blue-light:#DBEAFE;
  --g50:#F9FAFB;--g100:#F3F4F6;--g200:#E5E7EB;--g300:#D1D5DB;
  --g400:#6B7280;
  --g500:#4B5563;
  --g600:#374151;
  --g700:#1F2937;
  --g800:#111827;--g900:#030712;
  --bg:#EFEBE3;--surface:#FFFFFF;--ink:#111827;
  --navy:#1a1a2e;--navy2:#16213e;
  --r:14px;--rs:9px;
  --sh:0 1px 4px rgba(0,0,0,.08),0 1px 2px rgba(0,0,0,.05);
  --shm:0 4px 12px rgba(0,0,0,.10),0 2px 4px rgba(0,0,0,.06);
  --ease-spring:cubic-bezier(.34,1.56,.64,1);
  --ease-out:cubic-bezier(.22,1,.36,1);
}

/* ══ VARIABILI — MODALITÀ NOTTE (sistema) ══════════════════ */
@media(prefers-color-scheme:dark){
  body:not(.light){
    --amber:#FFB830;--amber-dark:#FFD570;--amber-light:#2A1A00;--amber-mid:#FFC040;
    --red:#FF8080;--red-light:#2A0A0A;--green:#50E0A0;--green-light:#042010;
    --blue:#7EC8FF;--blue-light:#071525;
    --g50:#141720;--g100:#1C2030;--g200:#28304A;--g300:#3A4560;
    --g400:#8896B0;--g500:#A8B6CC;--g600:#C4CEDF;--g700:#DCE4EF;--g800:#EDF1F7;--g900:#F5F8FC;
    --bg:#0E1018;--surface:#1C2030;--ink:#E8EEF8;
    --navy:#DCE4EF;--navy2:#A8B6CC;
    --sh:0 1px 6px rgba(0,0,0,.5),0 1px 2px rgba(0,0,0,.35);
    --shm:0 4px 16px rgba(0,0,0,.6),0 2px 6px rgba(0,0,0,.4);
  }
}

/* ══ VARIABILI — MODALITÀ NOTTE (esplicita via body.dark) ══ */
body.dark{
  --amber:#FFB830;--amber-dark:#FFD570;--amber-light:#2A1A00;--amber-mid:#FFC040;
  --red:#FF8080;--red-light:#2A0A0A;--green:#50E0A0;--green-light:#042010;
  --blue:#7EC8FF;--blue-light:#071525;
  --g50:#141720;--g100:#1C2030;--g200:#28304A;--g300:#3A4560;
  --g400:#8896B0;--g500:#A8B6CC;--g600:#C4CEDF;--g700:#DCE4EF;--g800:#EDF1F7;--g900:#F5F8FC;
  --bg:#0E1018;--surface:#1C2030;--ink:#E8EEF8;
  --navy:#DCE4EF;--navy2:#A8B6CC;
  --sh:0 1px 6px rgba(0,0,0,.5),0 1px 2px rgba(0,0,0,.35);
  --shm:0 4px 16px rgba(0,0,0,.6),0 2px 6px rgba(0,0,0,.4);
}

/* ══ DARK — OVERRIDES STRUTTURALI (solo body.dark, no duplicati) ══ */
body.dark,body:not(.light){background:var(--bg);color:var(--ink);}
body.dark #map .leaflet-tile-pane,body:not(.light) #map .leaflet-tile-pane{filter:invert(.92) hue-rotate(180deg) brightness(.88) saturate(.8);}
body.dark .ms,body:not(.light) .ms{background:var(--surface)!important;}
body.dark input,body.dark textarea,body.dark select,
body:not(.light) input,body:not(.light) textarea,body:not(.light) select{
  background:var(--g100)!important;color:var(--ink)!important;border-color:var(--g300)!important;
}
body.dark .sc,body:not(.light) .sc,
body.dark .ic,body:not(.light) .ic,
body.dark .rc,body:not(.light) .rc,
body.dark .stepper-item,body:not(.light) .stepper-item{
  background:var(--surface)!important;border-color:var(--g200)!important;
}
body.dark header,body:not(.light) header,
body.dark nav,body:not(.light) nav,
body.dark .dtb,body:not(.light) .dtb{background:#0A0C14!important;}
body.dark .chat-tabs,body:not(.light) .chat-tabs,
body.dark .chat-input-wrap,body:not(.light) .chat-input-wrap{background:var(--surface)!important;border-color:var(--g200)!important;}
body.dark .logo,body:not(.light) .logo{color:var(--amber);}
body.dark .br,body:not(.light) .br{background:#3A0A0A;color:#FF8080;border:1px solid #5A1A1A;}
body.dark .ba,body:not(.light) .ba{background:#2A1800;color:#FFB830;border:1px solid #4A3000;}
body.dark .bg-g,body:not(.light) .bg-g{background:#042010;color:#50E0A0;border:1px solid #0A3020;}
body.dark .bg-gr,body:not(.light) .bg-gr{background:var(--g100);color:var(--g600);border:1px solid var(--g200);}
body.dark .bg-b,body:not(.light) .bg-b{background:#071525;color:#7EC8FF;border:1px solid #0E2540;}
body.dark .mf-chip,body:not(.light) .mf-chip{background:rgba(28,32,48,.92);color:var(--ink);border:1.5px solid var(--g300);backdrop-filter:blur(4px);}
body.dark .mf-chip.active,body:not(.light) .mf-chip.active{background:var(--amber);color:#0E1018;border-color:var(--amber);}
body.dark .cmsg:not(.mine) .cbub,body:not(.light) .cmsg:not(.mine) .cbub{background:var(--g100);color:var(--ink);}
body.dark .cmsg.mine .cbub,body:not(.light) .cmsg.mine .cbub{background:#1A3060;color:#E8EEF8;}
body.dark .ac-dropdown,body:not(.light) .ac-dropdown{background:var(--surface);box-shadow:0 4px 24px rgba(0,0,0,.6);}
body.dark .ac-item,body:not(.light) .ac-item{color:var(--ink);border-color:var(--g200);}
body.dark .ac-item:hover,body.dark .ac-item:active,body.dark .ac-item.active,
body:not(.light) .ac-item:hover,body:not(.light) .ac-item:active{background:var(--g100);}
body.dark .ac-item-sub,body:not(.light) .ac-item-sub{color:var(--g500);}
body.dark .map-search-box input,body:not(.light) .map-search-box input{background:var(--surface)!important;color:var(--ink)!important;}
body.dark .fc,body:not(.light) .fc{background:var(--g100);color:var(--g600);border-color:var(--g200);}
body.dark .fc.active,body:not(.light) .fc.active{background:var(--navy);color:var(--bg);}
body.dark #mapListPanel,body:not(.light) #mapListPanel{background:var(--bg);}
body.dark #mapListPanel .sc,body:not(.light) #mapListPanel .sc{background:var(--surface)!important;}
body.dark .map-list-header,body:not(.light) .map-list-header{background:var(--surface);border-bottom-color:var(--g200);}
/* Step wizard dark */
body.dark .step-panel,body:not(.light) .step-panel{background:var(--bg);}
body.dark .step-summary-row,body:not(.light) .step-summary-row{background:var(--surface);border-color:var(--g200);}

/* ══ RESET ══════════════════════════════════════════════════ */
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{height:100%;font-family:'Barlow',sans-serif;background:var(--bg);color:var(--ink);overflow:hidden}
#app{display:flex;flex-direction:column;height:100vh;height:100dvh}

/* ══ HEADER ══════════════════════════════════════════════════ */
header{background:var(--navy);padding:10px 14px 8px;flex-shrink:0;display:flex;align-items:center;justify-content:space-between;gap:10px}
.logo{display:flex;align-items:center;gap:8px;flex-shrink:0}
.logo-svg{width:28px;height:49px;object-fit:contain;display:block}
.logo-text{display:flex;flex-direction:column;gap:2px}
.logo-name{font-family:'Barlow Condensed',sans-serif;font-size:19px;font-weight:800;color:var(--amber-mid);letter-spacing:.5px;line-height:1}
.logo-sub{font-family:'Barlow',sans-serif;color:var(--amber);font-weight:500;font-size:9.5px;letter-spacing:.3px;font-style:italic;line-height:1;opacity:1;display:block}
.header-right{display:flex;align-items:center;gap:8px}
.hbadge{background:var(--amber);color:#fff;font-size:11px;font-weight:700;padding:4px 10px;border-radius:20px;letter-spacing:.3px;flex-shrink:0}
.user-chip{display:flex;align-items:center;gap:7px;background:rgba(255,255,255,.1);border-radius:20px;padding:4px 10px 4px 4px;cursor:pointer;border:1px solid rgba(255,255,255,.15);transition:background .15s}
.user-chip:active{background:rgba(255,255,255,.18)}
.user-avatar{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;flex-shrink:0;overflow:hidden}
.user-avatar img{width:100%;height:100%;object-fit:cover}
.user-name{font-size:12px;font-weight:600;color:rgba(255,255,255,.85);max-width:80px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.login-btn{background:var(--amber);color:#fff;border:none;border-radius:20px;padding:5px 13px;font-family:'Barlow',sans-serif;font-size:12px;font-weight:700;cursor:pointer;letter-spacing:.3px}
@media(max-width:480px){
  .logo-name{font-size:15px}
  .logo-sub{font-size:8px}
  .logo-svg{width:24px;height:42px}
  .user-name{max-width:55px}
  .hbadge{font-size:10px;padding:3px 7px}
}

/* ══ LAYOUT ══════════════════════════════════════════════════ */
main{flex:1;overflow:hidden;display:flex;flex-direction:column}
.screens{flex:1;overflow:hidden}
.screen{display:none;height:100%;overflow-y:auto}
.screen.active{display:flex;flex-direction:column}

/* ══ NAV ══════════════════════════════════════════════════════ */
nav{background:var(--navy);display:flex;flex-shrink:0;border-top:1px solid rgba(255,255,255,.08)}
.nb{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:8px 2px 10px;background:none;border:none;cursor:pointer;color:rgba(255,255,255,.55);font-family:'Barlow',sans-serif;font-size:9px;font-weight:600;gap:3px;transition:color .2s var(--ease-out);letter-spacing:.3px}
.nb .ni{font-size:18px;line-height:1;transition:transform .2s var(--ease-spring)}
.nb.active{color:var(--amber-mid)}
.nb.active .ni{transform:scale(1.15)}
.nb:hover{color:rgba(255,255,255,.75)}

/* ══ BANNER ══════════════════════════════════════════════════ */
.banner{padding:7px 14px;font-size:12px;display:flex;align-items:center;gap:8px;flex-shrink:0;border-bottom:1px solid}
.banner.warn{background:#FEF9C3;border-color:#FDE68A;color:#854D0E}
.banner.ok{background:#F0FDF4;border-color:#BBF7D0;color:#14532D}
.banner.err{background:#FEE2E2;border-color:#FCA5A5;color:#991B1B}
.banner code{background:rgba(0,0,0,.08);padding:1px 5px;border-radius:3px;font-size:11px}
.banner button{margin-left:auto;background:none;border:none;font-size:11px;font-weight:700;color:inherit;cursor:pointer;text-decoration:underline;font-family:'Barlow',sans-serif;white-space:nowrap}

/* ══ MAPPA ══════════════════════════════════════════════════ */
#screen-mappa{position:relative}
.map-view-toggle{position:absolute;top:12px;right:12px;z-index:1002;display:flex;background:var(--surface);border-radius:22px;padding:3px;box-shadow:0 2px 10px rgba(0,0,0,.22);gap:2px}
.mvt-btn{padding:6px 14px;border:none;border-radius:18px;font-family:'Barlow',sans-serif;font-size:12px;font-weight:700;cursor:pointer;color:var(--g500);background:transparent;transition:all .18s;letter-spacing:.2px}
.mvt-btn.active{background:var(--navy);color:#fff;box-shadow:0 1px 4px rgba(0,0,0,.2)}
#mapListPanel{position:absolute;inset:0;z-index:500;display:flex;flex-direction:column;background:var(--bg);overflow:hidden}
.map-list-header{display:flex;align-items:center;justify-content:space-between;padding:12px 14px 10px;background:var(--surface);border-bottom:1px solid var(--g200);flex-shrink:0;gap:10px}
#map{flex:1;z-index:0}
/* mapFilters: pointer-events:none sul contenitore evita che blocchi FAB e fab-loc;
   i chip recuperano pointer-events:auto individualmente.
   padding-left:68px libera la zona del bottone GPS (44px+16px+8px margine) */
#mapFilters{position:absolute;bottom:90px;left:0;right:0;z-index:1000;overflow-x:auto;display:flex;gap:6px;padding:0 12px 0 68px;scrollbar-width:none;-webkit-overflow-scrolling:touch;background:transparent;pointer-events:none}
#mapFilters::-webkit-scrollbar{display:none}
.mf-chip{pointer-events:auto}

/* FAB e fab-loc: z-index sopra mapFilters per sicurezza */
.fab{position:absolute;bottom:76px;right:16px;background:var(--amber);color:#fff;border:none;border-radius:28px;padding:11px 18px;font-family:'Barlow Condensed',sans-serif;font-size:15px;font-weight:700;letter-spacing:.5px;cursor:pointer;box-shadow:var(--shm);z-index:1002;display:flex;align-items:center;gap:6px;transition:transform .15s var(--ease-spring),box-shadow .15s}
.fab:active{transform:scale(.95);box-shadow:var(--sh)}
.fab-loc{position:absolute;bottom:76px;left:16px;background:var(--navy);color:var(--amber-mid);border:none;border-radius:50%;width:44px;height:44px;font-size:20px;cursor:pointer;box-shadow:var(--shm);z-index:1002;display:flex;align-items:center;justify-content:center;transition:transform .15s var(--ease-spring)}
.fab-loc:active{transform:scale(.92)}

/* ══ MARKER MAPPA PERSONALIZZATI ══════════════════════════════ */
.map-pin{
  width:42px;
  height:52px;
  display:flex;
  align-items:flex-start;
  justify-content:center;
  position:relative;
  filter:drop-shadow(0 3px 6px rgba(0,0,0,.35));
}
.map-pin::before{
  content:'';
  position:absolute;
  width:38px;
  height:38px;
  border-radius:50% 50% 50% 0;
  background:var(--pin-color,var(--amber));
  transform:rotate(-45deg);
  top:0;
  left:2px;
  border:3px solid rgba(255,255,255,.9);
}
.map-pin span{
  position:relative;
  z-index:1;
  font-size:18px;
  margin-top:7px;
  line-height:1;
}
/* Varianti colore per stato */
.map-pin.status-late::after{
  content:'!';
  position:absolute;
  top:-4px;
  right:0;
  background:#DC2626;
  color:#fff;
  width:16px;
  height:16px;
  border-radius:50%;
  font-size:10px;
  font-weight:900;
  display:flex;
  align-items:center;
  justify-content:center;
  font-family:'Barlow',sans-serif;
  border:2px solid #fff;
  z-index:2;
}

/* ══ POPUP MAPPA ══════════════════════════════════════════════ */
.cwp{min-width:200px}
.cwp-row{display:flex;gap:6px;margin-top:2px}
.cwp-fav{flex:0 0 36px;background:var(--g100);border:none;border-radius:var(--rs);font-size:18px;cursor:pointer;padding:0}
.cwp-btn2{flex:1;padding:8px;background:var(--navy);color:#fff;border:none;border-radius:var(--rs);font-family:'Barlow',sans-serif;font-size:13px;font-weight:600;cursor:pointer}
.card-fav{background:none;border:none;font-size:20px;cursor:pointer;padding:4px 8px;flex-shrink:0;line-height:1;color:var(--amber);transition:transform .15s,opacity .15s}
.card-fav:active{transform:scale(1.25);opacity:.7}
.oc-wrap{padding:4px 0}
.oc-row{display:flex;align-items:center;gap:8px;margin-bottom:6px}
.oc-day{width:28px;font-size:11px;font-weight:700;color:var(--g500);text-transform:uppercase;flex-shrink:0}
.oc-bar-wrap{flex:1;height:14px;background:var(--g100);border-radius:7px;overflow:hidden}
.oc-bar{height:100%;background:var(--amber);border-radius:7px;min-width:4px;transition:width .5s var(--ease-out)}
.oc-stat{font-size:11px;color:var(--g600);width:68px;text-align:right;flex-shrink:0}
.oc-empty{font-size:13px;color:var(--g400);text-align:center;padding:10px}
.stepper-row{display:flex;align-items:center;justify-content:space-between;background:var(--g50);border:1.5px solid var(--g200);border-radius:var(--r);overflow:hidden}
.step-btn{width:48px;height:48px;border:none;background:transparent;font-size:22px;font-weight:700;color:var(--amber-dark);cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:background .15s}
.step-btn:active{background:var(--amber-light)}
.step-display{flex:1;display:flex;align-items:center;justify-content:center;gap:8px}
.step-icon{font-size:20px}
.step-val{font-family:'Barlow Condensed',sans-serif;font-size:26px;font-weight:700;color:var(--ink);min-width:28px;text-align:center}
.stepper-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:6px}
.stepper-item{background:var(--g50);border:1.5px solid var(--g200);border-radius:var(--r);padding:8px 10px}
.stepper-label{font-size:11px;font-weight:700;color:var(--g500);margin-bottom:6px;text-align:center}
.stepper-item .stepper-row{border:none;background:transparent}
.stepper-item .step-btn{width:36px;height:36px;font-size:18px;background:var(--g100);border-radius:8px}
.stepper-item .step-val{font-size:20px;min-width:22px}
.cwp-t{font-family:'Barlow Condensed',sans-serif;font-size:16px;font-weight:700;color:var(--g900);margin-bottom:2px}
.cwp-a{font-size:12px;color:var(--g500);margin-bottom:8px}
.cwp-b{height:5px;background:var(--g200);border-radius:3px;overflow:hidden;margin-bottom:6px}
.cwp-f{height:100%;background:var(--amber);border-radius:3px}
.cwp-r{display:flex;justify-content:space-between;font-size:12px;color:var(--g500);margin-bottom:8px}
.cwp-btn{width:100%;padding:8px;background:var(--navy);color:#fff;border:none;border-radius:var(--rs);font-family:'Barlow',sans-serif;font-size:13px;font-weight:600;cursor:pointer}
.leaflet-popup-content-wrapper{border-radius:var(--r)!important;box-shadow:var(--shm)!important}
.leaflet-popup-content{margin:14px!important}

/* ══ LISTA ════════════════════════════════════════════════════ */
.sh{padding:14px 16px 0;flex-shrink:0}
.sh-title{font-family:'Barlow Condensed',sans-serif;font-size:22px;font-weight:800;color:var(--ink);margin-bottom:12px}
.frow{display:flex;gap:6px;overflow-x:auto;padding-bottom:6px;scrollbar-width:none}
.frow::-webkit-scrollbar{display:none}
.fc{flex-shrink:0;padding:5px 13px;border-radius:20px;border:1.5px solid var(--g300);background:var(--surface);font-size:12px;font-weight:600;color:var(--g500);cursor:pointer;font-family:'Barlow',sans-serif;transition:all .18s;white-space:nowrap}
.fc.active{background:var(--navy);color:#fff;border-color:var(--navy)}
.filter-group{margin-bottom:8px}
.filter-group-label{font-size:10px;font-weight:700;color:var(--g400);letter-spacing:.8px;text-transform:uppercase;margin-bottom:6px}
.sort-bar{display:flex;align-items:center;gap:6px;padding:0 16px 10px;flex-shrink:0}
.sort-label{font-size:11px;font-weight:600;color:var(--g500);white-space:nowrap}
.sort-sel{padding:4px 10px;border:1.5px solid var(--g200);border-radius:20px;font-family:'Barlow',sans-serif;font-size:12px;font-weight:600;color:var(--g700);background:var(--surface);outline:none;cursor:pointer;-webkit-appearance:none}
.ls{flex:1;overflow-y:auto;padding:8px 16px 20px}

/* Card cantiere — con animazione di ingresso */
.sc{
  background:var(--surface);
  border-radius:var(--r);
  padding:14px;
  margin-bottom:10px;
  box-shadow:var(--sh);
  cursor:pointer;
  border:1.5px solid transparent;
  transition:border-color .15s,transform .15s var(--ease-out),box-shadow .15s;
  animation:card-in .25s var(--ease-out) both;
}
.sc:active{border-color:var(--amber);transform:scale(.99)}
@keyframes card-in{
  from{opacity:0;transform:translateY(8px)}
  to{opacity:1;transform:translateY(0)}
}
.sr{display:flex;align-items:flex-start;gap:12px;margin-bottom:10px}
.si{width:42px;height:42px;background:var(--amber-light);border-radius:var(--rs);display:flex;align-items:center;justify-content:center;font-size:21px;flex-shrink:0}
.sn{font-family:'Barlow Condensed',sans-serif;font-size:18px;font-weight:700;color:var(--ink);line-height:1.2;margin-bottom:2px}
.sa{font-size:12px;color:var(--g500)}
.bgs{display:flex;gap:5px;flex-wrap:wrap;margin-bottom:10px}
.badge{font-size:11px;font-weight:600;padding:3px 9px;border-radius:20px;font-family:'Barlow',sans-serif}
.br{background:var(--red-light);color:var(--red)}.ba{background:var(--amber-light);color:var(--amber-dark)}
.bg-g{background:var(--green-light);color:var(--green)}.bg-gr{background:var(--g100);color:var(--g600)}
.bg-b{background:var(--blue-light);color:var(--blue)}
.pw{margin-bottom:6px}.pl{display:flex;justify-content:space-between;font-size:11px;color:var(--g500);margin-bottom:4px}
.pb{height:5px;background:var(--g100);border-radius:3px;overflow:hidden}.pf{height:100%;background:var(--amber);border-radius:3px;transition:width .5s var(--ease-out)}
.cf{display:flex;justify-content:space-between;align-items:center}.as{font-size:12px;color:var(--amber-dark);font-weight:600}

/* ══ SKELETON SCREENS ══════════════════════════════════════════ */
@keyframes shimmer{
  0%{background-position:-400px 0}
  100%{background-position:400px 0}
}
.skeleton{
  background:linear-gradient(90deg,var(--g100) 25%,var(--g200) 50%,var(--g100) 75%);
  background-size:400px 100%;
  animation:shimmer 1.4s ease-in-out infinite;
  border-radius:var(--rs);
}
.skeleton-card{
  background:var(--surface);
  border-radius:var(--r);
  padding:14px;
  margin-bottom:10px;
  box-shadow:var(--sh);
}
.sk-line{height:12px;margin-bottom:8px}
.sk-line.wide{width:75%}
.sk-line.short{width:45%}
.sk-line.full{width:100%}
.sk-icon{width:42px;height:42px;border-radius:var(--rs);flex-shrink:0}
.sk-row{display:flex;gap:12px;margin-bottom:12px;align-items:flex-start}
.sk-text{flex:1}

/* ══ DETAIL ══════════════════════════════════════════════════ */
#screen-detail{background:var(--bg)}
.dtb{background:var(--navy);padding:12px 16px;display:flex;align-items:center;gap:12px;flex-shrink:0}
.bbtn{background:none;border:none;color:var(--amber-mid);font-size:28px;cursor:pointer;padding:0;line-height:1;transition:transform .15s var(--ease-spring)}
.bbtn:active{transform:scale(.9) translateX(-3px)}
.dtt{font-family:'Barlow Condensed',sans-serif;font-size:18px;font-weight:700;color:#fff;flex:1;line-height:1.2}
.db{flex:1;overflow-y:auto;padding:14px 16px 28px}
.sl{font-family:'Barlow Condensed',sans-serif;font-size:12px;font-weight:700;color:var(--g400);letter-spacing:1.2px;text-transform:uppercase;margin:18px 0 8px;display:flex;justify-content:space-between;align-items:center}
.sl button{font-size:12px;color:var(--amber-dark);font-weight:700;background:none;border:none;cursor:pointer;font-family:'Barlow',sans-serif;letter-spacing:0;text-transform:none}
.ic{background:var(--surface);border-radius:var(--r);padding:14px;box-shadow:var(--sh);margin-bottom:8px}
.ig{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:12px}
.ii-l{font-size:10px;color:var(--g400);margin-bottom:3px;font-weight:700;letter-spacing:.5px;text-transform:uppercase}
.ii-v{font-family:'Barlow Condensed',sans-serif;font-size:18px;font-weight:700;color:var(--ink)}
.or{display:flex;justify-content:space-between;align-items:center;padding:9px 0;border-bottom:1px solid var(--g100);font-size:13px}
.or:last-child{border-bottom:none}.og{font-weight:600;color:var(--g700)}
.od{width:8px;height:8px;border-radius:50%;margin-right:5px;display:inline-block}
.dg{background:var(--green)}.oo{color:var(--g500);font-size:12px}
.rc{background:var(--surface);border-radius:var(--r);padding:14px;box-shadow:var(--sh);margin-bottom:8px}
.rh{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.rav{width:34px;height:34px;border-radius:50%;background:var(--amber-light);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:var(--amber-dark);flex-shrink:0;overflow:hidden}
.rav img{width:100%;height:100%;object-fit:cover}
.rn{font-weight:600;font-size:14px;color:var(--ink)}.rd{font-size:11px;color:var(--g400);margin-top:1px}
.rst{color:var(--amber-mid);font-size:14px;margin-bottom:6px;letter-spacing:1px}
.rt{font-size:13px;color:var(--g600);line-height:1.55}
.rpt{margin-top:8px;border-radius:var(--rs);overflow:hidden}.rpt img{width:100%;max-height:160px;object-fit:cover}
.mf-chip{flex-shrink:0;padding:5px 12px;border:none;border-radius:16px;background:rgba(255,255,255,.92);color:var(--navy);font-family:'Barlow',sans-serif;font-size:12px;font-weight:700;cursor:pointer;box-shadow:0 1px 4px rgba(0,0,0,.18);white-space:nowrap;transition:all .15s}
.mf-chip.active{background:var(--amber);color:#fff}
.mf-chip:active{transform:scale(.96)}
.fav-btn{background:none;border:none;font-size:22px;cursor:pointer;padding:4px 8px;line-height:1;color:var(--amber);transition:transform .2s var(--ease-spring)}
.fav-btn:active{transform:scale(1.4)}
.search-bar{display:flex;align-items:center;gap:8px;padding:10px 14px 0;background:var(--g50)}
.search-bar input{flex:1;padding:9px 12px;border:1.5px solid var(--g200);border-radius:20px;font-size:14px;font-family:'Barlow',sans-serif;outline:none;background:#fff;transition:border-color .2s}
.search-bar input:focus{border-color:var(--amber)}
.map-search-box{position:absolute;top:12px;left:50%;transform:translateX(-50%);z-index:1000;width:calc(100% - 100px);max-width:380px;display:flex;flex-direction:column;gap:0}
.map-search-row{display:flex;gap:6px}
.map-search-box input{flex:1;padding:9px 14px;border:none;border-radius:20px;font-size:14px;font-family:'Barlow',sans-serif;box-shadow:0 2px 8px rgba(0,0,0,.2);outline:none}
.map-search-box button{padding:0 14px;border:none;border-radius:20px;background:var(--amber);color:#fff;font-size:18px;cursor:pointer;box-shadow:0 2px 8px rgba(0,0,0,.2)}
.ac-dropdown{background:var(--surface);border-radius:14px;box-shadow:0 4px 20px rgba(0,0,0,.18);overflow:hidden;margin-top:4px;max-height:260px;overflow-y:auto}
.ac-item{display:flex;align-items:center;gap:10px;padding:11px 14px;cursor:pointer;border-bottom:1px solid var(--g100);transition:background .12s;font-family:'Barlow',sans-serif;font-size:13px;color:var(--ink)}
.ac-item:last-child{border-bottom:none}
.ac-item:active,.ac-item:hover,.ac-item.active{background:var(--g50)}
.ac-item-icon{font-size:16px;flex-shrink:0;width:22px;text-align:center}
.ac-item-main{flex:1;min-width:0}
.ac-item-title{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ac-item-sub{font-size:11px;color:var(--g500);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px}
.ac-item-dist{font-size:11px;font-weight:700;color:var(--amber-mid);flex-shrink:0}
.inline-search-wrap{position:relative;flex:1}
.inline-search-wrap .ac-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;z-index:2000;margin-top:0}
.photo-gallery{display:flex;gap:8px;overflow-x:auto;padding:4px 0;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}
.photo-gallery:empty::after{content:'Nessuna foto aggiunta';font-size:13px;color:var(--g400);padding:8px 0}
.photo-thumb{flex:0 0 auto;width:140px;height:140px;border-radius:var(--rs);overflow:hidden;scroll-snap-align:start;cursor:pointer;position:relative}
.photo-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.photo-thumb-cover{flex:0 0 auto;width:100%;height:200px;border-radius:var(--rs);overflow:hidden;cursor:pointer}
.photo-thumb-cover img{width:100%;height:100%;object-fit:cover;display:block}
.photo-lightbox{position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:9999;display:flex;align-items:center;justify-content:center;padding:16px}
.photo-lightbox img{max-width:100%;max-height:90vh;border-radius:8px;object-fit:contain}
.photo-lightbox-close{position:absolute;top:16px;right:16px;background:rgba(255,255,255,.15);color:#fff;border:none;border-radius:50%;width:36px;height:36px;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center}
.arb{width:100%;padding:13px;margin-top:10px;background:none;border:2px dashed var(--amber);border-radius:var(--r);font-family:'Barlow Condensed',sans-serif;font-size:16px;font-weight:700;color:var(--amber-dark);cursor:pointer;transition:background .15s}
.arb:active{background:var(--amber-light)}
.rev-filters{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:10px}
.rev-filter-chips{display:flex;gap:5px;overflow-x:auto;scrollbar-width:none;flex:1}
.rev-filter-chips::-webkit-scrollbar{display:none}
.rfc{flex-shrink:0;padding:4px 10px;border-radius:20px;border:1.5px solid var(--g200);background:var(--surface);font-size:12px;font-weight:600;color:var(--g500);cursor:pointer;font-family:'Barlow',sans-serif;transition:all .15s}
.rfc.active{background:var(--amber);color:#fff;border-color:var(--amber)}
.rev-sort{padding:4px 10px;border:1.5px solid var(--g200);border-radius:20px;font-family:'Barlow',sans-serif;font-size:12px;font-weight:600;color:var(--g600);background:var(--surface);outline:none;cursor:pointer;-webkit-appearance:none;flex-shrink:0}
.lock-banner{background:var(--navy);border-radius:var(--r);padding:14px 16px;display:flex;align-items:center;gap:12px;margin-bottom:8px}
.lock-icon{font-size:24px;flex-shrink:0}
.lock-text{flex:1;font-size:13px;color:rgba(255,255,255,.8);line-height:1.5}
.lock-text strong{color:#fff}
.lock-cta{background:var(--amber);color:#fff;border:none;border-radius:20px;padding:7px 14px;font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:700;cursor:pointer;white-space:nowrap;flex-shrink:0}

/* ══ FORM AGGIUNGI (WIZARD) ══════════════════════════════════ */
#screen-aggiungi{background:var(--bg)}

/* Progress bar wizard */
.wizard-progress{
  display:flex;
  align-items:center;
  padding:14px 20px 12px;
  background:var(--surface);
  border-bottom:1px solid var(--g200);
  flex-shrink:0;
  gap:0;
}
.wizard-step-dot{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:4px;
  flex:1;
  position:relative;
}
.wizard-step-dot:not(:last-child)::after{
  content:'';
  position:absolute;
  top:13px;
  left:calc(50% + 14px);
  right:calc(-50% + 14px);
  height:2px;
  background:var(--g200);
  transition:background .3s;
}
.wizard-step-dot.done:not(:last-child)::after,
.wizard-step-dot.active:not(:last-child)::after{
  background:var(--amber);
}
.wsd-circle{
  width:26px;
  height:26px;
  border-radius:50%;
  background:var(--g200);
  color:var(--g500);
  display:flex;
  align-items:center;
  justify-content:center;
  font-family:'Barlow Condensed',sans-serif;
  font-size:13px;
  font-weight:700;
  transition:all .25s var(--ease-out);
  position:relative;
  z-index:1;
}
.wizard-step-dot.active .wsd-circle{
  background:var(--amber);
  color:#fff;
  box-shadow:0 0 0 4px var(--amber-light);
  transform:scale(1.1);
}
.wizard-step-dot.done .wsd-circle{
  background:var(--navy);
  color:#fff;
}
.wsd-label{
  font-size:9px;
  font-weight:700;
  color:var(--g400);
  letter-spacing:.4px;
  text-transform:uppercase;
  text-align:center;
}
.wizard-step-dot.active .wsd-label{color:var(--amber-dark);}
.wizard-step-dot.done .wsd-label{color:var(--navy);}

/* Pannelli step */
.wizard-panels{flex:1;overflow:hidden;position:relative}
.wizard-panel{
  display:none;
  height:100%;
  overflow-y:auto;
  padding:16px 16px 24px;
  animation:panel-slide-in .22s var(--ease-out) both;
}
.wizard-panel.active{display:block}
@keyframes panel-slide-in{
  from{opacity:0;transform:translateX(12px)}
  to{opacity:1;transform:translateX(0)}
}

.wizard-nav{
  display:flex;
  gap:10px;
  padding:12px 16px;
  background:var(--surface);
  border-top:1px solid var(--g200);
  flex-shrink:0;
}
.wn-prev{
  flex:0 0 auto;
  padding:12px 20px;
  background:var(--g100);
  color:var(--g700);
  border:none;
  border-radius:var(--r);
  font-family:'Barlow Condensed',sans-serif;
  font-size:15px;
  font-weight:700;
  cursor:pointer;
  transition:background .15s;
}
.wn-prev:active{background:var(--g200)}
.wn-next{
  flex:1;
  padding:13px;
  background:var(--navy);
  color:var(--amber-mid);
  border:none;
  border-radius:var(--r);
  font-family:'Barlow Condensed',sans-serif;
  font-size:17px;
  font-weight:800;
  letter-spacing:.5px;
  cursor:pointer;
  transition:all .18s var(--ease-out);
}
.wn-next:active{background:var(--amber-dark);color:#fff;transform:scale(.98)}
.wn-next:disabled{background:var(--g200);color:var(--g400);cursor:not-allowed;transform:none}

/* Titolo sezione nel wizard */
.ws-title{
  font-family:'Barlow Condensed',sans-serif;
  font-size:22px;
  font-weight:800;
  color:var(--ink);
  margin-bottom:4px;
}
.ws-sub{
  font-size:13px;
  color:var(--g500);
  margin-bottom:18px;
  line-height:1.5;
}

/* Scandalo meter (migliorato) */
.scandalo-row{display:flex;gap:8px;align-items:center}
.sbtn{font-size:28px;cursor:pointer;opacity:.2;transition:opacity .15s,transform .15s var(--ease-spring);background:none;border:none;padding:2px}
.sbtn.active{opacity:1}
.sbtn:active{transform:scale(1.25)}
.scandalo-label{font-size:12px;color:var(--g500);margin-top:6px;text-align:center;min-height:18px;font-weight:500}

/* Riepilogo step 4 */
.step-summary-section{
  background:var(--surface);
  border-radius:var(--r);
  padding:14px;
  margin-bottom:10px;
  box-shadow:var(--sh);
}
.step-summary-title{
  font-size:10px;
  font-weight:700;
  color:var(--g400);
  letter-spacing:.8px;
  text-transform:uppercase;
  margin-bottom:10px;
}
.step-summary-row{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  padding:7px 0;
  border-bottom:1px solid var(--g100);
  font-size:13px;
}
.step-summary-row:last-child{border-bottom:none}
.ssr-label{color:var(--g500);font-weight:600;flex-shrink:0;min-width:80px}
.ssr-value{color:var(--ink);font-weight:500;text-align:right}
.step-confirm-btn{
  width:100%;
  padding:15px;
  background:var(--amber);
  color:#fff;
  border:none;
  border-radius:var(--r);
  font-family:'Barlow Condensed',sans-serif;
  font-size:20px;
  font-weight:800;
  letter-spacing:1px;
  cursor:pointer;
  margin-top:4px;
  transition:transform .15s var(--ease-spring),background .15s;
  box-shadow:var(--shm);
}
.step-confirm-btn:active{transform:scale(.97);background:var(--amber-dark)}
.step-confirm-btn:disabled{background:var(--g200);color:var(--g400);cursor:not-allowed;transform:none;box-shadow:none}

/* Form fields generici (condivisi tra wizard e modali) */
#screen-aggiungi{background:var(--bg)}
/* .fs dentro il wizard deve essere flex column per far funzionare wizard-panels{flex:1} */
#screen-aggiungi .fs{display:flex;flex-direction:column;flex:1;overflow:hidden;padding:0}
.fs{flex:1;overflow-y:auto;padding:14px 16px 32px}
.fst{font-family:'Barlow Condensed',sans-serif;font-size:22px;font-weight:800;color:var(--ink);margin-bottom:16px}
.fg{margin-bottom:14px}
.fl{display:block;font-size:11px;font-weight:700;color:var(--g500);letter-spacing:.6px;text-transform:uppercase;margin-bottom:6px}
.fi,.fse,.fta{width:100%;padding:11px 13px;border:1.5px solid var(--g200);border-radius:var(--rs);font-family:'Barlow',sans-serif;font-size:15px;color:var(--g900);background:var(--surface);outline:none;transition:border-color .2s;-webkit-appearance:none}
.fi:focus,.fse:focus,.fta:focus{border-color:var(--amber)}
.fta{min-height:80px;resize:vertical}
.addr-row{display:flex;gap:8px}
.addr-row .fi{flex:1}
.geo-btn{padding:11px 13px;background:var(--amber-light);border:1.5px solid var(--amber);border-radius:var(--rs);font-size:13px;font-weight:700;color:var(--amber-dark);cursor:pointer;font-family:'Barlow',sans-serif;white-space:nowrap;flex-shrink:0;transition:background .15s}
.geo-btn:active{background:var(--amber);color:#fff}
.mmap-wrap{border-radius:var(--rs);overflow:hidden;border:1.5px solid var(--g200);margin-bottom:4px}
#miniMap{height:200px}
.mmap-hint{font-size:11px;color:var(--g400);margin-bottom:10px;text-align:center}
.geo-info{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--g50);border-radius:var(--rs);font-size:12px;margin-top:6px}
.gps-btn{margin-left:auto;padding:5px 10px;background:var(--amber-light);border:1.5px solid var(--amber);border-radius:6px;font-size:11px;font-weight:700;color:var(--amber-dark);cursor:pointer;font-family:'Barlow',sans-serif;white-space:nowrap}
.star-row{display:flex;gap:10px}
.pha{border:2px dashed var(--g300);border-radius:var(--rs);padding:16px;text-align:center;cursor:pointer;background:var(--surface);transition:border-color .15s,background .15s}
.pha:active{background:var(--g50);border-color:var(--amber)}
.pha-i{font-size:24px;margin-bottom:5px}.pha-t{font-size:13px;color:var(--g500);font-weight:500}
.php{margin-top:10px;border-radius:var(--rs);overflow:hidden}.php img{width:100%;max-height:180px;object-fit:cover}
#photoInput,#reviewPhotoInput,#detailPhotoInput{display:none}
.sbmit{width:100%;padding:15px;background:var(--navy);color:var(--amber-mid);border:none;border-radius:var(--r);font-family:'Barlow Condensed',sans-serif;font-size:18px;font-weight:800;letter-spacing:1px;cursor:pointer;margin-top:8px;transition:all .15s}
.sbmit:active{background:var(--amber-dark);color:#fff}

/* ══ CHAT ══════════════════════════════════════════════════════ */
#screen-chat{background:var(--bg)}
.chat-screen-body{flex:1;display:flex;flex-direction:column;overflow:hidden}
.chat-tabs{display:flex;padding:0 16px;border-bottom:2px solid var(--g200);flex-shrink:0;background:var(--surface)}
.chat-tab{flex:1;padding:12px 8px;font-family:'Barlow Condensed',sans-serif;font-size:15px;font-weight:700;color:var(--g500);cursor:pointer;text-align:center;border-bottom:2.5px solid transparent;margin-bottom:-2px;transition:all .15s;background:none;border-top:none;border-left:none;border-right:none;display:flex;align-items:center;justify-content:center;gap:6px}
.chat-tab.active{color:var(--ink);border-bottom-color:var(--amber)}
.chat-panel{display:none;flex:1;flex-direction:column;overflow:hidden}
.chat-panel.active{display:flex}
.chat-msgs{flex:1;overflow-y:auto;padding:14px 16px;display:flex;flex-direction:column;gap:10px}
.cmsg{display:flex;gap:8px;align-items:flex-end}
.cmsg.mine{flex-direction:row-reverse}
.cav-s{width:28px;height:28px;border-radius:50%;background:var(--amber-light);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:var(--amber-dark);flex-shrink:0;overflow:hidden}
.cav-s img{width:100%;height:100%;object-fit:cover}
.cmsg.mine .cav-s{background:var(--navy);color:var(--amber-mid)}
.cbub{max-width:75%;padding:9px 13px;border-radius:18px;font-size:14px;line-height:1.45;word-break:break-word}
.cmsg:not(.mine) .cbub{background:var(--surface);color:var(--ink);border-bottom-left-radius:4px;box-shadow:var(--sh)}
.cmsg.mine .cbub{background:var(--navy);color:#fff;border-bottom-right-radius:4px}
.cmeta{font-size:10px;color:var(--g400);margin-top:3px}.cmsg.mine .cmeta{text-align:right}
.chat-input-wrap{padding:10px 12px 12px;background:var(--surface);border-top:1px solid var(--g200);flex-shrink:0}
.chat-compose{display:flex;gap:8px;align-items:center}
.chat-in{flex:1;padding:10px 14px;border:1.5px solid var(--g200);border-radius:22px;font-family:'Barlow',sans-serif;font-size:14px;color:var(--g900);background:var(--surface);outline:none;transition:border-color .2s}
.chat-in:focus{border-color:var(--amber)}
.chat-send{width:40px;height:40px;border-radius:50%;background:var(--amber);border:none;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#fff;transition:transform .15s var(--ease-spring),background .15s}
.chat-send:active{background:var(--amber-dark);transform:scale(.9)}
.chat-empty{text-align:center;padding:40px 20px;color:var(--g400);font-size:14px;line-height:1.6}
.chat-empty .ce-i{font-size:36px;margin-bottom:10px}
.chat-site-list{flex:1;overflow-y:auto;padding:10px 16px 20px}
.site-chat-bar{display:flex;align-items:center;padding:10px 14px;background:var(--navy);border-bottom:1px solid rgba(255,255,255,.1);flex-shrink:0}
.chat-site-item{background:var(--surface);border-radius:var(--r);padding:13px 14px;margin-bottom:8px;box-shadow:var(--sh);cursor:pointer;display:flex;align-items:center;gap:12px;border:1.5px solid transparent;transition:all .15s}
.chat-site-item:active{border-color:var(--amber)}
.csi-icon{width:42px;height:42px;border-radius:var(--rs);background:var(--amber-light);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.csi-body{flex:1;overflow:hidden}
.csi-name{font-family:'Barlow Condensed',sans-serif;font-size:16px;font-weight:700;color:var(--navy);margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.csi-preview{font-size:12px;color:var(--g500);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.csi-meta{text-align:right;flex-shrink:0}
.csi-time{font-size:10px;color:var(--g400);margin-bottom:4px}
.csi-cnt{background:var(--amber);color:#fff;font-size:10px;font-weight:700;padding:2px 7px;border-radius:10px;display:inline-block}
/* ── CHAT SITE CONTROLS ─────────────────────────────── */
.csc-wrap{padding:8px 12px 4px;flex-shrink:0;background:var(--surface);border-bottom:1px solid var(--g200)}
.csc-row{display:flex;align-items:center;gap:6px}
.csc-chips{display:flex;gap:5px;overflow-x:auto;scrollbar-width:none;flex:1}
.csc-chips::-webkit-scrollbar{display:none}
.csc-chip{flex-shrink:0;padding:5px 11px;border:1.5px solid var(--g200);border-radius:16px;background:var(--bg);color:var(--g500);font-family:'Barlow',sans-serif;font-size:12px;font-weight:700;cursor:pointer;white-space:nowrap;transition:all .15s}
.csc-chip.active{background:var(--amber);color:#fff;border-color:var(--amber)}
.csc-chip:active{transform:scale(.95)}
.csc-sort{flex-shrink:0;padding:5px 10px;border:1.5px solid var(--g200);border-radius:16px;background:var(--bg);color:var(--navy);font-family:'Barlow',sans-serif;font-size:12px;font-weight:700;cursor:pointer;white-space:nowrap;transition:all .15s}
.csc-sort:active{transform:scale(.95)}
.csl-label{font-size:11px;font-weight:700;color:var(--g400);text-transform:uppercase;letter-spacing:.5px;padding:8px 2px 5px}
/* dark mode */
body.dark .csc-wrap,body:not(.light) .csc-wrap{background:var(--surface);border-bottom-color:rgba(255,255,255,.07)}
body.dark .csc-chip,body:not(.light) .csc-chip{background:rgba(28,32,48,.92);color:var(--g400);border-color:rgba(255,255,255,.12)}
body.dark .csc-chip.active,body:not(.light) .csc-chip.active{background:var(--amber);color:#0E1018;border-color:var(--amber)}
body.dark .csc-sort,body:not(.light) .csc-sort{background:rgba(28,32,48,.92);color:var(--ink);border-color:rgba(255,255,255,.12)}
.site-chat-wrap{background:var(--surface);border-radius:var(--r);box-shadow:var(--sh);overflow:hidden;margin-bottom:8px}
.site-chat-msgs{max-height:280px;overflow-y:auto;padding:12px 14px;display:flex;flex-direction:column;gap:8px}
.site-chat-input{padding:10px 12px;border-top:1px solid var(--g200)}

/* ══ STATS ════════════════════════════════════════════════════ */
#screen-stats{background:var(--bg)}
.ssc{flex:1;overflow-y:auto;padding:14px 16px 24px}
.stt{font-family:'Barlow Condensed',sans-serif;font-size:22px;font-weight:800;color:var(--navy);margin-bottom:14px}
.sgrid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:16px}
.stc{background:var(--surface);border-radius:var(--r);padding:16px 12px;text-align:center;box-shadow:var(--sh)}
.stn{font-family:'Barlow Condensed',sans-serif;font-size:38px;font-weight:800;color:var(--amber);line-height:1}
.stl{font-size:12px;color:var(--g500);margin-top:4px;font-weight:500}
.mc{background:var(--surface);border-radius:var(--r);padding:14px;box-shadow:var(--sh);margin-bottom:10px}
.mt{font-family:'Barlow Condensed',sans-serif;font-size:16px;font-weight:700;color:var(--navy);margin-bottom:12px}
.mr{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.mr:last-child{margin-bottom:0}
.mn{min-width:100px;color:var(--g700);font-size:12px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.mbw{flex:1;height:7px;background:var(--g100);border-radius:4px;overflow:hidden}
.mbf{height:100%;border-radius:4px;transition:width .5s var(--ease-out)}
.mv{min-width:32px;text-align:right;font-size:12px;color:var(--g500);font-weight:600}

/* ══ AUTH MODAL ══════════════════════════════════════════════ */
.auth-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.65);z-index:19999;align-items:flex-end;justify-content:center}
.auth-overlay.open{display:flex}
.auth-sheet{background:var(--surface);border-radius:24px 24px 0 0;width:100%;max-height:90vh;overflow-y:auto;padding:20px 20px 36px;animation:sheet-up .28s var(--ease-out)}
@keyframes sheet-up{from{transform:translateY(100%)}to{transform:translateY(0)}}
.auth-handle{width:36px;height:4px;background:var(--g200);border-radius:2px;margin:0 auto 20px}
.auth-logo{text-align:center;margin-bottom:6px;font-size:32px}
.auth-title{font-family:'Barlow Condensed',sans-serif;font-size:24px;font-weight:800;color:var(--navy);text-align:center;margin-bottom:4px}
.auth-sub{font-size:13px;color:var(--g500);text-align:center;margin-bottom:20px;line-height:1.5}
.auth-tabs{display:flex;background:var(--g100);border-radius:10px;padding:3px;margin-bottom:20px}
.auth-tab{flex:1;padding:8px;text-align:center;font-family:'Barlow Condensed',sans-serif;font-size:15px;font-weight:700;color:var(--g500);cursor:pointer;border-radius:8px;transition:all .2s}
.auth-tab.active{background:var(--surface);color:var(--navy);box-shadow:var(--sh)}
.google-btn{width:100%;padding:13px;border:1.5px solid var(--g200);border-radius:var(--r);background:var(--surface);display:flex;align-items:center;justify-content:center;gap:10px;cursor:pointer;font-family:'Barlow',sans-serif;font-size:15px;font-weight:600;color:var(--g800);margin-bottom:16px;transition:border-color .15s,box-shadow .15s}
.google-btn:active{border-color:var(--amber);box-shadow:0 0 0 3px var(--amber-light)}
.google-btn svg{flex-shrink:0}
.auth-divider{display:flex;align-items:center;gap:10px;margin-bottom:16px}
.auth-divider::before,.auth-divider::after{content:'';flex:1;height:1px;background:var(--g200)}
.auth-divider span{font-size:12px;color:var(--g400);font-weight:600;white-space:nowrap}
.auth-field{margin-bottom:12px}
.auth-label{font-size:11px;font-weight:700;color:var(--g500);letter-spacing:.5px;text-transform:uppercase;margin-bottom:5px;display:block}
.auth-input{width:100%;padding:12px 14px;border:1.5px solid var(--g200);border-radius:var(--rs);font-family:'Barlow',sans-serif;font-size:15px;color:var(--g900);background:var(--surface);outline:none;transition:border-color .2s}
.auth-input:focus{border-color:var(--amber)}
.auth-submit{width:100%;padding:14px;background:var(--navy);color:var(--amber-mid);border:none;border-radius:var(--r);font-family:'Barlow Condensed',sans-serif;font-size:18px;font-weight:800;letter-spacing:.5px;cursor:pointer;margin-top:4px;transition:all .15s}
.auth-submit:active{background:var(--amber-dark);color:#fff}
.auth-error{background:var(--red-light);color:var(--red);font-size:13px;padding:10px 12px;border-radius:var(--rs);margin-bottom:12px;display:none}
.auth-error.show{display:block}

/* ══ MODALE GENERICA ══════════════════════════════════════════ */
.mo{display:none;position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:9999;align-items:flex-end;justify-content:center}
.mo.open{display:flex}
.ms{background:var(--surface);border-radius:20px 20px 0 0;width:100%;max-height:88vh;overflow-y:auto;padding:20px 16px 34px;animation:sheet-up .25s var(--ease-out)}
.mh{width:36px;height:4px;background:var(--g200);border-radius:2px;margin:0 auto 18px}
.mtt{font-family:'Barlow Condensed',sans-serif;font-size:21px;font-weight:800;color:var(--navy);margin-bottom:16px}
.mc-btn{width:100%;padding:13px;margin-top:10px;background:var(--g100);color:var(--g700);border:none;border-radius:var(--r);font-family:'Barlow',sans-serif;font-size:15px;font-weight:600;cursor:pointer;transition:background .15s}
.mc-btn:active{background:var(--g200)}
.danger-btn{background:var(--red-light);color:var(--red);}

/* ══ TOAST ═══════════════════════════════════════════════════ */
.toast{
  position:fixed;
  bottom:90px;
  left:50%;
  transform:translateX(-50%) translateY(20px);
  background:var(--navy);
  color:#fff;
  padding:10px 20px;
  border-radius:20px;
  font-size:13px;
  font-weight:500;
  opacity:0;
  transition:opacity .25s,transform .25s var(--ease-out);
  pointer-events:none;
  white-space:nowrap;
  z-index:99999;
  max-width:90vw;
  text-align:center;
  overflow:hidden;
  text-overflow:ellipsis;
}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast.ok{background:#15803D}
.toast.err{background:#B91C1C}
.toast.warn{background:#B86A00}

/* ══ EMPTY STATE ══════════════════════════════════════════════ */
.empty{text-align:center;padding:48px 20px}
.ei{font-size:48px;margin-bottom:12px}
.ett{font-family:'Barlow Condensed',sans-serif;font-size:20px;font-weight:700;color:var(--g700);margin-bottom:6px}
.etx{font-size:14px;color:var(--g400)}

/* ══ SEGNALAZIONE / REPORT ══════════════════════════════════ */
.flag-btn{background:none;border:none;cursor:pointer;font-size:13px;opacity:.3;transition:opacity .15s;padding:2px 5px;line-height:1;flex-shrink:0;font-family:'Barlow',sans-serif}
.flag-btn:hover,.flag-btn:active{opacity:1;color:var(--red)}
.msg-row{display:flex;align-items:flex-end;gap:4px;width:100%}
.msg-row.mine{flex-direction:row-reverse}
.msg-content{flex:1;min-width:0}

/* ══ PHOTO DISCLAIMER ════════════════════════════════════════ */
/* disc-overlay rimosso — photo disclaimer eliminato */

/* ══ TERMS ═══════════════════════════════════════════════════ */
.terms-wrap{display:flex;align-items:flex-start;gap:10px;margin-bottom:14px;padding:10px 12px;background:var(--g50);border-radius:var(--rs)}
.terms-wrap input[type=checkbox]{width:17px;height:17px;flex-shrink:0;margin-top:2px;accent-color:var(--amber)}
.terms-wrap label{font-size:12px;color:var(--g600);line-height:1.5;cursor:pointer}
.terms-wrap a{color:var(--amber-dark);font-weight:600;text-decoration:none}

/* ══ WELCOME OVERLAY ══════════════════════════════════════════ */
.welcome-overlay{display:none;position:fixed;inset:0;background:var(--navy);z-index:99999;flex-direction:column;overflow:hidden}
.welcome-overlay.open{display:flex}
.welcome-header{padding:22px 20px 14px;background:linear-gradient(180deg,var(--navy) 0%,var(--navy2) 100%);text-align:center;flex-shrink:0;border-bottom:1px solid rgba(255,255,255,.08)}
.welcome-logo{font-size:42px;line-height:1;margin-bottom:8px}
.welcome-title{font-family:'Barlow Condensed',sans-serif;font-size:26px;font-weight:800;color:var(--amber-mid);letter-spacing:.5px;margin-bottom:4px}
.welcome-sub{font-size:12px;color:rgba(255,255,255,.55);font-weight:500;letter-spacing:.3px}
.welcome-body{flex:1;overflow-y:auto;background:var(--bg);padding:18px 18px 12px}
.welcome-section{background:var(--surface);border-radius:var(--r);padding:14px 14px 12px;margin-bottom:10px;box-shadow:var(--sh);border-left:4px solid var(--amber)}
.welcome-section.warn{border-left-color:var(--red)}
.welcome-section.info{border-left-color:var(--blue)}
.welcome-section.priv{border-left-color:#7C3AED}
.welcome-sec-title{font-family:'Barlow Condensed',sans-serif;font-size:15px;font-weight:800;color:var(--navy);margin-bottom:6px;display:flex;align-items:center;gap:6px;letter-spacing:.3px;text-transform:uppercase}
.welcome-sec-text{font-size:13px;color:var(--g700);line-height:1.55}
.welcome-sec-text strong{color:var(--navy);font-weight:700}
.welcome-sec-text ul{margin:6px 0 0 18px;padding:0}
.welcome-sec-text li{margin-bottom:3px}
.welcome-footer{flex-shrink:0;padding:14px 18px 18px;background:var(--surface);border-top:1px solid var(--g200);box-shadow:0 -4px 12px rgba(0,0,0,.06)}
.welcome-check{display:flex;align-items:flex-start;gap:11px;margin-bottom:12px;cursor:pointer;padding:11px 12px;background:var(--g50);border-radius:var(--rs);border:1.5px solid var(--g200);transition:all .15s}
.welcome-check.checked{background:#F0FDF4;border-color:#86EFAC}
.welcome-check input[type=checkbox]{width:19px;height:19px;flex-shrink:0;margin-top:1px;accent-color:var(--amber)}
.welcome-check span{font-size:13px;color:var(--g700);line-height:1.5;font-weight:500}
.welcome-accept{width:100%;padding:14px;background:var(--navy);color:var(--amber-mid);border:none;border-radius:var(--r);font-family:'Barlow Condensed',sans-serif;font-size:17px;font-weight:800;letter-spacing:.6px;cursor:pointer;transition:all .2s}
.welcome-accept:disabled{background:var(--g200);color:var(--g400);cursor:not-allowed}
.welcome-accept:not(:disabled):active{background:var(--amber-dark);color:#fff}.welcome-version{text-align:center;font-size:10px;color:var(--g400);margin-top:8px}

/* ═══════════════════════════════════════════════════════
   GAMIFICATION v2.2.0
   ═══════════════════════════════════════════════════════ */

/* ── CHIP AVATAR — FOUNDER + BADGE EMOJI ──────────────── */
.chip--founder .user-avatar{box-shadow:0 0 0 2.5px #F0A500,0 0 10px 2px rgba(240,165,0,.45);}
.chip--founder .user-name{color:#F0A500;}
.chip-badge-emoji{font-size:13px;margin-left:2px;line-height:1;flex-shrink:0;}

/* ── BADGE UNLOCK OVERLAY ────────────────────────────── */
.bu-overlay{display:none;position:fixed;inset:0;z-index:99990;align-items:center;justify-content:center;background:rgba(10,10,30,.82);backdrop-filter:blur(6px);}
.bu-overlay.open{display:flex;}
.bu-card{background:var(--surface);border-radius:20px;padding:36px 28px 28px;text-align:center;max-width:320px;width:90%;position:relative;overflow:hidden;box-shadow:0 24px 60px rgba(0,0,0,.35),0 0 0 1.5px rgba(240,165,0,.3);}
.bu-shine{position:absolute;inset:0;background:linear-gradient(135deg,rgba(240,165,0,.08) 0%,transparent 60%);pointer-events:none;}
.bu-label{font-family:'Barlow Condensed',sans-serif;font-size:12px;font-weight:800;letter-spacing:1.5px;text-transform:uppercase;color:var(--amber);margin-bottom:14px;}
.bu-emoji{font-size:72px;line-height:1;margin-bottom:12px;animation:bu-pop .4s cubic-bezier(.34,1.56,.64,1) both;}
@keyframes bu-pop{from{transform:scale(.5);opacity:0;}to{transform:scale(1);opacity:1;}}
.bu-name{font-family:'Barlow Condensed',sans-serif;font-size:22px;font-weight:800;color:var(--navy);margin-bottom:6px;letter-spacing:.3px;}
.bu-desc{font-size:13px;color:var(--g500);margin-bottom:22px;line-height:1.4;}
.bu-btn{background:var(--amber);color:#fff;border:none;border-radius:50px;padding:12px 32px;font-family:'Barlow Condensed',sans-serif;font-size:16px;font-weight:800;letter-spacing:.5px;cursor:pointer;width:100%;transition:opacity .15s;}
.bu-btn:active{opacity:.8;}

/* ── LEADERBOARD SCREEN ──────────────────────────────── */
.lb-podium{display:flex;align-items:flex-end;justify-content:center;gap:10px;padding:18px 8px 8px;background:linear-gradient(180deg,rgba(240,165,0,.07) 0%,transparent 100%);border-radius:var(--r);margin-bottom:12px;}
.lb-slot{display:flex;flex-direction:column;align-items:center;gap:4px;flex:1;max-width:110px;}
.lb-slot.rank-1{order:2;padding-bottom:0;}
.lb-slot.rank-2{order:1;padding-bottom:8px;}
.lb-slot.rank-3{order:3;padding-bottom:16px;}
.lb-slot-av{width:52px;height:52px;border-radius:50%;background:var(--amber-light);color:var(--amber-dark);font-family:'Barlow Condensed',sans-serif;font-size:18px;font-weight:800;display:flex;align-items:center;justify-content:center;overflow:hidden;border:2.5px solid var(--g200);}
.lb-slot.rank-1 .lb-slot-av{width:64px;height:64px;border-color:#F0A500;box-shadow:0 0 12px rgba(240,165,0,.4);}
.lb-slot.rank-2 .lb-slot-av{border-color:#94A3B8;}
.lb-slot.rank-3 .lb-slot-av{border-color:#B45309;}
.lb-slot-medal{font-size:22px;line-height:1;}
.lb-slot-name{font-family:'Barlow Condensed',sans-serif;font-size:13px;font-weight:700;color:var(--navy);text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100px;}
.lb-slot-pts{font-size:12px;color:var(--amber);font-weight:700;}
.lb-slot.lb-me .lb-slot-av{outline:2.5px solid var(--amber);outline-offset:2px;}

.lb-list{display:flex;flex-direction:column;gap:6px;margin-bottom:10px;}
.lb-row{display:flex;align-items:center;gap:10px;background:var(--surface);border-radius:var(--rs);padding:10px 12px;box-shadow:var(--sh);}
.lb-row.lb-me{background:rgba(240,165,0,.1);border:1.5px solid rgba(240,165,0,.3);}
.lb-rank{font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:800;color:var(--g400);min-width:28px;}
.lb-av-sm{width:36px;height:36px;border-radius:50%;background:var(--amber-light);color:var(--amber-dark);font-family:'Barlow Condensed',sans-serif;font-size:13px;font-weight:800;display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0;}
.lb-name-txt{flex:1;font-size:14px;font-weight:600;color:var(--navy);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.lb-pts-txt{font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:800;color:var(--amber);flex-shrink:0;}

.lb-empty{padding:24px;text-align:center;color:var(--g400);font-size:14px;}
.lb-mypos{text-align:center;padding:10px;font-size:13px;color:var(--g500);background:var(--g50);border-radius:var(--rs);margin-top:8px;}

/* ── BADGE LEGEND MODAL ──────────────────────────────── */
.bl-cat{padding:12px 16px 4px;}
.bl-cat-title{font-family:'Barlow Condensed',sans-serif;font-size:13px;font-weight:800;letter-spacing:1px;text-transform:uppercase;color:var(--amber);margin-bottom:8px;}
.bl-badge{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--rs);margin-bottom:6px;transition:opacity .15s;}
.bl-badge--ok{background:var(--surface);box-shadow:var(--sh);}
.bl-badge--locked{background:var(--g50);opacity:.6;}
.bl-badge-emoji{font-size:28px;width:36px;text-align:center;flex-shrink:0;}
.bl-badge-info{flex:1;min-width:0;}
.bl-badge-name{font-family:'Barlow Condensed',sans-serif;font-size:15px;font-weight:700;color:var(--navy);display:flex;align-items:center;gap:6px;}
.bl-badge-desc{font-size:12px;color:var(--g500);margin-top:1px;}
.bl-badge-e