/* SAYFORME — ОБЩИЕ КОМПОНЕНТЫ (шапка, меню, футер, рассылка, оверлёры) */
/* Единый источник для прототипа и будущей WordPress-темы. */

/* ============================================================
   RESET
   ============================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;}
body{
  font-family:var(--font);
  background:var(--bg);
  color:var(--ink);
  line-height:1.5;
  overflow-x:hidden;
}
img{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit;}
ul{list-style:none;}

:focus-visible{outline:2px solid var(--ink);outline-offset:3px;}

.eyebrow{text-transform:uppercase;}

/* ============================================================
   ХЕДЕР / NAV
   ============================================================ */
.nav{
  position:sticky;top:0;z-index:100;
  height:var(--nav-h);
  display:flex;align-items:center;justify-content:space-between;
  padding:0 var(--pad-x);
  background:var(--bg);
  border-bottom:1px solid var(--border);
}
.nav__side{flex:1 0 0;min-width:0;display:flex;align-items:center;}
.nav__side--right{justify-content:flex-end;gap:0;}

.nav__menu{
  position:relative;
  display:flex;align-items:center;gap:10px;
  color:var(--muted);
}
.nav__menu-label{
  font-weight:500;font-size:13px;letter-spacing:1.43px;text-transform:uppercase;
}
.nav__burger{display:flex;flex-direction:column;gap:3px;width:20px;}
.nav__burger span{display:block;height:1px;background:currentColor;width:100%;}

.nav__logo{display:flex;align-items:center;flex:0 0 auto;position:relative;z-index:3;transform:translateY(13px);}
.nav__logo img{height:53px;width:auto;max-width:none;display:block;}

.nav__icon{
  position:relative;
  width:40px;height:40px;
  display:flex;align-items:center;justify-content:center;
  color:var(--ink);transition:opacity .2s ease;
}
.nav__icon:hover{opacity:.55;}
.nav__icon svg{display:block;}
.nav__icon-badge{
  position:absolute;top:3px;right:1px;min-width:16px;height:16px;padding:0 4px;box-sizing:border-box;
  display:flex;align-items:center;justify-content:center;
  background:var(--ink);color:#fff;border-radius:9px;
  font-weight:600;font-size:9px;line-height:1;
}
.nav__icon-badge[data-count="0"]{display:none;}

/* ИЗБРАННОЕ — бейдж в шапке (отдельный класс, чтобы фрагменты корзины не затирали) */
.nav__wish-badge{
  position:absolute;top:3px;right:1px;min-width:16px;height:16px;padding:0 4px;box-sizing:border-box;
  display:flex;align-items:center;justify-content:center;
  background:var(--ink);color:#fff;border-radius:9px;
  font-weight:600;font-size:9px;line-height:1;
}
.nav__wish-badge[data-count="0"]{display:none;}

/* Переключатель избранного — общие правила (иконки, активное, пульс) */
.wishlist-toggle{cursor:pointer;}
.wishlist-toggle .ico-x{display:none;}
.wishlist-toggle.is-active .ico-heart{fill:currentColor;}
.wishlist-toggle--remove .ico-heart{display:none;}
.wishlist-toggle--remove .ico-x{display:block;}
.wishlist-toggle.is-pulse{animation:wishPulse .28s ease;}
@keyframes wishPulse{0%{transform:scale(1);}40%{transform:scale(1.22);}100%{transform:scale(1);}}

/* Угловая кнопка-кружок на карточках (каталог + избранное) */
.product-card-wrap{position:relative;}
.product-card-wrap .wishlist-toggle,
.wl-card .wishlist-toggle{
  position:absolute;top:14px;right:14px;z-index:4;
  width:38px;height:38px;display:flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.92);border:none;border-radius:50%;color:var(--ink);padding:0;
  transition:background .2s ease,transform .15s ease,opacity .25s ease;
}
.product-card-wrap .wishlist-toggle:hover,
.wl-card .wishlist-toggle:hover{background:#fff;}
/* В каталоге сердечко проявляется на ховер; активное — всегда видно */
.product-card-wrap .wishlist-toggle{opacity:0;transform:translateY(-4px);}
.product-card-wrap:hover .wishlist-toggle,
.product-card-wrap .wishlist-toggle.is-active,
.product-card-wrap:focus-within .wishlist-toggle{opacity:1;transform:none;}
@media (hover:none){.product-card-wrap .wishlist-toggle{opacity:1;transform:none;}}

/* ПОЛНОЭКРАННОЕ МЕНЮ → боковой drawer слева (шаблон Figma 89:778) */
.menu-overlay{
  position:fixed;inset:0;z-index:200;
  visibility:hidden;transition:visibility .35s;
}
.menu-overlay[data-open="true"]{visibility:visible;}
.menu-overlay__backdrop{
  position:absolute;inset:0;background:rgba(10,10,10,.35);
  opacity:0;transition:opacity .35s ease;
}
.menu-overlay[data-open="true"] .menu-overlay__backdrop{opacity:1;}
.menu-overlay__panel{
  position:absolute;left:0;top:0;height:100%;width:min(340px,86vw);
  background:var(--bg);overflow-y:auto;
  transform:translateX(-100%);transition:transform .35s cubic-bezier(.2,.7,.2,1);
}
.menu-overlay[data-open="true"] .menu-overlay__panel{transform:translateX(0);}
.menu-overlay__inner{
  min-height:100%;box-sizing:border-box;
  padding:44px;
  display:flex;flex-direction:column;justify-content:space-between;gap:48px;
}
.menu-overlay__close{
  position:fixed;top:24px;right:24px;z-index:1;
  width:40px;height:40px;
  display:flex;align-items:center;justify-content:center;color:var(--ink);
  transition:opacity .2s ease;
}
.menu-overlay__close:hover{opacity:.5;}

.menu-nav{display:flex;flex-direction:column;align-items:flex-start;gap:24px;}
.menu-nav>a,.menu-nav__group>a{
  font-weight:500;font-size:16px;letter-spacing:1.43px;text-transform:uppercase;
  color:var(--ink-pure);line-height:1;transition:opacity .2s ease;
}
.menu-nav a:hover{opacity:.5;}
.menu-nav__group{display:flex;flex-direction:column;align-items:flex-start;gap:16px;}
.menu-nav__sub{display:flex;flex-direction:column;gap:14px;padding-left:16px;}
.menu-nav__sub a{
  font-weight:500;font-size:16px;letter-spacing:1.43px;
  color:var(--ink-pure);line-height:1;transition:opacity .2s ease;
}

.menu-contacts{display:flex;flex-direction:column;align-items:flex-start;gap:16px;}
.menu-contacts__title{
  font-weight:500;font-size:16px;letter-spacing:1.43px;text-transform:uppercase;
  color:var(--ink-pure);line-height:1;
}
.menu-contacts__phone{font-weight:400;font-size:14px;color:var(--ink-pure);transition:opacity .2s ease;}
.menu-contacts__phone:hover{opacity:.5;}
.menu-contacts__social{display:flex;gap:16px;align-items:center;}
.menu-contacts__social a{
  width:24px;height:24px;display:flex;align-items:center;justify-content:center;
  color:var(--ink-pure);transition:opacity .2s ease;
}
.menu-contacts__social a:hover{opacity:.5;}


/* ============================================================
   NEWSLETTER «БУДЬТЕ ПЕРВЫМИ»
   ============================================================ */
.newsletter{
  padding:90px var(--pad-x);
  display:flex;flex-direction:column;align-items:center;
}
.newsletter__title{
  font-weight:300;font-size:clamp(36px,2.917vw,56px);line-height:1;color:var(--ink);
  text-align:center;margin-bottom:16px;
}
.newsletter__lead{
  font-weight:400;font-size:14px;line-height:24px;color:var(--muted);
  text-align:center;max-width:627px;margin-bottom:40px;
}

.benefits{
  display:flex;gap:14px;width:835px;max-width:100%;margin-bottom:44px;
}
.benefit{flex:1 1 0;display:flex;gap:14px;align-items:flex-start;}
.benefit__icon{
  flex-shrink:0;width:32px;height:32px;
  border:1px solid var(--border-2);
  display:flex;align-items:center;justify-content:center;
  color:var(--ink);
}
.benefit__title{font-weight:600;font-size:14px;letter-spacing:.48px;color:var(--ink);line-height:1.5;}
.benefit__desc{font-weight:400;font-size:12px;line-height:18.15px;color:var(--muted-2);margin-top:6px;}

.subscribe{width:835px;max-width:100%;display:flex;flex-direction:column;gap:10px;}
.subscribe__label{
  font-weight:600;font-size:9px;letter-spacing:1.8px;text-transform:uppercase;color:var(--muted);
}
.subscribe__row{display:flex;}
.subscribe__input{
  flex:1 1 0;min-width:0;
  background:#fff;border:1px solid var(--border-input);
  padding:15px 16px 15px 17px;
  font-family:inherit;font-size:12px;color:var(--ink);
  transition:border-color .2s ease,box-shadow .2s ease;
}
.subscribe__input:focus,.subscribe__input:focus-visible{
  outline:none;
  border-color:var(--ink);
  box-shadow:inset 0 0 0 1px var(--ink);
}
.subscribe__input::placeholder{color:var(--border-input);}
.subscribe__btn{
  background:var(--ink);color:#fff;
  padding:16px 28px;
  font-weight:600;font-size:10px;letter-spacing:1.8px;text-transform:uppercase;
  white-space:nowrap;transition:opacity .2s ease;
}
.subscribe__btn:hover{opacity:.85;}
.subscribe__note{
  font-weight:400;font-size:10px;line-height:17px;color:var(--muted-2);padding-top:2px;
}
.subscribe__note a{color:var(--muted);text-decoration:underline;text-underline-offset:2px;}

.socials{
  width:835px;max-width:100%;
  margin-top:48px;padding-top:37px;
  border-top:1px solid var(--border-2);
  display:flex;flex-direction:column;align-items:center;gap:16px;
}
.socials__label{
  font-weight:600;font-size:9px;letter-spacing:1.8px;text-transform:uppercase;color:var(--muted-2);
}
.socials__row{display:flex;gap:12px;justify-content:center;}
.social-link{
  display:flex;align-items:center;gap:8px;
  border:1px solid var(--border-2);
  padding:11px 17px;color:var(--muted);
  transition:border-color .2s ease,color .2s ease;
}
.social-link:hover{border-color:var(--muted);color:var(--ink);}
.social-link__label{font-weight:500;font-size:10px;letter-spacing:1px;text-transform:uppercase;}


/* ============================================================
   ФУТЕР
   ============================================================ */
.footer{
  background:var(--footer-bg);color:#fff;
  padding:44px;
  display:grid;
  grid-template-columns:1.4fr 1fr 1fr 1fr;
  gap:40px;
}
.footer__brand{display:flex;flex-direction:column;gap:13px;}
.footer__logo{width:167px;height:51px;object-fit:contain;object-position:left center;}
.footer__brand-text{font-weight:400;font-size:14px;line-height:1.6;color:#fff;}
.footer__col-title{
  font-weight:600;font-size:10px;letter-spacing:1.8px;text-transform:uppercase;color:#fff;
  margin-bottom:18px;
}
.footer__list{display:flex;flex-direction:column;gap:10px;}
.footer__list a,.footer__list span{
  font-weight:400;font-size:12px;color:#fff;
  transition:opacity .2s ease;
}
.footer__list a:hover{opacity:.6;}


/* Скролл-ревилы */
/* Скролл-ревилы */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease;}
.reveal.is-visible{opacity:1;transform:none;}

/* Поиск */
.search{position:fixed;inset:0;z-index:120;visibility:hidden;}
.search[aria-hidden="false"]{visibility:visible;}
.search__backdrop{position:absolute;inset:0;z-index:0;background:rgba(10,10,10,.35);opacity:0;transition:opacity .3s ease;}
.search[aria-hidden="false"] .search__backdrop{opacity:1;}
.search__panel{position:absolute;top:0;left:0;right:0;z-index:1;background:#fff;transform:translateY(-100%);transition:transform .35s cubic-bezier(.2,.7,.2,1);max-height:82vh;overflow-y:auto;}
.search[aria-hidden="false"] .search__panel{transform:none;}
.search__bar{display:flex;align-items:center;gap:16px;padding:22px 40px;border-bottom:1px solid var(--border-2);}
.search__icon{flex-shrink:0;color:var(--muted-2);}
.search__input{flex:1 1 0;min-width:0;border:0;outline:0;background:none;font-family:inherit;font-size:20px;color:var(--ink);}
.search__input::placeholder{color:var(--border-input);}
.search__close{flex-shrink:0;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:none;border:0;cursor:pointer;color:var(--ink);transition:opacity .2s ease;}
.search__close:hover{opacity:.55;}
.search__body{padding:24px 40px 40px;}
.search__hint-label,.search__results-label{display:block;font-weight:600;font-size:9px;letter-spacing:1.8px;text-transform:uppercase;color:var(--muted-2);margin-bottom:16px;}
.search__tags{display:flex;flex-wrap:wrap;gap:10px;}
.search__tag{border:1px solid var(--border-2);background:#fff;padding:9px 16px;font-family:inherit;font-size:13px;color:var(--muted);cursor:pointer;transition:border-color .2s ease,color .2s ease;}
.search__tag:hover{border-color:var(--ink);color:var(--ink);}
.search__results{display:flex;flex-direction:column;}
.search__row{display:flex;align-items:center;gap:16px;padding:12px 0;border-bottom:1px solid var(--border-2);color:inherit;text-decoration:none;}
.search__row:hover .search__row-name{text-decoration:underline;text-underline-offset:2px;}
.search__row-img{width:54px;height:72px;flex-shrink:0;background:#e9e7e3;overflow:hidden;}
.search__row-img img{width:100%;height:100%;object-fit:cover;display:block;}
.search__row-info{display:flex;flex-direction:column;gap:4px;}
.search__row-name{font-size:15px;color:var(--ink);}
.search__row-price{font-size:13px;color:var(--muted);}
.search__empty{text-align:center;padding:32px 0 8px;}
.search__empty-title{font-family:var(--font-serif);font-style:italic;font-weight:400;font-size:28px;color:var(--ink);margin-bottom:10px;}
.search__empty-sub{font-size:14px;color:var(--muted);margin-bottom:22px;}
.search__empty-btn{display:inline-flex;align-items:center;justify-content:center;background:var(--ink);color:#fff;padding:14px 30px;font-weight:600;font-size:10px;letter-spacing:1.8px;text-transform:uppercase;}
.search__footer{margin-top:22px;}
.search__footer a{font-weight:600;font-size:11px;letter-spacing:.5px;text-transform:uppercase;color:var(--ink);text-decoration:none;border-bottom:1px solid var(--ink);padding-bottom:3px;}
body.search-open{overflow:hidden;}
@media (max-width:768px){
  .search__bar{padding:16px 20px;}
  .search__input{font-size:17px;}
  .search__body{padding:20px 20px 32px;}
}

/* Мини-корзина */
.minicart{position:fixed;inset:0;z-index:125;visibility:hidden;}
.minicart[aria-hidden="false"]{visibility:visible;}
.minicart__backdrop{position:absolute;inset:0;z-index:0;background:rgba(10,10,10,.35);opacity:0;transition:opacity .3s ease;}
.minicart[aria-hidden="false"] .minicart__backdrop{opacity:1;}
.minicart__panel{position:absolute;top:58px;right:24px;z-index:1;width:min(380px,calc(100vw - 32px));max-height:calc(100vh - 80px);background:#fff;border:1px solid var(--border-2);box-shadow:0 18px 50px rgba(10,10,10,.16);display:flex;flex-direction:column;transform:translateY(-10px);opacity:0;transition:transform .25s ease,opacity .25s ease;}
.minicart[aria-hidden="false"] .minicart__panel{transform:none;opacity:1;}
.minicart__head{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid var(--border-2);}
.minicart__title{font-weight:500;font-size:15px;color:var(--ink);}
.minicart__count{color:var(--muted-2);font-weight:400;}
.minicart__close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:none;border:0;cursor:pointer;color:var(--ink);transition:opacity .2s ease;}
.minicart__close:hover{opacity:.55;}
.minicart__items{overflow-y:auto;padding:4px 20px;flex:1 1 auto;}
.mc-item{display:flex;gap:14px;padding:14px 0;border-bottom:1px solid var(--border-2);}
.mc-item:last-child{border-bottom:0;}
.mc-item__img{width:60px;height:78px;flex-shrink:0;background:#e9e7e3;overflow:hidden;}
.mc-item__img img{width:100%;height:100%;object-fit:cover;display:block;}
.mc-item__info{flex:1 1 0;min-width:0;display:flex;flex-direction:column;gap:4px;}
.mc-item__name{font-size:14px;color:var(--ink);}
.mc-item__meta{font-size:12px;color:var(--muted-2);}
.mc-item__price{font-size:13px;color:var(--ink);margin-top:auto;}
.mc-item__remove{align-self:flex-start;background:none;border:0;cursor:pointer;color:var(--muted-2);font-size:18px;line-height:1;padding:0 2px;transition:color .2s ease;}
.mc-item__remove:hover{color:var(--ink);}
.minicart__foot{padding:18px 20px;border-top:1px solid var(--border-2);display:flex;flex-direction:column;gap:10px;}
.minicart__subtotal{display:flex;align-items:center;justify-content:space-between;font-size:14px;color:var(--ink);margin-bottom:4px;}
.minicart__subtotal span:last-child{font-family:var(--font-serif);font-size:20px;}
.minicart__btn{display:flex;align-items:center;justify-content:center;padding:15px;font-weight:600;font-size:10px;letter-spacing:1.8px;text-transform:uppercase;text-align:center;transition:opacity .2s ease;}
.minicart__btn--solid{background:var(--ink);color:#fff;}
.minicart__btn--solid:hover{opacity:.85;}
.minicart__btn--outline{border:1px solid var(--ink);color:var(--ink);}
.minicart__btn--outline:hover{background:#fafafa;}
.minicart__empty{display:flex;flex-direction:column;align-items:center;text-align:center;padding:48px 20px;}
.minicart__empty svg{width:56px;height:56px;color:var(--muted-2);margin-bottom:18px;}
.minicart__empty-title{font-family:var(--font-serif);font-style:italic;font-weight:400;font-size:24px;color:var(--ink);margin-bottom:20px;}
.minicart__empty a{display:inline-flex;background:var(--ink);color:#fff;padding:13px 28px;font-weight:600;font-size:10px;letter-spacing:1.8px;text-transform:uppercase;}
@media (max-width:768px){
  .minicart__panel{top:54px;right:10px;width:calc(100vw - 20px);}
}

[hidden]{display:none!important;}
/* Cookie-баннер */
.cookie{position:fixed;left:0;right:0;bottom:0;z-index:115;background:#fff;border-top:1px solid var(--border-2);box-shadow:0 -8px 30px rgba(10,10,10,.06);display:flex;align-items:center;gap:24px;padding:18px 40px;}
.cookie__text{flex:1 1 0;min-width:0;font-size:13px;line-height:1.5;color:var(--muted);}
.cookie__text a{color:var(--ink);text-decoration:underline;text-underline-offset:2px;}
.cookie__actions{display:flex;gap:10px;flex-shrink:0;}
.cookie__btn{padding:12px 26px;font-weight:600;font-size:10px;letter-spacing:1.6px;text-transform:uppercase;cursor:pointer;transition:opacity .2s ease,border-color .2s ease;}
.cookie__btn--solid{background:var(--ink);color:#fff;border:1px solid var(--ink);}
.cookie__btn--solid:hover{opacity:.85;}
.cookie__btn--ghost{background:#fff;border:1px solid var(--border-2);color:var(--ink);}
.cookie__btn--ghost:hover{border-color:var(--ink);}
@media (max-width:768px){.cookie{flex-direction:column;align-items:stretch;gap:14px;padding:16px 20px;}.cookie__btn{flex:1 1 0;}}


/* ОБЩАЯ АДАПТИВНОСТЬ (шапка/меню/футер) */
@media (max-width:768px){
  :root{--pad-x:20px;}
  .nav__menu-label{display:none;}
  .nav__logo{transform:translateY(6px);}
  .nav__logo img{height:32px;width:auto;}
  .nav__icon{width:36px;height:36px;}
  .menu-overlay__inner{padding:28px 24px;gap:40px;}
  .menu-overlay__close{top:20px;right:20px;}
  .footer{grid-template-columns:1fr;gap:32px;}
}
@media (prefers-reduced-motion:reduce){
  *{transition:none!important;scroll-behavior:auto!important;}
  .reveal{opacity:1;transform:none;}
}
