:root{
  --bg:#f6f1e6;          /* sabbia */
  --surface:#fffdf8;
  --surface-2:#f1ead9;
  --line:#e5dcc7;
  --text:#2b3540;        /* ardesia */
  --muted:#8a8578;
  --teal:#0e8f84;        /* mare */
  --teal-dim:#0b6d65;
  --booking:#2f6fb8;     /* Booking.com */
  --airbnb:#e5564f;      /* Airbnb */
  --amber:#d98a2b;       /* attenzione / richieste */
  --ok:#3f9d63;
  --danger:#cf4d4d;
  --radius:12px;
  --unitcol:200px;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  background:var(--bg);color:var(--text);
  font-family:'Inter',system-ui,sans-serif;font-size:14px;
  display:flex;min-height:100vh;
}
h1,h2,h3,.brand{font-family:'Outfit',sans-serif}
.mono{font-family:'JetBrains Mono',monospace}
a{color:var(--teal)}

/* ---------- Sidebar ---------- */
aside.sidebar{
  width:220px;flex-shrink:0;background:var(--surface);
  border-right:1px solid var(--line);display:flex;flex-direction:column;
  padding:20px 0;position:sticky;top:0;height:100vh;overflow-y:auto;
}
.brand{display:flex;align-items:center;gap:10px;padding:0 20px 20px;font-weight:700;font-size:17px;letter-spacing:.02em;color:var(--text);text-decoration:none}
.brand .dot{width:26px;height:26px;border-radius:8px;background:linear-gradient(135deg,#f2c14e,var(--teal));display:grid;place-items:center;font-size:13px}
nav.mainnav{flex:1}
nav.mainnav a{
  display:flex;align-items:center;gap:10px;padding:9px 20px;color:var(--muted);
  text-decoration:none;font-weight:500;border-left:2px solid transparent;
}
nav.mainnav a:hover{color:var(--text);background:rgba(14,143,132,.05)}
nav.mainnav a.active{color:var(--teal);border-left-color:var(--teal);background:rgba(14,143,132,.08)}
nav.mainnav a .badge{margin-left:auto;background:var(--amber);color:#fff;border-radius:20px;padding:1px 7px;font-size:11px;font-weight:600}
nav.mainnav .sep{font-size:10px;text-transform:uppercase;letter-spacing:.14em;color:#b0a893;padding:16px 20px 6px}
.tenant-box{padding:14px 20px 0;border-top:1px solid var(--line);font-size:12px;color:var(--muted)}
.tenant-box strong{display:block;color:var(--text);font-size:13px}
.tenant-box .plan{color:var(--teal)}
.tenant-box a{color:var(--muted)}

/* ---------- Main ---------- */
main.bo{flex:1;min-width:0;display:flex;flex-direction:column}
header.topbar{
  display:flex;align-items:center;gap:14px;padding:16px 24px;
  border-bottom:1px solid var(--line);background:var(--surface);
  position:sticky;top:0;z-index:30;
}
header.topbar h1{font-size:18px;font-weight:600}
select.prop, .field select, .field input, .field textarea, .inline-form select, .inline-form input{
  background:var(--surface-2);color:var(--text);border:1px solid var(--line);
  border-radius:8px;padding:7px 10px;font:inherit;font-weight:500;
}
.field input:focus,.field textarea:focus,.field select:focus{outline:2px solid rgba(14,143,132,.35)}
.spacer{flex:1}
.btn{
  background:var(--teal);color:#fff;border:none;border-radius:8px;
  padding:8px 14px;font:inherit;font-weight:600;cursor:pointer;text-decoration:none;display:inline-block;
}
.btn:hover{filter:brightness(1.08)}
.btn.ghost{background:transparent;color:var(--muted);border:1px solid var(--line)}
.btn.ghost:hover{color:var(--text);border-color:var(--muted)}
.btn.danger{background:transparent;color:var(--danger);border:1px solid var(--danger)}
.btn.mini{padding:5px 10px;font-size:12px;border-radius:6px}
.btn.amber{background:var(--amber)}

.content{padding:20px 24px 60px;display:flex;flex-direction:column;gap:18px}

/* ---------- Toolbar calendario ---------- */
.cal-bar{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.cal-bar .month{font-family:'Outfit';font-size:16px;font-weight:600;min-width:190px}
.legend{display:flex;gap:14px;margin-left:auto;flex-wrap:wrap;font-size:12px;color:var(--muted)}
.legend span{display:flex;align-items:center;gap:6px}
.chip{width:12px;height:12px;border-radius:3px;display:inline-block}
.chip.direct{background:var(--teal)}
.chip.booking{background:var(--booking)}
.chip.airbnb{background:var(--airbnb)}
.chip.block{background:repeating-linear-gradient(45deg,#ddd3bd 0 3px,#c5b99d 3px 6px)}
.chip.req{background:#fbf6ea;border:1.5px dashed var(--amber)}

/* ---------- Tape chart ---------- */
.tape{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.tape-head,.tape-row{display:grid;grid-template-columns:var(--unitcol) 1fr}
.tape-head{border-bottom:1px solid var(--line);background:var(--surface-2)}
.tape-head .corner{padding:10px 14px;font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);border-right:1px solid var(--line)}
.days{display:flex}
.day{
  flex:1;text-align:center;padding:8px 0 6px;font-size:11px;color:var(--muted);
  border-right:1px solid rgba(43,53,64,.05);
}
.day .dow{display:block;font-size:10px;text-transform:uppercase;letter-spacing:.08em}
.day .num{font-family:'JetBrains Mono';font-size:13px;color:var(--text)}
.day.we .num{color:var(--amber)}
.day.today{background:rgba(14,143,132,.10)}
.day.today .num{color:var(--teal);font-weight:600}

.prop-row{
  padding:8px 14px;font-family:'Outfit';font-weight:600;font-size:13px;color:var(--teal-dim);
  background:rgba(14,143,132,.06);border-bottom:1px solid var(--line);
}
.tape-row{border-bottom:1px solid var(--line)}
.tape-row:last-child{border-bottom:none}
.unit{padding:12px 14px;border-right:1px solid var(--line)}
.unit b{display:block;font-weight:600;font-size:13px}
.unit small{color:var(--muted);font-size:11px}
.track{position:relative;height:56px;user-select:none}
.grid-cells{display:flex;height:100%}
.cell{flex:1;border-right:1px solid rgba(43,53,64,.05);cursor:crosshair}
.cell.we{background:rgba(217,138,43,.05)}
.cell.today{background:rgba(14,143,132,.07)}
.cell.sel{background:rgba(217,138,43,.28)}

.bar{
  position:absolute;top:10px;height:36px;border-radius:7px;
  display:flex;align-items:center;padding:0 10px;gap:6px;
  font-size:12px;font-weight:500;color:#fff;cursor:pointer;
  overflow:hidden;white-space:nowrap;box-shadow:0 2px 6px rgba(43,53,64,.18);
  transition:filter .12s, transform .12s;border:none;
}
.bar:hover{filter:brightness(1.06);transform:translateY(-1px);z-index:5}
.bar.direct{background:var(--teal)}
.bar.booking{background:var(--booking)}
.bar.airbnb{background:var(--airbnb)}
.bar.request{background:#fbf6ea;border:1.5px dashed var(--amber);color:#a5691c}
.bar.mblock{
  top:14px;height:28px;border-radius:5px;cursor:pointer;color:#5c6672;
  background:repeating-linear-gradient(45deg,#ddd3bd 0 4px,#cfc4ab 4px 8px);
  font-size:11px;
}
.bar .src{font-size:10px;opacity:.75;font-family:'JetBrains Mono'}

/* ---------- Cards ---------- */
.row2{display:grid;grid-template-columns:1.2fr .8fr;gap:18px}
.row3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px}
.card h2{font-size:14px;font-weight:600;margin-bottom:12px;display:flex;align-items:center;gap:8px}
.card h2 .badge{background:var(--amber);color:#fff;border-radius:20px;padding:1px 8px;font-size:11px}
.kpi{display:flex;flex-direction:column;gap:2px}
.kpi .num{font-family:'Outfit';font-size:28px;font-weight:700;color:var(--teal-dim)}
.kpi .lbl{font-size:12px;color:var(--muted)}
.order{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--line)}
.order:last-child{border-bottom:none}
.order .ico{width:34px;height:34px;border-radius:8px;background:var(--surface-2);display:grid;place-items:center;font-size:16px;flex-shrink:0}
.order .what b{font-weight:600;font-size:13px}
.order .what small{display:block;color:var(--muted);font-size:12px;margin-top:1px}
.order .act{margin-left:auto;display:flex;gap:6px;align-items:center;flex-shrink:0}
.order .price{font-family:'JetBrains Mono';font-size:12px;color:var(--muted);margin-right:6px}
.sync{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid var(--line);font-size:13px}
.sync:last-child{border-bottom:none}
.dot-ok,.dot-ko,.dot-na{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.dot-ok{background:var(--ok);box-shadow:0 0 6px rgba(63,157,99,.5)}
.dot-ko{background:var(--danger);box-shadow:0 0 6px rgba(207,77,77,.5)}
.dot-na{background:#c5b99d}
.sync small{margin-left:auto;color:var(--muted);font-family:'JetBrains Mono';font-size:11px}

/* ---------- Tables ---------- */
table.list{width:100%;border-collapse:collapse;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
table.list th{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);text-align:left;padding:10px 12px;background:var(--surface-2);border-bottom:1px solid var(--line)}
table.list td{padding:10px 12px;border-bottom:1px solid var(--line);font-size:13px;vertical-align:middle}
table.list tr:last-child td{border-bottom:none}
table.list tr:hover td{background:rgba(14,143,132,.04)}
.status-pill{display:inline-block;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600}
.st-confirmed{background:rgba(14,143,132,.12);color:var(--teal-dim)}
.st-paid{background:rgba(63,157,99,.14);color:#2c7a4a}
.st-request{background:rgba(217,138,43,.14);color:#a5691c}
.st-cancelled{background:rgba(207,77,77,.12);color:var(--danger)}
.st-pending{background:rgba(217,138,43,.14);color:#a5691c}
.st-done{background:rgba(63,157,99,.14);color:#2c7a4a}
.st-hidden{background:rgba(138,133,120,.15);color:var(--muted)}
.st-published{background:rgba(63,157,99,.14);color:#2c7a4a}
.src-tag{font-family:'JetBrains Mono';font-size:10px;padding:2px 6px;border-radius:4px;color:#fff}
.src-direct{background:var(--teal)}
.src-booking{background:var(--booking)}
.src-airbnb{background:var(--airbnb)}

/* ---------- Forms ---------- */
.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}
.field{display:flex;flex-direction:column;gap:5px}
.field label{font-size:12px;font-weight:600;color:var(--muted)}
.field textarea{min-height:90px;resize:vertical}
.inline-form{display:flex;gap:8px;flex-wrap:wrap;align-items:flex-end}
.tabs{display:flex;gap:4px;border-bottom:1px solid var(--line);margin-bottom:14px}
.tabs button{background:none;border:none;padding:8px 14px;font:inherit;font-weight:600;color:var(--muted);cursor:pointer;border-bottom:2px solid transparent}
.tabs button.active{color:var(--teal);border-bottom-color:var(--teal)}
.error-box{background:rgba(207,77,77,.1);border:1px solid var(--danger);color:var(--danger);border-radius:8px;padding:10px 14px;font-size:13px}
.ok-box{background:rgba(63,157,99,.12);border:1px solid var(--ok);color:#2c7a4a;border-radius:8px;padding:10px 14px;font-size:13px}
.hint{font-size:12px;color:var(--muted)}
code.copy{background:var(--surface-2);border:1px solid var(--line);border-radius:6px;padding:4px 8px;font-family:'JetBrains Mono';font-size:11px;word-break:break-all;cursor:pointer}

/* ---------- Photo grid ---------- */
.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px}
.photo-grid figure{position:relative;border-radius:8px;overflow:hidden;border:1px solid var(--line);background:var(--surface-2);cursor:grab}
.photo-grid img{width:100%;height:110px;object-fit:cover;display:block}
.photo-grid .tools{position:absolute;inset:auto 0 0 0;display:flex;gap:4px;padding:5px;background:linear-gradient(transparent,rgba(43,53,64,.65))}
.photo-grid .tools button{background:rgba(255,253,248,.9);border:none;border-radius:5px;font-size:11px;padding:3px 7px;cursor:pointer}
.photo-grid .coverflag{position:absolute;top:6px;left:6px;background:var(--teal);color:#fff;font-size:10px;font-weight:700;border-radius:5px;padding:2px 6px}

/* ---------- Drawer ---------- */
.drawer{
  position:fixed;top:0;right:0;width:400px;max-width:92vw;height:100vh;
  background:var(--surface);border-left:1px solid var(--line);z-index:60;
  transform:translateX(105%);transition:transform .25s ease;
  display:flex;flex-direction:column;box-shadow:-16px 0 40px rgba(43,53,64,.22);
}
.drawer.open{transform:translateX(0)}
.d-head{padding:18px 20px;border-bottom:1px solid var(--line);display:flex;align-items:flex-start;gap:12px}
.d-head h3{font-size:16px}
.d-head .code{font-family:'JetBrains Mono';font-size:11px;color:var(--muted)}
.d-head .close{margin-left:auto;background:none;border:none;color:var(--muted);font-size:20px;cursor:pointer}
.d-body{padding:18px 20px;overflow-y:auto;flex:1}
.kv{display:grid;grid-template-columns:110px 1fr;gap:8px 12px;font-size:13px;margin-bottom:18px}
.kv dt{color:var(--muted)}
.kv dd{font-weight:500}
.kv dd.mono{font-family:'JetBrains Mono';font-size:12.5px}
.d-body h4{font-size:12px;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);margin:16px 0 8px}
.note{background:var(--surface-2);border-radius:8px;padding:10px 12px;font-size:13px;margin-bottom:8px}
.note small{display:block;color:var(--muted);font-size:11px;margin-top:4px}
.d-foot{padding:14px 20px;border-top:1px solid var(--line);display:flex;gap:8px}
.overlay{position:fixed;inset:0;background:rgba(43,53,64,.32);z-index:50;opacity:0;pointer-events:none;transition:opacity .25s}
.overlay.show{opacity:1;pointer-events:auto}

.toast{
  position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(80px);
  background:#2b3540;border:1px solid var(--teal);color:#fffdf8;
  padding:10px 18px;border-radius:10px;font-size:13px;z-index:80;transition:transform .3s;
}
.toast.show{transform:translateX(-50%) translateY(0)}

/* ---------- Login ---------- */
.login-wrap{margin:auto;width:360px;max-width:92vw;display:flex;flex-direction:column;gap:18px}
.login-wrap .card{padding:26px}
.login-wrap .brand{justify-content:center;padding:0}

/* ---------- Messages ---------- */
.msg{max-width:75%;padding:10px 12px;border-radius:12px;margin-bottom:8px;font-size:13px}
.msg.guest{background:var(--surface-2);border:1px solid var(--line)}
.msg.staff{background:rgba(14,143,132,.12);margin-left:auto}
.msg small{display:block;color:var(--muted);font-size:11px;margin-top:4px}

/* ---------- Responsive ---------- */
.hamburger{
  display:none;background:var(--surface-2);border:1px solid var(--line);
  color:var(--text);border-radius:8px;width:38px;height:38px;font-size:17px;
  cursor:pointer;flex-shrink:0;
}
.side-overlay{position:fixed;inset:0;background:rgba(43,53,64,.35);z-index:90;opacity:0;pointer-events:none;transition:opacity .25s}
.side-overlay.show{opacity:1;pointer-events:auto}

@media (max-width:1100px){
  .row2,.row3{grid-template-columns:1fr}
}
@media (max-width:900px){
  aside.sidebar{
    position:fixed;left:0;top:0;z-index:95;height:100vh;
    transform:translateX(-105%);transition:transform .25s ease;
    box-shadow:16px 0 40px rgba(43,53,64,.22);
  }
  aside.sidebar.open{transform:translateX(0)}
  .hamburger{display:grid;place-items:center}
  header.topbar{padding:12px 14px;flex-wrap:wrap;gap:8px}
  header.topbar h1{font-size:16px}
  select.prop{max-width:46vw}
  .content{padding:14px 12px 60px;gap:14px}
  .btn{padding:7px 11px;font-size:13px}
  :root{--unitcol:120px}
  .unit{padding:9px 8px}
  .unit b{font-size:12px}
  .unit small{font-size:10px}
  .day .dow{display:none}
  .day .num{font-size:12px}
  .bar{font-size:11px;padding:0 6px}
  .bar .src{display:none}
  .drawer{width:100vw;max-width:100vw}
  .legend{margin-left:0;gap:10px}
  table.list{display:block;overflow-x:auto}
}
@media (max-width:520px){
  :root{--unitcol:96px}
  .track{height:50px}
  .bar{top:8px;height:34px}
  .bar.mblock{top:12px;height:26px}
  .cal-bar .month{font-size:14px;min-width:0}
}
