@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";:root{font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.6;font-weight:400;--color-bg: #f5f7fb;--color-bg-soft: #eef1f6;--color-bg-panel: #ffffff;--color-border: #d6dbe5;--color-shadow: rgba(31, 41, 55, .08);--color-text: #1f2937;--color-text-muted: #586174;--color-text-soft: #6f7a8f;--color-primary: #2563eb;--color-primary-strong: #1d4ed8;--color-primary-soft: rgba(37, 99, 235, .12);--color-accent: #0ea5e9;--color-success: #16a34a;--color-warning: #d97706;--color-danger: #dc2626;color:var(--color-text);background-color:var(--color-bg);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:var(--color-primary);text-decoration:none;transition:color .2s ease}a:hover{color:var(--color-primary-strong)}body{margin:0;min-width:320px;min-height:100vh;background:#fbfcff;color:var(--color-text)}h1,h2,h3,h4,h5,h6{font-weight:600;color:var(--color-text)}button{border-radius:8px;border:1px solid var(--color-border);padding:.6em 1.2em;font-size:.95em;font-weight:600;font-family:inherit;background:#fff;color:var(--color-text);cursor:pointer;transition:all .2s ease;box-shadow:0 6px 16px #0f172a0f}button:hover{transform:translateY(-1px);box-shadow:0 10px 22px #0f172a1f}button:focus,button:focus-visible{outline:3px solid rgba(37,99,235,.35);outline-offset:2px}*{box-sizing:border-box}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;background:#fbfcff;color:var(--color-text);gap:18px}.spinner{width:56px;height:56px;border:5px solid #d6dbe5;border-top-color:var(--color-primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-screen p{font-size:1rem;color:var(--color-text-soft)}.app{min-height:100vh;display:flex;flex-direction:column}.navbar{background:#fff;border-bottom:1px solid var(--color-border);padding:18px 32px;display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;z-index:100;box-shadow:0 4px 16px #0f172a14}.nav-brand{display:flex;flex-direction:column;gap:4px}.nav-brand h1{font-size:1.4rem;letter-spacing:.04em;color:var(--color-text)}.user-info{font-size:.8rem;text-transform:uppercase;letter-spacing:.14em;color:var(--color-text-soft)}.nav-menu{display:flex;align-items:center;gap:12px}.nav-menu button{background:#fff;border:1px solid var(--color-border);color:var(--color-text-soft);padding:9px 18px;border-radius:8px;font-size:.9rem;transition:all .2s ease}.nav-menu button:hover{color:var(--color-text);border-color:var(--color-primary);box-shadow:0 8px 20px #0f172a1f}.nav-menu button.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff;box-shadow:0 10px 24px #2563eb40}.btn-logout{background:#fff!important;color:var(--color-danger)!important;border-color:#dc262640!important}.btn-logout:hover{background:#fef2f2!important;color:#b91c1c!important}.main-content{flex:1;width:min(1240px,100% - 48px);margin:0 auto;padding:36px 0 60px;display:flex;flex-direction:column;gap:28px}.section-title{font-size:1.25rem;color:var(--color-text)}.section-subtitle{font-size:.9rem;color:var(--color-text-soft)}.scadenze-page{display:flex;flex-direction:column;gap:20px}.scadenze-header{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.scadenze-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}.scadenze-table-wrapper{border-radius:16px;border:1px solid var(--color-border);background:#fff;box-shadow:0 12px 30px #0f172a14;overflow:hidden}.scadenze-table{width:100%;border-collapse:collapse;font-size:.9rem;color:var(--color-text)}.scadenze-table thead{background:#f4f6fb;text-transform:uppercase;letter-spacing:.08em;font-size:.78rem;color:var(--color-text-muted)}.scadenze-table th,.scadenze-table td{padding:16px;border-bottom:1px solid var(--color-border);vertical-align:middle}.scadenze-table tbody tr:hover{background:#2563eb0d}.scadenza-table-meta{display:flex;flex-direction:column;gap:4px}.scadenza-table-meta .meta-cat{font-weight:600;color:var(--color-text)}.scadenza-table-meta .meta-prod{color:var(--color-text-soft);font-size:.85rem}.col-giorni{font-weight:600;color:var(--color-text)}.scadenza-card{border-radius:12px;padding:20px;background:#fff;border:1px solid var(--color-border);box-shadow:0 10px 28px #0f172a14;transition:transform .2s ease,box-shadow .2s ease}.scadenza-card:hover{transform:translateY(-4px);box-shadow:0 14px 32px #0f172a1f}.scadenza-card h3{margin:0 0 6px;font-size:1.1rem;color:var(--color-text);cursor:pointer}.scadenza-card h3:hover{color:var(--color-primary)}.scadenza-card p{margin:4px 0;color:var(--color-text-soft);font-size:.9rem}.scadenza-info{margin-top:12px;padding-top:12px;border-top:1px solid var(--color-border);display:flex;justify-content:space-between;align-items:center;color:var(--color-text);font-weight:500}.badge{padding:6px 10px;border-radius:999px;font-size:.75rem;font-weight:600}.badge.ok{background:#16a34a1f;color:#15803d}.badge.attenzione{background:#0d94881f;color:#0f766e}.badge.urgente{background:#d977061f;color:#b45309}.badge.scaduto{background:#dc26261f;color:#b91c1c}@media(max-width:820px){.scadenze-header{flex-direction:column;align-items:stretch}.scadenze-table th,.scadenze-table td{padding:12px 14px}}.config-page{display:grid;gap:24px}.config-section{background:#fff;border:1px solid var(--color-border);border-radius:16px;padding:26px 28px;box-shadow:0 12px 30px #0f172a14;display:flex;flex-direction:column;gap:20px}.config-section h2{margin:0;font-size:1.2rem}.config-form{display:grid;gap:16px}.config-form .form-group{display:grid;gap:6px}.config-form label{font-size:.8rem;text-transform:uppercase;letter-spacing:.12em;color:var(--color-text-soft)}.input-button,.input-row{display:flex;gap:12px;flex-wrap:wrap}.input-button input,.input-row input,.input-row select,.input-row textarea{flex:1;min-width:180px;padding:10px 14px;border-radius:8px;border:1px solid var(--color-border);background:#fbfcff;color:var(--color-text);font-size:.9rem;transition:border-color .2s ease,box-shadow .2s ease}.input-button input:focus,.input-row input:focus,.input-row select:focus,.input-row textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-soft);outline:none}.btn-add{background:#2563eb;border-color:var(--color-primary);color:#fff;box-shadow:0 10px 24px #2563eb33}.btn-add:hover{transform:translateY(-1px);box-shadow:0 12px 28px #2563eb3d}.btn-add:disabled{background:#edf0f7;border-color:var(--color-border);color:var(--color-text-soft);box-shadow:none;cursor:not-allowed}.categorie-list{display:flex;flex-direction:column;gap:14px}.categoria-item{padding:18px;border-radius:12px;border:1px solid var(--color-border);background:#fff;display:grid;gap:12px}.categoria-header{display:flex;justify-content:space-between;align-items:center}.categoria-header h3{margin:0;font-size:1rem;color:var(--color-text)}.btn-delete-small{background:#fff;width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;border:1px solid rgba(220,38,38,.22);color:var(--color-danger);cursor:pointer;transition:all .2s ease}.btn-delete-small:hover{background:#dc262614}.prodotti-tags{display:flex;flex-wrap:wrap;gap:10px}.prodotto-tag{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;border-radius:999px;background:#eef2f8;color:#405172;font-size:.85rem}.btn-delete-tag{background:transparent;border:none;color:inherit;cursor:pointer;font-size:.9rem;padding:0;display:flex;align-items:center;transition:transform .2s ease}.btn-delete-tag:hover{transform:scale(1.1)}.empty-tag{color:var(--color-text-soft);font-style:italic}.backup-actions{display:flex;gap:12px;flex-wrap:wrap}.btn-export,.btn-import{display:inline-flex;align-items:center;gap:10px;padding:12px 20px;border-radius:8px;background:linear-gradient(180deg,#fff,#f4f6fa);border:1px solid var(--color-border);color:var(--color-text);font-weight:600}.btn-export:hover,.btn-import:hover{transform:translateY(-1px);box-shadow:0 10px 24px #0f172a1f}.btn-import input{display:none}.empty-state{margin-top:24px;padding:36px;border-radius:12px;background:#f5f7fb;border:1px dashed var(--color-border);color:var(--color-text-soft);text-align:center}@media(max-width:1024px){.navbar{flex-direction:column;align-items:flex-start;gap:14px}.nav-menu{width:100%;flex-wrap:wrap}.main-content{width:92%}}@media(max-width:640px){.navbar{padding:16px}.nav-menu button{flex:1}.scadenze-grid{grid-template-columns:1fr}.config-section{padding:20px}.input-button,.input-row{flex-direction:column;align-items:stretch}.btn-export,.btn-import{width:100%;justify-content:center}}.template-attribute-list{display:flex;flex-direction:column;gap:14px}.config-placeholder{color:var(--color-text-soft);font-style:italic;margin:0}.template-attribute-item{padding:18px;border-radius:12px;border:1px solid var(--color-border);background:#fff;display:flex;justify-content:space-between;align-items:flex-start;gap:14px}.template-attribute-meta{display:grid;gap:8px;flex:1}.template-attribute-type{display:inline-block;padding:4px 10px;border-radius:999px;background:#eef2f8;color:#405172;font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;font-weight:600}.template-attribute-options{color:var(--color-text-soft);font-size:.88rem}.template-attribute-actions{display:flex;gap:8px}.btn-edit-small{background:#fff;width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;border:1px solid var(--color-border);color:var(--color-primary-strong);cursor:pointer;transition:all .2s ease}.btn-edit-small:hover{background:#2563eb14;border-color:#2563eb4d}.form-edit-notice{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-radius:8px;background:#fef3c7;border:1px solid #fbbf24;color:#92400e;font-size:.9rem;gap:12px}.form-edit-notice strong{color:#78350f}.btn-cancel-edit{background:transparent;border:1px solid #d97706;color:#92400e;padding:6px 12px;border-radius:6px;font-size:.82rem;cursor:pointer;transition:all .2s ease;white-space:nowrap}.btn-cancel-edit:hover{background:#fef3c7;border-color:#b45309}.template-selectors{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.template-form{display:grid;gap:16px}.template-actions{display:flex;gap:12px;flex-wrap:wrap}.config-subtitle{margin:-8px 0 0;color:var(--color-text-soft);font-size:.92rem;line-height:1.6}@media(max-width:720px){.template-selectors{grid-template-columns:1fr}.form-edit-notice{flex-direction:column;align-items:stretch}.btn-cancel-edit{width:100%}.template-attribute-actions{flex-direction:column}}.login-page{min-height:100vh;background:var(--color-bg);display:flex;justify-content:center;align-items:center;padding:48px 20px;color:var(--color-text)}.login-container{width:min(460px,100%);display:flex;flex-direction:column;gap:26px}.login-header{text-align:center;display:grid;gap:12px}.login-header h1{margin:0;font-size:2.2rem;letter-spacing:.04em}.login-header p{margin:0;font-size:1rem;color:var(--color-text-muted)}.login-card{padding:36px 34px;background:#fff;border-radius:16px;border:1px solid var(--color-border);box-shadow:0 20px 44px #0f172a1f;display:flex;flex-direction:column;gap:26px}.login-tabs{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));background:var(--color-bg-soft);border-radius:12px;padding:6px;border:1px solid var(--color-border)}.login-tab{border:none;background:transparent;color:var(--color-text-muted);font-size:.95rem;font-weight:600;letter-spacing:.04em;padding:12px 10px;border-radius:8px;cursor:pointer;transition:background .2s ease,color .2s ease,box-shadow .2s ease}.login-tab.active{background:#fff;color:var(--color-text);box-shadow:0 6px 16px #0f172a14}.login-form{display:flex;flex-direction:column;gap:18px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-size:.85rem;text-transform:uppercase;letter-spacing:.14em;color:var(--color-text-muted)}.form-group input{width:100%;padding:12px 14px;border-radius:8px;border:1px solid var(--color-border);background:#fff;color:var(--color-text);font-size:.95rem;transition:border-color .2s ease,box-shadow .2s ease}.form-group input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-soft);outline:none}.form-group input:disabled{background:#f3f4f8;color:var(--color-text-muted);cursor:not-allowed}.login-error{padding:12px 14px;border-radius:8px;border:1px solid rgba(220,38,38,.2);background:#dc262614;color:#b91c1c;font-size:.9rem}.btn-login{width:100%;padding:12px 14px;border-radius:8px;border:1px solid var(--color-primary);background:var(--color-primary);color:#fff;font-size:.98rem;font-weight:600;box-shadow:0 14px 36px #2563eb38;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.btn-login:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 16px 40px #2563eb42}.btn-login:disabled{opacity:.55;cursor:not-allowed}.login-divider{position:relative;text-align:center;color:var(--color-text-muted);font-size:.85rem;letter-spacing:.14em}.login-divider:before,.login-divider:after{content:"";position:absolute;top:50%;width:32%;height:1px;background:#94a3b840}.login-divider:before{left:0}.login-divider:after{right:0}.login-divider span{background:#fff;padding:0 12px;position:relative}.btn-google{width:100%;padding:12px 14px;border-radius:8px;border:1px solid var(--color-border);background:#fff;color:var(--color-text);font-size:.95rem;font-weight:600;display:flex;align-items:center;justify-content:center;gap:10px;transition:border-color .2s ease,box-shadow .2s ease}.btn-google:hover:not(:disabled){border-color:var(--color-primary);box-shadow:0 12px 28px #0f172a1f}.btn-google:disabled{opacity:.55;cursor:not-allowed}.login-footer{text-align:center;font-size:.95rem;color:var(--color-text-muted)}.link-button{background:none;border:none;color:var(--color-primary);font-weight:600;cursor:pointer;padding:0;font-size:.95rem;text-decoration:underline}.link-button:hover{color:var(--color-primary-strong)}.login-info{text-align:center;color:var(--color-text-muted);font-size:.9rem;display:grid;gap:6px}.login-info p{margin:0}@media(max-width:640px){.login-card{padding:28px 24px}.login-header h1{font-size:1.9rem}.login-divider:before,.login-divider:after{width:28%}}.gestione-clienti-wrapper{width:100%;display:flex;flex-direction:column;gap:24px}.guida-rapida{padding:22px;border-radius:12px;background:#fff;border:1px solid var(--color-border);box-shadow:0 12px 26px var(--color-shadow);color:var(--color-text)}.guida-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.guida-header h3{margin:0;font-size:1.05rem}.btn-close-guida{background:#fff;border:1px solid var(--color-border);color:var(--color-text-soft);width:28px;height:28px;border-radius:6px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s ease}.btn-close-guida:hover{background:#f1f4f9}.guida-steps{margin:0;padding-left:20px;display:grid;gap:8px;color:var(--color-text-soft);font-size:.92rem}.guida-steps li strong{color:var(--color-text)}.gestione-clienti{display:grid;grid-template-columns:minmax(320px,380px) 1fr;gap:24px}.form-section,.lista-section{display:flex;flex-direction:column;gap:18px}.form-section h2,.lista-section h2{margin:0;font-size:1.2rem}.section-description{margin:0;padding:14px;border-radius:10px;background:#f4f6fb;border:1px solid var(--color-border);color:var(--color-text-soft);line-height:1.6}.cliente-form{background:#fff;border-radius:12px;padding:24px;border:1px solid var(--color-border);box-shadow:0 12px 26px var(--color-shadow);display:flex;flex-direction:column;gap:18px}.form-group label{font-size:.8rem;text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-soft)}.form-group input,.form-group textarea{width:100%;padding:11px 12px;border-radius:8px;border:1px solid var(--color-border);background:#fbfcff;color:var(--color-text);font-size:.92rem;transition:border-color .2s ease,box-shadow .2s ease;resize:vertical}.form-group textarea{min-height:96px}.form-group input:focus,.form-group textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-soft);outline:none}.form-actions{display:flex;gap:12px;flex-wrap:wrap}.btn-primary,.btn-secondary{flex:1;min-width:160px;padding:11px 14px;border-radius:8px;border:1px solid var(--color-border);font-size:.92rem;transition:all .2s ease}.btn-primary{background:linear-gradient(180deg,#2563eb,#1d4ed8);border-color:var(--color-primary);color:#fff;box-shadow:0 12px 28px #2563eb33}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 14px 32px #2563eb42}.btn-secondary{background:#fff;color:var(--color-text-soft)}.btn-secondary:hover{color:var(--color-text);border-color:var(--color-primary)}.lista-header{display:flex;justify-content:space-between;align-items:center;gap:12px}.lista-toolbar{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.view-toggle{display:inline-flex;border:1px solid var(--color-border);border-radius:999px;background:#fff;padding:4px;box-shadow:0 6px 18px #0f172a14}.view-toggle button{border:none;background:transparent;color:var(--color-text-soft);padding:6px 14px;border-radius:999px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s ease}.view-toggle button.active{background:var(--color-primary);color:#fff;box-shadow:0 8px 18px #2563eb2e}.search-input{flex:0 0 260px;padding:10px 12px;border-radius:8px;border:1px solid var(--color-border);background:#fbfcff;color:var(--color-text);font-size:.9rem}.search-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-soft);outline:none}.clienti-table-wrapper{border-radius:12px;border:1px solid var(--color-border);background:#fff;box-shadow:0 12px 26px var(--color-shadow);overflow:hidden}.clienti-table{width:100%;border-collapse:collapse;font-size:.9rem;color:var(--color-text)}.clienti-table thead{background:#f4f6fb;text-transform:uppercase;letter-spacing:.08em;font-size:.78rem;color:var(--color-text-muted)}.clienti-table th,.clienti-table td{padding:14px 16px;border-bottom:1px solid var(--color-border);vertical-align:top}.clienti-table tbody tr:hover{background:#2563eb0a}.link-button{background:none;border:none;color:var(--color-primary-strong);font-weight:600;padding:0;cursor:pointer;text-align:left}.link-button:hover{text-decoration:underline}.btn-inline{border:1px solid var(--color-border);background:#fff;color:var(--color-text);border-radius:6px;padding:6px 10px;font-size:.82rem;cursor:pointer;transition:all .2s ease}.btn-inline:hover{border-color:var(--color-primary);color:var(--color-primary-strong)}.btn-inline.danger{color:var(--color-danger);border-color:#dc262638}.btn-inline.danger:hover{background:#dc262614;border-color:#dc262652}.col-actions{display:flex;gap:8px;flex-wrap:wrap;min-width:160px}.col-note{max-width:260px;color:var(--color-text-soft)}.clienti-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:18px}.cliente-card{background:#fff;border-radius:12px;padding:20px;border:1px solid var(--color-border);box-shadow:0 12px 26px var(--color-shadow);transition:transform .2s ease,box-shadow .2s ease}.cliente-card:hover{transform:translateY(-3px);box-shadow:0 16px 32px #0f172a1f}.cliente-header{cursor:pointer;padding-bottom:12px;border-bottom:1px solid var(--color-border);margin-bottom:12px;display:flex;justify-content:space-between;align-items:center;gap:10px}.cliente-header h3{margin:0;font-size:1.05rem;color:var(--color-text)}.click-hint{font-size:.75rem;color:var(--color-text-soft);display:flex;align-items:center;gap:4px}.cliente-header:hover h3{color:var(--color-primary)}.cliente-info{display:grid;gap:8px;color:var(--color-text-soft);font-size:.9rem}.cliente-info p{margin:0;display:flex;align-items:center;gap:6px}.cliente-info .note{font-style:italic;color:var(--color-text-soft);padding-top:10px;margin-top:10px;border-top:1px solid var(--color-border)}.cliente-actions{display:flex;gap:10px;margin-top:16px;padding-top:14px;border-top:1px solid var(--color-border)}.btn-edit,.btn-delete{flex:1;padding:9px 12px;border-radius:8px;border:1px solid var(--color-border);font-size:.88rem;display:inline-flex;align-items:center;justify-content:center;gap:6px;transition:all .2s ease}.btn-edit{background:#f1f4fb;color:var(--color-primary-strong)}.btn-edit:hover{background:#2563eb1f;border-color:#2563eb40}.btn-delete{background:#fff5f5;color:var(--color-danger)}.btn-delete:hover{background:#dc26261a;border-color:#dc262633}.empty-state{margin-top:18px;padding:32px 16px;border-radius:12px;border:1px dashed var(--color-border);background:#f7f9fd;color:var(--color-text-soft);text-align:center}@media(max-width:1100px){.gestione-clienti{grid-template-columns:1fr}.lista-header{align-items:flex-start}.search-input{flex:1}.lista-toolbar{width:100%}.col-actions{min-width:120px}}@media(max-width:720px){.form-row{grid-template-columns:1fr}.form-actions{flex-direction:column}.lista-toolbar{flex-direction:column;align-items:stretch}.view-toggle{justify-content:center;width:100%}.search-input{width:100%}.col-note{max-width:none}}@media(max-width:520px){.cliente-form{padding:20px}.cliente-card{padding:18px}.clienti-grid{grid-template-columns:1fr}.clienti-table th,.clienti-table td{padding:12px}}.scheda-cliente-overlay{position:fixed;inset:0;background:#11182759;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;justify-content:center;align-items:center;padding:36px 24px;z-index:1000}.scheda-cliente{width:min(1240px,100%);max-height:92vh;background:var(--color-bg-panel);border:1px solid var(--color-border);border-radius:18px;box-shadow:0 28px 60px #0f172a29;display:flex;flex-direction:column;overflow:hidden}.scheda-header{display:flex;justify-content:space-between;align-items:flex-start;gap:20px;padding:28px 32px 24px;background:var(--color-bg-soft);border-bottom:1px solid var(--color-border)}.scheda-header h2{margin:0 0 8px;font-size:1.5rem;color:var(--color-text)}.cliente-details{display:flex;flex-wrap:wrap;gap:12px 20px;color:var(--color-text-soft);font-size:.92rem}.cliente-details span{display:inline-flex;align-items:center;gap:6px}.header-actions{display:flex;align-items:center;gap:12px}.anno-selector{padding:10px 14px;border-radius:8px;border:1px solid var(--color-border);background:#fff;color:var(--color-text);font-weight:600;letter-spacing:.04em;transition:border-color .2s ease,box-shadow .2s ease}.anno-selector:hover,.anno-selector:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-soft);outline:none}.btn-close{width:38px;height:38px;border-radius:8px;border:1px solid rgba(220,38,38,.26);background:#fff;color:var(--color-danger);font-size:1.1rem;display:grid;place-items:center;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.btn-close:hover{transform:translateY(-2px);box-shadow:0 10px 24px #dc26262e}.scheda-body{padding:28px 32px;overflow-y:auto;flex:1;background:var(--color-bg)}.scheda-body::-webkit-scrollbar{width:10px}.scheda-body::-webkit-scrollbar-track{background:#e8ecf5;border-radius:999px}.scheda-body::-webkit-scrollbar-thumb{background:#c5ccda;border-radius:999px}.servizi-section{display:flex;flex-direction:column;gap:24px}.section-header{display:flex;justify-content:space-between;align-items:center;gap:16px}.section-header h3{margin:0;font-size:1.25rem;color:var(--color-text)}.btn-add-servizio{padding:11px 20px;border-radius:8px;background:var(--color-primary);border:1px solid var(--color-primary);color:#fff;font-size:.92rem;font-weight:600;box-shadow:0 12px 28px #2563eb2e;transition:transform .2s ease,box-shadow .2s ease}.btn-add-servizio:hover{transform:translateY(-2px);box-shadow:0 16px 32px #2563eb38}.servizio-form{padding:24px;border-radius:12px;background:#fff;border:1px solid var(--color-border);box-shadow:0 16px 40px #0f172a1a;display:flex;flex-direction:column;gap:18px}.servizio-form .template-form-header{display:flex;justify-content:space-between;align-items:center;gap:12px}.servizio-form .template-add-button{border:1px solid var(--color-primary);background:#fff;color:var(--color-primary-strong);border-radius:8px;padding:9px 16px;font-size:.85rem;font-weight:600;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.servizio-form .template-add-button:hover{transform:translateY(-1px);border-color:var(--color-primary-strong);box-shadow:0 10px 22px #2563eb2e}.form-header-info{border-bottom:1px solid var(--color-border);padding-bottom:14px;display:grid;gap:6px}.form-header-info h4{margin:0;font-size:1.05rem;color:var(--color-primary-strong)}.form-header-info h4 .template-field{border-radius:8px;padding:14px;border:1px solid rgba(15,23,42,.08);background:#fff;box-shadow:0 10px 22px #0f172a14;gap:12px}.form-header-info h4 .template-field-header{display:flex;justify-content:space-between;align-items:center;gap:10px}.form-header-info h4 .template-remove-btn{background:#fff1f2;border:1px solid rgba(220,38,38,.28);color:#b91c1c;border-radius:8px;padding:6px 10px;cursor:pointer;font-size:.85rem;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.form-header-info h4 .template-remove-btn:hover{transform:translateY(-1px);border-color:#dc262666;box-shadow:0 10px 20px #dc262629}.form-header-info h4 .inline-template-form{border-top:1px solid var(--color-border);margin-top:6px;padding-top:14px;display:grid;gap:14px}.form-header-info h4 .inline-template-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.form-header-info h4 .template-inline-actions{display:flex;gap:10px;justify-content:flex-end}.form-header-info h4 .btn-secondary{padding:11px 24px;border-radius:8px;border:1px solid var(--color-border);background:#fff;color:var(--color-text);font-size:.9rem;font-weight:600;transition:transform .2s ease,box-shadow .2s ease}.form-header-info h4 .btn-secondary:hover{transform:translateY(-1px);box-shadow:0 10px 24px #0f172a1f}.form-header-info p{margin:0;color:var(--color-text-soft);font-size:.9rem;line-height:1.5}.form-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:.78rem;text-transform:uppercase;letter-spacing:.12em;color:var(--color-text-soft)}.form-group input,.form-group select{padding:11px 12px;border-radius:8px;border:1px solid var(--color-border);background:#fbfcff;color:var(--color-text);font-size:.94rem;transition:border-color .2s ease,box-shadow .2s ease}.form-group input:disabled,.form-group select:disabled{background:#f3f4f8;color:var(--color-text-muted);cursor:not-allowed}.form-group input:focus,.form-group select:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-soft);outline:none}.attributi-form{border-radius:10px;padding:18px;display:grid;gap:14px;border:1px solid var(--color-border);background:#f6f8fd}.attributi-form.has-template{border-color:#2563eb4d}.attributi-form.no-template{border-color:#d9770666;background:#fff7ed}.attributi-form h4{margin:0;font-size:.98rem;color:var(--color-primary-strong)}.form-help{margin:0;font-size:.85rem;color:var(--color-text-soft)}.info-message{margin:0;font-size:.9rem;font-weight:600;color:#b45309}.help-text{margin:0;font-size:.86rem;color:var(--color-text-soft);line-height:1.5}.checkbox-group{display:flex;flex-wrap:wrap;gap:10px}.checkbox-label{display:inline-flex;align-items:center;gap:8px;padding:9px 12px;border-radius:8px;background:#fff;border:1px solid var(--color-border);color:var(--color-text);font-size:.9rem;transition:border-color .2s ease,box-shadow .2s ease}.checkbox-label:hover{border-color:var(--color-primary);box-shadow:0 6px 14px #0f172a14}.checkbox-label input[type=checkbox]{width:16px;height:16px;cursor:pointer}.form-actions{display:flex;justify-content:flex-end;gap:12px}.btn-primary{padding:11px 24px;border-radius:8px;border:1px solid var(--color-primary);background:var(--color-primary);color:#fff;font-size:.94rem;font-weight:600;box-shadow:0 12px 28px #2563eb33;transition:transform .2s ease,box-shadow .2s ease}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 16px 34px #2563eb3d}.servizi-list{display:grid;gap:18px}.servizio-card{border-radius:12px;padding:20px;background:#fff;border:1px solid var(--color-border);box-shadow:0 14px 32px #0f172a1a;display:grid;gap:16px;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.servizio-card:hover{transform:translateY(-3px);box-shadow:0 18px 38px #0f172a24;border-color:#2563eb4d}.servizio-card.ok{border-left:4px solid rgba(22,163,74,.65)}.servizio-card.attenzione{border-left:4px solid rgba(13,148,136,.65)}.servizio-card.urgente{border-left:4px solid rgba(217,119,6,.7)}.servizio-card.scaduto{border-left:4px solid rgba(220,38,38,.7)}.servizio-header{display:flex;justify-content:space-between;gap:16px;align-items:flex-start}.servizio-header h4{margin:0 0 6px;font-size:1.08rem;color:var(--color-text)}.tipo-scadenza{display:inline-flex;align-items:center;padding:5px 12px;border-radius:999px;background:#e5edff;color:var(--color-primary-strong);font-size:.78rem;font-weight:600;letter-spacing:.06em}.servizio-actions{display:inline-flex;gap:8px}.btn-icon{background:#fff;border:1px solid var(--color-border);width:34px;height:34px;border-radius:8px;display:grid;place-items:center;color:var(--color-text);cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.btn-icon:hover{transform:translateY(-2px);border-color:var(--color-primary);box-shadow:0 12px 26px #0f172a1f}.btn-icon.btn-delete{color:var(--color-danger);border-color:#dc26264d}.servizio-scadenza{margin:0;padding:16px;border-radius:10px;background:#f7f9fd;border:1px solid var(--color-border);display:grid;gap:10px}.scadenza-info{display:flex;flex-wrap:wrap;gap:12px 20px;align-items:center;color:var(--color-text-soft);font-size:.92rem}.scadenza-info .label{font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.1em;font-size:.72rem}.scadenza-info .data{font-size:1.04rem;font-weight:600;color:var(--color-text)}.scadenza-info .giorni{padding:7px 14px;border-radius:999px;font-weight:600;font-size:.82rem;letter-spacing:.04em;border:1px solid transparent}.scadenza-info .giorni.ok{background:#16a34a1f;border-color:#16a34a3d;color:#166534}.scadenza-info .giorni.attenzione{background:#0d94881f;border-color:#0d94883d;color:#0f766e}.scadenza-info .giorni.urgente{background:#d9770624;border-color:#d9770642;color:#b45309}.scadenza-info .giorni.scaduto{background:#dc262624;border-color:#dc26264d;color:#b91c1c}.attributi-servizio{margin:0;padding:16px;border-radius:10px;border:1px solid var(--color-border);background:#f4f6fb;display:grid;gap:10px}.attributi-header{display:flex;justify-content:space-between;align-items:center;gap:10px}.attributi-servizio h4{margin:0;font-size:.92rem;letter-spacing:.08em;color:var(--color-text-muted);text-transform:uppercase}.btn-edit-attributi{background:#fff;border:1px solid var(--color-border);color:var(--color-primary-strong);border-radius:6px;padding:6px 12px;font-size:.82rem;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-edit-attributi:hover{border-color:var(--color-primary);box-shadow:0 8px 18px #2563eb24;transform:translateY(-1px)}.attributi-edit-form{display:grid;gap:14px;padding:14px;border-radius:8px;background:#fff;border:1px solid rgba(37,99,235,.2)}.attributi-edit-actions{display:flex;gap:10px;justify-content:flex-end;padding-top:10px;border-top:1px solid var(--color-border)}.attributo-item{display:flex;gap:8px;font-size:.94rem;color:var(--color-text-soft)}.attributo-label{font-weight:600;color:var(--color-text)}.attributo-value{color:var(--color-text-soft)}.tracking-section{margin:0;padding-top:14px;border-top:1px solid var(--color-border);display:grid;gap:10px}.tracking-section h5{margin:0;font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;color:var(--color-text-muted)}.tracking-checkboxes{display:flex;flex-wrap:wrap;gap:10px 16px}.tracking-checkboxes .checkbox-label{background:#fff;border:1px solid var(--color-border);border-radius:8px;padding:9px 12px;gap:8px}.tracking-checkboxes .checkbox-label span{font-size:.9rem;color:var(--color-text-soft);transition:color .2s ease}.tracking-checkboxes .checkbox-label span.checked{color:var(--color-success)}.empty-state{padding:40px 18px;border-radius:12px;border:1px dashed var(--color-border);background:#f7f9fd;color:var(--color-text-soft);text-align:center;font-size:.96rem}@media(max-width:1024px){.scheda-cliente-overlay{padding:24px 16px}.scheda-body{padding:24px}.form-row{grid-template-columns:1fr}}@media(max-width:720px){.scheda-header{flex-direction:column;align-items:flex-start}.header-actions{width:100%;justify-content:space-between}.section-header{flex-direction:column;align-items:flex-start;gap:12px}.btn-add-servizio{width:100%}}@media(max-width:640px){.inline-template-row{grid-template-columns:1fr}.template-inline-actions{justify-content:stretch}.template-inline-actions button{width:100%}}@media(max-width:560px){.scheda-body{padding:20px}.servizio-card{padding:18px}.servizio-scadenza{padding:14px}}
