/* =========================================================
   Catalogo prodotti — design 2026
   ========================================================= */

/* HERO */
.cat-hero{
  background:linear-gradient(135deg,#fff5e8 0%,#ffe2b8 60%,#ffd29a 100%);
  padding:36px 0 30px;border-bottom:1px solid var(--c-border);
  position:relative;overflow:hidden
}
.cat-hero::before{content:'';position:absolute;top:-180px;right:-120px;width:420px;height:420px;background:radial-gradient(circle,rgba(255,213,74,.45),transparent 65%);border-radius:50%;pointer-events:none}
.cat-hero::after{content:'';position:absolute;bottom:-150px;left:-100px;width:360px;height:360px;background:radial-gradient(circle,rgba(255,122,0,.18),transparent 65%);border-radius:50%;pointer-events:none}
.cat-hero .container{position:relative;z-index:1}
.cat-hero-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:30px;align-items:end}
.cat-hero h1{margin:6px 0 4px;font-size:clamp(24px,3.4vw,38px)}
.cat-hero .lead{margin:0;font-size:16px;color:#3f3a31}
.cat-hero .breadcrumb{font-size:13px;color:#6b5d3d;margin-bottom:6px}
.cat-hero .breadcrumb a{color:var(--c-primary-dark)}
.cat-search-wrap{display:flex;background:#fff;padding:6px;border-radius:40px;box-shadow:0 10px 30px rgba(255,122,0,.15);align-items:center;gap:6px}
.cat-search-icon{padding-left:14px;font-size:18px;color:var(--c-primary)}
.cat-search-wrap input{flex:1;border:0;outline:0;padding:10px 8px;font-size:15px;background:transparent;min-width:0}
.cat-search-wrap .btn{padding:10px 22px;font-size:14px;border-radius:30px}

/* Active filters bar */
.cat-active{padding:14px 18px;display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:13px}
.cat-active strong{color:#374151;margin-right:4px}
.cat-chip{display:inline-flex;align-items:center;gap:6px;background:#fff5e8;color:var(--c-primary-dark);padding:6px 12px;border-radius:30px;text-decoration:none;border:1px solid #ffd6a8;font-weight:600;font-size:13px;transition:.15s}
.cat-chip:hover{background:#ffd29a;text-decoration:none}
.cat-chip span{font-size:16px;line-height:1;opacity:.7;font-weight:700}
.cat-chip-clear{background:#fee;color:#c00;padding:6px 12px;border-radius:30px;border:1px solid #fcc;font-weight:600;font-size:13px;text-decoration:none}
.cat-chip-clear:hover{background:#fdd;text-decoration:none}

/* Layout principale */
.cat-main{display:grid;grid-template-columns:260px 1fr;gap:24px;padding:22px 18px 60px;position:relative}

/* Sidebar */
.cat-sidebar{background:#fff;border:1px solid var(--c-border);border-radius:14px;padding:18px;align-self:start;position:sticky;top:90px;max-height:calc(100vh - 110px);overflow-y:auto;box-shadow:0 4px 16px rgba(0,0,0,.04)}
.cat-sidebar::-webkit-scrollbar{width:6px}
.cat-sidebar::-webkit-scrollbar-thumb{background:#ddd;border-radius:6px}
.cat-sidebar-close{display:none;position:absolute;top:10px;right:12px;background:none;border:0;font-size:28px;cursor:pointer;color:#666;width:36px;height:36px;line-height:1}
.cat-filter-form{display:flex;flex-direction:column;gap:6px}
.cat-filter-block{padding:10px 0;border-bottom:1px solid #f0eee5}
.cat-filter-block:last-of-type{border-bottom:0}
.cat-filter-block h4{margin:0 0 10px;font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:#374151}
.cat-filter-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:2px;max-height:280px;overflow-y:auto}
.cat-filter-list a{display:flex;justify-content:space-between;align-items:center;padding:7px 10px;border-radius:8px;font-size:13px;color:#374151;text-decoration:none;transition:.12s}
.cat-filter-list a:hover{background:#fff5e8;color:var(--c-primary-dark);text-decoration:none}
.cat-filter-list a.active{background:var(--c-primary);color:#fff;font-weight:700}
.cat-filter-list a.active .n{background:rgba(255,255,255,.25);color:#fff}
.cat-filter-list .n{background:#f3f4f6;color:#666;padding:1px 8px;border-radius:10px;font-size:11px;font-weight:600;min-width:24px;text-align:center}
.cat-brands{max-height:260px}

/* Range prezzo */
.cat-price-row{display:flex;gap:6px;align-items:center;margin-bottom:8px}
.cat-price-row input{flex:1;width:100%;border:1px solid var(--c-border);border-radius:8px;padding:8px 10px;font-size:13px;outline:0;background:#faf8f4;min-width:0}
.cat-price-row input:focus{border-color:var(--c-primary);background:#fff}
.cat-price-row span{color:#999;font-size:12px}
.cat-price-quick{display:flex;flex-wrap:wrap;gap:4px}
.cat-price-quick a{padding:5px 10px;background:#f3f4f6;border-radius:14px;font-size:12px;color:#374151;text-decoration:none;transition:.12s}
.cat-price-quick a:hover{background:#fff5e8;color:var(--c-primary-dark);text-decoration:none}
.cat-price-quick a.active{background:var(--c-primary);color:#fff;font-weight:600}

/* Sconto grid */
.cat-disc-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}
.cat-disc-grid a{padding:8px 6px;border:1.5px solid var(--c-border);border-radius:10px;font-size:13px;font-weight:600;text-align:center;color:#374151;text-decoration:none;background:#faf8f4;transition:.12s}
.cat-disc-grid a:hover{border-color:var(--c-primary);color:var(--c-primary-dark);background:#fff;text-decoration:none}
.cat-disc-grid a.active{background:var(--c-primary);color:#fff;border-color:var(--c-primary)}

/* Risultati */
.cat-results{min-width:0}
.cat-toolbar{display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap;background:#fff;border:1px solid var(--c-border);border-radius:14px;padding:14px 18px;margin-bottom:18px;box-shadow:0 2px 8px rgba(0,0,0,.03)}
.cat-count{font-size:14px;color:#374151;font-weight:600}
.cat-count strong{color:var(--c-primary-dark)}
.cat-sort{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.cat-sort label{font-size:13px;color:#6b7280;font-weight:500}
.cat-sort-pills{display:flex;gap:4px;flex-wrap:wrap}
.cat-sort-pills a{padding:6px 12px;font-size:12px;font-weight:600;border-radius:14px;background:#f3f4f6;color:#374151;text-decoration:none;transition:.12s;white-space:nowrap}
.cat-sort-pills a:hover{background:#fff5e8;color:var(--c-primary-dark);text-decoration:none}
.cat-sort-pills a.active{background:var(--c-primary);color:#fff}

/* Grid prodotti */
.cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:18px}
.cat-card{background:#fff;border:1px solid var(--c-border);border-radius:14px;overflow:hidden;text-decoration:none;color:inherit;transition:.2s ease;display:flex;flex-direction:column;position:relative;box-shadow:0 2px 6px rgba(0,0,0,.03)}
.cat-card:hover{transform:translateY(-4px);box-shadow:0 14px 40px rgba(255,122,0,.18);border-color:#ffd6a8;text-decoration:none}
.cat-card-hot{box-shadow:0 4px 16px rgba(220,38,38,.10);border-color:#fecaca}
.cat-card-hot:hover{box-shadow:0 14px 40px rgba(220,38,38,.22)}
.cat-card-img{position:relative;background:linear-gradient(135deg,#fff8f0,#fff1e0);aspect-ratio:1/1;display:flex;align-items:center;justify-content:center;overflow:hidden}
.cat-card-img img{max-width:90%;max-height:90%;object-fit:contain;transition:transform .35s}
.cat-card:hover .cat-card-img img{transform:scale(1.06)}
.cat-card-img img.cat-card-fallback{opacity:.4;max-width:55%}
.cat-card-noimg{font-size:24px;font-weight:900;color:var(--c-primary);text-align:center;padding:18px;line-height:1.2}
.cat-badge{position:absolute;top:10px;font-weight:800;font-size:12px;padding:4px 10px;border-radius:20px;letter-spacing:.3px;box-shadow:0 4px 10px rgba(0,0,0,.18)}
.cat-badge-disc{right:10px;background:linear-gradient(135deg,#dc2626,#ea580c);color:#fff}
.cat-badge-new{left:10px;background:#16a34a;color:#fff;font-size:11px;padding:4px 9px}
.cat-badge-hot{left:10px;background:linear-gradient(135deg,#f59e0b,#dc2626);color:#fff;font-size:11px}
.cat-card-body{padding:14px;flex:1;display:flex;flex-direction:column;gap:6px}
.cat-card-brand{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--c-primary-dark);font-weight:700}
.cat-card-title{font-size:14px;font-weight:600;line-height:1.35;margin:0;color:#0f172a;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:2.7em}
.cat-card-foot{margin-top:auto;display:flex;justify-content:space-between;align-items:flex-end;gap:8px;padding-top:8px;border-top:1px dashed #f0eee5}
.cat-card-prices{display:flex;flex-direction:column;gap:1px;line-height:1.1}
.cat-card-price{color:var(--c-primary);font-size:18px;font-weight:800}
.cat-card-old{color:#999;font-size:12px;text-decoration:line-through}
.cat-card-cta{font-size:13px;font-weight:700;color:var(--c-primary-dark);background:#fff5e8;padding:6px 12px;border-radius:14px;white-space:nowrap;transition:.15s}
.cat-card:hover .cat-card-cta{background:var(--c-primary);color:#fff}

/* Pagination */
.cat-pagination{display:flex;justify-content:center;align-items:center;gap:6px;margin:30px 0;flex-wrap:wrap}
.cat-pagination a,.cat-pagination .cat-page-cur{display:inline-flex;align-items:center;justify-content:center;min-width:40px;height:40px;padding:0 14px;border-radius:10px;background:#fff;border:1.5px solid var(--c-border);color:#374151;font-weight:600;text-decoration:none;font-size:14px;transition:.12s}
.cat-pagination a:hover{background:#fff5e8;border-color:var(--c-primary-light);color:var(--c-primary-dark);text-decoration:none}
.cat-pagination .cat-page-cur{background:var(--c-primary);border-color:var(--c-primary);color:#fff}
.cat-pagination .cat-page-prev,.cat-pagination .cat-page-next{font-weight:700}
.cat-pagination .cat-ellip{color:#9ca3af;padding:0 4px}

/* Empty */
.cat-empty{background:#fff;border:1px solid var(--c-border);border-radius:14px;padding:60px 30px;text-align:center;color:#6b7280}
.cat-empty .icon{font-size:48px;margin-bottom:12px}
.cat-empty h3{margin:0 0 8px;color:#374151}
.cat-empty .btn{margin-top:12px}

/* Mobile drawer toggle */
.cat-mobile-toggle{display:none;align-items:center;gap:8px;background:var(--c-primary);color:#fff;border:0;padding:12px 18px;border-radius:30px;font-weight:700;cursor:pointer;font-size:14px;margin-bottom:14px;box-shadow:0 4px 12px rgba(255,122,0,.3);position:relative}
.cat-mobile-pill{background:rgba(255,255,255,.3);padding:1px 8px;border-radius:10px;font-size:12px;margin-left:4px}

/* Responsive */
@media(max-width:1000px){
  .cat-hero-grid{grid-template-columns:1fr;gap:18px}
  .cat-main{grid-template-columns:240px 1fr;gap:18px}
}
@media(max-width:760px){
  .cat-hero{padding:24px 0 22px}
  .cat-main{grid-template-columns:1fr;padding:14px 14px 40px}
  .cat-mobile-toggle{display:inline-flex}
  .cat-sidebar{position:fixed;top:0;left:-110%;height:100vh;max-height:100vh;width:90vw;max-width:340px;border-radius:0 18px 18px 0;z-index:200;transition:left .25s ease;box-shadow:0 0 60px rgba(0,0,0,.3);padding-top:50px}
  .cat-sidebar-open{left:0}
  .cat-sidebar-close{display:flex;align-items:center;justify-content:center}
  body.cat-sidebar-bodylock{overflow:hidden}
  body.cat-sidebar-bodylock::after{content:'';position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:150}
  .cat-toolbar{padding:12px 14px;flex-direction:column;align-items:flex-start}
  .cat-sort{width:100%}
  .cat-sort-pills{width:100%;overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch;padding-bottom:4px}
  .cat-sort-pills::-webkit-scrollbar{height:4px}
  .cat-grid{grid-template-columns:repeat(2,1fr);gap:12px}
  .cat-card-body{padding:10px}
  .cat-card-title{font-size:13px}
  .cat-card-price{font-size:16px}
  .cat-card-cta{padding:5px 10px;font-size:12px}
  .cat-active{padding:10px 14px}
}
@media(max-width:380px){
  .cat-grid{grid-template-columns:1fr}
}
