*{margin:0;padding:0;box-sizing:border-box}:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Helvetica Neue,sans-serif;line-height:1.6;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh;color:#333;background-color:#f5f5f5}#root{min-height:100vh}button,input,select,textarea{font-family:inherit}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#f1f1f1}::-webkit-scrollbar-thumb{background:#888;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#555}.componente-form{background:#fff;border-radius:12px;padding:2rem;margin-bottom:2rem;box-shadow:0 2px 8px #0000001a}.componente-form h2{margin:0 0 1.5rem;color:#333;font-size:1.5rem}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:1.5rem}.form-group{display:flex;flex-direction:column;position:relative}.form-group label{margin-bottom:.5rem;font-weight:500;color:#555;font-size:.95rem}.form-group input,.form-group select{padding:.75rem;border:2px solid #e0e0e0;border-radius:6px;font-size:1rem;transition:border-color .2s}.form-group input:focus,.form-group select:focus{outline:none;border-color:#667eea}.autocomplete-wrapper{position:relative}.suggestions-list{position:absolute;top:100%;left:0;right:0;background:#fff;border:2px solid #667eea;border-top:none;border-radius:0 0 6px 6px;max-height:200px;overflow-y:auto;list-style:none;padding:0;margin:0;z-index:1000;box-shadow:0 4px 8px #0000001a}.suggestions-list li{padding:.75rem;cursor:pointer;transition:background .2s;border-bottom:1px solid #f0f0f0}.suggestions-list li:last-child{border-bottom:none}.suggestions-list li:hover{background:#f8f9ff}.suggestions-list strong{color:#667eea;font-weight:600}@media(max-width:768px){.componente-form{padding:1.5rem;border-radius:8px}.componente-form h2{font-size:1.3rem}.form-grid{grid-template-columns:1fr;gap:1rem}.suggestions-list{max-height:150px}}@media(max-width:480px){.componente-form{padding:1rem}.form-group input,.form-group select{padding:.6rem;font-size:.95rem}}.magazzino-list{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 2px 8px #0000001a}.list-header{margin-bottom:1.5rem}.list-header h2{margin:0 0 1rem;color:#333;font-size:1.5rem}.search-bar{display:flex;gap:1rem;flex-wrap:wrap}.search-bar input{flex:1;min-width:200px;padding:.75rem;border:2px solid #e0e0e0;border-radius:6px;font-size:1rem}.search-bar input:focus{outline:none;border-color:#667eea}.search-bar select{padding:.75rem;border:2px solid #e0e0e0;border-radius:6px;font-size:1rem;background:#fff;cursor:pointer}.search-bar select:focus{outline:none;border-color:#667eea}.componenti-table-wrapper{overflow-x:auto;margin-bottom:1rem}.componenti-table{width:100%;border-collapse:collapse;font-size:.95rem}.componenti-table thead{background:#f8f9fa}.componenti-table th{padding:1rem;text-align:left;font-weight:600;color:#555;border-bottom:2px solid #e0e0e0}.componenti-table td{padding:1rem;border-bottom:1px solid #f0f0f0}.componenti-table tbody tr:hover{background:#f8f9ff}.quantity-col{text-align:center;width:100px}.actions-col{width:250px;text-align:center}.quantity-badge{display:inline-block;padding:.4rem .8rem;background:#28a745;color:#fff;border-radius:20px;font-weight:600;min-width:40px}.quantity-badge.zero{background:#dc3545}.action-buttons{display:flex;gap:.5rem;justify-content:center;flex-wrap:wrap}.empty-state{text-align:center;padding:3rem;color:#999;font-size:1.1rem}.list-footer{padding-top:1rem;border-top:2px solid #e0e0e0;text-align:right;color:#666;font-weight:500}@media(max-width:768px){.magazzino-list{padding:1.5rem;border-radius:8px}.list-header h2{font-size:1.3rem}.search-bar{flex-direction:column}.search-bar input,.search-bar select{width:100%}.componenti-table{display:block}.componenti-table thead{display:none}.componenti-table tbody{display:block}.componenti-table tr{display:block;margin-bottom:1rem;border:2px solid #e0e0e0;border-radius:8px;overflow:hidden}.componenti-table tr:hover{background:#fff}.componenti-table td{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;border-bottom:1px solid #f0f0f0}.componenti-table td:last-child{border-bottom:none}.componenti-table td:before{content:attr(data-label);font-weight:600;color:#555}.quantity-col,.actions-col{width:auto}.action-buttons{justify-content:flex-end}}@media(max-width:480px){.magazzino-list{padding:1rem}.search-bar input,.search-bar select{padding:.6rem;font-size:.95rem}.componenti-table td{padding:.5rem .75rem;font-size:.9rem}.action-buttons{gap:.3rem}.btn-sm{padding:.3rem .6rem;font-size:.85rem}}.modal-backdrop{position:fixed;inset:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .2s ease-out}.modal-content{background:#fff;border-radius:12px;width:90%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 4px 20px #0000004d;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:2px solid #e0e0e0}.modal-header h2{margin:0;font-size:1.5rem;color:#333}.close-btn{background:none;border:none;font-size:2rem;color:#999;cursor:pointer;padding:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s}.close-btn:hover{background:#f0f0f0;color:#333;transform:none}.modal-body{padding:1.5rem}.modal-body .form-group{margin-bottom:1.5rem;position:relative}.modal-body .form-group:last-child{margin-bottom:0}.modal-body label{display:block;margin-bottom:.5rem;font-weight:500;color:#555;font-size:.95rem}.modal-body input{width:100%;padding:.75rem;border:2px solid #e0e0e0;border-radius:6px;font-size:1rem;transition:border-color .2s}.modal-body input:focus{outline:none;border-color:#667eea}.modal-body .autocomplete-wrapper{position:relative}.modal-body .suggestions-list{position:absolute;top:100%;left:0;right:0;background:#fff;border:2px solid #667eea;border-top:none;border-radius:0 0 6px 6px;max-height:200px;overflow-y:auto;list-style:none;padding:0;margin:0;z-index:1001;box-shadow:0 4px 8px #0000001a}.modal-body .suggestions-list li{padding:.75rem;cursor:pointer;transition:background .2s;border-bottom:1px solid #f0f0f0}.modal-body .suggestions-list li:last-child{border-bottom:none}.modal-body .suggestions-list li:hover{background:#f8f9ff}.modal-body .suggestions-list strong{color:#667eea;font-weight:600}.modal-footer{display:flex;justify-content:flex-end;gap:1rem;padding:1.5rem;border-top:2px solid #e0e0e0}.btn-secondary{background:#6c757d;color:#fff}@media(max-width:768px){.modal-content{width:95%;max-height:95vh}.modal-header,.modal-body,.modal-footer{padding:1rem}.modal-header h2{font-size:1.3rem}.modal-footer{flex-direction:column-reverse}.modal-footer .btn{width:100%}}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2)}.login-box{background:#fff;padding:2.5rem;border-radius:12px;box-shadow:0 10px 40px #0003;width:100%;max-width:420px}.login-header{text-align:center;margin-bottom:2rem}.login-header h1{margin:0;color:#333;font-size:1.8rem;font-weight:600}.login-header p{margin:.5rem 0 0;color:#666;font-size:.95rem}.login-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:500;color:#444;font-size:.95rem}.form-group input{padding:.75rem 1rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;transition:border-color .3s}.form-group input:focus{outline:none;border-color:#667eea}.form-group input:disabled{background-color:#f5f5f5;cursor:not-allowed}.error-message{padding:.75rem;background-color:#fee;color:#c33;border-radius:8px;font-size:.9rem;text-align:center}.btn-login{padding:.875rem 2rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.btn-login:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 15px #667eea66}.btn-login:disabled{opacity:.6;cursor:not-allowed}@media(max-width:480px){.login-box{padding:2rem;margin:1rem}.login-header h1{font-size:1.5rem}}.session-modal-overlay{position:fixed;inset:0;background-color:#000000bf;display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .3s ease-in-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.session-modal{background:#fff;border-radius:12px;padding:2.5rem;max-width:450px;width:90%;box-shadow:0 20px 60px #0000004d;text-align:center;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}.session-modal-icon{color:#f59e0b;margin:0 auto 1.5rem;width:64px;height:64px}.session-modal-title{font-size:1.75rem;font-weight:700;color:#1f2937;margin:0 0 1rem}.session-modal-message{font-size:1.125rem;color:#4b5563;margin:0 0 .75rem;font-weight:500}.session-modal-submessage{font-size:1rem;color:#6b7280;margin:0 0 2rem;line-height:1.5}.session-modal-button{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border:none;padding:.875rem 2.5rem;font-size:1rem;font-weight:600;border-radius:8px;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #2563eb4d;width:100%}.session-modal-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #2563eb66}.session-modal-button:active{transform:translateY(0)}@media(max-width:480px){.session-modal{padding:2rem 1.5rem}.session-modal-title{font-size:1.5rem}.session-modal-message{font-size:1rem}.session-modal-submessage{font-size:.9rem}}.app{min-height:100vh;background:#f5f5f5}.app-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:1.5rem;box-shadow:0 2px 4px #0000001a}.app-header h1{margin:0;font-size:1.8rem;font-weight:600}.app-main{max-width:1400px;margin:0 auto;padding:2rem 1rem}.message{max-width:1400px;margin:1rem auto;padding:1rem;border-radius:8px;font-weight:500;animation:slideIn .3s ease-out}.message-success{background:#d4edda;color:#155724;border:1px solid #c3e6cb}.message-error{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb}@keyframes slideIn{0%{transform:translateY(-20px);opacity:0}to{transform:translateY(0);opacity:1}}.loading{text-align:center;padding:3rem;font-size:1.2rem;color:#666}.btn{padding:.6rem 1.2rem;border:none;border-radius:6px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s;text-align:center}.btn:hover{transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.btn:active{transform:translateY(0)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn:disabled:hover{transform:none;box-shadow:none}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-success{background:#28a745;color:#fff}.btn-warning{background:#ffc107;color:#212529}.btn-danger{background:#dc3545;color:#fff}.btn-info{background:#17a2b8;color:#fff}.btn-delete{background:#6c757d;color:#fff}.btn-sm{padding:.4rem .8rem;font-size:.9rem}.search-bar{background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:1.5rem;display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.search-input{flex:1;min-width:250px;padding:.75rem 1rem;border:2px solid #e0e0e0;border-radius:6px;font-size:1rem;transition:all .2s}.search-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.search-info{color:#666;font-size:.9rem;white-space:nowrap}.pagination{background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-top:1.5rem;display:flex;align-items:center;justify-content:center;gap:1rem;flex-wrap:wrap}.pagination-btn{padding:.6rem 1.2rem;border:2px solid #667eea;border-radius:6px;background:#fff;color:#667eea;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s}.pagination-btn:hover:not(:disabled){background:#667eea;color:#fff;transform:translateY(-2px);box-shadow:0 4px 8px #667eea33}.pagination-btn:disabled{opacity:.3;cursor:not-allowed;border-color:#ccc;color:#ccc}.pagination-info{color:#666;font-size:1rem;font-weight:500;padding:0 1rem}.pagination-pages{display:flex;gap:.5rem}.pagination-page{width:40px;height:40px;border:2px solid #e0e0e0;border-radius:6px;background:#fff;color:#666;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.pagination-page:hover{border-color:#667eea;color:#667eea;transform:translateY(-2px)}.pagination-page.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:transparent}@media(max-width:768px){.app-header h1{font-size:1.4rem}.app-main{padding:1rem .5rem}.message{margin:.5rem;padding:.75rem}.search-bar{padding:1rem;flex-direction:column;align-items:stretch}.search-input{min-width:100%}.search-info{text-align:center}.pagination{padding:1rem;gap:.5rem}.pagination-btn{padding:.5rem .8rem;font-size:.9rem}.pagination-info{width:100%;text-align:center;padding:.5rem 0}.pagination-pages{flex-wrap:wrap;justify-content:center}.pagination-page{width:36px;height:36px;font-size:.9rem}}
