
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --giallo:       #FFD300;
  --giallo-dark:  #E6BE00;
  --giallo-light: #FFFBE6;
  --nero:         #000000;
  --bianco:       #FFFFFF;
  --grigio-bg:    #F7F7F5;
  --grigio-mid:   #E0E0E0;
  --grigio-dark:  #555555;
  --testo:        #111111;
  --font-display: 'Montserrat', sans-serif;
  --font-body:    'Barlow', sans-serif;
  --font-mono:    'Courier Prime', monospace;
  --sidebar-w:    248px;
  --header-h:     54px;
  --bnav-h:       60px;
  --radius:       6px;
}

body { font-family: var(--font-body); background: var(--grigio-bg); color: var(--testo); height: 100vh; overflow: hidden; }

/* ══ SCHERMATE ══ */
#screenLogin { display: none; height: 100vh; }
#screenApp   { display: none; flex-direction: column; height: 100vh; }
#screenLogin.active { display: flex; }
#screenApp.active   { display: flex; }

/* ══ LOGIN ══ */
.login-left {
  flex: 1; background: var(--nero); display: flex; flex-direction: column;
  align-items: center; justify-content: center; padding: 48px;
  position: relative; overflow: hidden;
}
.login-left::after { content:''; position:absolute; top:0; left:0; right:0; height:4px; background:var(--giallo); }
.login-brand { position:relative; z-index:1; text-align:center; display:flex; flex-direction:column; align-items:center; gap:16px; }
.login-logo  { width:96px; height:96px; object-fit:contain; filter:drop-shadow(0 2px 8px rgba(255,211,0,.25)); }
.login-club  { font-family:var(--font-display); font-size:22px; font-weight:800; color:var(--bianco); text-transform:uppercase; letter-spacing:.04em; line-height:1.15; }
.login-club span { color:var(--giallo); }
.login-club-sub  { font-family:var(--font-body); font-size:11px; color:rgba(255,255,255,.4); letter-spacing:.12em; text-transform:uppercase; margin-top:-6px; }
.login-season    { font-family:var(--font-mono); font-size:11px; color:rgba(255,211,0,.4); letter-spacing:.1em; text-transform:uppercase; padding-top:14px; border-top:1px solid rgba(255,255,255,.08); width:100%; text-align:center; }

.login-right { width:420px; background:var(--bianco); border-left:3px solid var(--giallo); display:flex; flex-direction:column; justify-content:center; padding:48px 40px; overflow-y:auto; }
.login-right h2 { font-family:var(--font-display); font-size:24px; font-weight:800; text-transform:uppercase; margin-bottom:4px; }
.login-right .sub { font-size:13px; color:var(--grigio-dark); margin-bottom:26px; }

.form-field { margin-bottom:14px; display:flex; flex-direction:column; gap:4px; }
.form-field label { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.08em; color:var(--grigio-dark); }
.form-field input, .form-field select, .form-field textarea {
  width:100%; border:1.5px solid var(--grigio-mid); border-radius:var(--radius);
  padding:9px 12px; font-size:14px; font-family:var(--font-body); color:var(--testo);
  background:var(--grigio-bg); outline:none; transition:border-color .15s, box-shadow .15s;
}
.form-field input:focus, .form-field select:focus, .form-field textarea:focus {
  border-color:var(--giallo); background:var(--bianco); box-shadow:0 0 0 3px rgba(255,211,0,.18);
}
.login-error { color:#c00; font-size:12px; margin-bottom:10px; min-height:16px; }

.btn-primary { width:100%; padding:11px; background:var(--giallo); color:var(--nero); border:none; border-radius:var(--radius); font-family:var(--font-display); font-size:13px; font-weight:800; text-transform:uppercase; letter-spacing:.06em; cursor:pointer; transition:background .15s, transform .1s; }
.btn-primary:hover  { background:var(--giallo-dark); }
.btn-primary:active { transform:scale(.98); }

.demo-section { margin-top:22px; padding-top:18px; border-top:1.5px solid var(--grigio-mid); }
.demo-label   { font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:.1em; color:var(--grigio-dark); margin-bottom:8px; }
.demo-grid    { display:grid; grid-template-columns:1fr 1fr; gap:5px; }
.demo-btn     { padding:7px 9px; border:1.5px solid var(--grigio-mid); border-radius:var(--radius); background:var(--grigio-bg); font-size:11.5px; cursor:pointer; text-align:left; transition:border-color .1s, background .1s; color:var(--testo); }
.demo-btn:hover { border-color:var(--giallo); background:var(--giallo-light); }
.demo-btn .db-role { font-size:9.5px; font-weight:600; margin-top:1px; }

/* ══ HEADER ══ */
.app-header { height:var(--header-h); background:var(--nero); border-bottom:3px solid var(--giallo); display:flex; align-items:center; flex-shrink:0; }
.header-brand { width:var(--sidebar-w); height:100%; background:var(--giallo); display:flex; align-items:center; padding:0 14px; gap:10px; flex-shrink:0; }
.header-logo  { width:30px; height:30px; object-fit:contain; flex-shrink:0; }
.header-brand-text .hb-title { font-family:var(--font-display); font-size:12px; font-weight:900; text-transform:uppercase; line-height:1; color:var(--nero); }
.header-brand-text .hb-sub   { font-family:var(--font-mono); font-size:9px; color:rgba(0,0,0,.5); margin-top:2px; }

.header-nav { display:flex; align-items:center; gap:2px; padding:0 16px; flex:1; }
.nav-tab { padding:6px 16px; border-radius:var(--radius); border:none; background:none; font-family:var(--font-display); font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.06em; color:rgba(255,255,255,.5); cursor:pointer; transition:background .15s, color .15s; white-space:nowrap; }
.nav-tab:hover  { background:rgba(255,255,255,.08); color:var(--bianco); }
.nav-tab.active { background:var(--giallo); color:var(--nero); }

.header-user { display:flex; align-items:center; gap:8px; padding-right:14px; flex-shrink:0; }
.role-badge  { font-family:var(--font-display); font-size:9px; font-weight:700; text-transform:uppercase; padding:3px 8px; border-radius:3px; color:white; white-space:nowrap; }
.user-name   { font-size:13px; font-weight:600; color:var(--bianco); white-space:nowrap; }
.logout-btn  { padding:5px 11px; border:1px solid rgba(255,255,255,.25); border-radius:var(--radius); background:none; font-size:11px; font-weight:600; cursor:pointer; color:rgba(255,255,255,.6); transition:border-color .1s, color .1s; white-space:nowrap; }
.logout-btn:hover { border-color:var(--giallo); color:var(--giallo); }
.sidebar-toggle-btn { width:36px; height:36px; background:rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.2); border-radius:var(--radius); cursor:pointer; display:flex; align-items:center; justify-content:center; color:white; flex-shrink:0; }
.sidebar-toggle-btn:hover { background:rgba(255,211,0,.2); }

/* ══ VIEW PANES ══ */
.view-pane { flex:1; overflow:hidden; display:none; }
.view-pane.active { display:flex; }
.view-calendar.active { display:flex; }

/* ══ HOME ══ */
.view-home.active { flex-direction:column; overflow-y:auto; background:var(--grigio-bg); }
.view-home::-webkit-scrollbar { width:4px; }
.view-home::-webkit-scrollbar-thumb { background:var(--grigio-mid); border-radius:2px; }

.home-content { max-width:900px; width:100%; margin:0 auto; padding:24px 24px 32px; display:flex; flex-direction:column; gap:20px; }

/* Profile banner */
.home-profile-card { background:var(--nero); border-radius:12px; border-left:5px solid var(--giallo); padding:20px 24px; display:flex; align-items:center; gap:18px; }
.profile-avatar { width:52px; height:52px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-family:var(--font-display); font-size:18px; font-weight:900; color:white; flex-shrink:0; }
.profile-name   { font-family:var(--font-display); font-size:18px; font-weight:800; color:var(--bianco); text-transform:uppercase; letter-spacing:-.01em; }
.profile-role   { font-size:13px; font-weight:600; margin-top:2px; }
.profile-sport  { font-family:var(--font-mono); font-size:11px; color:rgba(255,255,255,.35); text-transform:uppercase; letter-spacing:.08em; margin-top:3px; }

/* Stat cards */
.home-stats { display:grid; grid-template-columns:repeat(3,1fr); gap:10px; }
.stat-card  { background:var(--bianco); border:1.5px solid var(--grigio-mid); border-radius:10px; padding:14px 16px; }
.stat-val   { font-family:var(--font-display); font-size:26px; font-weight:900; line-height:1; }
.stat-lbl   { font-size:11px; font-weight:600; text-transform:uppercase; letter-spacing:.07em; color:var(--grigio-dark); margin-top:4px; }

/* Sections */
.home-section       { background:var(--bianco); border-radius:10px; border:1.5px solid var(--grigio-mid); overflow:hidden; }
.home-section-title { font-family:var(--font-display); font-size:10px; font-weight:800; text-transform:uppercase; letter-spacing:.12em; color:var(--grigio-dark); padding:12px 16px 10px; border-bottom:1.5px solid var(--grigio-mid); background:var(--grigio-bg); }

/* Today matches */
.home-matches    { display:flex; gap:10px; flex-wrap:wrap; padding:14px 16px; }
.home-match-card { border:1.5px solid var(--grigio-mid); border-left-width:4px; border-radius:var(--radius); padding:10px 14px; min-width:200px; flex:1; background:var(--grigio-bg); }
.hmc-sport { font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:.07em; color:var(--grigio-dark); margin-bottom:3px; }
.hmc-title { font-family:var(--font-display); font-size:13px; font-weight:800; text-transform:uppercase; }
.hmc-meta  { font-family:var(--font-mono); font-size:11px; color:var(--grigio-dark); margin-top:3px; }

/* Upcoming events */
.home-events-list { display:flex; flex-direction:column; }
.home-ev-row { display:flex; align-items:center; gap:12px; padding:11px 16px; border-bottom:1px solid var(--grigio-mid); cursor:pointer; transition:background .1s; }
.home-ev-row:last-child { border-bottom:none; }
.home-ev-row:hover { background:var(--giallo-light); }
.her-color { width:4px; height:36px; border-radius:2px; flex-shrink:0; }
.her-date  { font-family:var(--font-mono); font-size:11px; color:var(--grigio-dark); width:72px; flex-shrink:0; }
.her-info  { flex:1; min-width:0; }
.her-title { font-size:13px; font-weight:600; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.her-meta  { font-size:11px; color:var(--grigio-dark); margin-top:1px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.her-type  { font-family:var(--font-display); font-size:9px; font-weight:700; text-transform:uppercase; letter-spacing:.06em; padding:2px 7px; border-radius:3px; flex-shrink:0; }
.her-type.match    { background:#dbeafe; color:#1d4ed8; }
.her-type.event    { background:#ede9fe; color:#7c3aed; }
.her-type.training { background:#dcfce7; color:#059669; }

.home-empty { padding:16px; font-size:13px; color:var(--grigio-dark); }

/* Nav cards */
.home-nav-cards { display:flex; gap:12px; flex-wrap:wrap; padding:14px 16px; }
.home-nav-card  { border:1.5px solid var(--grigio-mid); border-radius:var(--radius); padding:16px 20px; cursor:pointer; transition:border-color .15s, background .15s, transform .1s; background:var(--grigio-bg); min-width:140px; text-align:center; }
.home-nav-card:hover { border-color:var(--giallo); background:var(--giallo-light); transform:translateY(-2px); }
.hnc-icon  { font-size:26px; margin-bottom:6px; }
.hnc-label { font-family:var(--font-display); font-size:12px; font-weight:800; text-transform:uppercase; }
.hnc-sub   { font-size:11px; color:var(--grigio-dark); margin-top:2px; }

/* ══ CALENDAR VIEW ══ */
.view-calendar { display:none; }
.view-calendar.active { display:flex; flex:1; overflow:hidden; }

/* Sidebar */
.sidebar { width:var(--sidebar-w); background:var(--bianco); border-right:1.5px solid var(--grigio-mid); display:flex; flex-direction:column; flex-shrink:0; transition:transform .25s ease; z-index:10; }
.sidebar-scroll { flex:1; overflow-y:auto; padding:6px 0 16px; }
.sidebar-scroll::-webkit-scrollbar { width:3px; }
.sidebar-scroll::-webkit-scrollbar-thumb { background:var(--grigio-mid); border-radius:2px; }
.sidebar-backdrop { display:none; position:fixed; inset:0; background:rgba(0,0,0,.4); z-index:9; }

.group-header { display:flex; align-items:center; justify-content:space-between; padding:10px 12px 4px; }
.group-label  { font-family:var(--font-display); font-size:9px; font-weight:800; text-transform:uppercase; letter-spacing:.12em; color:var(--grigio-dark); }
.group-toggle { font-size:10px; font-weight:600; color:var(--grigio-dark); cursor:pointer; background:none; border:none; text-decoration:underline; text-underline-offset:2px; }
.group-toggle:hover { color:var(--testo); }

.team-row { display:flex; align-items:center; gap:8px; padding:5px 12px; cursor:pointer; user-select:none; transition:background .1s; }
.team-row:hover { background:var(--giallo-light); }
.team-swatch { width:9px; height:9px; border-radius:2px; flex-shrink:0; }
.team-row.off .team-swatch { opacity:.2; }
.team-label { font-size:12px; font-weight:500; flex:1; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.team-row.off .team-label { color:var(--grigio-mid); }
.my-team-badge { font-family:var(--font-display); font-size:8px; font-weight:800; text-transform:uppercase; color:var(--nero); background:var(--giallo); padding:1px 5px; border-radius:2px; flex-shrink:0; }

/* Main */
.main { flex:1; display:flex; flex-direction:column; overflow:hidden; }
#partiteOggi { background:var(--giallo); border-bottom:1.5px solid rgba(0,0,0,.15); padding:9px 16px; flex-shrink:0; }
.oggi-header { display:flex; align-items:center; gap:7px; margin-bottom:8px; }
.oggi-dot    { width:7px; height:7px; border-radius:50%; background:var(--nero); flex-shrink:0; }
.oggi-title  { font-family:var(--font-display); font-size:9px; font-weight:800; text-transform:uppercase; letter-spacing:.12em; color:var(--nero); }
.oggi-cards  { display:flex; gap:8px; overflow-x:auto; padding-bottom:2px; }
.oggi-cards::-webkit-scrollbar { height:2px; }
.oggi-cards::-webkit-scrollbar-thumb { background:rgba(0,0,0,.2); border-radius:1px; }

.match-card { border:1.5px solid rgba(0,0,0,.2); border-left-width:4px; border-radius:var(--radius); background:rgba(255,255,255,.7); padding:7px 11px; min-width:180px; cursor:pointer; transition:background .1s, transform .1s; display:flex; flex-direction:column; gap:2px; flex-shrink:0; }
.match-card:hover { background:var(--bianco); transform:translateY(-1px); }
.mc-sport { font-size:9px; font-weight:700; text-transform:uppercase; letter-spacing:.08em; color:var(--grigio-dark); }
.mc-teams { font-family:var(--font-display); font-size:12px; font-weight:700; text-transform:uppercase; line-height:1.2; }
.mc-meta  { font-family:var(--font-mono); font-size:10.5px; color:var(--grigio-dark); }

.cal-header { height:48px; background:var(--bianco); border-bottom:1.5px solid var(--grigio-mid); padding:0 16px; display:flex; align-items:center; gap:8px; flex-shrink:0; }
.nav-btn    { width:28px; height:28px; border:1.5px solid var(--grigio-mid); border-radius:var(--radius); background:none; cursor:pointer; display:flex; align-items:center; justify-content:center; font-size:18px; color:var(--testo); transition:border-color .1s, background .1s; }
.nav-btn:hover { border-color:var(--nero); background:var(--giallo-light); }
.month-label { font-family:var(--font-display); font-size:15px; font-weight:800; text-transform:uppercase; min-width:180px; text-align:center; }
.today-btn  { border:1.5px solid var(--grigio-mid); border-radius:var(--radius); background:none; padding:5px 12px; font-family:var(--font-display); font-size:10px; font-weight:700; text-transform:uppercase; cursor:pointer; color:var(--testo); transition:border-color .1s, background .1s; }
.today-btn:hover { border-color:var(--nero); background:var(--giallo-light); }
.add-ev-btn { border:1.5px solid var(--nero); border-radius:var(--radius); background:var(--giallo); padding:5px 13px; font-family:var(--font-display); font-size:10px; font-weight:800; text-transform:uppercase; cursor:pointer; color:var(--nero); transition:background .1s; }
.add-ev-btn:hover { background:var(--giallo-dark); }

.cal-body { flex:1; display:flex; flex-direction:column; padding:8px 10px 10px; gap:3px; overflow:hidden; }
.dow-row  { display:grid; grid-template-columns:repeat(7,1fr); }
.dow-cell { text-align:center; font-family:var(--font-display); font-size:9px; font-weight:700; text-transform:uppercase; letter-spacing:.08em; color:var(--grigio-dark); padding:2px 0 4px; }
.cal-grid { flex:1; display:grid; grid-template-columns:repeat(7,1fr); gap:3px; overflow:hidden; }

.day-cell { background:var(--bianco); border:1px solid var(--grigio-mid); border-radius:4px; padding:4px 4px 3px; display:flex; flex-direction:column; gap:2px; overflow:hidden; min-height:0; cursor:default; }
.day-cell.other-month { background:var(--grigio-bg); opacity:.4; }
.day-cell.is-today    { border-color:var(--giallo); border-width:2px; background:var(--giallo-light); }
.day-num { font-family:var(--font-display); font-size:11px; font-weight:700; width:20px; height:20px; display:flex; align-items:center; justify-content:center; color:var(--grigio-dark); flex-shrink:0; border-radius:50%; }
.day-cell:not(.other-month) .day-num { color:var(--testo); }
.day-cell.is-today .day-num { background:var(--nero); color:var(--giallo); }
.ev-list  { display:flex; flex-direction:column; gap:2px; flex:1; overflow:hidden; }
.ev-pill  { display:flex; align-items:center; gap:3px; padding:2px 4px; border-radius:3px; font-size:10px; line-height:1.3; cursor:pointer; white-space:nowrap; overflow:hidden; color:white; transition:filter .1s; }
.ev-pill:hover { filter:brightness(.88); }
.ev-time  { font-family:var(--font-mono); font-size:9px; opacity:.85; flex-shrink:0; }
.ev-name  { overflow:hidden; text-overflow:ellipsis; font-weight:600; }
.more-pill { font-family:var(--font-display); font-size:9px; font-weight:700; color:var(--grigio-dark); cursor:pointer; padding:1px 4px; }
.more-pill:hover { color:var(--testo); text-decoration:underline; }

/* ══ BOTTOM NAV (mobile) ══ */
.bottom-nav { display:none; }

/* ══ USERS VIEW ══ */
.view-users.active { flex-direction:column; overflow-y:auto; background:var(--grigio-bg); }
.users-content { max-width:860px; width:100%; margin:0 auto; padding:24px; display:flex; flex-direction:column; gap:16px; }
.users-topbar  { display:flex; align-items:center; justify-content:space-between; }
.users-topbar h2 { font-family:var(--font-display); font-size:18px; font-weight:800; text-transform:uppercase; }
.btn-add-user { padding:8px 16px; background:var(--giallo); border:1.5px solid var(--nero); border-radius:var(--radius); font-family:var(--font-display); font-size:11px; font-weight:800; text-transform:uppercase; cursor:pointer; transition:background .1s; }
.btn-add-user:hover { background:var(--giallo-dark); }

.users-list { display:flex; flex-direction:column; gap:8px; }
.user-card  { background:var(--bianco); border:1.5px solid var(--grigio-mid); border-radius:10px; padding:14px 16px; display:flex; align-items:center; gap:14px; }
.uc-avatar  { width:42px; height:42px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-family:var(--font-display); font-size:15px; font-weight:900; color:white; flex-shrink:0; }
.uc-info    { flex:1; min-width:0; }
.uc-name    { font-family:var(--font-display); font-size:14px; font-weight:700; }
.uc-email   { font-size:12px; color:var(--grigio-dark); margin-top:1px; }
.uc-role    { font-family:var(--font-display); font-size:10px; font-weight:700; text-transform:uppercase; padding:3px 8px; border-radius:3px; color:white; flex-shrink:0; white-space:nowrap; }
.uc-team    { font-size:12px; color:var(--grigio-dark); min-width:100px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.uc-actions { display:flex; gap:6px; flex-shrink:0; }
.btn-edit-sm   { padding:5px 10px; background:none; border:1.5px solid var(--grigio-mid); border-radius:var(--radius); font-family:var(--font-display); font-size:10px; font-weight:700; text-transform:uppercase; cursor:pointer; transition:border-color .1s, background .1s; }
.btn-edit-sm:hover   { border-color:var(--giallo); background:var(--giallo-light); }
.btn-delete-sm { padding:5px 10px; background:none; border:1.5px solid #fca5a5; border-radius:var(--radius); font-family:var(--font-display); font-size:10px; font-weight:700; text-transform:uppercase; color:#c00; cursor:pointer; transition:background .1s; }
.btn-delete-sm:hover { background:#fff5f5; }

/* ══ MODALI ══ */
#overlay { display:none; position:fixed; inset:0; background:rgba(0,0,0,.45); z-index:300; align-items:center; justify-content:center; }
#overlay.open { display:flex; }
.modal { background:var(--bianco); border-radius:10px; border:1.5px solid var(--grigio-mid); box-shadow:0 20px 60px rgba(0,0,0,.15); width:420px; max-width:94vw; max-height:90vh; overflow-y:auto; position:relative; }
.modal-head    { padding:18px 18px 0; position:sticky; top:0; background:var(--bianco); z-index:1; border-radius:10px 10px 0 0; }
.modal-close   { position:absolute; top:12px; right:12px; background:none; border:1.5px solid var(--grigio-mid); border-radius:50%; width:26px; height:26px; display:flex; align-items:center; justify-content:center; font-size:15px; cursor:pointer; color:var(--grigio-dark); line-height:1; transition:border-color .1s, color .1s, background .1s; }
.modal-close:hover { border-color:var(--nero); color:var(--nero); background:var(--giallo-light); }
.modal-badge   { display:inline-flex; align-items:center; gap:5px; padding:3px 10px; border-radius:20px; font-family:var(--font-display); font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:.08em; color:white; margin-bottom:7px; }
.modal-title   { font-family:var(--font-display); font-size:17px; font-weight:800; text-transform:uppercase; letter-spacing:-.01em; line-height:1.2; padding-right:30px; margin-bottom:4px; }
.modal-content { padding:14px 18px 20px; }
.detail-rows { display:flex; flex-direction:column; gap:8px; }
.detail-row  { display:flex; align-items:flex-start; gap:10px; font-size:13px; padding-bottom:8px; border-bottom:1px solid var(--grigio-mid); }
.detail-row:last-child { border-bottom:none; padding-bottom:0; }
.detail-icon { font-size:14px; width:20px; text-align:center; flex-shrink:0; margin-top:1px; }
.detail-lbl  { font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:.07em; color:var(--grigio-dark); min-width:62px; flex-shrink:0; margin-top:2px; }
.detail-val  { color:var(--testo); font-weight:500; }
.modal-actions { display:flex; gap:8px; margin-top:16px; padding-top:14px; border-top:1.5px solid var(--grigio-mid); }
.btn-edit   { flex:1; padding:9px; background:var(--giallo); color:var(--nero); border:1.5px solid var(--nero); border-radius:var(--radius); font-family:var(--font-display); font-size:11px; font-weight:800; text-transform:uppercase; cursor:pointer; transition:background .1s; }
.btn-edit:hover { background:var(--giallo-dark); }
.btn-delete { padding:9px 14px; background:none; color:#c00; border:1.5px solid #fca5a5; border-radius:var(--radius); font-family:var(--font-display); font-size:11px; font-weight:700; text-transform:uppercase; cursor:pointer; transition:background .1s; }
.btn-delete:hover { background:#fff5f5; }
.day-ev-list { display:flex; flex-direction:column; gap:6px; }
.day-ev-item { border:1px solid var(--grigio-mid); border-left-width:4px; border-radius:var(--radius); padding:10px 12px; cursor:pointer; transition:background .1s; }
.day-ev-item:hover { background:var(--grigio-bg); }
.dei-type  { font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:.07em; color:var(--grigio-dark); margin-bottom:2px; }
.dei-title { font-family:var(--font-display); font-size:13px; font-weight:700; }
.dei-meta  { font-family:var(--font-mono); font-size:11px; color:var(--grigio-dark); margin-top:2px; }
.form-grid { display:flex; flex-direction:column; gap:13px; }
.form-row  { display:flex; gap:10px; }
.form-row .form-field { flex:1; margin-bottom:0; }

/* ══ CALENDAR VIEW TOGGLE ══ */
.cal-view-toggle { display:flex; gap:3px; background:var(--grigio-bg); border:1.5px solid var(--grigio-mid); border-radius:var(--radius); padding:2px; flex-shrink:0; }
.view-btn { padding:4px 12px; border:none; border-radius:4px; background:none; font-family:var(--font-display); font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:.05em; color:var(--grigio-dark); cursor:pointer; transition:background .15s, color .15s; white-space:nowrap; }
.view-btn:hover { color:var(--testo); }
.view-btn.active { background:var(--bianco); color:var(--nero); box-shadow:0 1px 3px rgba(0,0,0,.1); }

/* ══ AGENDA VIEW ══ */
.cal-body.agenda-mode { padding:0; overflow:hidden; display:flex; flex-direction:column; }
.agenda-view { flex:1; overflow-y:auto; padding:10px 12px 16px; display:block; }
.agenda-view::-webkit-scrollbar { width:4px; }
.agenda-view::-webkit-scrollbar-thumb { background:var(--grigio-mid); border-radius:2px; }

.agenda-day { background:var(--bianco); border:1.5px solid var(--grigio-mid); border-radius:8px; overflow:hidden; margin-bottom:6px; }
.agenda-day.is-today { border-color:var(--giallo); border-width:2px; }
.agenda-day.is-past  { opacity:.65; }

.agenda-day-hd { display:flex; align-items:center; gap:10px; padding:8px 12px; background:var(--grigio-bg); border-bottom:1px solid var(--grigio-mid); }
.agenda-day.is-today .agenda-day-hd { background:var(--giallo-light); }

.agenda-day-num { font-family:var(--font-display); font-size:18px; font-weight:900; line-height:1; width:30px; text-align:center; flex-shrink:0; }
.agenda-day-num.today-circle { background:var(--nero); color:var(--giallo); border-radius:50%; width:30px; height:30px; display:flex; align-items:center; justify-content:center; font-size:14px; }

.agenda-day-sub { display:flex; flex-direction:column; }
.agenda-dow { font-family:var(--font-display); font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.06em; }
.agenda-mon { font-family:var(--font-mono); font-size:10px; color:var(--grigio-dark); text-transform:uppercase; }

.agenda-evs { display:flex; flex-direction:column; }

.agenda-ev { display:flex; align-items:center; gap:10px; padding:9px 12px; border-bottom:1px solid var(--grigio-mid); cursor:pointer; transition:background .1s; }
.agenda-ev:last-child { border-bottom:none; }
.agenda-ev:hover { background:var(--grigio-bg); }

.ae-bar  { width:4px; min-height:32px; border-radius:2px; background:var(--ev-color, #ccc); flex-shrink:0; align-self:stretch; }
.ae-time { font-family:var(--font-mono); font-size:11px; color:var(--grigio-dark); width:38px; flex-shrink:0; text-align:right; }
.ae-info { flex:1; min-width:0; }
.ae-title { font-size:13px; font-weight:600; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.ae-meta  { font-size:11px; color:var(--grigio-dark); margin-top:1px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }

.ae-badge { font-family:var(--font-display); font-size:9px; font-weight:700; text-transform:uppercase; letter-spacing:.05em; padding:2px 7px; border-radius:3px; flex-shrink:0; }
.ae-badge.match    { background:#dbeafe; color:#1d4ed8; }
.ae-badge.event    { background:#ede9fe; color:#7c3aed; }
.ae-badge.training { background:#dcfce7; color:#059669; }

.agenda-empty { padding:32px 16px; text-align:center; font-size:13px; color:var(--grigio-dark); }

/* ══ MOBILE ══ */
@media (max-width: 768px) {
  /* Header compatto */
  .header-brand { width:auto; padding:0 12px; }
  .header-nav   { display:none; }
  .user-name, .role-badge { display:none; }
  .logout-btn { padding:5px 8px; font-size:10px; }

  /* Bottom nav */
  .bottom-nav { display:flex; align-items:stretch; background:var(--bianco); border-top:1.5px solid var(--grigio-mid); flex-shrink:0; height:var(--bnav-h); padding-bottom:env(safe-area-inset-bottom, 0); }
  .bnav-btn { flex:1; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:3px; background:none; border:none; cursor:pointer; color:var(--grigio-dark); padding:4px 0; transition:color .15s; -webkit-tap-highlight-color:transparent; }
  .bnav-btn.active { color:var(--nero); }
  .bnav-btn.active .bnav-icon { stroke:var(--nero); }
  .bnav-btn span { font-family:var(--font-display); font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:.04em; }
  .bnav-icon { width:22px; height:22px; stroke:var(--grigio-dark); transition:stroke .15s; }
  .bnav-btn.active .bnav-icon { stroke:var(--nero); }

  /* Views fill between header and bottom nav */
  .view-home.active, .view-users.active { padding-bottom:8px; }

  /* Home */
  .home-content { padding:16px 14px 24px; gap:14px; }
  .home-profile-card { padding:14px 16px; gap:12px; }
  .profile-avatar { width:42px; height:42px; font-size:15px; }
  .profile-name { font-size:15px; }
  .home-stats { grid-template-columns:repeat(3,1fr); gap:8px; }
  .stat-card  { padding:10px 12px; }
  .stat-val   { font-size:22px; }
  .home-nav-cards { gap:8px; }
  .home-nav-card  { min-width:120px; padding:12px 14px; }

  /* Calendar: sidebar as drawer */
  .view-calendar.active { position:relative; }
  .sidebar {
    position:fixed;
    top:var(--header-h);
    bottom:var(--bnav-h);
    left:0;
    width:280px;
    transform:translateX(-100%);
    z-index:200;
    box-shadow:4px 0 20px rgba(0,0,0,.15);
  }
  .sidebar.open { transform:translateX(0); }
  .sidebar-backdrop.open { display:block; position:fixed; inset:0; z-index:199; }
  .sidebar-toggle-btn { display:flex !important; }

  /* Calendar grid: leggermente più compatto */
  .cal-body { padding:6px 6px 8px; gap:2px; }
  .cal-grid  { gap:2px; }
  .day-cell  { padding:3px 3px 2px; }
  .day-num   { font-size:10px; width:18px; height:18px; }
  .ev-pill   { font-size:9px; padding:1px 3px; }
  .ev-time   { display:none; }
  .month-label { font-size:13px; min-width:140px; }

  /* Modal full-width */
  .modal { width:100%; max-width:100vw; border-radius:16px 16px 0 0; position:fixed; bottom:0; left:0; right:0; max-height:88vh; border-left:none; border-right:none; border-bottom:none; }
  #overlay { align-items:flex-end; }

  /* Agenda view mobile */
  .agenda-view { padding:8px 10px 12px; }
  .agenda-day-num { font-size:16px; }
  .ae-time { font-size:10px; width:34px; }
  .ae-title { font-size:12px; }
  .ae-badge { font-size:8px; padding:2px 5px; }
  .cal-view-toggle { }
  .view-btn { padding:4px 10px; font-size:9px; }
}
