*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --red:#e60023;--red-d:#c4001a;
  --black:#0f0f0f;--white:#fff;
  --gray:#767676;--gray-l:#f2f2f2;--gray-m:#e0e0e0;
  --bg:#efefef;--r:18px;--gap:10px;
  --spring:cubic-bezier(.34,1.56,.64,1);
  --snap:cubic-bezier(.16,1,.3,1);
  --ease:cubic-bezier(.4,0,.2,1);
}
html{scroll-behavior:auto}
body{
  font-family:'Manrope',system-ui,sans-serif;
  background:var(--bg);color:var(--black);
  min-height:100vh;overflow-x:hidden;
  -webkit-user-select:none;user-select:none;
}
input,textarea{-webkit-user-select:text;user-select:text}
*{scrollbar-width:none}::-webkit-scrollbar{display:none}
button{font:inherit;border:none;outline:none;cursor:pointer;background:none}
img{display:block;max-width:100%;pointer-events:none}
a{text-decoration:none;color:inherit}

/* ── HEADER ── */
.hdr{
  position:sticky;top:0;z-index:100;
  background:rgba(255,255,255,.88);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid rgba(0,0,0,.07);
  transition:box-shadow .3s;
}
.hdr.scrolled{box-shadow:0 4px 24px rgba(0,0,0,.08)}
.hdr-inner{
  display:flex;align-items:center;gap:12px;
  padding:0 16px;height:58px;
  max-width:1400px;margin:0 auto;
}

/* ── BURGER ── */
.burger-btn{
  display:flex;align-items:center;justify-content:center;
  width:38px;height:38px;flex-shrink:0;order:-1;
  border-radius:10px;background:none;
  transition:background .15s,transform .2s var(--spring);
}
.burger-btn:hover{background:#dbdbdb;}
.burger-btn:active{transform:scale(.88)}
.burger-btn.active svg rect{fill:#000000;}

/* ── LOGO ── */
.logo{
  display:flex;flex-direction:column;line-height:1;
  flex-shrink:0;cursor:default;
  transition:opacity .2s,transform .3s var(--spring);
}
.logo:hover{opacity:.75;transform:scale(1.04)}
.logo-line1{font-size:1.08rem;font-weight:900;display:flex;align-items:baseline}
.logo-red{color:var(--red);letter-spacing:-.02em}
.logo-tanya{color:var(--black);letter-spacing:-.02em}
.logo-mebel{font-size:.56rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:#bbb;margin-top:1px}

/* ── SEARCH ── */
.sw{
  flex:1;display:flex;align-items:center;
  background:var(--gray-l);
  border-radius:99px;padding:0 16px;height:40px;gap:8px;min-width:0;
  border:2px solid transparent;
  transition:border-color .25s,background .25s,box-shadow .25s;
}
.sw:focus-within{
  background:var(--white);
  border-color:rgba(0,0,0,.12);
  box-shadow:0 4px 20px rgba(0,0,0,.08);
}
.sw svg{flex-shrink:0;color:#aaa;transition:color .2s}
.sw:focus-within svg{color:var(--red)}
.si{
  flex:1;border:none;background:none;
  font-size:.88rem;font-weight:500;outline:none;
  min-width:0;color:var(--black);
  font-family:'Manrope',sans-serif;
}
.si::placeholder{color:#bbb}
.sc{
  display:none;width:20px;height:20px;border-radius:50%;
  background:var(--gray-m);color:var(--gray);
  font-size:.65rem;align-items:center;justify-content:center;
  transition:background .2s,transform .2s var(--spring);
  flex-shrink:0;
}
.sc.show{display:flex}
.sc:hover{background:var(--black);color:#fff;transform:rotate(90deg)}

/* ── SIDEBAR ── */
.sidebar-overlay{
  display:none;position:fixed;inset:0;
  background:rgba(0,0,0,.5);z-index:98;
  backdrop-filter:blur(4px);
  -webkit-backdrop-filter:blur(4px);
  opacity:0;transition:opacity .3s;
}
.sidebar-overlay.open{display:block;opacity:1}
.sidebar{
  position:fixed;top:0;left:0;
  width:300px;height:100dvh;
  background:var(--white);z-index:99;
  padding:0;
  box-shadow:8px 0 40px rgba(0,0,0,.15);
  transform:translateX(-100%);
  transition:transform .38s var(--snap);
  overflow-y:auto;display:flex;flex-direction:column;
}
.sidebar.open{transform:translateX(0)}
.sidebar-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:20px 20px 16px;
  border-bottom:1px solid var(--gray-l);
  position:sticky;top:0;background:var(--white);z-index:2;
}
.sidebar-header h2{font-size:1rem;font-weight:800;color:var(--black)}
.sidebar-close{
  width:34px;height:34px;border-radius:50%;
  background:var(--gray-l);
  display:flex;align-items:center;justify-content:center;
  font-size:.9rem;color:var(--gray);
  transition:background .2s,transform .3s var(--spring),color .2s;
}
.sidebar-close:hover{background:var(--black);color:#fff;transform:rotate(90deg)}
.sb-title{
  font-size:.65rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.15em;color:#bbb;
  padding:40px 20px 8px;
}
.sb-cat{
  display:flex;align-items:center;
  width:100%;text-align:left;
  padding:13px 20px;font-size:.92rem;font-weight:600;
  border-radius:0;color:#555;
  transition:background .15s,color .15s,padding-left .2s;
  border-left:3px solid transparent;
}
.sb-cat:hover{background:var(--gray-l);color:var(--black);padding-left:24px}
.sb-cat.on{background:#f8f8f8;color:var(--black);font-weight:700;border-left-color:var(--red)}

/* ── FEED ── */
.feed{min-height:80vh;padding:10px 10px 100px}

/* ── MASONRY ── */
.masonry{display:flex;gap:var(--gap);align-items:flex-start}
.mcol{flex:1;display:flex;flex-direction:column;gap:var(--gap);min-width:0}

/* ── CARD ── */
.card{
  margin-bottom:0;
  width:100%;
  border-radius:var(--r);
  overflow:hidden;
  background:var(--gray-m);
  cursor:pointer;
  position:relative;
  line-height:0;
  box-shadow:0 2px 12px rgba(0,0,0,.08);
  transform:translateY(0) scale(1);
  transition:transform .4s var(--spring),box-shadow .4s var(--ease);
  animation:cardIn .5s var(--snap) both;
  animation-delay:var(--delay,0ms);
}
@keyframes cardIn{
  from{opacity:0;transform:translateY(28px) scale(.95)}
  to{opacity:1;transform:translateY(0) scale(1)}
}
@media(min-width:768px){
  .card:hover{transform:translateY(-6px) scale(1.015);box-shadow:0 20px 48px rgba(0,0,0,.14)}
}
.card:active{transform:scale(.97)!important;box-shadow:0 4px 16px rgba(0,0,0,.1)!important}

.card-media-wrap{position:relative;overflow:hidden;line-height:0;background:#e0e0e0;width:100%}
.card-media-wrap img,
.card-media-wrap video{
  width:100%;height:100%;display:block;object-fit:cover;object-position:center center;
  transition:transform .6s var(--snap);
}
.card:hover .card-media-wrap img,
.card:hover .card-media-wrap video{transform:scale(1.06)}

/* Градиент снизу */
.card-media-wrap::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(
    to top,
    rgba(0,0,0,.42) 0%,
    rgba(0,0,0,.12) 35%,
    transparent 60%
  );
  pointer-events:none;
  transition:opacity .3s;
}
.card:hover .card-media-wrap::after{opacity:.7}

/* ── PILLS ── */
.card-bottom-bar{
  position:absolute;bottom:10px;left:10px;right:10px;
  display:flex;align-items:center;justify-content:space-between;
  gap:6px;z-index:2;pointer-events:none;
}
.card-price{
  background:rgba(20 20 20 / 47%);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  color:#fff;
  font-size:.77rem;font-weight:650;
  border-radius:99px;
  padding:14px 9px;
  white-space:nowrap;
  letter-spacing:-.02em;
  box-shadow:0 2px 12px rgba(0,0,0,.3);
  transition:transform .2s var(--spring);
}
.card:hover .card-price{transform:translateY(-2px)}
.card-discount{
  background:var(--red);color:#fff;
  font-size:.77rem;font-weight:800;
  border-radius:99px;
  padding:14px 9px;
  white-space:nowrap;
  min-width:45px;text-align:center;
  box-shadow:0 3px 10px rgba(230,0,35,.45);
  letter-spacing:-.01em;
  transition:transform .2s var(--spring);
}
.card:hover .card-discount{transform:translateY(-2px)}

/* ── LOADER ── */
.loader{display:none;justify-content:center;padding:32px}
.loader.show{display:flex}
.dots{display:flex;gap:7px;align-items:center}
.dots span{
  width:9px;height:9px;border-radius:50%;
  background:var(--gray-m);
  animation:dotPop 1.2s infinite ease-in-out;
}
.dots span:nth-child(2){animation-delay:.18s}
.dots span:nth-child(3){animation-delay:.36s}
@keyframes dotPop{
  0%,80%,100%{transform:scale(.6);background:var(--gray-m)}
  40%{transform:scale(1.2);background:var(--red)}
}

/* ── LIGHTBOX ── */
#lightbox{
  display:none;position:fixed;inset:0;z-index:9999;
  background:rgba(0,0,0,.96);
  flex-direction:column;align-items:center;justify-content:center;
  animation:fadeIn .25s var(--ease);
}
#lightbox.open{display:flex}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
#ifClose{
  position:absolute;top:16px;right:16px;
  width:42px;height:42px;border-radius:50%;
  background:rgba(255,255,255,.1);color:#fff;
  font-size:1.1rem;display:flex;align-items:center;justify-content:center;
  z-index:10;border:1px solid rgba(255,255,255,.15);
  transition:background .2s,transform .3s var(--spring);
}
#ifClose:hover{background:var(--red);transform:rotate(90deg)}
#ifImgWrap{flex:1;display:flex;align-items:center;justify-content:center;padding:60px 20px;width:100%}
#ifImg,#ifVid{max-width:100%;max-height:70vh;object-fit:contain;border-radius:8px}
#ifVid{display:none}
#ifBottomBar{display:flex;align-items:center;gap:16px;padding:16px}
#ifPrev,#ifNext{
  width:46px;height:46px;border-radius:50%;
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.15);
  color:#fff;font-size:1.5rem;
  display:flex;align-items:center;justify-content:center;
  transition:background .2s,transform .2s var(--spring);
}
#ifPrev:hover,#ifNext:hover{background:rgba(255,255,255,.2);transform:scale(1.1)}
#ifDots2{display:flex;gap:7px}
#ifDots2 button{
  width:7px;height:7px;border-radius:50%;
  background:rgba(255,255,255,.28);border:none;padding:0;cursor:pointer;
  transition:background .2s,transform .2s var(--spring);
}
#ifDots2 button.active{background:#fff;transform:scale(1.5)}

/* ── TOASTS ── */
#toasts{
  position:fixed;bottom:100px;left:50%;transform:translateX(-50%);
  z-index:9999;display:flex;flex-direction:column;gap:8px;
  pointer-events:none;align-items:center;
}
.toast{
  background:var(--black);color:#fff;
  padding:11px 22px;border-radius:99px;
  font-size:.82rem;font-weight:600;
  animation:toastIn .35s var(--spring);
  white-space:nowrap;
  box-shadow:0 6px 24px rgba(0,0,0,.25);
}
@keyframes toastIn{from{opacity:0;transform:translateY(12px) scale(.9)}to{opacity:1;transform:none}}

/* ── SCROLL TOP ── */
#stBtn{
  position:fixed;bottom:90px;left:20px;
  width:44px;height:44px;border-radius:50%;
  background:var(--white);
  box-shadow:0 4px 20px rgba(0,0,0,.14);
  display:flex;align-items:center;justify-content:center;
  z-index:40;color:var(--black);
  opacity:0;pointer-events:none;
  transform:translateY(12px) scale(.85);
  transition:opacity .3s,transform .35s var(--spring),background .2s;
}
#stBtn.show{opacity:1;pointer-events:auto;transform:translateY(0) scale(1)}
#stBtn:hover{background:var(--black);color:#fff;transform:translateY(-3px) scale(1.08)!important}
#stBtn:active{transform:scale(.92)!important}

/* ── CONTACT WIDGET ── */
#contactWidget{
  position:fixed;bottom:24px;right:20px;z-index:40;
  display:flex;flex-direction:column;align-items:center;gap:14px;
}
#contactToggle{
  width:56px;height:56px;border-radius:50%;
  background:var(--black);
  box-shadow:0 6px 24px rgba(0,0,0,.28);
  display:flex;align-items:center;justify-content:center;
  border:none;cursor:pointer;color:#fff;position:relative;
  transition:transform .35s var(--spring),background .2s,box-shadow .2s;
}
#contactToggle:hover{transform:scale(1.1);box-shadow:0 10px 32px rgba(0,0,0,.3)}
#contactToggle:active{transform:scale(.9)}
#contactToggle.open{background:#222}
.contact-badge{
  position:absolute;top:-3px;right:-3px;
  width:20px;height:20px;border-radius:50%;
  background:var(--red);color:#fff;
  font-size:.58rem;font-weight:800;
  display:flex;align-items:center;justify-content:center;
  border:2px solid #fff;
  font-family:'Manrope',sans-serif;
  animation:badgePop .4s var(--spring);
}
@keyframes badgePop{from{transform:scale(0)}to{transform:scale(1)}}
#contactToggle .icon-x{display:none}
#contactToggle.open .icon-msg{display:none}
#contactToggle.open .icon-x{display:block}
#contactBtns{
  display:flex;flex-direction:column;align-items:center;gap:14px;
  opacity:0;pointer-events:none;
  transform:translateY(16px) scale(.9);
  transition:opacity .3s var(--ease),transform .35s var(--spring);
}
#contactBtns.open{opacity:1;pointer-events:auto;transform:translateY(0) scale(1)}
.fab-btn{
  width:52px;height:52px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  border:none;cursor:pointer;
  box-shadow:0 6px 20px rgba(0,0,0,.18);
  transition:transform .3s var(--spring),box-shadow .2s;
  position:relative;text-decoration:none;
}
.fab-btn:hover{transform:scale(1.12);box-shadow:0 10px 28px rgba(0,0,0,.22)}
.fab-btn:active{transform:scale(.9)}
.fab-vk{background:#0077ff}
.fab-phone{background:#ff5500}
.fab-label{
  position:absolute;right:64px;
  background:rgba(15,15,15,.92);
  backdrop-filter:blur(8px);
  color:#fff;font-size:.78rem;font-weight:700;
  border-radius:10px;padding:6px 14px;
  white-space:nowrap;font-family:'Manrope',sans-serif;
  box-shadow:0 4px 16px rgba(0,0,0,.2);
  pointer-events:none;
  opacity:0;transform:translateX(8px);
  transition:opacity .2s,transform .2s;
}
.fab-btn:hover .fab-label{opacity:1;transform:translateX(0)}
.fab-label::after{
  content:'';position:absolute;right:-6px;top:50%;
  transform:translateY(-50%);
  border:5px solid transparent;
  border-right:none;border-left-color:rgba(15,15,15,.92);
}

/* ── RESPONSIVE ── */
@media(max-width:480px){
  .hdr-inner{gap:8px;padding:0 12px}
  .logo-line1{font-size:.95rem}
  .feed{padding:8px 8px 100px}
}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
}
