:root{--blu: #003366;--blu2: #2c76c3;--giallo: #ffe600;--bg: #eef2f7;--card: #ffffff;--ok: #2e7d32;--no: #c62828;--attesa: #ef6c00;--canc: #757575;--line: #e2e8f0;--shadow: 0 6px 24px rgba(0,0,0,.08)}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:Segoe UI,system-ui,-apple-system,sans-serif;background:var(--bg);color:#1f2937;-webkit-tap-highlight-color:transparent}.splash{display:grid;place-items:center;height:100vh;color:var(--blu);font-weight:600}.muted{color:#6b7280;font-size:.9rem}.center{text-align:center}.link{display:inline-block;margin-top:.5rem;text-decoration:none}.brand{color:var(--blu);font-weight:800;letter-spacing:.3px;margin:0}.brand.sm{font-size:1rem}.card{background:var(--card);border-radius:16px;box-shadow:var(--shadow)}.auth-wrap{min-height:100vh;display:grid;place-items:center;padding:1.2rem;background:linear-gradient(160deg,#036,#2c76c3)}.auth-card{width:100%;max-width:380px;padding:2rem 1.5rem}.auth-card h1{margin:0 0 .2rem;font-size:1.5rem}.field{display:flex;flex-direction:column;gap:.35rem;margin:.7rem 0}.field>span{font-size:.85rem;font-weight:600;color:#374151}.field input,.field select,.field textarea{padding:.7rem .8rem;border:1px solid var(--line);border-radius:10px;font-size:1rem;background:#fff;outline:none;transition:border-color .15s,box-shadow .15s}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--blu2);box-shadow:0 0 0 3px #2c76c326}.check{display:flex;align-items:center;gap:.5rem;margin:.4rem 0;font-size:.9rem}.row2{display:flex;gap:.7rem}.row2 .field{flex:1}.btn{border:none;border-radius:10px;padding:.7rem 1rem;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .08s,background .15s,opacity .15s}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.6;cursor:default}.btn.primary{background:var(--blu2);color:#fff;width:100%}.btn.primary:hover{background:#1e5a91}.btn.primary.big{padding:.95rem;font-size:1.1rem}.btn.ghost{background:transparent;color:var(--blu);border:1px solid var(--line)}.alert{padding:.6rem .8rem;border-radius:10px;font-size:.9rem;margin:.6rem 0}.alert.error{background:#fdecea;color:#b71c1c}.alert.ok{background:#e8f5e9;color:#1b5e20}.page{max-width:760px;margin:0 auto;min-height:100vh;display:flex;flex-direction:column}.topbar{display:flex;align-items:center;justify-content:space-between;padding:.9rem 1rem;background:#fff;box-shadow:0 2px 8px #0000000d;position:sticky;top:0;z-index:10}.tabs{display:flex;gap:.4rem;padding:.8rem 1rem 0;overflow-x:auto}.tab{flex:1;min-width:max-content;border:none;background:#fff;border-radius:12px 12px 0 0;padding:.6rem .8rem;font-weight:600;color:#6b7280;cursor:pointer;display:flex;align-items:center;gap:.4rem;justify-content:center;border-bottom:3px solid transparent}.tab.active{color:var(--blu);border-bottom-color:var(--blu)}.tab.active.ok{color:var(--ok);border-bottom-color:var(--ok)}.tab.active.no{color:var(--no);border-bottom-color:var(--no)}.tab.active.attesa{color:var(--attesa);border-bottom-color:var(--attesa)}.tab.active.canc{color:var(--canc);border-bottom-color:var(--canc)}.tab-count{background:#eef2f7;border-radius:999px;padding:.05rem .5rem;font-size:.78rem}.list{flex:1;padding:1rem;display:flex;flex-direction:column;gap:.8rem}.empty{text-align:center;color:#9ca3af;padding:2.5rem 1rem}.permesso-card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:1rem;box-shadow:0 2px 6px #0000000a}.pc-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:.4rem}.pc-tipo{font-weight:800;color:var(--blu)}.pc-periodo{font-size:1.1rem;font-weight:700}.pc-ore{color:#6b7280;font-size:.9rem}.pc-row{margin-top:.3rem;font-size:.95rem}.pc-row.no{color:var(--no)}.pc-foot{margin-top:.5rem;font-size:.8rem;color:#9ca3af}.badge{font-size:.72rem;font-weight:700;padding:.18rem .55rem;border-radius:999px;color:#fff}.badge.attesa{background:var(--attesa)}.badge.ok{background:var(--ok)}.badge.no{background:var(--no)}.badge.canc{background:var(--canc)}.fab{position:fixed;right:1.1rem;bottom:1.3rem;width:60px;height:60px;border-radius:50%;border:none;background:var(--blu2);color:#fff;font-size:2rem;line-height:1;cursor:pointer;box-shadow:0 8px 20px #2c76c373}.fab:active{transform:scale(.94)}.form-page .form-card{margin:1rem;padding:1.2rem}.seg{display:flex;gap:.5rem;margin:.6rem 0 1rem}.seg-btn{flex:1;padding:.7rem;border:2px solid var(--line);background:#fff;border-radius:12px;font-weight:700;color:#6b7280;cursor:pointer;transition:all .12s}.seg-btn.active{border-color:var(--blu2);color:var(--blu);background:#eaf2fb}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:grid;place-items:center;padding:1rem;z-index:50}.modal{background:#fff;border-radius:16px;width:100%;max-width:420px;padding:1.4rem;box-shadow:var(--shadow);animation:pop .15s ease-out}@keyframes pop{0%{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}.modal h3{margin:0 0 .6rem;color:var(--blu);text-align:center}.modal-body p{margin:.3rem 0}.big-name{text-align:center;font-weight:800;color:var(--blu2);font-size:1.2rem;margin-bottom:.6rem}.modal-actions{display:flex;gap:.6rem;margin-top:1rem}.modal-actions .btn{flex:1}
