/* K-Promo — Design System
   Brand: yellow #FFCF02 + ink #0A0A0A. Type: Futura PT (brand).
   Grid: 1240 container, 12 cols, gap 24, base unit 8.
*/

@font-face{font-family:"Futura PT";src:url("../fonts/futurapt-book.woff2") format("woff2");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"Futura PT";src:url("../fonts/futurapt-medium.woff2") format("woff2");font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:"Futura PT";src:url("../fonts/futurapt-demi.woff2") format("woff2");font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:"Futura PT";src:url("../fonts/futurapt-bold.woff2") format("woff2");font-weight:700 900;font-style:normal;font-display:swap}

:root{
  --yellow:#FFCF02;
  --yellow-hover:#FFD933;
  --yellow-soft:#FFF4B8;
  --ink:#0A0A0A;
  --ink-2:#3D3D3D;
  --ink-3:#8A8A8A;
  --line:#E5E5E5;
  --fog:#F7F7F7;
  --paper:#FFFFFF;
  --eco:#7CB342;
  --hot:#E74C3C;
  --radius:12px;
  --radius-sm:8px;
  --radius-lg:16px;
  --container:1240px;
  --gutter:24px;
  --shadow-card:0 8px 24px rgba(0,0,0,.07);
  --shadow-soft:0 2px 8px rgba(0,0,0,.04);
}

/* Базовый ресет применяется только внутри .kp-page для изоляции от WoodMart */
.kp-page *{box-sizing:border-box}
.kp-page{
  font-family:"Futura PT","Helvetica Neue",Helvetica,Arial,sans-serif;
  font-weight:400;font-size:16px;line-height:1.55;color:var(--ink);
  font-feature-settings:"ss01","cv11";
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
.kp-page img,.kp-page svg{display:block}
.kp-page a{color:inherit;text-decoration:none}
.kp-page button{font:inherit;color:inherit;background:none;border:0;cursor:pointer;padding:0}
.kp-page ul{list-style:none;margin:0;padding:0}

.kp-container{max-width:var(--container);margin:0 auto;padding:0 20px}

/* ───────── Top bar ───────── */
.kp-topbar{background:var(--ink);color:#FFFFFF;font-size:15px;line-height:1}
.kp-topbar-row{display:flex;justify-content:space-between;align-items:center;min-height:44px;padding:8px 20px}
.kp-topbar-left,.kp-topbar-right{display:flex;gap:24px;align-items:center;line-height:1}
.kp-tb-msgs{display:inline-flex;gap:8px;align-items:center;height:100%}
.kp-tb-msg{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;
  transition:transform .15s,filter .15s;line-height:0;vertical-align:middle}
.kp-tb-msg img{width:22px;height:22px;display:block;object-fit:contain}
.kp-tb-msg:hover{transform:translateY(-1px) scale(1.08)}
.kp-tb-item{display:inline-flex;gap:8px;align-items:center;color:rgba(255,255,255,.78);
  letter-spacing:normal;transition:color .15s}
.kp-tb-item:hover{color:#fff}
.kp-tb-item svg{stroke:rgba(255,255,255,.7)}

/* ───────── Logo ───────── */
.kp-logo{display:inline-flex;align-items:center;gap:10px;line-height:1;color:var(--ink);text-decoration:none}
.kp-logo-mark-img{height:34px;width:34px;display:block;border-radius:6px}
.kp-logo-word{font-weight:900;font-size:26px;letter-spacing:normal;color:inherit}
.kp-logo-light{color:#fff}

/* ───────── Header ───────── */
.kp-header{background:var(--paper);border-bottom:1px solid var(--line)}
.kp-header-row{display:grid;grid-template-columns:auto 1fr auto auto;gap:32px;align-items:center;height:90px}

.kp-search{position:relative;display:flex;align-items:center;background:var(--fog);
  border-radius:var(--radius-sm);height:48px;max-width:520px;width:100%;
  border:1px solid transparent;transition:border-color .15s,background .15s}
.kp-search:focus-within{background:#fff;border-color:var(--ink)}
.kp-search-input{flex:1;background:transparent;border:0;outline:0;height:100%;
  padding:0 16px;font-size:15px;color:var(--ink)}
.kp-search-input::placeholder{color:var(--ink-3)}
.kp-search-btn{width:48px;height:48px;background:var(--yellow);border-radius:var(--radius-sm);
  display:grid;place-items:center;transition:background .15s}
.kp-search-btn:hover{background:var(--yellow-hover)}

.kp-phones{display:flex;flex-direction:column;gap:2px;text-align:right}
.kp-phone-line{font-weight:700;font-size:16px;letter-spacing:normal}
.kp-phone-line:first-child{color:var(--ink)}
.kp-phone-mobile{color:var(--ink-2);font-weight:600;font-size:14px}

.kp-cta-call{display:inline-flex;align-items:center;gap:8px;height:48px;padding:0 22px;
  background:var(--yellow);color:var(--ink);border-radius:var(--radius-sm);
  font-weight:600;font-size:15px;
  transition:background .15s,transform .15s; white-space:nowrap}
.kp-cta-call:hover{background:var(--yellow-hover);transform:translateY(-1px)}

/* ───────── Sticky Nav ───────── */
.kp-snav-wrap{position:sticky;top:0;z-index:50;}
.kp-snav{background:var(--yellow);border-bottom:1px solid rgba(0,0,0,.08);position:relative}
.kp-snav-row{display:flex;justify-content:space-between;align-items:stretch;height:56px}
.kp-snav-left{display:flex;align-items:stretch;gap:28px}
.kp-snav-allcats{display:inline-flex;align-items:center;gap:10px;background:var(--ink);
  color:#fff;padding:0 22px;font-weight:800;font-size:15px;letter-spacing:normal;
  text-transform:uppercase;transition:background .15s; align-self:stretch;
  margin-left:-20px;border-radius:0 0 0 0}
.kp-snav-allcats:hover,.kp-snav-allcats.is-open{background:#1a1a1a}
.kp-snav-link{display:inline-flex;align-items:center;font-weight:700;font-size:15px;
  letter-spacing:normal;text-transform:uppercase;color:var(--ink);position:relative}
.kp-snav-link:hover::after{content:"";position:absolute;left:0;right:0;bottom:14px;
  height:2px;background:var(--ink)}
.kp-snav-right{display:flex;align-items:center;gap:18px}
.kp-snav-icon{position:relative;display:grid;place-items:center;width:36px;height:36px;
  border-radius:50%;color:var(--ink);transition:background .15s}
.kp-snav-icon:hover{background:rgba(0,0,0,.08)}
.kp-snav-cart{display:inline-flex;align-items:center;gap:8px;background:var(--ink);
  color:#fff;padding:0 16px;height:36px;border-radius:var(--radius-sm);
  font-weight:700;font-size:15px;position:relative;transition:background .15s}
.kp-snav-cart:hover{background:#1a1a1a}
.kp-snav-cart-sum{font-feature-settings:"tnum"}
.kp-badge-count{position:absolute;top:-4px;right:-4px;min-width:18px;height:18px;
  padding:0 4px;background:var(--ink);color:var(--yellow);font-weight:800;font-size:11px;
  border-radius:9px;display:grid;place-items:center;border:2px solid var(--yellow);
  box-sizing:content-box}
.kp-badge-cart{background:var(--yellow);color:var(--ink);border-color:var(--ink)}

/* mega menu */
.kp-mega-scrim{position:fixed;inset:0;background:rgba(10,10,10,.4);z-index:40;animation:fade .2s}
.kp-mega{position:absolute;top:100%;left:0;right:0;background:#fff;
  box-shadow:0 24px 48px rgba(0,0,0,.18);z-index:60;
  display:grid;grid-template-columns:280px 1fr 380px;
  max-width:var(--container);margin:0 auto;border-radius:0 0 var(--radius) var(--radius);
  overflow:hidden;animation:slideDown .2s ease}
@keyframes fade{from{opacity:0}to{opacity:1}}
@keyframes slideDown{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:none}}
.kp-mega-col{padding:24px}
.kp-mega-col-1{background:var(--fog);display:flex;flex-direction:column;gap:2px}
.kp-mega-cat{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;
  border-radius:var(--radius-sm);font-weight:700;font-size:14px;text-align:left;
  text-transform:uppercase;letter-spacing:normal;color:var(--ink-2);transition:all .15s}
.kp-mega-cat.is-active{background:var(--yellow-soft);color:var(--ink)}
.kp-mega-cat:hover{background:var(--yellow-soft);color:var(--ink)}
.kp-mega-spacer{flex:1}
.kp-mega-allcats{display:inline-flex;gap:8px;align-items:center;padding:12px 16px;
  font-weight:800;text-transform:uppercase;letter-spacing:normal;font-size:12px;
  background:var(--ink);color:var(--yellow);border-radius:var(--radius-sm)}
.kp-mega-col-title{font-weight:800;font-size:11px;text-transform:uppercase;
  letter-spacing:normal;color:var(--ink-3);margin-bottom:14px}
.kp-mega-sublist{display:grid;grid-template-columns:1fr 1fr;gap:2px}
.kp-mega-sub{display:grid;grid-template-columns:auto 1fr auto auto;gap:12px;align-items:center;
  padding:12px;border-radius:var(--radius-sm);transition:background .15s;color:var(--ink)}
.kp-mega-sub:hover{background:var(--fog)}
.kp-mega-sub-name{font-weight:600;font-size:14px}
.kp-mega-sub-count{color:var(--ink-3);font-size:15px;font-feature-settings:"tnum"}
.kp-mega-col-3{background:var(--fog);display:flex;flex-direction:column;gap:14px}
.kp-mega-hits{display:flex;flex-direction:column;gap:8px}
.kp-mega-hit{display:flex;gap:12px;padding:8px;background:#fff;border-radius:var(--radius-sm);transition:transform .15s,box-shadow .15s}
.kp-mega-hit:hover{transform:translateY(-2px);box-shadow:var(--shadow-soft)}
.kp-mega-hit-thumb{width:64px;height:64px;flex-shrink:0;border-radius:6px;overflow:hidden}
.kp-mega-hit-meta{flex:1;min-width:0;display:flex;flex-direction:column;justify-content:center}
.kp-mega-hit-name{font-size:15px;font-weight:600;line-height:1.3;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.kp-mega-hit-price{font-size:14px;font-weight:800;margin-top:4px}
.kp-mega-promo{position:relative;background:var(--ink);color:#fff;border-radius:var(--radius);
  padding:20px;margin-top:auto;overflow:hidden}
.kp-mega-promo::before{content:"";position:absolute;right:-40px;top:-40px;width:140px;height:140px;
  background:var(--yellow);border-radius:50%}
.kp-mega-promo-kicker{font-size:11px;letter-spacing:normal;text-transform:uppercase;color:var(--ink-3);position:relative}
.kp-mega-promo-title{font-weight:900;font-size:20px;line-height:1;letter-spacing:normal;margin-top:8px;position:relative}
.kp-mega-promo-arrow{position:absolute;right:16px;bottom:16px;width:36px;height:36px;background:var(--yellow);color:var(--ink);
  border-radius:50%;display:grid;place-items:center}

/* ───────── Hero ───────── */
.kp-hero{padding:64px 0 80px;background:var(--paper);position:relative;overflow:hidden}
.kp-hero-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:64px;align-items:center;min-height:520px}
.kp-hero-kicker{display:inline-flex;gap:10px;align-items:center;font-weight:700;font-size:12px;
  letter-spacing:normal;text-transform:uppercase;color:var(--ink-2);margin-bottom:24px}
.kp-hero-kicker-dot{width:8px;height:8px;background:var(--yellow);border-radius:50%;
  box-shadow:0 0 0 4px var(--yellow-soft)}
.kp-hero-title{font-weight:900;font-size:72px;line-height:.98;letter-spacing:normal;
  text-transform:uppercase;margin:0 0 28px;color:var(--ink)}
.kp-hero-sub{font-size:18px;line-height:1.55;color:var(--ink-2);max-width:520px;margin:0 0 36px}
.kp-hero-ctas{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:40px}
.kp-hero-trust{display:flex;gap:28px;flex-wrap:wrap}
.kp-hero-trust-item{display:inline-flex;gap:8px;align-items:center;font-weight:600;font-size:15px;color:var(--ink-2);
  letter-spacing:normal;text-transform:uppercase}
.kp-hero-trust-item svg{color:var(--yellow);stroke:var(--ink)}

.kp-hero-right{position:relative;height:520px;isolation:isolate}
.kp-hero-blob{position:absolute;inset:0;background:var(--yellow);
  border-radius:50% 16% 50% 16% / 50% 50% 50% 50%;
  transform:rotate(-8deg) translateX(20px)}
.kp-hero-product{position:absolute;left:50%;top:50%;width:62%;
  transform:translate(-50%,-50%) rotate(2deg);
  filter:drop-shadow(0 24px 40px rgba(0,0,0,.25))}
.kp-hero-product-deck{position:absolute;inset:0}
.kp-hero-product-slide{opacity:0;transition:opacity .5s ease, transform .6s ease;
  transform:translate(-50%,-50%) rotate(-4deg) scale(.96)}
.kp-hero-product-slide.is-active{opacity:1;transform:translate(-50%,-50%) rotate(2deg) scale(1)}
.kp-hero-dots .kp-dot{border:0;padding:0;cursor:pointer;transition:all .2s}
.kp-hero-dots .kp-dot:hover{opacity:.5}
.kp-hero-dots .kp-dot.is-active{opacity:1}
.kp-hero-tag{position:absolute;background:#fff;border-radius:var(--radius);
  padding:14px 18px;box-shadow:var(--shadow-card);}
.kp-hero-tag-1{left:-20px;top:60px;}
.kp-hero-tag-num{font-weight:900;font-size:28px;letter-spacing:normal;line-height:1;font-feature-settings:"tnum"}
.kp-hero-tag-lbl{font-size:11px;color:var(--ink-3);letter-spacing:normal;text-transform:uppercase;margin-top:6px}
.kp-hero-tag-2{right:-20px;bottom:60px;display:flex;align-items:center;gap:10px}
.kp-hero-tag-meta{font-size:10px;color:var(--ink-3);letter-spacing:normal;text-transform:uppercase;
  border-right:1px solid var(--line);padding-right:10px}
.kp-hero-tag-name{font-weight:700;font-size:14px}
.kp-hero-dots{position:absolute;bottom:-20px;left:50%;transform:translateX(-50%);display:flex;gap:8px}
.kp-hero-dots .kp-dot{width:8px;height:8px;border-radius:50%;background:var(--ink);opacity:.18}
.kp-hero-dots .kp-dot.is-active{opacity:1;width:24px;border-radius:4px}

/* hero variants */
.kp-hero-v-split .kp-hero-blob{border-radius:0;transform:none;width:100%;height:100%}
.kp-hero-v-wide .kp-hero-blob{border-radius:var(--radius-lg);transform:none}

/* ── hero · stack variant ── */
.kp-hero-stack{position:relative;width:100%;height:100%}
.kp-hero-blob-stack{border-radius:46% 22% 46% 22% / 46% 46% 46% 46%;
  transform:rotate(6deg) translate(10px,10px)}
.kp-hstack-card{position:absolute;width:46%;background:#fff;border-radius:14px;
  padding:14px;box-shadow:var(--shadow-card);overflow:hidden}
.kp-hstack-card .kp-hstack-chip{position:absolute;left:14px;bottom:14px;
  display:inline-block;background:var(--yellow);color:var(--ink);
  font-weight:900;font-size:10px;letter-spacing:normal;padding:6px 10px;border-radius:999px}
.kp-hstack-card .kp-hstack-chip.is-dark{background:var(--ink);color:var(--yellow)}
.kp-hstack-c1{left:50%;top:50%;transform:translate(-50%,-50%) rotate(-2deg);z-index:3}
.kp-hstack-c2{left:8%;top:18%;transform:rotate(-9deg);z-index:2;width:42%}
.kp-hstack-c3{right:6%;top:24%;transform:rotate(7deg);z-index:1;width:42%}
.kp-hstack-tag{left:-8px;bottom:60px;z-index:4}
.kp-hstack-flag{position:absolute;right:-12px;top:30px;z-index:4;
  background:var(--ink);color:var(--yellow);border-radius:14px;
  padding:14px 18px;display:flex;align-items:center;gap:12px;
  box-shadow:var(--shadow-card)}
.kp-hstack-flag-num{font-weight:900;font-size:42px;letter-spacing:normal;line-height:.9;
  font-feature-settings:"tnum"}
.kp-hstack-flag-lbl{font-size:10px;letter-spacing:normal;text-transform:uppercase;line-height:1.3;
  border-left:1px solid rgba(255,207,2,.4);padding-left:12px;color:var(--yellow)}

/* ── hero · mosaic variant ── */
.kp-hero-mosaic{position:relative;width:100%;height:100%;
  background:var(--yellow);border-radius:var(--radius-lg);
  padding:18px;overflow:hidden;isolation:isolate}
.kp-hero-mosaic::before{content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 30% 20%,rgba(255,255,255,.45),transparent 50%);
  pointer-events:none}
.kp-hero-mosaic-grid{position:relative;display:grid;grid-template-columns:repeat(3,1fr);
  grid-template-rows:repeat(2,1fr);gap:10px;width:100%;height:100%;z-index:1}
.kp-hmos-cell{position:relative;background:#fff;border-radius:10px;padding:12px;
  overflow:hidden;box-shadow:0 2px 0 rgba(0,0,0,.05)}
.kp-hmos-chip{position:absolute;left:10px;bottom:10px;background:var(--ink);color:var(--yellow);
  font-weight:900;font-size:9px;letter-spacing:normal;padding:5px 8px;border-radius:999px}
.kp-hmos-c0{transform:rotate(-1deg)}
.kp-hmos-c2{transform:rotate(1deg)}
.kp-hmos-c3{transform:rotate(1deg)}
.kp-hmos-c5{transform:rotate(-1deg)}
.kp-hero-mosaic-badge{position:absolute;left:50%;top:50%;
  transform:translate(-50%,-50%) rotate(-3deg);z-index:2;
  background:var(--ink);color:#fff;border-radius:50%;
  width:160px;height:160px;display:flex;flex-direction:column;
  align-items:center;justify-content:center;text-align:center;
  box-shadow:0 16px 32px rgba(0,0,0,.25)}
.kp-hmos-badge-num{font-weight:900;font-size:30px;letter-spacing:normal;
  font-feature-settings:"tnum";color:var(--yellow)}
.kp-hmos-badge-lbl{font-size:10px;letter-spacing:normal;text-transform:uppercase;
  margin-top:6px;line-height:1.3;color:#fff;opacity:.85}
.kp-hero-mosaic-pill{position:absolute;left:50%;bottom:-14px;transform:translateX(-50%);
  z-index:3;background:#fff;border-radius:999px;padding:10px 18px;
  display:inline-flex;align-items:center;gap:8px;
  font-weight:800;font-size:12px;letter-spacing:normal;text-transform:uppercase;
  box-shadow:var(--shadow-card);white-space:nowrap}

/* ───────── Buttons ───────── */
.kp-btn{display:inline-flex;align-items:center;gap:10px;height:56px;padding:0 28px;
  border-radius:var(--radius-sm);font-weight:800;font-size:14px;letter-spacing:normal;
  text-transform:uppercase;transition:all .15s;white-space:nowrap}
.kp-btn-primary{background:var(--ink);color:#fff}
.kp-btn-primary:hover{background:#1a1a1a;transform:translateY(-1px);box-shadow:var(--shadow-card)}
.kp-btn-ghost{background:transparent;color:var(--ink);box-shadow:inset 0 0 0 2px var(--ink)}
.kp-btn-ghost:hover{background:var(--yellow);box-shadow:inset 0 0 0 2px var(--ink)}

.kp-link-yellow{display:inline-flex;align-items:center;gap:10px;font-weight:800;font-size:15px;
  letter-spacing:normal;text-transform:uppercase;color:var(--ink);position:relative;padding-bottom:4px}
.kp-link-yellow::after{content:"";position:absolute;left:0;right:0;bottom:0;height:2px;background:var(--yellow)}
.kp-link-yellow:hover::after{height:4px;background:var(--ink)}
.kp-inline-link{color:var(--ink);font-weight:600;text-decoration:underline;text-decoration-color:var(--yellow);text-decoration-thickness:2px;text-underline-offset:3px}

/* ───────── Stats ───────── */
.kp-stats{padding:64px 0;background:var(--fog);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.kp-stats-row{display:grid;grid-template-columns:repeat(5,1fr);gap:0}
.kp-stat{padding:8px 24px;position:relative}
.kp-stat:not(:first-child){border-left:1px solid var(--line)}
.kp-stats-divider-bar .kp-stat:not(:first-child){border-left:0;background-image:linear-gradient(to bottom,transparent 30%,var(--ink) 30% 70%,transparent 70%);background-size:1px 100%;background-repeat:no-repeat}
.kp-stats-divider-none .kp-stat{border-left:0}
.kp-stat-bar{width:32px;height:4px;background:var(--yellow);margin-bottom:14px}
.kp-stat-num{font-weight:900;font-size:56px;line-height:1;letter-spacing:normal;font-feature-settings:"tnum";color:var(--ink)}
.kp-stat-lbl{font-size:15px;color:var(--ink-3);margin-top:10px;line-height:1.4}

/* ───────── Section heads ───────── */
.kp-sec{padding:80px 0;background:var(--paper)}
.kp-sec-pop{background:var(--paper)}
.kp-sec-prods{background:var(--fog)}
.kp-sec-print{background:var(--paper)}
.kp-sec-cat-map{background:var(--fog)}
.kp-sec-adv{background:var(--ink);color:#fff}
.kp-sec-brands{background:var(--paper)}
.kp-sec-clients{padding:64px 0;background:var(--fog);overflow:hidden}
.kp-sec-cases{background:var(--paper)}
.kp-sec-faq{background:var(--paper)}
.kp-sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:32px;margin-bottom:48px;flex-wrap:wrap}
.kp-sec-head-split{align-items:flex-start}
.kp-sec-kicker{font-weight:700;font-size:12px;letter-spacing:normal;text-transform:uppercase;
  color:var(--ink-3);margin-bottom:12px}
.kp-sec-adv .kp-sec-kicker{color:rgba(255,255,255,.55)}
.kp-sec-title{font-weight:900;font-size:44px;line-height:1.05;letter-spacing:normal;
  text-transform:uppercase;margin:0;color:inherit}
.kp-sec-bar{display:block;width:64px;height:4px;background:var(--yellow);margin-top:18px}
.kp-sec-link{display:inline-flex;align-items:center;gap:8px;font-weight:700;font-size:15px;
  letter-spacing:normal;text-transform:uppercase;color:var(--ink-2)}
.kp-sec-link:hover{color:var(--ink)}
.kp-sec-blurb{max-width:420px;font-size:16px;line-height:1.55;color:var(--ink-2);margin:0;padding-top:18px}
.kp-sec-adv .kp-sec-blurb{color:rgba(255,255,255,.7)}
.kp-sec-foot{display:flex;justify-content:center;margin-top:48px}

/* ───────── Popular categories ───────── */
.kp-cat-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:20px}
.kp-cat-card{display:flex;flex-direction:column;gap:14px;padding:18px;background:#fff;
  border:1px solid var(--line);border-radius:var(--radius);transition:all .2s;position:relative;overflow:hidden}
.kp-cat-card:hover{border-color:var(--ink);transform:translateY(-4px);box-shadow:var(--shadow-card)}
.kp-cat-tone-ink{background:var(--ink);color:#fff;border-color:var(--ink)}
.kp-cat-tone-ink .kp-cat-count{color:rgba(255,255,255,.6)}
.kp-cat-num{font-size:11px;font-weight:700;letter-spacing:normal;color:var(--ink-3)}
.kp-cat-tone-ink .kp-cat-num{color:rgba(255,255,255,.45)}
.kp-cat-img{flex:1}
.kp-cat-foot{display:grid;grid-template-columns:auto 1fr auto;gap:12px;align-items:center}
.kp-cat-icon{width:40px;height:40px;border-radius:50%;background:var(--yellow);color:var(--ink);
  display:grid;place-items:center;flex-shrink:0;transition:transform .2s}
.kp-cat-card:hover .kp-cat-icon{transform:rotate(-8deg) scale(1.05)}
.kp-cat-name{font-weight:800;font-size:14px;letter-spacing:normal;text-transform:uppercase;line-height:1.2}
.kp-cat-count{font-size:12px;color:var(--ink-3);margin-top:2px;font-feature-settings:"tnum"}

/* ───────── Products ───────── */
.kp-prods-head{display:grid;grid-template-columns:auto 1fr auto;gap:20px;align-items:end;margin-bottom:36px}
.kp-prods-tabs{display:flex;gap:32px;justify-self:center}
.kp-tab{position:relative;padding:8px 0;font-weight:800;font-size:18px;letter-spacing:normal;text-transform:uppercase;color:var(--ink-3);transition:color .15s}
.kp-tab.is-active{color:var(--ink)}
.kp-tab.is-active::after{content:"";position:absolute;left:0;right:0;bottom:0;height:4px;background:var(--yellow)}
.kp-prods-arrows{display:flex;gap:8px}
.kp-rndbtn{width:44px;height:44px;border-radius:50%;background:#fff;border:1px solid var(--line);
  display:grid;place-items:center;transition:all .15s;color:var(--ink)}
.kp-rndbtn:hover{background:var(--yellow);border-color:var(--yellow)}
.kp-rndbtn:first-child svg{transform:rotate(180deg)}

.kp-prod-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:20px}
.kp-prod{background:#fff;border-radius:var(--radius);padding:14px;display:flex;flex-direction:column;gap:8px;
  border:1px solid var(--line);transition:all .2s;position:relative}
.kp-prod:hover{transform:translateY(-4px);box-shadow:var(--shadow-card);border-color:var(--ink)}
.kp-prod-imgwrap{position:relative;background:#fff;border-radius:var(--radius-sm);overflow:hidden}
.kp-prod-badge{position:absolute;top:8px;left:8px;padding:4px 8px;border-radius:4px;
  font-weight:800;font-size:10px;letter-spacing:normal;text-transform:uppercase;z-index:2}
.kp-prod-badge-new,.kp-prod-badge-hit{background:var(--yellow);color:var(--ink)}
.kp-prod-badge-eco{background:var(--eco);color:#fff}
.kp-prod-badge-rus{background:var(--ink);color:var(--yellow)}
.kp-prod-fav{position:absolute;top:8px;right:8px;width:28px;height:28px;background:#fff;
  border-radius:50%;display:grid;place-items:center;color:var(--ink-3);box-shadow:var(--shadow-soft);z-index:2;
  transition:color .15s}
.kp-prod-fav:hover{color:var(--hot)}
.kp-prod-img{aspect-ratio:1/1}
.kp-prod-quick{position:absolute;left:50%;bottom:10px;transform:translateX(-50%) translateY(8px);
  background:var(--ink);color:#fff;padding:8px 14px;border-radius:var(--radius-sm);
  font-weight:700;font-size:11px;letter-spacing:normal;text-transform:uppercase;
  opacity:0;transition:all .2s;white-space:nowrap;z-index:2}
.kp-prod:hover .kp-prod-quick{opacity:1;transform:translateX(-50%) translateY(0)}
.kp-prod-swatches{display:flex;gap:6px;align-items:center;height:20px;margin-top:4px}
.kp-swatch{width:16px;height:16px;border-radius:50%;border:1px solid;display:inline-block}
.kp-swatch-more{font-size:11px;color:var(--ink-3);font-weight:700;font-feature-settings:"tnum"}
.kp-prod-name{margin:0;font-weight:700;font-size:14px;line-height:1.3;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:36px}
.kp-prod-sku{font-size:11px;color:var(--ink-3);letter-spacing:normal;font-feature-settings:"tnum"}
.kp-prod-stock{display:inline-flex;align-items:center;gap:4px;font-size:12px;color:var(--ink-2);font-weight:600}
.kp-prod-stock svg{color:var(--eco);background:var(--yellow-soft);border-radius:50%;padding:2px;box-sizing:content-box;stroke:var(--ink)}
.kp-prod-stock.is-out{color:var(--ink-3)}
.kp-prod-stock.is-out svg{color:var(--ink-3);background:var(--fog)}
.kp-prod-foot{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:end;margin-top:auto;padding-top:8px}
.kp-prod-price-num{font-weight:900;font-size:22px;letter-spacing:normal;font-feature-settings:"tnum"}
.kp-prod-price-cur{font-weight:700;font-size:14px;color:var(--ink-2)}
.kp-prod-price-req{font-weight:800;font-size:15px;color:var(--ink);text-transform:uppercase;letter-spacing:normal}
.kp-prod-price-from{font-size:11px;color:var(--ink-3);margin-top:2px;letter-spacing:normal}
.kp-prod-add{padding:10px 14px;border-radius:var(--radius-sm);font-weight:800;font-size:11px;
  letter-spacing:normal;text-transform:uppercase;background:#fff;color:var(--ink);
  box-shadow:inset 0 0 0 1.5px var(--ink);transition:all .15s}
.kp-prod-add:hover{background:var(--yellow);box-shadow:inset 0 0 0 1.5px var(--ink)}

/* ───────── Print methods ───────── */
.kp-print-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:20px}
.kp-print-card{display:flex;flex-direction:column;gap:14px;padding:20px;background:#fff;
  border:1px solid var(--line);border-radius:var(--radius);transition:all .2s;position:relative}
.kp-print-card:hover{border-color:var(--ink);transform:translateY(-4px);box-shadow:var(--shadow-card)}
.kp-print-num{font-size:11px;font-weight:700;letter-spacing:normal;color:var(--ink-3);font-feature-settings:"tnum"}
.kp-print-img{aspect-ratio:1/1}
.kp-print-name{margin:0;font-weight:800;font-size:18px;letter-spacing:normal;text-transform:uppercase}
.kp-print-desc{margin:0;font-size:15px;line-height:1.5;color:var(--ink-2)}
.kp-print-more{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:800;letter-spacing:normal;
  text-transform:uppercase;color:var(--ink);padding-top:6px;border-top:1px solid var(--line);margin-top:auto}
.kp-print-card:hover .kp-print-more{color:var(--ink)}
.kp-print-card:hover .kp-print-more svg{color:var(--yellow);transform:translateX(4px);transition:transform .15s}

/* ───────── Catalog map ───────── */
.kp-catmap-group{margin-bottom:48px}
.kp-catmap-grouphead{display:flex;align-items:center;gap:20px;margin-bottom:20px}
.kp-catmap-grouplabel{font-weight:800;font-size:15px;letter-spacing:normal;text-transform:uppercase;color:var(--ink);
  background:var(--yellow);padding:8px 14px;border-radius:var(--radius-sm)}
.kp-catmap-line{flex:1;height:1px;background:var(--line)}
.kp-catmap-grouplink{display:inline-flex;align-items:center;gap:8px;font-weight:700;font-size:12px;
  letter-spacing:normal;text-transform:uppercase;color:var(--ink-2)}
.kp-catmap-grouplink:hover{color:var(--ink)}
.kp-catmap-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.kp-catmap-grid-4,.kp-catmap-grid-5,.kp-catmap-grid-6{grid-template-columns:repeat(3,1fr)}
.kp-catmap-tile{display:grid;grid-template-columns:auto 1fr auto;gap:18px;align-items:center;
  padding:18px 20px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  transition:all .2s}
.kp-catmap-tile:hover{border-color:var(--yellow);background:var(--yellow-soft);transform:translateY(-2px)}
.kp-catmap-icon{width:48px;height:48px;border-radius:var(--radius-sm);background:var(--fog);
  display:grid;place-items:center;color:var(--ink);transition:all .2s}
.kp-catmap-tile:hover .kp-catmap-icon{background:var(--yellow);transform:scale(1.06)}
.kp-catmap-row{display:flex;align-items:baseline;gap:10px}
.kp-catmap-name{font-weight:800;font-size:15px;letter-spacing:normal;text-transform:uppercase;line-height:1.2}
.kp-catmap-count{font-size:12px;color:var(--ink-3);font-weight:600;font-feature-settings:"tnum"}
.kp-catmap-count-srv{color:var(--ink-2);background:var(--fog);padding:2px 8px;border-radius:4px;text-transform:uppercase;letter-spacing:normal}
.kp-catmap-tile:hover .kp-catmap-count-srv{background:#fff}
.kp-catmap-sub{font-size:15px;color:var(--ink-2);margin-top:6px;line-height:1.4}
.kp-dot-sep{margin:0 6px;color:var(--ink-3)}

/* ───────── Advantages ───────── */
.kp-adv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(255,255,255,.08)}
.kp-adv-card{display:flex;flex-direction:column;gap:14px;padding:36px 32px;background:var(--ink);color:#fff;
  position:relative;transition:background .2s;min-height:240px}
.kp-adv-card:hover{background:#1a1a1a}
.kp-adv-num{font-size:12px;font-weight:700;letter-spacing:normal;color:rgba(255,255,255,.45);font-feature-settings:"tnum"}
.kp-adv-icon{width:56px;height:56px;border-radius:50%;border:1.5px solid rgba(255,255,255,.18);
  display:grid;place-items:center;color:#fff;transition:all .2s}
.kp-adv-card:hover .kp-adv-icon{background:var(--yellow);color:var(--ink);border-color:var(--yellow)}
.kp-adv-title{margin:0;font-weight:900;font-size:18px;letter-spacing:normal;text-transform:uppercase}
.kp-adv-desc{margin:0;font-size:14px;line-height:1.5;color:rgba(255,255,255,.7)}
.kp-adv-arrow{position:absolute;right:24px;top:24px;color:rgba(255,255,255,.3);transition:all .2s}
.kp-adv-card:hover .kp-adv-arrow{color:var(--yellow);transform:translateX(4px)}

/* ───────── Brands ───────── */
.kp-brand-grid{display:grid;grid-template-columns:repeat(6,1fr);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:var(--line);gap:1px}
.kp-brand-cell{display:grid;place-items:center;background:#fff;height:96px;
  font-weight:800;font-size:14px;letter-spacing:normal;color:var(--ink-3);transition:all .2s}
.kp-brand-cell:hover{color:var(--ink);background:var(--yellow-soft)}
.kp-brand-cell:hover .kp-brand-word{transform:scale(1.06)}
.kp-brand-word{transition:transform .2s}

/* ───────── Clients marquee ───────── */
.kp-clients-head{margin-bottom:24px}
.kp-clients-title{font-weight:900;font-size:32px;line-height:1.1;letter-spacing:normal;text-transform:uppercase;margin:0}
.kp-clients-count{color:var(--yellow);background:var(--ink);padding:0 12px;border-radius:var(--radius-sm);
  display:inline-block;font-feature-settings:"tnum"}
.kp-clients-marquee{overflow:hidden;mask-image:linear-gradient(to right,transparent,#000 6%,#000 94%,transparent);
  -webkit-mask-image:linear-gradient(to right,transparent,#000 6%,#000 94%,transparent)}
.kp-clients-track{display:flex;gap:48px;align-items:center;width:max-content;
  animation:marquee 50s linear infinite;padding:24px 0}
.kp-client-word{font-weight:800;font-size:18px;letter-spacing:normal;color:var(--ink-3);
  white-space:nowrap;transition:color .2s}
.kp-client-word:hover{color:var(--ink)}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ───────── Cases ───────── */
.kp-cases-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.kp-case-card{background:#fff;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);
  transition:all .2s;display:flex;flex-direction:column}
.kp-case-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-card);border-color:var(--ink)}
.kp-case-img{position:relative}
.kp-case-tag{position:absolute;left:16px;top:16px;background:var(--yellow);color:var(--ink);
  padding:6px 12px;border-radius:var(--radius-sm);font-weight:800;font-size:11px;letter-spacing:normal}
.kp-case-body{padding:24px;display:flex;flex-direction:column;gap:10px;flex:1}
.kp-case-client{font-size:11px;font-weight:700;letter-spacing:normal;text-transform:uppercase;color:var(--ink-3)}
.kp-case-title{margin:0;font-weight:800;font-size:20px;line-height:1.2;letter-spacing:normal}
.kp-case-desc{margin:0;font-size:14px;line-height:1.5;color:var(--ink-2);flex:1}
.kp-case-more{display:inline-flex;align-items:center;gap:6px;font-weight:800;font-size:11px;
  letter-spacing:normal;text-transform:uppercase;color:var(--ink);padding-top:8px;border-top:1px solid var(--line);margin-top:auto}
.kp-case-more svg{color:var(--yellow);transition:transform .15s}
.kp-case-card:hover .kp-case-more svg{transform:translateX(4px)}

/* ───────── FAQ ───────── */
.kp-faq-grid{display:grid;grid-template-columns:1fr 1.5fr;gap:64px;align-items:start}
.kp-faq-side .kp-sec-bar{margin-bottom:24px}
.kp-faq-blurb{font-size:15px;line-height:1.6;color:var(--ink-2);margin:0 0 24px}
.kp-faq-list{display:flex;flex-direction:column;gap:8px}
.kp-faq-item{background:var(--fog);border-radius:var(--radius);overflow:hidden;
  border-left:4px solid transparent;transition:all .2s}
.kp-faq-item.is-open{background:var(--yellow-soft);border-left-color:var(--yellow)}
.kp-faq-q{display:grid;grid-template-columns:auto 1fr auto;gap:18px;align-items:center;
  width:100%;padding:20px 24px;text-align:left}
.kp-faq-num{font-weight:700;font-size:12px;letter-spacing:normal;color:var(--ink-3);font-feature-settings:"tnum"}
.kp-faq-item.is-open .kp-faq-num{color:var(--ink)}
.kp-faq-qtext{font-weight:700;font-size:16px;letter-spacing:normal}
.kp-faq-toggle{width:32px;height:32px;background:#fff;border-radius:50%;display:grid;place-items:center;color:var(--ink)}
.kp-faq-item.is-open .kp-faq-toggle{background:var(--ink);color:var(--yellow)}
.kp-faq-a-wrap{max-height:0;overflow:hidden;transition:max-height .3s ease}
.kp-faq-item.is-open .kp-faq-a-wrap{max-height:600px}
.kp-faq-a{margin:0;padding:0 24px 24px 64px;font-size:15px;line-height:1.6;color:var(--ink-2)}

/* ───────── Newsletter ───────── */
.kp-sec-newsletter{background:var(--yellow);padding:64px 0}
.kp-nl-row{display:grid;grid-template-columns:1.1fr 1fr;gap:48px;align-items:center}
.kp-nl-kicker{font-weight:800;font-size:12px;letter-spacing:normal;color:var(--ink-2);margin-bottom:14px}
.kp-nl-title{margin:0;font-weight:900;font-size:44px;line-height:1;letter-spacing:normal;text-transform:uppercase}
.kp-nl-sub{margin:18px 0 0;font-size:16px;color:var(--ink-2);line-height:1.5;max-width:480px}
.kp-nl-form{display:flex;flex-direction:column;gap:12px}
.kp-nl-field{display:flex;background:#fff;border-radius:var(--radius-sm);overflow:hidden;height:64px;
  box-shadow:0 8px 24px rgba(0,0,0,.08)}
.kp-nl-field input{flex:1;border:0;outline:0;padding:0 24px;font-size:16px;background:transparent;font-weight:600}
.kp-nl-btn{display:inline-flex;align-items:center;gap:10px;padding:0 28px;background:var(--ink);color:#fff;
  font-weight:800;font-size:15px;letter-spacing:normal;text-transform:uppercase;transition:background .15s}
.kp-nl-btn:hover{background:#1a1a1a}
.kp-nl-tos{margin:0;font-size:12px;color:var(--ink-2);line-height:1.5}
.kp-nl-tos a{text-decoration:underline}
.kp-nl-done{display:inline-flex;align-items:center;gap:10px;padding:18px 24px;background:var(--ink);color:#fff;
  border-radius:var(--radius-sm);font-weight:800;font-size:14px;letter-spacing:normal;text-transform:uppercase}

/* ───────── Footer ───────── */
.kp-footer{background:var(--ink);color:rgba(255,255,255,.7);padding:64px 0 24px;font-size:14px}
.kp-footer-row{display:grid;grid-template-columns:1.4fr repeat(3,1fr) 1.2fr;gap:32px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.08)}
.kp-footer-col-brand .kp-logo{margin-bottom:18px}
.kp-footer-blurb{font-size:14px;line-height:1.6;color:rgba(255,255,255,.6);margin:0 0 20px}
.kp-footer-socials{display:flex;gap:12px;align-items:center}
.kp-footer-soc{width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center;
  line-height:0;transition:transform .15s,opacity .15s;opacity:.85}
.kp-footer-soc img{width:22px;height:22px;display:block;object-fit:contain}
.kp-footer-soc:hover{transform:translateY(-2px) scale(1.08);opacity:1}
.kp-footer-h{font-weight:800;font-size:11px;letter-spacing:normal;text-transform:uppercase;color:#fff;margin-bottom:18px}
.kp-footer-col ul{display:flex;flex-direction:column;gap:10px}
.kp-footer-col li a{color:rgba(255,255,255,.6);font-size:14px;transition:color .15s}
.kp-footer-col li a:hover{color:var(--yellow)}
.kp-footer-phone{display:block;color:#fff;font-weight:600;font-size:18px;margin-bottom:6px;letter-spacing:normal}
.kp-footer-mail{display:block;color:var(--yellow);font-weight:600;margin:14px 0}
.kp-footer-addr{margin:14px 0 4px;line-height:1.5;color:rgba(255,255,255,.6)}
.kp-footer-hours{margin:0;color:rgba(255,255,255,.45);font-size:15px}
.kp-footer-bottom{display:grid;grid-template-columns:1.2fr 1.5fr 1fr;gap:24px;align-items:center;padding-top:24px;font-size:12px;color:rgba(255,255,255,.45)}
.kp-footer-legal{display:flex;gap:10px;align-items:center;justify-content:center;flex-wrap:wrap}
.kp-footer-legal a{color:rgba(255,255,255,.55);transition:color .15s}
.kp-footer-legal a:hover{color:var(--yellow)}
.kp-footer-socials-bottom{display:flex;gap:14px;justify-content:flex-end;align-items:center;flex-wrap:wrap}
.kp-footer-soc-bottom{width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center;
  line-height:0;opacity:.85;transition:transform .15s,opacity .15s}
.kp-footer-soc-bottom img{width:22px;height:22px;display:block;object-fit:contain}
.kp-footer-soc-bottom:hover{transform:translateY(-2px) scale(1.08);opacity:1}

/* ───────── Mobile sticky CTA + toast ───────── */
.kp-mobile-cta{display:none;position:fixed;bottom:16px;left:16px;right:16px;height:56px;
  background:var(--yellow);color:var(--ink);font-weight:800;font-size:15px;letter-spacing:normal;
  text-transform:uppercase;border-radius:var(--radius-sm);align-items:center;justify-content:center;gap:10px;
  box-shadow:0 8px 24px rgba(0,0,0,.2);z-index:30}

.kp-toast{position:fixed;bottom:24px;right:24px;background:var(--ink);color:#fff;padding:14px 20px;
  border-radius:var(--radius);display:flex;gap:14px;align-items:center;
  box-shadow:0 12px 32px rgba(0,0,0,.32);z-index:1000;animation:toastIn .25s ease;max-width:340px}
@keyframes toastIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
.kp-toast-t{font-weight:700;font-size:14px}
.kp-toast-s{font-size:12px;color:rgba(255,255,255,.6);margin-top:2px;line-height:1.3}

/* ───────── Density ───────── */
[data-density="compact"] .kp-sec{padding:56px 0}
[data-density="compact"] .kp-hero{padding:48px 0 60px}
[data-density="comfy"] .kp-sec{padding:104px 0}
[data-density="comfy"] .kp-hero{padding:88px 0 100px}

/* ───────── Responsive ───────── */
@media (max-width:1100px){
  .kp-header-row{grid-template-columns:auto 1fr auto;gap:20px}
  .kp-phones{display:none}
  .kp-cat-grid,.kp-print-grid,.kp-prod-grid{grid-template-columns:repeat(3,1fr)}
  .kp-stats-row{grid-template-columns:repeat(3,1fr) ;gap:24px;row-gap:32px}
  .kp-stat:nth-child(4),.kp-stat:nth-child(5){border-left:0}
  .kp-hero-title{font-size:56px}
  .kp-sec-title{font-size:36px}
  .kp-nl-title{font-size:36px}
  .kp-adv-grid,.kp-cases-grid,.kp-catmap-grid{grid-template-columns:repeat(2,1fr)}
  .kp-brand-grid{grid-template-columns:repeat(4,1fr)}
  .kp-footer-row{grid-template-columns:1fr 1fr 1fr;gap:32px 24px}
  .kp-footer-col-brand,.kp-footer-col-contact{grid-column:span 3}
  .kp-footer-bottom{grid-template-columns:1fr;text-align:center}
  .kp-footer-legal,.kp-footer-socials-bottom{justify-content:center}
}
@media (max-width:760px){
  .kp-topbar-left .kp-tb-item:nth-child(2),.kp-topbar-right .kp-tb-item:nth-child(2){display:none}
  .kp-header-row{grid-template-columns:auto 1fr auto;height:72px}
  .kp-search{display:none}
  .kp-cta-call{padding:0 14px;font-size:11px}
  .kp-snav-left .kp-snav-link{display:none}
  .kp-hero-grid{grid-template-columns:1fr;gap:32px}
  .kp-hero-right{height:360px}
  .kp-hero-title{font-size:40px}
  .kp-hero-ctas .kp-btn{flex:1;justify-content:center}
  .kp-stats-row{grid-template-columns:repeat(2,1fr)}
  .kp-stat:nth-child(3){border-left:0}
  .kp-cat-grid,.kp-print-grid,.kp-prod-grid{grid-template-columns:repeat(2,1fr)}
  .kp-catmap-grid,.kp-adv-grid,.kp-cases-grid{grid-template-columns:1fr}
  .kp-brand-grid{grid-template-columns:repeat(3,1fr)}
  .kp-faq-grid{grid-template-columns:1fr;gap:40px}
  .kp-nl-row{grid-template-columns:1fr;gap:32px}
  .kp-sec-title{font-size:30px}
  .kp-mobile-cta{display:flex}
}

/* ───────── PATCH 1.2: фикс мега-меню (закрыто по умолчанию) ───────── */
/* Управление видимостью через CSS-класс, не через [hidden] — атрибут [hidden]
 * перебивается WoodMart/плагинами, а класс с !important — нет. */

.kp-mega.kp-mega-hidden,
.kp-mega-scrim.kp-mega-hidden,
.kp-mega-group-pane.kp-mega-hidden {
  display: none !important;
}

/* Стартовое состояние: до загрузки JS меню должно быть закрыто (страховка от FOUC) */
.kp-mega:not(.kp-mega-init),
.kp-mega-scrim:not(.kp-mega-init) {
  display: none;
}
.kp-mega.kp-mega-init,
.kp-mega-scrim.kp-mega-init {
  display: revert;
}
.kp-mega.kp-mega-init.kp-mega-hidden,
.kp-mega-scrim.kp-mega-init.kp-mega-hidden {
  display: none !important;
}

/* ───────── PATCH 1.3: Полосатый Placeholder ───────── */
/* Точная реплика KP.Placeholder из прототипа Claude Design.
 * 4 цветовых тона: warm (бежевый) / cool (серый) / yellow (жёлтый) / ink (чёрный).
 * Полосы 135deg, ширина 12px, светлый/тёмный сегмент.
 * Подпись в моноширинном шрифте 11px UPPERCASE с полупрозрачной плашкой. */

.kp-placeholder {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  position: relative;
  background-repeat: no-repeat;
  background-size: 100% 100%;
}
.kp-placeholder-warm {
  background: repeating-linear-gradient(135deg, #EAE6DC 0 12px, #D9D2BF 12px 24px);
}
.kp-placeholder-cool {
  background: repeating-linear-gradient(135deg, #E5E8EB 0 12px, #D2D8DD 12px 24px);
}
.kp-placeholder-yellow {
  background: repeating-linear-gradient(135deg, #FFE98A 0 12px, #FFDA3D 12px 24px);
}
.kp-placeholder-ink {
  background: repeating-linear-gradient(135deg, #1B1B1B 0 12px, #0A0A0A 12px 24px);
}

.kp-placeholder-label {
  font-family: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, Consolas, monospace;
  font-weight: 500;
  font-size: 11px;
  line-height: 1;
  letter-spacing:normal;
  text-transform: uppercase;
  padding: 6px 10px;
  border-radius: 4px;
  backdrop-filter: blur(2px);
  color: rgba(0, 0, 0, .42);
  background: rgba(255, 255, 255, .7);
  text-align: center;
  max-width: 80%;
}
.kp-placeholder-ink .kp-placeholder-label {
  color: rgba(255, 255, 255, .55);
  background: rgba(0, 0, 0, .4);
}

/* В hero-слайдере placeholder занимает весь слайд */
.kp-hero-product-slide .kp-placeholder {
  height: 100%;
}

/* В карточках товаров — фильтр не нужен, прямые стили */
.kp-prod-imgwrap .kp-placeholder,
.kp-cat-img .kp-placeholder,
.kp-print-img .kp-placeholder,
.kp-case-img .kp-placeholder {
  height: 100%;
  display: flex;
}

/* Иконка категории внутри карточки — нужна обёртка для центровки SVG */
.kp-cat-icon svg,
.kp-catmap-icon svg {
  width: 22px;
  height: 22px;
  display: block;
}
.kp-catmap-icon svg {
  width: 26px;
  height: 26px;
}
