:root {
  --blu:#1F4E79;--blu-l:#E6F1FB;--blu-m:#185FA5;
  --grigio:#5F5E5A;--grigio-l:#F1EFE8;
  --rosso:#A32D2D;--rosso-l:#FCEBEB;
  --bordo:#BFBFBF;--testo:#1a1a1a;--sfondo:#f8f8f6;--b:#fff;--r:6px;
}
*{box-sizing:border-box;margin:0;padding:0;}
body{font-family:'Segoe UI',system-ui,sans-serif;font-size:13px;background:var(--sfondo);color:var(--testo);}

/* ── HEADER ── */
header{background:var(--blu);color:#fff;padding:11px 20px;display:flex;align-items:center;justify-content:space-between;}
header h1{font-size:15px;font-weight:600;}
.hdr-r{display:flex;align-items:center;gap:12px;}
.hdr-user{font-size:12px;opacity:.8;}
.logout-btn{padding:4px 12px;background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.2);border-radius:20px;color:#fff;cursor:pointer;font-size:12px;font-weight:600;text-decoration:none;}
.logout-btn:hover{background:rgba(255,255,255,.25);}

/* ── LAYOUT ── */
.main{padding:24px;max-width:900px;margin:0 auto;}

/* ── APPS GRID ── */
.apps-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;}
.app-card{display:block;background:var(--b);border:1px solid var(--bordo);border-radius:var(--r);padding:20px;text-decoration:none;color:var(--testo);transition:box-shadow .15s,border-color .15s;}
.app-card:hover{border-color:var(--blu-m);box-shadow:0 2px 10px rgba(0,0,0,.08);}
.app-name{font-size:15px;font-weight:600;color:var(--blu);margin-bottom:6px;}
.app-desc{font-size:12px;color:var(--grigio);line-height:1.4;}

/* ── LOGIN ── */
.login-wrap{display:flex;align-items:center;justify-content:center;min-height:100vh;}
.login-card{background:var(--b);border:1px solid var(--bordo);border-radius:var(--r);padding:36px;width:320px;box-shadow:0 2px 16px rgba(0,0,0,.07);}
.login-card h1{font-size:18px;font-weight:700;color:var(--blu);margin-bottom:6px;}
.login-sub{font-size:12px;color:var(--grigio);margin-bottom:22px;}
.login-error{background:var(--rosso-l);color:var(--rosso);border-radius:4px;padding:8px 12px;font-size:12px;margin-bottom:16px;}
.login-card label{display:block;font-size:11px;font-weight:600;color:var(--grigio);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;margin-top:14px;}
.login-card input{width:100%;padding:8px 10px;border:1px solid var(--bordo);border-radius:4px;font-size:13px;font-family:inherit;}
.login-card input:focus{outline:none;border-color:var(--blu-m);}
.login-card button{margin-top:22px;width:100%;padding:9px;background:var(--blu);color:#fff;border:none;border-radius:4px;font-size:13px;font-weight:600;cursor:pointer;}
.login-card button:hover{background:var(--blu-m);}

/* ── MISC ── */
.empty{padding:36px;text-align:center;color:var(--grigio);font-size:12px;}
