:root{
  --m-bg:#fde68a; --m-fg:#92400e;   /* Mattina  */
  --p-bg:#bfdbfe; --p-fg:#1e3a8a;   /* Pomeriggio */
  --r-bg:#e5e7eb; --r-fg:#374151;   /* Riposo */
  --f-bg:#bbf7d0; --f-fg:#065f46;   /* Ferie */
  --line:#e5e7eb; --ink:#1f2937; --muted:#9ca3af;
}
*{box-sizing:border-box}
body{
  margin:0; font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  color:var(--ink); background:#f8fafc; overflow-x:hidden;
}

/* --- Login --- */
.login-page{display:flex; min-height:100vh; align-items:center; justify-content:center; padding:16px}
.login-card{
  background:#fff; padding:28px 24px; border-radius:16px; width:100%; max-width:360px;
  box-shadow:0 10px 30px rgba(0,0,0,.08); text-align:center;
}
.login-card h1{margin:0 0 2px; font-size:24px}
.login-card .sub{margin:0 0 18px; color:var(--muted)}
.login-card label{display:block; text-align:left; font-size:13px; color:#374151; margin:10px 0 4px}
.login-card input{
  width:100%; padding:11px 12px; border:1px solid var(--line); border-radius:10px; font-size:16px;
}
.login-card button{
  margin-top:18px; width:100%; padding:12px; border:0; border-radius:10px; cursor:pointer;
  background:#2563eb; color:#fff; font-size:16px; font-weight:600;
}
.alert{background:#fee2e2; color:#991b1b; padding:9px 12px; border-radius:10px; font-size:14px; margin-bottom:8px}

/* --- Topbar --- */
.topbar{
  display:flex; align-items:center; justify-content:space-between;
  background:#fff; padding:12px 16px; border-bottom:1px solid var(--line); position:sticky; top:0; z-index:5;
}
.brand{font-weight:700}
.user{display:flex; align-items:center; gap:12px; font-size:14px}
.logout{color:#2563eb; text-decoration:none}

main{max-width:900px; margin:0 auto; padding:16px}

.navmonth{display:flex; align-items:center; justify-content:center; gap:18px; margin:6px 0 14px}
.navmonth h2{margin:0; font-size:20px; min-width:190px; text-align:center; text-transform:capitalize}
.navbtn{
  text-decoration:none; color:var(--ink); background:#fff; border:1px solid var(--line);
  width:38px; height:38px; border-radius:10px; display:grid; place-items:center; font-size:22px;
}

.legend{display:flex; align-items:center; gap:8px; flex-wrap:wrap; font-size:13px; color:#374151; justify-content:center}
.hint{text-align:center; color:var(--muted); font-size:13px; margin:8px 0 14px}

/* --- Griglia --- */
.grid{display:grid; grid-template-columns:repeat(6,minmax(0,1fr)); gap:6px}
.head{text-align:center; font-weight:600; color:#6b7280; font-size:13px; padding:4px 0}
.day{
  background:#fff; border:1px solid var(--line); border-radius:10px; min-height:78px;
  padding:6px; cursor:pointer; transition:box-shadow .12s, transform .12s;
}
.day[data-date]:hover{box-shadow:0 4px 12px rgba(0,0,0,.08); transform:translateY(-1px)}
.day.out{background:#f3f4f6; color:var(--muted); cursor:default; border-style:dashed}
.day.today{border-color:#2563eb; box-shadow:0 0 0 2px rgba(37,99,235,.25)}
.daynum{font-size:13px; font-weight:600; color:#6b7280; margin-bottom:4px}
.day.today .daynum{color:#2563eb}

.badges{display:flex; flex-direction:column; gap:4px}
.person{display:flex; align-items:center; gap:5px; font-size:12px; border-radius:7px; padding:1px 3px}
.person .pname{color:var(--muted); width:26px}
.person:not(.me){opacity:.5}                        /* l'altro: piu' sbiadito */
.person.me{font-weight:800; background:#e7f0ff}     /* TU: riga evidenziata */
.person.me .pname{color:#2563eb; font-weight:800}
.person.me .badge{font-size:16px; min-width:28px; padding:3px 9px}  /* TU: turno piu' grande */

.badge{
  display:inline-block; min-width:22px; text-align:center; font-weight:800;
  border-radius:6px; padding:1px 5px; font-size:13px; line-height:1.4;
}
.st-M{background:var(--m-bg); color:var(--m-fg)}
.st-P{background:var(--p-bg); color:var(--p-fg)}
.st-R{background:var(--r-bg); color:var(--r-fg)}
.st-F{background:var(--f-bg); color:var(--f-fg)}
.st-empty{background:#f3f4f6; color:transparent; min-width:22px}

/* --- Modale --- */
.overlay{
  position:fixed; inset:0; background:rgba(15,23,42,.45);
  display:flex; align-items:flex-end; justify-content:center; z-index:20;
}
.overlay.hidden{display:none}
.modal{
  background:#fff; width:100%; max-width:420px; border-radius:18px 18px 0 0;
  padding:20px 18px 24px; box-shadow:0 -10px 30px rgba(0,0,0,.15);
}
.modal h3{margin:0 0 2px}
.modal-sub{margin:0 0 16px; color:var(--muted); font-size:14px}
.choices{display:grid; grid-template-columns:repeat(4,1fr); gap:8px}
.ch{
  display:flex; flex-direction:column; align-items:center; gap:2px; cursor:pointer;
  border:1px solid var(--line); border-radius:12px; padding:12px 4px; font-size:20px; font-weight:800;
}
.ch small{font-size:11px; font-weight:600; opacity:.8}
.clearbtn{
  margin-top:12px; width:100%; padding:11px; border:1px solid var(--line); background:#fff;
  border-radius:12px; cursor:pointer; color:#b91c1c; font-weight:600;
}
.closebtn{
  margin-top:8px; width:100%; padding:11px; border:0; background:#f1f5f9;
  border-radius:12px; cursor:pointer; font-weight:600;
}

@media (min-width:560px){
  .overlay{align-items:center}
  .modal{border-radius:18px}
}
@media (max-width:430px){
  .person .pname{width:24px}
  .day{min-height:72px; padding:5px}
  main{padding:10px}
  .grid{gap:4px}
  .navmonth h2{min-width:0}
}

/* --- Richieste: topbar + marcatori --- */
.reqlink{color:#2563eb; text-decoration:none; font-weight:600}
.count{
  display:inline-block; min-width:18px; text-align:center; background:#ef4444; color:#fff;
  border-radius:10px; padding:0 6px; font-size:12px; font-weight:700; margin-left:2px;
}
.pmark{font-size:12px}

/* --- Pannello richieste --- */
.panel{margin-top:26px; background:#fff; border:1px solid var(--line); border-radius:14px; padding:16px}
.panel h3{margin:0 0 10px; font-size:16px}
.panel h3.mt{margin-top:20px}
.panel .empty{color:var(--muted); font-size:14px; margin:0 0 4px}
.reqcard{border:1px solid var(--line); border-radius:12px; padding:10px 12px; margin-bottom:8px}
.reqcard.in{border-left:4px solid #2563eb}
.reqcard.out{border-left:4px solid #f59e0b}
.reqcard.accepted{border-left:4px solid #10b981; color:#374151; font-size:14px}
.reqcard.rejected{border-left:4px solid #ef4444; color:#374151; font-size:14px}
.reqhead{font-size:14px}
.reqcomment{font-size:13px; color:#475569; font-style:italic; margin-top:4px}
.reqcomment.inline{display:inline; margin:0}
.reqactions{display:flex; gap:8px; align-items:center; margin-top:10px; flex-wrap:wrap}
.respc{flex:1; min-width:140px; padding:8px 10px; border:1px solid var(--line); border-radius:9px; font-size:14px}
button.ok,button.no,button.link{cursor:pointer; border-radius:9px; font-weight:600; font-size:14px; padding:8px 12px; border:0}
button.ok{background:#10b981; color:#fff}
button.no{background:#ef4444; color:#fff}
button.link{background:none; color:#2563eb; padding:6px 4px; text-decoration:underline}

/* --- Modale: stato attuale + richiesta + sezioni --- */
.m-current{font-size:14px; color:#374151; background:#f8fafc; border:1px solid var(--line);
  border-radius:10px; padding:8px 10px; margin-bottom:12px}
.m-pending{border-radius:12px; padding:10px 12px; margin-bottom:14px}
.m-pending.hidden{display:none}
.m-pending.in,.m-pending{background:#eff6ff; border:1px solid #bfdbfe}
.m-pending .mp-c{font-size:13px; color:#475569; font-style:italic; margin-top:4px}
.mp-btns{display:flex; gap:8px; margin-top:10px}
.mp-btns.hidden{display:none}
.m-section{margin-top:6px; margin-bottom:14px}
.m-label{font-size:13px; font-weight:600; color:#374151; margin-bottom:8px}
.m-label small{font-weight:400; color:var(--muted)}
.choices2{display:flex; gap:8px}
.choices2 .ch{flex:1}
.ch.clear{background:#fff; color:#b91c1c}
.m-comment{width:100%; margin-top:10px; padding:9px 11px; border:1px solid var(--line);
  border-radius:10px; font-size:14px; font-family:inherit; resize:vertical; min-height:46px}
.m-comment.hidden{display:none}

/* Casella con proposta IN ATTESA: grigia e tratteggiata (diventa bianca quando accettata) */
.day.pending{background:#dde2e8; border-style:dashed; border-color:#9aa6b4}
.day.pending:hover{background:#d2d9e2}
.legend-cell{display:inline-block; width:20px; height:14px; background:#dde2e8;
  border:1px dashed #9aa6b4; border-radius:4px; vertical-align:middle}

/* === Cella interamente colorata dal turno di CHI E' LOGGATO === */
.day.my-M{background:var(--m-bg)}
.day.my-P{background:var(--p-bg)}
.day.my-R{background:var(--r-bg)}
.day.my-F{background:var(--f-bg)}
.day.my-none{background:#fff}
.day.my-pending{background:#e6eaf0; border-style:dashed; border-color:#9aa6b4}

.myturn-big{display:flex; flex-direction:column; align-items:center; justify-content:center; gap:1px; padding:4px 0 2px}
.myturn-big .ico{font-size:20px; line-height:1}
.myturn-big .word{font-size:11px; font-weight:800; line-height:1.05; text-align:center; overflow-wrap:anywhere}
.myturn-big .word.empty{font-weight:600; color:#aeb6c2}
.day.my-M .myturn-big{color:var(--m-fg)}
.day.my-P .myturn-big{color:var(--p-fg)}
.day.my-R .myturn-big{color:var(--r-fg)}
.day.my-F .myturn-big{color:var(--f-fg)}
.day.my-pending .myturn-big{color:#4b5563}

/* Riga piccola dell'altra persona (leggibile su qualunque colore) */
.otherturn{display:flex; align-items:center; justify-content:center; gap:4px;
  font-size:10px; color:#475569; background:rgba(255,255,255,.65);
  border-radius:6px; padding:1px 5px; margin-top:3px}
.otherturn .oname{opacity:.8}
.otherturn .omini{font-weight:800}

/* Oggi piu' marcato + Sabato distinto */
.day.today{border-color:#2563eb; box-shadow:0 0 0 3px rgba(37,99,235,.4)}
.todaytag{background:#2563eb; color:#fff; font-size:9px; font-weight:700;
  border-radius:6px; padding:0 5px; margin-left:3px; vertical-align:middle}
.head.sat{color:#b45309}
.day.sat .daynum{color:#b45309}

/* Giorni PASSATI opacizzati · OGGI in rilievo (.day.today sopra) · futuri normali */
.day.past{opacity:.45}
.day.past:hover{opacity:.9}
.day.today{position:relative; z-index:2}

@media (max-width:430px){
  .myturn-big .ico{font-size:18px}
  .myturn-big .word{font-size:10px}
}
