@import"https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@300;400;500;600;700;800&display=swap";@import"https://cdn.jsdelivr.net/npm/bootstrap-icons@1.11.3/font/bootstrap-icons.min.css";:root{--acea-primary: #3B9B9B;--acea-primary-light: #4DB5B5;--acea-primary-dark: #2D7A7A;--acea-secondary: #3B9B9B;--acea-secondary-light: #5FBFBF;--acea-accent: #2D7A7A;--color-luce: #fbbf24;--color-luce-light: #fcd34d;--color-luce-bg: #fef3c7;--color-gas: #3b82f6;--color-gas-light: #60a5fa;--color-gas-bg: #dbeafe;--color-dual-start: #fbbf24;--color-dual-end: #3b82f6;--gray-50: #f8fafc;--gray-100: #f1f5f9;--gray-200: #e2e8f0;--gray-300: #cbd5e1;--gray-400: #94a3b8;--gray-500: #64748b;--gray-600: #475569;--gray-700: #334155;--gray-800: #1e293b;--gray-900: #0f172a;--color-success: #10b981;--color-success-light: #d1fae5;--color-warning: #f59e0b;--color-warning-light: #fef3c7;--color-error: #ef4444;--color-error-light: #fee2e2;--color-info: #3b82f6;--color-info-light: #dbeafe;--font-family: "Plus Jakarta Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 2rem;--font-size-4xl: 2.5rem;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--spacing-3xl: 4rem;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .04);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .06), 0 1px 2px rgba(0, 0, 0, .04);--shadow: 0 4px 6px -1px rgba(0, 0, 0, .08), 0 2px 4px -1px rgba(0, 0, 0, .04);--shadow-md: 0 10px 15px -3px rgba(0, 0, 0, .08), 0 4px 6px -2px rgba(0, 0, 0, .04);--shadow-lg: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--shadow-xl: 0 25px 50px -12px rgba(0, 0, 0, .15);--shadow-glow: 0 0 40px rgba(59, 155, 155, .15);--shadow-glow-success: 0 0 30px rgba(16, 185, 129, .2);--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-2xl: 1.25rem;--radius-full: 9999px;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .2s cubic-bezier(.4, 0, .2, 1);--transition-slow: .3s cubic-bezier(.4, 0, .2, 1);--transition-spring: .5s cubic-bezier(.34, 1.56, .64, 1)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth}body{font-family:var(--font-family);font-size:var(--font-size-base);line-height:1.6;color:var(--gray-800);background:var(--gray-50);min-height:100vh}.app:before{content:"";position:fixed;top:0;left:0;right:0;bottom:0;background:radial-gradient(ellipse 80% 50% at 50% -20%,rgba(59,155,155,.08) 0%,transparent 50%),radial-gradient(ellipse 60% 40% at 100% 100%,rgba(59,155,155,.06) 0%,transparent 50%),linear-gradient(180deg,var(--gray-50) 0%,#f0f7ff 50%,var(--gray-50) 100%);z-index:-1}.app{display:flex;flex-direction:column;min-height:100vh;position:relative}.container{max-width:1200px;margin:0 auto;padding:0 var(--spacing-lg)}.app-header{background:#ffffffd9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid rgba(59,155,155,.08);padding:var(--spacing-md) 0;position:sticky;top:0;z-index:100;transition:all var(--transition-base)}.app-header:hover{background:#fffffff2}.app-header .container{display:flex;align-items:center;justify-content:space-between}.logo{display:flex;align-items:center;gap:var(--spacing-sm)}.logo-svg{height:36px;width:auto}.logo-text{font-size:26px;font-weight:800;fill:var(--acea-primary);letter-spacing:-.5px}.logo-text-sub{font-size:13px;font-weight:500;fill:var(--acea-secondary);letter-spacing:.5px}.header-nav{display:flex;align-items:center;gap:var(--spacing-md)}.nav-item{display:inline-flex;align-items:center;gap:var(--spacing-xs);font-size:var(--font-size-sm);color:var(--gray-600);font-weight:600;padding:var(--spacing-sm) var(--spacing-md);background:var(--gray-100);border-radius:var(--radius-full);transition:all var(--transition-fast)}.nav-item i{color:var(--acea-secondary)}.app-main{flex:1;padding:var(--spacing-3xl) 0}.form-wizard{max-width:880px;margin:0 auto}.progress-container{margin-bottom:var(--spacing-2xl);padding:0 var(--spacing-md)}.progress-steps{display:flex;justify-content:space-between;margin-bottom:var(--spacing-lg);position:relative}.progress-steps:before{content:"";position:absolute;top:18px;left:40px;right:40px;height:2px;background:var(--gray-200);z-index:0}.progress-step{display:flex;flex-direction:column;align-items:center;flex:1;position:relative;z-index:1}.step-indicator{width:36px;height:36px;border-radius:var(--radius-full);background:#fff;border:2px solid var(--gray-200);color:var(--gray-400);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:var(--font-size-sm);transition:all var(--transition-base);box-shadow:var(--shadow-sm)}.progress-step.active .step-indicator{background:var(--acea-primary);border-color:var(--acea-primary);color:#fff;box-shadow:0 0 0 4px #3b9b9b26,var(--shadow-md);transform:scale(1.1)}.progress-step.completed .step-indicator{background:var(--color-success);border-color:var(--color-success);color:#fff}.progress-step.completed .step-indicator i{font-size:var(--font-size-base)}.step-label{margin-top:var(--spacing-sm);font-size:var(--font-size-xs);color:var(--gray-400);text-align:center;font-weight:600;text-transform:uppercase;letter-spacing:.5px;transition:color var(--transition-fast)}.progress-step.active .step-label{color:var(--acea-primary)}.progress-step.completed .step-label{color:var(--color-success)}.progress-bar{height:6px;background:var(--gray-100);border-radius:var(--radius-full);overflow:hidden;box-shadow:inset 0 1px 2px #0000000f}.progress-fill{height:100%;background:linear-gradient(90deg,var(--acea-primary) 0%,var(--acea-secondary) 100%);border-radius:var(--radius-full);transition:width var(--transition-slow);position:relative}.progress-fill:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.3) 50%,transparent 100%);animation:shimmer 2s infinite}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.form-container{background:#fffffff2;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:var(--radius-2xl);box-shadow:var(--shadow-lg),var(--shadow-glow);padding:var(--spacing-2xl) var(--spacing-2xl) var(--spacing-xl);border:1px solid rgba(255,255,255,.8);position:relative;overflow:hidden}.form-container:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--acea-primary) 0%,var(--acea-secondary) 100%)}.step-content{animation:slideUp .4s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.step-header{text-align:center;margin-bottom:var(--spacing-2xl)}.step-header h2{font-size:var(--font-size-3xl);font-weight:800;color:var(--gray-900);margin-bottom:var(--spacing-sm);letter-spacing:-.5px}.step-header p{color:var(--gray-500);font-size:var(--font-size-lg)}.tipo-options{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-lg)}@media (max-width: 768px){.tipo-options{grid-template-columns:1fr;gap:var(--spacing-md)}}.tipo-card{background:#fff;border:2px solid var(--gray-100);border-radius:var(--radius-xl);padding:var(--spacing-xl) var(--spacing-lg);text-align:center;cursor:pointer;transition:all var(--transition-spring);position:relative;overflow:hidden}.tipo-card:before{content:"";position:absolute;top:0;left:0;right:0;height:0;background:linear-gradient(180deg,rgba(0,51,102,.03) 0%,transparent 100%);transition:height var(--transition-base)}.tipo-card:hover{border-color:var(--acea-accent);transform:translateY(-4px);box-shadow:var(--shadow-lg)}.tipo-card:hover:before{height:100%}.tipo-card.selected{border-color:var(--acea-primary);box-shadow:0 0 0 3px #3b9b9b1a,var(--shadow-md)}.tipo-card.selected:after{content:"";position:absolute;top:12px;right:12px;width:24px;height:24px;background:var(--acea-primary);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;animation:scaleIn .3s ease-out}@keyframes scaleIn{0%{transform:scale(0)}to{transform:scale(1)}}.tipo-card.selected:before{content:"";font-family:bootstrap-icons;position:absolute;top:15px;right:15px;font-size:14px;color:#fff;z-index:1}.tipo-icon{width:72px;height:72px;margin:0 auto var(--spacing-lg);border-radius:var(--radius-xl);display:flex;align-items:center;justify-content:center;font-size:32px;transition:all var(--transition-base);position:relative}.tipo-card:nth-child(1) .tipo-icon{background:linear-gradient(135deg,var(--color-luce-bg) 0%,var(--color-luce-light) 100%);color:#b45309;box-shadow:0 8px 24px #fbbf2440}.tipo-card:nth-child(2) .tipo-icon{background:linear-gradient(135deg,var(--color-gas-bg) 0%,var(--color-gas-light) 100%);color:#1d4ed8;box-shadow:0 8px 24px #3b82f640}.tipo-card.dual .tipo-icon,.tipo-card:nth-child(3) .tipo-icon{background:linear-gradient(135deg,var(--color-dual-start) 0%,var(--color-dual-end) 100%);color:#fff;box-shadow:0 8px 24px #3b82f64d}.tipo-card:hover .tipo-icon{transform:scale(1.05)}.tipo-card h3{font-size:var(--font-size-xl);font-weight:700;color:var(--gray-900);margin-bottom:var(--spacing-xs)}.tipo-card p{font-size:var(--font-size-sm);color:var(--gray-500);margin-bottom:var(--spacing-md);line-height:1.5}.tipo-badge{display:inline-flex;align-items:center;gap:var(--spacing-xs);background:var(--gray-100);color:var(--gray-600);font-size:var(--font-size-xs);font-weight:700;padding:6px 12px;border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.5px}.tipo-promo{display:flex;align-items:center;justify-content:center;gap:var(--spacing-xs);margin-top:var(--spacing-md);font-size:var(--font-size-sm);color:var(--acea-secondary);font-weight:700}.tipo-promo:before{content:"";font-family:bootstrap-icons}.form-section{margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-xl);border-bottom:1px solid var(--gray-100)}.form-section:last-of-type{border-bottom:none;margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-md)}.form-section h3{font-size:var(--font-size-lg);font-weight:700;color:var(--gray-900);margin-bottom:var(--spacing-lg);display:flex;align-items:center;gap:var(--spacing-sm)}.form-section h3 i{color:var(--acea-primary);font-size:var(--font-size-xl)}.section-header{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-sm);border-bottom:2px solid var(--gray-100)}.section-header h3{margin-bottom:0;border-bottom:none;padding-bottom:0}.section-header i{font-size:var(--font-size-2xl)}.fornitura-luce .section-header{border-color:var(--color-luce)}.fornitura-luce .section-header i{color:var(--color-luce)}.fornitura-gas .section-header{border-color:var(--color-gas)}.fornitura-gas .section-header i{color:var(--color-gas)}.form-row{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-md);margin-bottom:var(--spacing-md)}.form-row.single{grid-template-columns:1fr}.form-row .col-3,.form-row .col-4,.form-row .col-6,.form-row .col-8{grid-column:span 1}@media (min-width: 768px){.form-row{grid-template-columns:repeat(12,1fr)}.form-row>*{grid-column:span 6}.form-row .col-3{grid-column:span 3}.form-row .col-4{grid-column:span 4}.form-row .col-6{grid-column:span 6}.form-row .col-8{grid-column:span 8}}.form-group{margin-bottom:var(--spacing-md)}.form-label{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--font-size-sm);font-weight:600;color:var(--gray-700);margin-bottom:6px}.form-label .required{color:var(--color-error)}.input-wrapper{position:relative}.input-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--gray-400);font-size:var(--font-size-lg);transition:color var(--transition-fast);z-index:1}.form-input,.form-select{width:100%;padding:14px 16px;font-size:var(--font-size-base);font-family:inherit;font-weight:500;border:2px solid var(--gray-200);border-radius:var(--radius-lg);background:#fff;transition:all var(--transition-fast);color:var(--gray-800)}.form-input::placeholder{color:var(--gray-400);font-weight:400}.form-input.has-icon{padding-left:46px}.form-input:hover,.form-select:hover{border-color:var(--gray-300)}.form-input:focus,.form-select:focus{outline:none;border-color:var(--acea-primary);box-shadow:0 0 0 4px #3b9b9b14}.form-input:focus+.input-icon,.form-group:focus-within .input-icon{color:var(--acea-primary)}.form-group.verified .form-input{border-color:var(--color-success);background:var(--color-success-light)}.form-group.verified .input-icon{color:var(--color-success)}.has-error .form-input,.has-error .form-select{border-color:var(--color-error);background:var(--color-error-light)}.form-error{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--font-size-sm);color:var(--color-error);margin-top:6px;font-weight:500}.form-error:before{content:"";font-family:bootstrap-icons}.form-help{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--font-size-sm);color:var(--gray-500);margin-top:6px}.form-checkbox{display:flex;align-items:flex-start;gap:var(--spacing-sm);margin-bottom:var(--spacing-md);padding:var(--spacing-md);background:var(--gray-50);border-radius:var(--radius-lg);transition:background var(--transition-fast)}.form-checkbox:hover{background:var(--gray-100)}.checkbox-input{width:22px;height:22px;margin-top:0;accent-color:var(--acea-primary);cursor:pointer;flex-shrink:0}.checkbox-label{font-size:var(--font-size-sm);color:var(--gray-700);cursor:pointer;line-height:1.6}.radio-group{display:flex;flex-wrap:wrap;gap:var(--spacing-md)}.radio-option{display:flex;align-items:flex-start;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);border:2px solid var(--gray-200);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);flex:1;min-width:180px;background:#fff}.radio-option:hover{border-color:var(--acea-accent);background:var(--gray-50)}.radio-option.selected{border-color:var(--acea-primary);background:#3b9b9b0a;box-shadow:0 0 0 3px #3b9b9b14}.radio-input{width:22px;height:22px;margin-top:2px;accent-color:var(--acea-primary);flex-shrink:0}.radio-content{display:flex;flex-direction:column}.radio-label{font-weight:600;color:var(--gray-800);font-size:var(--font-size-base)}.radio-description{font-size:var(--font-size-sm);color:var(--gray-500);margin-top:2px}.info-box{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);background:linear-gradient(135deg,var(--color-info-light) 0%,white 100%);border-radius:var(--radius-lg);font-size:var(--font-size-sm);color:var(--gray-700);border-left:4px solid var(--color-info);margin-top:var(--spacing-md)}.info-box i{color:var(--color-info);font-size:var(--font-size-lg)}.info-box strong{color:var(--gray-900)}.debug-box{background:linear-gradient(135deg,#fef3c7,#fef9e7);border:1px dashed var(--color-warning);border-radius:var(--radius-lg);padding:var(--spacing-md);margin-bottom:var(--spacing-lg);font-family:Courier New,monospace;font-size:var(--font-size-sm)}.debug-header{display:flex;align-items:center;gap:var(--spacing-sm);color:var(--color-warning);font-weight:600;margin-bottom:var(--spacing-sm);font-family:var(--font-family)}.debug-header i{font-size:var(--font-size-lg)}.debug-content{color:var(--gray-700);line-height:1.6}.debug-content div{word-break:break-all}.debug-content strong{color:var(--gray-900)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:14px 28px;font-size:var(--font-size-base);font-weight:700;font-family:inherit;border:none;border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);text-decoration:none;position:relative;overflow:hidden}.btn:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(180deg,rgba(255,255,255,.15) 0%,transparent 100%);opacity:0;transition:opacity var(--transition-fast)}.btn:hover:before{opacity:1}.btn:disabled{opacity:.5;cursor:not-allowed}.btn:disabled:before{display:none}.btn-primary{background:linear-gradient(135deg,var(--acea-primary) 0%,var(--acea-primary-light) 100%);color:#fff;box-shadow:0 4px 14px #3b9b9b40}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #3b9b9b59}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-secondary{background:linear-gradient(135deg,var(--acea-secondary) 0%,var(--acea-secondary-light) 100%);color:#fff;box-shadow:0 4px 14px #3b9b9b40}.btn-secondary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #3b9b9b59}.btn-outline{background:#fff;color:var(--gray-700);border:2px solid var(--gray-200);padding:12px 26px}.btn-outline:hover:not(:disabled){border-color:var(--gray-300);background:var(--gray-50)}.btn-ghost{background:transparent;color:var(--gray-600)}.btn-ghost:hover:not(:disabled){background:var(--gray-100);color:var(--gray-800)}.btn-sm{padding:10px 18px;font-size:var(--font-size-sm)}.btn-lg{padding:18px 36px;font-size:var(--font-size-lg)}.btn.loading{position:relative;color:transparent}.btn-spinner{position:absolute;width:22px;height:22px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.btn-group{display:flex;gap:var(--spacing-md);margin-top:var(--spacing-xl);padding-top:var(--spacing-xl);border-top:1px solid var(--gray-100)}.btn-group.align-between{justify-content:space-between}.btn-group.align-right{justify-content:flex-end}.btn-group.align-center{justify-content:center}.alert{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--radius-lg);margin-bottom:var(--spacing-lg);font-size:var(--font-size-sm);font-weight:500;border-left:4px solid}.alert:before{font-family:bootstrap-icons;font-size:var(--font-size-lg)}.alert-error{background:linear-gradient(135deg,var(--color-error-light) 0%,white 100%);color:#991b1b;border-color:var(--color-error)}.alert-error:before{content:"";color:var(--color-error)}.alert-success{background:linear-gradient(135deg,var(--color-success-light) 0%,white 100%);color:#166534;border-color:var(--color-success)}.alert-success:before{content:"";color:var(--color-success)}.alert-warning{background:linear-gradient(135deg,var(--color-warning-light) 0%,white 100%);color:#92400e;border-color:var(--color-warning)}.alert-warning:before{content:"";color:var(--color-warning)}.alert-info{background:linear-gradient(135deg,var(--color-info-light) 0%,white 100%);color:#1e40af;border-color:var(--color-info)}.alert-info:before{content:"";color:var(--color-info)}.riepilogo-section{margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-lg);border-bottom:1px solid var(--gray-100)}.riepilogo-section h3{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-lg);font-weight:700;color:var(--gray-900);margin-bottom:var(--spacing-md)}.riepilogo-section h3 i{color:var(--acea-primary)}.riepilogo-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-md)}.riepilogo-item{padding:var(--spacing-sm) 0}.riepilogo-item.full{grid-column:span 2}.riepilogo-item .label{display:block;font-size:var(--font-size-xs);color:var(--gray-500);text-transform:uppercase;letter-spacing:.5px;font-weight:600;margin-bottom:4px}.riepilogo-item .value{font-size:var(--font-size-base);color:var(--gray-900);font-weight:600}.consensi-section{background:var(--gray-50);padding:var(--spacing-lg);border-radius:var(--radius-xl);margin-top:var(--spacing-lg);border:1px solid var(--gray-100)}.consensi-section h4{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-md);font-weight:700;color:var(--gray-800)}.consensi-section h4 i{color:var(--acea-secondary)}.step-success{text-align:center;padding:var(--spacing-2xl) var(--spacing-lg)}.success-icon-wrapper{width:100px;height:100px;margin:0 auto var(--spacing-lg);background:linear-gradient(135deg,var(--color-success-light) 0%,white 100%);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;animation:successPop .5s ease-out;box-shadow:var(--shadow-glow-success)}@keyframes successPop{0%{transform:scale(0)}50%{transform:scale(1.1)}to{transform:scale(1)}}.success-icon{font-size:48px;color:var(--color-success)}.step-success h2{color:var(--color-success);margin-bottom:var(--spacing-md);font-size:var(--font-size-2xl)}.step-success .subtitle{color:var(--gray-600);font-size:var(--font-size-lg);margin-bottom:var(--spacing-xl)}.success-info{background:var(--gray-50);padding:var(--spacing-xl);border-radius:var(--radius-xl);margin:var(--spacing-xl) 0;text-align:left;border:1px solid var(--gray-100)}.success-info h4{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-md);font-weight:700}.success-info h4 i{color:var(--acea-secondary)}.success-info ol{padding-left:var(--spacing-xl)}.success-info li{margin-bottom:var(--spacing-sm);color:var(--gray-600);line-height:1.6}.success-info li::marker{color:var(--acea-primary);font-weight:700}.loading-overlay{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-3xl);gap:var(--spacing-md)}.spinner{width:48px;height:48px;border:3px solid var(--gray-200);border-top-color:var(--acea-primary);border-radius:50%;animation:spin .8s linear infinite}.loading-overlay p{color:var(--gray-500);font-weight:500}@media (max-width: 768px){.app-main{padding:var(--spacing-xl) 0}.form-container{padding:var(--spacing-lg);border-radius:var(--radius-xl);margin:0 var(--spacing-sm)}.step-header h2{font-size:var(--font-size-2xl)}.step-header p{font-size:var(--font-size-base)}.form-row{grid-template-columns:1fr}.form-row>*{grid-column:span 1!important}.btn-group{flex-direction:column-reverse;gap:var(--spacing-sm)}.btn-group .btn{width:100%}.progress-container{padding:0}.progress-steps{display:none}.riepilogo-grid{grid-template-columns:1fr}.riepilogo-item.full{grid-column:span 1}.radio-group{flex-direction:column}.radio-option{min-width:auto}}@media (max-width: 480px){.container{padding:0 var(--spacing-md)}.form-container{padding:var(--spacing-md);margin:0;border-radius:var(--radius-lg)}.tipo-card{padding:var(--spacing-lg) var(--spacing-md)}.tipo-icon{width:60px;height:60px;font-size:28px}.btn{padding:12px 20px;font-size:var(--font-size-sm)}}.step-mode-select .step-header{margin-bottom:var(--spacing-2xl)}.mode-options{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-xl)}@media (max-width: 768px){.mode-options{grid-template-columns:1fr;gap:var(--spacing-md)}}.mode-card{background:#fff;border:2px solid var(--gray-100);border-radius:var(--radius-xl);padding:var(--spacing-xl);text-align:center;cursor:pointer;transition:all var(--transition-spring);position:relative;overflow:hidden;display:flex;flex-direction:column;align-items:center}.mode-card:before{content:"";position:absolute;top:0;left:0;right:0;height:0;background:linear-gradient(180deg,rgba(0,51,102,.04) 0%,transparent 100%);transition:height var(--transition-base)}.mode-card:hover{border-color:var(--acea-accent);transform:translateY(-6px);box-shadow:var(--shadow-lg)}.mode-card:hover:before{height:100%}.mode-card.selected{border-color:var(--acea-primary);box-shadow:0 0 0 4px #3b9b9b1f,var(--shadow-lg)}.mode-card.selected:after{content:"";font-family:bootstrap-icons;position:absolute;top:16px;right:16px;width:28px;height:28px;background:var(--acea-primary);border-radius:var(--radius-full);color:#fff;font-size:14px;display:flex;align-items:center;justify-content:center;animation:scaleIn .3s ease-out}.mode-icon{width:90px;height:90px;margin-bottom:var(--spacing-lg);border-radius:var(--radius-2xl);display:flex;align-items:center;justify-content:center;font-size:40px;transition:all var(--transition-base);position:relative}.mode-icon.self{background:linear-gradient(135deg,#fef3c7,#fcd34d);color:#b45309;box-shadow:0 12px 32px #fbbf244d}.mode-icon.compilazione{background:linear-gradient(135deg,#dbeafe,#60a5fa);color:#1d4ed8;box-shadow:0 12px 32px #3b82f64d}.mode-card:hover .mode-icon{transform:scale(1.08)}.mode-content{margin-bottom:var(--spacing-md)}.mode-content h3{font-size:var(--font-size-xl);font-weight:800;color:var(--gray-900);margin-bottom:var(--spacing-xs)}.mode-content p{font-size:var(--font-size-sm);color:var(--gray-500);line-height:1.5;margin:0}.mode-badge{display:inline-flex;align-items:center;gap:var(--spacing-xs);background:linear-gradient(135deg,var(--acea-primary) 0%,var(--acea-primary-light) 100%);color:#fff;font-size:var(--font-size-xs);font-weight:700;padding:8px 16px;border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--spacing-md)}.mode-badge.secondary{background:linear-gradient(135deg,var(--gray-600) 0%,var(--gray-700) 100%)}.mode-features{display:flex;flex-direction:column;gap:var(--spacing-xs);width:100%;text-align:left;padding-top:var(--spacing-md);border-top:1px solid var(--gray-100)}.mode-features span{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-sm);color:var(--gray-600)}.mode-features i{color:var(--acea-secondary);font-size:var(--font-size-base)}.step-upload .step-header{margin-bottom:var(--spacing-xl)}.upload-container{display:flex;flex-direction:column;gap:var(--spacing-lg)}.dropzone{border:2px dashed var(--gray-300);border-radius:var(--radius-xl);padding:var(--spacing-3xl) var(--spacing-xl);text-align:center;cursor:pointer;transition:all var(--transition-base);background:var(--gray-50);position:relative}.dropzone:hover{border-color:var(--acea-accent);background:#3b9b9b0a}.dropzone.dragging{border-color:var(--acea-primary);background:#3b9b9b14;transform:scale(1.01);box-shadow:0 0 0 4px #3b9b9b1a}.dropzone.disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.dropzone.has-error{border-color:var(--color-error);background:var(--color-error-light)}.dropzone-content{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md)}.dropzone-icon{width:80px;height:80px;background:linear-gradient(135deg,var(--acea-primary) 0%,var(--acea-primary-light) 100%);border-radius:var(--radius-2xl);display:flex;align-items:center;justify-content:center;color:#fff;font-size:36px;box-shadow:0 12px 32px #3b9b9b40;transition:transform var(--transition-base)}.dropzone:hover .dropzone-icon{transform:scale(1.05)}.dropzone.dragging .dropzone-icon{transform:scale(1.1);animation:bounce .5s ease infinite}@keyframes bounce{0%,to{transform:translateY(0) scale(1.1)}50%{transform:translateY(-8px) scale(1.1)}}.dropzone-text{display:flex;flex-direction:column;gap:var(--spacing-xs)}.dropzone-title{font-size:var(--font-size-lg);font-weight:700;color:var(--gray-800)}.dropzone-subtitle{font-size:var(--font-size-base);color:var(--gray-500)}.dropzone-link{color:var(--acea-primary);font-weight:600;text-decoration:underline}.dropzone-info{font-size:var(--font-size-sm);color:var(--gray-400)}.dropzone-error{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);margin-top:var(--spacing-md);padding:var(--spacing-md);background:#fff;border-radius:var(--radius-lg);color:var(--color-error);font-size:var(--font-size-sm);font-weight:500}.upload-divider{display:flex;align-items:center;gap:var(--spacing-md)}.upload-divider:before,.upload-divider:after{content:"";flex:1;height:1px;background:var(--gray-200)}.upload-divider span{color:var(--gray-400);font-size:var(--font-size-sm);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.camera-button{display:flex;align-items:center;gap:var(--spacing-lg);padding:var(--spacing-lg) var(--spacing-xl);background:#fff;border:2px solid var(--gray-200);border-radius:var(--radius-xl);cursor:pointer;transition:all var(--transition-fast);width:100%;text-align:left}.camera-button:hover{border-color:var(--acea-accent);background:var(--gray-50);transform:translateY(-2px);box-shadow:var(--shadow-md)}.camera-button-icon{width:56px;height:56px;background:linear-gradient(135deg,var(--gray-100) 0%,var(--gray-200) 100%);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:24px;color:var(--gray-600);flex-shrink:0}.camera-button:hover .camera-button-icon{background:linear-gradient(135deg,var(--acea-primary) 0%,var(--acea-primary-light) 100%);color:#fff}.camera-button-content{flex:1}.camera-button-title{display:block;font-size:var(--font-size-base);font-weight:700;color:var(--gray-800);margin-bottom:2px}.camera-button-description{display:block;font-size:var(--font-size-sm);color:var(--gray-500)}.camera-button>i:last-child{color:var(--gray-400);font-size:var(--font-size-lg)}.upload-result{display:flex;flex-direction:column;gap:var(--spacing-md)}.file-preview{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);background:var(--gray-50);border-radius:var(--radius-lg);border:1px solid var(--gray-200)}.file-preview-icon{width:48px;height:48px;background:linear-gradient(135deg,var(--acea-primary) 0%,var(--acea-primary-light) 100%);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:20px;color:#fff}.file-preview-info{flex:1}.file-name{display:block;font-size:var(--font-size-base);font-weight:600;color:var(--gray-800);word-break:break-all}.file-size{display:block;font-size:var(--font-size-sm);color:var(--gray-500)}.file-remove{width:36px;height:36px;border:none;background:var(--gray-200);border-radius:var(--radius-full);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--gray-600);transition:all var(--transition-fast)}.file-remove:hover{background:var(--color-error);color:#fff}.upload-progress{padding:var(--spacing-md);background:var(--gray-50);border-radius:var(--radius-lg)}.upload-progress-bar{height:8px;background:var(--gray-200);border-radius:var(--radius-full);overflow:hidden;margin-bottom:var(--spacing-sm)}.upload-progress-fill{height:100%;background:linear-gradient(90deg,var(--acea-primary) 0%,var(--acea-secondary) 100%);border-radius:var(--radius-full);transition:width var(--transition-base)}.upload-progress-text{font-size:var(--font-size-sm);color:var(--gray-600);font-weight:500}.upload-success{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-md);background:var(--color-success-light);border-radius:var(--radius-lg);color:var(--color-success);font-weight:600}.upload-success i{font-size:var(--font-size-xl)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-md);animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:#fff;border-radius:var(--radius-2xl);box-shadow:var(--shadow-xl);max-width:700px;width:100%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.verify-modal{max-width:800px}.modal-header{display:flex;align-items:flex-start;gap:var(--spacing-md);padding:var(--spacing-xl);border-bottom:1px solid var(--gray-100);position:relative}.modal-header-icon{width:48px;height:48px;background:linear-gradient(135deg,var(--color-success-light) 0%,white 100%);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:24px;color:var(--color-success);flex-shrink:0}.modal-header h3{font-size:var(--font-size-xl);font-weight:700;color:var(--gray-900);margin-bottom:4px}.modal-header p{font-size:var(--font-size-sm);color:var(--gray-500);margin:0}.modal-close{position:absolute;top:var(--spacing-lg);right:var(--spacing-lg);width:36px;height:36px;border:none;background:var(--gray-100);border-radius:var(--radius-full);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--gray-600);transition:all var(--transition-fast)}.modal-close:hover{background:var(--gray-200);color:var(--gray-800)}.modal-body{flex:1;overflow-y:auto;padding:var(--spacing-xl)}.modal-footer{padding:var(--spacing-lg) var(--spacing-xl);border-top:1px solid var(--gray-100);background:var(--gray-50)}.modal-footer .btn-group{margin:0;padding:0;border:none;justify-content:flex-end}.verify-empty{text-align:center;padding:var(--spacing-2xl);color:var(--gray-500)}.verify-empty i{font-size:48px;color:var(--color-warning);margin-bottom:var(--spacing-md);display:block}.verify-sections{display:flex;flex-direction:column;gap:var(--spacing-xl)}.verify-section{padding-bottom:var(--spacing-lg);border-bottom:1px solid var(--gray-100)}.verify-section:last-child{border-bottom:none;padding-bottom:0}.verify-section h4{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-base);font-weight:700;color:var(--gray-800);margin-bottom:var(--spacing-md)}.verify-section h4 i{color:var(--acea-primary)}.verify-section.luce h4 i{color:var(--color-luce)}.verify-section.gas h4 i{color:var(--color-gas)}.verify-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-md)}@media (max-width: 600px){.verify-grid{grid-template-columns:1fr}}.verify-grid .full-width{grid-column:span 2}@media (max-width: 600px){.verify-grid .full-width{grid-column:span 1}}@media print{.app-header,.btn-group,.progress-container{display:none!important}.form-container{box-shadow:none;padding:0}body{background:#fff}}.invio-section{background:var(--gray-50);padding:var(--spacing-lg);border-radius:var(--radius-xl);margin-top:var(--spacing-lg);border:1px solid var(--gray-100)}.invio-section h3{font-size:var(--font-size-lg);font-weight:700;color:var(--gray-900);margin-bottom:var(--spacing-sm)}.invio-section .section-description{color:var(--gray-500);font-size:var(--font-size-sm);margin-bottom:var(--spacing-lg)}.invio-targets{display:flex;flex-wrap:wrap;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.sidial-options{background:#fff;padding:var(--spacing-lg);border-radius:var(--radius-lg);border:1px solid var(--gray-200);margin-top:var(--spacing-md)}.sidial-options .form-row{margin-bottom:0}.sidial-required-note{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-sm);color:var(--color-info);margin-bottom:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);background:var(--color-info-light);border-radius:var(--radius-md)}.sidial-required-note i{font-size:var(--font-size-base)}.loading-indicator{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-sm);color:var(--gray-500);margin-top:var(--spacing-md)}.loading-indicator .spin{animation:spin .8s linear infinite}.submit-result{display:flex;flex-direction:column;gap:var(--spacing-sm);margin:var(--spacing-lg) 0;padding:var(--spacing-lg);background:var(--gray-50);border-radius:var(--radius-lg)}.submit-result .result-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:#fff;border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:600}.submit-result .result-item.success{color:var(--color-success);border-left:3px solid var(--color-success)}.submit-result .result-item.error{color:var(--color-error);border-left:3px solid var(--color-error)}.submit-result .result-id{margin-left:auto;font-size:var(--font-size-xs);color:var(--gray-500);font-weight:400}.submit-result .result-error{font-size:var(--font-size-xs);color:var(--color-error);font-weight:400}.logo-img{height:44px;width:auto;object-fit:contain;display:block}
