/* =============================================================================
   B420 SHOP — полірування, анімації, адаптив (завантажується після style.css)
============================================================================= */

/* Фікс "стрибка" при переході між сторінками (скролбар завжди присутній) */
html { overflow-y: scroll; scrollbar-gutter: stable; }

/* точкові transition (без "all" — щоб не лагало) */
.btn, .pill, .chip, .add-btn, .arrow-btn, .icon-btn {
    transition: color .25s var(--ease), background-color .25s var(--ease), border-color .25s var(--ease);
}
.pcard { transition: box-shadow .3s var(--ease), border-color .3s var(--ease); }
.field input, .field textarea, .select { transition: border-color .2s var(--ease); }

/* Бейдж кошика/обраного: показувати ЛИШЕ коли є що показувати (не "0") */
.badge[hidden] { display: none !important; }

/* Дисплейний шрифт Fraunces (≈ Lobelia) — важкий + характерна «вензельна» вісь */
.display, .hero__title, .product__title, .page-title, .section-title { font-weight: 900; }
.display, .hero__title, .product__title, .page-title, .section-title,
h1, h2, h3 { font-variation-settings: 'opsz' 144, 'SOFT' 0, 'WONK' 1; }

/* Біжучий рядок — трохи швидше */
.ticker__track { animation-duration: 26s; }
.benefits__track { animation-duration: 24s; }

/* Підзаголовок hero — моноширинний (як у макеті) */
.hero__text { font-family: 'JetBrains Mono', ui-monospace, monospace; letter-spacing: 0; line-height: 1.65; font-weight: 400; }

/* Картка "+80": число чорне, останнє слово — акцент */
.hero__count { color: var(--ink) !important; }
.hero__count b { color: inherit; }
.loc-accent { color: var(--accent); font-style: normal; text-decoration: underline; text-underline-offset: 2px; font-weight: 700; }
.hero__socials a { text-transform: uppercase; letter-spacing: .06em; font-weight: 700; }

/* =============================================================================
   Соц-кнопки: плавна підсвітка кольором бренду при наведенні.
   Чистий CSS (transform на GPU) — БЕЗ Tailwind/JS/бібліотек, не навантажує сайт.
   Розмір/висота однакові → не «вибиває з колеї», немає стрибка на hover.
============================================================================= */
/* Заголовок картки соцмереж */
.hero__card-head { margin-bottom: 14px; }
.hero__card-title { font-weight: 800; font-size: 20px; letter-spacing: -.01em; color: var(--ink); }
.hero__card-sub { font-size: 13px; color: var(--ink-2); margin-top: 2px; }

/* Кнопки соцмереж — як у прикладі: світлі, сірі, повітряні */
.hero__socials { gap: 12px; }
.hero__socials a {
    min-height: 46px; padding: 13px 18px; border-radius: 12px;
    position: relative; isolation: isolate;
    border: 1.5px solid #e6e6ea;
    color: #a6a6ae; font-weight: 600; font-size: 12.5px; letter-spacing: .1em;
}
.hero__socials a i { flex: none; color: #b3b3ba; font-size: 16px; }
.hero__socials a::before { content: none; }             /* БЕЗ слайд-заливки */
/* колір бренду при наведенні — коротке м'яке перетікання (без слайду, але не різко) */
.hero__socials a { transition: background .22s ease, color .22s ease, border-color .22s ease; }
.hero__socials a i { transition: color .22s ease; }
.hero__socials a:hover { color: #fff; border-color: transparent; }
.hero__socials a:hover i { color: #fff; }
.hero__socials a.is-tg:hover { background: #2aabee; }   /* Telegram — фірмовий синій */
.hero__socials a.is-ig:hover {                          /* Instagram — фірмовий градієнт */
    background: linear-gradient(45deg, #f09433 0%, #e6683c 22%, #dc2743 50%, #cc2366 74%, #bc1888 100%);
}

/* Кнопка «Зв'язок з оператором»: без заливки й без тіні — просто легкий сірий фон.
   Форма — прямокутна зі скругленням 15px, ЯК у контейнера обране/кошик/профіль. */
.operator-btn { border-radius: 15px; }
.operator-btn::before { display: none !important; }
.operator-btn { transition: background-color .2s ease; }
.operator-btn:hover, .operator-btn:hover svg { color: var(--ink) !important; }
.operator-btn:hover {
    border-color: var(--line) !important;
    background: #f3f3f5;
    box-shadow: none;
}

/* -------- Банер-слайди (готове зображення з текстом): кнопка внизу -------- */
.hero__slide { justify-content: flex-end; }
.hero__bg::after { background: linear-gradient(0deg, rgba(6,6,8,.72) 0%, rgba(6,6,8,.15) 34%, rgba(6,6,8,0) 60%); }
.hero__inner { max-width: none; min-width: 0; }
/* .hero__slide — flex-стовпчик; без min-width:0 довге неперенесене слово
   (напр. «КОЛЕКЦІОНУВАННЯ») змушувало елемент бути ширшим за контейнер —
   звідси «зʼїдений» зліва/справа текст на вузьких екранах. */
.hero__slide { min-width: 0; }
.hero__title { overflow-wrap: break-word; word-break: break-word; }

/* Логотип — великий, «падає» вниз у виїмку банера (негативний нижній відступ
   виводить низ лого за межі шапки — у білу полку вирізу, як у макеті) */
.brand img { height: calc(104px * var(--notch-scale)); position: relative; z-index: 61; }

/* Зона «бургер + лого» — відцентрована по ширині виїмки банера (~308px) */
.brand-zone { display: flex; align-items: center; gap: 18px; width: 308px; justify-content: center; margin: calc(-4px * var(--notch-scale)) 0 calc(-32px * var(--notch-scale)); position: relative; z-index: 61; }
.burger { display: inline-grid; border: none !important; background: transparent !important; width: auto; height: auto; }
.burger::before { display: none !important; }
.burger:hover { color: var(--ink); opacity: .7; }

/* «Каталог» — одразу за сходинкою вирізу (як у макеті) */
.header__left .has-dropdown { margin-left: 14px; }
.header__actions { margin-left: auto; }

/* -------- Група дій: обране / кошик / профіль — в одному контейнері --------
   (як у макеті: єдина заокруглена «пігулка» з тонкою рамкою) */
.action-group {
    display: inline-flex; align-items: center; gap: 2px;
    padding: 4px; background: #fff;
    border: 1.5px solid var(--line); border-radius: 15px;
    flex: none;
}
.action-group .icon-btn {
    width: 40px; height: 40px; border: none; background: transparent; border-radius: 11px;
}
.action-group .icon-btn::before { display: none !important; }      /* без чорної заливки всередині групи */
.action-group .icon-btn:hover { background: var(--bg-soft); color: var(--ink); border-color: transparent; }
.action-group .icon-btn .badge { top: -4px; right: -4px; z-index: 3; box-shadow: 0 0 0 2px #fff; }

/* -------- Пошук, що розкривається (лупа → плавно з'являється поле) -------- */
.hsearch { position: relative; width: 44px; height: 44px; flex: none; }
.hsearch__box {
    position: absolute; right: 0; top: 50%; transform: translateY(-50%); z-index: 5;
    display: flex; align-items: center;
    background: transparent; border: 1.5px solid transparent; border-radius: 12px; overflow: hidden;
    transition: background .3s var(--ease), border-color .3s var(--ease);
}
.hsearch__box input {
    width: 0; opacity: 0; padding: 0; border: none; outline: none; background: transparent;
    font-size: 15px; color: var(--ink);
    transition: width .4s var(--ease), padding .35s var(--ease), opacity .3s;
}
.hsearch:hover .hsearch__box, .hsearch.open .hsearch__box, .hsearch__box:focus-within {
    background: #fff; border-color: var(--line);
}
.hsearch:hover .hsearch__box input, .hsearch.open .hsearch__box input, .hsearch__box:focus-within input {
    width: clamp(150px, 18vw, 240px); opacity: 1; padding: 11px 4px 11px 16px;
}
.hsearch__btn {
    width: 44px; height: 44px; display: grid; place-items: center; flex: none;
    background: none; border: none; color: var(--ink); cursor: pointer;
}
@media (max-width: 560px) {
    .hsearch:hover .hsearch__box input, .hsearch.open .hsearch__box input { width: min(58vw, 220px); }
}

/* -------- ХОВЕРИ: БЕЗ слайдів — простий м'який перехід кольору ------------
   Єдиний виняток — кнопка hero «Перейти у Shop»: біле тече ВІД стрілки
   справа наліво (нижче). Решта кнопок просто плавно міняють колір.          */
.btn, .pill, .chip, .add-btn, .arrow-btn, .icon-btn, .abtn {
    position: relative; isolation: isolate;
}
.btn::before, .pill::before, .chip::before, .add-btn::before,
.arrow-btn::before, .icon-btn::before { content: none; }

.hero__cta .btn { overflow: hidden; }
/* у style.css є .hero__cta .btn:hover { background: var(--accent); } — це давало
   миттєву (без анімації) заливку кольором одразу при наведенні. Скасовуємо це,
   щоб заливку створювала ТІЛЬКИ смуга ::before, яка їде справа наліво. */
.hero__cta .btn:hover { background: #fff; }
.hero__cta .btn::before {
    content: ''; position: absolute; inset: 0; z-index: -1;
    /* Суцільна смуга кольору фону стрілки — виїжджає СПРАВА НАЛІВО на всю площу кнопки */
    background: var(--ink);
    transform: translateX(101%);                          /* стартує повністю за межами кнопки праворуч */
    transition: transform .6s cubic-bezier(.65, 0, .35, 1);
}
.hero__cta .btn:hover::before { transform: translateX(0); }
/* стрілка повертається вниз (↗ → ↘) СИНХРОННО із заливкою */
.hero__cta .btn .b-arrow svg { transition: transform 1s cubic-bezier(.55, .06, .28, .99); }
.hero__cta .btn:hover .b-arrow svg { transform: rotate(90deg); }

.btn--dark::before   { background: var(--accent); }
.btn--accent::before { background: var(--ink); }
.btn--ghost::before  { background: var(--ink); }
.pill::before        { background: var(--ink); }
.pill--dark::before  { background: var(--accent); }
.chip::before        { background: var(--ink); }
.add-btn::before     { background: var(--ink); }
.arrow-btn::before   { background: var(--ink); }
.icon-btn::before    { background: var(--accent); }

/* прості ховери: світлі кнопки — легкий сірий; «Каталог» — біла; акційні — темні */
.pill:hover { background: #f3f3f5; }
/* «Каталог»: менш заокруглена форма; чорний → БІЛИЙ з обводкою при наведенні */
.pill.pill--dark { border-radius: 11px; }
.pill.pill--dark:hover { background: #fff; color: var(--ink); border-color: var(--ink); }
.icon-btn:hover { background: #f3f3f5; }
.btn--ghost:hover { background: #f3f3f5; }
.btn--dark:hover, .btn--accent:hover { background: #26262c; }
.chip:hover, .add-btn:hover, .arrow-btn:hover { background: var(--ink); color: #fff; border-color: transparent; }
.add-btn:hover .add-btn__ico { background: rgba(255, 255, 255, .16); }

/* стрілка в кнопці — статична (без обертань) */
.b-arrow { display: inline-grid; place-items: center; }

/* hero CTA — БІЛА кнопка + ЧОРНИЙ квадрат зі стрілкою НА ВСЮ ВИСОТУ (як у макеті) */
.hero__cta .btn {
    background: #fff; color: var(--ink); border-color: transparent;
    border-radius: 10px;                          /* менше заокруглення */
    padding: 17px 78px 17px 24px;                 /* справа — місце під квадрат стрілки */
}
.hero__cta .btn .b-arrow {
    position: absolute; right: 0; top: 0; bottom: 0;
    width: 56px; height: auto; margin: 0;
    border-radius: 0;                             /* врівень із кнопкою, без своїх кутів */
    background: var(--ink); color: #fff;          /* чорний квадрат, біла стрілка */
    transform: none !important;
}
/* текст біліє швидко, одразу за смугою заливки (без довгих затримок) */
.hero__cta .btn { transition: color .18s ease; }
.hero__cta .btn:hover { color: #fff; transition: color .18s ease .08s; }
/* на ховері чорний квадрат РОЗЧИНЯЄТЬСЯ в кнопці (як у макеті) — лишається сама стрілка */
.hero__cta .btn .b-arrow { transition: background-color .3s ease; }
.hero__cta .btn:hover .b-arrow { background: transparent; color: #fff; }
/* (переливання і поворот стрілки — див. блок ховерів вище) */

/* -------- ТАЧ-ПРИСТРОЇ: та сама анімація кнопки «Перейти у Shop» ----------
   На телефоні/планшеті немає :hover — користувач одразу тапає і переходить
   по посиланню. Щоб анімація (заливка+колір+стрілка) була такою самою, як
   на ПК, дублюємо всі :hover-правила на :active — вони спрацьовують у
   момент дотику, поки браузер ще не встиг перейти за посиланням.           */
@media (hover: none) {
    .hero__cta .btn:active { background: #fff; color: #fff; transition: color .18s ease; }
    .hero__cta .btn:active::before { transform: translateX(0); }
    .hero__cta .btn:active .b-arrow svg { transform: rotate(90deg); }
    .hero__cta .btn:active .b-arrow { background: transparent; color: #fff; }
}

/* -------- Перемикач мови: випадашка при наведенні (slide) ---------------- */
.lang-switch { position: relative; }
.lang-switch .lang {
    display: inline-flex; align-items: center; gap: 7px;
    padding: 9px 12px; border: 1.5px solid var(--line); border-radius: 12px; background: #fff;
    font-weight: 700; font-size: 14px; color: var(--ink); cursor: pointer;
}
.lang-switch .flag { border-radius: 2px; box-shadow: 0 0 0 1px rgba(0, 0, 0, .06); flex: none; }
.lang-menu {
    position: absolute; top: calc(100% + 8px); right: 0; z-index: 60;
    min-width: 124px; background: #fff; border: 1px solid var(--line);
    border-radius: 12px; padding: 6px; box-shadow: var(--shadow);
    opacity: 0; visibility: hidden; transform: translateY(-8px) scale(.98);
    transition: opacity .25s var(--ease), transform .25s var(--ease), visibility .25s;
    transform-origin: top right;
}
.lang-switch:hover .lang-menu, .lang-switch.open .lang-menu {
    opacity: 1; visibility: visible; transform: translateY(0) scale(1);
}
.lang-switch .lang > svg:last-child { transition: transform .25s var(--ease); }
.lang-switch:hover .lang > svg:last-child { transform: rotate(180deg); }
.lang-menu a { display: flex; align-items: center; gap: 8px; padding: 9px 11px; border-radius: 8px; font-weight: 700; font-size: 14px; color: var(--ink-2); }
.lang-menu a:hover { background: var(--bg-soft); color: var(--accent); }
.lang-menu a.active { color: var(--ink); }

/* -------- Єдина висота всіх контролів у хедері (рівна лінія, без стрибків) --
   Каталог/оператор = 46px → підганяємо пошук, групу іконок і мову під них. */
.header__actions { --ctl-h: 46px; }
.hsearch, .hsearch__btn { height: var(--ctl-h); }
.action-group { height: var(--ctl-h); padding: 0 5px; }
.action-group .icon-btn { height: 38px; }
.lang-switch .lang { height: var(--ctl-h); padding: 0 14px; }
.lang-switch { margin-left: 8px; }               /* мову — трохи правіше від іконок */

/* -------- REVEAL (GSAP) — ховаємо до анімації лише якщо є JS -------------- */
.has-js .pcard { opacity: 0; }

/* =============================================================================
   АДАПТИВ (Android / iPhone / усі браузери)
============================================================================= */
@media (max-width: 1024px) {
    .header__nav { gap: 18px; }
    /* на цій ширині «Каталог» ще з текстом, а місця замало — звужуємо пошук ще сильніше */
    .hsearch:hover .hsearch__box input, .hsearch.open .hsearch__box input, .hsearch__box:focus-within input {
        width: clamp(110px, 20vw, 170px);
    }
}

@media (max-width: 860px) {
    :root { --header-h: 62px; }
    .header__row { gap: 10px; }
    .header__nav { display: none; }
    .burger { display: inline-grid; }
    .header__left { gap: 8px; align-items: center; }
    .header__left .has-dropdown { margin-left: 0; }
    .brand-zone { width: auto; justify-content: flex-start; gap: 8px; margin: 0; }
    .brand img { height: 40px; }
    .pill.pill--dark span { display: none; }
    .pill.pill--dark { padding: 11px; }
    .header__actions { gap: 6px; }
    .icon-btn { width: 40px; height: 40px; }
    .operator-btn .txt { display: none; }
    .hero__title { font-size: clamp(34px, 11vw, 60px); }
    .product { grid-template-columns: 1fr; }
    .product__gallery { position: static; }
}

/* -------- Дуже вузькі телефони (≤400px, напр. Galaxy S8/S9/miniA) --------
   На такій ширині бургер+лого+іконка каталогу+пошук+обране+кошик впритул
   одне до одного — трохи стискаємо відступи й самі елементи, щоб рядок
   гарантовано вміщався в одну лінію без переносу.                          */
@media (max-width: 400px) {
    :root { --gutter: 12px; }
    .header__row { gap: 6px; }
    .header__left { gap: 6px; }
    .brand-zone { gap: 6px; }
    .brand img { height: 34px; }
    .pill.pill--dark { padding: 9px; }
    .header__actions { gap: 4px; }
    .icon-btn { width: 36px; height: 36px; }
    .hsearch, .hsearch__btn { width: 36px; height: 36px; }
    .action-group { padding: 3px; }
    .action-group .icon-btn { width: 34px; height: 34px; }
    .hsearch:hover .hsearch__box input, .hsearch.open .hsearch__box input, .hsearch__box:focus-within input {
        width: min(48vw, 150px);
    }
}

@media (max-width: 560px) {
    :root { --gutter: 14px; }
    .hero { padding-top: 12px; }
    .hero__stage { border-radius: 20px; min-height: 0; }
    .hero__slide { padding: 22px 18px 26px; min-height: clamp(300px, 84vw, 460px); }
    .hero__title { font-size: clamp(30px, 12vw, 52px); line-height: .94; margin-bottom: 14px; }
    .hero__text { font-size: 12px; margin-bottom: 18px; }
    .hero__card { position: static; grid-column: 1; width: auto; margin-top: 14px; box-shadow: none; border: 1px solid var(--line); }
    .hero__dots { position: absolute; right: clamp(10px, 3vw, 22px); left: auto; top: 50%; bottom: auto; transform: translateY(-50%); flex-direction: column; }
    .hero__dots .num { display: block; }
    .products { grid-template-columns: repeat(2, 1fr); gap: 10px; }
    .pcard { padding: 8px; border-radius: 14px; }
    .pcard__name { font-size: 12.5px; min-height: 2.6em; }
    .pcard__price { font-size: 17px; }
    .add-btn { font-size: 12px; padding: 10px; }
    .add-btn__label { font-size: 12px; }
    .section { padding-block: 34px; }
    .section-title { font-size: 22px; }
    .lang-switch { display: none; }
    .search-bar input { font-size: 16px; }
    .footer__top { grid-template-columns: 1fr 1fr; gap: 18px; }
    .footer__brand { grid-column: 1 / -1; }
    .cart-item { grid-template-columns: 70px 1fr; }
    .cart-item__right { grid-column: 1 / -1; justify-content: space-between; margin-top: 8px; }
    .qty button { width: 40px; height: 46px; }
    .qty input { width: 46px; height: 46px; }
}

@media (max-width: 380px) {
    .products { grid-template-columns: 1fr 1fr; gap: 8px; }
    .hero__title { font-size: 30px; }
}

/* touch: hover-заливки не липнуть */
@media (hover: none) {
    .btn::before, .pill::before, .chip::before, .add-btn::before, .arrow-btn::before, .icon-btn::before { display: none; }
    .lang-menu { transition: none; }
}

/* =============================================================================
   МОНОХРОМ: майже все чорно-біле. Оранжевий — ЛИШЕ на лічильниках (badge)
   поверх іконок серця/кошика/профілю.
============================================================================= */
:root {
    --accent: #17171b;   /* монохром: акцент = майже чорний (прибирає оранжевий скрізь) */
    --accent-2: #2b2b31;
    --badge: #e8631a;    /* оранжевий ЛИШЕ для лічильників поверх іконок */
}
:focus-visible { outline-color: var(--ink); }

/* Тикер — як у макеті: моношрифт, малі літери, приглушений сірий, ОРАНЖЕВІ блискавки */
.ticker__item {
    font-family: 'JetBrains Mono', ui-monospace, monospace;
    text-transform: lowercase;
    font-weight: 500; font-size: 13px; letter-spacing: .06em;
    color: #9b9ba3;                                   /* приглушений сірий текст */
    gap: 52px;                                        /* більше повітря між пунктами */
}
.ticker__track { padding-block: 8px; }
.ticker__item svg { color: #f97316; }                 /* блискавки — оранжеві, як у макеті */
.benefits__item svg { color: var(--ink); }
.loc-accent { color: var(--ink); text-decoration-color: var(--ink); }
.pcard__rate svg { color: var(--ink); }               /* зірки — чорні */
.pcard__fav:hover, .pcard__fav.is-active { color: var(--ink); border-color: var(--ink); }
.pcard__fav.is-active svg { fill: var(--ink); }
.link-more { border-bottom-color: var(--ink); }
.flash { border-left-color: var(--ink); }
.hero__stage { background: #101014; }                 /* нейтральний фон під фото */

/* Оранжевий лишається ТІЛЬКИ тут — лічильники поверх іконок */
.badge, .icon-btn .badge { background: var(--badge) !important; color: #fff; }

/* -------- Ховери монохром (без слайдів; слайд лише у hero-CTA) ------------ */
/* оранжеві акцент-кнопки робимо чорними */
.btn--accent { background: var(--ink); }

/* =============================================================================
   STICKY FOOTER — прибирає порожню область унизу на коротких сторінках
============================================================================= */
body { min-height: 100vh; display: flex; flex-direction: column; }
.ticker, .header, .mmenu, .flashes { flex: none; }
.main { flex: 1 0 auto; }
.footer { flex-shrink: 0; }


/* Картка «+80» та вогнуті кути банера → див. окремий файл assets/css/shapes.css
   (усі вирізи/маски зібрані ТАМ). Тут лишається тільки перенос вмісту на мобільному. */
@media (max-width: 560px) {
    .hero__card-top { flex-wrap: wrap; }
    .hero__card-top span { min-width: 0; }
}

/* Тикер — повільніше (компенсуємо збільшене наповнення) */
.ticker__track { animation-duration: 80s !important; }
.benefits__track { animation-duration: 70s !important; }

/* Футер-лого — біла версія БЕЗ білої підкладки */
.footer__brand img { background: none !important; padding: 0 !important; height: 112px; margin-bottom: 16px; }
/* Hover пунктів меню в футері (замінено з var(--accent) за проханням) */
.footer__links a:hover { color: #c9c9d1; }

/* Футер-лого на телефоні — менше і по центру */
@media (max-width: 560px) {
    .footer__brand img { height: 64px; display: block; margin: 0 auto 16px; }
}