.products{padding-inline:var(--pd-x);padding-block:8rem 6rem;background:#fff;position:relative}.products-container{max-width:1200px;margin:0 auto}.products-header{text-align:center;margin-bottom:4rem}.products-title{font-size:var(--fs-4);font-weight:var(--font-medium);color:#333;margin-bottom:1rem;line-height:1.2}.products-title span{color:var(--color-primary);font-weight:var(--font-bold)}.products-subtitle{font-size:var(--fs-1);color:#555;opacity:.9}.products-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:2rem;gap:2rem;align-items:start}.product-card{background:#fff;border-radius:20px;padding:2rem 1.5rem;box-shadow:0 10px 30px rgba(0,0,0,.08);position:relative;text-align:center;overflow:hidden;min-height:200px;cursor:pointer;border:2px solid transparent;transform:translateZ(0);will-change:transform;backface-visibility:hidden}.product-card:hover{box-shadow:0 20px 40px rgba(0,0,0,.12);border-color:rgba(74,0,224,.2)}.product-image-wrapper{position:relative;margin-bottom:1.5rem;overflow:hidden;border-radius:15px;z-index:2}.product-image{width:100%;height:auto;object-fit:contain;max-height:300px}.product-name{font-size:var(--fs-1);font-weight:var(--font-semibold);color:#333;line-height:1.4;z-index:2;position:relative;margin:0 0 .5rem;height:2.8em;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis}.product-price{font-size:1rem;font-weight:var(--font-medium);color:var(--color-primary);margin:0;z-index:2;position:relative}.interactive-panel{position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(255,255,255,.98);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:2rem 1rem;border-radius:20px;z-index:3;overflow-y:auto;overflow-x:hidden}.interactive-panel:after{content:"";position:absolute;bottom:0;left:0;right:0;height:50px;background:linear-gradient(0deg,rgba(255,255,255,1),transparent);pointer-events:none;opacity:0;transition:opacity .3s ease;z-index:4}.interactive-panel.show-scroll-hint:after{opacity:0}.product-card.active.show-scroll-hint:before{content:"";position:absolute;bottom:0;left:0;right:0;height:70px;background:linear-gradient(0deg,rgb(255,255,255),transparent);pointer-events:none;opacity:1;transition:opacity .3s ease;z-index:10}.panel-header{margin-bottom:1.5rem;text-align:center}.panel-header h4{font-size:var(--fs-1);font-weight:var(--font-semibold);color:#333;margin:0 0 .5rem}.selected-device{font-size:.9rem;color:var(--color-primary);font-weight:var(--font-medium);margin:0}.selected-problems{font-size:.8rem;color:#666;margin:.5rem 0 0}.variants-grid{display:flex;flex-direction:column;gap:.8rem;overflow-y:auto}.variant-button{display:flex;align-items:center;gap:1rem;padding:.8rem 1rem;background:#f8f9fa;border:2px solid transparent;border-radius:12px;cursor:pointer;text-align:left;width:100%}.variant-button:hover{background:#e9ecef;border-color:var(--color-primary)}.variant-preview{flex-shrink:0;width:40px;height:80px;display:flex;align-items:center;justify-content:center;background:#fff;border-radius:8px;padding:.5rem}.variant-image{width:100%;height:auto;object-fit:contain}.variant-info{display:flex;flex-direction:column;gap:.2rem}.variant-name{font-size:.9rem;font-weight:var(--font-medium);color:#333}.variant-description{font-size:.75rem;color:#666;opacity:.8}.problems-grid{display:flex;flex-direction:column;gap:.8rem;margin-bottom:1rem}.problems-grid.mobile-grid{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:.8rem;gap:.8rem}.problem-button{display:flex;align-items:center;gap:1rem;padding:1rem;background:#f8f9fa;border:2px solid transparent;border-radius:12px;cursor:pointer;text-align:left;width:100%;position:relative}.problem-button:hover{background:#e9ecef;border-color:var(--color-primary)}.problem-button.selected{background:rgba(74,0,224,.1);border-color:var(--color-primary);box-shadow:0 2px 8px rgba(74,0,224,.2)}.problem-button.unavailable{filter:grayscale(1);cursor:not-allowed;opacity:.7}.problem-button.has-warning.selected:before{content:"";position:absolute;top:8px;left:8px;width:20px;height:20px;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%234a00e0' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpath d='M10.29 3.86L1.82 18a2 2 0 0 0 1.71 3h16.94a2 2 0 0 0 1.71-3L13.71 3.86a2 2 0 0 0-3.42 0z' /%3e%3cline x1='12' y1='9' x2='12' y2='13' /%3e%3cline x1='12' y1='17' x2='12.01' y2='17' /%3e%3c/svg%3e");background-repeat:no-repeat;background-position:50%;background-size:contain}.aftermarket-warning{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.aftermarket-warning svg{color:var(--color-primary);width:24px;height:24px;flex-shrink:0}.aftermarket-warning p{font-size:.9rem;color:#555;margin:0;width:100%}.aftermarket-warning a{color:var(--color-primary);text-decoration:underline;font-weight:var(--font-semibold)}.footer-actions{display:flex;justify-content:space-between;align-items:center;gap:1rem;width:100%}.footer-actions .continue-button,.footer-actions .total-price{flex:1 1}.footer-actions .total-price{text-align:left}.problem-icon{font-size:1.5rem;flex-shrink:0}.problem-info{display:flex;flex-direction:column;gap:.2rem;flex-grow:1}.problem-name{font-size:.9rem;font-weight:var(--font-medium);color:#333}.problem-price{font-size:.85rem;color:var(--color-primary);font-weight:var(--font-semibold)}.problems-footer{display:flex;flex-direction:column;gap:1rem;margin-top:1rem;padding:1.5rem 0 0;border-top:1px solid #e9ecef}.problems-footer>*{flex:1 1}.problems-footer.mobile-footer{display:grid;grid-template-rows:1fr 1fr;grid-gap:0;gap:0;align-items:center;padding:1rem 0 0}.total-price{text-align:center;padding:1rem;background:rgba(74,0,224,.1);border-radius:12px;color:var(--color-primary);font-size:1.1rem;flex:1 1;white-space:nowrap}.continue-button{padding:1rem 1.5rem;background:var(--color-primary);color:white;border:none;border-radius:12px;font-size:1rem;font-weight:var(--font-semibold);cursor:pointer}.continue-button.disabled,.continue-button:disabled{background:#d1d5db;color:#9ca3af;cursor:not-allowed}.actions-grid{display:flex;flex-direction:column;gap:1rem}.action-button{display:flex;align-items:center;gap:1rem;padding:1.2rem;background:#f8f9fa;border:2px solid transparent;border-radius:12px;cursor:pointer;text-align:left;width:100%}.action-button.appointment{background:linear-gradient(135deg,rgba(74,0,224,.1),rgba(45,157,226,.1));border-color:var(--color-primary)}.action-button.online{background:linear-gradient(135deg,rgba(40,167,69,.1),rgba(32,201,151,.1));border-color:#28a745}.action-icon{font-size:1.8rem;flex-shrink:0}.action-info{display:flex;flex-direction:column;gap:.3rem}.action-name{font-size:1rem;font-weight:var(--font-semibold);color:#333}.action-description{font-size:.8rem;color:#666;opacity:.9}.bottom-sheet-backdrop{top:0;background:rgba(0,0,0,.5);z-index:998}.bottom-sheet,.bottom-sheet-backdrop{position:fixed;left:0;right:0;bottom:0}.bottom-sheet{background:white;border-radius:20px 20px 0 0;z-index:999;height:85vh;min-height:500px;max-height:85vh;overflow:hidden;box-shadow:0 -10px 40px rgba(0,0,0,.2);display:flex;flex-direction:column}.bottom-sheet-handle{width:40px;height:4px;background:#d1d5db;border-radius:2px;margin:12px auto 8px;flex-shrink:0;cursor:grab}.bottom-sheet-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;border-bottom:1px solid #e5e7eb;background:white;position:sticky;top:0;z-index:1}.bottom-sheet-header h3{font-weight:var(--font-semibold);color:#333;margin:0}.bottom-sheet-close{background:#f3f4f6;border:none;border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.2rem;color:#6b7280;aspect-ratio:1}.lg-icon.lg-zoom-in:after{content:""!important;white-space:nowrap;font-size:12px}.lg-icon.lg-zoom-out:after{content:"x"!important}.bottom-sheet-content{padding:1.5rem;overflow-y:auto;flex:1 1;display:flex;flex-direction:column}.bottom-sheet .problems-panel{display:flex;flex-direction:column;height:100%}.bottom-sheet .problems-grid{flex:1 1}.bottom-sheet .problems-footer{margin-top:auto;flex-shrink:0}@media (max-width:768px){.product-card.active .product-image-wrapper,.product-card.active .product-name{transform:none!important;opacity:1!important}.product-card.active.variant-selected .product-image-wrapper{transform:none!important}.bottom-sheet .problem-button,.bottom-sheet .variant-button{padding:1.2rem 1rem;gap:1rem;min-height:70px}.bottom-sheet .problems-grid.mobile-grid .problem-button{flex-direction:column;text-align:center;gap:.5rem;padding:1rem .5rem;min-height:90px}.bottom-sheet .problems-grid.mobile-grid .problem-icon{font-size:1.5rem;margin-bottom:.3rem}.bottom-sheet .problems-grid.mobile-grid .problem-info{align-items:center;gap:.3rem}.bottom-sheet .problems-grid.mobile-grid .problem-name{font-size:.85rem;line-height:1.2}.bottom-sheet .problems-grid.mobile-grid .problem-price{font-size:.9rem;font-weight:var(--font-bold)}.bottom-sheet .action-button{padding:1.5rem 1.2rem;min-height:80px}.bottom-sheet .continue-button{padding:1.2rem 1.5rem;font-size:1.1rem;min-height:56px}.bottom-sheet .problems-footer.mobile-footer .continue-button,.bottom-sheet .problems-footer.mobile-footer .total-price{padding:1rem;min-height:56px;display:flex;align-items:center;justify-content:center;font-size:1rem}}@media (max-width:1024px) and (min-width:769px){.products-grid{grid-template-columns:repeat(2,1fr);gap:2rem}.product-card{min-height:280px}.interactive-panel,.product-card{padding:1.8rem 1.3rem}}@media (max-width:768px){.products{padding-block:6rem 4rem}.products-header{margin-bottom:3rem}.products-subtitle{font-size:.9rem}.products-grid{grid-template-columns:repeat(2,1fr);gap:1.5rem}.product-card{padding:1.5rem 1rem;border-radius:15px;min-height:250px}.product-name{font-size:.9rem}}@media (max-width:480px){.products-grid{gap:1rem}.product-card{padding:1.2rem .8rem;min-height:220px}.product-image-wrapper{margin-bottom:1rem}.product-name{font-size:.8rem}}.appointment-panel{display:flex;flex-direction:column;height:100%}.appointment-form{gap:1rem;overflow-y:auto;padding-right:.5rem;flex-grow:1}.appointment-form,.form-group{display:flex;flex-direction:column}.form-group{gap:.5rem}.form-group label{font-size:.85rem;font-weight:var(--font-medium);color:#555;text-align:left}.form-group input{width:100%;padding:.8rem 1rem;border:1px solid #d1d5db;border-radius:8px;font-size:.9rem;background-color:#f9fafb}.form-group input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px rgba(74,0,224,.2)}.date-picker-input,.form-group input{height:44px;box-sizing:border-box}.form-row{display:flex;gap:1rem}.form-row .form-group{flex:1 1}.form-actions{display:flex;gap:1rem;margin-top:1rem;flex-direction:row;align-items:center}.form-actions .submit-button{flex-grow:1;white-space:nowrap}@media (min-width:769px){.form-actions{flex-direction:column;align-items:stretch}}.back-button,.submit-button{flex:1 1;padding:1rem;border-radius:12px;font-size:1rem;font-weight:var(--font-semibold);cursor:pointer;border:none}.back-button{background:#e9ecef;color:#333;border:1px solid #d1d5db}.submit-button{background:var(--color-primary);color:white}.submit-button:hover{transform:translateY(-2px);box-shadow:0 6px 15px rgba(0,123,255,.25)}.consent-required-panel{padding:2rem;text-align:center}.consent-required-content{display:flex;flex-direction:column;align-items:center;gap:1.5rem}.consent-required-content p{font-size:1rem;color:#555;max-width:45ch;line-height:1.6}.consent-required-panel .submit-button{width:100%;max-width:300px}.date-picker-wrapper{width:100%}.date-picker-input{width:100%;border:1px solid #d1d5db;background-color:#f9fafb;cursor:pointer;text-align:left}.date-picker-container{position:relative;width:100%}.date-picker-popover{position:absolute;top:calc(100% + 8px);left:0;right:0;background:white;border-radius:12px;box-shadow:0 10px 30px rgba(0,0,0,.15);z-index:1000;display:flex;padding:1rem;gap:1rem;border:1px solid #e5e7eb}.time-picker-grid{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:.5rem;gap:.5rem;overflow-y:auto;max-height:280px;border-left:1px solid #e5e7eb;padding-left:1rem}.time-slot-button{padding:.5rem 1rem;border-radius:8px;border:1px solid #d1d5db;background-color:#f9fafb;cursor:pointer;font-size:.9rem;transition:all .2s ease}.time-slot-button:hover{background-color:#e9ecef;border-color:var(--color-primary)}.time-slot-button.selected{background-color:var(--color-primary);color:white;border-color:var(--color-primary);font-weight:var(--font-semibold)}.rdp{--rdp-cell-size:40px;--rdp-accent-color:var(--color-primary);--rdp-background-color:#e9ecef;margin:0}.rdp-day_selected,.rdp-day_selected:focus-visible,.rdp-day_selected:hover{background-color:var(--color-primary);color:white}@media (max-width:768px){.date-picker-popover{flex-direction:column}.time-picker-grid{grid-template-columns:repeat(4,1fr);border-left:none;padding-left:0;max-height:150px}}.react-datepicker-popper{z-index:1000}.react-datepicker{font-family:var(--font-primary);border:1px solid #ddd;border-radius:12px;box-shadow:0 10px 30px rgba(0,0,0,.1)}.react-datepicker__header{background-color:var(--color-primary);color:white;border-bottom:none;border-radius:12px 12px 0 0;padding:15px}.react-datepicker-time__header,.react-datepicker__current-month,.react-datepicker__day-name{color:white;font-weight:var(--font-medium)}.react-datepicker__day--in-range,.react-datepicker__day--in-selecting-range,.react-datepicker__day--selected,.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--selected{background-color:var(--color-primary)!important;color:white!important;font-weight:var(--font-semibold)}.react-datepicker__day:hover,.react-datepicker__time-list-item:hover{background-color:#f0f0f0;border-radius:50%}.react-datepicker__day--keyboard-selected{background-color:#e9ecef}.react-datepicker__navigation-icon:before{border-color:white}.react-datepicker__time-container{border-left:1px solid #eee}.online-instructions-panel{display:flex;flex-direction:column;gap:1.5rem;padding:1rem}.instructions-grid{display:flex;flex-direction:column;gap:1rem}.instruction-step{display:flex;flex-direction:column;align-items:flex-start;gap:.5rem;background-color:rgba(0,0,0,.02);padding:1rem;border-radius:8px;border:1px solid rgba(0,0,0,.05)}.instruction-icon{flex-shrink:0;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:50%;background-color:rgba(0,122,255,.1);color:var(--color-primary);font-weight:600;font-size:.9rem}.instruction-text h5{font-size:.95rem;font-weight:600;margin:0 0 .1rem;color:#333}.instruction-text p{font-size:.85rem;margin:0;color:#555;line-height:1.4}@media (max-width:768px){.instructions-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:.75rem;gap:.75rem}.instruction-step{flex-direction:column;align-items:center;text-align:center;gap:.75rem;padding:1.25rem .75rem}.instruction-text h5{font-size:.9rem}.instruction-text p{font-size:.8rem}}.extra-info-link{text-align:center;margin-top:1.5rem}.extra-info-link a{font-size:.9rem;color:var(--color-primary);text-decoration:underline;transition:opacity .2s}.extra-info-link a:hover{opacity:.8}.details-panel{padding:1rem;display:flex;flex-direction:column;text-align:left}.details-header{margin-bottom:1rem;text-align:center}.main-image-wrapper{margin-bottom:1rem;border-radius:12px;overflow:hidden;line-height:0;position:relative;cursor:zoom-in}.main-image-clickable{width:100%;height:auto;aspect-ratio:1/1;object-fit:cover}.thumbnail-strip{display:grid;grid-template-columns:repeat(5,1fr);grid-gap:.5rem;gap:.5rem}.thumbnail-item{border:2px solid transparent;border-radius:8px;overflow:hidden;cursor:pointer;line-height:0}.thumbnail-item:hover{border-color:#ccc}.thumbnail-item.active{border-color:var(--color-primary)}.thumbnail-item img{width:100%;height:auto;aspect-ratio:1/1;object-fit:cover}.lg-icon.lg-zoom-in,.lg-icon.lg-zoom-out{background:none!important;font-size:0!important;width:44px;height:44px}.lg-icon.lg-zoom-in:before,.lg-icon.lg-zoom-out:before{content:""!important;display:block;width:100%;height:100%;background-repeat:no-repeat;background-position:50%;background-size:24px;opacity:.8;transition:opacity .2s}.lg-icon.lg-zoom-in:hover:before,.lg-icon.lg-zoom-out:hover:before{opacity:1}.lg-icon.lg-zoom-in:before{background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3ccircle cx='11' cy='11' r='8'%3e%3c/circle%3e%3cline x1='21' y1='21' x2='16.65' y2='16.65'%3e%3c/line%3e%3cline x1='11' y1='8' x2='11' y2='14'%3e%3c/line%3e%3cline x1='8' y1='11' x2='14' y2='11'%3e%3c/line%3e%3c/svg%3e")}.lg-icon.lg-zoom-out:before{background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3ccircle cx='11' cy='11' r='8'%3e%3c/circle%3e%3cline x1='21' y1='21' x2='16.65' y2='16.65'%3e%3c/line%3e%3cline x1='8' y1='11' x2='14' y2='11'%3e%3c/line%3e%3c/svg%3e")}.lightgallery-custom-container{display:none}.lg-close.lg-icon{background:none!important;border:none!important;box-shadow:none!important;opacity:1!important;font-size:0!important;width:44px;height:44px;position:relative}.lg-close.lg-icon:before{content:""!important;display:none!important}.lg-close.lg-icon:after{content:"×"!important;font-family:Arial,sans-serif!important;font-size:32px!important;color:#fff!important;font-weight:400;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);opacity:.8;transition:opacity .2s}.lg-close.lg-icon:hover:after{opacity:1}.details-image-gallery{display:none}.product-gallery-container{margin-bottom:1.5rem}.lightgallery-custom-container{display:flex;flex-direction:column;gap:.5rem}.lightgallery-custom-container .gallery-item{display:none}.lightgallery-custom-container .gallery-item:first-child{display:block;cursor:zoom-in;border-radius:12px;overflow:hidden;line-height:0}.lightgallery-custom-container .gallery-item:first-child .gallery-thumbnail{width:100%;height:auto;aspect-ratio:1/1;object-fit:cover}.lg-thumb{gap:10px}.lg-thumb-item{border-radius:6px!important;border:2px solid transparent!important}.lg-thumb-item.active{border-color:var(--color-primary)!important}.details-image-gallery img{width:100%;height:auto;border-radius:8px;background:#f0f0f0;object-fit:cover;aspect-ratio:1/1}.details-header h3{font-size:1.2rem;font-weight:var(--font-semibold);margin:0}.details-description{font-size:.9rem;color:#444;line-height:1.6;flex-grow:1;overflow-y:auto}.details-description p{margin-bottom:1rem}.details-description ol,.details-description ul{padding-left:1.5rem;margin-bottom:1rem}.loader{text-align:center;padding:2rem;font-size:1rem;color:var(--color-primary)}.hero-cta{margin-bottom:5rem}.hero-img{width:100%;height:auto;object-fit:cover;border-radius:15px;margin-bottom:1.5rem}