/* Catalogue Makito — sans prix public */
.makito-page{
  padding:calc(64px + 2rem) 1.25rem 3rem;
  max-width:1200px;margin:0 auto;
}
.makito-page--explorer .makito-hero{margin-bottom:1.5rem}
.makito-hero{margin-bottom:2rem;max-width:720px}
.makito-breadcrumb--hero{margin-bottom:.65rem!important}
.makito-hero h1{
  font-size:clamp(1.75rem,4vw,2.35rem);
  font-weight:600;letter-spacing:-.03em;line-height:1.12;margin:.35rem 0 .75rem;
}
.makito-hero-lead{font-size:.9375rem;line-height:1.55;color:var(--muted);margin:0}
.section-label{font-size:.8125rem;color:var(--ig-blue);margin-bottom:.5rem;font-weight:600}

.makito-unavailable{
  padding:2rem 1.5rem;border-radius:14px;text-align:center;
  background:var(--ig-surface);border:1px solid var(--border);
}
.makito-unavailable p{margin:0;font-size:.9375rem;color:var(--text);font-weight:600}
.makito-unavailable-sub{
  margin-top:.5rem!important;font-size:.875rem!important;font-weight:400!important;color:var(--muted)!important;
}
.makito-unavailable-cta{
  display:inline-flex;margin-top:1.25rem;padding:.65rem 1.25rem;
  font-size:.875rem;font-weight:600;color:#fff!important;
  background:var(--ig-blue);border-radius:999px;
  box-shadow:0 2px 10px rgba(0,149,246,.25);
  transition:background .2s,transform .2s;
}
.makito-unavailable-cta:hover{background:var(--ig-blue-hover);transform:translateY(-1px)}

.makito-alert{
  padding:1rem 1.15rem;border-radius:12px;
  background:rgba(237,73,86,.08);border:1px solid rgba(237,73,86,.2);
  color:#c13545;font-size:.875rem;
}
.makito-alert-muted{color:var(--muted)}

.makito-toolbar{
  display:flex;flex-wrap:wrap;gap:.65rem;align-items:center;
  margin-bottom:1rem;padding:1rem;
  background:var(--ig-surface);border:1px solid var(--border);border-radius:12px;
}
.makito-search{flex:1 1 220px}
.makito-search input,
.makito-filter select{
  width:100%;padding:.65rem .85rem;
  background:var(--ig-bg);border:1px solid var(--border);border-radius:10px;
  font-family:inherit;font-size:.875rem;color:var(--text);outline:none;
}
.makito-search input:focus,
.makito-filter select:focus{border-color:var(--ig-blue);box-shadow:0 0 0 3px rgba(0,149,246,.12)}
.makito-filter{flex:0 1 200px;min-width:160px}
.makito-toolbar-btn{
  padding:.65rem 1.1rem;border:none;border-radius:999px;
  background:var(--ig-blue);color:#fff;font-weight:600;font-size:.8125rem;
  cursor:pointer;font-family:inherit;
}
.makito-toolbar-btn:hover{background:var(--ig-blue-hover)}
.makito-toolbar-reset{font-size:.8125rem;font-weight:600;color:var(--muted);white-space:nowrap}
.makito-toolbar-reset:hover{color:var(--ig-blue)}

/* Grille catégories — style megamenu Makito */
.makito-families{margin-bottom:2.5rem}
.makito-families-head{
  display:flex;flex-wrap:wrap;align-items:baseline;justify-content:space-between;gap:.5rem 1rem;
  margin-bottom:1rem;
}
.makito-families-head h2{font-size:1.0625rem;font-weight:700;margin:0;letter-spacing:-.02em}
.makito-families-head p{margin:0;font-size:.8125rem;color:var(--muted)}
.makito-families-grid{
  list-style:none;margin:0;padding:0;
  display:grid;grid-template-columns:repeat(9,minmax(0,1fr));gap:.75rem;
}
.makito-families-grid > li{display:flex;min-width:0}
.makito-family-card{
  display:flex;flex-direction:column;align-items:center;justify-content:flex-start;text-align:center;
  width:100%;height:148px;padding:.75rem .45rem .65rem;border-radius:12px;box-sizing:border-box;
  background:var(--ig-surface);border:1px solid var(--border);color:var(--text);
  text-decoration:none;transition:border-color .2s,box-shadow .2s,transform .2s;
}
.makito-family-card:hover{
  border-color:#c7c7c7;box-shadow:0 6px 18px rgba(0,0,0,.06);transform:translateY(-2px);
}
.makito-family-icon{
  flex:0 0 70px;width:70px;height:70px;display:flex;align-items:center;justify-content:center;
  border-radius:999px;background:linear-gradient(180deg,#fff 0%,#f7f7f7 100%);
  border:1px solid rgba(0,0,0,.06);color:var(--ig-blue);
}
.makito-family-icon img{width:42px;height:42px;display:block}
.makito-family-label{
  flex:1 1 auto;display:flex;align-items:center;justify-content:center;
  width:100%;min-height:2.4em;margin-top:.35rem;
  font-size:.6875rem;font-weight:600;line-height:1.2;
  overflow:hidden;
}
.makito-family-count{
  flex:0 0 auto;font-size:.625rem;color:var(--muted);font-weight:500;line-height:1;
  margin-top:.2rem;
}

/* Grille intégrée dans la section #catalogue (accueil) — carrousel horizontal */
.catalogue-cats-wrap .makito-families-carousel{
  position:relative;
  display:flex;align-items:center;gap:.35rem;
  padding:0 1.5rem 2rem;
}
.catalogue-cats-wrap .makito-families-scroll{
  flex:1 1 auto;min-width:0;min-height:198px;
  overflow-x:auto;overflow-y:hidden;
  scroll-snap-type:x mandatory;scroll-behavior:smooth;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:thin;scrollbar-color:rgba(0,0,0,.15) transparent;
  container-type:inline-size;
  container-name:makito-families;
}
.catalogue-cats-wrap .makito-families-scroll::-webkit-scrollbar{height:6px}
.catalogue-cats-wrap .makito-families-scroll::-webkit-scrollbar-thumb{
  background:rgba(0,0,0,.12);border-radius:999px;
}
.catalogue-cats-wrap .makito-families-grid--embed{
  display:flex;flex-wrap:nowrap;gap:.75rem;
  padding:0;margin:0;
  grid-template-columns:none;
}
.catalogue-cats-wrap .makito-families-grid--embed > li{
  flex:0 0 calc(100cqw / 4.5 - 0.55rem);
  min-width:96px;max-width:140px;
  scroll-snap-align:start;
}
.catalogue-cats-wrap .makito-families-grid--embed .makito-family-card{
  background:var(--ig-bg);height:198px;padding:.95rem .55rem .8rem;
}
.catalogue-cats-wrap .makito-families-grid--embed .makito-family-icon{
  flex-basis:86px;width:86px;height:86px;
}
.catalogue-cats-wrap .makito-families-grid--embed .makito-family-icon img{
  width:50px;height:50px;
}
.catalogue-cats-wrap .makito-families-grid--embed .makito-family-label{
  min-height:2.6em;margin-top:.45rem;font-size:.75rem;
}
.makito-families-nav{
  flex:0 0 2rem;width:2rem;height:2rem;padding:0;
  display:inline-flex;align-items:center;justify-content:center;
  border:1px solid var(--border);border-radius:999px;
  background:#fff;color:var(--text);cursor:pointer;
  box-shadow:0 2px 8px rgba(0,0,0,.06);
  transition:opacity .2s,border-color .2s,transform .2s;
}
.makito-families-nav:hover:not(:disabled){
  border-color:var(--ig-blue);color:var(--ig-blue);transform:scale(1.05);
}
.makito-families-nav:disabled{opacity:.35;cursor:default;box-shadow:none}

.makito-family-chips{
  display:flex;flex-wrap:wrap;gap:.45rem;margin:-.25rem 0 1.25rem;
  overflow-x:auto;padding-bottom:.15rem;-webkit-overflow-scrolling:touch;
}
.makito-family-chip{
  display:inline-flex;align-items:center;gap:.35rem;flex:0 0 auto;
  padding:.4rem .7rem;border-radius:999px;font-size:.6875rem;font-weight:600;
  background:var(--ig-surface);border:1px solid var(--border);color:var(--muted);
  text-decoration:none;white-space:nowrap;transition:all .2s;
}
.makito-family-chip img{opacity:.85}
.makito-family-chip:hover,.makito-family-chip.is-active{
  border-color:var(--ig-blue);color:var(--ig-blue);background:rgba(0,149,246,.06);
}

.makito-count{font-size:.8125rem;color:var(--muted);margin:0 0 1.25rem}
.makito-empty{
  text-align:center;padding:3rem 1.5rem;color:var(--muted);
  background:var(--ig-surface);border:1px solid var(--border);border-radius:12px;
}

.makito-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem;
}
.makito-card{
  display:flex;flex-direction:column;
  background:var(--ig-surface);border:1px solid var(--border);border-radius:14px;
  overflow:hidden;transition:border-color .2s,box-shadow .2s,transform .2s;
}
.makito-card:hover{
  border-color:#c7c7c7;box-shadow:0 8px 24px rgba(0,0,0,.06);transform:translateY(-2px);
}
.makito-card-link{
  display:flex;flex-direction:column;flex:1;color:inherit;text-decoration:none;
}
.makito-card-link:hover .makito-card-title{color:var(--ig-blue)}
.makito-card-footer{padding:0 1rem 1rem}
.makito-card-media{
  position:relative;aspect-ratio:1;background:#fff;
  display:flex;align-items:center;justify-content:center;overflow:hidden;
}
.makito-card-media img{width:100%;height:100%;object-fit:contain;padding:.75rem}
.makito-card-placeholder{width:100%;height:100%;background:linear-gradient(135deg,var(--ig-bg),#efefef)}
.makito-stock{
  position:absolute;top:.55rem;right:.55rem;
  font-size:.625rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;
  padding:.25rem .45rem;border-radius:999px;
}
.makito-stock.in-stock{background:rgba(88,195,34,.12);color:#3d9418}
.makito-stock.out-stock{background:rgba(115,115,115,.12);color:#737373}

.makito-card-body{padding:1rem;display:flex;flex-direction:column;gap:.35rem;flex:1}
.makito-card-ref{font-size:.6875rem;font-weight:600;color:var(--ig-blue);letter-spacing:.04em;text-transform:uppercase;margin:0}
.makito-card-title{font-size:.9375rem;font-weight:600;line-height:1.3;margin:0;color:var(--text)}
.makito-card-cat{font-size:.75rem;color:var(--muted);margin:0}
.makito-card-print{font-size:.6875rem;color:var(--muted);margin:0;line-height:1.35}
.makito-card-cta{
  display:block;
  font-size:.8125rem;font-weight:600;color:var(--ig-blue)!important;
}
.makito-card-cta:hover{opacity:.75}

/* Fiche produit */
.makito-breadcrumb{
  display:flex;flex-wrap:wrap;align-items:center;gap:.35rem .5rem;
  font-size:.8125rem;color:var(--muted);margin-bottom:1.5rem;
}
.makito-breadcrumb a{color:var(--ig-blue);font-weight:600}
.makito-product{
  display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.1fr);gap:2rem;align-items:start;
}
.makito-product-main-image{
  position:relative;aspect-ratio:1;background:#fff;border:1px solid var(--border);
  border-radius:14px;display:flex;align-items:center;justify-content:center;overflow:hidden;
}
.makito-product-main-image img{width:100%;height:100%;object-fit:contain;padding:1rem}
.makito-product-thumbs{
  display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.75rem;
}
.makito-product-thumb{
  width:64px;height:64px;padding:0;border:1px solid var(--border);border-radius:8px;
  background:#fff;cursor:pointer;overflow:hidden;
}
.makito-product-thumb img{width:100%;height:100%;object-fit:contain}
.makito-product-title{
  font-size:clamp(1.5rem,3vw,2rem);font-weight:600;line-height:1.15;
  letter-spacing:-.03em;margin:.25rem 0 .5rem;
}
.makito-product-cat{font-size:.875rem;color:var(--muted);margin:0 0 1rem}
.makito-product-desc{
  font-size:.9375rem;line-height:1.6;color:var(--text);margin-bottom:1.25rem;
}
.makito-product-desc p{margin:0 0 .75rem}
.makito-product-specs{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.65rem;
  margin:0 0 1.25rem;padding:1rem;background:var(--ig-surface);
  border:1px solid var(--border);border-radius:12px;
}
.makito-product-specs div{display:flex;flex-direction:column;gap:.15rem}
.makito-product-specs dt{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}
.makito-product-specs dd{margin:0;font-size:.875rem;font-weight:600}
.makito-product-variants{margin-bottom:1.25rem}
.makito-product-variants h2{font-size:.875rem;font-weight:600;margin:0 0 .65rem}
.makito-product-variants ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}
.makito-product-variants li{
  display:flex;align-items:center;gap:.65rem;font-size:.8125rem;
  padding:.5rem .65rem;background:var(--ig-surface);border:1px solid var(--border);border-radius:10px;
}
.makito-product-variants li img{border-radius:6px;object-fit:contain;background:#fff}
.makito-variant-stock{font-size:.6875rem;font-weight:700;text-transform:uppercase;margin-left:auto}
.makito-variant-stock.in{color:#3d9418}
.makito-variant-stock.out{color:#737373}
.makito-product-cta{
  display:inline-flex;align-items:center;justify-content:center;
  padding:.75rem 1.35rem;border-radius:999px;
  background:var(--ig-blue);color:#fff!important;font-weight:600;font-size:.875rem;
  text-decoration:none;border:none;cursor:pointer;
  box-shadow:0 2px 10px rgba(0,149,246,.28);
  transition:background .2s,transform .2s cubic-bezier(.22,1,.36,1),box-shadow .2s;
}
.makito-product-cta:hover{
  background:var(--ig-blue-hover);
  transform:translateY(-1px);
  box-shadow:0 4px 14px rgba(0,149,246,.32);
}
.makito-product-cta:focus-visible{
  outline:2px solid rgba(0,149,246,.45);
  outline-offset:2px;
}
.makito-product-cta.shimmer-btn::after{display:none}
.makito-product-note{font-size:.75rem;color:var(--muted);margin:.75rem 0 0;line-height:1.45}

.makito-pagination{
  display:flex;align-items:center;justify-content:center;gap:1rem;
  margin-top:2rem;font-size:.875rem;font-weight:600;
}
.makito-pagination a{color:var(--ig-blue)}
.makito-pagination span{color:var(--muted)}

.visually-hidden{
  position:absolute;width:1px;height:1px;padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;
}

@media (max-width:1024px){
  .makito-families-grid{grid-template-columns:repeat(6,minmax(0,1fr))}
}
@media (max-width:768px){
  .makito-page{padding:calc(64px + 1.25rem) 1rem 2.5rem}
  .makito-families-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:.65rem}
  .makito-family-card{height:136px;padding:.65rem .35rem .55rem}
  .makito-family-icon{flex-basis:58px;width:58px;height:58px}
  .makito-family-icon img{width:34px;height:34px}
  .makito-family-label{font-size:.625rem;min-height:2.2em}
  .makito-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem}
  .makito-product{grid-template-columns:1fr;gap:1.25rem}
}

@media (max-width:480px){
  .makito-grid{grid-template-columns:1fr}
  .makito-families-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
  .makito-family-card{height:128px}
}
