/* Mobile Header (< 1024px) */
.mobile-header{position:fixed;top:0;left:0;right:0;z-index:1000;background:var(--bleu-principal);height:60px;padding:0 var(--s-4);display:flex;align-items:center;justify-content:space-between;box-shadow:var(--header-shadow)}
.mobile-header .mobile-menu-toggle{order:1;flex-shrink:0}
.mobile-header .mobile-logo{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);z-index:1000;display:flex;justify-content:center;align-items:center;pointer-events:none}
.mobile-header .mobile-logo a{pointer-events:auto}
.mobile-header .mobile-nav-icons{order:3;display:flex;gap:1rem;align-items:center;flex-shrink:0}
.mobile-nav-icon-btn,.mobile-menu-toggle{background:none;border:none;color:var(--blanc);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:.5rem;width:40px;height:40px;flex-shrink:0;touch-action:manipulation;-webkit-tap-highlight-color:transparent;position:relative;z-index:1001}
.mobile-nav-icon-btn svg,.mobile-menu-toggle svg{width:24px;height:24px;display:block;pointer-events:none}
.mobile-nav-icon-btn i{font-size:24px;display:block;pointer-events:none;color:var(--blanc);font-weight:400}
.mobile-nav-icon-btn i.ph-phone,.mobile-nav-icon-btn i.ph-bag-simple{font-weight:300}
.mobile-menu-toggle{flex-direction:column;gap:0;position:relative;padding:0}
.hamburger-line{display:block;width:24px;height:2px;background:var(--blanc);transition:transform .3s ease,background .3s ease;border-radius:2px;pointer-events:none;position:absolute;left:50%;top:50%;margin:0;backface-visibility:hidden;transform-origin:center;will-change:transform}
.mobile-menu-toggle .hamburger-line:nth-child(1){transform:translate(-50%,-6px)}
.mobile-menu-toggle .hamburger-line:nth-child(2){transform:translate(-50%,6px)}
.mobile-menu-toggle.active .hamburger-line:nth-child(1){transform:translate(-50%,0) rotate(45deg);-webkit-font-smoothing:antialiased}
.mobile-menu-toggle.active .hamburger-line:nth-child(2){transform:translate(-50%,0) rotate(-45deg);-webkit-font-smoothing:antialiased}

/* Desktop Header (≥ 1024px) */
.main-nav{position:fixed !important;top:0 !important;left:0 !important;right:0 !important;z-index:1000 !important;background:var(--bleu-principal) !important;height:70px !important}
body{padding-top:70px}
html{scroll-padding-top:70px}
.nav-container{max-width:1280px;margin:0 auto;height:100%;padding:0 2rem;display:flex;align-items:center;justify-content:space-between;gap:var(--s-6)}

/* Logo */
.nav-logo img{height:40px;width:auto}
.mobile-logo img{height:34px;width:auto}

/* Menu items */
.nav-menu{display:flex;list-style:none;align-items:center;margin:0;padding:0}
.nav-menu-left{margin-right:auto}
.nav-menu-right{margin-left:auto}
.nav-item{position:relative}
.nav-link{display:flex;align-items:center;gap:.4rem;padding:.75rem 1rem;color:var(--blanc) !important;text-decoration:none;font-family:'Satoshi',sans-serif;font-weight:500;font-size:.9375rem;border-radius:6px}
.nav-link:hover,.nav-link:focus,.nav-link:active,.nav-item.active .nav-link,.nav-item:hover .nav-link{background:var(--bleu-secondaire)}

/* Icons */
.nav-icon{width:12px;height:12px;flex-shrink:0;color:var(--blanc) !important;fill:var(--blanc) !important}
.nav-icon.chevron{transform:rotate(0deg);color:var(--blanc) !important;fill:var(--blanc) !important;font-size:12px;display:flex;align-items:center;justify-content:center}
.nav-item.active .nav-icon.chevron{transform:rotate(180deg);color:var(--blanc) !important;fill:var(--blanc) !important}
.nav-link:hover .nav-icon,.nav-link:focus .nav-icon,.nav-link:active .nav-icon,.nav-item.active .nav-link .nav-icon,.nav-item:hover .nav-link .nav-icon{color:var(--blanc) !important;fill:var(--blanc) !important}
.nav-icon-btn i{font-size:20px;color:var(--blanc);display:flex;align-items:center;justify-content:center;font-weight:400}
.nav-icon-btn i.ph-magnifying-glass,.nav-icon-btn i.ph-bag-simple{font-weight:300}
.plus-yellow{color:var(--jaune);font-weight:600;margin-left:.15rem}
.nav-link i.ph-plus,.mobile-nav-link i.ph-plus{color:var(--jaune);font-size:12px}

/* Boutons actions */
.nav-icons{display:flex;gap:.75rem;align-items:center}
.nav-icon-btn{background:none;border:none;color:var(--blanc);cursor:pointer;padding:.5rem;display:flex;align-items:center;justify-content:center;border-radius:6px}
.nav-icon-btn:hover{background:var(--bleu-secondaire)}
.nav-icon-btn svg{width:20px;height:20px}
.nav-icon-btn i{font-size:20px}
.cart-badge{position:absolute;top:0;right:0;background:var(--blanc);color:var(--bleu-principal);border-radius:50%;width:18px;height:18px;display:none;align-items:center;justify-content:center;font-size:.6875rem;font-weight:700}

/* Mega Menu */
.mega-menu{position:fixed;top:70px;left:0;right:0;background:var(--blanc);display:none;z-index:1001}
.mega-menu.active{display:block}
.mega-content{max-width:1280px;margin:0 auto;padding:2.5rem 2rem 3rem;display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--s-7)}
.mega-column{display:flex;flex-direction:column}
.mega-title{font-family:'Satoshi',sans-serif;font-weight:600;font-size:1.15rem}
.mega-links{display:flex;flex-direction:column;gap:.5rem}
.mega-links li a{align-items:center;padding:.35rem .35rem .35rem .35rem;border-radius:5px}
.mega-links li a:hover{background:var(--gris)}
.mega-icon{width:16px;height:16px;flex-shrink:0;opacity:.7}

/* Mega Menu CTA Column */
.mega-column-cta{min-width:280px;max-width:320px;align-self:stretch}
.mega-cta-image{display:block;position:relative;text-decoration:none;overflow:hidden;border-radius:8px;height:100%;min-height:300px;transition:transform .3s ease}
.mega-cta-image:hover{transform:scale(1.02)}
.mega-cta-image img{width:100%;height:100%;display:block;object-fit:cover}
.mega-cta-title{position:absolute;bottom:0;left:0;right:0;padding:var(--s-4);background:linear-gradient(to top, rgba(15,24,46,0.9), transparent);color:var(--blanc);font-family:'Satoshi',sans-serif}
.mega-cta-headline{font-weight:600;font-size:1.125rem;margin-bottom:0.25rem;line-height:1.3}
.mega-cta-subheadline{font-weight:400;font-size:0.875rem;opacity:0.95;line-height:1.4}

/* Mega footer (CTAs) */
.mega-footer{background:var(--blanc)}
.mega-footer-content{max-width:1280px;margin:0 auto;padding:var(--s-5) 2rem;display:flex;gap:var(--s-5);justify-content:flex-end;flex-wrap:wrap}

/* Search & Cart mega-menus */
#search,#cart{width:550px;left:auto;padding-top:var(--s-6);top:0;height:100vh;z-index:1002}
.mega-close-btn{position:absolute;top:var(--s-5);right:var(--s-5);background:none;border:none;cursor:pointer;color:var(--text);width:32px;height:32px;display:flex;align-items:center;justify-content:center;z-index:1003;transition:all .2s ease}
.mega-close-btn svg{width:50px;height:50px}
.mega-close-btn i{font-size:24px;color:var(--text);display:flex;align-items:center;justify-content:center}
#search ~ .mega-overlay,#cart ~ .mega-overlay{z-index:1001}
.search-input-wrapper{position:relative;margin-bottom:var(--s-6);border-bottom:1px solid var(--gris)}
.search-input-wrapper:focus-within{border-bottom-color:var(--bleu-principal)}
.search-icon{position:absolute;right:1rem;top:50%;transform:translateY(-50%);pointer-events:none;font-size:20px;color:var(--muted);display:flex;align-items:center;justify-content:center}
.search-input{width:100%;padding:1.5rem 3rem 1.5rem 0rem;border:none;background:transparent;font-size:1.125rem;font-family:'General Sans',sans-serif}
.search-input:focus{outline:none}

/* Search Results */
.search-results.loading:before{content:"Recherche en cours...";display:block;padding:2rem;text-align:center;color:var(--muted)}
.search-results.empty:before{content:"Aucun résultat trouvé";display:block;padding:2rem;text-align:center;color:var(--muted);font-weight:500}
.search-results.empty:after{content:"Essayez avec d'autres mots-clés";display:block;padding:0 2rem 2rem;text-align:center;color:var(--muted);font-size:.875rem}
.search-results.error:before{content:"Erreur lors de la recherche. Veuillez réessayer.";display:block;padding:2rem;text-align:center;color:#dc2626}
.search-result-item{display:flex;gap:1rem;padding:1rem 0;align-items:center}
.search-result-item:hover{background:var(--gris)}
.search-result-thumb{width:60px;height:60px;object-fit:cover;flex-shrink:0;background:var(--gris);display:block}
.search-result-thumb.placeholder{background:var(--gris);display:flex !important;align-items:center;justify-content:center;min-width:60px}
.search-result-thumb.placeholder:before{content:"";width:24px;height:24px;background: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='%2364748B' stroke-width='2'%3E%3Crect x='3' y='3' width='18' height='18' rx='2'/%3E%3Ccircle cx='8.5' cy='8.5' r='1.5'/%3E%3Cpolyline points='21 15 16 10 5 21'/%3E%3C/svg%3E") no-repeat center;display:block}
.search-result-content{flex:1;min-width:0}
.search-result-title{font-weight:500;color:var(--text);margin-bottom:.25rem}
.search-result-type{font-size:.875rem;color:var(--muted)}
.search-result-price{font-size:.875rem;color:var(--bleu-principal);font-weight:500;margin-top:.25rem}

.cart-dynamic-title{font-family:'Satoshi',sans-serif;font-weight:600;font-size:1.125rem;color:var(--text);margin-bottom:var(--s-4)}
.cart-status,.cart-message{color:var(--muted);font-size:.9375rem;line-height:1.6}
.cart-message a{color:var(--bleu-principal)}

/* ========== Cart drawer ========== */
#cart .mega-content{display:flex;flex-direction:column;height:calc(100vh - var(--s-6) * 2)}
#cart .mega-content .mega-column{display:flex;flex-direction:column;flex:1;height:100%}

/* Panier vide : centré */
#cart .cart-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:var(--s-4);width:100%;flex:1}
#cart .cart-empty-title{font-family:'Satoshi',sans-serif;font-weight:600;font-size:var(--fs-h2);line-height:var(--lh-h2)}
#cart .cart-empty-subtitle{color:var(--muted)}
#cart .cart-empty-categories{display:flex;gap:var(--s-4)}
#cart .cart-empty-cat{display:flex;flex-direction:column;gap:var(--s-4)}
#cart .cart-empty-cat:hover{opacity:.9}
#cart .cart-empty-cat img{width:85%;margin:0 auto}
#cart .cart-empty-cat span{font-weight:500}

/* Panier avec items : items en haut, boutons en bas */
#cart .cart-drawer-content:not(:empty) + .cart-empty-state{display:none}
#cart .cart-drawer-content:not(:empty){display:flex;flex-direction:column;flex:1;justify-content:space-between;overflow:hidden}
#cart .cart-items{display:flex;flex-direction:column;gap:var(--s-3);width:100%;flex:1;overflow-y:auto;scrollbar-width:none;-ms-overflow-style:none}
#cart .cart-items::-webkit-scrollbar{display:none}
#cart .cart-item{display:flex;align-items:center;gap:var(--s-3);padding:var(--s-3);border-radius:8px}
#cart .cart-item-info{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}
#cart .cart-item-cat{font-size:var(--fs-badge);color:var(--muted)}
#cart .cart-item-name{font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}
#cart .cart-item-qty{display:inline-flex;align-items:center;border:1px solid var(--gris);margin-top:var(--s-2);width:fit-content;font-family:'Satoshi',sans-serif}
#cart .cart-qty-btn{background:none;border:none;width:32px;height:32px;font-size:1rem;color:var(--text);cursor:pointer;display:flex;align-items:center;justify-content:center}
#cart .cart-qty-value{min-width:24px;text-align:center;font-weight:500;font-size:.875rem}
#cart .cart-item-remove{opacity:0;background:none;border:none;color:var(--muted);cursor:pointer;font-size:1rem}
#cart .cart-item:hover .cart-item-remove{opacity:1}
#cart .cart-item-remove:hover{color:var(--danger,#e53935)}
#cart .cart-actions{display:flex;flex-direction:column;gap:var(--s-3);width:100%}
#cart .cart-actions .bouton-bleu,#cart .cart-actions .bouton-blanc{width:100%;text-align:center}
#cart .cart-continue{cursor:pointer}

/* Overlay */
.mega-overlay{position:fixed;inset:0;background:rgba(15,24,46,.8);opacity:0;visibility:hidden;z-index:999;pointer-events:none;transition:opacity .3s ease,visibility .3s ease}
.mega-overlay.visible{opacity:1;visibility:visible;pointer-events:auto}
.mega-overlay.drawer{z-index:1001}

/* Mobile Menu (drawer) */
.mobile-menu{position:fixed !important;width:100% !important;height: calc(100dvh - 60px) !important;background:var(--blanc);overflow:hidden;z-index:1002 !important;transform:translateX(-100%);opacity:0;visibility:hidden;pointer-events:none;transition:transform .3s ease,opacity .3s ease,visibility .3s ease;backface-visibility:hidden;will-change:transform}
body.mobile-menu-open .mobile-menu{transform:translateX(0) !important;opacity:1 !important;visibility:visible !important;pointer-events:auto !important}
.mobile-menu-content{width:100%;height:100%;position:relative}
.mobile-menu-header{padding:var(--s-5);border-bottom:1px solid var(--gris)}
/* Volet principal (sans header) */
.mobile-menu-pane[data-pane-id="main"]{display:flex;flex-direction:column;height:100%}
.mobile-menu-pane[data-pane-id="main"] .mobile-menu-pane-content{display:flex;flex-direction:column;flex:1;min-height:0;height:100%;overflow:hidden}
.mobile-menu-pane[data-pane-id="main"] .mobile-menu-pane-content > .mobile-nav-list:first-child{flex:1;overflow-y:auto;min-height:0}
.mobile-menu-pane[data-pane-id="main"] .mobile-menu-pane-content > .mobile-menu-secondary{flex-shrink:0}
.mobile-menu-pane[data-pane-id="main"] .mobile-menu-pane-content > .mobile-menu-footer{flex-shrink:0}
.mobile-nav-link{display:flex;align-items:center;justify-content:space-between;padding:var(--s-4);color:var(--text) !important;text-decoration:none;font-family:'Satoshi',sans-serif;font-weight:500;font-size:1rem}
.mobile-nav-link > span{display:inline-flex;align-items:center;white-space:nowrap;gap:.4rem}
.mobile-nav-chevron{color:var(--text) !important;fill:var(--text) !important;font-size:16px;display:flex;align-items:center;justify-content:center;transition:transform .3s ease;flex-shrink:0}
.mobile-nav-link i.ph-plus{color:var(--jaune);font-size:12px;margin-left:0}

/* Navigation par volets */
.mobile-menu-panes{width:100%;height:100%;position:relative}
.mobile-menu-pane{display:none;position:absolute;top:0;left:0;width:100%;height:100%;background:var(--blanc);overflow:hidden;flex-direction:column}
.mobile-menu-pane.active{display:flex;z-index:11}
.mobile-menu-pane-header{display:flex;align-items:center;gap:var(--s-4);padding:var(--s-4);border-bottom:1px solid var(--gris);position:sticky;top:0;background:var(--blanc);z-index:12;flex-shrink:0}
.mobile-menu-pane-back{background:none;border:none;cursor:pointer;color:var(--text);padding:.5rem;display:flex;align-items:center;justify-content:center;font-size:20px;width:40px;height:40px;flex-shrink:0;margin-left:-.5rem}
.mobile-menu-pane-back i{font-size:20px;color:var(--text)}
.mobile-menu-pane-title{flex:1;font-family:'Satoshi',sans-serif;font-weight:600;font-size:1rem;color:var(--text);display:flex;align-items:center;gap:.4rem}
.mobile-menu-pane-content{padding:0;display:flex;flex-direction:column;flex:1;min-height:0;overflow-y:auto}
.mobile-menu-pane-content > .mobile-submenu-list{flex:1;overflow-y:auto;min-height:0}
.mobile-menu-pane-link{display:flex;align-items:center;justify-content:space-between;padding:var(--s-4);color:var(--text) !important;text-decoration:none;font-family:'Satoshi',sans-serif;font-weight:500;font-size:1rem}
.mobile-menu-pane-link i{display:none}
.mobile-menu-pane-footer{flex-shrink:0;padding:var(--s-4);display:flex;flex-direction:column;gap:var(--s-4)}
.mobile-menu-pane-footer-btn{width:100%;text-align:center;justify-content:center}
.mobile-menu-pane-footer .mobile-menu-footer-image{display:block;position:relative;text-decoration:none;overflow:hidden;border-radius:8px;flex:0 0 30vh;min-height:30vh;max-height:30vh;height:30vh}
.mobile-menu-pane-footer .mobile-menu-footer-image img{width:100%;height:100%;display:block;object-fit:cover}
.mobile-menu-pane-footer .mobile-menu-footer-title{position:absolute;bottom:0;left:0;right:0;padding:var(--s-4);background:linear-gradient(to top, rgba(15,24,46,0.9), transparent);color:var(--blanc);font-family:'Satoshi',sans-serif;font-weight:600;font-size:1rem;line-height:1.3}

/* Submenu mobile - maintenant caché par défaut */
.mobile-submenu{display:none}
.mobile-submenu-list{background:var(--blanc);color:var(--text)}
.mobile-submenu-section-title{display:flex;align-items:center;justify-content:space-between;padding:var(--s-4);color:var(--text);font-family:'Satoshi',sans-serif;font-weight:500;font-size:1rem;cursor:pointer;transition:background .2s ease;text-transform:none}
.mobile-submenu-section-title:hover{background:var(--gris)}
.mobile-submenu-section-title a{color:var(--text) !important;text-decoration:none;flex:1;display:flex;align-items:center;justify-content:space-between;width:100%}
.mobile-submenu-section-title span{flex:1}
.mobile-submenu-section-title .mobile-nav-chevron{color:var(--muted) !important;fill:var(--muted) !important;font-size:16px;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-left:var(--s-3)}
.mobile-submenu-link{display:block;padding:.625rem var(--s-5);color:var(--text) !important;text-decoration:none;font-size:.9375rem}
.mobile-submenu-view-all{list-style:none}
.mobile-submenu-view-all-link{display:flex;align-items:center;justify-content:space-between;padding:var(--s-4);color:var(--text) !important;text-decoration:none;font-family:'Satoshi',sans-serif;font-weight:500;font-size:1rem;cursor:pointer;transition:background .2s ease}
.mobile-submenu-view-all-link:hover{background:var(--gris)}
.mobile-submenu-list li{color:var(--text);border-bottom:none}
.mobile-submenu-list{list-style:none;padding:0;margin:0}
.mobile-nav-list{list-style:none;padding:0;margin:0}

/* Section secondaire mobile (Services +, L'entreprise) */
.mobile-menu-secondary{display:flex;flex-direction:column;gap:var(--s-4);flex-shrink:0}
.mobile-menu-secondary .mobile-nav-list{padding:0}

/* CTA boutons mobile */
.mobile-menu-cta{display:flex;flex-direction:row;gap:var(--s-3);padding:0 var(--s-4) var(--s-4);flex-shrink:0}
.mobile-menu-btn-contact{width:100%;text-align:center;justify-content:center}

/* Footer image mobile */
.mobile-menu-footer{flex:0 0 30vh;padding:0 var(--s-4) var(--s-4);flex-shrink:0;min-height:30vh;max-height:30vh}
.mobile-menu-footer-image{display:block;position:relative;text-decoration:none;overflow:hidden;border-radius:8px;height:100%}
.mobile-menu-footer-image img{width:100%;height:100%;display:block;object-fit:cover}
.mobile-menu-footer-title{position:absolute;bottom:0;left:0;right:0;padding:var(--s-4);background:linear-gradient(to top, rgba(15,24,46,0.9), transparent);color:var(--blanc);font-family:'Satoshi',sans-serif;font-weight:600;font-size:1rem;line-height:1.3}

/* Responsive */
@media (max-width:1023px){
  html{scroll-padding-top:60px}
  body{padding-top:60px}
  .main-nav{display:none !important}
  #search,#cart{width:100%}
}

@media (min-width:1024px){
  .mobile-header{display:none !important}
  .mobile-menu{display:none !important}
}

@media (min-width:1024px) and (max-width:1279px){
  .nav-container{padding:0 var(--s-5);gap:1rem}
  .nav-link{padding:.75rem .75rem;font-size:.875rem}
  .mega-content{padding:var(--s-6) var(--s-5);gap:var(--s-6)}
}
body.mobile-menu-open{overflow:hidden}
