/* ============================================================
   Music Dashboard — restyle minimal / grafite / squadrato
   Carattere: Geist (grotesque) · densità compatta · responsive
   ============================================================ */

:root{
  --bg:#fafafa;
  --panel:#ffffff;
  --ink:#0b0b0c;
  --ink-2:#646469;
  --ink-3:#9a9aa0;
  --line:#e8e8ea;
  --line-strong:#d8d8db;
  --subtle:#f5f5f6;
  --accent:#111113;
  --accent-ink:#ffffff;
  --accent-hover:#2c2c30;
  --ok:#137a4b;        --ok-bg:#eef7f1;       --ok-line:#cfe7da;
  --warn:#946400;      --warn-bg:#fbf6e9;     --warn-line:#ecdfb8;
  --danger:#c5392b;    --danger-bg:#fbeeec;   --danger-line:#f0cfcb;
  --info-bg:#f1f1f2;
  --radius:3px;
  --radius-lg:5px;
  --sidebar-w:218px;
  --font:'Geist','Geist Fallback',system-ui,-apple-system,'Segoe UI',sans-serif;
  --mono:'Geist Mono',ui-monospace,'SF Mono','SFMono-Regular',Menlo,monospace;
}

*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:var(--font);
  font-size:14px;
  line-height:1.45;
  color:var(--ink);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
a{color:inherit;text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3,h4,p{margin:0}
code{
  font-family:var(--mono);
  font-size:.86em;
  background:var(--subtle);
  border:1px solid var(--line);
  padding:1px 5px;
  border-radius:var(--radius);
}
::selection{background:var(--ink);color:#fff}

/* ---------- Icone (sprite SVG a tratto) ---------- */
svg.ico{
  width:16px;height:16px;flex:none;
  stroke:currentColor;fill:none;
  stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round;
  vertical-align:middle;
}
svg.ico.fill{fill:currentColor;stroke:none}
svg.ico.lg{width:20px;height:20px}
svg.ico.xl{width:26px;height:26px}
.icon-sprite{position:absolute;width:0;height:0;overflow:hidden}

/* ============================================================
   LAYOUT
   ============================================================ */
.layout{display:flex;min-height:100vh;align-items:stretch}

.sidebar{
  width:var(--sidebar-w);flex:none;
  position:sticky;top:0;align-self:flex-start;
  height:100vh;
  display:flex;flex-direction:column;
  background:var(--panel);
  border-right:1px solid var(--line);
  padding:18px 14px;
}
.brand{
  display:flex;align-items:center;gap:9px;
  font-weight:600;font-size:15px;letter-spacing:-.01em;
  padding:4px 8px 16px;
}
.brand svg.ico{width:20px;height:20px}
.sidebar nav{display:flex;flex-direction:column;gap:2px}
.sidebar nav a{
  display:flex;align-items:center;gap:10px;
  padding:8px 10px;border-radius:var(--radius);
  color:var(--ink-2);font-size:13.5px;font-weight:500;
  position:relative;line-height:1;
}
.sidebar nav a svg.ico{width:17px;height:17px;color:var(--ink-3)}
.sidebar nav a:hover{background:var(--subtle);color:var(--ink);text-decoration:none}
.sidebar nav a:hover svg.ico{color:var(--ink-2)}
.sidebar nav a.active{background:var(--subtle);color:var(--ink);font-weight:600}
.sidebar nav a.active svg.ico{color:var(--ink)}
.sidebar nav a.active::before{
  content:"";position:absolute;left:0;top:6px;bottom:6px;width:2px;
  background:var(--ink);border-radius:2px;
}
.sidebar-foot{
  margin-top:auto;padding-top:14px;border-top:1px solid var(--line);
  display:flex;flex-direction:column;gap:8px;
}
.sidebar-foot .user{
  display:flex;align-items:center;gap:8px;
  font-size:12.5px;color:var(--ink-2);padding:2px 8px;
}
.sidebar-foot .user svg.ico{width:16px;height:16px;color:var(--ink-3)}
.sidebar-foot .logout{
  display:inline-flex;align-items:center;gap:7px;
  font-size:12.5px;color:var(--ink-2);padding:6px 8px;border-radius:var(--radius);
}
.sidebar-foot .logout:hover{background:var(--subtle);color:var(--danger);text-decoration:none}

.content{
  flex:1;min-width:0;
  padding:26px 30px 60px;
  max-width:1180px;
}

/* ============================================================
   TESTATE / TESTO
   ============================================================ */
.page-head{margin-bottom:18px}
.page-head h1{
  display:flex;align-items:center;gap:9px;
  font-size:21px;font-weight:600;letter-spacing:-.02em;line-height:1.15;
}
.page-head h1 svg.ico{width:19px;height:19px;color:var(--ink-2)}
.page-head .muted{margin-top:5px;max-width:70ch}
.page-head .back{
  display:inline-flex;align-items:center;gap:6px;
  font-size:12.5px;color:var(--ink-2);margin-bottom:9px;
}
.page-head .back:hover{color:var(--ink);text-decoration:none}
.muted{color:var(--ink-2);font-size:13px}
small.muted{font-size:11.5px}

/* ============================================================
   BANNER / FLASH
   ============================================================ */
.banner,.flash,.conn-row{
  display:flex;align-items:center;gap:10px;flex-wrap:wrap;
  font-size:13px;
  padding:10px 13px;border:1px solid var(--line);border-radius:var(--radius);
  background:var(--info-bg);
}
.banner svg.ico,.flash svg.ico,.conn-row svg.ico{color:var(--ink-2)}
.banner{margin-bottom:16px;background:var(--panel)}
.banner .btn-primary,.banner .btn-danger-sm,.conn-row .btn-primary,.conn-row .btn-danger-sm{margin-left:auto}
.banner.warn{background:var(--warn-bg);border-color:var(--warn-line)}
.banner.warn svg.ico{color:var(--warn)}
.banner.ok{background:var(--ok-bg);border-color:var(--ok-line)}
.banner.ok svg.ico{color:var(--ok)}

.flash{margin-bottom:12px}
.flash.success,.flash.ok{background:var(--ok-bg);border-color:var(--ok-line);color:#0e5e3a}
.flash.error,.flash.danger{background:var(--danger-bg);border-color:var(--danger-line);color:#9a2c20}
.flash.warning,.flash.warn{background:var(--warn-bg);border-color:var(--warn-line);color:#75500a}
.flash.message,.flash.info{background:var(--info-bg)}

.conn-row{margin:4px 0 14px}
.conn-row.ok{background:var(--ok-bg);border-color:var(--ok-line);color:#0e5e3a}
.conn-row.ok svg.ico{color:var(--ok)}

/* ============================================================
   PULSANTI
   ============================================================ */
button{font-family:inherit}
.btn-primary,.btn-ghost,.btn-danger-sm,.as-summary{
  display:inline-flex;align-items:center;gap:7px;justify-content:center;
  font-family:inherit;font-size:13px;font-weight:500;line-height:1;
  padding:8px 14px;border-radius:var(--radius);
  border:1px solid transparent;cursor:pointer;
  transition:background .12s,border-color .12s,color .12s;
  text-decoration:none;white-space:nowrap;
}
.btn-primary svg.ico,.btn-ghost svg.ico,.btn-danger-sm svg.ico{width:15px;height:15px}
.btn-primary{background:var(--accent);color:var(--accent-ink);border-color:var(--accent)}
.btn-primary:hover{background:var(--accent-hover);border-color:var(--accent-hover);text-decoration:none}
.btn-primary:disabled{opacity:.4;cursor:not-allowed}
.btn-primary.big{padding:10px 18px;font-size:13.5px}
.btn-ghost{background:var(--panel);color:var(--ink);border-color:var(--line-strong)}
.btn-ghost:hover{background:var(--subtle);text-decoration:none}
.btn-danger-sm{background:var(--panel);color:var(--danger);border:1px solid var(--danger-line);padding:7px 12px;font-size:12.5px}
.btn-danger-sm:hover{background:var(--danger-bg)}
.icon-btn{
  display:inline-flex;align-items:center;justify-content:center;
  width:30px;height:30px;padding:0;
  background:transparent;border:1px solid transparent;border-radius:var(--radius);
  color:var(--ink-3);cursor:pointer;
}
.icon-btn svg.ico{width:16px;height:16px}
.icon-btn:hover{background:var(--danger-bg);color:var(--danger)}

.badge{
  display:inline-flex;align-items:center;gap:6px;
  font-family:inherit;font-size:11.5px;font-weight:600;letter-spacing:.02em;
  padding:4px 9px;border-radius:var(--radius);cursor:pointer;
  border:1px solid var(--line-strong);background:var(--panel);color:var(--ink-2);
}
.badge.on{background:var(--ink);border-color:var(--ink);color:#fff}
.badge.off{background:var(--subtle);color:var(--ink-3)}
.badge::before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor;opacity:.7}

/* ============================================================
   CARD / GRIGLIE
   ============================================================ */
.card{
  background:var(--panel);
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  padding:16px 18px;
  margin-bottom:16px;
}
.card>h3,.card-head h3{
  display:flex;align-items:center;gap:8px;
  font-size:14px;font-weight:600;letter-spacing:-.01em;
}
.card>h3{margin-bottom:12px}
.card>h3 svg.ico,.card-head h3 svg.ico{width:16px;height:16px;color:var(--ink-2)}
.card>h3+.muted,.card-head+.muted{margin-top:-6px;margin-bottom:12px}
.card-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}

.grid-2{display:grid;grid-template-columns:1.4fr 1fr;gap:16px;align-items:start}
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}

.stat-row{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:18px}
.stat{
  display:flex;align-items:baseline;gap:7px;
  background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  padding:10px 14px;font-size:12.5px;color:var(--ink-2);
}
.stat-num{font-size:20px;font-weight:600;color:var(--ink);letter-spacing:-.02em}

.empty{
  text-align:center;padding:40px 20px;
  border:1px dashed var(--line-strong);border-radius:var(--radius-lg);
  background:var(--panel);color:var(--ink-2);
}
.empty p{margin-bottom:14px}
.empty .btn-primary{display:inline-flex}

/* ---------- Device card (dashboard) ---------- */
.device-card{display:flex;flex-direction:column;margin-bottom:0}
.device-card .card-head{margin-bottom:12px}
.device-card h3{font-size:14px}
.time-badge{
  display:inline-flex;align-items:center;gap:5px;
  font-family:var(--mono);font-size:11.5px;color:var(--ink-2);
  background:var(--subtle);border:1px solid var(--line);
  padding:3px 7px;border-radius:var(--radius);white-space:nowrap;
}
.time-badge svg.ico{width:13px;height:13px}
.now-playing{display:flex;gap:12px;align-items:center;margin-bottom:14px;flex:1}
.now-playing img{width:54px;height:54px;border-radius:var(--radius);object-fit:cover;flex:none;border:1px solid var(--line)}
.np-label{
  font-size:10.5px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;
  color:var(--ink-3);
}
.np-title{font-size:14px;font-weight:600;margin-top:2px;letter-spacing:-.01em}
.np-title.muted{font-weight:500}
.np-reason{font-size:12px;color:var(--ink-2);margin-top:2px}
.device-card .btn-ghost{align-self:flex-start;margin-top:auto}

/* ============================================================
   TABELLE
   ============================================================ */
.table{width:100%;border-collapse:collapse;font-size:13px}
.table th{
  text-align:left;font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.05em;
  color:var(--ink-3);padding:0 10px 8px;border-bottom:1px solid var(--line);
}
.table td{padding:9px 10px;border-bottom:1px solid var(--line)}
.table tr:last-child td{border-bottom:none}
.table td a{font-weight:500}
.table td a:hover{text-decoration:underline}
.table .right{text-align:right}
.table tbody tr:hover{background:var(--subtle)}

/* ============================================================
   FORM
   ============================================================ */
label{display:block;font-size:13px}
.big-form label,form>label,.inline-label{
  display:block;font-size:12.5px;font-weight:500;color:var(--ink-2);margin-bottom:12px;
}
input,select,textarea{
  font-family:inherit;font-size:13.5px;color:var(--ink);
  width:100%;
  background:var(--panel);
  border:1px solid var(--line-strong);border-radius:var(--radius);
  padding:8px 10px;margin-top:5px;
  transition:border-color .12s,box-shadow .12s;
}
input::placeholder{color:var(--ink-3)}
input:focus,select:focus,textarea:focus{
  outline:none;border-color:var(--ink);box-shadow:0 0 0 3px rgba(17,17,19,.07);
}
input[type=checkbox],input[type=radio]{width:auto;margin:0;accent-color:var(--ink)}
input[type=date],input[type=time]{min-width:0}

.inline-form{display:flex;gap:8px;flex-wrap:wrap;align-items:flex-start}
.inline-form input{margin-top:0}
.inline-form .btn-primary{flex:none}

.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-row .inline-label{margin-bottom:0}

.field{margin-bottom:16px}
.field-label{
  display:block;font-size:12.5px;font-weight:600;color:var(--ink);margin-bottom:8px;
}
.field-label .muted{font-weight:400}
.time-field .time-row{margin-top:0}
.time-row{display:flex;gap:12px;margin-top:5px}
.time-row.wrap{flex-wrap:wrap}
.time-row .inline-label{flex:1;min-width:130px;margin-bottom:0}

.toggle{
  display:flex;align-items:center;gap:9px;
  font-size:13px;font-weight:500;color:var(--ink);cursor:pointer;margin:4px 0 16px;
}
.toggle input{margin:0}

.copybox{display:flex;gap:8px}
.copybox input{margin-top:0;font-family:var(--mono);font-size:12px;color:var(--ink-2)}
.copybox .btn-ghost{flex:none}

.danger-zone{margin-top:22px;padding-top:16px;border-top:1px solid var(--line);display:flex;justify-content:flex-end}

/* ---------- details / collapsible ---------- */
details{margin:0}
summary{list-style:none;cursor:pointer}
summary::-webkit-details-marker{display:none}
.collapsible summary{display:flex;align-items:center;gap:8px}
.collapsible summary h3{font-size:14px;font-weight:600;display:flex;align-items:center;gap:8px}
.collapsible summary::after{
  content:"";width:7px;height:7px;border-right:1.5px solid var(--ink-3);border-bottom:1.5px solid var(--ink-3);
  transform:rotate(45deg);margin-left:auto;transition:transform .15s;
}
.collapsible details[open] summary::after{transform:rotate(-135deg)}
.collapsible details>*{margin-top:12px}
.collapsible details>summary{margin-top:0}

.add-special{margin-top:14px}
.add-special .as-summary{
  display:inline-flex;background:var(--panel);color:var(--ink);border:1px solid var(--line-strong);
}
.add-special .as-summary:hover{background:var(--subtle)}
.add-special[open] .as-summary{margin-bottom:16px}
.add-special .big-form{margin-top:14px;padding-top:14px;border-top:1px solid var(--line)}

/* ============================================================
   PLAYLIST PICKER (radio cards)
   ============================================================ */
.pl-picker{display:flex;flex-wrap:wrap;gap:8px}
.pl-pick{position:relative;margin:0}
.pl-pick input{position:absolute;opacity:0;pointer-events:none}
.pl-pick-card{
  display:flex;flex-direction:column;align-items:center;gap:6px;
  width:90px;padding:8px;
  border:1px solid var(--line-strong);border-radius:var(--radius);
  background:var(--panel);cursor:pointer;text-align:center;
  transition:border-color .12s,background .12s;
}
.pl-pick-card img,.pl-pick-card .pp-ico{
  width:48px;height:48px;border-radius:var(--radius);object-fit:cover;
  display:flex;align-items:center;justify-content:center;
  background:var(--subtle);border:1px solid var(--line);color:var(--ink-3);
}
.pl-pick-card .pp-ico svg.ico{width:20px;height:20px}
.pl-pick-card.none .pp-ico{color:var(--ink-3)}
.pp-name{
  font-size:11px;font-weight:500;color:var(--ink-2);line-height:1.25;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.pl-pick:hover .pl-pick-card{border-color:var(--ink-3)}
.pl-pick input:checked + .pl-pick-card{
  border-color:var(--ink);background:var(--subtle);box-shadow:inset 0 0 0 1px var(--ink);
}
.pl-pick input:checked + .pl-pick-card .pp-name{color:var(--ink);font-weight:600}

/* ============================================================
   CARD PLAYLIST (libreria)
   ============================================================ */
.playlist-card{
  display:flex;align-items:center;gap:13px;
  padding:12px 14px;margin-bottom:0;
}
.playlist-card .pl-cover{
  width:54px;height:54px;flex:none;
  border-radius:var(--radius);object-fit:cover;
  border:1px solid var(--line);background:var(--subtle);
}
.playlist-card .pl-cover.placeholder{
  display:flex;align-items:center;justify-content:center;color:var(--ink-3);
}
.playlist-card .pl-cover.placeholder svg.ico{width:22px;height:22px}
.pl-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}
.pl-name{
  font-size:14px;font-weight:600;letter-spacing:-.01em;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.pl-link{
  display:inline-flex;align-items:center;gap:5px;
  font-size:12px;color:var(--ink-2);width:fit-content;
}
.pl-link svg.ico{width:13px;height:13px}
.pl-link:hover{color:var(--ink);text-decoration:none}
.playlist-card form{margin:0;flex:none}

/* ============================================================
   "SUONA SUBITO" + RICERCA
   ============================================================ */
.quick-playlists{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px}
.quick-pl{
  display:flex;align-items:center;gap:9px;
  background:var(--panel);border:1px solid var(--line-strong);border-radius:var(--radius);
  padding:6px 12px 6px 6px;cursor:pointer;font-family:inherit;font-size:12.5px;font-weight:500;color:var(--ink);
  transition:border-color .12s,background .12s;
}
.quick-pl:hover{border-color:var(--ink);background:var(--subtle)}
.quick-pl img,.quick-pl .pp-ico{
  width:30px;height:30px;border-radius:var(--radius);object-fit:cover;flex:none;
  display:flex;align-items:center;justify-content:center;background:var(--subtle);border:1px solid var(--line);color:var(--ink-3);
}
.quick-pl .pp-ico svg.ico{width:15px;height:15px}
.quick-pl.loading{opacity:.5;pointer-events:none}
.quick-pl span{max-width:170px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

.search-box{position:relative;margin-bottom:10px}
.search-box input{margin-top:0}
.search-results{display:flex;flex-direction:column;gap:2px}
.sr-item{
  display:flex;align-items:center;gap:11px;
  padding:7px 8px;border-radius:var(--radius);border:1px solid transparent;
}
.sr-item:hover{background:var(--subtle);border-color:var(--line)}
.sr-item img,.sr-item .pp-ico.sm{
  width:38px;height:38px;border-radius:var(--radius);object-fit:cover;flex:none;
  display:flex;align-items:center;justify-content:center;background:var(--subtle);border:1px solid var(--line);color:var(--ink-3);
}
.sr-main{flex:1;min-width:0}
.sr-name{font-size:13px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sr-art{font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sr-play{flex:none}

/* ---------- preview "secondo le regole" ---------- */
.preview.small{padding:13px 16px}
.preview.small .np-title{font-size:14px;display:flex;align-items:center;gap:7px}
.preview.small .np-title svg.ico{width:15px;height:15px;color:var(--ink-2)}
.preview.small .np-reason{margin-top:4px}

/* ============================================================
   PLAYER LIVE
   ============================================================ */
.player{min-height:96px}
.player-loading{padding:6px 0}
.np-wrap{display:flex;gap:16px;align-items:center}
.np-art{width:74px;height:74px;flex:none;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line)}
.np-art img{width:100%;height:100%;object-fit:cover;display:block}
.np-art.ph{
  display:flex;align-items:center;justify-content:center;
  background:var(--subtle);color:var(--ink-3);border:1px solid var(--line);
}
.np-art.ph svg.ico{width:28px;height:28px}
.np-info{flex:1;min-width:0}
.np-track{font-size:15px;font-weight:600;letter-spacing:-.01em;margin-top:3px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.np-track.muted{font-weight:500}
.np-artist{font-size:13px;color:var(--ink-2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.np-progress{height:3px;background:var(--line);border-radius:2px;margin:10px 0 4px;overflow:hidden}
.np-progress span{display:block;height:100%;background:var(--ink);border-radius:2px}
.np-times{font-family:var(--mono);font-size:11px}

.np-controls{
  display:flex;align-items:center;gap:6px;
  margin-top:14px;padding-top:14px;border-top:1px solid var(--line);
}
.ctl{
  display:inline-flex;align-items:center;justify-content:center;
  width:36px;height:36px;padding:0;
  background:var(--panel);border:1px solid var(--line-strong);border-radius:var(--radius);
  color:var(--ink);cursor:pointer;transition:background .12s,border-color .12s,color .12s;
}
.ctl svg.ico{width:16px;height:16px}
.ctl:hover{background:var(--subtle);border-color:var(--ink-3)}
.ctl.big{width:42px;height:42px;background:var(--ink);border-color:var(--ink);color:#fff}
.ctl.big svg.ico{width:18px;height:18px}
.ctl.big:hover{background:var(--accent-hover);border-color:var(--accent-hover)}
.ctl.on{border-color:var(--ink);color:var(--ink);background:var(--subtle)}
.np-vol{display:flex;align-items:center;gap:8px;margin-left:auto;color:var(--ink-2)}
.np-vol svg.ico{width:16px;height:16px}
#npVolVal{font-family:var(--mono);font-size:11px;min-width:34px;text-align:right}

input[type=range]{
  -webkit-appearance:none;appearance:none;width:110px;height:18px;
  background:transparent;border:none;padding:0;margin:0;cursor:pointer;
}
input[type=range]::-webkit-slider-runnable-track{height:3px;background:var(--line-strong);border-radius:2px}
input[type=range]::-moz-range-track{height:3px;background:var(--line-strong);border-radius:2px}
input[type=range]::-webkit-slider-thumb{
  -webkit-appearance:none;appearance:none;width:13px;height:13px;border-radius:50%;
  background:var(--ink);border:2px solid var(--panel);margin-top:-5px;box-shadow:0 0 0 1px var(--line-strong);
}
input[type=range]::-moz-range-thumb{
  width:13px;height:13px;border-radius:50%;background:var(--ink);border:2px solid var(--panel);box-shadow:0 0 0 1px var(--line-strong);
}

/* ============================================================
   REGOLE / DATE SPECIALI
   ============================================================ */
.rule-list{display:flex;flex-direction:column;gap:2px;margin-bottom:6px}
.rule-item{
  display:flex;align-items:center;gap:11px;
  padding:9px 8px;border-radius:var(--radius);border:1px solid transparent;
}
.rule-item:hover{background:var(--subtle);border-color:var(--line)}
.rule-item.disabled{opacity:.5}
.rule-dot{width:9px;height:9px;border-radius:2px;flex:none;background:var(--ink)}
.rule-main{flex:1;min-width:0}
.rule-title{font-size:13px;font-weight:500}
.rule-title .muted{font-weight:400}
.rule-sub{font-size:11.5px;color:var(--ink-2);margin-top:1px}
.rule-item form{margin:0}

/* ============================================================
   CALENDARIO SETTIMANALE
   ============================================================ */
.cal-hint{margin-bottom:14px}
.cal-hint b{font-weight:600;color:var(--ink)}
.cal{
  border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  background:var(--panel);user-select:none;
}
.cal-head{display:grid;grid-template-columns:46px repeat(7,1fr);border-bottom:1px solid var(--line)}
.cal-corner{border-right:1px solid var(--line)}
.cal-dh{
  text-align:center;font-size:11px;font-weight:600;color:var(--ink-2);
  padding:8px 2px;border-right:1px solid var(--line);
}
.cal-dh:last-child{border-right:none}
.cal-dh.today{color:var(--ink);background:var(--subtle)}
.cal-body{display:grid;grid-template-columns:46px 1fr;height:560px;position:relative}
.cal-hours{position:relative;border-right:1px solid var(--line)}
.cal-hl{
  position:absolute;right:6px;transform:translateY(-50%);
  font-family:var(--mono);font-size:10px;color:var(--ink-3);
}
.cal-cols{display:grid;grid-template-columns:repeat(7,1fr);position:relative}
.cal-col{position:relative;border-right:1px solid var(--line);cursor:crosshair}
.cal-col:last-child{border-right:none}
.cal-line{position:absolute;left:0;right:0;height:0;border-top:1px solid var(--subtle)}
.cal-line.major{border-top:1px solid var(--line)}
.cal-now{position:absolute;left:0;right:0;height:0;border-top:1.5px solid var(--danger);z-index:5}
.cal-now::before{content:"";position:absolute;left:-3px;top:-3px;width:5px;height:5px;border-radius:50%;background:var(--danger)}

/* blocchi generati da calendar.js (stima — affinabili con il file reale) */
.cal-block,.cal .block,.cal-event{
  position:absolute;left:3px;right:3px;
  border-radius:var(--radius);overflow:hidden;cursor:pointer;
  background:var(--ink);color:#fff;
  font-size:11px;line-height:1.2;padding:4px 6px;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.12);z-index:3;
}
.cal-block .cal-block-label,.cal-event-label{font-weight:600;display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cal-block .cal-block-time,.cal-event-time{font-family:var(--mono);font-size:9.5px;opacity:.8}
.cal-block-handle,.cal-handle,.cal-rz{position:absolute;left:0;right:0;height:6px;cursor:ns-resize}
.cal-block-handle.top,.cal-handle.top{top:0}
.cal-block-handle.bottom,.cal-handle.bottom{bottom:0}
.cal-ghost{position:absolute;left:3px;right:3px;background:rgba(17,17,19,.12);border:1px dashed var(--ink-3);border-radius:var(--radius);z-index:2}

/* --- Allineamento alle classi reali generate da calendar.js --- */
.cal-block{cursor:grab}
.cal-block.dragging{cursor:grabbing;opacity:.92;z-index:6;box-shadow:0 6px 18px rgba(0,0,0,.22)}
.cal-block.off{opacity:.45}
.cal-block.ghost{background:rgba(17,17,19,.10);color:var(--ink-2);border:1px dashed var(--ink-3);
  box-shadow:none;pointer-events:none;z-index:6}
.cb-body{pointer-events:none}
.cb-name{font-weight:600;display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cb-time{font-family:var(--mono);font-size:9.5px;opacity:.85}
.cb-rz{position:absolute;left:0;right:0;height:8px;cursor:ns-resize;z-index:4}
.cb-rz.top{top:0}
.cb-rz.bottom{bottom:0}

/* Popover scelta playlist / azioni (clic su un blocco) */
.cal-pop{position:fixed;z-index:60;background:var(--panel);border:1px solid var(--line-strong);
  border-radius:var(--radius-lg);padding:9px;width:232px;box-shadow:0 10px 30px rgba(0,0,0,.18)}
.cp-title{font-size:10.5px;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-3);
  margin-bottom:7px;font-weight:600}
.cp-list{display:flex;flex-direction:column;gap:3px;max-height:236px;overflow:auto}
.cp-item{display:flex;align-items:center;gap:8px;background:var(--panel);border:1px solid var(--line);
  color:var(--ink);border-radius:var(--radius);padding:7px 9px;text-align:left;font-size:12.5px;
  cursor:pointer;font-family:inherit;line-height:1.2}
.cp-item:hover{background:var(--subtle)}
.cp-item.sel{border-color:var(--ink);font-weight:600}
.cp-dot{width:11px;height:11px;border-radius:50%;flex:none}
.cp-actions{display:flex;gap:6px;margin-top:8px}
.cp-actions button{flex:1;background:var(--panel);border:1px solid var(--line);color:var(--ink);
  border-radius:var(--radius);padding:7px;font-size:12px;cursor:pointer;font-family:inherit}
.cp-actions button:hover{background:var(--subtle)}
.cp-del{color:var(--danger)!important;border-color:var(--danger-line)!important}
.cp-del:hover{background:var(--danger-bg)!important}

/* --- Personalizzazione aspetto (logo + colori) --- */
.brand-logo{width:22px;height:22px;object-fit:contain;border-radius:3px;flex:none}
.login-logo-img{max-width:140px;max-height:70px;object-fit:contain}
.logo-current{display:inline-flex;padding:6px;border:1px solid var(--line);border-radius:var(--radius);
  background:var(--subtle);margin:6px 0}
.logo-current img{max-width:170px;max-height:60px;object-fit:contain;display:block}
.color-field{display:inline-flex;align-items:center;gap:9px;margin-top:5px}
.color-field input[type=color]{width:46px;height:32px;padding:2px;border:1px solid var(--line-strong);
  border-radius:var(--radius);background:var(--panel);cursor:pointer}
.checkbox-row{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--ink-2);margin:6px 0}
.checkbox-row input{width:auto}

/* ============================================================
   LOGIN
   ============================================================ */
.login-wrap{
  min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;
  background:var(--bg);padding:24px;
}

/* footer versione */
.app-footer{
  margin-top:30px;padding-top:14px;
  text-align:center;font-size:11.5px;color:var(--ink-3);
  border-top:1px solid var(--line);
}
.login-wrap .app-footer{margin-top:0;padding-top:0;border-top:none}
.login-card{
  width:100%;max-width:360px;
  background:var(--panel);border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:32px 28px;text-align:center;
}
.login-logo{
  width:48px;height:48px;margin:0 auto 16px;
  display:flex;align-items:center;justify-content:center;
  border:1px solid var(--line);border-radius:var(--radius);background:var(--subtle);color:var(--ink);
}
.login-logo svg.ico{width:24px;height:24px}
.login-card h1{font-size:19px;font-weight:600;letter-spacing:-.02em}
.login-card>.muted{margin:4px 0 20px}
.login-card label{text-align:left;font-size:12.5px;font-weight:500;color:var(--ink-2);margin-bottom:14px}
.login-card .btn-primary{width:100%;margin-top:4px;padding:10px}
.login-card .flash{text-align:left}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:980px){
  .grid-2{grid-template-columns:1fr}
}
@media (max-width:820px){
  .layout{flex-direction:column}
  .sidebar{
    width:auto;height:auto;position:sticky;top:0;z-index:20;
    flex-direction:row;align-items:center;gap:6px;
    border-right:none;border-bottom:1px solid var(--line);
    padding:8px 12px;overflow-x:auto;
  }
  .brand{padding:0 8px 0 2px;flex:none}
  .brand span{display:none}
  .sidebar nav{flex-direction:row;gap:2px}
  .sidebar nav a{padding:7px 10px}
  .sidebar nav a.active::before{display:none}
  .sidebar-foot{
    margin:0 0 0 auto;padding:0;border-top:none;
    flex-direction:row;align-items:center;gap:4px;flex:none;
  }
  .sidebar-foot .user{display:none}
  .content{padding:20px 18px 48px}
}
@media (max-width:560px){
  body{font-size:13.5px}
  .content{padding:16px 14px 40px}
  .page-head h1{font-size:19px}
  .form-row{grid-template-columns:1fr}
  .time-row{flex-direction:column;gap:10px}
  .inline-form{flex-direction:column}
  .inline-form .btn-primary{width:100%}
  .cards{grid-template-columns:1fr}
  .np-controls{flex-wrap:wrap}
  .np-vol{margin-left:0;width:100%;margin-top:4px}
  input[type=range]{flex:1;width:auto}
  .cal-head{grid-template-columns:34px repeat(7,1fr)}
  .cal-body{grid-template-columns:34px 1fr;height:480px}
  .cal-dh{font-size:10px;padding:6px 1px}
  .copybox{flex-direction:column}
  .copybox .btn-ghost{width:100%}
  .brand span{display:inline}
}
