:root{--navy: #1f3a5f;--navy-dark: #16293f;--accent: #2c6fb5;--bg: #f4f6f9;--card: #ffffff;--border: #e2e8f0;--text: #1f2937;--muted: #6b7280;--ok: #16a34a;--warn: #d97706;--crit: #dc2626;--radius: 10px;--shadow: 0 1px 3px rgba(0, 0, 0, .08), 0 1px 2px rgba(0, 0, 0, .04)}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--text);font-size:14px}a{color:var(--accent);text-decoration:none}.app-shell{display:flex;min-height:100vh}.sidebar{width:230px;background:var(--navy);color:#cbd5e1;display:flex;flex-direction:column;padding:16px 0;flex-shrink:0}.sidebar .brand{display:flex;align-items:center;gap:10px;padding:4px 18px 18px;color:#fff;font-weight:700;font-size:15px}.sidebar .brand img{height:30px;border-radius:6px;background:#fff;padding:2px}.sidebar nav a{display:flex;align-items:center;gap:10px;padding:10px 18px;color:#cbd5e1;font-weight:500}.sidebar nav a.active,.sidebar nav a:hover{background:var(--navy-dark);color:#fff}.sidebar .nav-section{padding:14px 18px 6px;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:#7d93ad}.sidebar .spacer{flex:1}.sidebar .logout{padding:10px 18px;color:#cbd5e1;cursor:pointer}.sidebar .logout:hover{color:#fff}.main{flex:1;display:flex;flex-direction:column;min-width:0}.topbar{height:56px;background:var(--card);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 22px}.topbar h1{font-size:17px;margin:0}.topbar .user{color:var(--muted);display:flex;align-items:center;gap:14px}.content{padding:22px;flex:1}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px}.card h2{margin:0 0 12px;font-size:15px}.grid{display:grid;gap:16px}.grid-stats{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}.stat{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;box-shadow:var(--shadow)}.stat .num{font-size:26px;font-weight:700;color:var(--navy)}.stat .lbl{color:var(--muted);font-size:12px;margin-top:2px}table{width:100%;border-collapse:collapse}th,td{text-align:left;padding:9px 10px;border-bottom:1px solid var(--border)}th{font-size:12px;text-transform:uppercase;letter-spacing:.03em;color:var(--muted)}tr:hover td{background:#f9fafb}.btn{display:inline-flex;align-items:center;gap:6px;background:var(--navy);color:#fff;border:none;border-radius:8px;padding:8px 14px;font-size:14px;font-weight:600;cursor:pointer}.btn:hover{background:var(--navy-dark)}.btn.secondary{background:#e5e9f0;color:var(--text)}.btn.secondary:hover{background:#d6dce6}.btn.danger{background:var(--crit)}.btn.ghost{background:transparent;color:var(--accent)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}.icon-btn{background:none;border:none;cursor:pointer;font-size:16px;color:var(--muted)}input,select,textarea{width:100%;padding:8px 10px;border:1px solid var(--border);border-radius:8px;font-size:14px;font-family:inherit;background:#fff}input:focus,select:focus,textarea:focus{outline:2px solid var(--accent);border-color:var(--accent)}.field{display:block;margin-bottom:12px}.field-label{display:block;font-size:12px;color:var(--muted);margin-bottom:4px;font-weight:600}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:0 16px}.badge{display:inline-block;padding:2px 9px;border-radius:999px;font-size:12px;font-weight:600}.badge-ok{background:#dcfce7;color:var(--ok)}.badge-in_scadenza{background:#fef3c7;color:var(--warn)}.badge-critico{background:#fee2e2;color:var(--crit)}.badge-scaduto{background:#dc2626;color:#fff}.badge-senza_data{background:#e5e7eb;color:var(--muted)}.pill{background:#eef2f7;color:var(--navy);border-radius:999px;padding:2px 9px;font-size:12px;font-weight:600;margin:2px;display:inline-block}.toasts{position:fixed;bottom:18px;right:18px;display:flex;flex-direction:column;gap:8px;z-index:9999}.toast{padding:11px 16px;border-radius:8px;color:#fff;box-shadow:var(--shadow);font-weight:500;max-width:360px}.toast-ok{background:var(--ok)}.toast-err{background:var(--crit)}.toast-info{background:var(--navy)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px}.modal{background:#fff;border-radius:12px;width:460px;max-width:100%;max-height:90vh;overflow:auto;box-shadow:0 10px 40px #0003}.modal-wide{width:720px}.modal-head{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border)}.modal-head h3{margin:0;font-size:16px}.modal-body{padding:18px}.login-wrap{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,var(--navy),var(--accent))}.login-card{background:#fff;border-radius:14px;padding:32px;width:360px;box-shadow:0 12px 40px #00000040}.login-card .logo{text-align:center;margin-bottom:18px}.login-card .logo img{height:52px}.login-card h2{text-align:center;margin:4px 0 20px;color:var(--navy)}.empty{color:var(--muted);text-align:center;padding:30px}.muted{color:var(--muted)}.row-between{display:flex;align-items:center;justify-content:space-between;gap:12px}.spinner{width:26px;height:26px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;margin:30px auto}@keyframes spin{to{transform:rotate(360deg)}}.notif-dot{background:var(--crit);color:#fff;border-radius:999px;font-size:11px;padding:1px 6px}.mobile-shell{max-width:480px;margin:0 auto;min-height:100vh;background:var(--bg);display:flex;flex-direction:column}.mobile-head{background:var(--navy);color:#fff;padding:16px 18px;display:flex;align-items:center;justify-content:space-between}.mobile-head .hi{font-size:13px;opacity:.85}.mobile-head .nm{font-size:17px;font-weight:700}.mobile-content{flex:1;padding:16px 16px 78px}.mobile-tabbar{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:480px;background:#fff;border-top:1px solid var(--border);display:flex;justify-content:space-around;padding:8px 0}.mobile-tabbar a{color:var(--muted);display:flex;flex-direction:column;align-items:center;font-size:11px;gap:2px}.mobile-tabbar a.active{color:var(--navy);font-weight:700}.mobile-tabbar a .ico{font-size:20px}.big-action{width:100%;padding:22px;border-radius:14px;border:none;color:#fff;font-size:18px;font-weight:700;cursor:pointer;margin-bottom:14px}.big-in{background:var(--ok)}.big-out{background:var(--crit)}.tile{background:#fff;border:1px solid var(--border);border-radius:12px;padding:16px;margin-bottom:12px;box-shadow:var(--shadow)}.tile h3{margin:0 0 8px;font-size:15px}.list-item{display:flex;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--border)}.list-item:last-child{border-bottom:none}@media(max-width:640px){.form-grid{grid-template-columns:1fr}}
