:root{--color-primary: #6B59A1;--color-secondary: #E53D3E;--color-success: #37A069;--color-info: #60B0E2;--color-warning: #EC739D;--color-danger: #FF6B35;--color-white: #ffffff;--color-black: #000000;--color-gray-50: #f9fafb;--color-gray-100: #f3f4f6;--color-gray-200: #e5e7eb;--color-gray-300: #d1d5db;--color-gray-400: #9ca3af;--color-gray-500: #6b7280;--color-gray-600: #4b5563;--color-gray-700: #374151;--color-gray-800: #1f2937;--color-gray-900: #111827;font-family:Poppins,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.5;font-weight:400}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{margin:0;min-width:320px;min-height:100vh;color:var(--color-gray-900);background-color:var(--color-white)}#root{min-height:100vh}h1,h2,h3,h4,h5,h6{margin:0;font-weight:600;line-height:1.2}a{color:var(--color-primary);text-decoration:none;transition:color .2s ease}a:hover{color:var(--color-secondary)}button{font-family:inherit;cursor:pointer;border:none;background:none;transition:all .2s ease}button:disabled{cursor:not-allowed;opacity:.5}img{max-width:100%;height:auto;display:block}ul,ol{list-style:none}input,textarea,select{font-family:inherit;font-size:inherit;line-height:inherit}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:var(--color-gray-100)}::-webkit-scrollbar-thumb{background:var(--color-gray-400);border-radius:5px}::-webkit-scrollbar-thumb:hover{background:var(--color-gray-500)}.app-header{position:fixed;top:0;left:0;right:0;background:#f9fafb;box-shadow:0 2px 10px #0000001a;z-index:1000;height:70px}.header-content{display:flex;justify-content:space-between;align-items:center;padding:0 1rem;height:100%}.header-left,.header-right{display:flex;gap:.5rem;flex:1}.header-left{align-items:flex-start;padding-top:.5rem}.header-right{justify-content:flex-end;align-items:flex-end;padding-bottom:.5rem}.header-center{display:flex;justify-content:center;align-items:flex-start;flex:0 0 auto;padding-top:.5rem}.header-logo{height:50px;width:auto;transition:transform .2s ease}.header-logo:hover{transform:scale(1.05)}.header-btn{position:relative;display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:transparent;border:none;border-radius:4px;cursor:pointer;transition:all .2s ease;color:#3e1e6b}.header-btn:hover:not(.disabled){background:#f3f4f6;color:#3e1e6b}.header-btn:hover:not(.disabled):after{content:attr(data-tooltip);position:absolute;bottom:-35px;left:50%;transform:translate(-50%);background:#3e1e6b;color:#fff;padding:6px 12px;border-radius:4px;font-size:12px;font-weight:600;white-space:nowrap;z-index:1000;pointer-events:none}.header-btn:hover:not(.disabled):before{content:"";position:absolute;bottom:-8px;left:50%;transform:translate(-50%);border-width:0 6px 8px 6px;border-style:solid;border-color:transparent transparent #3E1E6B transparent;z-index:1001;pointer-events:none}.header-btn:active:not(.disabled){transform:scale(.95)}.header-btn.active{background:transparent;color:#3e1e6b;position:relative;cursor:default}.header-btn.active:after{content:"";position:absolute;bottom:-2px;left:0;right:0;height:3px;background:#3e1e6b;border-radius:2px 2px 0 0}.header-btn.disabled{cursor:default;opacity:1;background:transparent}.header-btn i{font-size:18px}.cart-badge{position:absolute;top:-6px;right:-6px;background:#e53d3e;color:#fff;font-size:11px;font-weight:600;min-width:20px;height:20px;border-radius:10px;display:flex;align-items:center;justify-content:center;padding:0 5px;box-shadow:0 2px 4px #0003}.view-toggle{display:flex;gap:.5rem}@media (max-width: 768px){.header-content{padding:0 1rem}.hide-on-mobile,.view-toggle{display:none!important}.header-left{flex:0 0 auto}.header-center{flex:1;justify-content:flex-start}.header-right{flex:0 0 auto}.header-logo{height:40px}.header-btn{width:40px;height:40px}.header-btn i{font-size:16px}}@media (max-width: 480px){.header-content{padding:0 .5rem}.header-logo{height:35px}.header-btn{width:36px;height:36px;gap:.25rem}}.app-footer{background:#6b59a1;color:#fff;padding:2rem 0;margin-top:auto}.footer-content{max-width:1920px;margin:0 auto;padding:0 2rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.footer-left p{margin:0;font-size:.875rem}.footer-right{display:flex;gap:2rem;flex-wrap:wrap}.footer-link{color:#fff;text-decoration:none;font-size:.875rem;transition:opacity .2s ease}.footer-link:hover{opacity:.8;text-decoration:underline}@media (max-width: 768px){.footer-content{flex-direction:column;text-align:center;padding:0 1rem}.footer-right{gap:1rem;justify-content:center}}.product-card{position:relative;display:flex;flex-direction:column;background:#fff;border:1px solid;border-radius:12px;overflow:hidden;cursor:pointer;transition:all .3s ease;height:100%;width:100%}.product-card:hover{box-shadow:0 15px 35px #00000040;transform:translateY(-8px) scale(1.02)}.product-badge-container{position:absolute;top:0;right:0;z-index:5;display:flex;flex-direction:column;gap:.05rem}.product-badge.ribbon{padding:.5rem 1.1rem;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#fff;border-radius:12px;border:2px solid white;transition:all .2s ease}.product-badge.ribbon:hover{transform:scale(1.05)}.product-badge.ecologique{background:#10b981}.product-badge.top-quality{background:#f59e0b}.product-badge.nouveaute{background:#ff6b35;animation:badge-pulse 2s ease-in-out infinite}@keyframes badge-pulse{0%,to{opacity:1}50%{opacity:.85}}.product-badge.promo{background:#ef4444}.product-variants-badge{position:absolute;bottom:.5rem;left:.5rem;display:flex;align-items:center;gap:.35rem;background:#6b59a1;color:#fff;padding:.35rem .65rem;border-radius:50px;font-size:.75rem;font-weight:600;box-shadow:0 2px 8px #0003;z-index:3}.product-variants-badge i{font-size:.7rem}.product-variants-badge:hover:after{content:attr(data-tooltip);position:absolute;bottom:50%;left:calc(100% + 10px);transform:translateY(50%);background:var(--tooltip-color, #3E1E6B);color:#fff;padding:6px 12px;border-radius:4px;font-size:12px;font-weight:600;white-space:nowrap;z-index:1000;pointer-events:none}.product-variants-badge:hover:before{content:"";position:absolute;bottom:50%;left:calc(100% + 2px);transform:translateY(50%);border-width:6px 8px 6px 0;border-style:solid;border-color:transparent var(--tooltip-color, #3E1E6B) transparent transparent;z-index:1001;pointer-events:none}.product-group-badge{position:absolute;bottom:.5rem;left:.5rem;display:flex;align-items:center;gap:.35rem;background:#6b59a1;color:#fff;padding:.35rem .65rem;border-radius:50px;font-size:.75rem;font-weight:600;box-shadow:0 2px 8px #0003;z-index:3}.product-group-badge:hover:after{content:attr(data-tooltip);position:absolute;bottom:50%;left:calc(100% + 10px);transform:translateY(50%);background:var(--tooltip-color, #3E1E6B);color:#fff;padding:6px 12px;border-radius:4px;font-size:12px;font-weight:600;white-space:nowrap;z-index:1000;pointer-events:none}.product-group-badge:hover:before{content:"";position:absolute;bottom:50%;left:calc(100% + 2px);transform:translateY(50%);border-width:6px 8px 6px 0;border-style:solid;border-color:transparent var(--tooltip-color, #3E1E6B) transparent transparent;z-index:1001;pointer-events:none}.product-images-badge{position:absolute;bottom:.5rem;right:.5rem;display:flex;align-items:center;gap:.35rem;background:#6b59a1;color:#fff;padding:.35rem .65rem;border-radius:50px;font-size:.75rem;font-weight:600;box-shadow:0 2px 8px #0003;z-index:3}.product-images-badge i{font-size:.7rem}.product-images-badge:hover:after{content:attr(data-tooltip);position:absolute;bottom:50%;right:calc(100% + 10px);transform:translateY(50%);background:var(--tooltip-color, #3E1E6B);color:#fff;padding:6px 12px;border-radius:4px;font-size:12px;font-weight:600;white-space:nowrap;z-index:1000;pointer-events:none}.product-images-badge:hover:before{content:"";position:absolute;bottom:50%;right:calc(100% + 2px);transform:translateY(50%);border-width:6px 0 6px 8px;border-style:solid;border-color:transparent transparent transparent var(--tooltip-color, #3E1E6B);z-index:1001;pointer-events:none}.product-image-container{flex:1 1 auto;display:flex;align-items:center;justify-content:center;padding:.5rem;background:#fff;overflow:hidden;order:1;position:relative;min-height:0}.product-info{flex:0 0 auto;padding:.5rem .75rem;border-top:none;display:flex;flex-direction:column;justify-content:flex-start;order:2;min-height:fit-content}.product-image{width:100%;height:100%;object-fit:contain;transition:transform .3s ease}.product-card:hover .product-image{transform:scale(1.05)}.product-subsubcategory{font-size:.7rem;font-weight:600;text-transform:uppercase;color:#6b7280;margin:0 0 .15rem;letter-spacing:.3px}.product-name{font-size:.95rem;font-weight:700;color:#111827;margin:0 0 .15rem;line-height:1.2}.product-ref{font-size:.75rem;color:#6b7280;margin:0 0 .15rem}.product-description{font-size:.75rem;color:#4b5563;line-height:1.25;margin:0;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis}@media (max-width: 768px){.product-card{min-height:240px}.product-image{max-height:120px}.product-info{padding:.75rem}.product-name{font-size:.85rem}.product-ref,.product-description{font-size:.7rem}}@media (max-width: 480px){.product-card{min-height:220px}.product-image-container{padding:.75rem}.product-image{max-height:100px}.product-info{padding:.5rem}.product-subsubcategory{font-size:.65rem}.product-name{font-size:.8rem;-webkit-line-clamp:1}.product-ref{font-size:.65rem;margin-bottom:.25rem}.product-description{font-size:.65rem}.product-variants-badge{bottom:.35rem;left:.35rem;padding:.25rem .5rem;font-size:.65rem;gap:.25rem}.product-group-badge{bottom:.35rem;left:3.5rem;padding:.25rem .5rem;font-size:.65rem;gap:.25rem}.product-images-badge{bottom:.35rem;right:.35rem;padding:.25rem .5rem;font-size:.65rem;gap:.25rem}.product-images-badge i{font-size:.6rem}}.catalogue-page{width:100%;height:100%;background:#fff;position:relative}.introduction-page{display:flex;align-items:center;justify-content:center}.page-image{width:100%;height:100%;object-fit:contain;padding:1rem}.toc-page{display:flex;flex-direction:column;position:relative;overflow:hidden}.toc-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:transparent;display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-start;padding:clamp(1.5rem,3vh,3rem) clamp(2rem,4vw,4rem) clamp(1.5rem,3vh,3rem) clamp(2.5rem,4vw,4.5rem);overflow-y:auto}.toc-container{max-width:800px;margin:0 auto;margin-top:12vh;width:100%}.toc-title{font-size:clamp(1.5rem,4vh,3rem);font-weight:700;color:#3e1e6b;text-align:left;margin-bottom:clamp(.75rem,2vh,2.5rem)}.toc-content{display:flex;flex-direction:column;gap:clamp(.25rem,.5vh,.5rem)}.toc-category{display:flex;flex-direction:column}.toc-category-link{display:flex;align-items:center;gap:.5rem;padding:clamp(.35rem,1vh,1rem) clamp(.75rem,1.5vh,1.5rem);background:transparent;border:none;cursor:pointer;transition:all .2s ease;text-align:left;width:100%;border-radius:8px}.toc-category-link:hover{background:#3e1e6b0d}.toc-category-title{font-size:clamp(.8rem,1.6vh,1.125rem);font-weight:600;flex:1;word-wrap:break-word;overflow-wrap:break-word;line-height:1.2}.toc-chevron{font-size:1rem;color:#6b7280;margin-left:auto}.toc-dots{flex:1;height:1px;background-image:linear-gradient(to right,#d1d5db 40%,transparent 0%);background-position:bottom;background-size:8px 1px;background-repeat:repeat-x;margin:0 1rem}.toc-page-number{font-size:clamp(.75rem,1.5vh,1rem);font-weight:600;white-space:nowrap;min-width:40px;text-align:right;color:#6b7280}.toc-subcategories{display:flex;flex-direction:column;background:#f9fafb80;border-radius:0 0 8px 8px;padding:clamp(.25rem,.5vh,.5rem) 0}.toc-subcategory-link{display:flex;align-items:center;gap:.5rem;padding:clamp(.35rem,.8vh,.75rem) clamp(1.5rem,2vh,2.5rem);background:transparent;border:none;cursor:pointer;transition:all .2s ease;text-align:left;width:100%}.toc-subcategory-link:hover{background:#3e1e6b0d}.toc-subcategory-title{font-size:clamp(.75rem,1.4vh,1rem);font-weight:500;color:#4b5563;flex:1;line-height:1.2}.category-intro-page{display:flex;align-items:flex-start;justify-content:flex-start;position:relative;overflow:hidden}.category-intro-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:transparent;display:flex;flex-direction:column;justify-content:space-between;padding:17% 4rem 16rem clamp(2.5rem,4vw,4.5rem);margin:0;border-radius:0}.page-content[data-category-slug=fournitures-scolaires] .category-intro-overlay{padding:38% 4rem 5rem clamp(2.5rem,4vw,4.5rem)}.page-content[data-category-slug=equipement-et-mobilier-scolaire] .category-intro-overlay{padding-top:40%}.page-content[data-category-slug=equipement-et-mobilier-scolaire] .category-intro-flat-list{grid-template-columns:1fr}.page-content[data-category-slug=bricolage-et-loisirs-creatifs] .category-intro-overlay{padding:17% 4rem 17rem clamp(2.5rem,4vw,4.5rem)}.page-content[data-category-slug=jeux-educatifs] .category-intro-overlay{padding:17% 4rem 45% clamp(2.5rem,5vw,5rem)}.page-content[data-category-slug=jeux-educatifs] .category-intro-flat-list{grid-template-columns:1fr;gap:clamp(.2rem,.5vh,.4rem) clamp(1rem,2vw,2rem)}.page-content[data-category-slug=psychomotricite-et-sport] .category-intro-overlay{padding:17% 4rem 50% clamp(2.5rem,5vw,5rem)}.page-content[data-category-slug=psychomotricite-et-sport] .category-intro-flat-list{grid-template-columns:1fr}.category-intro-title{font-size:clamp(1rem,3vh,2rem);font-weight:700;text-align:center;margin:0 0 clamp(1rem,2vh,1.5rem) 0;padding:clamp(.75rem,1.5vh,1rem) clamp(.75rem,2vw,1.5rem);text-transform:uppercase;line-height:1.15;background:#fff;border-radius:20px;display:inline-block;width:fit-content;align-self:center}.category-back-to-summary-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:clamp(.5rem,1vh,.75rem) clamp(1rem,2vw,1.5rem);font-size:clamp(.8rem,1.5vh,1rem);font-weight:600;color:#fff;border:none;border-radius:12px;cursor:pointer;transition:all .2s ease;position:absolute;top:clamp(1rem,2vh,1.5rem);left:clamp(1rem,2vw,2rem);text-transform:uppercase;letter-spacing:.5px;box-shadow:0 2px 8px #00000026;z-index:10}.category-back-to-summary-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0003}.category-back-to-summary-btn:active{transform:translateY(0)}.category-back-to-summary-btn i{font-size:clamp(.75rem,1.3vh,.9rem)}.category-intro-list-container{background:#fff;border-radius:0;padding:0;margin:0;flex:0 1 auto;display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden;align-self:stretch;width:100%;scrollbar-width:none;-ms-overflow-style:none}.category-intro-list-container::-webkit-scrollbar{display:none}.category-intro-flat-list{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:1fr;gap:clamp(.15rem,.4vh,.3rem) clamp(1rem,2vw,2rem);column-gap:clamp(1.5rem,3vw,3rem)}.category-intro-flat-item{font-size:clamp(.75rem,1.4vh,.95rem);font-weight:700;color:#3e1e6b;text-transform:uppercase;padding:0;line-height:1.2;display:grid;grid-template-columns:1fr auto auto;align-items:center;gap:clamp(.3rem,.5vw,.5rem);transition:opacity .2s ease;max-width:100%}.category-intro-flat-item.clickable{cursor:pointer}.category-intro-flat-item.clickable:hover{opacity:.7}.subcat-name{min-width:0;word-wrap:break-word;overflow-wrap:break-word}.subcat-dots{height:1px;background-image:linear-gradient(to right,currentColor 40%,transparent 0%);background-position:bottom;background-size:6px 1px;background-repeat:repeat-x;opacity:.5;width:clamp(30px,5vw,50px)}.subcat-page{font-weight:600;text-align:right;width:clamp(25px,4vw,35px)}.category-intro-flat-item.level-3{padding-left:clamp(.75rem,1.2vw,1.2rem);font-size:clamp(.7rem,1.3vh,.9rem);text-transform:capitalize;font-weight:600}.category-intro-flat-item.level-3 .subcat-name{text-transform:capitalize}@media (max-width: 768px){.toc-overlay{padding:2rem 1.5rem 2rem 3rem}.toc-container{margin-top:12vh}.toc-title{font-size:2rem;margin-bottom:2rem}.toc-category-title{font-size:1.25rem}.toc-subcategory-title{font-size:1rem;padding-left:1rem}.toc-page-number{font-size:1rem}.category-intro-overlay{padding:2rem 1.5rem}.category-intro-title{font-size:2.5rem;margin-bottom:2rem}.category-intro-content{grid-template-columns:1fr;gap:1.5rem}}@media (max-width: 480px){.toc-overlay{padding:1.5rem 1rem 1.5rem 2rem}.toc-container{margin-top:12vh}.toc-title{font-size:1.5rem;margin-bottom:1.5rem}.toc-category-link,.toc-subcategory-link{padding:.5rem .75rem}.category-intro-overlay{padding:1.5rem 1rem}.category-intro-title{font-size:2rem;margin-bottom:1.5rem}.category-intro-subtitle{font-size:1.125rem}}.zoomable-page{width:100%;height:100%;position:relative;display:flex;flex-direction:column;background:#fff;overflow:hidden}.image-container{flex:1;position:relative;display:flex;align-items:center;justify-content:center;cursor:crosshair;overflow:hidden}.zoomable-image{width:100%;height:100%;object-fit:contain;-webkit-user-select:none;user-select:none;pointer-events:none}.magnifier{position:absolute;pointer-events:none;border:3px solid #3E1E6B;border-radius:50%;box-shadow:0 8px 24px #0000004d;transform:translate(-50%,-50%);z-index:1000;overflow:hidden;background:#fff}.magnifier-image{width:100%;height:100%;background-repeat:no-repeat;border-radius:50%}.zoom-info{position:absolute;top:1.5rem;right:1.5rem;width:36px;height:36px;border-radius:50%;background:#fff;color:#3e1e6b;display:flex;align-items:center;justify-content:center;cursor:help;transition:all .2s ease;box-shadow:0 2px 8px #00000026;z-index:10}.zoom-info:hover{background:#3e1e6b;color:#fff;transform:scale(1.1);box-shadow:0 4px 12px #3e1e6b4d}.zoom-info i{font-size:1.125rem}.download-button{position:absolute;bottom:2rem;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:.75rem;background:#3e1e6b;color:#fff;padding:1rem 2rem;border:none;border-radius:50px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #3e1e6b4d;z-index:100}.download-button:hover{background:#2e1650;transform:translate(-50%) translateY(-2px);box-shadow:0 6px 20px #3e1e6b66}.download-button:active{transform:translate(-50%) translateY(0)}.download-button i{font-size:1.125rem}@media (max-width: 768px){.zoom-info{top:1rem;right:1rem;width:32px;height:32px}.zoom-info i{font-size:1rem}}@media (max-width: 480px){.zoom-info{width:28px;height:28px}.zoom-info i{font-size:.875rem}}@media (hover: none) and (pointer: coarse){.magnifier{display:none}.image-container{cursor:default}.zoom-info{display:none}}.promotion-page{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:#fff;position:relative;overflow:hidden;opacity:1!important;visibility:visible!important;z-index:1}.promotion-page.clickable{cursor:pointer;transition:transform .3s ease}.promotion-page.clickable:hover{transform:scale(1.02)}.promotion-image{width:100%;height:100%;object-fit:contain}.promotion-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#0000;display:flex;align-items:flex-end;justify-content:center;padding-bottom:3rem;transition:background .3s ease;pointer-events:none}.promotion-page.clickable:hover .promotion-overlay{background:#0000001a}.promotion-cta{display:flex;align-items:center;gap:.5rem;background:#fff;color:#6b59a1;padding:1rem 2rem;border-radius:50px;font-size:1.125rem;font-weight:600;opacity:0;transform:translateY(20px);transition:all .3s ease;pointer-events:none;box-shadow:0 4px 12px #00000026}.promotion-page.clickable:hover .promotion-cta{opacity:1;transform:translateY(0)}.promotion-cta i{font-size:1rem}@media (max-width: 768px){.promotion-overlay{padding-bottom:2rem}.promotion-cta{padding:.75rem 1.5rem;font-size:1rem}}.animated-background{position:absolute;top:0;left:0;width:100%;height:100%;overflow:hidden;pointer-events:none;z-index:0}.animated-background-svg{width:100%;height:100%;position:absolute;top:0;left:0}.shapes-container{will-change:transform}.shape-group{animation:float var(--duration, 20s) ease-in-out infinite;transform-origin:center center}.organic-shape{will-change:transform,opacity}@keyframes float{0%{transform:translate(var(--start-x),var(--start-y)) rotate(0) scale(1)}15%{transform:translate(calc(var(--start-x) - 8%),calc(var(--start-y) + 12%)) rotate(15deg) scale(1.12)}35%{transform:translate(calc(var(--start-x) + 10%),calc(var(--start-y) - 6%)) rotate(-10deg) scale(.88)}55%{transform:translate(calc(var(--start-x) + 5%),calc(var(--start-y) + 15%)) rotate(18deg) scale(1.18)}70%{transform:translate(calc(var(--start-x) - 12%),calc(var(--start-y) - 8%)) rotate(-15deg) scale(.92)}85%{transform:translate(calc(var(--start-x) + 8%),calc(var(--start-y) + 5%)) rotate(8deg) scale(1.05)}to{transform:translate(var(--start-x),var(--start-y)) rotate(0) scale(1)}}@keyframes pulse{0%,to{opacity:.2}50%{opacity:.3}}@media (max-width: 768px){.shape-group{animation-duration:calc(var(--duration, 20s) * 1.5)!important}}@media (prefers-reduced-motion: reduce){.shape-group{animation:none}}.goto-page-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:2000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.goto-page-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%)!important;background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;z-index:2001;width:90%;max-width:340px;padding:2rem}.goto-page-title{font-size:1.25rem;font-weight:600;color:#1f2937;margin:0 0 1.5rem;text-align:center}.goto-page-form{display:flex;flex-direction:column;gap:1.5rem}.goto-page-input{width:100%;padding:.875rem 1rem;border:2px solid #f97316;border-radius:8px;font-size:1.5rem;font-family:inherit;font-weight:600;text-align:center;transition:all .2s ease;color:#1f2937}.goto-page-input:focus{outline:none;border-color:#f97316;box-shadow:0 0 0 3px #f973161a}.goto-page-input::-webkit-outer-spin-button,.goto-page-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.goto-page-input[type=number]{-moz-appearance:textfield}.goto-page-actions{display:flex;gap:.75rem}.goto-page-btn{flex:1;padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;font-family:inherit}.goto-page-btn-cancel{background:#f3f4f6;color:#6b7280}.goto-page-btn-cancel:hover{background:#e5e7eb;color:#374151}.goto-page-btn-submit{background:#3b82f6;color:#fff}.goto-page-btn-submit:hover{background:#2563eb;transform:translateY(-1px);box-shadow:0 4px 12px #3b82f64d}.goto-page-btn:active{transform:translateY(0)}@media (max-width: 480px){.goto-page-modal{width:95%;padding:1.5rem}.goto-page-title{font-size:1.125rem}.goto-page-input{font-size:1.25rem}}.catalogue-viewer{display:flex;flex-direction:column;height:calc(100vh - 70px);position:fixed;top:70px;left:0;right:0;background:#fff}.catalogue-container{flex:1;display:flex;align-items:center;justify-content:center;padding:0;position:relative;perspective:2000px;overflow:hidden;background:#fff}.catalogue-book{width:100%;height:100%;position:relative;transform-style:preserve-3d;display:flex;align-items:center;justify-content:center;padding:0}.page-content{width:auto;height:100%;max-height:100%;aspect-ratio:1 / 1.414;background:#fff;overflow:hidden;transform-style:preserve-3d;display:flex;flex-direction:column;box-sizing:border-box}.cover-page{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:#fff}.cover-image{width:100%;height:100%;object-fit:contain;padding:0}.products-page{width:100%;height:100%;display:flex;flex-direction:column;position:relative;background-size:cover;background-position:center;isolation:isolate}.products-page-header{display:flex;flex-direction:column;align-items:flex-start;padding:1rem 2rem;flex-shrink:0;min-height:120px;position:relative;z-index:1;gap:.75rem}.products-page-header .category-title{background:#fff;padding:.75rem 2rem;border-radius:50px;font-size:clamp(.65rem,1.3vh,.85rem);font-weight:700;text-transform:uppercase;letter-spacing:.5px;box-shadow:0 2px 8px #0000001a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:fit-content;align-self:flex-start}.products-page-header .subcategory-container{display:flex;flex-direction:row;align-items:center;gap:0;width:100%;justify-content:flex-end}.products-page-header .subcategory-title{background:#ffffff40;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:.5rem 1.5rem;border-radius:50px;font-size:clamp(.7rem,1.3vh,.9rem);font-style:italic;font-weight:400;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.products-page-header .subcategory-separator{color:#fff;font-size:clamp(.7rem,1.3vh,.9rem);font-weight:400;opacity:.6;margin:0 .25rem}.products-page-header .subsubcategory-title{background:#ffffff40;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:.5rem 1.5rem;border-radius:50px;font-size:clamp(.7rem,1.3vh,.9rem);font-style:italic;font-weight:400;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.products-grid{flex:1;display:grid;gap:1rem;padding:1rem 1rem 2rem;margin-bottom:.5rem;width:100%;overflow:hidden;position:relative;z-index:1;align-items:stretch}.product-card-wrapper-catalogue{transition:all .3s ease;height:100%;display:flex}.product-card-wrapper-catalogue .product-card{height:100%;width:100%}.product-card-wrapper-catalogue.highlighted{animation:highlight-pulse-catalogue 1s ease-in-out 3;z-index:10}@keyframes highlight-pulse-catalogue{0%,to{transform:scale(1);filter:drop-shadow(0 0 0 rgba(107,89,161,0))}50%{transform:scale(1.08);filter:drop-shadow(0 0 20px rgba(107,89,161,.8))}}.products-grid:has(.product-card-wrapper-catalogue:nth-child(6)){grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(2,minmax(0,1fr))}.products-grid:has(.product-card-wrapper-catalogue:nth-child(5)):not(:has(.product-card-wrapper-catalogue:nth-child(6))){grid-template-columns:repeat(6,1fr);grid-template-rows:repeat(2,minmax(0,1fr))}.products-grid:has(.product-card-wrapper-catalogue:nth-child(5)):not(:has(.product-card-wrapper-catalogue:nth-child(6))) .product-card-wrapper-catalogue:nth-child(1),.products-grid:has(.product-card-wrapper-catalogue:nth-child(5)):not(:has(.product-card-wrapper-catalogue:nth-child(6))) .product-card-wrapper-catalogue:nth-child(2),.products-grid:has(.product-card-wrapper-catalogue:nth-child(5)):not(:has(.product-card-wrapper-catalogue:nth-child(6))) .product-card-wrapper-catalogue:nth-child(3){grid-column:span 2}.products-grid:has(.product-card-wrapper-catalogue:nth-child(5)):not(:has(.product-card-wrapper-catalogue:nth-child(6))) .product-card-wrapper-catalogue:nth-child(4),.products-grid:has(.product-card-wrapper-catalogue:nth-child(5)):not(:has(.product-card-wrapper-catalogue:nth-child(6))) .product-card-wrapper-catalogue:nth-child(5){grid-column:span 3}.products-grid:has(.product-card-wrapper-catalogue:nth-child(4)):not(:has(.product-card-wrapper-catalogue:nth-child(5))){grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(2,minmax(0,1fr))}.products-grid:has(.product-card-wrapper-catalogue:nth-child(3)):not(:has(.product-card-wrapper-catalogue:nth-child(4))){grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(2,minmax(0,1fr))}.products-grid:has(.product-card-wrapper-catalogue:nth-child(3)):not(:has(.product-card-wrapper-catalogue:nth-child(4))) .product-card-wrapper-catalogue:nth-child(3){grid-column:1 / -1}.products-grid:has(.product-card-wrapper-catalogue:nth-child(2)):not(:has(.product-card-wrapper-catalogue:nth-child(3))){grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(2,minmax(0,1fr));gap:1rem}.products-grid:has(.product-card-wrapper-catalogue:nth-child(2)):not(:has(.product-card-wrapper-catalogue:nth-child(3))) .product-card-wrapper-catalogue:nth-child(1){grid-column:1 / -1;grid-row:1}.products-grid:has(.product-card-wrapper-catalogue:nth-child(2)):not(:has(.product-card-wrapper-catalogue:nth-child(3))) .product-card-wrapper-catalogue:nth-child(2){grid-column:1 / -1;grid-row:2}.products-grid:not(:has(.product-card-wrapper-catalogue:nth-child(2))){grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(2,1fr)}.products-grid:not(:has(.product-card-wrapper-catalogue:nth-child(2))) .product-card-wrapper-catalogue{grid-column:1 / -1;grid-row:1 / -1}.nav-arrow{position:absolute;top:50%;transform:translateY(-50%);background:#fff;border:none;width:60px;height:60px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #00000026;color:#6b59a1;z-index:10}.nav-arrow:hover:not(:disabled){background:#6b59a1;color:#fff;transform:translateY(-50%) scale(1.1);box-shadow:0 6px 20px #6b59a14d}.nav-arrow:active:not(:disabled){transform:translateY(-50%) scale(.95)}.nav-arrow:disabled{opacity:.3;cursor:not-allowed}.nav-arrow-left{left:10px}.nav-arrow-right{right:10px}.catalogue-progress{background:#fff;padding:1rem 2rem;box-shadow:0 -2px 10px #0000001a;flex-shrink:0}.progress-info{max-width:400px;margin:0 auto}.page-controls{display:flex;flex-direction:column;gap:0;align-items:center}.controls-container{display:inline-flex;flex-direction:column;gap:0}.progress-bar{height:4px;background:#e5e7eb;overflow:hidden;width:100%;border-radius:2px 2px 0 0}.progress-fill{height:100%;background:#6b59a1;transition:width .3s ease}.left-controls{display:flex;align-items:center;justify-content:center;gap:1.5rem;background:#fff;padding:.75rem 2rem;border-radius:0 0 50px 50px;box-shadow:0 2px 8px #0000001a}.control-button{background:transparent;border:none;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;color:#4b5563}.control-button i{font-size:16px}.control-button:hover:not(:disabled){background:#f3f4f6;color:#374151}.control-button:disabled{opacity:.25;cursor:not-allowed}.page-counter{display:flex;align-items:center;min-width:100px;justify-content:center;font-size:1rem;font-weight:500;color:#374151}.page-counter-content{cursor:pointer;padding:0;transition:all .2s ease;display:flex;align-items:center}.page-counter-content:hover{background:transparent}.current-page-number{font-weight:600;color:#374151}.page-separator{margin:0 .375rem;color:#9ca3af;font-weight:400}.total-pages{color:#9ca3af}.page-input-form{display:flex;align-items:center;gap:.5rem}.page-input{width:60px;padding:.25rem;border:2px solid #6B59A1;border-radius:4px;text-align:center;font-size:1rem;font-weight:600;color:#374151;background:#fff}.page-input:focus{outline:none;box-shadow:0 0 0 2px #6b59a133;border-color:#6b59a1}.page-input::-webkit-outer-spin-button,.page-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.page-input[type=number]{-moz-appearance:textfield}.page-number-badge{position:absolute;bottom:.5rem;left:50%;transform:translate(-50%);background:transparent;color:#3e1e6b;border:none;display:flex;align-items:center;justify-content:center;font-size:1rem;font-weight:600;z-index:100}@media (max-width: 1200px){.nav-arrow-left{left:10px}.nav-arrow-right{right:10px}.page-content{height:75vh}}@media (max-width: 768px){.catalogue-container,.catalogue-book{padding:1rem}.page-content{height:70vh}.nav-arrow{width:44px;height:44px}.nav-arrow svg{width:24px;height:24px}.products-page{padding:1rem}.catalogue-progress{padding:.75rem 1rem}.control-button{width:32px;height:32px}.control-button svg{width:16px;height:16px}.page-number-badge{width:40px;height:40px;font-size:.875rem;bottom:1rem}}@media (max-width: 480px){.catalogue-book{padding:.5rem}.page-content{height:65vh}.nav-arrow{width:36px;height:36px}.nav-arrow svg{width:20px;height:20px}.page-controls{gap:.5rem}}.catalogue-list-view{width:100%;height:100vh;overflow-y:auto;background:#fff;padding-top:70px}.catalogue-list-view .catalogue-list-container{width:100%;margin:0;padding:0 0 100vh}.catalogue-list-view .list-view-incentive{padding:2rem;text-align:center;background:#f9fafb;border-bottom:2px solid #e5e7eb}.catalogue-list-view .incentive-text{font-size:1.1rem;color:#6b7280;margin:0}.catalogue-list-view .incentive-icon{display:inline-block;margin-left:.5rem;animation:list-bounce 2s infinite}@keyframes list-bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.catalogue-list-view .category-block{margin:0;padding:0;border:none;border-radius:0;overflow:visible;box-shadow:none;background:transparent}.catalogue-list-view .category-header{width:100%;padding:2rem;background:#6b59a1;color:#fff;border:none;margin:0;border-radius:0;display:flex;align-items:center;justify-content:center;position:relative;cursor:pointer;transition:all .3s ease}.catalogue-list-view .category-header:hover{filter:brightness(1.05)}.catalogue-list-view .category-title{font-size:1.5rem;font-weight:700;margin:0;text-transform:capitalize;letter-spacing:.3px}.catalogue-list-view .category-toggle-icon{position:absolute;right:2rem;display:flex;align-items:center;transition:transform .3s ease}.catalogue-list-view .category-content{padding:0;margin:0;background:#fff}.catalogue-list-view .subcategory-block{margin:0;padding:0;border:none;border-bottom:1px solid #e5e7eb;background:#fff}.catalogue-list-view .subcategory-block:last-child{margin-bottom:0}.catalogue-list-view .subcategory-header{width:100%;padding:1rem 2rem;background:#fff;border:none;border-bottom:1px solid #e5e7eb;margin:0;border-radius:0;display:flex;align-items:center;justify-content:space-between;cursor:pointer;transition:background .2s ease}.catalogue-list-view .subcategory-header:hover{background:#f9fafb}.catalogue-list-view .subcategory-title{font-size:1.1rem;font-weight:600;margin:0;color:#1f2937;text-transform:capitalize}.catalogue-list-view .subcategory-toggle-icon{display:flex;align-items:center;color:#6b7280}.catalogue-list-view .subcategory-products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;padding:2rem;background:#fff;margin:0}.catalogue-list-view .product-image-container{flex:0 0 200px}.catalogue-list-view .product-card-wrapper{transition:all .3s ease}.catalogue-list-view .product-card-wrapper.highlighted{animation:highlight-pulse 1s ease-in-out 3}@keyframes highlight-pulse{0%,to{transform:scale(1);box-shadow:0 0 #6b59a100}50%{transform:scale(1.05);box-shadow:0 0 20px 10px #6b59a14d}}.catalogue-list-view .product-card-placeholder{background:#f3f4f6;border-radius:12px;border:1px solid #e5e7eb;height:400px;position:relative;overflow:hidden}.catalogue-list-view .placeholder-shimmer{position:absolute;top:0;left:-100%;height:100%;width:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.5),transparent);animation:list-shimmer 1.5s infinite}@keyframes list-shimmer{0%{left:-100%}to{left:100%}}@media (max-width: 1400px){.catalogue-list-view .subcategory-products-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}}@media (max-width: 1024px){.catalogue-list-view .category-title{font-size:1.5rem}.catalogue-list-view .subcategory-title{font-size:1.125rem}.catalogue-list-view .subcategory-products-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem}}@media (max-width: 768px){.catalogue-list-view .category-header{padding:1rem 1.5rem}.catalogue-list-view .category-title{font-size:1.25rem}.catalogue-list-view .subcategory-header{flex-direction:column;align-items:flex-start;gap:.5rem}.catalogue-list-view .subcategory-products-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}}@media (max-width: 480px){.catalogue-list-view .category-header{padding:.75rem 1rem}.catalogue-list-view .category-title{font-size:1rem}.catalogue-list-view .subcategory-header{padding:.75rem 1rem}.catalogue-list-view .subcategory-title{font-size:1rem}.catalogue-list-view .subcategory-products-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.75rem}}.filtered-products-view{width:100%;min-height:100vh;background:#fff;padding-top:70px;padding-bottom:2rem}.filtered-header{display:flex;justify-content:space-between;align-items:center;padding:2rem;background:#f9fafb;border-bottom:2px solid #e5e7eb;gap:1rem}.filtered-info{flex:1}.filtered-title{font-size:1.5rem;font-weight:700;color:#111827;margin:0 0 .5rem}.search-term{color:#6b59a1}.filtered-count{font-size:.95rem;color:#6b7280;margin:0}.clear-search-button{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:#6b59a1;color:#fff;border:none;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap}.clear-search-button:hover{background:#5a4a8a;transform:translateY(-1px);box-shadow:0 4px 12px #6b59a14d}.clear-search-button:active{transform:translateY(0)}.filtered-products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;padding:2rem}.filtered-product-wrapper{position:relative;transition:all .3s ease}.filtered-product-wrapper:hover{transform:translateY(-2px)}.product-page-badge{position:absolute;top:.5rem;left:.5rem;display:flex;align-items:center;gap:.35rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;padding:.4rem .75rem;border-radius:50px;font-size:.8rem;font-weight:600;box-shadow:0 2px 8px #0003;z-index:10;cursor:pointer;transition:all .2s ease}.product-page-badge:after{content:"Aller à la page " attr(data-page-number);position:absolute;top:120%;left:50%;transform:translate(-50%) translateY(5px);background:var(--tooltip-bg, #6B59A1);color:#fff;padding:.5rem .75rem;border-radius:6px;font-size:.75rem;font-weight:500;white-space:nowrap;opacity:0;pointer-events:none;transition:all .3s ease;z-index:100}.product-page-badge:before{content:"";position:absolute;top:calc(120% - 5px);left:50%;transform:translate(-50%);border-width:0 6px 6px 6px;border-style:solid;border-color:transparent transparent var(--tooltip-bg, #6B59A1) transparent;opacity:0;pointer-events:none;transition:all .3s ease;z-index:100}.product-page-badge:hover{filter:brightness(.85);transform:scale(1.05);box-shadow:0 4px 12px #0000004d}.product-page-badge:hover:after,.product-page-badge:hover:before{opacity:1;transform:translate(-50%) translateY(0)}.product-page-badge:active{transform:scale(.95)}.page-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.5px;opacity:.9}.page-number{font-size:.9rem;font-weight:700}.no-results{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center}.no-results i{font-size:4rem;color:#d1d5db;margin-bottom:1rem}.no-results p{font-size:1.1rem;color:#6b7280;margin:0 0 1.5rem}.reset-button{padding:.75rem 1.5rem;background:#6b59a1;color:#fff;border:none;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s ease}.reset-button:hover{background:#5a4a8a;transform:translateY(-1px);box-shadow:0 4px 12px #6b59a14d}@media (max-width: 1400px){.filtered-products-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}}@media (max-width: 1024px){.filtered-products-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem}}@media (max-width: 768px){.filtered-header{flex-direction:column;align-items:flex-start;padding:1.5rem}.clear-search-button{width:100%;justify-content:center}.filtered-products-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}.product-page-badge{display:none}}@media (max-width: 480px){.filtered-title{font-size:1.25rem}.filtered-products-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.75rem}}.search-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:2000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.search-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%)!important;background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;z-index:2001;width:90%;max-width:600px;max-height:80vh;display:flex;flex-direction:column;overflow:hidden}.search-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem 2rem;border-bottom:1px solid #e5e7eb}.search-modal-title{font-size:1.5rem;font-weight:600;color:#3e1e6b;margin:0}.search-modal-close{background:transparent;border:none;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;color:#6b7280;font-size:20px}.search-modal-close:hover{background:#f3f4f6;color:#374151}.search-modal-form{padding:1.5rem 2rem;display:flex;gap:1rem;border-bottom:1px solid #e5e7eb}.search-modal-input{flex:1;padding:.75rem 1rem;border:2px solid #e5e7eb;border-radius:8px;font-size:1rem;font-family:inherit;transition:all .2s ease}.search-modal-input:focus{outline:none;border-color:#3e1e6b;box-shadow:0 0 0 3px #3e1e6b1a}.search-modal-button{padding:.75rem 2rem;background:#3e1e6b;color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap}.search-modal-button:hover{background:#2d1650;transform:translateY(-1px);box-shadow:0 4px 12px #3e1e6b4d}.search-modal-button:active{transform:translateY(0)}.search-modal-results{flex:1;overflow-y:auto;padding:1.5rem 2rem}.search-results-count{font-size:.875rem;color:#6b7280;margin-bottom:1rem;font-weight:500}.search-no-results{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1rem;color:#9ca3af;text-align:center}.search-no-results i{font-size:3rem;margin-bottom:1rem;opacity:.5}.search-no-results p{font-size:1.125rem;margin:0}.search-results-list{display:flex;flex-direction:column;gap:.75rem}.search-result-item{display:flex;gap:1rem;padding:1rem;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;cursor:pointer;transition:all .2s ease}.search-result-item:hover{background:#fff;border-color:#3e1e6b;box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.search-result-image{width:80px;height:80px;flex-shrink:0;border-radius:6px;overflow:hidden;background:#f9fafb;display:flex;align-items:center;justify-content:center}.search-result-image img{width:100%;height:100%;object-fit:contain}.search-result-info{flex:1;display:flex;flex-direction:column;gap:.25rem}.search-result-name{font-size:1rem;font-weight:600;color:#374151;margin:0;line-height:1.3}.search-result-ref{font-size:.875rem;color:#6b7280;margin:0}.search-result-category{font-size:.875rem;color:#3e1e6b;font-weight:500;margin:0}.search-modal-results::-webkit-scrollbar{width:8px}.search-modal-results::-webkit-scrollbar-track{background:#f9fafb}.search-modal-results::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:4px}.search-modal-results::-webkit-scrollbar-thumb:hover{background:#9ca3af}@media (max-width: 768px){.search-modal{width:95%;max-height:90vh}.search-modal-header{padding:1rem 1.5rem}.search-modal-title{font-size:1.25rem}.search-modal-form{padding:1rem 1.5rem;flex-direction:column}.search-modal-results{padding:1rem 1.5rem}.search-result-item{padding:.75rem}.search-result-image{width:60px;height:60px}.search-result-name{font-size:.9375rem}}@media (max-width: 480px){.search-modal{width:100%;max-height:100vh;border-radius:0}.search-modal-button{padding:.75rem 1.5rem}}.product-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.product-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%)!important;background:#fff;border-radius:20px;box-shadow:0 20px 60px #0000004d;z-index:1001;width:90%;max-width:900px;height:85vh;max-height:85vh;overflow:hidden;display:flex;flex-direction:column}.product-modal-close{position:absolute;top:1rem;left:1rem;width:44px;height:44px;border-radius:50%;background:#6b59a1;color:#fff;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;z-index:10;box-shadow:0 4px 12px #00000026}.product-modal-close:hover{transform:scale(1.1);box-shadow:0 6px 16px #0003}.product-modal-close:active{transform:scale(.95)}.product-modal-counter{position:absolute;top:1rem;right:1rem;padding:.5rem 1rem;border-radius:50px;background:#6b59a1;color:#fff;font-size:1rem;font-weight:600;z-index:10;box-shadow:0 4px 12px #00000026;display:flex;align-items:center;gap:.5rem}.product-modal-content{display:flex;flex:1;min-height:0}.product-modal-image-container{flex:0 0 50%;display:flex;align-items:center;justify-content:center;padding:0;background:transparent;border-right:1px solid #e5e7eb;position:relative}.product-modal-image{max-width:100%;max-height:100%;object-fit:contain}.product-modal-nav-arrow{position:absolute;top:50%;transform:translateY(-50%);background:#fff;border:none;width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #00000026;color:#6b59a1;z-index:5}.product-modal-nav-arrow:hover{transform:translateY(-50%) scale(1.1);box-shadow:0 6px 20px #0003}.product-modal-nav-arrow:active{transform:translateY(-50%) scale(.95)}.product-modal-nav-left{left:1rem}.product-modal-nav-right{right:1rem}.product-modal-image-wrapper{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.image-nav-arrow{position:absolute;top:50%;transform:translateY(-50%);background:#6b59a1;color:#fff;border:none;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #0003;z-index:4}.image-nav-arrow:hover{transform:translateY(-50%) scale(1.1);box-shadow:0 4px 12px #0000004d}.image-nav-arrow:active{transform:translateY(-50%) scale(.95)}.image-nav-left{left:1rem}.image-nav-right{right:1rem}.image-indicators{position:absolute;bottom:1rem;left:50%;transform:translate(-50%);display:flex;gap:.5rem;z-index:4}.image-indicator{width:10px;height:10px;border-radius:50%;border:none;cursor:pointer;transition:all .2s ease;padding:0}.image-indicator:hover{transform:scale(1.2)}.image-indicator.active{width:12px;height:12px}.product-modal-info{flex:1;display:flex;flex-direction:column;overflow:hidden;min-height:0}.product-modal-header{padding:3rem 3rem 1.5rem;flex-shrink:0}.product-modal-title{font-size:2rem;font-weight:700;margin:0 0 .75rem;line-height:1.3;color:#6b59a1}.product-modal-ref{font-size:1.125rem;color:#6b7280;margin:0 0 1.5rem;font-weight:500}.product-modal-variants{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #e5e7eb}.variant-button{padding:.75rem 1.5rem;border:2px solid #e5e7eb;border-radius:8px;background:#fff;color:#6b7280;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;font-family:inherit}.variant-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.variant-button.active{background:#6b59a10d}.product-modal-scrollable{flex:1;overflow-y:auto;padding:0 3rem 1.5rem}.product-modal-description-title{font-size:1.25rem;font-weight:600;color:#111827;margin:0 0 1rem}.product-modal-description{font-size:1rem;line-height:1.7;color:#4b5563;margin:0}.product-modal-cta{padding:1.5rem 3rem;border-top:1px solid #e5e7eb;background:#fff;flex-shrink:0}.product-modal-eshop-button{background:#6b59a1;color:#fff;border:none;padding:1rem 2rem;font-size:1.125rem;font-weight:600;border-radius:12px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #6b59a14d;width:100%}.product-modal-eshop-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #6b59a166}.product-modal-eshop-button:active{transform:translateY(0)}@media (max-width: 768px){.product-modal{width:95%;max-height:90vh}.product-modal-content{flex-direction:column}.product-modal-image-container{flex:0 0 auto;max-height:40vh;padding:2rem;border-right:none;border-bottom:1px solid #e5e7eb}.product-modal-info{padding:2rem}.product-modal-title{font-size:1.5rem}.product-modal-ref{font-size:1rem;margin-bottom:1.5rem}.product-modal-description-title{font-size:1.125rem}.product-modal-description{font-size:.9375rem;margin-bottom:1.5rem}.product-modal-eshop-button{width:100%;text-align:center}.product-modal-close{width:40px;height:40px}.product-modal-counter{font-size:.9rem;padding:.4rem .875rem}.product-modal-nav-arrow{width:44px;height:44px}.product-modal-nav-left{left:.75rem}.product-modal-nav-right{right:.75rem}}@media (max-width: 480px){.product-modal{width:100%;height:100%;max-height:100vh;border-radius:0}.product-modal-image-container,.product-modal-info{padding:1.5rem}.product-modal-title{font-size:1.25rem}.product-modal-close{width:36px;height:36px}.product-modal-counter{font-size:.8rem;padding:.35rem .75rem}.product-modal-nav-arrow{width:40px;height:40px}.product-modal-nav-left{left:.5rem}.product-modal-nav-right{right:.5rem}}.pdf-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:10000}.pdf-modal{background:#fff;border-radius:12px;padding:2rem;max-width:500px;width:90%;box-shadow:0 10px 40px #0000004d}.pdf-modal-content{text-align:center}.pdf-icon{font-size:4rem;color:#6b59a1;margin-bottom:1rem;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.pdf-modal-content h2{font-size:1.5rem;font-weight:700;color:#374151;margin-bottom:.5rem}.pdf-modal-content p{font-size:1rem;color:#6b7280;margin-bottom:1.5rem}.pdf-progress-bar{width:100%;height:8px;background:#e5e7eb;border-radius:4px;overflow:hidden;margin-bottom:1rem}.pdf-progress-fill{height:100%;background:linear-gradient(90deg,#6b59a1,#8b7ab8);transition:width .3s ease;border-radius:4px}.pdf-info{font-size:.875rem;color:#9ca3af}.app{min-height:100vh;display:flex;flex-direction:column;background:#fff}.main-content{flex:1;display:flex;flex-direction:column;position:relative}.footer-spacer{height:100vh}.app-loader{position:fixed;top:0;left:0;right:0;bottom:0;background:#fffffff2;display:none;align-items:center;justify-content:center;z-index:9999}.app-loader.active{display:flex}.loader-content{text-align:center}.spinner{width:60px;height:60px;border:4px solid #e5e7eb;border-top-color:#6b59a1;border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 1rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loader-content p{color:#6b7280;font-weight:500;margin:0}.error-container{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;text-align:center}.error-container h1{color:#e53d3e;margin-bottom:1rem}.error-container p{color:#6b7280;margin-bottom:2rem}.error-container button{background:#6b59a1;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:background .2s ease}.error-container button:hover{background:#5a4a8a}@media (max-width: 768px){.spinner{width:48px;height:48px}}:root{--bg-primary: #ffffff;--bg-secondary: #f9fafb;--text-primary: #111827;--text-secondary: #6b7280;--border-color: #e5e7eb;--shadow: rgba(0, 0, 0, .1)}.dark{--bg-primary: #111827;--bg-secondary: #1f2937;--text-primary: #f9fafb;--text-secondary: #9ca3af;--border-color: #374151;--shadow: rgba(0, 0, 0, .3)}.dark body{background:var(--bg-primary);color:var(--text-primary)}.dark .app-header{background:#1f2937;box-shadow:0 2px 10px #00000080;border-bottom:1px solid var(--border-color)}.dark .header-btn{color:#9ca3af}.dark .header-btn:hover:not(.disabled){background:#6b59a133;color:#6b59a1}.dark .header-btn:hover:not(.disabled):after{background:#6b59a1}.dark .header-btn:hover:not(.disabled):before{border-color:transparent transparent #6B59A1 transparent}.dark .header-btn.active{color:#6b59a1}.dark .header-btn.active:after{background:#6b59a1}.dark .catalogue-viewer,.dark .catalogue-container{background:var(--bg-primary)}.dark .page-content{background:var(--bg-secondary)}.dark .toc-page{background:var(--bg-secondary);color:var(--text-primary)}.dark .toc-title,.dark .toc-category-title,.dark .toc-subcategory-title{color:var(--text-primary)}.dark .toc-page-number{color:var(--text-secondary)}.dark .toc-category-link:hover,.dark .toc-subcategory-link:hover{background:#6b59a11a}.dark .category-intro-page{background:var(--bg-secondary)}.dark .category-intro-title{background:var(--bg-primary);color:var(--text-primary)}.dark .category-intro-list-container{background:var(--bg-primary)}.dark .category-intro-flat-item{color:var(--text-primary)}.dark .product-card{background:#1f2937;border-color:var(--border-color);box-shadow:0 4px 12px #0000004d}.dark .product-card:hover{box-shadow:0 15px 35px #00000080;transform:translateY(-5px)}.dark .product-name{color:var(--text-primary)}.dark .product-ref,.dark .product-description{color:var(--text-secondary)}.dark .product-badge{opacity:.9}.dark .ecological-badge{background:#059669;color:#fff}.dark .products-page{background:var(--bg-secondary)}.dark .products-grid,.dark .products-page-header{background:transparent}.dark .products-page-header .category-title{background:#1f2937;color:#f9fafb;box-shadow:0 2px 12px #0006;border:1px solid var(--border-color)}.dark .products-page-header .subcategory-title,.dark .products-page-header .subsubcategory-title{background:#ffffff26;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.3)}.dark .products-page-header .subcategory-separator{color:#ffffffb3}.dark .catalogue-progress{background:var(--bg-secondary);border-top-color:var(--border-color)}.dark .progress-bar{background:var(--border-color)}.dark .left-controls{background:var(--bg-primary);box-shadow:0 2px 8px var(--shadow)}.dark .control-button{color:var(--text-secondary)}.dark .control-button:hover:not(:disabled){background:var(--bg-secondary);color:var(--text-primary)}.dark .page-counter{color:var(--text-primary)}.dark .page-separator,.dark .total-pages{color:var(--text-secondary)}.dark .page-input{background:var(--bg-secondary);border-color:#6b59a1;color:var(--text-primary)}.dark .nav-arrow{background:var(--bg-primary);border-color:var(--border-color);color:#6b59a1;box-shadow:0 4px 12px var(--shadow)}.dark .nav-arrow:hover:not(:disabled){background:#6b59a1;color:#fff}.dark .filtered-products-view{background:var(--bg-primary)}.dark .filtered-header{background:var(--bg-secondary);border-bottom-color:var(--border-color)}.dark .filtered-title{color:var(--text-primary)}.dark .filtered-count,.dark .no-results{color:var(--text-secondary)}.dark .no-results i{color:var(--border-color)}.dark .modal-overlay,.dark .product-modal-overlay{background:#000000d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.dark .modal-content,.dark .product-modal{background:#1f2937;border:1px solid var(--border-color);box-shadow:0 20px 60px #0009}.dark .modal-title{color:var(--text-primary)}.dark .modal-close,.dark .product-modal-close{background:#6b59a1;color:#fff}.dark .modal-close:hover,.dark .product-modal-close:hover{background:#8171b8}.dark .product-modal-image-container{background:#111827;border-right-color:var(--border-color)}.dark .product-modal-details{background:#1f2937}.dark .product-modal-name{color:var(--text-primary)}.dark .product-modal-ref,.dark .product-modal-category,.dark .product-modal-description{color:var(--text-secondary)}.dark .product-modal-info-item{background:#111827;border-color:var(--border-color)}.dark .product-modal-info-label{color:var(--text-secondary)}.dark .product-modal-info-value{color:var(--text-primary)}.dark .image-nav-arrow{background:#1f2937e6;border-color:var(--border-color);color:var(--text-primary)}.dark .image-nav-arrow:hover:not(:disabled){background:#6b59a1;color:#fff}.dark .search-modal{background:#1f2937;border:1px solid var(--border-color)}.dark .search-modal-input{background:#111827;border-color:var(--border-color);color:var(--text-primary)}.dark .search-modal-input:focus{border-color:#6b59a1;box-shadow:0 0 0 3px #6b59a133}.dark .search-modal-input::placeholder{color:var(--text-secondary)}.dark .search-results-container{background:#1f2937}.dark .search-result-item{background:#111827;border-color:var(--border-color)}.dark .search-result-item:hover{background:#1f2937;border-color:#6b59a1}.dark .footer{background:var(--bg-secondary);border-top-color:var(--border-color)}.dark .page-number-indicator{color:var(--text-secondary);background:var(--bg-secondary)}.dark .catalogue-list-view,.dark .category-section{background:var(--bg-primary)}.dark .category-header{background:var(--bg-secondary);border-bottom-color:var(--border-color)}.dark .category-title-text{color:var(--text-primary)}*{transition:background-color .3s ease,color .3s ease,border-color .3s ease}
