/* Portale Pulizie — design allineato a ghepensimiaffittibrevi.it */
:root{
  --ink:#061c32; --ink-soft:#20384f; --muted:#5a6f80;
  --paper:#f6f8f4; --paper-2:#eef3ea; --white:#fff;
  --green:#2f721f; --green-deep:#1f5315; --green-soft:#e8f3df;
  --blue:#0a315f; --blue-deep:#061c32; --sky:#e2ecf5; --gold:#f1c46b;
  --red:#b42318; --red-soft:#fdecea; --warn:#9a5b00; --warn-soft:#fff4e0;
  --line:rgba(6,28,50,.12); --line-strong:rgba(6,28,50,.2);
  --radius-s:10px; --radius:16px; --radius-l:26px;
  --shadow-s:0 8px 24px rgba(6,28,50,.08); --shadow:0 22px 60px rgba(6,28,50,.14);
  --shadow-green:0 18px 40px rgba(47,114,31,.25);
  --font-sans:"Inter",system-ui,-apple-system,"Segoe UI",Roboto,Arial,sans-serif;
  --font-display:"Fraunces",Georgia,"Times New Roman",serif;
}
*{box-sizing:border-box}
body{margin:0;color:var(--ink);background:var(--paper);font-family:var(--font-sans);
  font-size:16px;line-height:1.55;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:600;line-height:1.12;letter-spacing:-.01em;margin:0}
button,input,select{font:inherit;color:inherit}

/* ---- header ---- */
header.top{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;
  gap:16px;padding:12px clamp(16px,4vw,40px);background:rgba(255,255,255,.92);
  backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
header.top .brand{display:flex;align-items:center;gap:12px}
header.top .brand img{height:32px;width:auto}
header.top .brand span{font-weight:600;font-size:14px;color:var(--ink-soft);
  border-left:1px solid var(--line);padding-left:12px}
.topnav{display:flex;align-items:center;gap:12px;font-size:14px;flex-wrap:wrap}
.topnav .who{color:var(--muted);font-weight:600}

/* ---- layout ---- */
main{max-width:1080px;margin:0 auto;padding:clamp(18px,4vw,36px) clamp(14px,4vw,36px)}
h1{font-size:clamp(24px,4vw,32px)}
.sub{color:var(--muted);font-size:15px;margin:6px 0 20px}

/* ---- KPI strip ---- */
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin:6px 0 20px}
.kpi{background:var(--white);border:1px solid var(--line);border-radius:var(--radius-s);padding:13px 15px;box-shadow:var(--shadow-s)}
.kpi .lbl{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);font-weight:700}
.kpi .val{font-family:var(--font-display);font-size:24px;font-weight:600;margin-top:4px;font-variant-numeric:tabular-nums}
.kpi.alert .val{color:var(--red)} .kpi.warn .val{color:var(--warn)} .kpi.good .val{color:var(--green)}

/* ---- toolbar ---- */
.toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:14px}
.toolbar .range{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--muted)}
.toolbar input[type=date]{border:1px solid var(--line);border-radius:8px;padding:7px 10px;background:var(--white)}

/* ---- day group ---- */
.day{margin:22px 0 10px}
.day h3{font-size:17px;display:flex;align-items:center;gap:10px}
.day h3 .count{font-family:var(--font-sans);font-size:12px;font-weight:700;color:var(--muted);
  background:var(--paper-2);border-radius:999px;padding:2px 10px}
.day.today h3::before{content:"OGGI";font-family:var(--font-sans);font-size:11px;font-weight:800;
  color:#fff;background:var(--green);border-radius:999px;padding:3px 9px}

/* ---- task card ---- */
.task{background:var(--white);border:1px solid var(--line);border-left:4px solid var(--green);
  border-radius:var(--radius);padding:14px 16px;box-shadow:var(--shadow-s);margin:10px 0}
.task.turnover{border-left-color:var(--red)}
.task.intermedio{border-left-color:var(--gold)}
.task.done{opacity:.62}
.task .row1{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap}
.task .name{font-family:var(--font-display);font-size:18px;font-weight:600}
.task .loc{color:var(--muted);font-size:13.5px;margin-top:1px}
.task .meta{display:flex;gap:14px;flex-wrap:wrap;font-size:13.5px;color:var(--ink-soft);margin-top:10px}
.task .meta b{font-weight:700}

/* ---- badges ---- */
.badge{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:800;
  text-transform:uppercase;letter-spacing:.04em;border-radius:999px;padding:4px 10px}
.badge.urg{background:var(--red-soft);color:var(--red)}
.badge.free{background:var(--green-soft);color:var(--green-deep)}
.badge.mid{background:var(--warn-soft);color:var(--warn)}
.badge.ch{background:var(--sky);color:var(--blue)}
.badge.st-da_assegnare{background:var(--paper-2);color:var(--ink-soft)}
.badge.st-assegnata{background:var(--sky);color:var(--blue)}
.badge.st-completata{background:var(--green-soft);color:var(--green-deep)}

/* ---- linen line ---- */
.linen{font-size:13px;color:var(--ink-soft);margin-top:8px}
.linen .chip{display:inline-block;background:var(--paper);border:1px solid var(--line);
  border-radius:999px;padding:3px 10px;margin:2px 4px 2px 0}

/* ---- task actions ---- */
.actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:12px;padding-top:12px;border-top:1px solid var(--line)}
.actions form{display:inline-flex;align-items:center;gap:6px;margin:0}
select,.btn{border-radius:999px}
select{border:1px solid var(--line-strong);padding:8px 12px;background:var(--white)}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:8px 16px;font-weight:700;
  font-size:14px;border:1.5px solid transparent;cursor:pointer;background:var(--green);color:#fff;box-shadow:var(--shadow-green);transition:.15s}
.btn:hover{background:var(--green-deep);transform:translateY(-1px)}
.btn.ghost{background:transparent;border-color:var(--line-strong);color:var(--ink);box-shadow:none}
.btn.ghost:hover{border-color:var(--ink);background:rgba(0,0,0,.03);transform:none}
.btn.wa{background:#25D366;box-shadow:none;color:#073b22}
.btn.wa:hover{background:#1ebe5b}
.btn.small{padding:6px 12px;font-size:13px}
.assignee{font-size:13.5px;font-weight:700;color:var(--blue)}

/* ---- laundry totals ---- */
.totali{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);
  padding:16px 18px;box-shadow:var(--shadow-s);margin:8px 0 18px}
.totali h4{font-size:15px;margin-bottom:10px}
.totali .vals{display:flex;gap:22px;flex-wrap:wrap}
.totali .v{display:flex;flex-direction:column}
.totali .v b{font-family:var(--font-display);font-size:22px}
.totali .v span{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;font-weight:700}

/* ---- responsabili per appartamento ---- */
.resp-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:12px}
.resp-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:0;
  background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-s);padding:12px 14px}
.resp-app{display:flex;flex-direction:column}
.resp-app b{font-size:15px}
.resp-app span{font-size:12px;color:var(--muted)}
.resp-row select{flex:0 0 auto;max-width:55%}

/* ---- calendario ---- */
.cal-head{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}
.cal-nav{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.cal-month{font-family:var(--font-display);font-size:20px;font-weight:600;min-width:150px;text-align:center}
.cal-legend{display:flex;align-items:center;gap:18px;flex-wrap:wrap;margin:14px 0 8px;font-size:13px;color:var(--ink-soft)}
.cal-legend .muted{color:var(--muted)}
.cal-legend .dot{display:inline-block;width:10px;height:10px;border-radius:3px;margin-right:6px;vertical-align:middle}
.cal-legend .dot.g{background:var(--green)} .cal-legend .dot.r{background:var(--red)} .cal-legend .dot.y{background:var(--gold)}

.cal{margin-top:6px;border:1px solid var(--line);border-top-left-radius:var(--radius);border-top-right-radius:var(--radius);
  overflow:hidden;background:var(--white)}
.cal-row{display:grid;grid-template-columns:repeat(7,1fr)}
.cal-dow-cell{padding:9px;text-align:center;font-size:11px;font-weight:700;text-transform:uppercase;
  letter-spacing:.05em;color:var(--muted);background:var(--paper-2);border-bottom:1px solid var(--line)}
.cal-cell{min-height:108px;border-right:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:6px;display:flex;flex-direction:column;gap:4px;background:var(--white)}
.cal-cell:nth-child(7n){border-right:0}
.cal-cell.out{background:var(--paper)}
.cal-cell.today{background:var(--green-soft)}
.cal-day{display:flex;align-items:center;justify-content:space-between;font-size:12px;font-weight:700;color:var(--ink-soft)}
.cal-cell.out .cal-day{opacity:.45}
.cal-day .n{font-size:10px;font-weight:800;color:#fff;background:var(--ink-soft);border-radius:999px;padding:1px 6px}
.cal-task{display:flex;justify-content:space-between;gap:4px;font-size:11.5px;line-height:1.25;padding:3px 6px;
  border-radius:6px;background:var(--green-soft);color:var(--green-deep);border-left:3px solid var(--green)}
.cal-task .ap{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cal-task .who{flex:0 0 auto;font-weight:700;opacity:.85}
.cal-task.turnover{background:var(--red-soft);color:var(--red);border-left-color:var(--red)}
.cal-task.intermedio{background:var(--warn-soft);color:var(--warn);border-left-color:var(--gold)}
.cal-task.done{opacity:.5;text-decoration:line-through}
@media (max-width:640px){
  .cal{overflow-x:auto}
  .cal-row{min-width:660px}
}

.empty{background:var(--white);border:1px dashed var(--line-strong);border-radius:var(--radius);
  padding:34px;text-align:center;color:var(--muted)}

/* ---- login ---- */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}
.login-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius-l);
  box-shadow:var(--shadow);padding:34px;max-width:380px;width:100%}
.login-card img{height:38px;margin:0 auto 18px}
.login-card h1{font-size:24px;text-align:center;margin-bottom:4px}
.login-card .sub{text-align:center;margin-bottom:22px}
.field{margin-bottom:14px}
.field label{display:block;font-size:13px;font-weight:700;color:var(--ink-soft);margin-bottom:6px}
.field input{width:100%;border:1px solid var(--line-strong);border-radius:10px;padding:11px 13px;background:var(--paper)}
.login-card .btn{width:100%;padding:12px}
.err{background:var(--red-soft);color:var(--red);border-radius:10px;padding:10px 12px;font-size:14px;margin-bottom:14px;text-align:center}

footer{text-align:center;color:var(--muted);font-size:13px;padding:30px 0}

@media (max-width:560px){
  .task .row1{flex-direction:column}
  .actions{flex-direction:column;align-items:stretch}
  .actions form{justify-content:space-between}
  .btn,select{width:100%}
}
