
:root {
  --cyan:    #00AEEF;
  --magenta: #EC008C;
  --yellow:  #FFF200;
  --black:   #1a1a1a;
  --white:   #ffffff;
  --off:     #F8F8F6;
  --light:   #F2F9FD;
  --gris:    #7a7a7a;
  --gris-c:  #e4e4e0;
  --cyan-d:  #0087c0;
  --mag-d:   #c00070;
  --green:   #27ae60;
  --orange:  #f39c12;
  --red:     #e74c3c;
  --sidebar-w: 272px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'DM Sans',sans-serif;background:var(--white);color:var(--black);overflow-x:hidden;cursor:none}

/* CURSOR */
.cursor{width:12px;height:12px;background:var(--cyan);border-radius:50%;position:fixed;top:0;left:0;pointer-events:none;z-index:9999;transition:transform .15s,background .2s;mix-blend-mode:multiply}
.cursor-ring{width:38px;height:38px;border:1.5px solid var(--magenta);border-radius:50%;position:fixed;top:0;left:0;pointer-events:none;z-index:9998;transition:all .3s;opacity:.5}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:200;display:flex;align-items:center;justify-content:space-between;padding:0 60px;height:72px;background:rgba(255,255,255,.97);backdrop-filter:blur(16px);border-bottom:3px solid transparent;border-image:linear-gradient(90deg,var(--cyan),var(--magenta),var(--yellow)) 1}
.logo-wrap { display:flex; align-items:center; text-decoration:none; flex-shrink:0; }
.logo-img { height:65px; width:auto; display:block; object-fit:contain; }
.nav-links{display:flex;gap:32px;list-style:none}
.nav-links a{font-size:12px;font-weight:500;letter-spacing:.06em;text-transform:uppercase;color:var(--black);text-decoration:none;transition:color .3s;position:relative;padding-bottom:4px}
.nav-links a::after{content:'';position:absolute;bottom:0;left:0;width:0;height:2px;background:var(--cyan);transition:width .3s}
.nav-links a:hover,.nav-links a.active{color:var(--cyan)}
.nav-links a.active::after,.nav-links a:hover::after{width:100%}
.nav-actions{display:flex;align-items:center;gap:14px}
.nav-sw{position:relative}
.nav-search{background:var(--light);border:1.5px solid transparent;border-radius:24px;padding:8px 18px 8px 34px;font-family:'DM Sans',sans-serif;font-size:13px;color:var(--gris);width:200px;transition:all .3s;outline:none}
.nav-search:focus{border-color:var(--cyan);background:white;width:240px}
.si{position:absolute;left:11px;top:50%;transform:translateY(-50%);font-size:13px;pointer-events:none}
.btn-cart{display:flex;align-items:center;gap:8px;background:var(--cyan);color:white;border:none;padding:10px 20px;border-radius:24px;font-family:'DM Sans',sans-serif;font-size:12px;font-weight:600;letter-spacing:.06em;cursor:none;transition:all .3s;position:relative}
.btn-cart:hover{background:var(--cyan-d);transform:translateY(-1px);box-shadow:0 6px 20px rgba(0,174,239,.3)}
.cart-badge{background:var(--magenta);color:white;font-size:9px;width:17px;height:17px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700}

/* BREADCRUMB */
.breadcrumb{margin-top:72px;padding:14px 60px;display:flex;align-items:center;gap:8px;background:var(--off);border-bottom:1px solid var(--gris-c)}
.breadcrumb a{font-size:12px;color:var(--gris);text-decoration:none;transition:color .2s;cursor:none}
.breadcrumb a:hover{color:var(--cyan)}
.breadcrumb span{font-size:12px;color:var(--gris-c)}
.breadcrumb .cur{font-size:12px;color:var(--black);font-weight:500}

/* CAT HEADER */
.cat-header{
  background:var(--black);
  padding:52px 60px 44px;
  display:flex;align-items:flex-end;justify-content:space-between;gap:40px;
  position:relative;overflow:hidden;
}
.cat-header::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(ellipse 500px 400px at 0% 50%,rgba(0,174,239,.1) 0%,transparent 60%),
    radial-gradient(ellipse 300px 300px at 100% 80%,rgba(236,0,140,.07) 0%,transparent 60%);
}
/* CMYK stripe top */
.cat-header::after{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--cyan) 0%,var(--cyan) 33%,var(--magenta) 33%,var(--magenta) 66%,var(--yellow) 66%,var(--yellow) 100%)}

.ch-left{position:relative;z-index:1}
.ch-tag{font-size:11px;letter-spacing:.25em;text-transform:uppercase;color:var(--cyan);margin-bottom:12px}
.ch-title{font-family:'Cormorant Garamond',serif;font-size:clamp(32px,4vw,50px);font-weight:300;color:white;line-height:1.05}
.ch-title em{font-style:italic;color:var(--magenta)}
.ch-count{font-size:13px;color:rgba(255,255,255,.35);margin-top:8px}

.ch-pills{display:flex;gap:8px;flex-wrap:wrap;align-items:flex-end;position:relative;z-index:1}
.type-pill{
  background:rgba(255,255,255,.06);border:1.5px solid rgba(255,255,255,.12);
  padding:9px 20px;font-size:12px;font-weight:500;letter-spacing:.06em;
  color:rgba(255,255,255,.65);cursor:none;transition:all .3s;border-radius:24px;white-space:nowrap;
}
.type-pill:hover,.type-pill.active{background:var(--cyan);border-color:var(--cyan);color:white}
.type-pill.active-m{background:var(--magenta);border-color:var(--magenta);color:white}

/* LAYOUT */
.catalogue-layout{
  display:grid;
  grid-template-columns:var(--sidebar-w) 1fr;
  align-items:start;
  position:relative;
}

/* SIDEBAR */
.sidebar{
  background:white;
  border-right:1px solid var(--gris-c);
  padding:32px 28px;
  position:sticky;
  top:72px;
  max-height:calc(100vh - 72px);
  height:auto;
  overflow-y:auto;
  scrollbar-width:thin;
  scrollbar-color:var(--gris-c) transparent;
  align-self:start;
}
.sidebar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:28px;padding-bottom:20px;border-bottom:1px solid var(--gris-c)}
.sidebar-title{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--cyan);font-weight:600}
.clear-btn{font-size:12px;color:var(--gris);text-decoration:underline;cursor:none;border:none;background:none;font-family:'DM Sans',sans-serif;transition:color .2s}
.clear-btn:hover{color:var(--red)}

.filter-group{margin-bottom:30px}
.fg-head{
  display:flex;justify-content:space-between;align-items:center;
  font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--black);font-weight:600;
  margin-bottom:14px;cursor:none;
}
.fg-toggle{color:var(--gris);font-size:14px;transition:transform .3s}
.fg-toggle.closed{transform:rotate(-90deg)}

.f-search{width:100%;padding:8px 12px;border:1.5px solid var(--gris-c);background:var(--off);font-family:'DM Sans',sans-serif;font-size:13px;outline:none;border-radius:24px;margin-bottom:12px;transition:border-color .3s}
.f-search:focus{border-color:var(--cyan)}

.f-options{display:flex;flex-direction:column;gap:9px}
.f-opt{display:flex;align-items:center;gap:10px;cursor:none;padding:3px 0}
.f-box{width:17px;height:17px;border:2px solid var(--gris-c);border-radius:3px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s}
.f-opt.on .f-box{background:var(--cyan);border-color:var(--cyan)}
.f-opt.on .f-box::after{content:'';font-size:10px;color:white;font-weight:700}
.f-label{font-size:13px;color:#444;transition:color .2s;flex:1}
.f-opt:hover .f-label{color:var(--cyan)}
.f-num{font-size:11px;color:var(--gris);background:var(--off);padding:2px 7px;border-radius:24px}

/* Color dots */
.color-filters{display:flex;flex-wrap:wrap;gap:10px}
.cf-item{display:flex;flex-direction:column;align-items:center;gap:4px;cursor:none}
.cf-dot{width:30px;height:30px;border-radius:50%;border:2px solid transparent;transition:all .2s}
.cf-dot.on{border-color:var(--cyan);box-shadow:0 0 0 3px rgba(0,174,239,.2)}
.cf-dot:hover{transform:scale(1.1)}
.cf-label{font-size:9px;color:var(--gris);text-align:center}

/* Price range */
.price-track{position:relative;height:4px;background:var(--gris-c);margin:18px 0 10px;border-radius:2px}
.price-fill{position:absolute;height:100%;background:linear-gradient(90deg,var(--cyan),var(--magenta));left:10%;right:30%;border-radius:2px}
.price-handle{position:absolute;width:16px;height:16px;background:white;border:2.5px solid var(--cyan);border-radius:50%;top:-6px;cursor:none;transition:transform .2s;box-shadow:0 2px 8px rgba(0,0,0,.15)}
.price-handle:hover{transform:scale(1.3)}
.ph-l{left:calc(10% - 8px)}
.ph-r{left:calc(70% - 8px)}
.price-labels{display:flex;justify-content:space-between;font-size:12px;color:var(--gris)}

/* Sidebar divider */
.s-divider{height:1px;background:var(--gris-c);margin:4px 0 20px}

/* PRODUCTS AREA */
.products-area{padding:28px 44px}

/* Toolbar */
.toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;padding-bottom:20px;border-bottom:1px solid var(--gris-c)}
.toolbar-left{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.active-tags{display:flex;gap:6px;flex-wrap:wrap}
.a-tag{
  display:flex;align-items:center;gap:5px;
  background:var(--black);color:white;
  padding:5px 12px;border-radius:24px;
  font-size:11px;font-weight:500;cursor:none;transition:background .2s;
}
.a-tag:hover{background:var(--red)}
.a-tag .x{font-size:14px;line-height:1;margin-left:2px}
.results-count{font-size:13px;color:var(--gris)}

.toolbar-right{display:flex;align-items:center;gap:16px}
.sort-wrap{position:relative}
.sort-wrap::after{content:'';position:absolute;right:12px;top:50%;transform:translateY(-50%);font-size:11px;color:var(--gris);pointer-events:none}
.sort-sel{
  border:1.5px solid var(--gris-c);background:white;
  padding:9px 32px 9px 14px;
  font-family:'DM Sans',sans-serif;font-size:13px;color:var(--black);
  cursor:none;appearance:none;outline:none;border-radius:24px;transition:border-color .2s;
}
.sort-sel:focus{border-color:var(--cyan)}

.view-btns{display:flex;gap:3px}
.vb{width:34px;height:34px;border:1.5px solid var(--gris-c);background:white;display:flex;align-items:center;justify-content:center;cursor:none;transition:all .2s;border-radius:6px}
.vb.on,.vb:hover{background:var(--cyan);border-color:var(--cyan)}
.vb svg{pointer-events:none}

/* PRODUCTS GRID */
.products-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:3px;margin-bottom:40px}

/* Product card */
.pc{background:white;border:1px solid var(--gris-c);position:relative;overflow:hidden;cursor:none;transition:transform .3s,box-shadow .3s,border-color .3s}
.pc:hover{transform:translateY(-5px);box-shadow:0 16px 44px rgba(0,0,0,.1);border-color:var(--cyan)}

/* Color stripe top on hover */
.pc::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--cyan),var(--magenta));transform:scaleX(0);transform-origin:left;transition:transform .3s;z-index:2}
.pc:hover::before{transform:scaleX(1)}

.pc-img{height:220px;background:var(--off);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.pc-img img{width:100%;height:100%;object-fit:contain;padding:12px;transition:transform .4s ease}
.pc:hover .pc-img img{transform:scale(1.06)}

/* Cartridge illustration */
.cart-mini{display:flex;flex-direction:column;align-items:center;transition:transform .4s ease}
.pc:hover .cart-mini{transform:scale(1.1) translateY(-6px)}
.cm-chip-bar{width:68px;height:4px;border-radius:2px 2px 0 0}
.cm-top{width:52px;height:10px;border-radius:3px 3px 0 0}
.cm-body{width:72px;height:72px;border-radius:5px;display:flex;align-items:center;justify-content:center;position:relative}
.cm-label{background:rgba(255,255,255,.18);padding:3px 10px;border-radius:2px;font-size:10px;font-weight:700;color:rgba(255,255,255,.9);letter-spacing:.06em}
.cm-nozzle{width:72px;height:9px;border-radius:0 0 4px 4px;filter:brightness(.6)}
.cm-drips{display:flex;gap:7px;margin-top:1px}
.cm-drip{width:6px;border-radius:0 0 50% 50%;animation:dripAnim 3s ease-in-out infinite}
.cm-drip-c{background:var(--cyan);height:14px}
.cm-drip-m{background:var(--magenta);height:10px;animation-delay:.6s}
.cm-drip-y{background:var(--yellow);height:16px;animation-delay:1.2s}
.cm-drip-k{background:#444;height:8px;animation-delay:1.8s}
@keyframes dripAnim{0%,100%{transform:scaleY(1)}50%{transform:scaleY(1.3)}}

.pc-badge{position:absolute;top:12px;left:12px;font-size:9px;letter-spacing:.1em;text-transform:uppercase;padding:4px 10px;color:white;border-radius:24px;z-index:3}
.b-best{background:var(--cyan)}
.b-new{background:var(--magenta)}
.b-eco{background:var(--green)}
.b-promo{background:var(--red)}
.b-pro{background:var(--black)}

.pc-wish{position:absolute;top:12px;right:12px;width:30px;height:30px;background:white;border:1px solid var(--gris-c);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;opacity:0;transition:opacity .3s;cursor:none;z-index:3}
.pc:hover .pc-wish{opacity:1}
.pc-wish:hover{background:#fff0f5;border-color:var(--red);color:var(--red)}

.pc-add{position:absolute;bottom:-42px;left:0;right:0;background:var(--magenta);color:white;text-align:center;padding:12px;font-size:11px;letter-spacing:.1em;text-transform:uppercase;transition:bottom .3s;z-index:3}
.pc:hover .pc-add{bottom:0}
.pc-add:hover{background:var(--mag-d)}

.pc-info{padding:16px 18px 18px}
.pc-compat{font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--gris);margin-bottom:4px}
.pc-name{font-family:'Cormorant Garamond',serif;font-size:17px;font-weight:400;margin-bottom:8px;line-height:1.2}
.pc-colors{display:flex;gap:5px;margin-bottom:10px}
.pc-color{width:11px;height:11px;border-radius:50%;border:1.5px solid rgba(0,0,0,.1)}
.pc-bottom{display:flex;align-items:flex-end;justify-content:space-between}
.pc-price{font-size:18px;font-weight:600}
.pc-old{font-size:12px;color:var(--gris);text-decoration:line-through;margin-left:6px}
.pc-promo{font-size:11px;color:var(--red);font-weight:600;margin-left:4px}
.pc-stars{display:flex;gap:2px}
.pc-star{color:var(--cyan);font-size:11px}
.pc-star-e{color:var(--gris-c);font-size:11px}
.pc-stock{display:flex;align-items:center;gap:5px;margin-top:8px;font-size:11px;color:var(--gris)}
.s-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}

/* In-grid banner */
.grid-banner{
  grid-column:1/-1;
  background:linear-gradient(90deg,var(--black) 0%,#001a2e 100%);
  padding:28px 36px;
  display:flex;align-items:center;justify-content:space-between;gap:24px;
  border-top:3px solid var(--cyan);
  position:relative;overflow:hidden;
}
.grid-banner::before{content:'';position:absolute;top:-80px;right:-80px;width:240px;height:240px;background:radial-gradient(circle,rgba(0,174,239,.12),transparent 70%)}
.gb-text h4{font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:300;color:white;margin-bottom:4px}
.gb-text h4 em{font-style:italic;color:var(--cyan)}
.gb-text p{font-size:12px;color:rgba(255,255,255,.4)}
.gb-btn{background:var(--cyan);color:white;border:none;padding:11px 28px;font-family:'DM Sans',sans-serif;font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;cursor:none;transition:all .2s;border-radius:24px;white-space:nowrap}
.gb-btn:hover{background:var(--cyan-d);transform:translateY(-1px)}

/* LIST VIEW */
.products-grid.list-view{grid-template-columns:1fr}
.products-grid.list-view .pc{display:flex;flex-direction:row;transform:none !important}
.products-grid.list-view .pc:hover{box-shadow:0 4px 20px rgba(0,0,0,.06);transform:none !important}
.products-grid.list-view .pc-img{width:160px;height:160px;aspect-ratio:auto;flex-shrink:0}
.products-grid.list-view .pc-info{flex:1;display:flex;align-items:center;gap:28px;padding:24px}
.products-grid.list-view .pc-main-info{flex:1}
.products-grid.list-view .pc-actions{display:flex;flex-direction:column;align-items:flex-end;gap:10px}
.products-grid.list-view .pc-add{position:static;background:var(--magenta);padding:10px 22px;font-size:11px;letter-spacing:.1em;text-transform:uppercase;cursor:none;border:none;font-family:'DM Sans',sans-serif;color:white;transition:background .2s;border-radius:24px;white-space:nowrap;font-weight:600}
.products-grid.list-view .pc-add:hover{background:var(--mag-d)}
.products-grid.list-view .grid-banner{display:none}

/* PAGINATION */
.pagination{display:flex;align-items:center;justify-content:center;gap:4px;padding:36px 0;border-top:1px solid var(--gris-c)}
.pg-btn{width:38px;height:38px;display:flex;align-items:center;justify-content:center;border:1.5px solid var(--gris-c);background:white;font-size:13px;color:var(--black);cursor:none;transition:all .2s;border-radius:6px}
.pg-btn:hover,.pg-btn.on{background:var(--cyan);border-color:var(--cyan);color:white}
.pg-dots{padding:0 6px;color:var(--gris)}

/* Mobile filter btn */
.mob-filter{display:none;align-items:center;gap:8px;background:var(--black);color:white;border:none;padding:10px 20px;border-radius:24px;font-family:'DM Sans',sans-serif;font-size:12px;font-weight:600;cursor:none;letter-spacing:.06em}

/* REVEAL */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease}
.reveal.visible{opacity:1;transform:translateY(0)}

/* RESPONSIVE */
@media(max-width:960px){
  nav{padding:0 20px}
  .nav-links{display:none}
  .breadcrumb,.cat-header{padding-left:20px;padding-right:20px}
  .catalogue-layout{grid-template-columns:1fr}
  .sidebar{position:fixed;left:-100%;top:0;height:100vh;z-index:300;transition:left .35s cubic-bezier(.4,0,.2,1);box-shadow:4px 0 32px rgba(0,0,0,.15)}
  .sidebar.open{left:0}
  .mob-filter{display:flex}
  .products-area{padding:20px}
  .products-grid{grid-template-columns:1fr 1fr}
  .toolbar-right{gap:10px}
  .cat-header{padding:40px 20px 32px}
  .ch-pills{display:none}
}

  /* Footer address block */
  .footer-address{display:flex;flex-direction:column;gap:10px;margin-bottom:24px}
  .fa-item{display:flex;align-items:flex-start;gap:10px}
  .fa-icon{font-size:15px;flex-shrink:0;margin-top:1px}
  .fa-label{display:block;font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--gris);margin-bottom:2px}
  .fa-val{display:block;font-size:13px;color:rgba(255,255,255,.55);text-decoration:none;transition:color .2s}
  .fa-val:hover{color:var(--cyan)}
  .fa-val-plain{display:block;font-size:13px;color:rgba(255,255,255,.55)}
  .social-btn{text-decoration:none}


  .nav-wa-badge{display:flex;align-items:center;gap:6px;background:#25D366;color:white;padding:7px 14px;border-radius:24px;font-size:11px;font-weight:700;text-decoration:none;letter-spacing:.04em;transition:all .3s;white-space:nowrap}
  .nav-wa-badge:hover{background:#128C7E;transform:translateY(-1px);box-shadow:0 4px 14px rgba(37,211,102,.35)}



/* Fix sidebar debordement */
.catalogue-layout > .sidebar {
  align-self: start;
}
.cat-main {
  min-height: 400px;
}
