:root{
  --brand:#CC912E;
  --brand-dark:#a9741f;
  --brand-darker:#825a14;
  --brand-light:#faf3e4;
  --brand-lighter:#fdfaf3;
  --brand-glow:rgba(204,145,46,.22);
  --gold-grad:linear-gradient(135deg,#e3b24f,#CC912E 55%,#a9741f);
  --bg:#fcfaf5;
  --text:#3a332a;
  --muted:#9c948677;
  --muted-txt:#9a9184;
  --crit:#d9342b;
  --ok:#2e9e5b;
  --phone:#2d7ff9;
  --card-shadow:0 6px 26px rgba(204,145,46,.10);
  --radius:16px;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Segoe UI',system-ui,-apple-system,Arial,sans-serif;background:var(--bg);color:var(--text);font-size:15px;line-height:1.5}
a{color:var(--brand-dark);text-decoration:none}
h1{font-size:1.75rem;color:var(--brand-darker);font-weight:800;letter-spacing:-.5px}
h2{font-size:1.2rem;margin-bottom:.8rem;color:var(--text);font-weight:700}
.subtitle{color:var(--muted-txt);font-size:.9rem;margin-top:.2rem}
em{font-style:normal;opacity:.75}

/* TOPBAR (bianco con bordo oro) */
.topbar{display:flex;justify-content:space-between;align-items:center;
  background:#fff;border-bottom:1px solid #f0e7d4;
  box-shadow:0 3px 16px rgba(204,145,46,.10);
  padding:.7rem 1.4rem;position:sticky;top:0;z-index:50;
  border-image:var(--gold-grad) 1;border-bottom-width:3px;border-bottom-style:solid}
.topbar-left{display:flex;align-items:center;gap:.85rem}
.topbar-logo{height:40px}
.menu-toggle{display:none;background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--brand-dark)}
.user-chip{font-size:.85rem;color:var(--brand-darker);margin-right:.6rem;background:var(--brand-light);padding:.35rem .8rem;border-radius:20px;font-weight:600}

/* LAYOUT */
.layout{display:flex;min-height:calc(100vh - 62px)}
.sidebar{width:240px;background:#fff;border-right:1px solid #f3ecdd;padding:1.2rem .7rem;display:flex;flex-direction:column;gap:.25rem}
.sidebar a{padding:.7rem .9rem;border-radius:12px;color:var(--text);font-weight:600;font-size:.92rem;transition:.18s}
.sidebar a:hover{background:var(--brand-light);color:var(--brand-darker);transform:translateX(3px)}
.sidebar a.active{background:var(--gold-grad);color:#fff;box-shadow:0 4px 12px var(--brand-glow)}
.sidebar hr{margin:.9rem .5rem;border:none;border-top:1px solid #f3ecdd}
.nav-section{font-size:.68rem;text-transform:uppercase;color:var(--muted-txt);padding:0 .9rem;letter-spacing:1px;font-weight:700}
.content{flex:1;padding:1.8rem;overflow-x:auto}

/* CARDS */
.card{background:#fff;border-radius:var(--radius);padding:1.4rem;box-shadow:var(--card-shadow);margin-bottom:1.3rem;border:1px solid #f5eedd}
.card-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}
.cards{display:flex;gap:1.2rem;flex-wrap:wrap;margin-bottom:1.3rem}
.stat{flex:1;min-width:150px;text-align:center;position:relative;overflow:hidden}
.stat::after{content:'';position:absolute;top:-30px;right:-30px;width:90px;height:90px;background:var(--brand-light);border-radius:50%;opacity:.6}
.stat-num{font-size:2.6rem;font-weight:800;background:var(--gold-grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;position:relative}
.stat.crit .stat-num{background:none;-webkit-text-fill-color:var(--crit)}
.stat-lbl{color:var(--muted-txt);font-size:.85rem;font-weight:600;position:relative}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1.3rem}

/* TABLE */
.table-wrap{overflow-x:auto}
.table{width:100%;border-collapse:collapse}
.table th,.table td{padding:.75rem .6rem;text-align:left;border-bottom:1px solid #f5eedd;font-size:.88rem;vertical-align:top}
.table th{background:var(--brand-light);color:var(--brand-darker);font-weight:700;text-transform:uppercase;font-size:.72rem;letter-spacing:.5px}
.table tbody tr{transition:.12s}
.table tbody tr:hover td{background:var(--brand-lighter)}
.actions-cell{white-space:nowrap}
.chip{display:inline-block;background:var(--brand-light);color:var(--brand-darker);padding:.15rem .55rem;border-radius:6px;font-size:.78rem;font-weight:600}

/* STATUS */
.status{font-size:.78rem;font-weight:700;padding:.15rem .5rem;border-radius:6px}
.status-0{background:#e3f2ff;color:#1565c0}
.status-2{background:#fff4e0;color:#b06a00}
.status-9{background:#ede7f6;color:#5e35b1}

/* BADGE */
.badge{display:inline-block;padding:.18rem .6rem;border-radius:20px;font-size:.7rem;font-weight:700;color:#fff;letter-spacing:.3px}
.badge-crit,.badge-CRITICA{background:var(--crit)}
.badge-alta,.badge-ALTA{background:#e8821e}
.badge-media,.badge-MEDIA{background:#d8b13e;color:#3a2c00}
.badge-bassa,.badge-BASSA{background:#6aa84f}
.badge-phone{background:var(--phone)}
.badge-onsite{background:var(--brand)}
.badge-admin{background:#7a6f5c}.badge-manutentore{background:var(--brand)}
.badge-programmata{background:var(--brand)}.badge-in_corso{background:#e8821e}
.badge-completata{background:var(--ok)}.badge-bozza{background:#b6aaa0}.badge-annullata{background:#c9bfaf}

/* FORM */
label{display:block;font-weight:600;font-size:.85rem;margin:.8rem 0 .3rem}
input,select,textarea{width:100%;padding:.6rem .8rem;border:1.5px solid #ece3d0;border-radius:11px;font-size:.9rem;font-family:inherit;background:var(--brand-lighter);transition:.15s}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 4px var(--brand-glow);background:#fff}
.check-inline{display:flex;align-items:center;gap:.5rem;font-weight:500}
.check-inline input{width:auto}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:.35rem;padding:.55rem 1rem;border-radius:11px;border:none;cursor:pointer;font-weight:700;font-size:.85rem;background:#f3ecdd;color:var(--brand-darker);transition:.18s;text-decoration:none}
.btn:hover{transform:translateY(-1px);box-shadow:0 5px 14px rgba(204,145,46,.18)}
.btn-primary{background:var(--gold-grad);color:#fff}
.btn-primary:hover{box-shadow:0 8px 22px var(--brand-glow)}
.btn-ghost{background:transparent;border:1.5px solid #e6dcc6}
.btn-sm{padding:.35rem .65rem;font-size:.78rem;border-radius:9px}
.btn-block{width:100%;justify-content:center;margin-top:1rem}

/* MAP */
.map{height:500px;width:100%;border-radius:13px;border:1px solid #f0e7d4}

/* TAPPE */
.tappe-list{list-style:none}
.tappa-base{padding:.7rem;background:linear-gradient(135deg,var(--brand-light),#fff);border-radius:11px;font-weight:700;margin-bottom:.6rem;border-left:4px solid var(--brand)}
.tappa-list li{margin-bottom:.6rem}
.tappa-row{display:flex;align-items:flex-start;gap:.8rem;padding:.8rem;border:1px solid #f5eedd;border-radius:11px;transition:.15s}
.tappa-row:hover{box-shadow:var(--card-shadow)}
.tappa-num{background:var(--gold-grad);color:#fff;width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;flex-shrink:0}
.tappa-info{flex:1}

/* misc */
.muted{color:var(--muted-txt);font-size:.82rem}
.page-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.3rem;flex-wrap:wrap;gap:.8rem}
.search{margin-bottom:1rem}
.alert{background:#fdecea;color:var(--crit);padding:.8rem 1rem;border-radius:11px;margin-bottom:1rem;border-left:4px solid var(--crit)}
.alert-ok{background:#e6f4ea;color:var(--ok);border-left-color:var(--ok)}
.info-strip{display:flex;gap:1.4rem;flex-wrap:wrap;background:#fff;padding:1rem 1.4rem;border-radius:13px;margin-bottom:1.3rem;font-size:.9rem;font-weight:600;box-shadow:var(--card-shadow)}
.empty{padding:1.5rem;text-align:center;color:var(--muted-txt);background:var(--brand-lighter);border-radius:11px;font-style:italic}

/* AI BOX / PLANNING */
.ai-box{border-left:4px solid var(--brand)}
.ai-day{padding:.8rem;border:1px solid #f5eedd;border-radius:11px;margin-bottom:.6rem}
.ai-day.fuori{border-color:var(--crit);background:#fff7f6}

/* SMART PICKER */
.picker-toolbar{display:flex;gap:.6rem;flex-wrap:wrap;margin-bottom:.8rem;align-items:center}
.picker-toolbar input,.picker-toolbar select{flex:1;min-width:140px;margin:0}
.picker-count{background:var(--brand-light);color:var(--brand-darker);padding:.45rem .9rem;border-radius:20px;font-weight:700;font-size:.82rem;white-space:nowrap}
.ticket-pick{max-height:340px;overflow:auto;border:1px solid #f5eedd;border-radius:12px;padding:.5rem;background:var(--brand-lighter)}
.pick-item{display:flex;align-items:center;gap:.7rem;padding:.6rem .65rem;border-radius:10px;transition:.12s;cursor:pointer;border:1.5px solid transparent;margin-bottom:.25rem;background:#fff}
.pick-item:hover{background:var(--brand-light)}
.pick-item.checked{border-color:var(--brand);background:var(--brand-light)}
.pick-item input{width:auto;accent-color:var(--brand);transform:scale(1.2)}
.pick-main{flex:1}
.pick-title{font-weight:700;font-size:.9rem}
.pick-meta{display:flex;gap:.4rem;flex-wrap:wrap;margin-top:.25rem;align-items:center}
.pick-region{font-size:.75rem;color:var(--muted-txt);font-weight:600}
.storico-item{padding:.7rem;border-bottom:1px solid #f5eedd}

/* SUGGERIMENTO USCITE (cards) */
.uscite-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:1rem}
.uscita-card{padding:1.1rem;border-radius:14px;border:1.5px solid #f3ecdd;background:linear-gradient(160deg,#fff,var(--brand-lighter));transition:.18s;position:relative}
.uscita-card:hover{box-shadow:var(--card-shadow);transform:translateY(-2px)}
.uscita-card.fuori{border-color:#f3c7c3;background:linear-gradient(160deg,#fff,#fff7f6)}
.uscita-head{display:flex;justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:.5rem}
.uscita-head strong{font-size:1rem;color:var(--brand-darker)}
.ticket-tags{display:flex;flex-wrap:wrap;gap:.3rem;margin:.7rem 0}
.tag{background:var(--brand-light);color:var(--brand-darker);padding:.12rem .55rem;border-radius:7px;font-size:.75rem;font-weight:700}

/* ASSISTENTE IA */
.hero-ai{display:flex;gap:1.2rem;align-items:flex-start;background:linear-gradient(135deg,#fffdf8,var(--brand-light));border-left:5px solid var(--brand)}
.hero-ai-icon{font-size:2.5rem;line-height:1}
.hero-ai p{font-size:1rem;line-height:1.7}
.ai-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.3rem;margin-bottom:1.3rem}
.ai-item{padding:.8rem;border-radius:11px;margin-bottom:.7rem;background:var(--brand-lighter);border:1px solid #f5eedd}
.ai-item-head{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;margin-bottom:.3rem}
.ai-phone{border-left:4px solid var(--phone)}
.ai-onsite{border-left:4px solid var(--brand)}

/* MODAL */
.modal{position:fixed;inset:0;background:rgba(130,90,20,.32);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:100;animation:fade .2s}
@keyframes fade{from{opacity:0}to{opacity:1}}
.modal.hidden{display:none}
.modal-box{background:#fff;padding:1.7rem;border-radius:18px;max-width:500px;width:92%;box-shadow:0 24px 70px rgba(130,90,20,.28);animation:pop .25s;border-top:5px solid var(--brand)}
@keyframes pop{from{transform:scale(.92);opacity:0}to{transform:scale(1);opacity:1}}
.modal-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:.8rem}
.modal-close{background:none;border:none;font-size:1.8rem;cursor:pointer;color:var(--muted-txt);line-height:1}
.modal-centro{font-weight:700;color:var(--brand-darker);font-size:1.1rem;margin-bottom:1rem}
.modal-field{margin-bottom:1rem}
.modal-field span{display:block;font-size:.72rem;text-transform:uppercase;letter-spacing:.5px;color:var(--muted-txt);font-weight:700;margin-bottom:.2rem}

/* LOGIN (oro & bianco) */
.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,var(--brand-light),#fff 60%,#fdeecb)}
.login-card{background:#fff;padding:2.6rem;border-radius:22px;box-shadow:0 24px 70px rgba(204,145,46,.22);width:360px;text-align:center;border-top:6px solid var(--brand)}
.login-logo{height:64px;margin-bottom:1.2rem}
.login-card h1{margin-bottom:1.4rem;font-size:1.4rem}
.login-card input{text-align:center}

/* RESPONSIVE */
@media(max-width:900px){
  .grid-2,.ai-grid{grid-template-columns:1fr}
  .sidebar{position:fixed;left:-250px;top:62px;bottom:0;transition:.25s;z-index:60;box-shadow:6px 0 30px rgba(0,0,0,.15)}
  .sidebar.open{left:0}
  .menu-toggle{display:block}
  .content{padding:1.1rem}
}/* ===== TRASFERTA INTELLIGENTE ===== */
.trasferta-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.8rem}
.trasferta-grid label{margin-top:0}

.timeline{display:flex;flex-direction:column;gap:.8rem;position:relative;padding-left:.5rem}
.giorno-card{border:1.5px solid #f3ecdd;border-left:5px solid var(--brand);border-radius:13px;padding:1rem 1.1rem;background:linear-gradient(160deg,#fff,var(--brand-lighter));transition:.18s}
.giorno-card:hover{box-shadow:var(--card-shadow)}
.giorno-card.fuori{border-left-color:var(--crit);background:linear-gradient(160deg,#fff,#fff7f6)}
.giorno-head{display:flex;justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:.4rem}
.giorno-data{font-weight:800;color:var(--brand-darker);font-size:1.02rem}
.giorno-tappe{margin:.6rem 0;display:flex;flex-direction:column;gap:.4rem}
.giorno-tappa{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;padding:.4rem .6rem;background:#fff;border-radius:9px;border:1px solid #f5eedd;font-size:.88rem;font-weight:600}
.giorno-note{margin-top:.4rem;font-size:.84rem;color:var(--brand-dark);background:var(--brand-light);padding:.5rem .7rem;border-radius:9px}

/* Loading overlay IA */
.ai-loading{position:fixed;inset:0;background:rgba(255,253,248,.85);backdrop-filter:blur(5px);display:flex;align-items:center;justify-content:center;z-index:200}
.ai-loading.hidden{display:none}
.ai-loading-box{text-align:center;font-size:2.5rem}
.ai-loading-box p{font-size:1rem;font-weight:700;color:var(--brand-darker);margin:.6rem 0}
.spinner{width:42px;height:42px;border:4px solid var(--brand-light);border-top-color:var(--brand);border-radius:50%;margin:.5rem auto 0;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}