:root{
  --purple:#7c3aed; --purple-d:#5b21b6; --purple-soft:#f3edff;
  --teal:#10b6ae; --teal-d:#0a8d88;
  --coral:#f4435e; --coral-d:#cc2843;
  --yellow:#fbb91e; --yellow-d:#e09e00;
  --ink:#2c2542; --ink2:#5b5470; --muted:#9a93ad;
  --line:#eee7fb; --line2:#e4ddf3; --bg:#faf8ff;
  --radius:12px; --radius-lg:18px; --radius-xl:24px;
  --shadow:0 14px 34px rgba(95,55,180,.14); --shadow-sm:0 6px 18px rgba(95,55,180,.10);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Nunito,-apple-system,Segoe UI,Roboto,sans-serif;color:var(--ink);
  background:#fff;line-height:1.6;font-size:15px;font-weight:500;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
.container{max-width:1280px;margin:0 auto;padding:0 22px}
.muted{color:var(--muted)}
.hidden{display:none}
img{max-width:100%}
h1{font-weight:900;font-size:34px;letter-spacing:-.3px;margin:8px 0 20px;line-height:1.12}
h2{font-weight:900;font-size:27px;letter-spacing:-.2px;margin:34px 0 18px}

/* header */
.site-header{position:sticky;top:0;background:#fff;z-index:30;border-bottom:1px solid var(--line);transition:box-shadow .3s ease}
.site-header.scrolled{box-shadow:0 8px 30px rgba(95,55,180,.10)}
.header-inner{display:flex;align-items:center;gap:24px;padding:16px 22px;max-width:1280px;margin:0 auto}
.logo{display:flex;align-items:center;gap:12px;outline:none;-webkit-tap-highlight-color:transparent}
.logo:focus,.logo:focus-visible{outline:none}
.logo img{height:96px;width:auto;display:block}
.logo-text{font-weight:900;font-size:30px;letter-spacing:-.5px;
  background:linear-gradient(92deg,var(--purple) 0%,var(--teal) 38%,var(--coral) 68%,var(--yellow) 100%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.logo-city{color:var(--muted);font-size:12px;letter-spacing:1.5px;text-transform:uppercase;font-weight:700}
.catalog-btn{display:inline-flex;align-items:center;gap:8px;color:#fff;font-weight:800;font-size:14px;
  padding:12px 22px;border-radius:var(--radius);white-space:nowrap;
  background:linear-gradient(180deg,#8b5cf6,var(--purple));
  box-shadow:0 5px 0 var(--purple-d),0 10px 18px rgba(124,58,237,.30);transition:transform .12s,box-shadow .12s}
.catalog-btn:hover{transform:translateY(-2px);box-shadow:0 7px 0 var(--purple-d),0 14px 24px rgba(124,58,237,.36)}
.catalog-btn:active{transform:translateY(2px);box-shadow:0 3px 0 var(--purple-d)}
.search{flex:1;display:flex;max-width:560px}
.search input{flex:1;padding:13px 18px;border:2px solid var(--line2);border-right:none;
  border-radius:var(--radius) 0 0 var(--radius);outline:none;font:inherit;font-weight:600;font-size:14px;background:var(--bg)}
.search input:focus{border-color:var(--purple);background:#fff}
.search button{padding:0 22px;border:none;color:#fff;cursor:pointer;font-size:16px;
  border-radius:0 var(--radius) var(--radius) 0;background:linear-gradient(180deg,#8b5cf6,var(--purple))}
.search button:hover{filter:brightness(1.06)}
.header-contacts{display:flex;align-items:center;gap:24px;margin-left:auto}
.phone{font-weight:900;white-space:nowrap;font-size:16px;color:var(--ink)}
.fav-link{font-weight:800;white-space:nowrap;font-size:15px;display:inline-flex;align-items:center;gap:6px;color:var(--coral)}
.fav-link:hover{filter:brightness(1.06)}
.fav-link .fav-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;
  background:var(--coral);color:#fff;border-radius:20px;padding:0 6px;font-size:11px;font-weight:800}
.cart-link{font-weight:800;white-space:nowrap;font-size:14px;display:inline-flex;align-items:center;gap:8px;
  background:var(--purple-soft);color:var(--purple);padding:10px 16px;border-radius:30px;transition:.2s}
.cart-link:hover{background:#e7dbff;transform:translateY(-1px)}
.cart-ico{font-size:16px}
.cart-count{display:inline-flex;align-items:center;justify-content:center;min-width:21px;height:21px;
  background:linear-gradient(180deg,#fb6f85,var(--coral));color:#fff;border-radius:20px;padding:0 6px;font-size:11px;font-weight:800;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.4),0 2px 5px rgba(244,67,94,.4)}

/* category nav — благородная глубокая лента со стрелкой прокрутки */
.catnav{background:linear-gradient(180deg,#7c3aed,#6a24d4);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.22),0 6px 18px rgba(91,33,182,.22)}
.catnav-wrap{position:relative;display:flex;align-items:center}
.catnav-inner{display:flex;gap:4px;overflow-x:auto;scrollbar-width:none;scroll-behavior:smooth;flex:1}
.catnav-inner::-webkit-scrollbar{display:none}
.catnav a{padding:14px 18px;font-size:14px;font-weight:700;white-space:nowrap;color:#fff;opacity:.92;
  border-radius:10px;margin:5px 0;transition:.18s}
.catnav a:hover{background:rgba(255,255,255,.16);opacity:1}
.catnav a.nalichie{background:linear-gradient(180deg,#ffd24d,var(--yellow));color:#5b3b00;font-weight:800;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.5),0 3px 0 var(--yellow-d)}
.catnav a.nalichie:hover{filter:brightness(1.05);opacity:1}
.catnav-wrap::after{content:"";position:absolute;right:0;top:0;bottom:0;width:90px;pointer-events:none;
  background:linear-gradient(90deg,rgba(106,36,212,0),#6a24d4);transition:.25s}
.catnav-wrap.at-end::after{opacity:0}
.catnav-arrow{position:absolute;right:8px;top:50%;transform:translateY(-50%);z-index:3;width:38px;height:38px;
  border:none;border-radius:50%;cursor:pointer;font-size:24px;font-weight:800;color:var(--purple);background:#fff;
  box-shadow:0 5px 14px rgba(0,0,0,.22);display:flex;align-items:center;justify-content:center;padding-bottom:3px;transition:.2s}
.catnav-arrow:hover{transform:translateY(-50%) scale(1.08)}
.catnav-wrap.at-end .catnav-arrow{opacity:0;pointer-events:none}

.breadcrumbs{font-size:13px;color:var(--muted);margin:20px 0;font-weight:600}
.breadcrumbs a:hover{color:var(--purple)}

/* promo banner */
.promo{display:block;margin:22px 0;border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow)}
.promo img{width:100%;display:block}

.section-head{display:flex;align-items:baseline;justify-content:space-between;gap:16px;margin-top:42px}
.section-head h2{margin:0;position:relative;padding-left:18px}
.section-head h2::before{content:"";position:absolute;left:0;top:6px;bottom:5px;width:8px;border-radius:8px;
  background:linear-gradient(var(--purple),var(--teal))}
.section-head .more{color:var(--purple);font-weight:800;font-size:14px}

/* преимущества — цветные плитки */
.usps{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;margin:28px 0 8px}
.usp{border-radius:var(--radius-lg);padding:20px 18px;background:var(--bg);border:1px solid var(--line);text-align:center;transition:.2s}
.usp:hover{transform:translateY(-4px);box-shadow:var(--shadow-sm)}
.usp .ico{width:66px;height:66px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-size:30px;margin:0 auto 14px;color:#fff;position:relative;transition:transform .2s ease;
  box-shadow:inset 0 4px 7px rgba(255,255,255,.55),inset 0 -7px 11px rgba(0,0,0,.22),0 12px 22px rgba(95,55,180,.30)}
.usp .ico::after{content:"";position:absolute;top:9px;left:16px;width:38%;height:26%;border-radius:50%;
  background:rgba(255,255,255,.5);filter:blur(3px)}
.usp:hover .ico{transform:translateY(-4px) scale(1.06)}
.usp:nth-child(1) .ico{background:radial-gradient(circle at 34% 26%,#c79bff,var(--purple) 72%)}
.usp:nth-child(2) .ico{background:radial-gradient(circle at 34% 26%,#5ee7e0,var(--teal) 72%)}
.usp:nth-child(3) .ico{background:radial-gradient(circle at 34% 26%,#ff96a6,var(--coral) 72%)}
.usp:nth-child(4) .ico{background:radial-gradient(circle at 34% 26%,#ffe08a,var(--yellow-d) 74%)}
.usp:nth-child(5) .ico{background:radial-gradient(circle at 34% 26%,#9be3df,#5b8fe0 74%)}
.usp b{display:block;font-weight:900;font-size:15px;margin-bottom:3px}
.usp span{color:var(--muted);font-size:12.5px;line-height:1.4;font-weight:600}

/* catalog layout with sidebar */
.catalog-layout{display:grid;grid-template-columns:260px 1fr;gap:34px;align-items:start;margin-top:8px}
.sidebar{border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;position:sticky;top:150px;background:#fff;box-shadow:var(--shadow-sm)}
.sidebar-title{font-weight:900;font-size:13px;letter-spacing:.5px;text-transform:uppercase;color:#fff;
  padding:16px 20px;background:linear-gradient(90deg,var(--purple),var(--teal))}
.sidebar-cats{list-style:none;margin:0;padding:8px 0;max-height:72vh;overflow:auto}
.sidebar-cats a{display:flex;justify-content:space-between;align-items:center;gap:8px;padding:9px 20px;font-size:14px;color:var(--ink2);font-weight:700;transition:.15s}
.sidebar-cats .cnt{background:var(--purple-soft);color:var(--purple);border-radius:20px;padding:1px 9px;font-size:12px;font-weight:800}
.sidebar-cats a:hover{color:var(--purple);background:var(--purple-soft)}
.sidebar-cats a.active{color:var(--purple);box-shadow:inset 4px 0 0 var(--purple);background:var(--purple-soft)}

/* category tiles — фото на всю плитку + название поверх */
.cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:20px}
.cat-tile{position:relative;border-radius:var(--radius-lg);overflow:hidden;display:block;
  background:var(--purple-soft);transition:.25s ease;box-shadow:var(--shadow-sm)}
.cat-tile:hover{box-shadow:var(--shadow);transform:translateY(-5px)}
.cat-tile-img{aspect-ratio:1;overflow:hidden}
.cat-tile-img img{width:100%;height:100%;object-fit:cover;transition:.5s ease}
.cat-tile:hover .cat-tile-img img{transform:scale(1.07)}
.cat-tile .no-img{width:100%;height:100%;background:linear-gradient(135deg,#a855f7,#22c9c0)}
.cat-tile span{position:absolute;left:0;right:0;bottom:0;padding:26px 16px 14px;font-weight:800;font-size:14.5px;color:#fff;
  background:linear-gradient(transparent,rgba(24,12,46,.82));line-height:1.25}

.subcats{display:flex;flex-wrap:wrap;gap:10px;margin:14px 0 22px}
.chip{border:2px solid var(--line2);border-radius:30px;padding:8px 18px;font-size:13.5px;background:#fff;transition:.2s;color:var(--ink2);font-weight:700}
.chip:hover{border-color:var(--purple);color:var(--purple);background:var(--purple-soft)}

/* product grid */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:22px}
.card{position:relative;border:1px solid var(--line);border-radius:var(--radius-lg);padding:15px;display:flex;flex-direction:column;
  background:#fff;transition:.25s ease}
.card:hover{box-shadow:var(--shadow);transform:translateY(-5px)}
.fav{position:absolute;top:13px;right:13px;z-index:2;border:none;background:#fff;width:36px;height:36px;
  border-radius:50%;font-size:18px;color:var(--coral);cursor:pointer;line-height:1;transition:.2s;box-shadow:var(--shadow-sm)}
.fav:hover,.fav.on{background:var(--coral);color:#fff;transform:scale(1.08)}
.card-img{display:block;aspect-ratio:1;overflow:hidden;border-radius:var(--radius);background:var(--bg)}
.card-img img{width:100%;height:100%;object-fit:cover;transition:.5s ease}
.card:hover .card-img img{transform:scale(1.06)}
.no-img{display:flex;align-items:center;justify-content:center;height:100%;color:var(--muted);font-size:13px}
.no-img.big{aspect-ratio:1;border-radius:var(--radius)}
.card-title{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
  margin:13px 0 10px;font-size:14.5px;font-weight:800;line-height:1.35;color:var(--ink);min-height:40px}
.card-title:hover{color:var(--purple)}
.card-bottom{margin-top:auto;display:flex;flex-direction:column;gap:11px}
.price{font-weight:900;font-size:18px;color:var(--coral)}
.price .old{color:var(--muted);text-decoration:line-through;font-weight:700;font-size:13px;margin-left:8px}
.price.big{font-size:32px;font-weight:900;margin:4px 0;color:var(--coral)}
.card .btn{width:100%}

/* объёмные кнопки */
.btn{display:inline-block;color:#fff;border:none;border-radius:var(--radius);padding:13px 24px;
  font-weight:800;font-size:14px;cursor:pointer;font-family:inherit;white-space:nowrap;text-align:center;
  background:linear-gradient(180deg,#9d6bff,var(--purple));
  box-shadow:inset 0 2px 0 rgba(255,255,255,.35),0 5px 0 var(--purple-d),0 10px 20px rgba(124,58,237,.26);transition:transform .12s,box-shadow .12s,filter .12s}
.btn:hover{transform:translateY(-2px);box-shadow:inset 0 2px 0 rgba(255,255,255,.35),0 7px 0 var(--purple-d),0 14px 26px rgba(124,58,237,.34)}
.btn:active{transform:translateY(3px);box-shadow:inset 0 2px 0 rgba(255,255,255,.3),0 2px 0 var(--purple-d),0 5px 12px rgba(124,58,237,.2)}
.btn-sm{padding:11px 16px;font-size:13px;box-shadow:0 4px 0 var(--purple-d),0 8px 16px rgba(124,58,237,.22)}
.btn-lg{padding:16px 30px;font-size:15.5px}
.btn-coral{background:linear-gradient(180deg,#fb6f85,var(--coral));box-shadow:0 5px 0 var(--coral-d),0 10px 20px rgba(244,67,94,.26)}
.btn-coral:hover{box-shadow:0 7px 0 var(--coral-d),0 14px 26px rgba(244,67,94,.34)}
.btn-coral:active{box-shadow:0 2px 0 var(--coral-d)}
.btn-ghost{background:#fff;color:var(--purple);border:2px solid var(--line2);box-shadow:0 4px 0 var(--line2)}
.btn-ghost:hover{border-color:var(--purple);box-shadow:0 6px 0 var(--line2);transform:translateY(-2px)}
.btn-ghost:active{box-shadow:0 2px 0 var(--line2)}

.pager{display:flex;align-items:center;gap:20px;justify-content:center;margin:40px 0;font-weight:700}
.pager a{font-weight:800;color:var(--purple)}

/* product page */
.product{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(0,1fr);gap:46px;margin-top:8px}
.product-gallery #main-photo{width:100%;border-radius:var(--radius-lg);background:var(--bg);object-fit:contain;border:1px solid var(--line);aspect-ratio:1}
.thumbs{display:flex;gap:10px;margin-top:14px;flex-wrap:wrap}
.thumbs img{width:72px;height:72px;object-fit:cover;border-radius:var(--radius);border:2px solid var(--line2);cursor:pointer;transition:.2s}
.thumbs img:hover{border-color:var(--purple)}
.product-info h1{margin-top:0}
.variants{margin:22px 0}
.variants-label{font-weight:800;margin-bottom:10px;font-size:14px}
.variant-btns{display:flex;flex-wrap:wrap;gap:10px}
.variant-btn{border:2px solid var(--line2);background:#fff;border-radius:var(--radius);padding:10px 16px;cursor:pointer;
  font:inherit;font-weight:800;font-size:14px;min-width:50px;transition:.2s;color:var(--ink2)}
.variant-btn:hover{border-color:var(--purple)}
.variant-btn.active{border-color:var(--purple);background:var(--purple-soft);color:var(--purple)}
.buy-panel{margin-top:26px;border:1px solid var(--line);border-radius:var(--radius-xl);padding:26px;display:flex;flex-direction:column;gap:14px;max-width:420px;box-shadow:var(--shadow);background:#fff}
.buy-panel .btn{width:100%}
.buy-contacts{font-size:13.5px;margin-top:2px;font-weight:600}
.description{margin-top:48px}
.desc-html{max-width:820px;font-size:15.5px;color:var(--ink2);line-height:1.85;font-weight:500}
.desc-html img{border-radius:var(--radius);margin:10px 0}

/* cart */
.cart-table{width:100%;border-collapse:collapse;margin:16px 0}
.cart-table th,.cart-table td{text-align:left;padding:14px 12px;border-bottom:1px solid var(--line)}
.cart-table th{color:var(--muted);font-weight:800;font-size:12px;letter-spacing:.5px;text-transform:uppercase}
.cart-total{font-size:24px;text-align:right;margin:14px 0;font-weight:900;color:var(--coral)}
.order-form{display:flex;flex-direction:column;gap:14px;max-width:480px}
.order-form input,.order-form textarea{padding:14px 16px;border:2px solid var(--line2);border-radius:var(--radius);font:inherit;font-weight:600;background:var(--bg)}
.order-form input:focus,.order-form textarea:focus{border-color:var(--purple);outline:none;background:#fff}
.success{background:var(--purple-soft);border:2px solid #ddd0fb;border-radius:var(--radius-xl);padding:30px;margin-top:16px}
.qty-btn{border:2px solid var(--line2);background:#fff;width:30px;height:30px;border-radius:8px;cursor:pointer;font-weight:800;color:var(--purple)}
.link-del{color:var(--muted);cursor:pointer;font-size:13px;font-weight:700}.link-del:hover{color:var(--coral)}

/* footer */
.site-footer{margin-top:72px;background:linear-gradient(120deg,#2c2542,#3b2a63);color:#fff}
.footer-inner{display:flex;gap:56px;flex-wrap:wrap;padding:46px 22px}
.footer-brand{font-weight:900;font-size:26px;
  background:linear-gradient(92deg,#a855f7,#22c9c0,#fb6f85,#ffd24d);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.site-footer a{color:#fff}.site-footer .muted{color:#b6aecf}
.socials a{display:block;margin-top:3px;font-size:14px;font-weight:700}
.notfound{text-align:center;padding:80px 0}

/* motion */
html.js-motion .reveal{opacity:0;transform:translateY(22px);transition:opacity .6s ease,transform .6s cubic-bezier(.22,.7,.2,1)}
html.js-motion .reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  html.js-motion .reveal{opacity:1;transform:none;transition:none}
  *{transition:none!important}
}

@media(max-width:980px){.usps{grid-template-columns:repeat(3,1fr)}}
@media(max-width:900px){
  .catalog-layout{grid-template-columns:1fr}
  .sidebar{display:none}
  h1{font-size:28px}h2{font-size:23px}
}
@media(max-width:760px){
  .product{grid-template-columns:1fr;gap:28px}
  .header-inner{flex-wrap:wrap;gap:10px;padding:10px 14px}
  .logo{order:1}
  .logo img{height:46px}
  .logo-city{display:none}
  .header-contacts{order:2;margin-left:auto;gap:12px}
  .phone{font-size:14px}
  .catalog-btn{order:3;padding:9px 14px}
  .search{order:4;flex-basis:100%;max-width:none}
  .catnav a{padding:11px 13px;font-size:13px}
  .catnav-arrow{width:32px;height:32px;font-size:20px}
  .buy-panel{max-width:none}
  .usps{grid-template-columns:repeat(2,1fr);gap:12px}
  .usp .ico{width:54px;height:54px;font-size:25px}
  .container{padding:0 14px}
  h1{font-size:24px}
}
@media(max-width:480px){
  .logo img{height:40px}
  .header-contacts .phone{display:none}
  .usps{grid-template-columns:1fr 1fr}
  .grid{grid-template-columns:repeat(2,1fr);gap:12px}
  .card{padding:10px}
  .card .btn{padding:10px;font-size:12px}
}
