

/* Start:/local/templates/formula/template_styles.css?1781028603122452*/
/* ===================== Формула Духов — стиль-лист ===================== */
/* Палитра G «Нуар & роза» — графичный чёрный + премиальная роза. Все цвета — токены (единый источник правды). */
:root{
  --bg:#FFFFFF; --surface:#FBF4F6; --surface-2:#F3E7EC;
  --ink:#19171A; --ink-2:#4C464C; --muted:#7A727A;
  --line:rgba(25,23,26,.10); --line-2:rgba(25,23,26,.18);
  --dark:#19171A; --dark-2:#241F26; --dark-line:rgba(255,255,255,.12);
  --accent:#E0668E; /* премиальная роза — заливки/ховеры/декор */
  --accent-text:#B23A63; /* контрастный акцент для текста/мелких бейджей (AA ~5.7:1) */
  --radius:12px;  /* сдержанные скругления (бренд-стандарт «Формула Духов») */
  --card-gap:32px;
  --font-display:'Manrope','Manrope Fallback',system-ui,sans-serif;
  --font-body:'Manrope','Manrope Fallback',system-ui,sans-serif;
  --maxw:1480px;
  --ease:cubic-bezier(.4,0,.2,1);
}
*{box-sizing:border-box;}
html,body{margin:0;padding:0;}
body{background:var(--bg);color:var(--ink);font-family:var(--font-body);font-size:16.5px;line-height:1.5;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;}
button{font-family:inherit;cursor:pointer;}
input,select{font-family:inherit;}
img,svg{display:block;}
::selection{background:color-mix(in srgb,var(--accent) 30%,transparent);}

/* Self-host Manrope (вариативный, веса 400–700): без запроса к Google (152-ФЗ-friendly) и без CLS от свопа.
   Один woff2 на субсет покрывает все веса; раздача по unicode-range (RU+EN). */
@font-face{font-family:'Manrope';font-style:normal;font-weight:200 800;font-display:swap;src:url(/local/templates/formula/fonts/manrope-cyrillic-ext.woff2) format('woff2');unicode-range:U+0460-052F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F;}
@font-face{font-family:'Manrope';font-style:normal;font-weight:200 800;font-display:swap;src:url(/local/templates/formula/fonts/manrope-cyrillic.woff2) format('woff2');unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116;}
@font-face{font-family:'Manrope';font-style:normal;font-weight:200 800;font-display:swap;src:url(/local/templates/formula/fonts/manrope-latin-ext.woff2) format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:'Manrope';font-style:normal;font-weight:200 800;font-display:swap;src:url(/local/templates/formula/fonts/manrope-latin.woff2) format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
/* Метрико-согласованный фолбэк на время загрузки woff2 — текст не «прыгает». src с фолбэками для разных ОС:
   Arial (Win/Mac) и Liberation Sans (Linux) метрически идентичны → size-adjust 103.96% корректен для обоих. */
@font-face{font-family:'Manrope Fallback';src:local('Arial'),local('Liberation Sans'),local('Helvetica Neue');size-adjust:103.96%;ascent-override:96.18%;descent-override:27.06%;line-gap-override:0%;}

/* Нативный скролл окна (НЕ внутренний overflow-контейнер) — компоновочный быстрый путь, без дёрганья */
html{scroll-behavior:smooth;scrollbar-gutter:stable;}
html.no-scroll{overflow:hidden;} /* gutter:stable резервирует место скроллбара → нет сдвига страницы при открытии попапа/корзины */
.app{display:flex;flex-direction:column;}
.app-scroll{min-width:0;}
.section{max-width:var(--maxw);margin:0 auto;padding:60px 32px 0;}
.section:last-of-type{padding-bottom:80px;}

/* ---------- typography helpers ---------- */
.eyebrow{font-family:var(--font-body);font-size:13px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);display:inline-block;}
.eyebrow-light{color:#E9A6BE;}
.section-h2{font-family:var(--font-display);font-weight:400;font-size:clamp(30px,3.4vw,42px);line-height:1.04;letter-spacing:-.01em;margin:.32em 0 0;color:var(--ink);}
.section-head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;margin-bottom:32px;}
.link-arrow{background:none;border:none;color:var(--ink-2);font-size:15px;font-weight:600;display:inline-flex;align-items:center;gap:7px;padding:6px 2px;transition:color .15s var(--ease);}
.link-arrow svg{transition:transform .15s var(--ease);}
.link-arrow:hover{color:var(--accent);}
.link-arrow:hover svg{transform:translateX(3px);}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;border:1px solid transparent;border-radius:10px;font-weight:600;letter-spacing:.01em;white-space:nowrap;transition:background .16s var(--ease),color .16s var(--ease),border-color .16s var(--ease),filter .16s var(--ease);}
.btn-sm{padding:8px 15px;font-size:14px;}
.btn-md{padding:11px 21px;font-size:14px;}
.btn-lg{padding:15px 28px;font-size:16px;}
.btn-full{width:100%;}
.btn-dark,.btn-primary{background:var(--ink);color:#fff;}
.btn-dark:hover,.btn-primary:hover{background:var(--accent);color:#fff;}
.btn-gold{background:var(--accent);color:#fff;}
.btn-gold:hover{filter:brightness(1.08);}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line-2);}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent);}
.btn-ghost-light{background:transparent;color:#fff;border-color:rgba(255,255,255,.42);}
.btn-ghost-light:hover{border-color:#fff;background:rgba(255,255,255,.08);}
.btn-white{background:#fff;color:var(--ink);}
.btn-white:hover{background:rgba(255,255,255,.88);}

/* ---------- bottle ---------- */

/* ---------- header ---------- */
/* без backdrop-filter: blur поверх ПРОИГРЫВАЮЩЕГОСЯ видео при скролле = дёрганье (GPU пересчитывает размытие каждый кадр). Делаем плотный полупрозрачный фон. */
.hd{position:sticky;top:0;z-index:60;background:color-mix(in srgb,var(--bg) 90%,transparent);border-bottom:1px solid transparent;transition:border-color .2s,background .2s;}
.hd-scroll{border-color:var(--line);background:color-mix(in srgb,var(--bg) 94%,transparent);}
.hd-inner{max-width:var(--maxw);margin:0 auto;padding:0 32px;height:74px;display:flex;align-items:center;gap:40px;}
.logo{display:inline-flex;align-items:center;gap:11px;background:none;border:none;font-family:var(--font-display);font-size:24px;letter-spacing:.005em;line-height:1;color:var(--ink);padding:0;font-weight:700;cursor:pointer;text-decoration:none;}
.logo-mark{width:auto;height:56px;flex-shrink:0;will-change:transform;}
.logo-dot{color:var(--accent-text);}
/* hover-анимация знака «ФД»: плавный оборот + лёгкий «вдох». Отключается при reduced-motion. */
@media (prefers-reduced-motion: no-preference){
  @keyframes fdSpin{50%{transform:rotate(180deg) scale(1.09);}to{transform:rotate(360deg) scale(1);}}
  .logo:hover .logo-mark{animation:fdSpin .7s cubic-bezier(.4,0,.2,1);}
}
.hd-nav{display:flex;gap:30px;flex:1;align-items:center;transform:translateY(3px);} /* меню выровнено по БАЗОВОЙ ЛИНИИ текста логотипа (замер: nav был на 3.3px выше baseline лого 24px) */
.hd-nav a{background:none;border:none;font-size:15.5px;color:var(--ink-2);padding:6px 0;position:relative;transition:color .15s;text-decoration:none;cursor:pointer;}
.hd-nav a::after{content:"";position:absolute;left:0;bottom:3px;height:2px;width:0;background:repeating-linear-gradient(90deg,var(--accent) 0 4px,transparent 4px 7px);transition:width .2s var(--ease);}
.hd-nav a:hover{color:var(--ink);}
.hd-nav a:hover::after{width:100%;}
.hd-actions{display:flex;align-items:center;gap:6px;}
.hd-ic{background:none;border:none;width:48px;height:48px;border-radius:12px;display:grid;place-items:center;color:var(--ink);position:relative;transition:background .15s,color .15s;}
.hd-ic:hover{background:var(--surface-2);color:var(--accent);}
.ic-badge{position:absolute;top:5px;right:4px;min-width:18px;height:18px;padding:0 4px;border-radius:9px;background:var(--accent);color:#fff;font-size:11.5px;font-weight:700;line-height:1;display:grid;place-items:center;border:2px solid var(--bg);}
/* Корзина выделена акцентной заливкой (выбор пользователя) — остальные иконки нейтральны */
.hd-cart{background:var(--accent);color:#fff;border-radius:50%;}
.hd-cart:hover{background:var(--accent-text);color:#fff;}
.hd-cart .ic-badge{background:#fff;color:var(--accent-text);border-color:var(--accent);}
/* бутерброд-меню (видно там, где десктоп-навигация скрыта) */
.hd-burger{display:none;background:none;border:none;width:48px;height:48px;border-radius:12px;place-items:center;color:var(--ink);margin-left:-6px;}
.hd-burger:hover{background:var(--surface-2);color:var(--accent);}
.hd-menu{display:none;}
/* личные действия (избранное/профиль) в бургер-меню — показываются только на узком мобайле, где иконки убраны из шапки */
.hd-menu-personal{display:none;border-top:1px solid var(--line);}
.hd-menu-act{display:flex;align-items:center;gap:12px;width:100%;text-align:left;background:none;border:none;border-bottom:1px solid var(--line);padding:15px 32px;font-size:16px;color:var(--ink);min-height:52px;}
.hd-menu-act:last-child{border-bottom:none;}
.hd-menu-act svg{color:var(--accent);flex-shrink:0;}
.hd-menu-act:hover,.hd-menu-act:active{background:var(--surface);color:var(--accent);}
.hd-menu-count{margin-left:auto;min-width:20px;height:20px;padding:0 6px;border-radius:10px;background:var(--accent);color:#fff;font-size:12px;font-weight:700;line-height:1;display:grid;place-items:center;}

/* ---------- hero (bold full-bleed banner) ---------- */
.hero{position:relative;color:#fff;overflow:hidden;min-height:580px;display:flex;align-items:center;}
.hero-bg{position:absolute;inset:0;z-index:0;background:#1a1a22;transform:translateZ(0);}
.hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .8s var(--ease);}
.hero-video.on{opacity:1;}
.hero-scrim{position:absolute;inset:0;z-index:1;background:linear-gradient(90deg,rgba(15,12,14,.74) 0%,rgba(15,12,14,.46) 33%,rgba(15,12,14,.1) 60%,transparent 100%);}
/* десктоп: текст героя начинается от центра и идёт вправо (визуал слева, текст справа — как в референсе),
   скрим затемняет правую часть, где лежит текст */
@media(min-width:1101px){
  .hero .hero-copy{margin-left:50%;max-width:500px;}
  .hero .hero-scrim{background:linear-gradient(90deg,transparent 28%,rgba(15,12,14,.42) 62%,rgba(15,12,14,.72) 100%);}
}
.hero-inner{position:relative;z-index:2;width:100%;max-width:var(--maxw);margin:0 auto;padding:84px 32px 96px;min-height:580px;display:flex;align-items:center;}
.hero .eyebrow{color:rgba(255,255,255,.9);}
.hero-copy{max-width:600px;animation:fadeUp .55s var(--ease);}
.hero-h1{font-family:var(--font-display);font-weight:400;font-size:clamp(40px,5.8vw,78px);line-height:1.0;letter-spacing:-.02em;margin:.18em 0 .3em;color:#fff;white-space:pre-line;text-shadow:0 1px 2px rgba(0,0,0,.55),0 2px 26px rgba(0,0,0,.4);}
.hero-sub{font-size:17.5px;line-height:1.6;color:#fff;max-width:470px;margin:0 0 28px;text-shadow:0 1px 2px rgba(0,0,0,.5),0 1px 14px rgba(0,0,0,.35);}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:30px;}
.hero-feature{display:inline-flex;align-items:center;gap:13px;background:rgba(255,255,255,.22);border:1px solid rgba(255,255,255,.3);border-radius:10px;padding:9px 18px 9px 9px;color:#fff;transition:background .15s,transform .15s;}
.hero-feature:hover{background:rgba(255,255,255,.24);transform:translateY(-2px);}
.hero-feature-media{width:48px;height:48px;border-radius:12px;overflow:hidden;flex-shrink:0;}
.hero-feature-media img{width:100%;height:100%;object-fit:cover;}
.hero-feature-txt{display:flex;flex-direction:column;text-align:left;line-height:1.18;}
.hero-feature-eyebrow{font-size:12px;text-transform:uppercase;letter-spacing:.16em;opacity:.8;}
.hero-feature-name{font-family:var(--font-display);font-size:18px;}
.hero-feature-price{font-size:14px;font-weight:600;margin-left:6px;}
.hero-dots{position:absolute;left:32px;bottom:34px;display:flex;gap:10px;z-index:3;}
.hero-dots button{width:44px;height:3px;border-radius:2px;border:none;background:rgba(255,255,255,.32);padding:0;overflow:hidden;position:relative;}
.hero-dots button.on{background:rgba(255,255,255,.4);}
.hero-dot-fill{position:absolute;inset:0;background:#fff;transform:scaleX(0);transform-origin:left;}
.hero-dots button.on .hero-dot-fill{animation:dotFill 5.5s linear forwards;}
@keyframes dotFill{from{transform:scaleX(0)}to{transform:scaleX(1)}}
.hero-arrows{position:absolute;right:32px;bottom:30px;display:flex;gap:10px;z-index:3;}
.hero-arrows button{width:46px;height:46px;border-radius:50%;border:1px solid rgba(255,255,255,.4);background:rgba(255,255,255,.12);color:#fff;display:grid;place-items:center;transition:background .15s,border-color .15s;}
.hero-arrows button:hover{background:rgba(255,255,255,.24);border-color:#fff;}

/* ---------- trust bar ---------- */
/* ---------- сторис: ряд кружков ---------- */
.stories{max-width:var(--maxw);margin:0 auto;padding:22px 32px 4px;}
.stories-inner{position:relative;}
.stories-row{display:flex;justify-content:center;gap:24px;overflow-x:auto;scroll-behavior:smooth;scrollbar-width:none;padding:6px 2px;}
.stories-row::-webkit-scrollbar{display:none;}
.story{flex:0 0 auto;width:104px;background:none;border:none;padding:0;display:flex;flex-direction:column;align-items:center;gap:9px;cursor:pointer;}
.story-ring{width:96px;height:96px;border-radius:50%;padding:3px;background:linear-gradient(135deg,var(--accent),#F0B2C8 55%,#C9A6E0);transition:transform .15s var(--ease);}
.story:hover .story-ring{transform:scale(1.05);}
.story-cover{display:block;width:100%;height:100%;border-radius:50%;overflow:hidden;border:3px solid var(--bg);background:var(--surface-2);}
.story-cover img{width:100%;height:100%;object-fit:cover;}
.story-label{font-size:12.5px;line-height:1.18;color:var(--ink-2);text-align:center;max-width:104px;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;}
.stories-arrow{position:absolute;top:34px;width:40px;height:40px;border-radius:50%;border:1px solid var(--line-2);background:color-mix(in srgb,var(--bg) 92%,transparent);color:var(--ink);display:grid;place-items:center;z-index:2;transition:background .15s,color .15s;}
.stories-arrow:hover{border-color:var(--accent);color:var(--accent);}
.stories-prev{left:-8px;}
.stories-next{right:-8px;}
/* центрируем, пока историй мало; на узких — скролл от левого края (иначе начало не доскроллить) */
@media(max-width:920px){.stories-row{justify-content:flex-start;}.stories-arrow{display:none;}}

/* ---------- сторис: полноэкранный плеер (активная по центру, соседи по бокам) ---------- */
.stv{position:fixed;inset:0;z-index:200;background:rgba(12,9,13,.94);display:none;overflow:hidden;}
.stv.open{display:block;}
.stv-track{position:absolute;top:50%;left:0;display:flex;gap:18px;align-items:center;transform:translate(0,-50%);transition:transform .35s var(--ease);will-change:transform;}
.stv-card{flex:0 0 auto;width:min(420px,86vw);height:min(86vh,760px);border-radius:16px;overflow:hidden;position:relative;background:#1a141f center/cover no-repeat;transform:scale(.82);opacity:.5;transition:transform .35s var(--ease),opacity .35s var(--ease);cursor:pointer;}
.stv-card.active{transform:scale(1);opacity:1;cursor:default;}
.stv-card:not(.active)::after{content:"";position:absolute;inset:0;background:rgba(0,0,0,.5);}
.stv-card:not(.active) .stv-tap{pointer-events:none;}
.stv-media{position:absolute;inset:0;}
.stv-media .stv-vid,.stv-media .stv-img{width:100%;height:100%;object-fit:cover;display:block;}
.stv-bars{position:absolute;top:10px;left:10px;right:10px;display:flex;gap:4px;z-index:4;}
.stv-bar{flex:1;height:3px;border-radius:2px;background:rgba(255,255,255,.35);overflow:hidden;}
.stv-bar i{display:block;height:100%;width:0;background:#fff;border-radius:2px;}
.stv-top{position:absolute;top:24px;left:14px;right:14px;display:flex;align-items:center;gap:10px;z-index:4;color:#fff;}
.stv-ava{width:30px;height:30px;border-radius:50%;overflow:hidden;border:1.5px solid rgba(255,255,255,.8);flex-shrink:0;}
.stv-ava img{width:100%;height:100%;object-fit:cover;}
.stv-name{font-size:14px;font-weight:600;text-shadow:0 1px 6px rgba(0,0,0,.5);}
.stv-cap{position:absolute;left:0;right:0;bottom:0;z-index:5;padding:64px 20px 24px;color:#fff;background:linear-gradient(transparent,rgba(0,0,0,.72));pointer-events:none;}
.stv-cap h3{font-family:var(--font-display);font-weight:500;font-size:26px;line-height:1.08;margin:0 0 6px;color:#fff;}
.stv-cap p{font-size:14.5px;line-height:1.45;color:rgba(255,255,255,.9);margin:0 0 14px;max-width:34ch;}
.stv-cap .stv-cta{pointer-events:auto;}
.stv-tap{position:absolute;top:0;bottom:120px;width:38%;background:none;border:none;cursor:pointer;z-index:3;}
.stv-tap-l{left:0;}
.stv-tap-r{right:0;}
.stv-x,.stv-sound{position:fixed;top:18px;width:44px;height:44px;border-radius:12px;border:none;background:rgba(255,255,255,.12);color:#fff;display:grid;place-items:center;z-index:6;transition:background .15s;}
.stv-x:hover,.stv-sound:hover{background:rgba(255,255,255,.22);}
.stv-x{right:18px;}
.stv-sound{left:18px;}
.stv-arrow{position:fixed;top:50%;transform:translateY(-50%);width:48px;height:48px;border-radius:50%;border:1px solid rgba(255,255,255,.4);background:rgba(255,255,255,.1);color:#fff;display:grid;place-items:center;z-index:6;transition:background .15s,opacity .15s;}
.stv-arrow:hover{background:rgba(255,255,255,.22);}
.stv-arrow:disabled{opacity:.3;pointer-events:none;}
.stv-prevst{left:24px;}
.stv-nextst{right:24px;}
@media(max-width:600px){
  .stv-card{width:94vw;height:86vh;}
  .stv-arrow{display:none;}
  .stv-cap h3{font-size:23px;}
}

/* ---------- promo ---------- */
.promo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--card-gap);}
.promo{position:relative;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;padding:26px;min-height:260px;color:var(--ink);text-align:left;display:flex;flex-direction:column;transition:transform .25s var(--ease),box-shadow .25s var(--ease);}
.promo:hover{transform:translateY(-4px);box-shadow:0 22px 50px -24px rgba(20,20,30,.25);}
.promo-top{display:flex;justify-content:space-between;align-items:flex-start;z-index:2;}
.promo-brand{font-family:var(--font-display);font-size:24px;}
.promo-off{background:var(--accent);color:#fff;font-weight:700;font-size:14px;padding:5px 11px;border-radius:10px;}
.promo-photo{position:absolute;right:0;top:0;bottom:0;width:56%;z-index:1;}
.promo-photo img{width:100%;height:100%;object-fit:cover;-webkit-mask-image:linear-gradient(90deg,transparent,#000 40%);mask-image:linear-gradient(90deg,transparent,#000 40%);transition:transform .5s var(--ease);}
.promo:hover .promo-photo img{transform:scale(1.06);}
.promo-cta{margin-top:auto;display:inline-flex;align-items:center;gap:7px;font-size:14px;font-weight:600;z-index:2;color:var(--ink-2);}

/* ---------- tabs ---------- */
.tabs-bar{margin-bottom:30px;border-bottom:1px solid var(--line);}
.tabs{display:flex;flex-wrap:wrap;gap:14px 30px;}
.tab{background:none;border:none;padding:0 0 16px;font-size:17px;color:var(--muted);position:relative;transition:color .15s;font-family:var(--font-display);}
.tab::after{content:"";position:absolute;left:0;bottom:-1px;height:2px;width:0;background:var(--accent);transition:width .2s var(--ease);}
.tab:hover{color:var(--ink-2);}
.tab.on{color:var(--ink);}
.tab.on::after{width:100%;}

/* ---------- product grid + card ---------- */
.grid{display:grid;gap:var(--card-gap);}
.grid-4{grid-template-columns:repeat(4,minmax(0,1fr));}
.grid-3{grid-template-columns:repeat(3,minmax(0,1fr));}
.card{cursor:pointer;display:flex;flex-direction:column;min-width:0;}
.card-media{position:relative;aspect-ratio:3/4;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);background:var(--surface);}
.badge{position:absolute;top:12px;left:12px;font-size:12.5px;font-weight:700;letter-spacing:.02em;padding:5px 10px;border-radius:10px;z-index:2;}
.badge-best{background:var(--ink);color:#fff;}
.badge-new{background:var(--accent);color:#fff;}
.badge-sale{background:#9A3148;color:#fff;left:auto;right:12px;}
.fav{position:absolute;top:10px;right:10px;width:36px;height:36px;border-radius:50%;border:none;background:rgba(251,247,240,.92);color:var(--ink-2);display:grid;place-items:center;z-index:2;opacity:0;transform:translateY(-4px);transition:opacity .2s,transform .2s,color .15s,background .15s;}
.card:hover .fav{opacity:1;transform:none;}
.fav:hover{color:var(--accent);}
.fav-on{opacity:1;transform:none;color:#9A3148;}
.fav-on svg{fill:#9A3148;}
.card-quick{position:absolute;left:12px;right:12px;bottom:12px;z-index:2;opacity:0;transform:translateY(10px);transition:opacity .22s var(--ease),transform .22s var(--ease);}
.card:hover .card-quick{opacity:1;transform:none;}
.card-body{padding:14px 2px 0;}
.card-brand{font-size:13.5px;color:var(--muted);letter-spacing:.04em;text-transform:uppercase;}
.card-name{font-family:var(--font-display);font-weight:400;font-size:20px;margin:3px 0 4px;line-height:1.1;}
.card-name a{color:inherit;text-decoration:none;}
.card-name a:hover,.card-name a:focus-visible{color:var(--accent-text);}
.card-name a:focus-visible{outline:2px solid var(--accent-text);outline-offset:2px;border-radius:3px;}
.card-fam{font-size:14px;margin-bottom:10px;}
.card-foot{display:flex;justify-content:space-between;align-items:center;}
.card-price{font-size:16px;font-weight:600;display:flex;align-items:baseline;gap:8px;}
.card-old{font-size:14px;color:var(--muted);text-decoration:line-through;font-weight:400;}
.card-rate{font-size:14px;color:var(--ink-2);display:inline-flex;align-items:center;gap:4px;}
.card-rate svg{fill:var(--accent);color:var(--accent);}

/* ---------- scent finder (fresh light) ---------- */
.sf{margin:80px auto 0;max-width:var(--maxw);}
.sf-grid{background:linear-gradient(120deg,#FFEFE7 0%,#F2F7F4 52%,#FCEFF4 100%);border:1px solid var(--line);border-radius:calc(var(--radius) + 8px);overflow:hidden;color:var(--ink);display:grid;grid-template-columns:1fr 1fr;gap:0;margin:0 32px;}
.sf-controls{padding:48px;}
.sf-h2{font-family:var(--font-display);font-weight:400;font-size:clamp(28px,3vw,38px);margin:.3em 0 .35em;color:var(--ink);}
.sf-lead{color:var(--ink-2);font-size:16px;margin:0 0 26px;max-width:400px;}
.sf-fams{display:flex;flex-wrap:wrap;gap:9px;margin-bottom:30px;}
.sf-fam{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:10px;border:1px solid var(--line-2);background:#fff;color:var(--ink-2);font-size:14px;transition:border-color .15s var(--ease),color .15s var(--ease),background .15s var(--ease);}
.sf-fam:hover{border-color:var(--accent);color:var(--ink);}
.sf-fam-dot{width:9px;height:9px;border-radius:50%;}
.sf-sliders{display:flex;flex-direction:column;gap:24px;}
.sf-slider-top{display:flex;justify-content:space-between;font-size:14px;margin-bottom:12px;color:var(--muted);}
.sf-slider-top strong{color:var(--accent);font-weight:600;}
.range{-webkit-appearance:none;appearance:none;width:100%;height:4px;border-radius:2px;background:rgba(20,20,30,.13);outline:none;accent-color:var(--accent);}
.range::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;border-radius:50%;background:var(--accent);border:3px solid #fff;cursor:pointer;box-shadow:0 2px 8px rgba(20,20,30,.22);transition:transform .12s;}
.range::-webkit-slider-thumb:hover{transform:scale(1.12);}
.range::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--accent);border:3px solid #fff;cursor:pointer;}
.sf-ticks{display:flex;justify-content:space-between;margin-top:9px;font-size:12.5px;color:var(--muted);}
.sf-ticks.five{justify-content:space-between;}
.sf-ticks .on{color:var(--accent);font-weight:600;}
.sf-result{background:rgba(255,255,255,.84);padding:40px;display:flex;flex-direction:column;border-left:1px solid var(--line);}
.sf-result-eyebrow{font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);margin-bottom:14px;font-weight:600;}
.sf-card{display:grid;grid-template-columns:120px 1fr;gap:18px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:16px;cursor:pointer;transition:border-color .2s,box-shadow .2s;}
.sf-card:hover{border-color:color-mix(in srgb,var(--c) 55%,var(--line));box-shadow:0 16px 36px -20px rgba(20,20,30,.25);}
.sf-card-media{border-radius:calc(var(--radius) - 4px);overflow:hidden;aspect-ratio:3/4;}
.sf-card-info{display:flex;flex-direction:column;}
.sf-card-brand{font-size:13px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);}
.sf-card-name{font-family:var(--font-display);font-size:24px;margin:2px 0 3px;color:var(--ink);}
.sf-card-fam{font-size:14px;color:var(--accent);margin-bottom:8px;}
.sf-card-blurb{font-size:14px;color:var(--ink-2);line-height:1.45;margin:0 0 14px;}
.sf-card-foot{margin-top:auto;display:flex;align-items:center;justify-content:space-between;gap:10px;}
.sf-card-price{font-family:var(--font-display);font-size:21px;color:var(--ink);}
.sf-alts{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:18px;}
.sf-alt{display:flex;flex-direction:column;gap:8px;background:#fff;border:1px solid var(--line);border-radius:12px;padding:10px;color:var(--ink);text-align:left;transition:border-color .15s,box-shadow .15s;}
.sf-alt:hover{border-color:var(--accent);box-shadow:0 10px 24px -16px rgba(20,20,30,.25);}
.sf-alt-media{aspect-ratio:1;border-radius:8px;overflow:hidden;}
.sf-alt-name{font-size:13.5px;display:block;line-height:1.2;}
.sf-alt-price{font-size:13px;color:var(--muted);}

/* ---------- families ---------- */
.fam-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;}
.fam-card{display:flex;align-items:center;gap:12px;padding:18px 20px;border-radius:var(--radius);border:1px solid var(--line);text-align:left;transition:transform .2s var(--ease),box-shadow .2s var(--ease);}
.fam-card:hover{transform:translateY(-3px);box-shadow:0 14px 32px -18px rgba(20,14,9,.4);}
.fam-dot{width:14px;height:14px;border-radius:50%;flex-shrink:0;}
.fam-label{flex:1;font-size:15px;font-weight:500;color:var(--ink);}

/* ---------- gift (fresh light) ---------- */
.gift{max-width:var(--maxw);margin:80px auto 0;padding:0 32px;}
.gift-inner{background:linear-gradient(120deg,#FFE6DC 0%,#FFF1EB 48%,#FCE5ED 100%);border:1px solid var(--line);border-radius:calc(var(--radius) + 8px);padding:56px;color:var(--ink);display:grid;grid-template-columns:1fr 1fr;gap:30px;align-items:center;overflow:hidden;}
.gift-h2{font-family:var(--font-display);font-weight:400;font-size:clamp(30px,3.4vw,44px);margin:.3em 0 .35em;color:var(--ink);}
.gift-copy p{color:var(--ink-2);max-width:420px;margin:0 0 26px;font-size:16px;}
.gift-cards{position:relative;display:flex;justify-content:center;align-items:center;height:230px;transition:transform .5s var(--ease);}
.gift-cards:hover{transform:scale(1.05);}
.gift-card{position:absolute;width:230px;height:150px;border-radius:16px;background:linear-gradient(140deg,var(--accent),color-mix(in srgb,var(--accent) 55%,#E0567E));border:none;padding:22px;display:flex;flex-direction:column;justify-content:space-between;box-shadow:0 22px 44px -20px color-mix(in srgb,var(--accent) 60%,transparent);color:#fff;}
.gift-card:nth-child(1){z-index:1;}.gift-card:nth-child(2){z-index:3;}.gift-card:nth-child(3){z-index:2;}
.gift-card-mark{font-family:var(--font-display);font-size:18px;letter-spacing:.12em;}
.gift-card-mark .logo-dot{color:#fff;opacity:.7;}
.gift-card-val{font-family:var(--font-display);font-size:30px;color:#fff;}
.gift-card-foot{font-size:12px;text-transform:uppercase;letter-spacing:.16em;color:rgba(255,255,255,.78);}

/* ---------- stars ---------- */
.stars{display:inline-flex;gap:1px;}
.stars .star{color:var(--line-2);}
.stars .star svg{fill:currentColor;}
.stars .star.on{color:var(--accent);}

/* ---------- catalog ---------- */
.catalog{max-width:var(--maxw);margin:0 auto;padding:32px 32px 80px;}
.crumbs{font-size:14px;color:var(--muted);display:flex;align-items:center;gap:8px;}
.crumbs span{opacity:.5;}
.crumbs button{background:none;border:none;color:var(--muted);font-size:14px;padding:0;}
.crumbs button:hover{color:var(--accent);}
.crumbs a{color:var(--ink-2);text-decoration:none;}
.crumbs a:hover{color:var(--accent-text);}
.crumbs em{color:var(--ink);font-style:normal;}
.catalog-top{margin-bottom:32px;}
.catalog-h1{font-family:var(--font-display);font-weight:400;font-size:clamp(34px,4vw,48px);margin:14px 0 6px;}
.catalog-sub{color:var(--muted);font-size:15.5px;}
.catalog-layout{display:grid;grid-template-columns:262px 1fr;gap:40px;align-items:start;}
.filters{position:sticky;top:94px;display:flex;flex-direction:column;gap:6px;}
.filter-search{display:flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--line-2);border-radius:12px;padding:11px 14px;color:var(--muted);margin-bottom:14px;}
.filter-search input{border:none;background:none;outline:none;width:100%;font-size:15px;color:var(--ink);}
.filters-head{display:flex;justify-content:space-between;align-items:center;font-size:14px;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-2);padding:6px 0 2px;}
.filter-clear{background:none;border:none;color:var(--accent);font-size:14px;letter-spacing:0;text-transform:none;}
.filter-group{border-top:1px solid var(--line);}
.filter-head{width:100%;background:none;border:none;display:flex;justify-content:space-between;align-items:center;padding:16px 2px;font-size:15.5px;font-weight:600;color:var(--ink);}
.filter-body{display:flex;flex-direction:column;gap:11px;padding:0 2px 16px;}
.filter-chev{display:inline-flex;transition:transform .2s var(--ease);transform:rotate(180deg);}
.filter-group.collapsed .filter-chev{transform:none;}
.filter-group.collapsed .filter-body{display:none;}
.check{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--ink-2);cursor:pointer;}
.check input{position:absolute;width:1px;height:1px;opacity:0;margin:0;} /* visually-hidden, НЕ display:none — остаётся фокусируемым с клавиатуры */
.check input:focus-visible + .check-box{outline:2px solid var(--accent-text);outline-offset:2px;}
.check-box{width:18px;height:18px;border-radius:5px;border:1.5px solid var(--line-2);display:grid;place-items:center;color:#fff;flex-shrink:0;transition:background .12s,border-color .12s;}
.check-box svg{opacity:0;}
.check input:checked + .check-box{background:var(--accent);border-color:var(--accent);}
.check input:checked + .check-box svg{opacity:1;}
.check-dot{width:9px;height:9px;border-radius:50%;}
.check:hover{color:var(--ink);}
.switch-row{display:flex;justify-content:space-between;align-items:center;padding:18px 2px 0;border-top:1px solid var(--line);font-size:15px;font-weight:500;}
.switch{width:42px;height:24px;border-radius:999px;border:none;background:var(--line-2);position:relative;transition:background .18s;flex-shrink:0;}
.switch.on{background:var(--accent);}
.switch-knob{position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:#fff;transition:transform .18s var(--ease);}
.switch.on .switch-knob{transform:translateX(18px);}
.results-bar{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:24px;flex-wrap:wrap;}
.chips{display:flex;flex-wrap:wrap;gap:8px;}
.chip{display:inline-flex;align-items:center;gap:7px;background:var(--surface-2);border:1px solid var(--line);border-radius:10px;padding:7px 12px;font-size:14px;color:var(--ink-2);}
.chip:hover{border-color:var(--accent);color:var(--accent);}
.sort{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--muted);margin-left:auto;}
.select-wrap{position:relative;display:flex;align-items:center;}
.select-wrap select{appearance:none;background:var(--surface);border:1px solid var(--line-2);border-radius:10px;padding:9px 36px 9px 14px;font-size:14px;color:var(--ink);}
.select-wrap svg{position:absolute;right:12px;pointer-events:none;color:var(--muted);}
.empty{text-align:center;padding:80px 20px;color:var(--muted);display:flex;flex-direction:column;align-items:center;gap:14px;}

/* ---------- product page ---------- */
.pdp{max-width:var(--maxw);margin:0 auto;padding:24px 32px 80px;}
.pdp-crumbs{margin-bottom:22px;}
.pdp-main{display:grid;grid-template-columns:1.05fr 1fr;gap:48px;align-items:start;}
.pdp-media{position:sticky;top:94px;}
.pdp-hero{position:relative;aspect-ratio:4/5;border-radius:calc(var(--radius) + 6px);overflow:hidden;border:1px solid var(--line);}
.pdp-thumbs{display:flex;gap:12px;margin-top:14px;}
.pdp-thumb{width:84px;aspect-ratio:1;border-radius:12px;overflow:hidden;border:1px solid var(--line);background:none;padding:0;transition:border-color .15s;}
.pdp-thumb.on{border-color:var(--accent);border-width:2px;}
.pdp-info{padding-top:4px;}
.pdp-headrow{display:flex;justify-content:space-between;align-items:center;}
.pdp-brand{font-size:14px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);}
.pdp-call{background:none;border:none;color:var(--ink-2);font-size:14px;display:inline-flex;align-items:center;gap:6px;}
.pdp-call:hover{color:var(--accent);}
.pdp-name{font-family:var(--font-display);font-weight:400;font-size:clamp(32px,3.6vw,46px);line-height:1.02;margin:8px 0 12px;}
.pdp-meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap;font-size:14px;color:var(--ink-2);}
.dotsep{color:var(--line-2);}
.pdp-fam{font-weight:600;}
.pdp-rate{display:inline-flex;align-items:center;gap:7px;color:var(--ink-2);text-decoration:none;}
.pdp-rate:hover{color:var(--accent);}
.pdp-blurb{font-size:16.5px;line-height:1.6;color:var(--ink-2);margin:20px 0 24px;max-width:520px;}
.pdp-meters{display:flex;gap:30px;padding:20px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.meter{flex:1;}
.meter-label{font-size:14px;color:var(--muted);display:block;margin-bottom:9px;}
.meter-track{display:flex;gap:4px;}
.meter-seg{height:5px;flex:1;border-radius:3px;}
.meter-val{font-size:14px;color:var(--ink);margin-top:8px;display:block;font-weight:600;}
.pdp-sizes{margin:26px 0 0;}
.pdp-label-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;}
.pdp-label{font-size:14px;font-weight:600;}
/* ссылка-справка под рядом вариантов (раньше была неприметная (?) сбоку у лейбла) */
.vol-help{display:inline-block;margin-top:14px;border:none;background:none;padding:0;cursor:pointer;font-size:13.5px;color:var(--accent-text);text-decoration:underline dashed;text-underline-offset:3px;text-decoration-thickness:1px;}
.vol-help:hover{color:var(--accent);}
.vol-help:focus-visible{outline:2px solid var(--accent-text);outline-offset:2px;border-radius:4px;}
.vol-opts{display:flex;gap:10px;flex-wrap:wrap;}
/* justify-content:center — контент по центру по вертикали: у флаконов (2 строки) и тестера/сэмпла (3 строки)
   нет «пустого низа», кнопки выглядят выровненными при равной высоте (align-items:stretch у .vol-opts) */
.vol-opt{display:flex;flex-direction:column;align-items:flex-start;justify-content:center;gap:2px;padding:11px 16px;border-radius:10px;border:1.5px solid var(--line-2);background:var(--surface);transition:border-color .15s,background .15s,box-shadow .15s;min-width:104px;text-align:left;}
.vol-opt.on{border-color:var(--ink);box-shadow:0 0 0 1px var(--ink);background:#fff;}
.vol-opt:focus-visible{outline:2px solid var(--accent-text);outline-offset:2px;}
.vol-ml{font-size:15px;font-weight:600;color:var(--ink);}
.vol-kind{font-size:11.5px;font-weight:500;color:var(--muted);letter-spacing:.02em;text-transform:lowercase;}
.vol-price{font-size:14px;color:var(--ink);margin-top:3px;}
/* сигнал «сэмплы/тестеры дешевле»: лёгкий акцентный фон + акцентная цена */
.vol-opt.is-sample,.vol-opt.is-tester{background:color-mix(in srgb,var(--accent) 7%,var(--surface));}
.vol-opt.is-sample.on,.vol-opt.is-tester.on{background:color-mix(in srgb,var(--accent) 10%,#fff);}
.vol-opt.is-sample .vol-price,.vol-opt.is-tester .vol-price{color:var(--accent-text);font-weight:700;}
.pdp-pricebox{margin:26px 0 0;padding:22px;border:1px solid var(--line-2);border-radius:var(--radius);background:var(--surface);}
.pdp-price-main{display:flex;align-items:baseline;flex-wrap:nowrap;gap:10px;min-width:0;}
.pdp-price-old{font-size:18px;font-weight:600;color:var(--muted);text-decoration:line-through;white-space:nowrap;flex-shrink:0;}
.pdp-price-val{font-family:var(--font-display);font-size:38px;font-weight:800;letter-spacing:-.01em;color:var(--ink);white-space:nowrap;}
.pdp-price-off{font-size:14px;font-weight:700;color:var(--accent-text);background:color-mix(in srgb,var(--accent) 14%,#fff);padding:2px 8px;border-radius:8px;white-space:nowrap;flex-shrink:0;}
.install-line{display:inline-flex;align-items:center;gap:8px;border:none;background:none;padding:0;margin:10px 0 0;cursor:pointer;font-size:15px;color:var(--ink-2);}
.install-line strong{color:var(--ink);font-weight:700;}
.install-q{display:inline-grid;place-items:center;width:17px;height:17px;border-radius:50%;border:1px solid var(--line-2);font-size:11px;line-height:1;font-weight:700;color:var(--muted);}
.install-line:hover{color:var(--accent-text);}
.install-line:hover .install-q{color:var(--accent-text);border-color:var(--accent-text);}
.install-line:focus-visible{outline:2px solid var(--accent-text);outline-offset:3px;border-radius:6px;}
/* orental-раскладка: цена слева, кнопка «В корзину» справа (заполняет пустоту), не на всю ширину */
.pdp-pricebox-top{display:flex;align-items:center;gap:18px 24px;flex-wrap:wrap;}
.pdp-price-col{flex:1 1 220px;min-width:0;}
.pdp-buy{display:flex;gap:12px;flex-shrink:0;align-items:center;}
.pdp-buy .btn{min-width:208px;border-radius:10px;}
@media(max-width:560px){.pdp-buy{flex:1 1 100%;}.pdp-buy .btn{flex:1;min-width:0;}}
/* выгоды в блоке цены — заполняют пустое место полезным (выбор пользователя) */
.pricebox-perks{display:flex;flex-wrap:wrap;align-items:center;gap:8px 16px;margin-top:10px;padding-top:11px;border-top:1px solid var(--line);}
.pb-perk{display:inline-flex;align-items:center;gap:6px;font-size:13.5px;color:var(--ink-2);}
.pb-perk svg{color:var(--accent);flex-shrink:0;}
/* избранное в ряду выгод — иконка+подпись, без круга (как orental) */
.pricebox-perks .fav-btn{margin-left:auto;width:auto;height:auto;border:none;border-radius:0;background:none;padding:0 2px;display:inline-flex;align-items:center;gap:7px;font-size:14px;line-height:1;color:var(--ink-2);}
.pricebox-perks .fav-btn svg{flex-shrink:0;}
/* выровнять и перки по той же логике (иконка+текст по центру, без сдвига от line-height) */
.pb-perk{line-height:1;}
.pricebox-perks .fav-btn:hover{color:var(--accent);}
.pricebox-perks .fav-btn.on{color:#9A3148;}
.fav-btn{width:54px;flex-shrink:0;border-radius:10px;border:1.5px solid var(--line-2);background:none;color:var(--ink-2);display:grid;place-items:center;transition:border-color .15s,color .15s;}
.fav-btn:hover{border-color:var(--accent);color:var(--accent);}
.fav-btn.on{color:#9A3148;border-color:#9A3148;}
.fav-btn.on svg{fill:#9A3148;}
.pdp-deliv{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:24px 0;padding:18px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.deliv-d{display:block;font-size:15.5px;font-weight:600;color:var(--accent);}
.deliv-l{font-size:13.5px;color:var(--muted);}
.info-chips{list-style:none;margin:0 0 24px;padding:0;display:grid;grid-template-columns:repeat(4,1fr);gap:10px;}
.info-chip{display:flex;flex-direction:column;align-items:center;gap:8px;width:100%;padding:16px 8px;border:1px solid var(--line-2);border-radius:10px;background:#fff;cursor:pointer;font-size:15px;font-weight:600;color:var(--ink);transition:border-color .15s,background .15s,color .15s;}
.info-chip svg{color:var(--accent);}
.info-chip:hover{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 6%,#fff);color:var(--accent-text);}
.info-chip:hover svg{color:var(--accent-text);}
.info-chip:focus-visible{outline:2px solid var(--accent-text);outline-offset:2px;}
.info-chip span{text-decoration:underline dashed;text-underline-offset:3px;text-decoration-thickness:1px;text-decoration-color:color-mix(in srgb,currentColor 45%,transparent);}
.pdp-attrs{margin:0;border-top:1px solid var(--line);}
.pdp-attrs>div{display:flex;justify-content:space-between;padding:11px 0;border-bottom:1px solid var(--line);font-size:14px;}
.pdp-attrs dt{color:var(--muted);margin:0;}
.pdp-attrs dd{margin:0;color:var(--ink);font-weight:500;text-decoration:underline;text-decoration-style:solid;text-underline-offset:3px;text-decoration-thickness:1px;text-decoration-color:var(--ink);}

/* ---------- характер аромата (мини-графики) ---------- */
.pdp-profile-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px 36px;}
.ch-card{min-width:0;}
.ch-title{font-size:14.5px;font-weight:600;color:var(--ink);margin-bottom:16px;}
.ch-plot{position:relative;height:70px;}
.ch-svg{position:absolute;inset:0;width:100%;height:100%;display:block;}
.ch-area{fill:color-mix(in srgb,var(--accent) 9%,transparent);}
.ch-line{fill:none;stroke:var(--accent);stroke-width:2;stroke-linejoin:round;stroke-linecap:round;}
.ch-cols{position:absolute;inset:0;display:flex;}
.ch-col{flex:1;position:relative;}
.ch-dot{position:absolute;left:50%;width:8px;height:8px;border-radius:50%;background:#fff;border:2px solid var(--accent);transform:translate(-50%,-50%);}
.ch-val{position:absolute;left:50%;transform:translate(-50%,-165%);font-size:11.5px;font-weight:600;color:var(--muted);white-space:nowrap;}
.ch-xlabels{display:flex;margin-top:9px;}
.ch-xlabels span{flex:1;text-align:center;font-size:11px;color:var(--muted);padding:0 2px;}
@media(max-width:860px){.pdp-profile-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:480px){.pdp-profile-grid{grid-template-columns:1fr;}}

/* ---------- pyramid ---------- */
.pyramid{max-width:var(--maxw);margin:0 auto;padding:70px 32px 0;}
.pyramid-head{margin-bottom:30px;}
.pyramid-rows{display:flex;flex-direction:column;gap:0;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;}
.pyramid-row{display:grid;grid-template-columns:220px 1fr;gap:28px;padding:26px 30px;align-items:center;border-bottom:1px solid var(--line);background:var(--surface);}
.pyramid-row:last-child{border-bottom:none;}
.pyramid-t{font-family:var(--font-display);font-size:21px;display:block;}
.pyramid-d{font-size:14px;color:var(--muted);}
.note-chips{display:flex;flex-wrap:wrap;gap:10px;}
.note-chip{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--line-2);border-radius:10px;padding:8px 15px;font-size:14px;color:var(--ink);background:var(--bg);}
.note-bullet{width:7px;height:7px;border-radius:50%;}

/* ---------- reviews ---------- */
.reviews{max-width:var(--maxw);margin:0 auto;padding:70px 32px 0;}
.reviews-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:30px;}
.reviews-grid{display:grid;grid-template-columns:260px 1fr;gap:40px;align-items:start;}
.reviews-score{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:28px;text-align:center;}
.rs-big{font-family:var(--font-display);font-size:56px;line-height:1;color:var(--ink);}
.reviews-score .stars{margin:8px 0;justify-content:center;}
.rs-count{font-size:14px;color:var(--muted);margin-bottom:18px;}
.rs-bars{display:flex;flex-direction:column;gap:8px;}
.rs-bar{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--muted);}
.rs-star{display:inline-flex;align-items:center;gap:2px;width:24px;}
.rs-star svg{fill:var(--accent);color:var(--accent);}
.rs-track{flex:1;height:6px;border-radius:3px;background:var(--line);overflow:hidden;}
.rs-fill{display:block;height:100%;border-radius:3px;}
.rs-n{width:26px;text-align:right;}
.reviews-list{display:flex;flex-direction:column;gap:16px;}
.review{border:1px solid var(--line);border-radius:var(--radius);padding:22px;background:var(--surface);}
.review-top{display:flex;align-items:center;gap:12px;margin-bottom:12px;}
.review-ava{width:40px;height:40px;border-radius:50%;display:grid;place-items:center;font-family:var(--font-display);font-size:18px;}
.review-name{font-size:15px;font-weight:600;}
.review-ok{margin-left:auto;font-size:13px;color:var(--muted);display:inline-flex;align-items:center;gap:5px;}
.review-ok svg{color:#2E7D5B;}
.review-text{margin:0;font-size:15px;line-height:1.6;color:var(--ink-2);}

/* ---------- footer (light) ---------- */
.ft{background:var(--surface);color:var(--ink-2);margin-top:90px;border-top:1px solid var(--line);}
.ft-top{max-width:var(--maxw);margin:0 auto;padding:60px 32px 44px;display:grid;grid-template-columns:minmax(0,1.2fr) minmax(0,2fr);gap:50px;}
.logo-ft{color:var(--ink);font-size:24px;font-weight:700;margin-bottom:16px;}
.logo-ft .logo-mark{width:56px;height:56px;}
.ft-brand p{font-size:15px;line-height:1.6;max-width:340px;margin:0 0 22px;color:var(--ink-2);}
.ft-news{display:flex;gap:10px;max-width:380px;}
.ft-news input{flex:1;min-width:0;background:#fff;border:1px solid var(--line-2);border-radius:10px;padding:12px 18px;color:var(--ink);outline:none;font-size:14px;}
.ft-news input::placeholder{color:var(--muted);}
.ft-news input:focus{border-color:var(--accent);}
.ft-cols{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:30px;}
.ft-col h3{font-family:var(--font-display);font-weight:400;font-size:17px;color:var(--ink);margin:0 0 16px;}
.ft-col button,.ft-col a,.ft-col span{display:block;background:none;border:none;color:var(--ink-2);font-size:14px;padding:6px 0;text-align:left;text-decoration:none;transition:color .15s;}
.ft-col button:hover,.ft-col a:hover{color:var(--accent);}
.ft-bottom{border-top:1px solid var(--line);}
.ft-bottom>span{max-width:var(--maxw);}
.ft-bottom{max-width:var(--maxw);margin:0 auto;padding:22px 32px;display:flex;justify-content:space-between;align-items:center;font-size:14px;color:var(--muted);}
.ft-pay{display:flex;gap:8px;}
.pay{border:1px solid var(--line-2);border-radius:6px;padding:4px 10px;font-size:13px;letter-spacing:.04em;color:var(--ink-2);}
/* мессенджеры в контактах (Telegram / Макс) */
.ft-col .ft-msg{display:flex;align-items:center;gap:9px;width:fit-content;}
.ft-msg-ic{width:30px;height:30px;border-radius:50%;background:var(--ink);color:#fff;display:grid;place-items:center;flex-shrink:0;transition:background .15s;}
.ft-msg-ic svg{display:block;}
.ft-msg:hover .ft-msg-ic{background:var(--accent);}

/* ---------- cart drawer ---------- */
.scrim{position:fixed;inset:0;background:rgba(20,14,9,.55);opacity:0;pointer-events:none;transition:opacity .25s;z-index:90;}
.scrim.show{opacity:1;pointer-events:auto;}
.drawer{position:fixed;top:0;right:0;height:100vh;width:430px;max-width:92vw;background:var(--bg);z-index:100;transform:translateX(100%);transition:transform .32s var(--ease);display:flex;flex-direction:column;box-shadow:-20px 0 50px -20px rgba(20,14,9,.4);}
.drawer.open{transform:none;}
.drawer-head{display:flex;justify-content:space-between;align-items:center;padding:22px 24px;border-bottom:1px solid var(--line);}
.drawer-head h2{font-family:var(--font-display);font-weight:400;font-size:24px;margin:0;}
.drawer-head h2 span{color:var(--muted);}
.drawer-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;color:var(--muted);}
.ship-bar{padding:16px 24px;background:var(--surface);border-bottom:1px solid var(--line);font-size:14px;color:var(--ink-2);}
.ship-bar strong{color:var(--accent);}
.ship-done{color:#2E7D5B;display:inline-flex;align-items:center;gap:6px;font-weight:600;}
.ship-track{display:block;height:5px;border-radius:3px;background:var(--line);margin-top:9px;overflow:hidden;}
.ship-fill{display:block;height:100%;background:var(--accent);border-radius:3px;transition:width .3s var(--ease);}
.drawer-items{flex:1;overflow-y:auto;padding:8px 24px;}
.ci{display:grid;grid-template-columns:72px 1fr auto;gap:14px;padding:18px 0;border-bottom:1px solid var(--line);position:relative;}
.ci-media{border-radius:12px;overflow:hidden;aspect-ratio:1;}
.ci-brand{font-size:12.5px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);}
.ci-name{font-family:var(--font-display);font-size:17px;margin:1px 0 2px;}
.ci-size{font-size:13.5px;color:var(--muted);margin-bottom:10px;}
.ci-foot{display:flex;align-items:center;justify-content:space-between;gap:10px;}
.qty{display:flex;align-items:center;gap:0;border:1px solid var(--line-2);border-radius:10px;}
.qty button{width:30px;height:30px;border:none;background:none;display:grid;place-items:center;color:var(--ink-2);border-radius:50%;}
.qty button:hover{color:var(--accent);}
.qty span{min-width:22px;text-align:center;font-size:14px;font-weight:600;}
.ci-price{font-size:15.5px;font-weight:600;}
.ci-x{position:absolute;top:18px;right:0;background:none;border:none;color:var(--muted);width:24px;height:24px;display:grid;place-items:center;border-radius:50%;}
.ci-x:hover{color:#9A3148;background:var(--surface-2);}
.drawer-foot{padding:20px 24px;border-top:1px solid var(--line);background:var(--surface);}
.gift-note{display:flex;align-items:center;gap:9px;font-size:14px;color:var(--ink-2);margin-bottom:14px;}
.gift-note svg{color:var(--accent);}
.sub-row{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:16px;}
.sub-row span{font-size:15.5px;color:var(--ink-2);}
.sub-row strong{font-family:var(--font-display);font-size:26px;}
.drawer-cont{width:100%;background:none;border:none;color:var(--muted);font-size:14px;padding:14px 0 2px;}
.drawer-cont:hover{color:var(--ink);}

/* ---------- animations ---------- */
@keyframes fadeUp{from{opacity:0;transform:translateY(16px);}to{opacity:1;transform:none;}}

/* ---------- responsive ---------- */
/* Шапка: 7 пунктов меню — компактим до 1280, прячем до 1100 (бургер-меню в исходном дизайне нет) */
@media(max-width:1280px){.hd-nav{gap:18px;}.hd-nav a{font-size:14px;}}
@media(max-width:1100px){
  .hd-nav{display:none;}
  .hd-burger{display:grid;}
  /* большое полноэкранное мобильное меню (как Gold Apple) */
  .hd-menu{display:flex;flex-direction:column;position:fixed;top:74px;left:0;right:0;bottom:0;background:var(--bg);transform:translateY(10px);opacity:0;pointer-events:none;transition:transform .26s var(--ease),opacity .2s;z-index:90;max-height:none;overflow:hidden;}
  .hd.menu-open .hd-menu{transform:none;opacity:1;pointer-events:auto;}
  .hd-menu-scroll{flex:1;overflow-y:auto;padding:16px 24px 28px;display:flex;flex-direction:column;}
  .hd-menu .hm-link{display:flex;align-items:center;justify-content:space-between;gap:12px;font-family:var(--font-display);font-size:27px;font-weight:700;line-height:1.1;color:var(--ink);text-decoration:none;padding:13px 0;border:none;min-height:0;}
  .hd-menu .hm-link svg{color:var(--muted);}
  .hd-menu .hm-link:active{color:var(--accent-text);}
  .hd-menu .hm-sale{color:var(--accent-text);}
  .hm-sep{height:1px;background:var(--line);margin:16px 0;}
  .hd-menu .hm-sub{display:flex;align-items:center;gap:8px;font-size:16px;color:var(--ink-2);text-decoration:none;padding:11px 0;border:none;min-height:0;}
  .hd-menu .hm-sub .hd-menu-count{margin-left:6px;}
  .hm-account{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:18px 24px;border-top:1px solid var(--line);background:var(--surface);font-weight:700;font-size:17px;color:var(--ink);text-decoration:none;flex-shrink:0;}
  .hm-account svg{color:var(--accent);}
  .hm-account span{display:inline-flex;align-items:center;gap:10px;}
}
@media(max-width:1080px){
  .hd-nav{gap:20px;}
  .grid-4{grid-template-columns:repeat(3,minmax(0,1fr));}
  .pdp-main{grid-template-columns:1fr;gap:32px;}
  .pdp-media{position:static;}
  .sf-grid{grid-template-columns:1fr;}
  .sf-controls,.sf-result{min-width:0;}
  .sf-result{border-left:none;border-top:1px solid var(--line);}
  .reviews-grid{grid-template-columns:1fr;}
}
@media(max-width:860px){
  .hd-nav{display:none;}
  .hero-inner{min-height:auto;padding:56px 24px 80px;}
  .hero-scrim{background:linear-gradient(180deg,rgba(15,12,14,.55) 0%,rgba(15,12,14,.32) 45%,rgba(15,12,14,.58) 100%);}
  .promo-grid{grid-template-columns:1fr;}
  .grid-4,.grid-3{grid-template-columns:repeat(2,minmax(0,1fr));}
  .fam-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
  .catalog-layout{grid-template-columns:1fr;}
  .filters{position:static;}
  .gift-inner{grid-template-columns:1fr;}
  .pyramid-row{grid-template-columns:1fr;gap:12px;}
  .section,.pyramid,.reviews,.gift,.catalog,.pdp{padding-left:20px;padding-right:20px;}
  .ft-top,.ft-bottom{padding-left:20px;padding-right:20px;}
  .section-head{flex-wrap:wrap;gap:6px 24px;} /* длинный заголовок + ссылка «Все …» не влезают в ряд на телефоне → ссылка переносится вниз */
  .ft-bottom{flex-wrap:wrap;gap:14px;}
  .sf-grid,.gift{margin-left:20px;margin-right:20px;}
}
@media(max-width:520px){
  .grid-4,.grid-3,.fam-grid{grid-template-columns:minmax(0,1fr) minmax(0,1fr);}
  .grid{gap:16px;}
  .sf-controls,.sf-result{padding:24px;}
  .sf-card{grid-template-columns:96px 1fr;}
  .sf-card-info{min-width:0;}
  .gift-inner{padding:32px;}
  .ft-top{grid-template-columns:minmax(0,1fr);gap:30px;}
  .ft-cols{grid-template-columns:minmax(0,1fr) minmax(0,1fr);}
}
/* компактная шапка на телефоне: в баре только поиск + корзина, остальное уходит в бургер-меню (иначе ряд шире вьюпорта) */
@media(max-width:640px){
  .hd-inner{padding:0 16px;gap:12px;}
  .logo-text{display:none;} /* мобайл: логотип = знак «ФД» (компактно); имя бренда — в aria-label, подвале и title */
  .logo-mark{width:56px;height:56px;} /* как обводка корзины (как на десктопе) */
  .hd-actions{margin-left:auto;}
  .hd-act-collapse{display:none;}
  .hd-menu-personal{display:block;}
  /* hero-контролы на телефоне: стрелки назад/вперёд (десктоп-аффорданс) убираем — точки тапаются; чтобы 6 широких полосок не лезли под кнопки. Пауза остаётся (WCAG 2.2.2). */
  #hero-prev,#hero-next{display:none;}
  .hero-dots{bottom:24px;gap:7px;}
  .hero-dots button{width:24px;}
  .hero-arrows{bottom:20px;}
}

/* ===================== Доп. секции главной ===================== */
/* свотчи семейств */
.swatch-row{display:flex;flex-wrap:wrap;gap:26px;margin-top:34px;padding-top:28px;border-top:1px solid var(--line);justify-content:center;}
.swatch{background:none;border:none;display:flex;flex-direction:column;align-items:center;gap:10px;padding:0;transition:transform .18s var(--ease);}
.swatch:hover{transform:translateY(-3px);}
.swatch-chip{width:52px;height:52px;border-radius:50%;border:1px solid var(--line);box-shadow:inset 0 -3px 8px rgba(20,20,30,.12),0 4px 12px -6px rgba(20,20,30,.2);transition:box-shadow .18s;}
.swatch:hover .swatch-chip{box-shadow:inset 0 -3px 8px rgba(20,20,30,.16),0 8px 18px -8px rgba(20,20,30,.32);}
.swatch-label{font-size:14px;color:var(--ink-2);}
.swatch:hover .swatch-label{color:var(--accent);}

/* наши коллекции */
.collections{margin-top:60px;}
.collections-head{padding-bottom:0!important;margin-bottom:26px;}
.collections-strip{display:grid;grid-template-columns:repeat(6,1fr);gap:4px;width:100%;}
.coll-tile{position:relative;height:330px;border:none;overflow:hidden;cursor:pointer;padding:0;display:block;}
.coll-scrim{position:absolute;inset:0;background:linear-gradient(180deg,transparent 45%,rgba(20,15,18,.5));}
.coll-label{position:absolute;left:20px;bottom:46px;right:16px;color:#fff;font-family:var(--font-display);font-size:21px;line-height:1.05;z-index:2;text-shadow:0 1px 12px rgba(0,0,0,.3);}
.coll-go{position:absolute;left:20px;bottom:18px;color:#fff;font-size:14px;font-weight:600;display:inline-flex;align-items:center;gap:6px;opacity:0;transform:translateY(6px);transition:opacity .2s,transform .2s;z-index:2;}
.coll-tile:hover .coll-go{opacity:1;transform:none;}

/* редакционный баннер */
.edito{margin-top:80px;}
.edito-inner{max-width:var(--maxw);margin:0 auto;padding:60px 32px;display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;}
.edito-inner.flip .edito-copy{order:2;}
.edito-copy{max-width:460px;}
.edito-h2{font-family:var(--font-display);font-weight:400;font-size:clamp(30px,3.6vw,46px);line-height:1.02;margin:.3em 0 .4em;color:var(--ink);}
.edito-text{font-size:16.5px;line-height:1.6;color:var(--ink-2);margin:0 0 26px;}
.edito-photo{height:340px;}
.edito-photo-inner{width:100%;height:100%;border-radius:calc(var(--radius) + 6px);overflow:hidden;background:rgba(255,255,255,.5);border:1px solid rgba(255,255,255,.6);}

/* #1 на рынке */
.market{display:grid;grid-template-columns:1fr 1.15fr;gap:48px;align-items:center;}
.market-copy{max-width:440px;}
.market-h2{font-family:var(--font-display);font-weight:400;font-size:clamp(30px,3.6vw,46px);line-height:1.02;margin:.3em 0 .4em;color:var(--ink);}
.market-copy p{font-size:16px;line-height:1.6;color:var(--ink-2);margin:0 0 26px;}
.market-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
.market-card{position:relative;aspect-ratio:3/4;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);}
.market-card-media{position:absolute;inset:0;}
.market-card-label{position:absolute;left:14px;right:14px;bottom:14px;color:#fff;font-size:14px;font-weight:600;z-index:2;text-shadow:0 1px 10px rgba(0,0,0,.35);}
.market-card::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(20,15,18,.42));}

/* статистика */
.stats{padding-top:80px;}
.stats-head{margin-bottom:14px;}
.stats-rows{display:flex;flex-direction:column;}
.stat-row{display:flex;align-items:center;gap:24px;padding:24px 0;border-bottom:1px solid var(--line);}
.stat-row:first-child{border-top:1px solid var(--line);}
.stat-num{font-family:var(--font-display);font-weight:400;font-size:clamp(40px,5.6vw,68px);line-height:1;color:var(--ink);min-width:160px;font-variant-numeric:tabular-nums;}
.stat-line{flex:1;height:0;border-bottom:1px dashed var(--line-2);}
.stat-label{border:1px solid var(--line-2);border-radius:10px;padding:9px 20px;font-size:14px;color:var(--ink-2);white-space:nowrap;text-decoration:underline;text-decoration-style:dashed;text-underline-offset:3px;text-decoration-color:var(--muted);cursor:pointer;transition:border-color .15s,color .15s;}
.stat-label:hover{border-color:var(--accent);color:var(--accent-text);text-decoration-color:var(--accent);}

/* бегущая строка */
.marquee{overflow:hidden;background:var(--accent);color:#fff;padding:17px 0;margin-top:80px;}
.marquee-track{display:inline-flex;align-items:center;white-space:nowrap;animation:marqueeScroll 32s linear infinite;will-change:transform;}
.marquee-paused .marquee-track{animation-play-state:paused;}
.marquee-item{display:inline-flex;align-items:center;gap:14px;padding:0 28px;font-size:16px;line-height:1;font-weight:600;letter-spacing:.02em;text-transform:uppercase;}
.marquee-star{opacity:.7;font-size:15px;line-height:1;}
@keyframes marqueeScroll{from{transform:translateX(0)}to{transform:translateX(-33.333%)}}

@media(max-width:1080px){
  .collections-strip{grid-template-columns:repeat(3,1fr);}
  .market{grid-template-columns:1fr;}
  .edito-inner{grid-template-columns:1fr;}
  .edito-inner.flip .edito-copy{order:0;}
}
@media(max-width:640px){
  .collections-strip{grid-template-columns:repeat(2,1fr);}
  .coll-tile{height:240px;}
  .market-cards{gap:10px;}
  .stat-row{gap:14px;}
  .stat-num{min-width:84px;}
  .stat-label{padding:7px 12px;font-size:13.5px;}
  .swatch-row{gap:16px;}
  .swatch-chip{width:44px;height:44px;}
}

/* ===================== Реальные изображения ===================== */
.card-img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s var(--ease);background:var(--surface);}
.card:hover .card-img{transform:scale(1.05);}
.sf-img{width:100%;height:100%;object-fit:cover;display:block;background:rgba(255,255,255,.5);transition:transform .5s var(--ease);}
.sf-card:hover .sf-img,.sf-alt:hover .sf-img{transform:scale(1.06);}
.coll-photo{position:absolute;inset:0;display:block;}
.coll-photo img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .45s var(--ease);}
.coll-tile:hover .coll-photo img{transform:scale(1.06);}
.market-card-media img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s var(--ease);}
.market-card:hover .market-card-media img{transform:scale(1.06);}
.edito-photo{height:380px;border-radius:calc(var(--radius) + 6px);overflow:hidden;border:1px solid var(--line);}
.edito-img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s var(--ease);}
.edito-photo:hover .edito-img{transform:scale(1.05);}
.pdp-img{width:100%;height:100%;object-fit:cover;display:block;}
.pdp-thumb-img{width:100%;height:100%;object-fit:cover;display:block;}
.ci-img{width:100%;height:100%;object-fit:cover;display:block;}

/* ---------- wide banner carousel (акции / тренды) ---------- */
.wbc-head{position:relative;display:flex;align-items:center;justify-content:center;margin-bottom:26px;}
.wbc-title{font-family:var(--font-display);font-weight:400;font-size:clamp(26px,3vw,36px);text-transform:lowercase;color:var(--ink);margin:0;}
.wbc-arrows{position:absolute;right:0;display:flex;gap:10px;}
.wbc-arrows button{width:42px;height:42px;border-radius:50%;border:1px solid var(--line-2);background:var(--bg);color:var(--ink);display:grid;place-items:center;transition:background .15s,color .15s,border-color .15s;}
.wbc-arrows button:hover{background:var(--ink);color:#fff;border-color:var(--ink);}
.wbc-viewport{overflow:hidden;}
.wbc-track{display:flex;transition:transform .45s var(--ease);}
.wbc-slide{flex:0 0 70%;margin:0 1.5%;cursor:pointer;opacity:.4;transition:opacity .35s var(--ease);}
.wbc-slide.on{opacity:1;}
.wbc-img{position:relative;border-radius:calc(var(--radius) + 4px);overflow:hidden;aspect-ratio:21/9;background:var(--surface);}
.wbc-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s var(--ease);}
.wbc-slide.on .wbc-img:hover img{transform:scale(1.03);}
.wbc-cap{padding:18px 6px 0;display:flex;flex-direction:column;gap:6px;}
.wbc-cap-title{font-family:var(--font-display);font-size:clamp(24px,2.6vw,34px);color:var(--ink);line-height:1.05;}
.wbc-cap-sub{font-size:15.5px;color:var(--ink-2);}

/* ---------- category split (готовимся к лету) ---------- */
.cat-split{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;}
.cat-media{border-radius:calc(var(--radius) + 4px);overflow:hidden;aspect-ratio:4/3;background:var(--surface);}
.cat-media img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s var(--ease);}
.cat-media:hover img{transform:scale(1.05);}
.cat-outline{font-family:var(--font-display);font-weight:400;font-size:clamp(40px,5.5vw,74px);line-height:.95;text-transform:lowercase;white-space:pre-line;margin:0 0 18px;color:transparent;-webkit-text-stroke:1.5px var(--ink-2);}
.cat-list{list-style:none;margin:0;padding:0;}
.cat-list li{border-bottom:1px solid var(--line);}
.cat-list button{width:100%;display:flex;align-items:center;justify-content:space-between;background:none;border:none;padding:15px 4px;font-size:19px;font-weight:600;color:var(--ink);transition:color .15s,transform .15s;}
.cat-list button:hover{color:var(--accent);transform:translateX(8px);}
.cat-list svg{opacity:0;transition:opacity .15s;color:var(--accent);}
.cat-list button:hover svg{opacity:1;}

/* ---------- brand showcase ---------- */
.brand-head{text-align:center;position:relative;margin-bottom:24px;}
.brand-name{font-family:var(--font-display);font-weight:400;font-size:clamp(32px,4.2vw,54px);margin:0;}
.brand-head .link-arrow{position:absolute;right:0;top:50%;transform:translateY(-50%);}
.brand-hero{position:relative;border-radius:calc(var(--radius) + 4px);overflow:hidden;aspect-ratio:21/7;cursor:pointer;background:var(--surface);}
.brand-hero img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s var(--ease);}
.brand-hero:hover img{transform:scale(1.03);}
.brand-hero-tag{position:absolute;top:18px;left:20px;background:rgba(255,255,255,.9);color:var(--ink);border-radius:10px;padding:7px 15px;font-size:13.5px;font-weight:600;}
.brand-cards{margin-top:-72px;position:relative;z-index:2;padding:0 12px;}

/* ---------- новости / статьи ---------- */
.ed-row.section{padding-top:48px;}
.ed-card{background:none;border:none;padding:0;text-align:left;cursor:pointer;text-decoration:none;display:flex;flex-direction:column;gap:12px;}
.ed-media{border-radius:var(--radius);overflow:hidden;aspect-ratio:16/10;background:var(--surface);}
.ed-media img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .45s var(--ease);}
.ed-card:hover .ed-media img{transform:scale(1.04);}
.ed-title{font-size:16px;font-weight:600;line-height:1.35;color:var(--ink);transition:color .15s;}
.ed-card:hover .ed-title{color:var(--accent);}

@media(max-width:860px){
  .cat-split{grid-template-columns:1fr;gap:26px;}
  .brand-cards{margin-top:24px;padding:0;}
  .brand-head .link-arrow{position:static;transform:none;display:inline-flex;margin-top:10px;}
  .wbc-cap-sub{display:none;}
}

/* ===================== Ревью-фиксы: контраст / фокус / движение / мобайл ===================== */

/* контраст: акцентный текст и мелкие «белое-на-акценте» бейджи под AA */
.eyebrow,.sf-result-eyebrow,.sf-card-fam,.filter-clear,.deliv-d,
.sf-slider-top strong,.sf-ticks .on,.link-arrow:hover,.crumbs button:hover,
.hd-nav a:hover,.cat-list button:hover,.ship-bar strong{color:var(--accent-text);}
.card-rate svg{fill:var(--accent-text);color:var(--accent-text);}
.ic-badge,.badge-new,.promo-off,.marquee,.btn-gold{background:var(--accent-text);}

/* видимый фокус (WCAG 2.4.7) */
:where(a,button,input,select,textarea,[tabindex]):focus-visible{outline:2px solid var(--accent-text);outline-offset:2px;border-radius:6px;}
.range:focus-visible{outline:2px solid var(--accent-text);outline-offset:3px;}

/* skip-link */
.skip-link{position:absolute;left:12px;top:-56px;z-index:200;background:var(--ink);color:#fff;padding:10px 16px;border-radius:8px;transition:top .15s;}
.skip-link:focus{top:12px;}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0;}

/* prefers-reduced-motion (WCAG 2.2.2 / 2.3.3) */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important;}
  .marquee-track{animation:none!important;}
  .hero-video{transition:none;}
}

/* инертные кнопки прототипа: визуальный «скоро» */
[aria-disabled="true"]{opacity:.55;cursor:not-allowed;}

/* мобильные фильтры каталога — нижний лист */
.cat-filter-btn{display:none;}
.filters-scrim{display:none;}
.filters-sheet-head{display:none;}
@media(max-width:860px){
  .cat-filter-btn{display:inline-flex;align-items:center;gap:8px;}
  .filters-scrim{display:block;position:fixed;inset:0;background:rgba(20,14,9,.5);opacity:0;pointer-events:none;transition:opacity .25s;z-index:96;}
  .filters-scrim.show{opacity:1;pointer-events:auto;}
  .filters{position:fixed;left:0;right:0;bottom:0;top:auto;max-height:84vh;overflow-y:auto;background:var(--bg);z-index:97;transform:translateY(101%);transition:transform .3s var(--ease);border-radius:18px 18px 0 0;padding:18px 20px 28px;box-shadow:0 -24px 50px -24px rgba(20,14,9,.45);}
  .filters.open{transform:none;}
  .filters-sheet-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px;}
  .filters-sheet-head h3{margin:0;font-size:18px;font-family:var(--font-display);}
}

/* липкая «В корзину» на мобильной карточке товара */
.pdp-sticky{display:none;}
@media(max-width:860px){
  .pdp-sticky{display:flex;align-items:center;gap:12px;position:fixed;left:0;right:0;bottom:0;z-index:80;background:color-mix(in srgb,var(--bg) 97%,transparent);border-top:1px solid var(--line);padding:12px 16px;transform:translateY(120%);transition:transform .25s var(--ease);box-shadow:0 -16px 40px -24px rgba(20,14,9,.4);}
  .pdp-sticky.show{transform:none;}
  .pdp-sticky-price{font-family:var(--font-display);font-size:20px;white-space:nowrap;}
  .pdp-sticky .btn{flex:1;}
}

/* ---------- описание товара (свернуть/раскрыть) ---------- */
.pdp-desc .desc-body{position:relative;color:var(--ink-2);line-height:1.65;font-size:15.5px;}
.pdp-desc .desc-body p{margin:0 0 12px;}
.pdp-desc .desc-body p:last-child{margin-bottom:0;}
.pdp-desc .desc-body strong{color:var(--ink);}
.desc-body.is-clamped{display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:3;overflow:hidden;}
.desc-body.is-clamped::after{content:"";position:absolute;left:0;right:0;bottom:0;height:46px;background:linear-gradient(transparent,var(--bg));pointer-events:none;}
.desc-toggle{margin-top:12px;border:none;background:none;padding:4px 0;cursor:pointer;font-size:14.5px;font-weight:600;color:var(--accent-text);}
.desc-toggle:hover{text-decoration:underline;}
.desc-toggle:focus-visible{outline:2px solid var(--accent-text);outline-offset:2px;border-radius:4px;}

/* ---------- статьи (журнал) ---------- */
.articles-track{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
.article-card{display:flex;flex-direction:column;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:#fff;text-align:left;padding:0;cursor:pointer;transition:box-shadow .2s var(--ease),transform .2s var(--ease);}
.article-card:hover{box-shadow:0 16px 36px -22px rgba(20,20,30,.3);transform:translateY(-3px);}
.article-card:focus-visible{outline:2px solid var(--accent-text);outline-offset:2px;}
.article-media{aspect-ratio:16/10;background:var(--surface);display:block;}
.article-media img{width:100%;height:100%;object-fit:cover;display:block;}
.article-body{padding:16px 18px 18px;display:flex;flex-direction:column;gap:9px;flex:1;}
.article-tag{font-size:11.5px;font-weight:600;color:var(--accent);text-transform:uppercase;letter-spacing:.06em;}
.article-title{font-size:16px;font-weight:600;line-height:1.35;color:var(--ink);}
.article-more{margin-top:auto;font-size:14px;font-weight:600;color:var(--accent-text);display:inline-flex;align-items:center;gap:5px;}

/* ---------- универсальная модалка (инфо-чипы / рассрочка / справка) ---------- */
.modal-scrim{position:fixed;inset:0;background:rgba(20,14,9,.55);opacity:0;pointer-events:none;transition:opacity .25s;z-index:110;}
.modal-scrim.show{opacity:1;pointer-events:auto;}
.modal{position:fixed;inset:0;z-index:111;display:grid;place-items:center;padding:18px;opacity:0;visibility:hidden;transition:opacity .22s,visibility .22s;}
.modal.open{opacity:1;visibility:visible;}
.modal:focus{outline:none;}
.modal-card{background:var(--bg);border-radius:var(--radius);max-width:500px;width:100%;max-height:86vh;overflow-y:auto;transform:translateY(10px);transition:transform .22s var(--ease);box-shadow:0 40px 90px -30px rgba(20,14,9,.5);}
.modal.open .modal-card{transform:none;}
.modal-head{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:22px 24px 8px;}
.modal-head h2{margin:0;font-family:var(--font-display);font-size:22px;}
.modal-body{padding:8px 24px 24px;line-height:1.6;color:var(--ink-2);font-size:15px;}
.modal-body p{margin:0 0 12px;}
.modal-body p:last-child{margin-bottom:0;}
.modal-body strong{color:var(--ink);}
.modal-lead{color:var(--ink);}
.modal-fine{font-size:13px;color:var(--muted);margin-top:14px;}
.install-providers{list-style:none;padding:0;margin:14px 0;display:flex;flex-direction:column;gap:10px;}
.install-providers li{display:grid;grid-template-columns:1fr auto;align-items:baseline;gap:2px 12px;padding:14px 16px;border:1px solid var(--line);border-radius:10px;}
.ip-name{font-weight:700;color:var(--ink);font-size:15px;}
.ip-bank{font-size:12.5px;color:var(--muted);text-align:right;}
.ip-terms{grid-column:1/-1;font-size:13px;color:var(--ink-2);margin-top:3px;}

/* ---------- адаптив PDP-блоков ---------- */
@media(max-width:520px){
  .info-chips{grid-template-columns:repeat(2,1fr);}
}
@media(max-width:760px){
  .articles-track{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;gap:12px;margin:0 -16px;padding:0 16px 4px;scrollbar-width:none;}
  .articles-track::-webkit-scrollbar{display:none;}
  .article-card{flex:0 0 80%;scroll-snap-align:start;}
}
@media(max-width:520px){
  .modal{place-items:end center;padding:0;}
  .modal-card{max-width:none;border-radius:var(--radius) var(--radius) 0 0;max-height:90vh;}
}
/* Тач-устройства: ховер-раскрытие действий карточки не работает → показываем сразу */
@media(hover:none){
  .card-quick,.fav{opacity:1;transform:none;}
  .pricebox-perks .fav-btn{min-height:44px;} /* tap-таргет ≥44px только на тач (на десктопе ряд компактнее) */
}
/* Тап-таргеты ≥44px на узких/тач-экранах (фикс ревью) */
@media(max-width:560px){
  .fav{width:44px;height:44px;}
  .card-quick .btn{min-height:44px;}
  .select-wrap select{padding-top:11px;padding-bottom:11px;}
}

/* ---------- футер: соц-иконки + оплата (ряд) ---------- */
.ft-mid{max-width:var(--maxw);margin:0 auto;padding:22px 32px;display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;border-top:1px solid var(--line);}
.ft-social{display:flex;gap:10px;}
.ft-soc{width:40px;height:40px;border-radius:50%;display:grid;place-items:center;color:var(--ink-2);background:var(--surface-2);transition:background .15s,color .15s,transform .15s;}
.ft-soc:hover{color:#fff;background:var(--accent);transform:translateY(-2px);}
/* ---------- футер: нижний бар (копирайт · тема · юр-ссылки · подпись) ---------- */
.ft-bottom{flex-wrap:wrap;gap:16px;}
.ft-copy{font-weight:500;color:var(--ink-2);}
.ft-bottom-mid{display:flex;align-items:center;gap:22px;flex-wrap:wrap;}
.ft-theme{display:inline-flex;align-items:center;gap:8px;background:none;border:none;color:var(--ink-2);font-size:14px;cursor:pointer;padding:6px 0;transition:color .15s;}
.ft-theme:hover{color:var(--accent);}
.ft-theme-ic{display:inline-grid;place-items:center;color:var(--accent-text);}
.ft-blink,.ft-flink{background:none;border:none;color:var(--ink-2);font-size:14px;padding:0;cursor:default;text-decoration:underline;text-decoration-color:var(--line-2);text-underline-offset:3px;transition:color .15s;}
.ft-blink:hover,.ft-flink:hover{color:var(--accent);}
.ft-dev{color:var(--muted);font-size:14px;}
/* ---------- футер: юр-текст ---------- */
/* (.ft-fine удалён вместе с блоком юр-текста) */
@media(max-width:640px){
  .ft-mid{padding-left:20px;padding-right:20px;flex-direction:column;align-items:flex-start;gap:16px;}
  .ft-bottom{flex-direction:column;align-items:flex-start;gap:14px;}
  .ft-bottom-mid{flex-direction:column;align-items:flex-start;gap:12px;}
}

/* ============ ТЁМНАЯ ТЕМА (data-theme="dark") — флип токенов + точечные оверрайды ============ */
:root[data-theme="dark"]{
  --bg:#16121C; --surface:#1F1A29; --surface-2:#2A2438;
  --ink:#F3EEF3; --ink-2:#BDB4C6; --muted:#8C8398;
  --line:rgba(255,255,255,.10); --line-2:rgba(255,255,255,.20);
  --dark:#0E0B14; --dark-2:#171221;
  --accent:#E0668E; --accent-text:#ED90AE; /* роза светлее — как текст-акцент на тёмном (AA на surface) */
}
/* поверхности с хардкод-#fff → тёмные */
:root[data-theme="dark"] .sf-fam,
:root[data-theme="dark"] .sf-card,
:root[data-theme="dark"] .sf-alt,
:root[data-theme="dark"] .vol-opt.on,
:root[data-theme="dark"] .info-chip,
:root[data-theme="dark"] .ft-news input,
:root[data-theme="dark"] .article-card{background:var(--surface);}
:root[data-theme="dark"] .sf-grid{background:linear-gradient(120deg,#241C2E 0%,#1B1922 52%,#281D27 100%);}
/* элементы с фоном=var(--ink) (стал светлым) → тёмный текст */
:root[data-theme="dark"] .btn-dark,
:root[data-theme="dark"] .btn-primary,
:root[data-theme="dark"] .badge-best,
:root[data-theme="dark"] .skip-link,
:root[data-theme="dark"] .wbc-arrows button:hover{color:var(--bg);}
:root[data-theme="dark"] .btn-white{color:#19171A;} /* белая кнопка — всегда тёмный текст */
/* бейджи/полосы с фоном=accent-text (светлеет) → насыщенная роза под белый текст */
:root[data-theme="dark"] .ic-badge,
:root[data-theme="dark"] .badge-new,
:root[data-theme="dark"] .promo-off,
:root[data-theme="dark"] .marquee,
:root[data-theme="dark"] .btn-gold,
:root[data-theme="dark"] .hd-cart:hover{background:#C24E6E;}
:root[data-theme="dark"] .hd-cart .ic-badge{background:#fff;color:#B23A63;}
/* декоративные светлые градиенты контента (инлайн) — гасим в тёмной до surface */
:root[data-theme="dark"] .promo,
:root[data-theme="dark"] .market-card,
:root[data-theme="dark"] .edito,
:root[data-theme="dark"] .gift,
:root[data-theme="dark"] .brand-hero,
:root[data-theme="dark"] .cat-split{background:var(--surface)!important;}

/* ---------- PDP: кнопки покупки в столбик (В корзину + Купить в 1 клик) ---------- */
.pdp-buy{flex-direction:column;gap:10px;align-items:stretch;}
@media(max-width:560px){.pdp-buy .btn{flex:0 0 auto;width:100%;}}
/* быстрый заказ (попап) */
.qo-lead{font-size:15px;color:var(--ink);margin:0 0 16px;}
.qo-field{display:block;margin:0 0 12px;}
.qo-field span{display:block;font-size:13px;color:var(--ink-2);margin:0 0 6px;}
.qo-field input{width:100%;background:var(--surface);border:1px solid var(--line-2);border-radius:10px;padding:12px 14px;font-size:15px;color:var(--ink);outline:none;}
.qo-field input:focus{border-color:var(--accent);}
.qo-note{font-size:12px;line-height:1.5;color:var(--muted);margin:12px 0 0;}
/* ---------- футер: цветные оплата-марки в чипах ---------- */
.ft-pay{align-items:center;flex-wrap:wrap;}
.pay{display:inline-flex;align-items:center;}
.pay svg{display:block;}
.pay-txt{font-weight:800;letter-spacing:.02em;}
/* ---------- cookie-баннер ---------- */
.cookie{position:fixed;left:16px;right:16px;bottom:16px;max-width:600px;margin:0 auto;z-index:150;background:var(--surface);border:1px solid var(--line-2);border-radius:14px;padding:15px 18px;box-shadow:0 14px 44px rgba(0,0,0,.20);display:flex;align-items:center;gap:16px;flex-wrap:wrap;transform:translateY(170%);transition:transform .35s var(--ease);}
.cookie.show{transform:none;}
.cookie-txt{flex:1;min-width:220px;font-size:13.5px;line-height:1.5;color:var(--ink-2);margin:0;}
.cookie-link{background:none;border:none;padding:0;font:inherit;color:var(--accent-text);text-decoration:underline;cursor:default;}
.cookie-ok{flex-shrink:0;}
@media(max-width:560px){.cookie{left:10px;right:10px;bottom:10px;gap:12px;}}

/* Ф2-2b: таб-панели товарных сеток (атрибут [hidden] перебивается display:grid у .grid → форсим) */
.tab-panel[hidden]{display:none;}
.tab-empty{padding:56px 24px;text-align:center;color:var(--muted);font-size:16px;}

/* Ф2-3a: фото-карточки = ссылка на товар */
.card-imglink{display:block;width:100%;height:100%;}
.card-imglink .card-img{display:block;}

/* Ф2-3b fix: товарные фото (на белом) — показывать ЦЕЛИКОМ, без зум-кропа cover */
.card-img{object-fit:contain;background:#fff;padding:6%;}
.pdp-img{object-fit:contain;background:#fff;}

/* Ф2-4c: кастом умный фильтр (наш сайдбар) */
.fd-smartfilter .filter-price{display:flex;align-items:center;gap:8px;}
.fd-smartfilter .filter-price-inp{flex:1;min-width:0;width:100%;border:1px solid var(--line);border-radius:10px;padding:9px 10px;font:inherit;font-size:14px;background:var(--surface);color:var(--ink);}
.fd-smartfilter .filter-price-dash{color:var(--muted);}
.fd-smartfilter .check-label{flex:1;}
.fd-smartfilter .check-count{color:var(--muted);font-size:12.5px;}
.fd-smartfilter .filter-body-scroll{max-height:280px;overflow:auto;margin-right:-6px;padding-right:6px;}
.fd-smartfilter .filter-actions{margin-top:16px;display:flex;flex-direction:column;gap:10px;}
.fd-smartfilter .filter-reset{text-align:center;color:var(--muted);font-size:14px;text-decoration:none;}
.fd-smartfilter .filter-reset:hover{color:var(--accent-text);}
.catalog-pager{margin-top:28px;}

/* Ф2: перелинковка атрибутов товара → каталог */
.pdp-attrs .attr-link{color:inherit;text-decoration:underline;text-underline-offset:3px;text-decoration-color:color-mix(in srgb,var(--accent) 45%,transparent);transition:color .15s;}
.pdp-attrs .attr-link:hover{color:var(--accent-text);}
a.note-chip{text-decoration:none;cursor:pointer;}
a.note-chip:hover{border-color:var(--accent)!important;color:var(--accent-text);}

/* Ф2-5b: тема страницы корзины (sale.basket.basket bootstrap_v4) под наш дизайн */
.basket-btn-checkout{background:var(--accent)!important;border:none!important;color:#fff!important;border-radius:10px!important;font-family:var(--font-body)!important;font-weight:600!important;box-shadow:none!important;}
.basket-btn-checkout:hover{background:var(--accent-text)!important;color:#fff!important;}
.basket-coupon-block-button,.basket-coupon-block-button-enter{background:var(--accent)!important;border:none!important;color:#fff!important;border-radius:10px!important;}
.basket-item-info-name,.basket-item-info-name a{font-family:var(--font-display)!important;font-weight:400!important;color:var(--ink)!important;font-size:19px!important;line-height:1.15!important;text-decoration:none!important;}
.basket-item-info-name a:hover{color:var(--accent-text)!important;}
.basket-item-price-current,.basket-item-price-sum,.basket-item-sum-price-current,.basket-checkout-block-total-price-current,.basket-checkout-block-total-price{font-family:var(--font-display)!important;color:var(--ink)!important;}
.basket-item-actions-remove{color:var(--muted)!important;}
.basket-item-actions-remove:hover{color:var(--accent-text)!important;}
.basket-item-amount-btn-plus,.basket-item-amount-btn-minus{border:1px solid var(--line)!important;color:var(--ink)!important;background:var(--surface)!important;}
.basket-item-amount-btn-plus:hover,.basket-item-amount-btn-minus:hover{border-color:var(--accent)!important;color:var(--accent)!important;}
.basket-filter,.basket-search,.basket-coupon-block-field-description{display:none!important;}

.basket-items-search-field{display:none!important;}

.basket-checkout-container{background:var(--surface)!important;}
.basket-checkout-container input.form-control,.basket-coupon-input,.basket-item-amount-field{background:var(--surface)!important;color:var(--ink)!important;border:1px solid var(--line)!important;}
.basket-items-list-header,.basket-items-list-container,.basket-items-list-wrapper,.basket-items-list-item-container{background:var(--surface)!important;}

/* Ф2: гендер-табы как ссылки + директория брендов */
.tabs-bar .tabs a.tab{text-decoration:none;}
.brands-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;margin-top:8px;}
.brand-tile{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:18px 20px;border:1px solid var(--line);border-radius:14px;background:var(--surface);text-decoration:none;color:var(--ink);transition:border-color .15s,transform .15s,box-shadow .15s;}
.brand-tile:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 12px 28px -18px rgba(20,14,9,.3);}
.brand-tile-name{font-family:var(--font-display);font-size:18px;}
.brand-tile-cnt{min-width:26px;height:24px;padding:0 8px;border-radius:12px;background:color-mix(in srgb,var(--accent) 14%,transparent);color:var(--accent-text);font-size:13px;font-weight:600;display:inline-flex;align-items:center;justify-content:center;}

/* Ф2: страницы Подарки / Сертификаты + cart-блок подарка */
.gifts-page,.giftcards-page{max-width:1200px;margin:0 auto;padding:30px 24px 64px;}
.gifts-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:18px;}
.gift-tier{border:1px solid var(--line);border-radius:16px;padding:26px 24px;background:var(--surface);display:flex;flex-direction:column;gap:20px;min-height:170px;}
.gift-tier-ic{display:flex;align-items:flex-end;gap:5px;height:48px;}
.gt-drop{width:16px;height:28px;border-radius:50% 50% 50% 50%/60% 60% 40% 40%;background:var(--accent);}
.gift-tier-txt{font-size:16px;line-height:1.45;color:var(--ink);}
.gift-tier-txt strong{font-weight:600;}
.gift-cta{grid-column:span 1;border-radius:16px;padding:28px 24px;background:linear-gradient(150deg,var(--accent),color-mix(in srgb,var(--accent) 60%,#E0567E));color:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:14px;text-decoration:none;}
.gift-cta-ic{width:60px;height:60px;border-radius:50%;background:rgba(255,255,255,.18);display:grid;place-items:center;}
.gift-cta-title{font-family:var(--font-display);font-size:20px;line-height:1.2;}
.giftcards-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:18px;}
.giftcard{border:1px solid var(--line);border-radius:16px;overflow:hidden;background:var(--surface);display:flex;flex-direction:column;}
.giftcard-art{aspect-ratio:8/5;position:relative;display:flex;flex-direction:column;justify-content:center;padding:22px;color:#fff;}
.giftcard-val{font-family:var(--font-display);font-size:38px;line-height:1;text-shadow:0 2px 12px rgba(0,0,0,.15);}
.giftcard-cur{font-size:15px;opacity:.9;}
.giftcard-mark{position:absolute;right:14px;bottom:12px;font-size:11px;letter-spacing:.1em;text-transform:uppercase;opacity:.85;}
.giftcard-body{padding:14px 16px 16px;display:flex;flex-direction:column;gap:10px;flex:1;}
.giftcard-name{font-size:14.5px;line-height:1.3;color:var(--ink);flex:1;}
.giftcard-foot{display:flex;align-items:center;justify-content:space-between;gap:10px;}
.giftcard-price{font-family:var(--font-display);font-size:19px;color:var(--ink);}
.cart-gift-note{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;border:1px solid var(--line);border-radius:12px;padding:12px 16px;margin-bottom:18px;background:var(--surface);}
.cart-gift-left{display:inline-flex;align-items:center;gap:8px;color:var(--ink);font-size:14.5px;}
.cart-gift-left svg{color:var(--accent);}
.cart-gift-link{color:var(--accent-text);font-weight:600;text-decoration:none;}
.cart-gift-link:hover{text-decoration:underline;}
@media(max-width:900px){.gifts-grid{grid-template-columns:repeat(2,1fr);}.giftcards-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:560px){.gifts-grid,.giftcards-grid{grid-template-columns:1fr;}}

/* Ф2: корзина — финальная полировка под orental */
.basket-btn-checkout{background:var(--ink)!important;color:#fff!important;}
.basket-btn-checkout:hover{background:#000!important;color:#fff!important;}
.cart-top-actions{margin:0 0 16px;}
.cart-atomizer{border:1px solid var(--line)!important;font-size:16px;}
.cart-atomizer svg{color:var(--accent);}
.cart-gift-note{justify-content:flex-start;gap:18px;}
.cart-gift-note .cart-gift-left strong{color:var(--accent-text);font-weight:600;}

/* Ф2: корзина — контейнер max-width + порядок (товары перед сводкой) + жирные цены */
.cart-wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px 44px;}
.bx-basket{display:flex;flex-direction:column;}
.bx-basket > .row:has(.basket-items-list-wrapper){order:-1;}
.basket-item-price-current,.basket-item-sum-price-current,.basket-item-sum-price,
.basket-checkout-block-total-price-current,.basket-checkout-block-total-price,
.basket-item-price-difference{font-weight:700!important;}

/* Ф2: каталог-листинг под orental — контролы в строке табов, переключатель вида, мелкая плитка */
.tabs-bar{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;flex-wrap:wrap;}
.catalog-controls{display:flex;align-items:center;gap:14px;padding-bottom:12px;}
.view-toggle{display:flex;gap:4px;}
.view-btn{width:40px;height:40px;border:1px solid var(--line);border-radius:9px;display:grid;place-items:center;background:none;color:var(--muted);cursor:pointer;transition:border-color .15s,color .15s;}
@media(max-width:768px){.view-btn{width:44px;height:44px;}}
.view-btn:hover{color:var(--ink-2);}
.view-btn.on{border-color:var(--accent);color:var(--accent);}
.results-bar{display:none;}
.grid.grid-small{grid-template-columns:repeat(5,minmax(0,1fr));gap:18px 14px;}
.grid.grid-small .card-name{font-size:14px;}
.grid.grid-small .card-brand{font-size:11px;}
.grid.grid-small .card-fam{font-size:12px;}
.grid.grid-small .card-quick{display:none;}
@media(max-width:1200px){.grid.grid-small{grid-template-columns:repeat(4,minmax(0,1fr));}}
@media(max-width:860px){
  .results-bar{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:18px;}
  .catalog-controls{padding-bottom:10px;}
  .grid.grid-small{grid-template-columns:repeat(2,minmax(0,1fr));}
}
@media(max-width:520px){.catalog-controls .sort span{display:none;}}

/* Ф2: шапка страницы бренда (название/страна/описание + «Читать дальше») */
.brandpage-hero{max-width:760px;}
.brandpage-hero-name{margin-bottom:8px;}
.brandpage-hero-country{color:var(--ink-2);margin:0 0 12px;font-size:15px;}
.brandpage-hero-country strong{font-weight:600;}
.brandpage-hero-desc{color:var(--muted);line-height:1.6;font-size:15px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.brandpage-hero-desc.expanded{-webkit-line-clamp:unset;display:block;}
.brandpage-hero-more{background:none;border:none;color:var(--ink);font-weight:600;padding:6px 0 0;cursor:pointer;text-decoration:underline;text-underline-offset:3px;font-size:14.5px;}
.brandpage-hero .catalog-sub{margin-top:14px;}

/* Ф2: корзина — заголовок «Корзина» + жирнее имена + попап атомайзера */
.cart-title{font-family:var(--font-display);font-weight:700;font-size:34px;margin:0 0 20px;color:var(--ink);}
.basket-item-info-name,.basket-item-info-name a{font-weight:600!important;}
.atomizer-popup{display:flex;gap:24px;align-items:center;}
.atom-img{flex:0 0 110px;display:grid;place-items:center;}
.atom-opts{flex:1;display:flex;flex-direction:column;gap:18px;min-width:0;}
.atom-label{font-weight:600;margin-bottom:8px;font-size:14px;color:var(--ink);}
.atom-pills,.atom-colors{display:flex;flex-wrap:wrap;gap:8px;}
.atom-pill{padding:8px 16px;border:1px solid var(--line);border-radius:9px;background:none;cursor:pointer;font-size:14px;color:var(--ink);}
.atom-pill.on{background:var(--ink);color:#fff;border-color:var(--ink);}
.atom-color{display:inline-flex;align-items:center;gap:7px;padding:7px 12px;border:1px solid var(--line);border-radius:9px;background:none;cursor:pointer;font-size:13.5px;color:var(--ink);}
.atom-color.on{border-color:var(--accent);box-shadow:inset 0 0 0 1px var(--accent);}
.atom-sw{width:16px;height:16px;border-radius:50%;border:1px solid rgba(0,0,0,.15);display:inline-block;}
.atom-foot{display:flex;align-items:center;gap:16px;margin-top:4px;flex-wrap:wrap;}
.atom-qty{display:flex;align-items:center;gap:2px;border:1px solid var(--line);border-radius:9px;padding:2px;}
.atom-q{width:30px;height:30px;border:none;background:none;cursor:pointer;font-size:18px;color:var(--ink);line-height:1;}
.atom-qty span{min-width:26px;text-align:center;font-weight:600;}
.atom-price{font-family:var(--font-display);font-size:22px;font-weight:700;margin-left:auto;color:var(--ink);}
@media(max-width:560px){.atomizer-popup{flex-direction:column;align-items:stretch;}.atom-price{margin-left:0;}}

/* ===== Ф2: КАСТОМ-КОРЗИНА (sale.basket.basket/.default) под orental ===== */
.fd-cart-table{border:1px solid var(--line);border-radius:16px;overflow:hidden;background:#fff;}
.fd-cart-head,.fd-cart-row{display:grid;grid-template-columns:1fr 92px 150px 132px 120px 40px;align-items:center;gap:16px;padding:0 22px;}
.fd-cart-head{height:48px;background:var(--surface);border-bottom:1px solid var(--line);}
.fd-ch{font-size:15px;color:var(--ink-2);font-weight:600;}
.fd-ch-disc,.fd-ch-price,.fd-ch-qty,.fd-ch-sum{text-align:center;}
.fd-cart-row{padding-top:18px;padding-bottom:18px;border-bottom:1px solid var(--line);background:#fff;}
.fd-cart-row:last-child{border-bottom:none;}
.fd-cart-row.is-busy{opacity:.5;pointer-events:none;}
.fd-cell-product{display:flex;align-items:center;gap:18px;min-width:0;}
.fd-cr-img{flex:0 0 72px;width:72px;height:92px;border-radius:8px;overflow:hidden;background:#fff;border:1px solid var(--line);display:grid;place-items:center;}
.fd-cr-img img{width:100%;height:100%;object-fit:contain;}
.fd-cr-noimg{background:var(--surface);}
.fd-cr-info{min-width:0;}
.fd-cr-brand{font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin-bottom:3px;}
.fd-cr-name{font-family:var(--font-display);font-size:17px;color:var(--ink);text-decoration:none;font-weight:600;display:inline-block;}
.fd-cr-name:hover{color:var(--accent-text);}
.fd-cr-offer{font-size:13px;color:var(--muted);margin-top:3px;}
.fd-cr-prop{font-size:13px;color:var(--ink-2);margin-top:3px;}
.fd-cr-prop strong{font-weight:600;}
.fd-cell-disc{text-align:center;font-weight:700;color:var(--accent-text);}
.fd-cell-price{display:flex;flex-direction:column;align-items:center;gap:1px;}
.fd-cr-price{font-family:var(--font-display);font-weight:800;font-size:16px;color:var(--ink);}
.fd-cr-oldprice{font-size:13px;color:var(--muted);text-decoration:line-through;}
.fd-cr-per{font-size:11px;color:var(--muted);}
.fd-cell-qty{display:flex;justify-content:center;}
.fd-qty{display:inline-flex;align-items:center;border:1px solid var(--line);border-radius:9px;}
.fd-q{width:34px;height:36px;border:none;background:none;font-size:18px;color:var(--ink);cursor:pointer;line-height:1;}
.fd-qv{width:42px;height:36px;border:none;text-align:center;font-weight:700;background:none;color:var(--ink);}
.fd-cell-sum{text-align:center;}
.fd-cr-sum{font-family:var(--font-display);font-weight:800;font-size:17px;color:var(--ink);}
.fd-cr-del{border:none;background:none;color:var(--muted);cursor:pointer;display:grid;place-items:center;padding:0;justify-self:end;}
.fd-cr-del:hover{color:var(--accent-text);}
.fd-cart-bottom{display:grid;grid-template-columns:1fr 1fr 360px;gap:18px;margin-top:22px;align-items:start;}
.fd-cart-gift{display:flex;align-items:center;gap:14px;border:1px solid var(--line);border-radius:14px;padding:18px 20px;background:var(--surface);}
.fd-gift-ic{flex:0 0 auto;color:var(--accent);display:inline-flex;}
.fd-gift-title{font-size:16px;color:var(--ink);}
.fd-gift-title strong{color:var(--accent-text);font-weight:700;}
.fd-gift-link{font-size:14px;color:var(--accent-text);font-weight:600;text-decoration:none;}
.fd-gift-link:hover{text-decoration:underline;}
.fd-coupon{border:1px solid var(--line);border-radius:14px;padding:0 20px;background:#fff;}
.fd-coupon summary{display:flex;align-items:center;justify-content:space-between;cursor:pointer;list-style:none;padding:19px 0;font-weight:600;color:var(--ink);}
.fd-coupon summary::-webkit-details-marker{display:none;}
.fd-coupon-sum{display:inline-flex;align-items:center;gap:12px;font-size:16px;}
.fd-coupon-sum svg{color:var(--accent);}
.fd-promo-ic{width:40px;height:40px;flex:0 0 40px;}
.fd-coupon-body{display:flex;gap:8px;padding:0 0 20px;}
.fd-coupon-inp{flex:1;border:1px solid var(--line);border-radius:9px;padding:0 14px;height:42px;font-size:14px;background:#fff;color:var(--ink);}
.fd-cart-total{border:1px solid var(--line);border-radius:14px;padding:20px 22px;background:var(--surface);}
.fd-total-row{display:flex;justify-content:space-between;align-items:baseline;gap:12px;margin-bottom:10px;color:var(--ink-2);font-size:15px;}
.fd-total-disc span:last-child{color:var(--accent-text);font-weight:600;}
.fd-total-final{font-size:16px;color:var(--ink);border-top:1px solid var(--line);padding-top:14px;margin-top:4px;font-weight:600;}
.fd-total-final span:last-child{font-family:var(--font-display);font-weight:800;font-size:26px;}
.fd-checkout{width:100%;margin-top:14px;justify-content:center;}
.fd-cart-empty{text-align:center;padding:70px 24px;color:var(--muted);display:flex;flex-direction:column;gap:18px;align-items:center;}
@media(max-width:860px){
  .cart-wrap{padding:0 16px 40px;}
  .fd-cart-head{display:none;}
  .fd-cart-row{grid-template-columns:1fr auto;grid-template-areas:"product del" "disc price" "qty sum";gap:10px 14px;}
  .fd-cell-product{grid-area:product;}
  .fd-cell-disc{grid-area:disc;text-align:left;}
  .fd-cell-disc::before{content:attr(data-th)": ";color:var(--muted);font-weight:400;}
  .fd-cell-price{grid-area:price;align-items:flex-end;}
  .fd-cell-qty{grid-area:qty;justify-content:flex-start;}
  .fd-cell-sum{grid-area:sum;text-align:right;}
  .fd-cell-sum::before{content:"Сумма: ";color:var(--muted);font-size:12px;}
  .fd-cr-del{grid-area:del;justify-self:end;}
  .fd-cart-bottom{grid-template-columns:1fr;}
}

/* Ф2: кастом-корзина — тёмная тема (белые блоки → тёмная поверхность) */
[data-theme="dark"] .fd-cart-table,
[data-theme="dark"] .fd-cart-row,
[data-theme="dark"] .fd-coupon,
[data-theme="dark"] .fd-cr-img,
[data-theme="dark"] .fd-coupon-inp{background:var(--surface);}

/* Ф2: блоки подарок/промокод одинаковой высоты */
.fd-cart-gift{min-height:88px;}
.fd-coupon{min-height:88px;display:flex;flex-direction:column;justify-content:center;}

/* Ф2: Quick-view попап (быстрый просмотр с листинга) — большой, как orental */
.modal-card:has(.qv){max-width:1280px;}
.modal-card:has(.qv) .modal-head{padding:26px 30px 8px;}
.modal-card:has(.qv) .modal-head h2{font-size:28px;}
.modal-card:has(.qv) .modal-body{padding:8px 30px 30px;}
.qv{display:grid;grid-template-columns:44% 1fr;gap:40px;align-items:start;}
.qv-media{background:#fff;border-radius:var(--radius);padding:22px;display:grid;place-items:center;min-height:400px;}
.qv-media img{max-width:100%;max-height:470px;object-fit:contain;}
.qv-opts{display:flex;flex-direction:column;gap:24px;padding-top:2px;}
.qv-subtitle{font-size:19px;color:var(--ink-2);}
.qv-field .qv-label{font-weight:700;margin-bottom:11px;font-size:16px;color:var(--ink);}
.qv-pills{display:flex;flex-wrap:wrap;gap:9px;}
.qv-pill{padding:12px 20px;border:1px solid var(--line);border-radius:10px;background:none;cursor:pointer;font-size:16px;color:var(--ink);}
.qv-pill.on{background:var(--ink);color:#fff;border-color:var(--ink);}
.qv-pricebox{display:flex;align-items:center;justify-content:space-between;gap:20px;background:var(--surface);border-radius:var(--radius);padding:22px 24px;flex-wrap:wrap;}
.qv-price{font-family:var(--font-display);font-weight:800;font-size:38px;color:var(--ink);}
.qv-pricebox .btn{margin-left:auto;}
.qv-more{align-self:flex-end;border:1px solid var(--line);border-radius:10px;padding:11px 22px;color:var(--ink);text-decoration:none;font-weight:600;font-size:15px;transition:border-color .15s,color .15s;}
.qv-more:hover{border-color:var(--accent);color:var(--accent-text);}
[data-theme="dark"] .qv-media{background:var(--surface);}
@media(max-width:760px){.qv{grid-template-columns:1fr;gap:20px;}.qv-media{min-height:240px;}.qv-pricebox .btn{margin-left:0;}}

/* Ф2: Попап «Товар добавлен в корзину» */
.fd-added{display:flex;flex-direction:column;gap:18px;}
.fd-added-item{display:flex;align-items:center;gap:14px;}
.fd-added-img{flex:0 0 56px;width:56px;height:70px;border-radius:8px;overflow:hidden;border:1px solid var(--line);background:#fff;display:grid;place-items:center;}
.fd-added-img img{width:100%;height:100%;object-fit:contain;}
.fd-added-info{flex:1;min-width:0;font-size:15px;color:var(--ink);line-height:1.35;}
.fd-added-brand{font-weight:700;}
.fd-added-price{font-family:var(--font-display);font-weight:800;font-size:16px;white-space:nowrap;}
.fd-added-summary{text-align:center;color:var(--ink-2);font-size:15px;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:16px 0;}
.fd-added-actions{display:flex;flex-direction:column;gap:10px;}
.fd-added-actions .btn{width:100%;justify-content:center;}
[data-theme="dark"] .fd-added-img{background:var(--surface);}

/* Ф2: пагинация каталога как orental — «Показать ещё» + номера по центру */
.catalog-pager-wrap{display:flex;flex-direction:column;align-items:center;gap:22px;margin-top:44px;}
.catalog-loadmore{min-width:210px;}
.catalog-loadmore.is-busy{opacity:.6;pointer-events:none;}
.catalog-pager{display:flex;flex-wrap:wrap;gap:6px;align-items:center;justify-content:center;width:100%;margin:0;}
.pg-num{display:inline-flex;align-items:center;justify-content:center;min-width:44px;height:44px;padding:0 10px;border-radius:11px;font-family:var(--font-display);font-size:16px;color:var(--ink-2);text-decoration:none;border:1px solid transparent;transition:border-color .15s,color .15s;}
.pg-num:hover{border-color:var(--line);color:var(--ink);}
.pg-num.active{background:var(--ink);color:#fff;font-weight:600;}
.pg-dots{display:inline-flex;align-items:flex-end;justify-content:center;min-width:30px;height:44px;color:var(--muted);}

/* Ф2: мобайл-фиксы — подбор аромата (кнопка «В корзину» не уезжает) + «В избранное» под «В наличии» */
@media(max-width:560px){
  .sf-card-foot{flex-direction:column;align-items:stretch;gap:10px;}
  .sf-card-foot .btn{width:100%;}
  .pricebox-perks .fav-btn{margin-left:0;flex-basis:100%;justify-content:flex-start;}
}

/* Ф2: скидка −20% (отображение; реальное списание — Ф4 с настройкой движка скидок) */
.card-badges{position:absolute;top:12px;left:12px;z-index:2;display:flex;flex-direction:column;align-items:flex-start;gap:6px;}
.card-badge{font-size:13px;font-weight:700;padding:6px 12px;border-radius:8px;color:#fff;line-height:1;}
.card-badge.bg-disc{background:var(--accent);}
.card-badge.bg-hit{background:#E6A52B;}
.card-badge.bg-new{background:var(--ink);}
.card-foot{display:flex;align-items:baseline;gap:8px;flex-wrap:wrap;}
.card-oldprice{font-size:13px;color:var(--muted);text-decoration:line-through;}
.pdp-price-main{display:flex;align-items:baseline;gap:12px;flex-wrap:wrap;}
.pdp-price-old{font-size:18px;color:var(--muted);text-decoration:line-through;font-family:var(--font-display);}
.pdp-price-disc{background:var(--accent);color:#fff;font-size:13px;font-weight:700;padding:3px 8px;border-radius:7px;align-self:center;}
.qv-priceblock{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap;}
.qv-oldprice{font-size:18px;color:var(--muted);text-decoration:line-through;font-family:var(--font-display);}
.qv-disc{background:var(--accent);color:#fff;font-size:13px;font-weight:700;padding:3px 8px;border-radius:7px;align-self:center;}

/* ── «Под заказ» (предзаказ) + форма заявки ── */
.btn-line{background:transparent;color:var(--ink);border:1px solid var(--line);}
.btn-line:hover{background:var(--ink);color:#fff;border-color:var(--ink);}
.card-badge.bg-pre{background:var(--ink);}
.card-preorder{font-size:14px;font-weight:600;color:var(--muted);}
.card-noimg{display:flex;align-items:center;justify-content:center;width:100%;height:100%;min-height:220px;color:var(--muted);font-size:13px;letter-spacing:.02em;background:var(--surface);border-radius:inherit;}
.pre-form{display:flex;flex-direction:column;gap:14px;}
.pre-lead{margin:0 0 4px;color:var(--muted);font-size:15px;line-height:1.5;}
.pre-row{display:flex;flex-direction:column;gap:6px;font-size:14px;font-weight:600;color:var(--ink);}
.pre-row input{padding:12px 14px;border:1px solid var(--line);border-radius:10px;background:var(--surface);color:var(--ink);font-size:15px;font-weight:400;}
.pre-row input:focus{outline:none;border-color:var(--accent);}
.pre-agree{display:flex;align-items:flex-start;gap:9px;font-size:13px;color:var(--muted);line-height:1.4;cursor:pointer;}
.pre-agree input{margin-top:2px;flex:0 0 auto;}
.pre-agree.pre-err span{color:var(--accent);}
.pre-ok{text-align:center;padding:10px 0;}
.pre-ok p{margin:0 0 18px;font-size:16px;line-height:1.5;}
.qv-media{position:relative;}
.pyramid-tiers{display:flex;flex-direction:column;gap:18px;}
.pyramid-tier-label{font-size:13px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--accent-text);margin-bottom:9px;}
.pyramid-tier .note-chips{display:flex;flex-wrap:wrap;gap:8px;}
/* инфо/право-страницы */
.info-page{max-width:900px;margin:0 auto;padding:0 20px 40px;}
.info-body{line-height:1.8;color:var(--ink-2);font-size:16px;margin-top:18px;}
.info-body h2{font-size:22px;font-weight:700;margin:30px 0 12px;color:var(--ink);font-family:var(--font-display);}
.info-body h3{font-size:18px;font-weight:700;margin:22px 0 10px;color:var(--ink);}
.info-body p{margin:0 0 14px;}
.info-body ul,.info-body ol{padding-left:22px;margin:8px 0 14px;}
.info-body li{margin:0 0 7px;}
.info-body a{color:var(--accent-text);font-weight:600;}
.info-body strong{color:var(--ink);}
.info-body table{width:100%;border-collapse:collapse;margin:14px 0;}
.info-body th,.info-body td{border:1px solid var(--line);padding:10px 12px;text-align:left;}
/* галерея товара (слайдер-миниатюры) */
.pdp-thumbs{display:flex;gap:10px;margin-top:12px;flex-wrap:wrap;}
.pdp-thumb{width:70px;height:88px;border-radius:10px;overflow:hidden;border:2px solid var(--line);background:var(--surface);padding:0;cursor:pointer;transition:border-color .15s;}
.pdp-thumb.on{border-color:var(--accent);}
.pdp-thumb img{width:100%;height:100%;object-fit:cover;display:block;}


.note-chip{display:inline-flex;align-items:center;}

.note-chip{display:inline-flex;align-items:center;}
.note-img{width:24px;height:24px;border-radius:50%;object-fit:cover;margin-right:8px;flex-shrink:0;background:var(--surface-2);}
.note-emoji{margin-right:7px;font-size:15px;line-height:1;}

/* Избранное — страница /personal/favorites/ */
.fav-page{min-height:50vh}
.fav-empty:not([hidden]){text-align:center;padding:48px 16px 72px;display:flex;flex-direction:column;align-items:center;gap:18px}
.fav-empty p{color:var(--muted,#6b6b6b);max-width:420px;margin:0}
.fav-grid:empty{display:none}

/* Оформление заказа (sale.order.ajax bootstrap) — лёгкая подгонка под бренд */
.bx-soa-section{border-radius:var(--radius,12px);border:1px solid var(--line,#ece8ea);margin-bottom:14px}
.bx-soa-section-title{font-family:inherit;font-weight:600}
.bx-soa .btn-default,.bx-soa .btn-primary{border-radius:999px;font-weight:600}
.bx-soa .btn-primary,#bx-soa-orderSave .btn,.bx-soa-cart-total .checkout-button{background:var(--ink,#19171A);border-color:var(--ink,#19171A);color:#fff}
.bx-soa-coupon-item,.bx-soa-pp-company{border-radius:10px}
.bx-soa-price-total .bx-soa-cart-total{border-radius:var(--radius,12px)}

/* ============ КАСТОМНЫЙ CHECKOUT (одностраничный) ============ */
.checkout{max-width:var(--maxw);margin:0 auto;padding:18px 32px 64px}
.co-grid{display:grid;grid-template-columns:1fr 360px;gap:28px;align-items:start;margin-top:18px}
.co-main{display:flex;flex-direction:column;gap:16px;min-width:0}
.co-block{background:var(--bg);border:1px solid var(--line);border-radius:var(--radius);padding:20px 22px}
.co-h2{display:flex;align-items:center;gap:10px;font-family:var(--font-display);font-weight:600;font-size:19px;margin:0 0 16px;color:var(--ink)}
.co-step{display:grid;place-items:center;width:26px;height:26px;border-radius:50%;background:var(--accent);color:#fff;font-size:14px;font-weight:700;flex-shrink:0}
.co-fields{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.co-field{display:flex;flex-direction:column;gap:6px}
.co-field:first-child{grid-column:1/-1}
.co-field span{font-size:13.5px;color:var(--ink-2);font-weight:600}
.co-field span i{color:var(--accent-text);font-style:normal}
.co-field input,.co-pop-city input{height:48px;border:1.5px solid var(--line-2);border-radius:12px;padding:0 14px;font:inherit;font-size:15.5px;color:var(--ink);background:var(--bg);transition:border-color .15s}
.co-field input:focus,.co-pop-city input:focus{outline:none;border-color:var(--accent)}
.co-err input,input.co-err,.co-err{animation:coShake .35s}
.co-err input{border-color:#e0455f!important}
.co-agree.co-err{outline:2px solid #e0455f;outline-offset:4px;border-radius:6px}
@keyframes coShake{0%,100%{transform:translateX(0)}25%{transform:translateX(-5px)}75%{transform:translateX(5px)}}
/* доставка */
.co-deliv-chosen{margin-bottom:12px}
.co-deliv-empty{color:var(--muted);font-size:15px}
.co-deliv-card{display:flex;align-items:center;justify-content:space-between;gap:14px;border:1.5px solid var(--accent);border-radius:12px;padding:14px 16px;background:var(--surface)}
.co-deliv-l{display:flex;align-items:center;gap:12px}
.co-deliv-ic,.co-pop-ic{font-size:26px;line-height:1}
.co-deliv-name{font-weight:600;color:var(--ink)}
.co-deliv-term{font-size:13px;color:var(--ink-2);margin-top:2px}
.co-deliv-price{font-weight:700;color:var(--ink);white-space:nowrap}
/* оплата */
.co-pay{display:flex;flex-direction:column;gap:10px}
.co-pay-opt{display:flex;align-items:flex-start;gap:11px;border:1.5px solid var(--line-2);border-radius:12px;padding:13px 15px;cursor:pointer;transition:border-color .15s}
.co-pay-opt:has(input:checked){border-color:var(--accent);background:var(--surface)}
.co-pay-opt input{margin-top:3px;accent-color:var(--accent);width:18px;height:18px}
.co-pay-opt span{display:flex;flex-direction:column;gap:2px}
.co-pay-opt small{color:var(--ink-2);font-size:13px}
.co-pay-note{font-size:13px;color:var(--muted);margin:4px 0 0}
/* товары */
.co-items{display:flex;flex-direction:column;gap:12px}
.co-item{display:grid;grid-template-columns:56px 1fr auto auto;gap:14px;align-items:center}
.co-item-img{width:56px;height:70px;border-radius:8px;overflow:hidden;background:var(--surface);flex-shrink:0}
.co-item-img img{width:100%;height:100%;object-fit:cover}
.co-item-brand{font-size:12px;color:var(--accent-text);font-weight:600}
.co-item-name{font-size:14.5px;color:var(--ink);line-height:1.3}
.co-item-vol{font-size:13px;color:var(--ink-2)}
.co-item-qty{font-size:14px;color:var(--ink-2);white-space:nowrap}
.co-item-sum{font-weight:700;color:var(--ink);white-space:nowrap}
.co-edit-cart{display:inline-block;margin-top:14px;font-size:14px;color:var(--accent-text);font-weight:600}
/* сводка-сайдбар */
.co-side{position:sticky;top:90px}
.co-summary{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:22px}
.co-sum-row{display:flex;justify-content:space-between;padding:7px 0;color:var(--ink-2);font-size:15px}
.co-sum-total{display:flex;justify-content:space-between;align-items:baseline;padding:14px 0 4px;margin-top:6px;border-top:1px solid var(--line);font-weight:700;font-size:21px;color:var(--ink)}
.co-free{color:#1a9f5a;font-weight:700}
.co-agree{display:flex;align-items:flex-start;gap:9px;margin:16px 0;font-size:13px;color:var(--ink-2);line-height:1.4}
.co-agree input{margin-top:2px;accent-color:var(--accent);width:17px;height:17px;flex-shrink:0}
.co-agree a{color:var(--accent-text)}
.co-side-note{text-align:center;font-size:12.5px;color:var(--muted);margin:12px 0 0}
/* попап доставки */
.co-pop{display:flex;flex-direction:column;gap:16px}
.co-pop-city{display:flex;flex-direction:column;gap:6px}
.co-pop-city span{font-size:13.5px;font-weight:600;color:var(--ink-2)}
.co-pop-cards{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.co-pop-card{display:flex;gap:11px;border:1.5px solid var(--line-2);border-radius:12px;padding:13px;cursor:pointer;transition:border-color .15s,background .15s;position:relative}
.co-pop-card:has(input:checked){border-color:var(--accent);background:var(--surface)}
.co-pop-card input{position:absolute;top:12px;right:12px;accent-color:var(--accent);width:18px;height:18px}
.co-pop-body{display:flex;flex-direction:column;gap:3px;min-width:0}
.co-pop-name{font-weight:600;color:var(--ink);font-size:14.5px}
.co-pop-price{font-weight:700;color:var(--ink)}
.co-pop-term{font-size:12.5px;color:var(--ink-2)}
.co-pop-note{font-size:12px;color:var(--accent-text);font-weight:600}
.co-shake{animation:coShake .35s}
/* финал/пусто */
.co-done,.co-empty{text-align:center;padding:56px 16px 72px;display:flex;flex-direction:column;align-items:center;gap:16px}
.co-done-ic{width:64px;height:64px;border-radius:50%;background:#1a9f5a;color:#fff;display:grid;place-items:center;font-size:34px}
.co-done p,.co-empty p{color:var(--ink-2);max-width:440px;margin:0}
@media(max-width:900px){
  .co-grid{grid-template-columns:1fr}
  .co-side{position:static}
  .co-fields,.co-pop-cards{grid-template-columns:1fr}
  .co-summary{position:sticky;bottom:0;top:auto}
}

/* SEO-посадочные: интро-текст под H1 */
.catalog-intro{color:var(--ink-2);font-size:15.5px;line-height:1.55;max-width:780px;margin:8px 0 0}
.catalog-intro strong{color:var(--ink)}

/* SEO-текст внизу каталога */
.catalog-seo{margin-top:40px;padding-top:28px;border-top:1px solid var(--line);max-width:900px;color:var(--ink-2)}
.catalog-seo h2{font-family:var(--font-display);font-weight:600;font-size:20px;color:var(--ink);margin:0 0 12px}
.catalog-seo p{font-size:15px;line-height:1.6;margin:0 0 12px}

/* Кликабельные бренд/семейство/мета/крошки на PDP — без дефолтного вида ссылки */
a.pdp-brand{text-decoration:none;cursor:pointer}
a.pdp-brand:hover{color:var(--accent-text)}
.pdp-meta a{text-decoration:none;transition:color .15s}
.pdp-meta a:hover{color:var(--accent-text)}
.pdp-crumbs a{text-decoration:none}
.pdp-crumbs a:hover{color:var(--accent-text)}

/* ============ БЛОГ ============ */
.blog-list,.blog-post{max-width:var(--maxw);margin:0 auto;padding:18px 32px 72px}
.blog-post{max-width:860px}
.blog-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:26px;margin-top:22px}
.blog-card{display:flex;flex-direction:column;background:var(--bg);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;text-decoration:none;transition:transform .18s var(--ease),box-shadow .18s var(--ease)}
.blog-card:hover{transform:translateY(-4px);box-shadow:0 14px 34px rgba(25,23,26,.10)}
.blog-card-cover{position:relative;aspect-ratio:16/10;background:var(--surface);overflow:hidden;display:block}
.blog-card-cover img{width:100%;height:100%;object-fit:cover;transition:transform .4s var(--ease)}
.blog-card:hover .blog-card-cover img{transform:scale(1.05)}
.blog-card-cat{position:absolute;top:12px;left:12px;background:var(--ink);color:#fff;font-size:12px;font-weight:600;padding:5px 11px;border-radius:999px}
.blog-card-body{display:flex;flex-direction:column;gap:8px;padding:16px 18px 20px}
.blog-card-date{font-size:12.5px;color:var(--muted)}
.blog-card-title{font-family:var(--font-display);font-weight:600;font-size:18px;line-height:1.25;color:var(--ink)}
.blog-card-excerpt{font-size:14px;line-height:1.5;color:var(--ink-2);display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.blog-card-more{margin-top:auto;display:inline-flex;align-items:center;gap:6px;color:var(--accent-text);font-weight:600;font-size:14px}
/* детальная */
.blog-post-head{display:flex;align-items:center;gap:14px;margin:14px 0 10px}
.blog-cat{background:var(--surface-2);color:var(--accent-text);font-weight:600;font-size:13px;padding:5px 13px;border-radius:999px;text-decoration:none}
.blog-date{color:var(--muted);font-size:14px}
.blog-post-title{font-family:var(--font-display);font-weight:700;font-size:clamp(28px,4vw,40px);line-height:1.1;letter-spacing:-.01em;color:var(--ink);margin:0 0 22px}
.blog-post-cover{border-radius:var(--radius);overflow:hidden;margin:0 0 28px;aspect-ratio:16/9;background:var(--surface)}
.blog-post-cover img{width:100%;height:100%;object-fit:cover}
.blog-post-body{font-size:17px;line-height:1.7;color:var(--ink)}
.blog-post-body p{margin:0 0 18px}
.blog-post-body strong{color:var(--ink);font-weight:600}
.blog-post-foot{display:flex;gap:12px;flex-wrap:wrap;margin:32px 0 8px;padding-top:24px;border-top:1px solid var(--line)}
.blog-related{margin-top:48px;padding-top:28px;border-top:1px solid var(--line)}
.blog-related .blog-card-cover{aspect-ratio:16/10}
@media(max-width:980px){.blog-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:620px){.blog-grid{grid-template-columns:1fr}.blog-list,.blog-post{padding:14px 16px 56px}}
/* минус-ноты (исключение нот) */
.fd-exnote .fd-ex-hint{font-size:12.5px;color:var(--muted);margin:0 0 8px;}
.fd-exnote .fd-ex-hint strong{color:var(--accent-text);}
.fd-ex-chips{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:8px;}
.fd-ex-chip{display:inline-flex;align-items:center;gap:6px;background:var(--surface);border:1px solid var(--line);color:var(--ink);border-radius:999px;padding:4px 6px 4px 11px;font-size:12.5px;}
.fd-ex-x{border:none;background:none;color:var(--accent-text);cursor:pointer;font-size:16px;line-height:1;padding:0 2px;}
.fd-ex-input{width:100%;border:1px solid var(--line);border-radius:10px;padding:9px 12px;font-size:14px;background:var(--surface);color:var(--ink);}
.fd-ex-input:focus{outline:none;border-color:var(--accent);}
.catalog-exnote{font-size:13.5px;color:var(--muted);margin:6px 0 0;}
.catalog-exnote strong{color:var(--accent-text);}
/* фикс: стрелка сортировки по центру + радио «Наличие» */
.select-wrap svg{top:50%;transform:translateY(-50%);}
.check-radio .check-box{border-radius:50%;}
/* кастомный автокомплит «Исключить ноты» */
.fd-ex-ac{position:relative;}
.fd-ex-dd{position:absolute;top:calc(100% + 4px);left:0;right:0;z-index:30;max-height:260px;overflow-y:auto;background:var(--surface);border:1px solid var(--line);border-radius:10px;box-shadow:0 10px 28px rgba(0,0,0,.14);padding:4px;}
.fd-ex-opt{display:block;width:100%;text-align:left;border:none;background:none;color:var(--ink);font-size:13.5px;padding:8px 10px;border-radius:7px;cursor:pointer;}
.fd-ex-opt:hover{background:var(--surface-2);}
/* поиск внутри фасетов + justify SEO-текста листинга */
.filter-search{position:sticky;top:0;z-index:2;width:100%;box-sizing:border-box;margin-bottom:6px;border:1px solid var(--line);border-radius:8px;padding:7px 10px;font-size:13px;background:var(--surface);color:var(--ink);}
.filter-search:focus{outline:none;border-color:var(--accent);}
.catalog-seo p{text-align:justify;}
/* SEO-блок листинга — на всю ширину (линия+текст), не узкой колонкой слева */
.catalog-seo{max-width:none;}
/* фикс: длинный список фильтра (1711 нот) раздувал высоту страницы мимо overflow — изолируем containment */
.filter-body-scroll{contain:content;}

/* End */
/* /local/templates/formula/template_styles.css?1781028603122452 */
