/* ============================================
   KOOTJE BOEF — Hoofdstylesheet
   ============================================ */


:root {
    --kb-bg:          #000000;   /* hero / hoofd achtergrond */
    --kb-bg-alt:      #111111;   /* featured / reviews secties */
    --kb-bg-mid:      #304451;   /* bestsellers / product cards */
    --kb-bg-about:    #1a2530;   /* about sectie */
    --kb-bg-footer:   #000000;   /* footer */
    --kb-orange:      #FF3108;   /* primaire accent kleur */
    --kb-orange-h:    #cc2600;   /* hover staat */
    --kb-yellow:      #FFC908;   /* gouden accent */
    --kb-ivory:       #FFFFF0;   /* crème wit accent */
    --kb-text:        #FFFFFF;   /* hoofdtekst wit */
    --kb-text-muted:  #8a8a8a;   /* subtekst grijs — bumped for readability with Barlow */
    --kb-border:      #1e2a33;   /* randen */
    --kb-font-head:   'Impact', 'Arial Narrow', Arial, sans-serif;
    --kb-font-body:   'Barlow', 'Helvetica Neue', Arial, sans-serif;
    --kb-radius:      5px;
    --kb-container:   100%;

    /* ---- Text sizes (editable via Customizer → Typography) ---- */
    --kb-size-hero:     80px;   /* hero title */
    --kb-size-section:  40px;   /* section headings (OUR PRODUCTS, BESTSELLERS…) */
    --kb-size-featured: 30px;   /* featured product title */
    --kb-size-cat:      28px;   /* category card labels */
    --kb-size-nav:      18px;   /* navigation links */
    --kb-size-body:     18px;   /* body / paragraph text */
    --kb-size-product:  16px;   /* product card title & price */
    --kb-size-btn:      20px;   /* buttons */
    --kb-size-topbar:   13px;   /* topbar contact text */
    --kb-size-footer:   14px;   /* footer text */

    --kb-header-logo-h: 150px; /* header logo height — tweak to resize logo without rebuilding */
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 16px; scroll-behavior: smooth; }

/* Hide scrollbars site-wide while keeping scroll functionality */
* { scrollbar-width: none; -ms-overflow-style: none; }
*::-webkit-scrollbar { display: none; }

/* Impact for headings & display text — overrides parent theme */
h1, h2, h3, h4, h5, h6,
.kb-section__title,
.kb-hero__title,
.kb-featured__title,
.kb-cat-card__label,
.kb-footer__heading,
.kb-single__name,
.kb-shop__title,
.kb-inspiration__hero-title,
.kb-insp-card__name,
.kb-logo-3d,
[class*="mk-"] h1, [class*="mk-"] h2, [class*="mk-"] h3,
[class*="jupiter-"] h1, [class*="jupiter-"] h2, [class*="jupiter-"] h3 {
    font-family: var(--kb-font-head) !important;
}

/* Barlow for body / readable text — overrides parent theme */
body,
p, a, li, span, div, button,
input, textarea, select, label,
.woocommerce, .woocommerce-page,
.entry-content,
[class*="mk-"], [class*="jupiter-"] {
    font-family: var(--kb-font-body) !important;
}

body {
    background: var(--kb-bg);
    color: var(--kb-text);
    font-family: var(--kb-font-body);
    font-size: var(--kb-size-body);
    line-height: 1.6;
}

a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; height: auto; }
ul { list-style: none; }

.kb-container {
    max-width: var(--kb-container);
    margin: 0 auto;
    padding: 0 48px;
}

/* ============================================
   TOPBAR — marquee spinner
   ============================================ */
.kb-topbar {
    background: var(--kb-orange);
    border-bottom: 1px solid var(--kb-border);
    overflow: hidden;
    width: 100%;
    height: 36px;
    display: flex;
    align-items: center;
}

.kb-topbar__track {
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    width: max-content;
    will-change: transform;
    animation: kb-topbar-scroll 30s linear infinite;
}

.kb-topbar:hover .kb-topbar__track {
    animation-play-state: paused;
}

.kb-topbar__item {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 0 28px;
    font-size: var(--kb-size-topbar);
    color: var(--kb-text);
    white-space: nowrap;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.kb-topbar__item a {
    color: var(--kb-text);
    display: inline-flex;
    align-items: center;
    gap: 6px;
    transition: opacity 0.2s;
}
.kb-topbar__item a:hover { opacity: 0.75; }
.kb-topbar__item svg { flex-shrink: 0; }

@keyframes kb-topbar-scroll {
    from { transform: translateX(0); }
    to   { transform: translateX(-50%); }
}

/* ============================================
   HEADER
   ============================================ */
.kb-header {
    position: sticky;
    top: 0;
    z-index: 100;
    background: var(--kb-bg);
    /* geen border — loopt naadloos over in de hero */
}

.kb-header__inner {
    max-width: var(--kb-container);
    margin: 0 auto;
    padding: 0 28px;
    height: 104px;
    display: flex;
    align-items: center;
    gap: 32px;
}

/* Logo */
.kb-header__logo {
    flex-shrink: 0;
    line-height: 1;
    position: relative;
    z-index: 3; /* keep the over-hanging logo above the hero below */
}

.kb-header__logo-img {
    height: var(--kb-header-logo-h);
    width: auto;
    max-height: var(--kb-header-logo-h);
    max-width: 340px;
    display: block;
    object-fit: contain;
    flex-shrink: 0;
    position: relative;
    z-index: 3;
    /* Let the logo break out of the bar and hang into the hero (transform = no layout shift) */
    transform: translateY(26px);
}

/* Nav — flex: 1 zodat hij de resterende ruimte vult */
.kb-nav { flex: 1; }

.kb-nav__list {
    display: flex;
    align-items: center;
    list-style: none;
    gap: 0;
    flex-wrap: nowrap;
    padding: 0;
    margin: 0;
}

/* WordPress voegt soms een extra ul toe via wp_nav_menu */
.kb-nav__list ul { list-style: none; padding: 0; margin: 0; }

.kb-nav__list a {
    font-family: var(--kb-font-body);
    font-size: var(--kb-size-nav);
    padding: 10px 16px;
    display: inline-block;
    transition: color 0.2s;
    color: var(--kb-text);
}

.kb-nav__list a:hover {
    color: var(--kb-orange);
}

.kb-nav__list li {
    position: relative;
    display: flex;
    align-items: center;
    gap: 2px;
}

.kb-nav__list button {
    font-weight: 500;
    color: var(--kb-text);
    padding: 6px 10px;
    white-space: nowrap;
    transition: color 0.15s;
    letter-spacing: 0;
}

.kb-nav__list a:hover,
.kb-nav__list .current-menu-item > a {
    color: var(--kb-orange);
}

/* Desktop nav dropdown */
.kb-nav__list .menu-item-has-children {
    position: relative;
}

.kb-nav__list .sub-menu {
    display: block;
    position: absolute;
    top: calc(100% + 10px);
    left: 50%;
    min-width: 220px;
    padding: 8px;
    background: rgba(0, 0, 0, 0.96);
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: 6px;
    z-index: 300;
    box-shadow: 0 18px 44px rgba(0,0,0,0.48);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transform: translate(-50%, 8px);
    transition: opacity 0.16s ease, transform 0.16s ease, visibility 0.16s ease;
}

.kb-nav__list .sub-menu::before {
    content: '';
    position: absolute;
    left: 0;
    right: 0;
    top: -11px;
    height: 11px;
}

.kb-nav__list .menu-item-has-children:hover > .sub-menu {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translate(-50%, 0);
}

.kb-nav__list .menu-item-has-children.kb-nav__item--open > .sub-menu,
.kb-nav__list .menu-item-has-children:focus-within > .sub-menu {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translate(-50%, 0);
}

.kb-nav__list > .menu-item-has-children:last-child > .sub-menu {
    left: auto;
    right: 0;
    transform: translateY(8px);
}

.kb-nav__list > .menu-item-has-children:last-child:hover > .sub-menu,
.kb-nav__list > .menu-item-has-children:last-child.kb-nav__item--open > .sub-menu,
.kb-nav__list > .menu-item-has-children:last-child:focus-within > .sub-menu {
    transform: translateY(0);
}

.kb-nav__list .sub-menu li {
    display: block;
    width: 100%;
}

.kb-nav__list .sub-menu a {
    width: 100%;
    padding: 11px 12px;
    display: block;
    font-size: 0.92rem;
    line-height: 1.25;
    border-bottom: none;
    white-space: nowrap;
    border-radius: 4px;
    text-align: left;
}

.kb-nav__list .sub-menu a:hover {
    background: rgba(255,49,8,0.12);
    color: var(--kb-orange);
}

/* Submenu toggle chevron button */
.kb-nav__submenu-toggle {
    background: none;
    border: none;
    cursor: pointer;
    width: 28px;
    height: 28px;
    padding: 0;
    border-radius: 50%;
    color: var(--kb-text-muted);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: color 0.2s, transform 0.2s;
    flex-shrink: 0;
}
.kb-nav__submenu-toggle:hover {
    color: var(--kb-orange);
    background: rgba(255, 255, 255, 0.06);
}
.kb-nav__submenu-toggle svg { transition: transform 0.2s ease; }
.kb-nav__item--open > .kb-nav__submenu-toggle {
    transform: none;
    color: var(--kb-orange);
}
.kb-nav__item--open > .kb-nav__submenu-toggle svg { transform: rotate(180deg); }

/* Cart */
.kb-header__actions {
    flex-shrink: 0;
    position: relative;
}

.kb-header__cart {
    display: flex;
    align-items: center;
    color: var(--kb-orange);
    padding: 6px;
    transition: opacity 0.2s;
}
.kb-header__cart:hover { opacity: 0.75; }

.kb-header__cart-count {
    position: absolute;
    top: -2px; right: -2px;
    background: var(--kb-orange);
    color: #fff;
    font-size: 0.6rem;
    font-weight: 700;
    width: 16px; height: 16px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
}

/* Hamburger */
.kb-nav__toggle {
    display: none;
    flex-direction: column;
    gap: 5px;
    background: none;
    border: none;
    cursor: pointer;
    padding: 4px;
    flex-shrink: 0;
}
.kb-nav__toggle span {
    display: block;
    width: 24px; height: 2px;
    background: var(--kb-text);
    border-radius: 2px;
    transition: 0.3s;
}

/* ============================================
   HERO
   ============================================ */
.kb-hero {
    position: relative;
    min-height: 540px;
    background: var(--kb-bg);
    overflow: hidden;
    display: flex;
    align-items: center;
    isolation: isolate;
}

/* Robot als achtergrond rechts — laag 1 (achterste) */
.kb-hero__robot-wrap {
    position: absolute;
    right: 20px;
    bottom: -52px;
    width: 58%;
    max-width: 820px;
    pointer-events: none;
    z-index: 1;
}

.kb-hero__robot-img {
    width: 100%;
    display: block;
}

/* Gradient over de robot — gebruikt dezelfde kleur als hero bg */
.kb-hero__robot-fade {
    position: absolute;
    top: 0; left: 0; right: 0; bottom: 0;
    background:
        linear-gradient(to right, var(--kb-bg) 0%, rgba(13,16,18,0.92) 12%, rgba(13,16,18,0) 34%),
        linear-gradient(to left, var(--kb-bg) 0%, rgba(13,16,18,0.9) 10%, rgba(13,16,18,0) 30%);
    pointer-events: none;
}

/* Tekst — laag 2 (voor de robot) */
.kb-hero__inner {
    position: relative;
    z-index: 10;
    max-width: var(--kb-container);
    margin: 0 auto;
    padding: 100px 28px;
    width: 100%;
    display: flex;
    justify-content: flex-start;
}

.kb-hero__content { max-width: 820px; }

.kb-hero__title {
    font-family: var(--kb-font-head);
    font-size: var(--kb-size-hero);
    line-height: 1.0;
    letter-spacing: 0;
    color: var(--kb-text);
    margin-bottom: 36px;
    text-transform: uppercase;
}

.kb-hero__title--accent { color: var(--kb-orange); }

/* Sterren decoraties */
.kb-hero__star {
    position: absolute;
    color: var(--kb-text);
    font-size: 1.2rem;
    opacity: 0.4;
    z-index: 10;
}
.kb-hero__star--1 { top: 60px; right: 180px; font-size: 1.6rem; }
.kb-hero__star--2 { bottom: 80px; left: 60px; }

/* ============================================
   SECTIES — ALGEMEEN
   ============================================ */
.kb-section__title {
    font-family: var(--kb-font-head);
    font-size: var(--kb-size-section);
    letter-spacing: 0;
    text-transform: uppercase;
    color: var(--kb-text);
    margin-bottom: 40px;
}
.kb-section__title--center { text-align: center; }
.kb-section__cta { text-align: center; margin-top: 40px; }

/* ============================================
   KNOPPEN
   ============================================ */
.kb-btn {
    display: inline-block;
    padding: 13px 30px;
    border-radius: var(--kb-radius);
    font-size: var(--kb-size-btn);
    letter-spacing: 0;
    transition: background 0.2s, color 0.2s;
    cursor: pointer;
    border: none;
    text-align: center;
}

.kb-btn--primary,
.kb-btn--orange {
    background: var(--kb-orange);
    color: #fff;
}
.kb-btn--primary:hover,
.kb-btn--orange:hover { background: var(--kb-orange-h); color: #fff; }

/* ============================================
   PRODUCTCATEGORIEËN
   ============================================ */
.kb-categories {
    padding: 72px 0;
    background: var(--kb-bg-mid);
}

.kb-categories__grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 24px;
}

.kb-categories__grid--3 {
    grid-template-columns: repeat(3, 1fr);
}

.kb-cat-card {
    position: relative;
    border-radius: var(--kb-radius);
    overflow: hidden;
    display: block;
    aspect-ratio: 3/4;
    background: var(--kb-bg-mid);
}

.kb-cat-card__img-wrap {
    position: absolute;
    inset: 0;
}

.kb-cat-card__img-wrap img {
    width: 100%; height: 100%;
    object-fit: contain;
    transition: transform 0.4s;
}

.kb-cat-card:hover .kb-cat-card__img-wrap img { transform: scale(1.05); }

.kb-cat-card__placeholder {
    width: 100%; height: 100%;
    background: var(--kb-bg-mid);
}

.kb-cat-card__label {
    position: absolute;
    bottom: 0; left: 0; right: 0;
    background: linear-gradient(to top, rgba(0,0,0,0.85) 0%, transparent 100%);
    padding: 28px 20px 18px;
    font-family: var(--kb-font-head);
    font-size: var(--kb-size-cat);
    letter-spacing: 0;
    text-transform: uppercase;
    color: var(--kb-text);
    text-align: center;
    transition: color 0.3s, padding-bottom 0.3s;
}
.kb-cat-card:hover .kb-cat-card__label {
    color: var(--kb-orange);
    padding-bottom: 22px;
}


/* ============================================
   UITGELICHT NIEUW DESIGN — asymmetric stage + overlapping card
   ============================================ */
.kb-featured {
    padding: 96px 0 80px;
    background: var(--kb-bg-alt);
    border-top: 1px solid var(--kb-border);
    border-bottom: 1px solid var(--kb-border);
    position: relative;
    overflow: hidden;
}

.kb-featured__inner {
    display: grid;
    grid-template-columns: minmax(0, 1.35fr) minmax(0, 1fr);
    gap: 0;
    align-items: stretch;
    border-radius: var(--kb-radius);
    position: relative;
    min-height: 420px;
}

/* Left — dramatic artwork stage */
.kb-featured__stage {
    position: relative;
    background:
        radial-gradient(130% 90% at 25% 55%, rgba(255, 49, 8, 0.95) 0%, rgba(180, 25, 0, 1) 42%, rgba(30, 6, 0, 1) 100%),
        var(--kb-bg);
    border-radius: var(--kb-radius) 0 0 var(--kb-radius);
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 56px 48px;
}

.kb-featured__stage::after {
    content: '';
    position: absolute;
    inset: 0;
    background:
        repeating-linear-gradient(135deg, rgba(0,0,0,0.14) 0 2px, transparent 2px 14px);
    mix-blend-mode: multiply;
    pointer-events: none;
}

.kb-featured__artwork {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    opacity: 0.92;
    z-index: 0;
}

.kb-featured__stage-headline {
    font-family: var(--kb-font-head);
    font-size: clamp(3rem, 8.4vw, 6.5rem);
    letter-spacing: 0;
    text-transform: uppercase;
    color: var(--kb-text);
    line-height: 0.92;
    text-align: center;
    position: relative;
    z-index: 1;
    text-shadow: 0 4px 22px rgba(0,0,0,0.6);
    max-width: 100%;
    word-break: break-word;
}

/* Right — product card with PNG overlap */
.kb-featured__card {
    background: var(--kb-bg-mid);
    border: 1px solid var(--kb-border);
    border-left: none;
    border-radius: 0 var(--kb-radius) var(--kb-radius) 0;
    padding: 40px 40px 36px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    position: relative;
    z-index: 2;
    box-shadow: -22px 0 48px rgba(0,0,0,0.32);
}

.kb-featured__img-link {
    position: absolute;
    top: -52px;
    left: -96px;
    width: 190px;
    height: 190px;
    z-index: 3;
    display: block;
    filter: drop-shadow(0 16px 28px rgba(0,0,0,0.5));
    transition: transform 0.3s ease;
}
.kb-featured__img-link:hover { transform: translateY(-4px) rotate(-1deg); }

.kb-featured__photo {
    width: 100%;
    height: 100%;
    object-fit: contain;
    display: block;
}

.kb-featured__eyebrow {
    font-size: 0.88rem;
    color: var(--kb-orange);
    margin: 0 0 10px;
    letter-spacing: 2px;
    text-transform: uppercase;
    font-weight: 700;
    text-align: left;
}

.kb-featured__title {
    font-family: var(--kb-font-head);
    font-size: clamp(1.6rem, 2.6vw, var(--kb-size-featured));
    letter-spacing: 0;
    text-transform: uppercase;
    margin-bottom: 14px;
    line-height: 1.08;
}

.kb-featured__desc {
    color: var(--kb-text-muted);
    line-height: 1.65;
    margin-bottom: 22px;
    font-size: 0.95rem;
}

.kb-featured__card .kb-btn {
    align-self: flex-start;
}

/* ============================================
   BESTSELLERS
   ============================================ */
.kb-bestsellers {
    padding: 72px 0;
    background: var(--kb-bg-mid);
}

.kb-bestsellers__grid-wrap {
    position: relative;
}

/* Fade edge to hint scrollability */
.kb-bestsellers__grid-wrap::after {
    content: '';
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    width: 60px;
    background: linear-gradient(to right, transparent, var(--kb-bg-mid));
    pointer-events: none;
    z-index: 2;
    border-radius: 0 var(--kb-radius) var(--kb-radius) 0;
}

.kb-bestsellers__grid {
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: minmax(280px, 320px);
    gap: 20px;
    overflow-x: auto;
    overflow-y: hidden;
    scroll-snap-type: x mandatory;
    overscroll-behavior-x: contain;
    scrollbar-width: none;          /* Firefox */
    -ms-overflow-style: none;       /* IE/Edge */
}

.kb-bestsellers__grid::-webkit-scrollbar {
    display: none;                  /* Chrome/Safari */
}

.kb-product-card {
    position: relative;
    background: #304451;
    border: 1px solid var(--kb-border);
    border-radius: var(--kb-radius);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    scroll-snap-align: start;
    transition: border-color 0.2s, transform 0.2s;
}

.kb-product-card:hover {
    border-color: var(--kb-orange);
    transform: translateY(-3px);
}

.kb-product-card__img-link {
    display: block;
    overflow: hidden;
    position: relative;
    aspect-ratio: 1 / 1;
    background: #304451;
}
.kb-product-card__img,
.kb-product-card .kb-product-card__img {
    width: 100% !important;
    height: 100% !important;
    object-fit: contain;
    padding: 8px;
    transition: transform 0.3s;
}
.kb-product-card:hover .kb-product-card__img { transform: scale(1.04); }

.kb-product-card__body {
    padding: 20px;
    display: flex;
    flex-direction: column;
    gap: 12px;
    flex: 1;
}

.kb-product-card__title {
    font-size: var(--kb-size-product);
    margin-bottom: 0;
    color: var(--kb-text);
    line-height: 1.35;
    text-align: center;
}
.kb-product-card__title a { color: var(--kb-text); }
.kb-product-card__title a:hover { color: var(--kb-orange); }

.kb-product-card__price {
    font-size: var(--kb-size-product);
    color: var(--kb-orange);
    margin-bottom: 4px;
    text-align: center;
}

.kb-product-card__actions {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-top: auto;
    width: 100%;
}

.kb-product-card__actions .kb-btn {
    flex: 1;
    min-height: 38px;
    padding: 9px 12px;
    font-size: 0.8rem;
    line-height: 1.2;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    white-space: nowrap;
}

.kb-product-card__cart-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 38px; height: 38px;
    background: var(--kb-bg-mid);
    border: 1px solid var(--kb-border);
    border-radius: var(--kb-radius);
    color: var(--kb-text);
    transition: background 0.2s, border-color 0.2s;
    flex-shrink: 0;
}
.kb-product-card__cart-icon:hover {
    background: var(--kb-orange);
    border-color: var(--kb-orange);
    color: #fff;
}

/* Badges (NEW / SALE) */
.kb-badge {
    position: absolute;
    top: 10px;
    left: 10px;
    z-index: 2;
    padding: 4px 10px;
    font-family: var(--kb-font-head);
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    border-radius: 3px;
    line-height: 1;
}
.kb-badge--sale {
    background: var(--kb-yellow);
    color: #000;
}
.kb-badge--new {
    background: var(--kb-orange);
    color: #fff;
}

/* Sale price accents on cards */
.kb-product-card__price del {
    color: var(--kb-text-muted);
    font-size: 0.8em;
    margin-right: 4px;
}
.kb-product-card__price ins {
    text-decoration: none;
    color: var(--kb-yellow);
    font-weight: 700;
}

/* ============================================
   REVIEWS
   ============================================ */
.kb-reviews {
    position: relative;
    padding: 80px 0;
    background: var(--kb-bg-alt);
    overflow: hidden;
}

.kb-reviews__bg {
    position: absolute;
    right: -60px; bottom: -20px;
    width: 380px;
    opacity: 0.06;
    pointer-events: none;
}

.kb-reviews__robot { width: 100%; }

.kb-reviews .kb-container { position: relative; z-index: 1; }

/* Fallback review cards (no Trustindex configured) */
.kb-reviews__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
    margin-bottom: 48px;
}

.kb-review-card {
    background: rgba(0, 0, 0, 0.25);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: var(--kb-radius);
    padding: 24px;
    transition: border-color 0.2s;
}
.kb-review-card:hover {
    border-color: rgba(255, 49, 8, 0.4);
}
.kb-review-card__text {
    color: var(--kb-text-muted);
    font-size: 0.9rem;
    line-height: 1.7;
    margin-bottom: 16px;
    font-style: italic;
}
.kb-review-card__author {
    font-weight: 700;
    font-size: 0.9rem;
    color: var(--kb-text);
}

/* ---- Trustindex widget — dark theme overrides ---- */
.kb-reviews__widget {
    width: 100%;
    margin: 0 auto 48px;
}

/* Blanket: transparent backgrounds + site text color on every element */
.kb-reviews__widget *,
.kb-reviews__widget *::before,
.kb-reviews__widget *::after {
    background-color: transparent !important;
    box-shadow: none !important;
    color: var(--kb-text) !important;
}

/* Outer wrappers */
.kb-reviews__widget .ti-widget,
.kb-reviews__widget .ti-widget-container,
.kb-reviews__widget [class*="ti-widget"] {
    background: transparent !important;
    border: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 auto !important;
    padding: 0 !important;
}

/* Review list — CSS grid for predictable equal-width columns */
.kb-reviews__widget .ti-reviews-container {
    display: grid !important;
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)) !important;
    gap: 24px !important;
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    box-sizing: border-box !important;
}

.kb-reviews__widget .ti-reviews-container > * {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    flex: none !important;
}

/* Individual review cards */
.kb-reviews__widget .ti-review-item,
.kb-reviews__widget .ti-review,
.kb-reviews__widget .ti-inner,
.kb-reviews__widget .ti-review-content,
.kb-reviews__widget .ti-review-card,
.kb-reviews__widget [class*="ti-review"] {
    background-color: rgba(255, 255, 255, 0.03) !important;
    border: 1px solid var(--kb-border) !important;
    border-radius: var(--kb-radius) !important;
    padding: 22px !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: none !important;
    box-sizing: border-box !important;
}

/* Author name */
.kb-reviews__widget .ti-name,
.kb-reviews__widget .ti-review-author,
.kb-reviews__widget .ti-reviewer,
.kb-reviews__widget .ti-review-item strong,
.kb-reviews__widget .ti-header,
.kb-reviews__widget [class*="ti-name"],
.kb-reviews__widget [class*="ti-author"] {
    color: var(--kb-text) !important;
}

/* Body text */
.kb-reviews__widget .ti-review-text,
.kb-reviews__widget .ti-text,
.kb-reviews__widget .ti-review-content p,
.kb-reviews__widget .ti-review-item p,
.kb-reviews__widget .ti-widget-container p,
.kb-reviews__widget p {
    color: var(--kb-text-muted) !important;
    line-height: 1.7 !important;
}

/* Stars — site yellow */
.kb-reviews__widget .ti-stars,
.kb-reviews__widget .ti-stars svg,
.kb-reviews__widget .ti-stars path,
.kb-reviews__widget [class*="ti-star"] {
    color: var(--kb-yellow) !important;
    fill: var(--kb-yellow) !important;
}

/* Dates, meta, footer text */
.kb-reviews__widget .ti-rating-text,
.kb-reviews__widget .ti-rating,
.kb-reviews__widget .ti-footer,
.kb-reviews__widget .ti-date,
.kb-reviews__widget .ti-powered-by,
.kb-reviews__widget [class*="ti-date"],
.kb-reviews__widget [class*="ti-footer"] {
    color: var(--kb-text-muted) !important;
}

/* Links */
.kb-reviews__widget a,
.kb-reviews__widget .ti-widget-container a,
.kb-reviews__widget .ti-footer a {
    color: var(--kb-text) !important;
}

/* Buttons */
.kb-reviews__widget .ti-load-more-reviews-button,
.kb-reviews__widget .ti-widget-container .ti-footer a,
.kb-reviews__widget .ti-widget-container .ti-button,
.kb-reviews__widget [class*="ti-button"],
.kb-reviews__widget [class*="ti-load-more"] {
    background-color: var(--kb-orange) !important;
    border: 1px solid var(--kb-orange) !important;
    border-radius: var(--kb-radius) !important;
    color: #fff !important;
    padding: 10px 18px !important;
    text-transform: none !important;
}
.kb-reviews__widget .ti-load-more-reviews-button:hover,
.kb-reviews__widget .ti-widget-container .ti-footer a:hover,
.kb-reviews__widget .ti-widget-container .ti-button:hover {
    background-color: var(--kb-orange-h) !important;
    border-color: var(--kb-orange-h) !important;
}

/* Avatar images */
.kb-reviews__widget img {
    border-radius: 999px;
}

/* ============================================
   ABOUT
   ============================================ */
.kb-about {
    padding: 80px 0;
    background: var(--kb-bg-about);
    position: relative;
    overflow: hidden;
}

.kb-about__inner {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 60px;
    align-items: center;
}

.kb-about__content p {
    color: var(--kb-text-muted);
    line-height: 1.8;
    max-width: 520px;
}

.kb-about__logo {
    position: absolute;
    top: clamp(16px, 3vw, 40px);
    left: clamp(16px, 3vw, 40px);
    height: clamp(80px, 11vw, 160px);
    width: auto;
    max-width: 280px;
    margin: 0;
    mix-blend-mode: screen;
    object-fit: contain;
    opacity: 0.92;
    pointer-events: none;
    z-index: 2;
}

/* About rechts: foto + logo gestapeld */
.kb-about__right {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0;
}

.kb-about__photo-wrap {
    width: 100%;
    max-width: 380px;
    border-radius: var(--kb-radius);
    overflow: hidden;
}

.kb-about__photo {
    width: 100%;
    display: block;
    object-fit: cover;
    aspect-ratio: 3/4;
    filter: grayscale(20%);
}

/* 3D KB logo */
.kb-logo-3d {
    display: inline-flex;
    flex-direction: column;
    line-height: 0.9;
    user-select: none;
    padding: 20px 0;
}

.kb-logo-3d__top,
.kb-logo-3d__bottom {
    display: flex;
    align-items: baseline;
}

.kb-logo-3d__k {
    font-family: var(--kb-font-head);
    font-size: 9rem;
    line-height: 1;
    color: var(--kb-orange);
    text-shadow:
        2px  2px 0 #c44000,
        4px  4px 0 #a33400,
        6px  6px 0 #832900,
        8px  8px 0 #622000,
        10px 10px 0 #3a1200,
        12px 12px 6px rgba(0,0,0,0.5);
}

.kb-logo-3d__b {
    font-family: var(--kb-font-head);
    font-size: 9rem;
    line-height: 1;
    color: #f0f0f0;
    text-shadow:
        2px  2px 0 #aaa,
        4px  4px 0 #888,
        6px  6px 0 #666,
        8px  8px 0 #444,
        10px 10px 0 #222,
        12px 12px 6px rgba(0,0,0,0.5);
}

.kb-logo-3d__small {
    font-family: var(--kb-font-head);
    font-size: 2.6rem;
    letter-spacing: 0;
    color: var(--kb-text-muted);
    padding-bottom: 14px;
    padding-left: 4px;
}

/* ============================================
   FOOTER
   ============================================ */
.kb-footer {
    background: var(--kb-bg-footer);
    border-top: 1px solid var(--kb-border);
    padding-top: 56px;
}

.kb-footer__inner {
    max-width: var(--kb-container);
    margin: 0 auto;
    padding: 0 28px 48px;
    display: grid;
    grid-template-columns: 1.4fr 1fr 1.6fr;
    gap: 48px;
}

.kb-footer__heading {
    font-family: var(--kb-font-head);
    font-size: 1rem;
    letter-spacing: 0;
    text-transform: uppercase;
    color: var(--kb-text);
    margin-bottom: 20px;
}

.kb-footer__brand {
    font-weight: 400;
    margin-bottom: 16px;
    font-size: 0.95rem;
}

.kb-footer__contact-list { display: flex; flex-direction: column; gap: 12px; }
.kb-footer__contact-list li {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    color: var(--kb-text);
    font-size: var(--kb-size-footer);
    line-height: 1.5;
}
.kb-footer__contact-list svg { flex-shrink: 0; margin-top: 3px; }
.kb-footer__contact-list a { color: var(--kb-text); transition: color 0.2s; }
.kb-footer__contact-list a:hover { color: var(--kb-orange); }

.kb-footer__sitemap { display: flex; flex-direction: column; gap: 8px; }
.kb-footer__sitemap a {
    color: var(--kb-text);
    font-size: var(--kb-size-footer);
    transition: color 0.2s;
}
.kb-footer__sitemap a:hover { color: var(--kb-orange); }
.kb-footer__sitemap a.kb-footer__sitemap-home { color: var(--kb-orange); font-weight: 700; }
.kb-footer__sitemap a.kb-footer__sitemap-home:hover { color: var(--kb-orange-h); }

/* Contactformulier */
.kb-footer__form { display: flex; flex-direction: column; gap: 10px; }

.kb-footer__form input,
.kb-footer__form textarea {
    background: var(--kb-bg-mid);
    border: 1px solid var(--kb-border);
    border-radius: var(--kb-radius);
    color: var(--kb-text);
    padding: 10px 14px;
    font-size: 0.88rem;
    font-family: var(--kb-font-body);
    transition: border-color 0.2s;
    width: 100%;
}

.kb-footer__form input::placeholder,
.kb-footer__form textarea::placeholder { color: var(--kb-text-muted); }

.kb-footer__form input:focus,
.kb-footer__form textarea:focus {
    outline: none;
    border-color: var(--kb-orange);
}

.kb-footer__form textarea { resize: vertical; }

.kb-footer__form .kb-btn {
    align-self: flex-start;
    padding: 11px 28px;
}

/* Footer bottom */
.kb-footer__bottom {
    border-top: 1px solid var(--kb-border);
    padding: 18px 28px;
    text-align: center;
}
.kb-footer__bottom p {
    font-size: 0.8rem;
    color: var(--kb-text);
}

/* ============================================
   RESPONSIVE — TABLET (max 1024px)
   ============================================ */
@media (max-width: 1024px) {
    /* Topbar hides earlier — at narrow desktops the contact row wraps awkwardly */
    .kb-topbar { display: none; }

    /* Header tightens so nav + logo + actions fit without overflow */
    .kb-header__inner         { height: 88px; padding: 0 20px; gap: 20px; }
    .kb-header__logo-img      { height: 72px; max-height: 72px; transform: none; }
    .kb-nav__list a           { padding: 8px 10px; font-size: 16px; }

    .kb-categories__grid      { grid-template-columns: repeat(2, 1fr); }
    .kb-bestsellers__grid     { grid-auto-columns: minmax(260px, 300px); }
    .kb-featured              { padding: 80px 0 72px; }
    .kb-featured__inner       { min-height: 360px; }
    .kb-featured__stage       { padding: 44px 32px; }
    .kb-featured__card        { padding: 32px 28px; }
    .kb-featured__img-link    { width: 150px; height: 150px; top: -40px; left: -64px; }
    .kb-footer__inner         { grid-template-columns: 1fr 1fr; gap: 32px; }
    .kb-footer__col:last-child{ grid-column: span 2; }

    /* Reviews — 2 columns on tablet */
    .kb-reviews__grid { grid-template-columns: repeat(2, 1fr); }
    .kb-reviews__widget .ti-reviews-container {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 20px !important;
    }
}

/* ============================================
   RESPONSIVE — MOBIEL (max 768px)
   ============================================ */
@media (max-width: 768px) {

    /* Topbar already hidden at ≤1024; nothing extra needed here */

    /* Desktop dropdown verbergen — mobiel via toggle */
    .kb-nav__list .menu-item-has-children {
        display: grid;
        grid-template-columns: minmax(0, 1fr) 52px;
        align-items: center;
        width: 100%;
    }
    .kb-nav__list .menu-item-has-children:hover > .sub-menu { display: none; }
    .kb-nav__list .sub-menu {
        display: none;
        position: static;
        grid-column: 1 / -1;
        width: 100%;
        min-width: 0;
        opacity: 1;
        visibility: visible;
        pointer-events: auto;
        transform: none;
    }
    .kb-nav__list .sub-menu::before { display: none; }
    .kb-nav__list .menu-item-has-children.kb-nav__item--open > .sub-menu {
        display: flex;
        flex-direction: column;
        position: static;
        background: rgba(255, 255, 255, 0.05);
        border: 1px solid rgba(255, 255, 255, 0.08);
        border-left: 3px solid var(--kb-orange);
        border-radius: 6px;
        min-width: auto;
        margin: 0 0 10px;
        padding: 6px;
        box-shadow: none;
        opacity: 1;
        visibility: visible;
        pointer-events: auto;
        transform: none;
    }
    .kb-nav__list .sub-menu a {
        padding: 12px 14px;
        font-size: 1rem;
        font-family: var(--kb-font-body) !important;
        text-transform: none;
        letter-spacing: 0;
        line-height: 1.3;
        min-height: 44px;
        border-bottom: none;
        border-radius: 4px;
        text-align: left;
        white-space: normal;
    }

    /* Header */
    .kb-header { position: sticky; top: 0; z-index: 100; }
    .kb-header__inner { height: 68px; padding: 0 16px; gap: 16px; }

    /* Nav — uitklapmenu */
    .kb-nav {
        display: none;
        position: fixed;
        top: 68px; left: 0; right: 0; bottom: 0;
        background: rgba(10, 10, 10, 0.97);
        padding: 24px 20px;
        z-index: 99;
        overflow-y: auto;
    }
    .kb-nav--open { display: block; }
    .kb-nav__list {
        flex-direction: column;
        gap: 0;
    }
    .kb-nav__list > li {
        width: 100%;
    }
    .kb-nav__list a {
        display: block;
        font-size: 1.6rem;
        font-family: var(--kb-font-head);
        text-transform: uppercase;
        letter-spacing: 0.03em;
        padding: 18px 8px;
        border-bottom: 1px solid rgba(255, 255, 255, 0.08);
        text-align: left;
        min-height: 56px;
        color: var(--kb-text);
    }
    .kb-nav__list a:active { color: var(--kb-orange); }
    .kb-nav__submenu-toggle {
        width: 52px;
        height: 56px;
        border-radius: 0;
        border-bottom: 1px solid rgba(255, 255, 255, 0.08);
        color: rgba(255, 255, 255, 0.72);
    }
    .kb-nav__submenu-toggle:hover,
    .kb-nav__item--open > .kb-nav__submenu-toggle {
        background: rgba(255, 255, 255, 0.06);
        color: var(--kb-orange);
    }

    .kb-nav__toggle { display: flex; }

    /* === Mobile header: logo + hamburger only, cart relocated to bottom bar === */
    .kb-header__inner { justify-content: flex-start; }
    .kb-nav__toggle {
        order: 1;
        padding: 12px;          /* 48px tap target */
        margin-left: -8px;
    }
    .kb-header__logo {
        order: 2;
        flex: 1 1 auto;
        display: flex;
        justify-content: center;
        margin-right: 40px;     /* visual balance with hamburger width */
    }
    .kb-header__actions { display: none; }  /* cart hidden — lives in mobilebar */

    /* Bigger hamburger lines for clearer hit area */
    .kb-nav__toggle span { width: 26px; height: 2.5px; }

    /* Full-screen overlay menu — layout only; visibility stays gated by --open */
    .kb-nav {
        top: 0;
        background: rgba(0, 0, 0, 0.97);
        padding: 88px 24px 120px;       /* room for header + bottombar */
        flex-direction: column;
        justify-content: center;
        align-items: stretch;
        backdrop-filter: blur(8px);
        -webkit-backdrop-filter: blur(8px);
    }
    .kb-nav--open {
        display: flex;
    }
    .kb-nav__list { max-width: 360px; margin: 0 auto; width: 100%; }

    /* When menu is open, morph hamburger to an X */
    .kb-nav__toggle[aria-expanded="true"] span:nth-child(1) {
        transform: translateY(7.5px) rotate(45deg);
    }
    .kb-nav__toggle[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
    .kb-nav__toggle[aria-expanded="true"] span:nth-child(3) {
        transform: translateY(-7.5px) rotate(-45deg);
    }

    /* Prevent body scroll when menu open */
    body.kb-menu-open { overflow: hidden; }

    /* ===== Mobile sticky bottom bar (cart + shop + account) ===== */
    .kb-mobilebar {
        display: grid;
        grid-template-columns: 1fr 1fr 1.4fr;
        position: fixed;
        bottom: 0; left: 0; right: 0;
        z-index: 200;
        background: rgba(0, 0, 0, 0.96);
        border-top: 1px solid rgba(255, 255, 255, 0.08);
        padding: 6px 0 calc(6px + env(safe-area-inset-bottom));
        backdrop-filter: blur(10px);
        -webkit-backdrop-filter: blur(10px);
    }

    /* Push page content above the bar so nothing is hidden behind it */
    body { padding-bottom: calc(64px + env(safe-area-inset-bottom)); }
}

/* === Mobilebar styles (rendered always; visibility controlled per breakpoint) === */
.kb-mobilebar { display: none; }
.kb-mobilebar__item {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 3px;
    color: var(--kb-text-muted);
    text-decoration: none;
    padding: 10px 6px;
    min-height: 56px;
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    font-family: var(--kb-font-body);
    transition: color 0.15s ease;
    position: relative;
}
.kb-mobilebar__item:hover,
.kb-mobilebar__item:active { color: var(--kb-text); }
.kb-mobilebar__item--cart {
    color: var(--kb-text);
    background: var(--kb-orange);
    margin: -6px 0 calc(-6px - env(safe-area-inset-bottom));
    padding-top: 14px;
    padding-bottom: calc(14px + env(safe-area-inset-bottom));
}
.kb-mobilebar__item--cart:hover,
.kb-mobilebar__item--cart:active { color: #fff; background: var(--kb-orange-h); }
.kb-mobilebar__cart-wrap {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.kb-mobilebar__badge {
    position: absolute;
    top: -6px; right: -10px;
    min-width: 18px;
    height: 18px;
    padding: 0 5px;
    border-radius: 9px;
    background: #fff;
    color: var(--kb-orange);
    font-family: var(--kb-font-head);
    font-size: 0.72rem;
    line-height: 18px;
    text-align: center;
    border: 2px solid var(--kb-orange);
}
.kb-mobilebar__label {
    font-weight: 600;
    white-space: nowrap;
}

/* === Larger touch targets (mobile) === */
@media (max-width: 768px) {
    .kb-btn,
    .kb-product-card__add-to-cart,
    .woocommerce a.button,
    .woocommerce button.button,
    .woocommerce input[type="submit"] {
        min-height: 48px;
        padding-left: 22px;
        padding-right: 22px;
    }
    .kb-product-card { padding-bottom: 12px; }
    .kb-product-card__link,
    .kb-product-card a {
        min-height: 44px;
    }
    /* Form inputs comfortably tappable */
    .woocommerce form .form-row input.input-text,
    .woocommerce form .form-row textarea,
    .woocommerce form .form-row select,
    .kb-checkout input.input-text {
        min-height: 48px;
        font-size: 16px; /* prevents iOS zoom on focus */
    }

    /* Hero — robot als bg, kleiner op mobiel */
    .kb-hero { min-height: 400px; }
    .kb-hero__inner { padding: 60px 20px 60px; }
    .kb-hero__content { max-width: 100%; }
    .kb-hero__title { font-size: clamp(2.8rem, 14vw, 4.5rem); margin-bottom: 24px; }
    .kb-hero__robot-wrap { width: 65%; right: -10px; bottom: -12px; left: auto; opacity: 0.18; }
    .kb-hero__star { display: none; }

    /* Secties */
    .kb-categories   { padding: 48px 0; }
    .kb-featured     { padding: 48px 0; }
    .kb-bestsellers  { padding: 48px 0; }
    .kb-reviews      { padding: 56px 0; }
    .kb-about        { padding: 48px 0; }

    .kb-section__title { font-size: 32px; margin-bottom: 28px; }

    /* Categorieën — 1 kolom */
    .kb-categories__grid {
        grid-template-columns: 1fr;
        max-width: 380px;
        margin: 0 auto;
        gap: 16px;
    }
    .kb-cat-card { aspect-ratio: 16/9; }

    /* Uitgelicht product — stack stage then card, image overlap repositioned */
    .kb-featured                { padding: 60px 0 72px; }
    .kb-featured__inner         { grid-template-columns: 1fr; min-height: 0; }
    .kb-featured__stage         {
        border-radius: var(--kb-radius) var(--kb-radius) 0 0;
        padding: 44px 24px;
        min-height: 220px;
    }
    .kb-featured__stage-headline { font-size: clamp(2.6rem, 13vw, 4.5rem); }
    .kb-featured__card          {
        border-left: 1px solid var(--kb-border);
        border-top: none;
        border-radius: 0 0 var(--kb-radius) var(--kb-radius);
        padding: 78px 24px 28px;
        box-shadow: none;
    }
    .kb-featured__img-link      {
        top: -56px;
        left: 50%;
        transform: translateX(-50%);
        width: 140px;
        height: 140px;
    }
    .kb-featured__img-link:hover { transform: translateX(-50%) translateY(-4px); }
    .kb-featured__eyebrow       { text-align: center; }
    .kb-featured__title         { text-align: center; }
    .kb-featured__desc          { text-align: center; }
    .kb-featured__card .kb-btn  { align-self: center; }

    /* Bestsellers — 2 kolommen */
    .kb-bestsellers__grid { grid-auto-columns: minmax(240px, 260px); gap: 14px; }
    .kb-product-card__actions { flex-direction: row; gap: 8px; }
    .kb-product-card__actions .kb-btn { min-height: 36px; padding: 8px 10px; }
    .kb-product-card__cart-icon { width: 36px; height: 36px; justify-content: center; }

    /* Reviews — stacked on mobile */
    .kb-reviews__grid { grid-template-columns: 1fr; gap: 18px; }
    .kb-reviews__widget .ti-reviews-container {
        grid-template-columns: 1fr !important;
        gap: 16px !important;
    }
    .kb-reviews__widget .ti-review-item,
    .kb-reviews__widget .ti-review,
    .kb-reviews__widget .ti-review-card {
        padding: 16px !important;
    }
    .kb-reviews__bg { display: none; }

    /* Shop — drop to 2 columns when sidebar stacks */
    .kb-shop__products-grid { grid-template-columns: repeat(2, 1fr); }

    /* Single product — keep tall crop but avoid excessive height */
    .kb-single__main-img {
        width: var(--kb-single-img-width-tablet, 100%);
        height: var(--kb-single-img-height-tablet, 460px);
        min-height: 0;
        max-height: var(--kb-single-img-height-tablet, 460px);
    }
    .kb-single__thumbs-wrap {
        width: var(--kb-single-img-width-tablet, 100%);
    }

    /* About */
    .kb-about__inner  { grid-template-columns: 1fr; }
    .kb-about__right  { flex-direction: row; align-items: flex-start; gap: 20px; flex-wrap: wrap; }
    .kb-about__photo-wrap { max-width: 200px; }
    /* Logo back to inline flow on mobile so it doesn't collide with the title */
    .kb-about__logo {
        position: static;
        height: 70px;
        margin: 0 0 16px;
        opacity: 1;
    }
    .kb-logo-3d { padding: 0; }
    .kb-logo-3d__k, .kb-logo-3d__b { font-size: 5rem; }

    /* Footer */
    .kb-footer { padding-top: 40px; }
    .kb-footer__inner {
        grid-template-columns: 1fr;
        gap: 32px;
        padding: 0 20px 36px;
    }
    .kb-footer__col:last-child { grid-column: auto; }
    .kb-footer__form .kb-btn { width: 100%; text-align: center; }
}

/* ============================================
   ABOUT — photo placeholder
   ============================================ */
.kb-about__photo-wrap {
    position: relative;
}

.kb-about__photo-placeholder {
    position: absolute;
    inset: 0;
    background: var(--kb-bg-mid);
    border-radius: var(--kb-radius);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 12px;
    color: var(--kb-text-muted);
    font-size: 0.8rem;
    letter-spacing: 0.5px;
}

.kb-about__photo {
    position: relative;
    z-index: 1;
}

/* Hide placeholder when real photo is loaded */
.kb-about__photo-wrap:has(.kb-about__photo[src]:not([style*="display:none"])) .kb-about__photo-placeholder {
    display: none;
}

/* ============================================
   FOOTER LOGO
   ============================================ */
.kb-footer__logo-link {
    display: inline-block;
    margin-bottom: 20px;
}

.kb-footer__logo {
    height: 120px;
    width: auto;
    max-width: 280px;
    display: block;
    object-fit: contain;
}

/* ============================================
   FOOTER PAYMENT ICONS
   ============================================ */
.kb-footer__payment {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 8px;
    margin-bottom: 14px;
}

.kb-pay-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    line-height: 0;
    opacity: 0.7;
    transition: opacity 0.2s;
}
.kb-pay-icon:hover { opacity: 1; }
.kb-pay-icon svg { display: block; }

/* ============================================
   CONTACT FORM 7 — footer styling
   ============================================ */
.kb-footer__col .wpcf7 input[type="text"],
.kb-footer__col .wpcf7 input[type="email"],
.kb-footer__col .wpcf7 textarea {
    background: var(--kb-bg-mid);
    border: 1px solid var(--kb-border);
    border-radius: var(--kb-radius);
    color: var(--kb-text);
    padding: 10px 14px;
    font-size: 0.88rem;
    font-family: var(--kb-font-body);
    transition: border-color 0.2s;
    width: 100%;
    display: block;
    margin-bottom: 10px;
}

.kb-footer__col .wpcf7 input[type="text"]::placeholder,
.kb-footer__col .wpcf7 input[type="email"]::placeholder,
.kb-footer__col .wpcf7 textarea::placeholder {
    color: var(--kb-text-muted);
}

.kb-footer__col .wpcf7 input[type="text"]:focus,
.kb-footer__col .wpcf7 input[type="email"]:focus,
.kb-footer__col .wpcf7 textarea:focus {
    outline: none;
    border-color: var(--kb-orange);
}

.kb-footer__col .wpcf7 textarea {
    resize: vertical;
    min-height: 90px;
}

.kb-footer__col .wpcf7 input[type="submit"] {
    background: var(--kb-orange);
    color: #fff;
    border: none;
    border-radius: var(--kb-radius);
    padding: 11px 28px;
    font-weight: 600;
    font-size: 0.88rem;
    letter-spacing: 0.5px;
    cursor: pointer;
    transition: background 0.2s;
    font-family: var(--kb-font-body);
}

.kb-footer__col .wpcf7 input[type="submit"]:hover {
    background: var(--kb-orange-h);
}

.kb-footer__col .wpcf7-not-valid-tip {
    color: var(--kb-orange);
    font-size: 0.78rem;
    margin-top: -6px;
    margin-bottom: 8px;
    display: block;
}

.kb-footer__col .wpcf7-response-output {
    border: 1px solid var(--kb-border);
    border-radius: var(--kb-radius);
    padding: 10px 14px;
    font-size: 0.82rem;
    margin-top: 12px;
    color: var(--kb-text-muted);
}

/* ============================================
   RESPONSIVE — KLEIN MOBIEL (max 480px)
   ============================================ */
@media (max-width: 480px) {

    .kb-container { padding: 0 16px; }

    /* Header */
    .kb-header__logo-text { font-size: 1.2rem; }

    /* Hero */
    .kb-hero__inner { padding: 36px 16px 0; }
    .kb-hero__title { font-size: clamp(2.4rem, 16vw, 3.5rem); }
    .kb-btn { padding: 12px 22px; font-size: 0.88rem; }

    /* Categorieën */
    .kb-categories__grid { max-width: 100%; }
    .kb-cat-card { aspect-ratio: 4/3; }

    /* Bestsellers — 1 kolom op kleine schermen */
    .kb-bestsellers__grid { grid-auto-columns: minmax(220px, 240px); }

    /* Featured */
    .kb-featured__stage         { padding: 32px 16px; min-height: 180px; }
    .kb-featured__stage-headline { font-size: clamp(2.2rem, 14vw, 3.6rem); }
    .kb-featured__card          { padding: 68px 18px 24px; }
    .kb-featured__img-link      { width: 120px; height: 120px; top: -48px; }

    /* Footer */
    .kb-footer__inner { padding: 0 16px 32px; }
    .kb-footer__bottom { padding: 16px; }

    /* Shop */
    .kb-shop__layout { grid-template-columns: 1fr; }
    .kb-shop__sidebar { order: -1; }
    .kb-shop__products-grid { grid-template-columns: repeat(2, 1fr); }
    /* Single product */
    .kb-single__top { grid-template-columns: 1fr; gap: 32px; }
    .kb-single__main-img { width: var(--kb-single-img-width-mobile, 100%); height: var(--kb-single-img-height-mobile, 360px); min-height: 0; max-height: var(--kb-single-img-height-mobile, 360px); }
    .kb-single__thumbs-wrap { width: var(--kb-single-img-width-mobile, 100%); }
    .kb-single__story-cols { column-count: 1; }
    .kb-single__related-grid { grid-template-columns: repeat(2, 1fr); }

    /* Inspiration */
    .kb-insp-grid { grid-template-columns: 1fr; }
    .kb-inspiration__hero-title { font-size: clamp(2.5rem, 12vw, 4rem); }

    /* WC cart/checkout */
    .woocommerce table.shop_table { font-size: 0.85rem; }
    .woocommerce-checkout .col2-set .col-1,
    .woocommerce-checkout .col2-set .col-2 { float: none; width: 100%; }

    /* My Account */
    .woocommerce-MyAccount-navigation { float: none; width: 100%; margin-bottom: 24px; }
    .woocommerce-MyAccount-content { float: none; width: 100%; }

    /* Trust strip + badges */
    .kb-trust-strip { flex-direction: column; gap: 10px; }
    .kb-badge { font-size: 0.65rem; padding: 3px 8px; }
}


/* ============================================
   TASK 12 — SHOP / CATEGORY PAGE
   ============================================ */

/* Homepage body background override — site header + inner sections
   keep their own black/dark backgrounds. Only the exposed body shows. */
body.home {
    background: var(--kb-bg-mid);
}

/* Main shop page container */
.kb-shop {
    background: #304451;
}

/* Page header (shared by shop + single) */
.kb-shop__header {
    background: #304451;
    padding: 48px 0 24px;
    text-align: center;
    border-bottom: 1px solid var(--kb-border);
}

.kb-shop__title {
    font-family: var(--kb-font-head);
    font-size: var(--kb-size-section);
    text-transform: uppercase;
    color: var(--kb-text);
    margin-bottom: 8px;
}

/* Breadcrumb */
.kb-breadcrumb {
    font-size: 0.82rem;
    color: var(--kb-text-muted);
    padding: 8px 0;
}
.kb-breadcrumb a { color: var(--kb-text-muted); transition: color 0.2s; }
.kb-breadcrumb a:hover { color: var(--kb-orange); }
.kb-breadcrumb__sep { margin: 0 6px; opacity: 0.5; }
.kb-breadcrumb--page { margin-bottom: 24px; padding-top: 16px; }

/* Category filter bar */
.kb-shop__filter-bar {
    background: #304451;
    border-bottom: 1px solid var(--kb-border);
    padding: 16px 0;
}
.kb-shop__filters {
    display: flex;
    gap: 10px;
    justify-content: center;
    flex-wrap: wrap;
}
.kb-shop__filter-btn {
    display: inline-flex;
    align-items: center;
    padding: 10px 24px;
    font-family: var(--kb-font-head);
    font-size: 0.85rem;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--kb-text-muted);
    background: var(--kb-bg-mid);
    border: 1px solid var(--kb-border);
    border-radius: var(--kb-radius);
    transition: color 0.2s, background 0.2s, border-color 0.2s;
    text-decoration: none;
}
.kb-shop__filter-btn:hover {
    color: var(--kb-text);
    border-color: var(--kb-orange);
}
.kb-shop__filter-btn--active {
    background: var(--kb-orange);
    border-color: var(--kb-orange);
    color: #fff;
}
.kb-shop__filter-btn--active:hover {
    background: var(--kb-orange-h);
    border-color: var(--kb-orange-h);
    color: #fff;
}

/* 2-column layout: sidebar + grid */
.kb-shop__layout {
    display: grid;
    grid-template-columns: 220px 1fr;
    gap: 36px;
    padding: 48px 0;
    align-items: start;
    background: #304451;
}

/* Filter sidebar */
.kb-shop__sidebar {
    background: var(--kb-bg-mid);
    border: 1px solid var(--kb-border);
    border-radius: var(--kb-radius);
    padding: 24px 20px;
    position: sticky;
    top: 100px;
}

.kb-shop__sidebar-widgets {
    max-height: none;
    overflow: visible;
    padding-right: 0;
}


.kb-shop__sidebar-title {
    font-family: var(--kb-font-head);
    font-size: 1rem;
    text-transform: uppercase;
    color: var(--kb-text);
    margin-bottom: 20px;
}

.kb-shop__sidebar-hint {
    font-size: 0.8rem;
    color: var(--kb-text-muted);
    line-height: 1.5;
}

/* ============================================================
   FILTER SIDEBAR — dark theme overrides for classic + block widgets
   ============================================================ */

/* Widget spacing */
.kb-filter-widget                   { margin-bottom: 20px; }
.kb-filter-widget:last-child        { margin-bottom: 0; }
.kb-shop__sidebar .widget           { margin-bottom: 20px; color: var(--kb-text-muted); }
.kb-shop__sidebar .widget:last-child{ margin-bottom: 0; }

/* Widget titles (classic widgets & block widgets) */
.kb-filter-widget__title,
.kb-shop__sidebar .widget-title,
.kb-shop__sidebar .wp-block-heading,
.kb-shop__sidebar .wc-block-components-filter-wrapper__title,
.kb-shop__sidebar .wc-block-filter-wrapper__title,
.kb-shop__sidebar h1, .kb-shop__sidebar h2,
.kb-shop__sidebar h3, .kb-shop__sidebar h4 {
    font-family: var(--kb-font-head);
    font-size: 0.85rem;
    text-transform: uppercase;
    color: var(--kb-text);
    margin-bottom: 10px;
    letter-spacing: 0.05em;
}

/* General backgrounds — prevent white boxes */
.kb-shop__sidebar .widget,
.kb-shop__sidebar [class*="wc-block-"],
.kb-shop__sidebar [class*="wp-block-woocommerce-"] {
    background: transparent !important;
    color: var(--kb-text-muted);
}

/* List items (classic category / attribute widgets) */
.kb-filter-widget ul,
.kb-shop__sidebar .widget ul { list-style: none; padding: 0; margin: 0; }
.kb-filter-widget li,
.kb-shop__sidebar .widget li {
    padding: 6px 0;
    font-size: 0.85rem;
    color: var(--kb-text-muted);
    border-bottom: 1px solid rgba(255,255,255,0.05);
}
.kb-filter-widget li:last-child,
.kb-shop__sidebar .widget li:last-child { border-bottom: none; }

/* Links */
.kb-filter-widget li a,
.kb-shop__sidebar .widget a,
.kb-shop__sidebar .wc-block-product-categories-list-item a,
.kb-shop__sidebar .wc-block-components-chip__text,
.kb-shop__sidebar .wc-block-components-chip__remove {
    color: var(--kb-text-muted);
    transition: color 0.2s;
}
.kb-filter-widget li a:hover,
.kb-shop__sidebar .widget a:hover,
.kb-shop__sidebar .wc-block-product-categories-list-item a:hover {
    color: var(--kb-orange);
}

/* Counts */
.kb-shop__sidebar .count,
.kb-shop__sidebar .wc-block-product-categories-list-item-count,
.kb-shop__sidebar small { color: var(--kb-text-muted); opacity: 0.7; }

/* ── Block widget: checkboxes ── */
.kb-shop__sidebar .wc-block-components-checkbox,
.kb-shop__sidebar .wc-block-attribute-filter-list li,
.kb-shop__sidebar .wc-block-product-categories-list-item {
    font-size: 0.85rem;
    color: var(--kb-text-muted);
    padding: 5px 0;
    border-bottom: 1px solid rgba(255,255,255,0.05);
}
.kb-shop__sidebar .wc-block-components-checkbox__label,
.kb-shop__sidebar .wc-block-attribute-filter-list li label,
.kb-shop__sidebar .wc-block-components-filter-checkbox-list__item-label {
    color: var(--kb-text-muted) !important;
    font-size: 0.85rem;
}
/* Checkbox box itself */
.kb-shop__sidebar .wc-block-components-checkbox__input,
.kb-shop__sidebar input[type="checkbox"] {
    accent-color: var(--kb-orange);
    width: 15px;
    height: 15px;
    cursor: pointer;
}
/* Checked state background for custom checkboxes */
.kb-shop__sidebar .wc-block-components-checkbox__input:checked,
.kb-shop__sidebar input[type="checkbox"]:checked {
    accent-color: var(--kb-orange);
}

/* ── Block widget: price range slider ── */
.kb-shop__sidebar .wc-block-price-filter,
.kb-shop__sidebar .wc-block-components-price-slider {
    color: var(--kb-text-muted);
}
.kb-shop__sidebar .wc-block-price-filter__range-input-wrapper,
.kb-shop__sidebar .wc-block-components-price-slider__range-input-wrapper {
    background: var(--kb-border);
    height: 4px;
    border-radius: 2px;
}
.kb-shop__sidebar .wc-block-price-filter__range-input-progress,
.kb-shop__sidebar .wc-block-components-price-slider__range-input-progress {
    background: var(--kb-orange) !important;
}
.kb-shop__sidebar .wc-block-price-filter__range-input,
.kb-shop__sidebar .wc-block-components-price-slider__range-input {
    accent-color: var(--kb-orange);
}
.kb-shop__sidebar .wc-block-price-filter__range-text,
.kb-shop__sidebar .wc-block-components-price-slider__range-text,
.kb-shop__sidebar .wc-block-price-filter__range-input-wrapper ~ * {
    color: var(--kb-text-muted);
    font-size: 0.82rem;
}

/* ── Active filters (chips) ── */
.kb-shop__sidebar .wc-block-active-filters,
.kb-shop__sidebar .wc-block-active-filters__list {
    background: transparent !important;
}
.kb-shop__sidebar .wc-block-components-chip {
    background: rgba(255,255,255,0.07) !important;
    border: 1px solid var(--kb-border) !important;
    border-radius: 999px !important;
    color: var(--kb-text-muted) !important;
    font-size: 0.78rem;
}
.kb-shop__sidebar .wc-block-components-chip:hover {
    border-color: var(--kb-orange) !important;
    color: var(--kb-text) !important;
}
.kb-shop__sidebar .wc-block-active-filters__clear-all {
    color: var(--kb-orange) !important;
    font-size: 0.8rem;
    background: transparent !important;
    border: none !important;
    cursor: pointer;
    text-decoration: underline;
}

/* ── Rating filter ── */
.kb-shop__sidebar .wc-block-rating-filter__star-icon,
.kb-shop__sidebar .wc-block-components-review-list-item__rating svg {
    color: var(--kb-yellow) !important;
    fill: var(--kb-yellow) !important;
}

/* ── Text inputs & selects ── */
.kb-filter-widget select,
.kb-filter-widget input[type="text"],
.kb-shop__sidebar select,
.kb-shop__sidebar input[type="text"],
.kb-shop__sidebar input[type="search"],
.kb-shop__sidebar input[type="number"] {
    width: 100%;
    background: var(--kb-bg);
    border: 1px solid var(--kb-border);
    border-radius: var(--kb-radius);
    color: var(--kb-text);
    padding: 8px 10px;
    font-size: 0.82rem;
    font-family: var(--kb-font-body);
}
.kb-filter-widget select:focus,
.kb-filter-widget input:focus,
.kb-shop__sidebar select:focus,
.kb-shop__sidebar input:focus {
    outline: none;
    border-color: var(--kb-orange);
}

/* ── Buttons (Apply / Filter) ── */
.kb-shop__sidebar button,
.kb-shop__sidebar .button,
.kb-shop__sidebar .wp-block-button__link,
.kb-shop__sidebar .wc-block-price-filter__actions button,
.kb-shop__sidebar .wc-block-components-filter-submit-button {
    background: var(--kb-orange) !important;
    border: 1px solid var(--kb-orange) !important;
    color: #fff !important;
    border-radius: var(--kb-radius) !important;
    padding: 7px 14px;
    font-size: 0.82rem;
    cursor: pointer;
    transition: background 0.2s, border-color 0.2s;
}
.kb-shop__sidebar button:hover,
.kb-shop__sidebar .button:hover,
.kb-shop__sidebar .wp-block-button__link:hover,
.kb-shop__sidebar .wc-block-price-filter__actions button:hover,
.kb-shop__sidebar .wc-block-components-filter-submit-button:hover {
    background: var(--kb-orange-h) !important;
    border-color: var(--kb-orange-h) !important;
}

@media (max-width: 1024px) {
    .kb-shop__layout {
        grid-template-columns: 1fr;
        gap: 24px;
    }

    .kb-shop__sidebar {
        position: static;
        top: auto;
        padding: 18px 16px;
    }

    .kb-shop__sidebar-widgets {
        max-height: none;
        overflow: visible;
        padding-right: 0;
    }
}

/* Product grid in shop */
.kb-shop__products .products,
.kb-shop__products-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
    list-style: none;
    padding: 0;
    margin: 0;
    align-items: stretch;
}

/* Shop overview: aspect-ratio image crop — always covers, scales with column width */
.kb-shop__products-grid .kb-product-card__img-link {
    position: relative;
    display: block;
    width: 100% !important;
    aspect-ratio: 3 / 4;
    height: auto !important;
    min-height: unset !important;
    max-height: unset !important;
    overflow: hidden;
    padding: 0 !important;
}

.kb-shop__products-grid .kb-product-card {
    height: 100%;
}

.kb-shop__products-grid .kb-product-card__img,
.kb-shop__products-grid .kb-product-card .kb-product-card__img,
.kb-shop__products-grid .kb-product-card__img-link img {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    object-position: center center !important;
    padding: 0 !important;
    max-width: unset !important;
    max-height: unset !important;
}

.kb-shop__products-grid .kb-product-card:hover .kb-product-card__img {
    transform: none;
}

/* Override WC default product styling */
.kb-shop__products .products .product {
    margin: 0 !important;
    padding: 0 !important;
    float: none !important;
    width: 100% !important;
}

.kb-shop__no-products {
    grid-column: 1 / -1;
    text-align: center;
    color: var(--kb-text-muted);
    padding: 60px 0;
}

/* Pagination */
.kb-shop__pagination {
    grid-column: 1 / -1;
    padding-top: 32px;
}

.kb-shop__pagination .woocommerce-pagination,
.woocommerce nav.woocommerce-pagination {
    text-align: center;
}

.woocommerce nav.woocommerce-pagination ul {
    display: inline-flex;
    gap: 6px;
    border: none;
    list-style: none;
    padding: 0;
    margin: 0;
}

.woocommerce nav.woocommerce-pagination ul li {
    border: none;
    margin: 0;
    padding: 0;
}

.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span {
    display: flex;
    align-items: center;
    justify-content: center;
    min-width: 40px;
    height: 40px;
    padding: 0 12px;
    border-radius: var(--kb-radius);
    background: var(--kb-bg-mid);
    color: var(--kb-text);
    font-size: 0.85rem;
    border: 1px solid var(--kb-border);
    transition: background 0.2s, border-color 0.2s;
}

.woocommerce nav.woocommerce-pagination ul li a:hover {
    background: var(--kb-orange);
    border-color: var(--kb-orange);
    color: #fff;
}

.woocommerce nav.woocommerce-pagination ul li span.current {
    background: var(--kb-orange);
    border-color: var(--kb-orange);
    color: #fff;
}


/* ============================================
   TASK 13 — SINGLE PRODUCT PAGE
   ============================================ */

.kb-single { background: var(--kb-bg-mid); }

/* Two-column layout */
.kb-single__top {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 48px;
    padding: 48px 0;
    align-items: start;
}

/* Gallery — thumbs below the main image, scrollable */
.kb-single__gallery {
    position: relative;
    display: flex;
    flex-direction: column;
    gap: 12px;
    min-width: 0;
}

.kb-single__main-img {
    background: var(--kb-bg-mid);
    border-radius: var(--kb-radius);
    overflow: hidden;
    cursor: zoom-in;
    flex: 1;
    min-width: 0;
    aspect-ratio: 1024 / 1200;
    width: var(--kb-single-img-width-desktop, 100%);
    height: var(--kb-single-img-height-desktop, var(--kb-product-img-height, 520px));
    min-height: 0;
    max-height: var(--kb-single-img-height-desktop, var(--kb-product-img-height, 520px));
    max-width: 100%;
    margin: 0 auto;
    display: flex;
    align-items: center;
    justify-content: center;
}

.kb-single__photo,
.kb-single__main-img .kb-single__photo {
    width: 100% !important;
    height: 100% !important;
    object-fit: contain;
    object-position: center center;
    padding: 10px;
    display: block;
    transition: transform 0.4s ease;
}
.kb-single__main-img:hover .kb-single__photo {
    transform: none;
}

/* Thumbnail scroller wrapper */
.kb-single__thumbs-wrap {
    position: relative;
    display: flex;
    align-items: center;
    gap: 0;
    width: var(--kb-single-img-width-desktop, 100%);
    max-width: 100%;
    margin: 0 auto;
}
.kb-single__thumbs-wrap .kb-thumbs-arrow {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 2;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    border: none;
    background: var(--kb-orange);
    color: #fff;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 2px 8px rgba(0,0,0,0.25);
    opacity: 0;
    transition: opacity 0.25s;
    pointer-events: none;
}
.kb-single__thumbs-wrap:hover .kb-thumbs-arrow.kb-thumbs-arrow--visible {
    opacity: 1;
    pointer-events: auto;
}
.kb-thumbs-arrow:hover {
    background: var(--kb-orange-hover, #e07b20);
}
.kb-thumbs-arrow--left { left: -6px; }
.kb-thumbs-arrow--right { right: -6px; }
.kb-thumbs-arrow svg {
    width: 16px;
    height: 16px;
}

.kb-single__thumbs {
    display: flex;
    flex-direction: row;
    gap: 10px;
    width: 100%;
    min-width: 0;
    overflow-x: auto;
    overflow-y: hidden;
    padding: 4px 0 8px;
    scroll-behavior: smooth;
    -webkit-overflow-scrolling: touch;
    touch-action: pan-x;
    scroll-snap-type: x proximity;
    cursor: grab;
    scrollbar-width: none;          /* Firefox */
    -ms-overflow-style: none;       /* IE/Edge */
}
.kb-single__thumbs::-webkit-scrollbar {
    display: none;                  /* Chrome/Safari */
}

.kb-single__thumbs.kb-single__thumbs--dragging {
    cursor: grabbing;
    scroll-behavior: auto;
}

.kb-single__thumb {
    width: 72px;
    height: 72px;
    min-width: 72px;
    border-radius: var(--kb-radius);
    overflow: hidden;
    border: 2px solid transparent;
    background: var(--kb-bg-mid);
    cursor: pointer;
    padding: 0;
    transition: border-color 0.2s;
    flex-shrink: 0;
    scroll-snap-align: start;
}

.kb-single__thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.kb-single__thumb:hover,
.kb-single__thumb--active {
    border-color: var(--kb-orange);
}

/* Product info */
.kb-single__name {
    font-family: var(--kb-font-head);
    font-size: 1.75rem;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    color: var(--kb-text);
    margin-bottom: 12px;
    line-height: 1.2;
}

.kb-single__short-desc {
    color: rgba(255, 255, 255, 0.9);
    font-size: 1rem;
    line-height: 1.6;
    margin-bottom: 20px;
}

.kb-single__price {
    font-size: 1.75rem;
    font-weight: 700;
    color: var(--kb-orange);
    margin-bottom: 24px;
    display: flex;
    align-items: baseline;
    gap: 10px;
    padding: 16px 20px;
    background: var(--kb-bg-alt);
    border-left: 3px solid var(--kb-orange);
    border-radius: 0 var(--kb-radius) var(--kb-radius) 0;
}

.kb-single__price del {
    color: var(--kb-text-muted);
    font-size: 1rem;
}

.kb-single__price ins {
    text-decoration: none;
    color: var(--kb-yellow);
    font-size: 1.75rem;
}

.kb-single__vat {
    font-size: 0.8rem;
    color: rgba(255, 255, 255, 0.7);
    font-weight: 400;
}

/* WC add-to-cart form styling */
.kb-single__cart-form { overflow: hidden; }   /* clears internal WC floats */
.kb-single__cart-form .variations {
    width: 100%;
    margin-bottom: 20px;
}

.kb-single__cart-form .variations td,
.kb-single__cart-form .variations th {
    padding: 8px 0;
    border: none;
    background: transparent;
    color: var(--kb-text);
    vertical-align: middle;
}

/* 1. Labels: no all-caps, better spacing */
.kb-single__cart-form .variations .label label {
    color: var(--kb-text);
    font-weight: 600;
    font-size: 0.8rem;
    text-transform: none;
    letter-spacing: 0.05em;
    line-height: 1.5;
    margin-bottom: 4px;
    display: block;
}

/* 2–6. Select: bigger text, better contrast, styled dropdown arrow */
.kb-single__cart-form .variations select,
.kb-single__cart-form select {
    width: 100%;
    background: rgba(0, 0, 0, 0.25);
    border: 1px solid rgba(255, 255, 255, 0.15);
    border-radius: var(--kb-radius);
    color: var(--kb-text);
    padding: 12px 36px 12px 14px;
    font-size: 1rem;
    font-weight: 500;
    font-family: var(--kb-font-body);
    line-height: 1.5;
    appearance: none;
    -webkit-appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='none'%3E%3Cpath d='M1 1.5l5 5 5-5' stroke='%23ffffff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 14px center;
    box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.2);
}

.kb-single__cart-form .variations select:focus {
    outline: none;
    border-color: var(--kb-orange);
    box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.2), 0 0 0 2px rgba(255, 49, 8, 0.2);
}

.kb-single__cart-form .quantity input[type="number"] {
    background: rgba(0, 0, 0, 0.25);
    border: 1px solid rgba(255, 255, 255, 0.15);
    border-radius: var(--kb-radius);
    color: var(--kb-text);
    padding: 12px 14px;
    font-size: 1rem;
    font-weight: 500;
    width: 80px;
    text-align: center;
    font-family: var(--kb-font-body);
    line-height: 1.5;
    box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.2);
}

.kb-single__cart-form .quantity input[type="number"]:focus {
    outline: none;
    border-color: var(--kb-orange);
    box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.2), 0 0 0 2px rgba(255, 49, 8, 0.2);
}

/* "Order now" button override */
.kb-single__cart-form .single_add_to_cart_button,
.kb-single__cart-form button[type="submit"] {
    width: 100%;
    background: var(--kb-orange) !important;
    color: #fff !important;
    border: none;
    border-radius: var(--kb-radius);
    padding: 18px 24px;
    font-family: var(--kb-font-head);
    font-size: 1.2rem;
    text-transform: uppercase;
    letter-spacing: 1px;
    cursor: pointer;
    transition: background 0.2s, transform 0.15s, box-shadow 0.2s;
    margin-top: 12px;
    box-shadow: 0 4px 15px rgba(255, 49, 8, 0.3);
}

.kb-single__cart-form .single_add_to_cart_button:hover {
    background: var(--kb-orange-h) !important;
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(255, 49, 8, 0.4);
}
.kb-single__cart-form .single_add_to_cart_button:active {
    transform: translateY(0);
    box-shadow: 0 2px 10px rgba(255, 49, 8, 0.3);
}

/* Accordion (Specifications / Material) */
.kb-accordion {
    margin-top: 24px;
    border-top: 1px solid var(--kb-border);
}

.kb-accordion__item {
    border-bottom: 1px solid var(--kb-border);
}

.kb-accordion__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 0;
    cursor: pointer;
    font-family: var(--kb-font-head);
    font-size: 0.95rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    line-height: 1.4;
    color: var(--kb-text);
    list-style: none;
    user-select: none;
}

.kb-accordion__header::-webkit-details-marker { display: none; }

.kb-accordion__icon {
    width: 20px;
    height: 20px;
    position: relative;
    flex-shrink: 0;
}

.kb-accordion__icon::before,
.kb-accordion__icon::after {
    content: '';
    position: absolute;
    background: var(--kb-orange);
    transition: transform 0.2s;
}

.kb-accordion__icon::before {
    width: 14px;
    height: 2px;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

.kb-accordion__icon::after {
    width: 2px;
    height: 14px;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

.kb-accordion__item[open] .kb-accordion__icon::after {
    transform: translate(-50%, -50%) rotate(90deg);
    opacity: 0;
}

.kb-accordion__body {
    padding: 0 0 20px;
    color: rgba(255, 255, 255, 0.9);
    font-size: 0.95rem;
    line-height: 1.7;
}

.kb-specs-list {
    list-style: disc;
    padding-left: 20px;
}

.kb-specs-list li {
    padding: 4px 0;
    list-style: disc;
}

/* Product story (below fold) */
.kb-single__story {
    background: var(--kb-bg-mid);
    padding: 60px 0;
    border-top: 1px solid var(--kb-border);
}

.kb-single__story-cols {
    column-count: 2;
    column-gap: 48px;
    color: var(--kb-text);
    font-size: 1rem;
    line-height: 1.8;
}

.kb-single__story-cols h2,
.kb-single__story-cols h3 {
    font-family: var(--kb-font-head);
    text-transform: uppercase;
    color: var(--kb-text);
    margin-bottom: 16px;
    break-after: avoid;
}

.kb-single__story-cols p {
    margin-bottom: 20px;
    color: var(--kb-text-muted);
}

/* Related products */
.kb-single__related {
    background: var(--kb-bg-mid);
    padding: 60px 0;
}

.kb-single__related-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
}

/* Trust strip */
.kb-trust-strip {
    display: flex;
    gap: 20px;
    padding: 16px 0;
    margin: 20px 0 0;
    border-top: 1px solid var(--kb-border);
    border-bottom: 1px solid var(--kb-border);
}
.kb-trust-strip__item {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 0.82rem;
    color: rgba(255, 255, 255, 0.85);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    line-height: 1.4;
}
.kb-trust-strip__item svg {
    color: var(--kb-orange);
    flex-shrink: 0;
}

/* ============================================
   SCROLL REVEAL ANIMATION
   ============================================ */
@keyframes kb-fadeUp {
    from { opacity: 0; transform: translateY(24px); }
    to   { opacity: 1; transform: translateY(0); }
}

.kb-reveal {
    opacity: 0;
    transform: translateY(24px);
}
.kb-reveal--visible {
    animation: kb-fadeUp 0.5s ease forwards;
}
.kb-reveal:nth-child(2) { animation-delay: 0.08s; }
.kb-reveal:nth-child(3) { animation-delay: 0.16s; }
.kb-reveal:nth-child(4) { animation-delay: 0.24s; }
.kb-reveal:nth-child(5) { animation-delay: 0.32s; }
.kb-reveal:nth-child(6) { animation-delay: 0.40s; }

@media (prefers-reduced-motion: reduce) {
    .kb-reveal { opacity: 1; transform: none; }
    .kb-reveal--visible { animation: none; }
}


/* ============================================
   TASK 14 — INSPIRATION PAGE
   ============================================ */

.kb-inspiration { background: var(--kb-bg-mid); }

/* Hero */
.kb-inspiration__hero {
    position: relative;
    background: var(--kb-bg);
    min-height: 240px;
    overflow: hidden;
    display: flex;
    align-items: flex-end;
    isolation: isolate;
}
.kb-inspiration__hero-bg {
    position: absolute; inset: 0;
    background: linear-gradient(90deg, var(--kb-bg) 0%, var(--kb-bg) 40%, #5a1208 70%, #b51a08 100%);
    z-index: 0;
}
.kb-inspiration__hero-robot {
    position: absolute;
    right: -40px; top: 50%;
    transform: translateY(-50%);
    height: 140%;
    width: auto;
    opacity: 0.75;
    mix-blend-mode: screen;
    pointer-events: none;
    z-index: 1;
}
.kb-inspiration__hero-beam {
    position: absolute;
    bottom: 0; left: 0; right: 0;
    height: 6px;
    background: var(--kb-orange);
    box-shadow: 0 0 24px 4px rgba(255, 49, 8, 0.6);
    z-index: 3;
}
.kb-inspiration__hero-inner {
    position: relative;
    z-index: 2;
    padding: 40px 28px 32px;
    width: 100%;
}
.kb-inspiration__hero-title {
    font-family: var(--kb-font-head);
    font-size: clamp(36px, 6vw, 72px);
    letter-spacing: 0.04em;
    color: var(--kb-text);
    text-shadow: 2px 2px 0 rgba(0, 0, 0, 0.5);
    line-height: 1;
}

/* Main content area */
.kb-inspiration__main {
    background: var(--kb-bg-mid);
    padding: 40px 0 60px;
}

/* Card grid */
.kb-insp-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
    margin-bottom: 16px;
}

/* Card */
.kb-insp-card {
    position: relative;
    display: flex;
    align-items: stretch;
    background: #3a5060;
    border: 1px solid rgba(255, 255, 255, 0.06);
    border-radius: 4px;
    overflow: hidden;
    min-height: 120px;
    cursor: pointer;
    transition: background 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
}
.kb-insp-card:hover {
    background: #435e70;
    transform: translateY(-2px);
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.35);
}
.kb-insp-card:focus-visible {
    outline: 2px solid var(--kb-orange);
    outline-offset: 2px;
}
.kb-insp-card:active { transform: translateY(0); }
.kb-insp-card--faded {
    opacity: 0.28;
    filter: blur(0.5px);
    pointer-events: none;
    user-select: none;
    cursor: default;
}

/* Card art (left) */
.kb-insp-card__art {
    width: 120px;
    flex-shrink: 0;
    overflow: hidden;
    background: #2a3c4a;
    display: flex;
    align-items: center;
    justify-content: center;
}
.kb-insp-card__art img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.4s ease;
}
.kb-insp-card:hover .kb-insp-card__art img { transform: scale(1.05); }
.kb-insp-card__art-placeholder {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 10px;
    color: rgba(255, 255, 255, 0.25);
    font-family: monospace;
    text-align: center;
    padding: 8px;
    background: repeating-linear-gradient(45deg, #243040 0 8px, #2a3848 8px 16px);
}

/* Card body (right) */
.kb-insp-card__body {
    flex: 1;
    padding: 14px 16px 14px 14px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    position: relative;
}
.kb-insp-card__artist {
    font-family: var(--kb-font-head);
    font-size: 18px;
    letter-spacing: 0.02em;
    color: var(--kb-text);
    margin-bottom: 4px;
    line-height: 1.1;
}
.kb-insp-card__song {
    font-size: 13px;
    font-style: italic;
    color: rgba(255, 255, 255, 0.7);
    font-weight: 500;
}

/* Spotify icon — top-right */
.kb-insp-card__spotify {
    position: absolute;
    top: 10px; right: 12px;
    width: 22px; height: 22px;
    background: rgba(255, 255, 255, 0.12);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--kb-text);
    transition: background 0.15s;
}
.kb-insp-card__spotify:hover { background: #1DB954; }

/* Play button — bottom-right */
.kb-insp-card__play {
    position: absolute;
    bottom: 10px; right: 12px;
    width: 28px; height: 28px;
    background: rgba(255, 255, 255, 0.15);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--kb-text);
    border: none;
    cursor: pointer;
    transition: background 0.15s;
    flex-shrink: 0;
}
.kb-insp-card__play:hover { background: var(--kb-orange); }
.kb-insp-card__play svg { margin-left: 2px; }

/* Listen more — faded teaser row with overlay label */
.kb-insp-listen-more {
    position: relative;
    margin-top: 0;
}
.kb-insp-grid--faded { pointer-events: none; }
.kb-insp-listen-more__label {
    position: absolute;
    top: 50%; left: 50%;
    transform: translate(-50%, -50%);
    z-index: 10;
    font-family: var(--kb-font-body, 'Barlow', sans-serif);
    font-size: 18px;
    font-weight: 600;
    color: var(--kb-text);
    text-decoration: underline;
    text-underline-offset: 4px;
    white-space: nowrap;
    cursor: pointer;
    padding: 10px 18px;
    transition: color 0.2s ease, transform 0.2s ease;
}
.kb-insp-listen-more__label:hover {
    color: var(--kb-orange);
    transform: translate(-50%, -50%) scale(1.05);
}
.kb-insp-listen-more__label:focus-visible {
    outline: 2px solid var(--kb-orange);
    outline-offset: 4px;
    border-radius: 2px;
}
.kb-insp-listen-more__label[disabled] {
    background: none;
    border: none;
    cursor: not-allowed;
}

/* Spotify embed modal */
.kb-spotify-modal {
    display: none;
    position: fixed;
    inset: 0;
    z-index: 999;
    background: rgba(0, 0, 0, 0.75);
    align-items: center;
    justify-content: center;
}
.kb-spotify-modal.open {
    display: flex;
    animation: kbModalFade 0.18s ease-out;
}
@keyframes kbModalFade {
    from { opacity: 0; }
    to   { opacity: 1; }
}
.kb-spotify-modal__inner {
    background: #121212;
    border-radius: 12px;
    overflow: hidden auto;
    width: 420px;
    max-width: calc(100vw - 32px);
    max-height: calc(100vh - 32px);
    position: relative;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.6);
}
.kb-spotify-modal__close {
    position: absolute;
    top: 8px; right: 8px;
    width: 36px; height: 36px;
    background: rgba(255, 255, 255, 0.08);
    border: none;
    border-radius: 50%;
    color: var(--kb-text);
    font-size: 24px;
    cursor: pointer;
    z-index: 2;
    line-height: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background 0.15s ease;
}
.kb-spotify-modal__close:hover { background: rgba(255, 255, 255, 0.18); }
.kb-spotify-modal__close:focus-visible {
    outline: 2px solid var(--kb-orange);
    outline-offset: 2px;
}
.kb-spotify-modal__loading {
    padding: 32px 20px;
    text-align: center;
    color: rgba(255, 255, 255, 0.6);
    font-size: 13px;
    letter-spacing: 0.04em;
}
.kb-spotify-modal__info {
    padding: 20px 20px 12px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}
.kb-spotify-modal__artist {
    font-family: var(--kb-font-head);
    font-size: 20px;
    color: var(--kb-text);
    margin-bottom: 2px;
}
.kb-spotify-modal__song {
    font-size: 13px;
    font-style: italic;
    color: rgba(255, 255, 255, 0.6);
}
.kb-spotify-modal__embed { width: 100%; }
.kb-spotify-modal__embed iframe {
    display: block;
    width: 100%;
    border: 0;
}

/* Linked products inside modal */
.kb-spotify-modal__products:empty { display: none; }
.kb-spotify-modal__products {
    padding: 16px 20px 20px;
    border-top: 1px solid rgba(255, 255, 255, 0.08);
}
.kb-spotify-modal__products-title {
    font-family: var(--kb-font-head);
    font-size: 14px;
    letter-spacing: 0.06em;
    color: var(--kb-text);
    margin-bottom: 12px;
    text-transform: uppercase;
}
.kb-spotify-modal__products-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
}
.kb-spotify-modal__product {
    display: flex;
    flex-direction: column;
    background: #1d1d1d;
    border: 1px solid rgba(255, 255, 255, 0.06);
    border-radius: 6px;
    overflow: hidden;
    text-decoration: none;
    color: var(--kb-text);
    transition: border-color 0.15s, transform 0.15s;
}
.kb-spotify-modal__product:hover {
    border-color: var(--kb-orange);
    transform: translateY(-2px);
}
.kb-spotify-modal__product img,
.kb-spotify-modal__product-noimg {
    width: 100%;
    aspect-ratio: 1;
    object-fit: cover;
    display: block;
    background: #2a2a2a;
}
.kb-spotify-modal__product-meta {
    padding: 8px 10px 10px;
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.kb-spotify-modal__product-title {
    font-size: 12px;
    font-weight: 600;
    line-height: 1.3;
    color: var(--kb-text);
}
.kb-spotify-modal__product-price {
    font-size: 12px;
    color: var(--kb-orange);
    font-weight: 700;
}
.kb-spotify-modal__product-price .woocommerce-Price-amount {
    color: inherit;
}



/* ============================================
   TASK 15 — CART & CHECKOUT
   ============================================ */

/* Shared WC dark overrides */
.woocommerce,
.woocommerce-page {
    background: var(--kb-bg-mid);
    color: var(--kb-text);
}

/* Cart table */
.woocommerce table.shop_table {
    background: var(--kb-bg-mid);
    border: 1px solid var(--kb-border);
    border-radius: var(--kb-radius);
    border-collapse: separate;
    border-spacing: 0;
}

.woocommerce table.shop_table th {
    background: var(--kb-bg-mid);
    color: var(--kb-text);
    font-family: var(--kb-font-head);
    text-transform: uppercase;
    font-size: 0.85rem;
    padding: 14px 16px;
    border-bottom: 1px solid var(--kb-border);
}

.woocommerce table.shop_table td {
    background: var(--kb-bg-alt);
    color: var(--kb-text);
    padding: 14px 16px;
    border-top: 1px solid var(--kb-border);
    vertical-align: middle;
}

.woocommerce table.shop_table td.product-name a {
    color: var(--kb-orange);
    transition: color 0.2s;
}
.woocommerce table.shop_table td.product-name a:hover {
    color: var(--kb-orange-h);
}

.woocommerce table.shop_table td.product-remove a {
    color: var(--kb-text-muted) !important;
    font-size: 1.2rem;
}
.woocommerce table.shop_table td.product-remove a:hover {
    color: var(--kb-orange) !important;
}

/* Quantity input in cart */
.woocommerce .quantity .qty {
    background: var(--kb-bg-mid);
    border: 1px solid var(--kb-border);
    border-radius: var(--kb-radius);
    color: var(--kb-text);
    padding: 6px 10px;
    width: 60px;
    text-align: center;
    font-family: var(--kb-font-body);
}
.woocommerce .quantity .qty:focus {
    outline: none;
    border-color: var(--kb-orange);
}

/* Update cart button */
.woocommerce button[name="update_cart"],
.woocommerce input[name="update_cart"] {
    background: transparent !important;
    border: 2px solid var(--kb-orange) !important;
    color: var(--kb-orange) !important;
    border-radius: var(--kb-radius);
    padding: 10px 24px;
    font-family: var(--kb-font-head);
    text-transform: uppercase;
    cursor: pointer;
    transition: background 0.2s, color 0.2s;
}
.woocommerce button[name="update_cart"]:hover {
    background: var(--kb-orange) !important;
    color: #fff !important;
}

/* Cart totals */
.woocommerce .cart_totals,
.woocommerce-page .cart_totals {
    background: var(--kb-bg-mid);
    border-radius: var(--kb-radius);
    padding: 24px;
}

.woocommerce .cart_totals h2 {
    font-family: var(--kb-font-head);
    text-transform: uppercase;
    color: var(--kb-text);
    margin-bottom: 16px;
}

.woocommerce .cart_totals table {
    border: none;
}

.woocommerce .cart_totals th,
.woocommerce .cart_totals td {
    background: transparent;
    color: var(--kb-text);
    border-bottom: 1px solid var(--kb-border);
    padding: 12px 0;
}

.woocommerce .cart_totals .order-total td {
    color: var(--kb-orange);
    font-weight: 700;
    font-size: 1.2rem;
}

/* Proceed to checkout button */
.woocommerce .wc-proceed-to-checkout a.checkout-button,
.wc-proceed-to-checkout .checkout-button {
    background: var(--kb-orange) !important;
    color: #fff !important;
    border: none;
    border-radius: var(--kb-radius);
    font-family: var(--kb-font-head);
    font-size: 1.1rem;
    text-transform: uppercase;
    padding: 15px 24px;
    display: block;
    text-align: center;
    width: 100%;
    transition: background 0.2s;
}
.woocommerce .wc-proceed-to-checkout a.checkout-button:hover {
    background: var(--kb-orange-h) !important;
}

/* Checkout form fields */
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select,
.woocommerce-checkout #order_review input.input-text,
.woocommerce-checkout #order_review textarea,
.woocommerce-checkout #order_review select {
    background: #0a0e12;
    border: 1px solid var(--kb-border);
    border-radius: var(--kb-radius);
    color: var(--kb-text);
    padding: 10px 14px;
    font-size: 0.9rem;
    font-family: var(--kb-font-body);
    width: 100%;
}
.woocommerce form .form-row input.input-text::placeholder,
.woocommerce form .form-row textarea::placeholder {
    color: rgba(255, 255, 255, 0.32);
}
.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus,
.woocommerce form .form-row select:focus {
    outline: none;
    border-color: var(--kb-orange);
}

.woocommerce form .form-row label {
    color: var(--kb-text);
    font-size: 0.85rem;
}

/* Checkout section headings */
.woocommerce-checkout h3,
.woocommerce-checkout #order_review_heading {
    font-family: var(--kb-font-head);
    text-transform: uppercase;
    color: var(--kb-text);
}

/* Order review box */
.woocommerce-checkout #order_review,
.woocommerce-checkout #order_review_heading + #order_review {
    background: var(--kb-bg-about);
    border: 1px solid var(--kb-border);
    border-radius: var(--kb-radius);
    padding: 24px;
}

/* Payment methods */
.woocommerce #payment {
    background: var(--kb-bg-alt) !important;
    border-radius: var(--kb-radius);
}

.woocommerce #payment ul.payment_methods {
    list-style: none;
    padding: 16px;
    margin: 0;
    border-bottom: 1px solid var(--kb-border);
}

.woocommerce #payment ul.payment_methods li {
    padding: 8px 0;
    color: var(--kb-text);
}

.woocommerce #payment ul.payment_methods li label {
    color: var(--kb-text);
}

/* Custom orange radio */
.woocommerce #payment ul.payment_methods input[type="radio"] {
    accent-color: var(--kb-orange);
}

.woocommerce #payment div.payment_box {
    background: #0a0e12 !important;
    color: var(--kb-text-muted);
    border: 1px solid var(--kb-border);
    border-radius: var(--kb-radius);
}

/* Place order button */
.woocommerce #place_order,
.woocommerce-page #place_order {
    background: var(--kb-orange) !important;
    color: #fff !important;
    border: none;
    border-radius: var(--kb-radius);
    font-family: var(--kb-font-head);
    font-size: 1.1rem;
    text-transform: uppercase;
    padding: 15px 24px;
    width: 100%;
    cursor: pointer;
    transition: background 0.2s;
}
.woocommerce #place_order:hover {
    background: var(--kb-orange-h) !important;
}

/* Coupon field */
.woocommerce .coupon input[type="text"] {
    background: var(--kb-bg-mid);
    border: 1px solid var(--kb-border);
    border-radius: var(--kb-radius);
    color: var(--kb-text);
    padding: 10px 14px;
    font-family: var(--kb-font-body);
}
.woocommerce .coupon input[type="text"]:focus {
    outline: none;
    border-color: var(--kb-orange);
}

.woocommerce .coupon button,
.woocommerce .coupon input[type="submit"] {
    background: var(--kb-orange);
    color: #fff;
    border: none;
    border-radius: var(--kb-radius);
    padding: 10px 20px;
    cursor: pointer;
    transition: background 0.2s;
}
.woocommerce .coupon button:hover,
.woocommerce .coupon input[type="submit"]:hover {
    background: var(--kb-orange-h);
}

/* WC notices */
.woocommerce-message,
.woocommerce-info {
    background: var(--kb-bg-mid) !important;
    border-top-color: var(--kb-orange) !important;
    color: var(--kb-text);
}

.woocommerce-error {
    background: var(--kb-bg-mid) !important;
    border-top-color: #e74c3c !important;
    color: var(--kb-text);
}

.woocommerce-message a,
.woocommerce-info a {
    color: var(--kb-orange);
}


/* ============================================
   TASK 16 — MY ACCOUNT PAGE
   ============================================ */

.woocommerce-account .woocommerce {
    max-width: var(--kb-container);
    margin: 0 auto;
    padding: 48px 28px;
}

/* Account navigation tabs */
.woocommerce-MyAccount-navigation {
    float: left;
    width: 220px;
    margin-right: 36px;
}

.woocommerce-MyAccount-navigation ul {
    list-style: none;
    padding: 0;
    margin: 0;
    background: var(--kb-bg-mid);
    border-radius: var(--kb-radius);
    overflow: hidden;
}

.woocommerce-MyAccount-navigation ul li {
    border-bottom: 1px solid var(--kb-border);
}

.woocommerce-MyAccount-navigation ul li:last-child {
    border-bottom: none;
}

.woocommerce-MyAccount-navigation ul li a {
    display: block;
    padding: 14px 20px;
    color: var(--kb-text);
    font-size: 0.9rem;
    transition: background 0.2s, color 0.2s;
}

.woocommerce-MyAccount-navigation ul li a:hover {
    background: rgba(255,49,8,0.08);
    color: var(--kb-orange);
}

.woocommerce-MyAccount-navigation ul li.is-active a {
    background: var(--kb-orange);
    color: #fff;
}

/* Account content */
.woocommerce-MyAccount-content {
    overflow: hidden;
    color: var(--kb-text);
}

/* Orders table */
.woocommerce-MyAccount-content table.woocommerce-orders-table {
    background: var(--kb-bg-alt);
    border: 1px solid var(--kb-border);
    border-radius: var(--kb-radius);
    border-collapse: separate;
}

.woocommerce-MyAccount-content table th {
    background: var(--kb-bg-mid);
    color: var(--kb-text);
    font-family: var(--kb-font-head);
    text-transform: uppercase;
    font-size: 0.82rem;
    padding: 12px 16px;
}

.woocommerce-MyAccount-content table td {
    background: var(--kb-bg-alt);
    color: var(--kb-text);
    padding: 12px 16px;
    border-top: 1px solid var(--kb-border);
}

/* Order status badges */
.woocommerce-MyAccount-content .woocommerce-orders-table__cell-order-status {
    color: var(--kb-orange);
    font-weight: 600;
}

/* Address form */
.woocommerce-MyAccount-content .woocommerce-address-fields input,
.woocommerce-MyAccount-content .woocommerce-address-fields select {
    background: var(--kb-bg-mid);
    border: 1px solid var(--kb-border);
    border-radius: var(--kb-radius);
    color: var(--kb-text);
    padding: 10px 14px;
    font-family: var(--kb-font-body);
    width: 100%;
}

.woocommerce-MyAccount-content .woocommerce-address-fields input:focus,
.woocommerce-MyAccount-content .woocommerce-address-fields select:focus {
    outline: none;
    border-color: var(--kb-orange);
}

/* Buttons in account */
.woocommerce-MyAccount-content .woocommerce-Button,
.woocommerce-MyAccount-content .button {
    background: var(--kb-orange) !important;
    color: #fff !important;
    border: none;
    border-radius: var(--kb-radius);
    padding: 10px 20px;
    cursor: pointer;
    font-family: var(--kb-font-head);
    text-transform: uppercase;
    transition: background 0.2s;
}

.woocommerce-MyAccount-content .woocommerce-Button:hover,
.woocommerce-MyAccount-content .button:hover {
    background: var(--kb-orange-h) !important;
}

/* Logout link */
.woocommerce-MyAccount-navigation ul li.woocommerce-MyAccount-navigation-link--customer-logout a {
    color: var(--kb-text-muted);
}
.woocommerce-MyAccount-navigation ul li.woocommerce-MyAccount-navigation-link--customer-logout a:hover {
    color: var(--kb-orange);
}


/* ============================================
   TASK 17 — ABOUT, FAQ, CONTACT PAGES
   ============================================ */

/* Generic dark page wrapper */
.page .entry-content,
.page-template-default .entry-content {
    background: var(--kb-bg);
    color: var(--kb-text);
    max-width: var(--kb-container);
    margin: 0 auto;
    padding: 48px 28px;
    line-height: 1.8;
}

.page .entry-content h1,
.page .entry-content h2,
.page .entry-content h3 {
    font-family: var(--kb-font-head);
    text-transform: uppercase;
    color: var(--kb-text);
}

.page .entry-content h1 { font-size: var(--kb-size-section); margin-bottom: 24px; }
.page .entry-content h2 { font-size: 1.6rem; margin: 36px 0 16px; }
.page .entry-content h3 { font-size: 1.2rem; margin: 28px 0 12px; }

.page .entry-content p {
    color: var(--kb-text-muted);
    margin-bottom: 20px;
}

.page .entry-content a {
    color: var(--kb-orange);
    transition: color 0.2s;
}
.page .entry-content a:hover { color: var(--kb-orange-h); }

.page .entry-content img {
    border-radius: var(--kb-radius);
}

/* FAQ accordion — uses <details> / <summary> in WP editor */
.page .entry-content details {
    border-bottom: 1px solid var(--kb-border);
    margin-bottom: 0;
}

.page .entry-content details summary {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 18px 0;
    cursor: pointer;
    font-family: var(--kb-font-head);
    font-size: 1rem;
    text-transform: uppercase;
    color: var(--kb-text);
    list-style: none;
    user-select: none;
}

.page .entry-content details summary::-webkit-details-marker { display: none; }

.page .entry-content details summary::after {
    content: '+';
    font-size: 1.4rem;
    color: var(--kb-orange);
    font-weight: 700;
    flex-shrink: 0;
    transition: transform 0.2s;
}

.page .entry-content details[open] summary::after {
    content: '\2212';
}

.page .entry-content details > *:not(summary) {
    padding: 0 0 20px;
    color: var(--kb-text-muted);
    font-size: 0.9rem;
    line-height: 1.7;
}

/* Contact page — CF7 reuses footer form styles */
.page .entry-content .wpcf7 input[type="text"],
.page .entry-content .wpcf7 input[type="email"],
.page .entry-content .wpcf7 textarea {
    background: var(--kb-bg-mid);
    border: 1px solid var(--kb-border);
    border-radius: var(--kb-radius);
    color: var(--kb-text);
    padding: 10px 14px;
    font-size: 0.9rem;
    font-family: var(--kb-font-body);
    width: 100%;
    display: block;
    margin-bottom: 12px;
    transition: border-color 0.2s;
}

.page .entry-content .wpcf7 input:focus,
.page .entry-content .wpcf7 textarea:focus {
    outline: none;
    border-color: var(--kb-orange);
}

.page .entry-content .wpcf7 textarea {
    resize: vertical;
    min-height: 120px;
}

.page .entry-content .wpcf7 input[type="submit"] {
    background: var(--kb-orange);
    color: #fff;
    border: none;
    border-radius: var(--kb-radius);
    padding: 13px 30px;
    font-family: var(--kb-font-head);
    font-size: 1rem;
    text-transform: uppercase;
    cursor: pointer;
    transition: background 0.2s;
}

.page .entry-content .wpcf7 input[type="submit"]:hover {
    background: var(--kb-orange-h);
}

/* About page — photo + text layout */
.kb-page-about__layout {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 48px;
    align-items: center;
    margin: 32px 0;
}

@media (max-width: 768px) {
    .kb-page-about__layout { grid-template-columns: 1fr; gap: 24px; }
}

/* Global dark background for WP pages not using custom templates */
body.page,
body.woocommerce-page,
body.woocommerce-cart,
body.woocommerce-checkout,
body.woocommerce-account {
    background: var(--kb-bg);
    color: var(--kb-text);
}

/* Ensure Jupiter parent theme containers don't override */
body.page .mk-main-wrapper-holder,
body.page #theme-page,
body.page .mk-page-section-wrapper,
body.woocommerce-page .mk-main-wrapper-holder,
body.woocommerce-page #theme-page {
    background: var(--kb-bg) !important;
}

/* Full-bleed: kill Jupiter's max-width wrappers on homepage so kb sections
   span the entire viewport. Otherwise the parent theme reintroduces the
   "borders" left/right of the hero. */
body.home .mk-main-wrapper-holder,
body.home #theme-page,
body.home .mk-page-section-wrapper,
body.home .theme-page-wrapper,
body.home .master-holder,
body.home .master-holder-inner,
body.home #mk-page-id,
body.home .kb-main {
    max-width: none !important;
    width: 100% !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
}

/* Hero itself: edge-to-edge background, no inner gutter capping
   the robot or text content. */
.kb-hero { width: 100%; }
.kb-hero__inner { max-width: none !important; }

/* ============================================================
   CART PAGE
   ============================================================ */

.kb-cart {
    background: var(--kb-bg);
    min-height: 60vh;
    padding-bottom: 80px;
}

/* Two-column layout: items (flex) + fixed 350px summary */
.kb-cart__layout {
    display: grid;
    grid-template-columns: 1fr 350px;
    gap: 40px;
    padding: 48px 0;
    align-items: start;
}

/* ── Column headings ── */
.kb-cart__col-title {
    font-family: var(--kb-font-head);
    font-size: 1.6rem;
    text-transform: uppercase;
    color: var(--kb-text);
    margin-bottom: 24px;
    padding-bottom: 12px;
    position: relative;
}
.kb-cart__col-title::after {
    content: '';
    display: block;
    width: 48px;
    height: 3px;
    background: var(--kb-orange);
    position: absolute;
    bottom: 0;
    left: 0;
}

/* ── Cart item rows ── */
.kb-cart__item {
    display: grid;
    grid-template-columns: 80px 1fr auto auto auto 32px;
    gap: 16px;
    align-items: center;
    padding: 20px 0;
    border-bottom: 1px solid var(--kb-border);
}

.kb-cart__item-thumb {
    width: 80px;
    height: 80px;
    background: var(--kb-bg-alt);
    border-radius: var(--kb-radius);
    overflow: hidden;
    flex-shrink: 0;
}
.kb-cart__item-thumb img,
.kb-cart__thumb-img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    padding: 4px;
    display: block;
}

.kb-cart__item-name {
    color: var(--kb-text);
    font-weight: 600;
    font-size: 0.95rem;
    text-decoration: none;
    display: block;
    margin-bottom: 4px;
    transition: color 0.2s;
}
.kb-cart__item-name:hover { color: var(--kb-orange); }

.kb-cart__item-attrs {
    font-size: 0.8rem;
    color: var(--kb-text-muted);
    margin-top: 4px;
    line-height: 1.5;
}
.kb-cart__item-attrs p { margin: 0; }

.kb-cart__item-price {
    color: var(--kb-orange);
    font-size: 0.9rem;
    white-space: nowrap;
}

.kb-cart__item-subtotal {
    color: var(--kb-text);
    font-weight: 700;
    font-size: 0.95rem;
    white-space: nowrap;
}

.kb-cart__remove {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    color: var(--kb-text-muted);
    font-size: 1.3rem;
    border-radius: 50%;
    text-decoration: none;
    line-height: 1;
    transition: color 0.2s, background 0.2s;
}
.kb-cart__remove:hover {
    color: var(--kb-orange);
    background: rgba(255, 49, 8, 0.1);
}

/* ── Quantity +/- widget ── */
.kb-qty {
    display: flex;
    align-items: center;
    border: 1px solid var(--kb-border);
    border-radius: var(--kb-radius);
    overflow: hidden;
    width: 110px;
}

.kb-qty__btn {
    background: var(--kb-bg-mid);
    border: none;
    color: var(--kb-text);
    width: 32px;
    height: 38px;
    cursor: pointer;
    font-size: 1.1rem;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    transition: background 0.2s, color 0.2s;
}
.kb-qty__btn:hover {
    background: var(--kb-orange);
    color: #fff;
}

.kb-qty__input {
    background: var(--kb-bg-alt);
    border: none;
    border-left: 1px solid var(--kb-border);
    border-right: 1px solid var(--kb-border);
    color: var(--kb-text);
    font-family: var(--kb-font-body);
    font-size: 0.9rem;
    text-align: center;
    width: 46px;
    height: 38px;
    padding: 0;
    appearance: textfield;
    -moz-appearance: textfield;
}
.kb-qty__input::-webkit-outer-spin-button,
.kb-qty__input::-webkit-inner-spin-button { -webkit-appearance: none; }
.kb-qty__input:focus {
    outline: none;
    border-color: var(--kb-orange);
}

/* ── Button variants (ghost + outline) ── */
.kb-btn--ghost {
    background: transparent;
    color: var(--kb-text);
    border: 1px solid var(--kb-border);
    padding: 13px 24px;
    font-size: var(--kb-size-btn);
    border-radius: var(--kb-radius);
    text-decoration: none;
    display: inline-block;
    font-family: var(--kb-font-body);
    transition: border-color 0.2s, color 0.2s;
    cursor: pointer;
}
.kb-btn--ghost:hover {
    border-color: var(--kb-orange);
    color: var(--kb-orange);
}

.kb-btn--outline {
    background: transparent;
    color: var(--kb-orange);
    border: 1px solid var(--kb-orange);
    padding: 13px 24px;
    font-size: var(--kb-size-btn);
    border-radius: var(--kb-radius);
    text-decoration: none;
    display: inline-block;
    font-family: var(--kb-font-body);
    transition: background 0.2s, color 0.2s;
    cursor: pointer;
}
.kb-btn--outline:hover {
    background: var(--kb-orange);
    color: #fff;
}

/* ── Cart actions row ── */
.kb-cart__actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding-top: 24px;
    flex-wrap: wrap;
}

/* ── Coupon area ── */
.kb-cart__coupon {
    margin-top: 28px;
    padding-top: 24px;
    border-top: 1px solid var(--kb-border);
}

.kb-cart__coupon-form {
    display: flex;
    gap: 12px;
    align-items: center;
}

.kb-cart__coupon-input {
    background: var(--kb-bg-alt);
    border: 1px solid var(--kb-border);
    border-radius: var(--kb-radius);
    color: var(--kb-text);
    font-family: var(--kb-font-body);
    font-size: 0.9rem;
    padding: 10px 14px;
    flex: 1;
    min-width: 0;
    transition: border-color 0.2s;
}
.kb-cart__coupon-input::placeholder { color: var(--kb-text-muted); }
.kb-cart__coupon-input:focus {
    outline: none;
    border-color: var(--kb-orange);
}

.kb-cart__coupon-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 12px;
}

.kb-cart__coupon-applied {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: rgba(255, 201, 8, 0.1);
    border: 1px solid var(--kb-yellow);
    border-radius: var(--kb-radius);
    padding: 4px 10px;
    font-size: 0.82rem;
    color: var(--kb-yellow);
}
.kb-cart__coupon-remove {
    color: var(--kb-text-muted);
    text-decoration: none;
    font-size: 1rem;
    transition: color 0.2s;
    line-height: 1;
}
.kb-cart__coupon-remove:hover { color: var(--kb-orange); }

/* ── Order summary sidebar ── */
.kb-cart__summary {
    position: sticky;
    top: 100px;
}

.kb-cart__summary-inner {
    background: var(--kb-bg-mid);
    border: 1px solid var(--kb-border);
    border-radius: var(--kb-radius);
    padding: 28px;
}

.kb-cart__summary-lines {
    margin-bottom: 24px;
}

.kb-cart__summary-line {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    padding: 10px 0;
    font-size: 0.9rem;
    color: var(--kb-text-muted);
    border-bottom: 1px solid var(--kb-border);
}
.kb-cart__summary-line:last-child { border-bottom: none; }

.kb-cart__summary-line--discount {
    color: var(--kb-yellow);
}

.kb-cart__summary-divider {
    border: none;
    border-top: 1px solid var(--kb-border);
    margin: 4px 0;
}

.kb-cart__summary-line--total {
    padding-top: 16px;
    font-size: 1rem;
    font-weight: 700;
    color: var(--kb-text);
    border-bottom: none;
}

.kb-cart__total-price {
    font-family: var(--kb-font-head);
    font-size: 1.6rem;
    color: var(--kb-orange);
}

.kb-cart__free-ship {
    color: #4caf50;
    font-weight: 600;
}

.kb-cart__muted {
    color: var(--kb-text-muted);
    font-size: 0.82rem;
}

/* Full-width checkout CTA */
.kb-cart__checkout-btn {
    display: block;
    width: 100%;
    padding: 16px;
    text-align: center;
    font-family: var(--kb-font-head);
    font-size: 1.05rem;
    letter-spacing: 1px;
    box-sizing: border-box;
}

/* Security trust line */
.kb-cart__secure {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    margin-top: 14px;
    font-size: 0.78rem;
    color: var(--kb-text-muted);
    text-align: center;
}
.kb-cart__secure svg {
    color: var(--kb-orange);
    flex-shrink: 0;
}

/* ── Empty cart state ── */
.kb-cart__empty {
    text-align: center;
    padding: 80px 28px;
}

.kb-cart__empty-icon {
    display: block;
    margin: 0 auto 28px;
    color: var(--kb-text-muted);
    opacity: 0.5;
}

.kb-cart__empty-title {
    font-family: var(--kb-font-head);
    font-size: 2rem;
    text-transform: uppercase;
    color: var(--kb-text);
    margin-bottom: 12px;
}

.kb-cart__empty-sub {
    font-size: 1rem;
    color: var(--kb-text-muted);
    margin-bottom: 32px;
}

/* ── Recommended products section ── */
.kb-cart__recommended {
    padding: 72px 0;
    background: var(--kb-bg-alt);
    border-top: 1px solid var(--kb-border);
}

.kb-cart__rec-sub {
    text-align: center;
    color: var(--kb-text-muted);
    font-size: 0.9rem;
    margin-top: -28px;
    margin-bottom: 40px;
}

.kb-cart__rec-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 24px;
}

/* ── WooCommerce notice overrides inside cart ── */
.kb-cart .woocommerce-message,
.kb-cart .woocommerce-info,
.kb-cart .woocommerce-error {
    background: var(--kb-bg-alt);
    border-top: none;
    border-left: 4px solid var(--kb-orange);
    color: var(--kb-text);
    padding: 12px 16px;
    border-radius: var(--kb-radius);
    margin: 0 0 24px;
    font-size: 0.9rem;
    list-style: none;
}
.kb-cart .woocommerce-error {
    border-left-color: #e00;
}
.kb-cart .woocommerce-message::before,
.kb-cart .woocommerce-info::before,
.kb-cart .woocommerce-error::before {
    display: none;
}
.kb-cart .woocommerce-message a.button,
.kb-cart .woocommerce-info a.button {
    background: var(--kb-orange);
    color: #fff;
    padding: 6px 14px;
    border-radius: var(--kb-radius);
    font-size: 0.82rem;
    float: right;
    text-decoration: none;
    font-family: var(--kb-font-body);
    transition: background 0.2s;
}
.kb-cart .woocommerce-message a.button:hover,
.kb-cart .woocommerce-info a.button:hover {
    background: var(--kb-orange-h);
}

/* ── Responsive: Tablet ≤1024px ── */
@media (max-width: 1024px) {
    .kb-cart__layout {
        grid-template-columns: 1fr;
        gap: 32px;
    }
    .kb-cart__summary {
        position: static;
        top: auto;
    }
    .kb-cart__rec-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* ── Responsive: Mobile ≤768px ── */
@media (max-width: 768px) {
    .kb-cart__item {
        grid-template-columns: 64px 1fr 28px;
        grid-template-rows: auto auto auto auto;
        row-gap: 6px;
        column-gap: 12px;
        padding-right: 0;
    }
    .kb-cart__item-thumb   { grid-column: 1; grid-row: 1 / 3; align-self: start; width: 64px; height: 64px; }
    .kb-cart__item-details { grid-column: 2; grid-row: 1; }
    .kb-cart__item-price   { grid-column: 2; grid-row: 2; font-size: 0.85rem; }
    .kb-cart__item-qty     { grid-column: 1 / 3; grid-row: 3; }
    .kb-cart__item-subtotal { grid-column: 2; grid-row: 4; }
    .kb-cart__item-remove  { grid-column: 3; grid-row: 1; align-self: start; }

    .kb-cart__coupon-form {
        flex-direction: column;
        align-items: stretch;
    }
    .kb-cart__coupon-form .kb-btn { width: 100%; text-align: center; }

    .kb-cart__actions {
        flex-direction: column;
        align-items: stretch;
    }
    .kb-cart__actions .kb-btn {
        width: 100%;
        text-align: center;
        box-sizing: border-box;
    }
}

/* ── Responsive: Small mobile ≤480px ── */
@media (max-width: 480px) {
    .kb-cart__rec-grid {
        grid-template-columns: 1fr;
    }
    .kb-cart__summary-inner {
        padding: 20px 16px;
    }
    .kb-cart__col-title {
        font-size: 1.3rem;
    }
    .kb-cart__layout {
        padding: 28px 0;
    }
}


/* ============================================================
   RESPONSIVE REFINEMENTS — scaling, tablet behavior, 320px safety
   Loaded last so it wins the cascade where intended.
   ============================================================ */

/* ---- Fluid typography: section + hero + featured titles ---- */
.kb-section__title        { font-size: clamp(1.9rem, 4.6vw, var(--kb-size-section)); }
.kb-hero__title           { font-size: clamp(2.6rem, 8.2vw, var(--kb-size-hero)); }
.kb-single__name          { font-size: clamp(1.45rem, 3.5vw, 2rem); }

/* ---- 3D KB logo scales fluidly so it never outgrows the viewport ---- */
.kb-logo-3d__k,
.kb-logo-3d__b            { font-size: clamp(4rem, 12vw, 9rem); }
.kb-logo-3d__small        {
    font-size: clamp(1.4rem, 4vw, 2.6rem);
    padding-bottom: clamp(6px, 1.2vw, 14px);
}

/* ---- Safety: no element should force horizontal overflow ---- */
html, body        { overflow-x: hidden; }
img, svg, video   { max-width: 100%; }

/* ============================================
   TABLET ≤1024px — tightened
   ============================================ */
@media (max-width: 1024px) {
    /* Single product: drop to single column earlier so 2 cramped cols never happens */
    .kb-single__top           { grid-template-columns: 1fr; gap: 32px; }
    .kb-single__related-grid  { grid-template-columns: repeat(2, 1fr); }
    .kb-single__story-cols    { column-count: 1; column-gap: 0; }

    /* Checkout: side-by-side billing/shipping columns stack */
    .woocommerce-checkout .col2-set .col-1,
    .woocommerce-checkout .col2-set .col-2 { float: none; width: 100%; margin-bottom: 24px; }

    /* My Account: nav stacks above content instead of floating sidebar */
    .woocommerce-MyAccount-navigation { float: none; width: 100%; margin: 0 0 24px; }
    .woocommerce-MyAccount-content    { float: none; width: 100%; }
}

/* ============================================
   MOBILE ≤768px — tightened
   ============================================ */
@media (max-width: 768px) {
    /* Container padding a touch tighter — keeps cards breathable */
    .kb-container                 { padding: 0 20px; }

    /* Hero robot: pull further off-screen, reduce opacity to avoid covering text */
    .kb-hero__robot-wrap          { width: 75%; right: -32px; bottom: -4px; opacity: 0.15; }
    .kb-hero__robot-fade          {
        background:
            linear-gradient(to right, var(--kb-bg) 0%, rgba(13,16,18,0.94) 30%, rgba(13,16,18,0) 70%);
    }

    /* About: center-stack photo + 3D logo */
    .kb-about__inner              { gap: 36px; }
    .kb-about__right              { justify-content: center; }
    .kb-about__photo-wrap         { max-width: 220px; }
    .kb-logo-3d                   { align-items: center; }

    /* Section CTA buttons should fill on narrow screens for easier tapping */
    .kb-section__cta .kb-btn      { width: 100%; max-width: 360px; }

    /* Bestsellers already scrolls horizontally; nudge padding for thumb comfort */
    .kb-bestsellers__grid         { padding-bottom: 4px; }

    /* Shop: sidebar sits above grid, limit its height so it's not a giant wall */
    .kb-shop__sidebar             { max-height: 420px; overflow-y: auto; }
    .kb-shop__products-grid       { grid-template-columns: repeat(2, 1fr); gap: 16px; }

    /* Filter bar buttons — smaller on mobile, no wrap-related overflow */
    .kb-shop__filter-btn          { padding: 8px 14px; font-size: 0.78rem; }

    /* Pagination: avoid squished wrapping */
    .woocommerce nav.woocommerce-pagination ul { flex-wrap: wrap; justify-content: center; }

    /* Trust strip — stack vertically with divider rhythm */
    .kb-trust-strip               { flex-direction: column; gap: 10px; }

    /* Thumbnail strip on single product: smaller tiles */
    .kb-single__thumb             { width: 56px; height: 56px; min-width: 56px; }

    /* Cart summary: no sticky on mobile so it doesn't fight the soft keyboard */
    .kb-cart__summary             { position: static; top: auto; }
    .kb-cart__summary-inner       { padding: 20px; }

    /* FAQ / generic page entry content */
    .page .entry-content          { padding: 36px 20px; }
    .page .entry-content h1       { font-size: clamp(1.8rem, 6vw, var(--kb-size-section)); }

    /* About-page layout override */
    .kb-page-about__layout        { gap: 24px; }
}

/* ============================================
   SMALL MOBILE ≤480px — extras
   ============================================ */
@media (max-width: 480px) {
    .kb-container                 { padding: 0 14px; }

    /* Hero */
    .kb-hero                      { min-height: 360px; }
    .kb-hero__inner               { padding: 28px 14px 24px; }
    .kb-btn                       { padding: 11px 20px; font-size: 0.85rem; }

    /* About: tighter stacking */
    .kb-about__right              { flex-direction: column; gap: 28px; }

    /* Shop grid stays 2 columns on small phones for product overview */
    .kb-shop__products-grid       { grid-template-columns: repeat(2, 1fr); gap: 10px; }
    .kb-product-card__body        { padding: 12px; gap: 8px; }

    /* Single product thumbs — even smaller tiles */
    .kb-single__thumb             { width: 48px; height: 48px; min-width: 48px; }
    .kb-single__related-grid      { grid-template-columns: 1fr; }

    /* Cart summary total — keep on one line */
    .kb-cart__total-price         { font-size: 1.4rem; }
}

/* ============================================
   EMERGENCY ≤360px — nothing must overflow
   ============================================ */
@media (max-width: 360px) {
    .kb-container                 { padding: 0 12px; }

    .kb-hero__title               { font-size: clamp(2rem, 12vw, 2.6rem); }
    .kb-logo-3d__k,
    .kb-logo-3d__b                { font-size: 3.4rem; }

    /* Cart rows: collapse quantity widget to full row to prevent horizontal spill */
    .kb-cart__item                {
        grid-template-columns: 56px 1fr 24px;
        column-gap: 10px;
    }
    .kb-cart__item-thumb          { width: 56px; height: 56px; }
    .kb-qty                       { width: 100px; }
    .kb-qty__input                { width: 38px; }

    /* Bestsellers scroller cards: narrower min so 1 card fits cleanly */
    .kb-bestsellers__grid         { grid-auto-columns: minmax(200px, 220px); }

    /* Featured stage stays readable even on narrow screens */
    .kb-featured__stage-headline  { font-size: clamp(1.9rem, 13vw, 3rem); }
    .kb-featured__img-link        { width: 104px; height: 104px; top: -42px; }
    .kb-featured__card            { padding: 58px 14px 22px; }
}


/* ============================================================
   CHECKOUT PAGE
   ============================================================ */

.kb-checkout {
    background: var(--kb-bg);
    min-height: 60vh;
    padding-bottom: 80px;
}

/* ── Step indicator ── */
.kb-checkout__steps {
    background: var(--kb-bg-alt);
    border-bottom: 1px solid var(--kb-border);
    padding: 18px 0;
}

.kb-checkout__steps-list {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0;
    list-style: none;
    margin: 0;
    padding: 0;
}

.kb-checkout__step {
    display: flex;
    align-items: center;
    gap: 10px;
    color: var(--kb-text-muted);
    font-size: 0.85rem;
    font-family: var(--kb-font-head);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    position: relative;
    padding: 0 28px;
}

.kb-checkout__step + .kb-checkout__step::before {
    content: '';
    position: absolute;
    left: -16px;
    top: 50%;
    width: 32px;
    height: 1px;
    background: var(--kb-border);
    transform: translateY(-50%);
}

.kb-checkout__step-num {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: transparent;
    border: 1px solid var(--kb-border);
    color: var(--kb-text-muted);
    font-size: 0.82rem;
    flex-shrink: 0;
}

.kb-checkout__step--done .kb-checkout__step-num,
.kb-checkout__step--current .kb-checkout__step-num {
    background: var(--kb-orange);
    border-color: var(--kb-orange);
    color: #fff;
}

.kb-checkout__step--current,
.kb-checkout__step--done {
    color: var(--kb-text);
}

/* ── Layout: form left, summary right ── */
.kb-checkout__layout {
    display: grid;
    grid-template-columns: 1fr 380px;
    gap: 40px;
    padding: 48px 0;
    align-items: start;
}

/* ── Form sections ── */
.kb-checkout__section {
    background: var(--kb-bg-alt);
    border: 1px solid var(--kb-border);
    border-radius: var(--kb-radius);
    margin-bottom: 20px;
    overflow: hidden;
}

.kb-checkout__section-head {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 18px 24px;
    border-bottom: 1px solid var(--kb-border);
    background: var(--kb-bg-about);
}

.kb-checkout__section-num {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: transparent;
    border: 1px solid var(--kb-orange);
    color: var(--kb-orange);
    font-family: var(--kb-font-head);
    font-size: 0.9rem;
    flex-shrink: 0;
}

.kb-checkout__section-title {
    font-family: var(--kb-font-head);
    font-size: 1.05rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--kb-text);
    margin: 0;
}

.kb-checkout__section-body {
    padding: 24px;
}

/* ── WC form row tightening inside kb-checkout ── */
.kb-checkout .woocommerce-billing-fields__field-wrapper,
.kb-checkout .woocommerce-shipping-fields__field-wrapper {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px 16px;
}

.kb-checkout .form-row-wide,
.kb-checkout .form-row-first,
.kb-checkout .form-row-last {
    width: 100%;
    margin: 0;
}

.kb-checkout .form-row-wide { grid-column: 1 / -1; }

.kb-checkout .woocommerce-billing-fields h3,
.kb-checkout .woocommerce-shipping-fields h3,
.kb-checkout .woocommerce-additional-fields h3 {
    font-family: var(--kb-font-head);
    font-size: 1rem;
    text-transform: uppercase;
    color: var(--kb-text);
    margin: 0 0 16px;
    letter-spacing: 0.04em;
}

.kb-checkout .woocommerce-shipping-fields .shipping_address {
    margin-top: 16px;
}

.kb-checkout .woocommerce-additional-fields__field-wrapper {
    margin-top: 12px;
}

/* "Ship to a different address" toggle */
.kb-checkout #ship-to-different-address label {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: var(--kb-text);
    cursor: pointer;
    font-weight: 600;
    font-size: 0.9rem;
}

/* ── Right summary column ── */
.kb-checkout__summary {
    position: sticky;
    top: 100px;
}

.kb-checkout__summary-inner {
    background: var(--kb-bg-alt);
    border: 1px solid var(--kb-border);
    border-radius: var(--kb-radius);
    padding: 28px;
}

.kb-checkout__summary-title {
    font-family: var(--kb-font-head);
    font-size: 1.1rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--kb-text);
    margin: 0 0 16px;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--kb-border);
}

/* ── Order review table inside summary ── */
.kb-checkout__review table.shop_table {
    background: transparent !important;
    border: none !important;
    width: 100%;
}

.kb-checkout__review table.shop_table th,
.kb-checkout__review table.shop_table td {
    background: transparent !important;
    padding: 10px 0 !important;
    border-top: 1px solid var(--kb-border) !important;
    border-bottom: none !important;
    font-size: 0.88rem;
}

.kb-checkout__review table.shop_table thead th {
    font-family: var(--kb-font-head);
    text-transform: uppercase;
    font-size: 0.78rem;
    letter-spacing: 0.05em;
    color: var(--kb-text-muted) !important;
    border: none !important;
    padding: 0 0 10px !important;
}

.kb-checkout__review table.shop_table tfoot th {
    color: var(--kb-text-muted) !important;
    font-weight: 400;
}

.kb-checkout__review .order-total td,
.kb-checkout__review .order-total th {
    padding-top: 14px !important;
    border-top: 1px solid var(--kb-border) !important;
}

.kb-checkout__review .order-total td strong,
.kb-checkout__review .order-total td .amount {
    color: var(--kb-orange);
    font-family: var(--kb-font-head);
    font-size: 1.3rem;
}

/* Payment list inside summary */
.kb-checkout__review #payment {
    background: transparent !important;
    margin-top: 16px;
}

.kb-checkout__review #payment ul.payment_methods {
    border: none;
    padding: 0;
}

.kb-checkout__review #payment ul.payment_methods li {
    padding: 10px 12px;
    margin-bottom: 6px;
    background: var(--kb-bg-alt);
    border: 1px solid var(--kb-border);
    border-radius: var(--kb-radius);
    transition: border-color 0.2s;
}

.kb-checkout__review #payment ul.payment_methods li:has(input:checked) {
    border-color: var(--kb-orange);
}

.kb-checkout__review #payment div.payment_box {
    margin: 10px 0 0;
    padding: 12px;
    font-size: 0.85rem;
    line-height: 1.5;
}

.kb-checkout__review .form-row.place-order {
    margin-top: 18px;
    padding: 0;
}

/* Secure trust line */
.kb-checkout__secure {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    margin: 16px 0 0;
    font-size: 0.78rem;
    color: var(--kb-text-muted);
    text-align: center;
}
.kb-checkout__secure svg {
    color: var(--kb-orange);
    flex-shrink: 0;
}


/* ============================================================
   THANK YOU / ORDER CONFIRMATION PAGE
   ============================================================ */

.kb-thankyou {
    background: var(--kb-bg);
    min-height: 60vh;
    padding-bottom: 80px;
}

.kb-thankyou .kb-container { max-width: 820px; }

/* ── Hero ── */
.kb-thankyou__hero {
    text-align: center;
    padding: 64px 20px 48px;
    background: var(--kb-bg-alt);
    border: 1px solid var(--kb-border);
    border-radius: var(--kb-radius);
    margin-top: 40px;
}

.kb-thankyou__hero--failed {
    border-color: rgba(255, 49, 8, 0.4);
    background: rgba(255, 49, 8, 0.06);
}

.kb-thankyou__hero-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 88px;
    height: 88px;
    border-radius: 50%;
    background: rgba(255, 49, 8, 0.12);
    color: var(--kb-orange);
    margin-bottom: 20px;
}

.kb-thankyou__hero--failed .kb-thankyou__hero-icon {
    background: rgba(255, 49, 8, 0.18);
}

.kb-thankyou__eyebrow {
    font-family: var(--kb-font-body);
    font-size: 0.82rem;
    color: var(--kb-orange);
    text-transform: uppercase;
    letter-spacing: 2.5px;
    font-weight: 700;
    margin: 0 0 8px;
}

.kb-thankyou__title {
    font-family: var(--kb-font-head);
    font-size: clamp(2rem, 5vw, 3rem);
    text-transform: uppercase;
    letter-spacing: 0;
    line-height: 1.05;
    color: var(--kb-text);
    margin: 0 0 14px;
}

.kb-thankyou__sub {
    color: var(--kb-text-muted);
    font-size: 1rem;
    line-height: 1.65;
    max-width: 520px;
    margin: 0 auto 28px;
}

/* ── Meta grid ── */
.kb-thankyou__meta {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: 0;
    list-style: none;
    padding: 0;
    margin: 0 0 32px;
    border-top: 1px solid var(--kb-border);
    border-bottom: 1px solid var(--kb-border);
    background: rgba(0, 0, 0, 0.2);
    border-radius: var(--kb-radius);
    text-align: left;
}

.kb-thankyou__meta li {
    padding: 16px 20px;
    border-right: 1px solid var(--kb-border);
}

.kb-thankyou__meta li:last-child { border-right: none; }

.kb-thankyou__meta-label {
    display: block;
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    color: var(--kb-text-muted);
    margin-bottom: 4px;
}

.kb-thankyou__meta-value {
    display: block;
    font-family: var(--kb-font-head);
    font-size: 1.05rem;
    color: var(--kb-text);
    text-transform: uppercase;
}

/* ── Actions ── */
.kb-thankyou__actions {
    display: flex;
    gap: 12px;
    justify-content: center;
    flex-wrap: wrap;
}

/* ── Next steps ── */
.kb-thankyou__next {
    margin-top: 48px;
}

.kb-thankyou__next-title {
    font-family: var(--kb-font-head);
    font-size: 1.4rem;
    text-transform: uppercase;
    color: var(--kb-text);
    margin: 0 0 20px;
    text-align: center;
}

.kb-thankyou__next-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
}

.kb-thankyou__next-list li {
    background: var(--kb-bg-alt);
    border: 1px solid var(--kb-border);
    border-radius: var(--kb-radius);
    padding: 20px;
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.kb-thankyou__next-num {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: var(--kb-orange);
    color: #fff;
    font-family: var(--kb-font-head);
    font-size: 1rem;
}

.kb-thankyou__next-list strong {
    font-family: var(--kb-font-head);
    font-size: 0.95rem;
    text-transform: uppercase;
    color: var(--kb-text);
    display: block;
    margin-bottom: 4px;
}

.kb-thankyou__next-list p {
    color: var(--kb-text-muted);
    font-size: 0.88rem;
    line-height: 1.6;
    margin: 0;
}

/* ── Order details card ── */
.kb-thankyou__details {
    margin-top: 48px;
    background: var(--kb-bg-alt);
    border: 1px solid var(--kb-border);
    border-radius: var(--kb-radius);
    padding: 28px;
}

.kb-thankyou__details h2 {
    font-family: var(--kb-font-head);
    font-size: 1.2rem;
    text-transform: uppercase;
    color: var(--kb-text);
    margin: 0 0 16px;
}

.kb-thankyou__details .woocommerce-order-details,
.kb-thankyou__details .woocommerce-customer-details {
    margin-bottom: 24px;
}

.kb-thankyou__details table.shop_table {
    background: transparent !important;
    border: none !important;
}

.kb-thankyou__details table.shop_table th,
.kb-thankyou__details table.shop_table td {
    background: transparent !important;
    border-top: 1px solid var(--kb-border) !important;
    padding: 12px 0 !important;
}

/* ── Support strip ── */
.kb-thankyou__support {
    margin-top: 32px;
    padding: 24px;
    background: rgba(255, 49, 8, 0.06);
    border: 1px solid rgba(255, 49, 8, 0.2);
    border-radius: var(--kb-radius);
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 12px;
}

.kb-thankyou__support-text {
    color: var(--kb-text);
    margin: 0;
    font-size: 0.95rem;
}

/* ── Responsive: Checkout + Thankyou ── */
@media (max-width: 1024px) {
    .kb-checkout__layout {
        grid-template-columns: 1fr;
        gap: 32px;
    }
    .kb-checkout__summary {
        position: static;
        top: auto;
    }
}

@media (max-width: 768px) {
    .kb-checkout__steps-list            { gap: 0; }
    .kb-checkout__step                  { padding: 0 16px; font-size: 0.75rem; }
    .kb-checkout__step-label            { display: none; }
    .kb-checkout__step + .kb-checkout__step::before { left: -8px; width: 16px; }
    .kb-checkout__step--current .kb-checkout__step-label { display: inline; }

    .kb-checkout__layout                { padding: 32px 0; }
    .kb-checkout__section-head          { padding: 14px 18px; }
    .kb-checkout__section-body          { padding: 18px; }
    .kb-checkout__summary-inner         { padding: 20px; }

    .kb-checkout .woocommerce-billing-fields__field-wrapper,
    .kb-checkout .woocommerce-shipping-fields__field-wrapper {
        grid-template-columns: 1fr;
    }

    .kb-thankyou__hero                  { padding: 44px 18px 36px; }
    .kb-thankyou__meta                  { grid-template-columns: 1fr 1fr; }
    .kb-thankyou__meta li               { border-right: none; border-bottom: 1px solid var(--kb-border); }
    .kb-thankyou__meta li:nth-child(even) { border-right: none; }
    .kb-thankyou__meta li:last-child,
    .kb-thankyou__meta li:nth-last-child(2) { border-bottom: none; }

    .kb-thankyou__next-list             { grid-template-columns: 1fr; }
    .kb-thankyou__actions .kb-btn       { width: 100%; max-width: 320px; }
    .kb-thankyou__support               { flex-direction: column; align-items: stretch; text-align: center; }
    .kb-thankyou__support .kb-btn       { width: 100%; }
}

@media (max-width: 480px) {
    .kb-thankyou__meta                  { grid-template-columns: 1fr; }
    .kb-thankyou__meta li               { border-right: none; }
    .kb-thankyou__details               { padding: 18px; }
}

/* ============================================================
   CHECKOUT — payment block polish
   ============================================================ */

.kb-checkout .required,
.kb-checkout abbr.required {
    color: var(--kb-orange);
    border: none;
    text-decoration: none;
    margin-left: 2px;
}

.kb-checkout .form-row label {
    display: block;
    margin: 0 0 6px;
    font-size: 0.82rem;
    color: var(--kb-text);
    letter-spacing: 0.02em;
}

/* Invalid field ring */
.kb-checkout .form-row.woocommerce-invalid input.input-text,
.kb-checkout .form-row.woocommerce-invalid select,
.kb-checkout .form-row.woocommerce-invalid textarea {
    border-color: var(--kb-orange) !important;
    background: rgba(255, 49, 8, 0.05) !important;
    box-shadow: 0 0 0 3px rgba(255, 49, 8, 0.15);
}
.kb-checkout .form-row.woocommerce-validated input.input-text {
    border-color: rgba(255, 255, 255, 0.18);
}

/* Top error list */
.kb-checkout .woocommerce-error,
.kb-checkout .woocommerce-NoticeGroup-checkout .woocommerce-error {
    list-style: none;
    margin: 0 0 20px;
    padding: 14px 18px 14px 44px;
    background: rgba(255, 49, 8, 0.08) !important;
    border: 1px solid rgba(255, 49, 8, 0.35) !important;
    border-left: 3px solid var(--kb-orange) !important;
    border-radius: var(--kb-radius);
    color: var(--kb-text) !important;
    position: relative;
}
.kb-checkout .woocommerce-error::before {
    content: '!';
    position: absolute;
    left: 14px;
    top: 50%;
    transform: translateY(-50%);
    width: 20px;
    height: 20px;
    border-radius: 50%;
    background: var(--kb-orange);
    color: #fff;
    font-family: var(--kb-font-head);
    font-size: 0.85rem;
    display: flex;
    align-items: center;
    justify-content: center;
}
.kb-checkout .woocommerce-error li {
    margin: 4px 0 0;
    font-size: 0.88rem;
}
.kb-checkout .woocommerce-error li:first-child { margin-top: 0; }
.kb-checkout .woocommerce-error a {
    color: var(--kb-orange);
    text-decoration: underline;
}

/* Shipping methods list inside summary */
.kb-checkout__review #shipping_method {
    list-style: none;
    margin: 0 0 6px;
    padding: 0;
}
.kb-checkout__review #shipping_method li {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 12px;
    background: var(--kb-bg-alt);
    border: 1px solid var(--kb-border);
    border-radius: var(--kb-radius);
    margin-bottom: 6px;
    font-size: 0.88rem;
    color: var(--kb-text);
}
.kb-checkout__review #shipping_method li:has(input:checked) {
    border-color: var(--kb-orange);
}
.kb-checkout__review #shipping_method input[type="radio"] {
    accent-color: var(--kb-orange);
    margin: 0;
}
.kb-checkout__review #shipping_method label {
    margin: 0;
    flex: 1;
    cursor: pointer;
    color: var(--kb-text);
}
.kb-checkout__review .shipping td { padding-bottom: 8px !important; }

/* Payment methods — full-label clickable card */
.kb-checkout__review #payment ul.payment_methods { margin-top: 6px; }

.kb-checkout__review #payment ul.payment_methods li {
    padding: 0;
    position: relative;
    transition: border-color 0.18s ease, background-color 0.18s ease, box-shadow 0.18s ease;
}
.kb-checkout__review #payment ul.payment_methods li:hover {
    border-color: rgba(255, 49, 8, 0.5);
}
.kb-checkout__review #payment ul.payment_methods li:has(input:checked) {
    border-color: var(--kb-orange);
    background: rgba(255, 49, 8, 0.06);
    box-shadow: 0 0 0 1px var(--kb-orange) inset;
}

.kb-checkout__review #payment ul.payment_methods li label {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 14px 14px 14px 12px;
    margin: 0;
    cursor: pointer;
    font-size: 0.92rem;
    color: var(--kb-text);
    font-weight: 600;
    width: 100%;
}

.kb-checkout__review #payment ul.payment_methods input[type="radio"] {
    accent-color: var(--kb-orange);
    width: 18px;
    height: 18px;
    margin: 0;
    flex-shrink: 0;
}

/* Gateway logo (Mollie / Stripe / PayPal render <img> in label) */
.kb-checkout__review #payment ul.payment_methods li label img {
    height: 22px;
    width: auto;
    margin: 0 0 0 auto;
    max-width: 130px;
    object-fit: contain;
    background: #fff;
    padding: 2px 6px;
    border-radius: 3px;
}

/* Gateway description box (shown when method expands) */
.kb-checkout__review #payment div.payment_box {
    margin: 0 14px 14px;
    padding: 14px;
    background: rgba(0, 0, 0, 0.25) !important;
    color: var(--kb-text) !important;
    border: 1px solid var(--kb-border);
    border-radius: var(--kb-radius);
    position: relative;
}
.kb-checkout__review #payment div.payment_box::before {
    content: '';
    position: absolute;
    top: -6px;
    left: 22px;
    width: 12px;
    height: 12px;
    background: rgba(0, 0, 0, 0.25);
    border-left: 1px solid var(--kb-border);
    border-top: 1px solid var(--kb-border);
    transform: rotate(45deg);
}
.kb-checkout__review #payment div.payment_box p:last-child { margin-bottom: 0; }
.kb-checkout__review #payment div.payment_box input.input-text,
.kb-checkout__review #payment div.payment_box select {
    background: var(--kb-bg-mid) !important;
    border: 1px solid var(--kb-border) !important;
    color: var(--kb-text) !important;
}

/* T&C row */
.kb-checkout__review .woocommerce-terms-and-conditions-wrapper { margin: 14px 0; }
.kb-checkout__review .form-row.validate-required label {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    font-size: 0.85rem;
    color: var(--kb-text-muted);
    line-height: 1.5;
    cursor: pointer;
}
.kb-checkout__review .form-row.validate-required input[type="checkbox"] {
    accent-color: var(--kb-orange);
    margin-top: 3px;
    flex-shrink: 0;
}
.kb-checkout__review .woocommerce-terms-and-conditions-link {
    color: var(--kb-orange);
    text-decoration: underline;
}

/* Place Order — large, animated arrow */
.kb-checkout__review #place_order {
    width: 100%;
    padding: 18px 24px !important;
    font-size: 1.15rem !important;
    font-family: var(--kb-font-head) !important;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    border-radius: var(--kb-radius) !important;
    box-shadow: 0 8px 24px -10px rgba(255, 49, 8, 0.65);
    transition: background-color 0.2s ease, transform 0.15s ease, box-shadow 0.2s ease;
    position: relative;
}
.kb-checkout__review #place_order::after {
    content: '→';
    margin-left: 10px;
    display: inline-block;
    transition: transform 0.2s ease;
}
.kb-checkout__review #place_order:hover {
    transform: translateY(-1px);
    box-shadow: 0 10px 28px -8px rgba(255, 49, 8, 0.8);
}
.kb-checkout__review #place_order:hover::after { transform: translateX(4px); }
.kb-checkout__review #place_order:focus-visible {
    outline: 2px solid #fff;
    outline-offset: 2px;
}
.kb-checkout__review #place_order:disabled,
.kb-checkout__review #place_order.disabled {
    opacity: 0.6;
    cursor: not-allowed;
    transform: none;
    box-shadow: none;
}

/* AJAX loading overlay */
.kb-checkout .blockUI.blockOverlay,
.kb-checkout__review .blockUI.blockOverlay {
    background: rgba(0, 0, 0, 0.55) !important;
    opacity: 1 !important;
    border-radius: var(--kb-radius);
}
.kb-checkout .blockUI.blockOverlay::before,
.kb-checkout__review .blockUI.blockOverlay::before {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 32px;
    height: 32px;
    margin: -16px 0 0 -16px;
    border: 3px solid rgba(255, 255, 255, 0.2);
    border-top-color: var(--kb-orange);
    border-radius: 50%;
    animation: kb-spin 0.8s linear infinite;
}
@keyframes kb-spin { to { transform: rotate(360deg); } }


/* ============================================================
   THANKYOU — order details + bank transfer polish
   ============================================================ */

/* Hide WC's built-in "Order received" line — we render our own hero */
.kb-thankyou__details .woocommerce-thankyou-order-received,
.kb-thankyou__details > .woocommerce-order-overview {
    display: none;
}

.kb-thankyou__details .woocommerce-order-details__title,
.kb-thankyou__details .woocommerce-column__title,
.kb-thankyou__details h2,
.kb-thankyou__details h3 {
    font-family: var(--kb-font-head);
    text-transform: uppercase;
    color: var(--kb-text);
    letter-spacing: 0.04em;
    margin: 0 0 14px;
    font-size: 1.15rem;
    padding-bottom: 10px;
    border-bottom: 1px solid var(--kb-border);
}

.kb-thankyou__details table.shop_table .product-name {
    color: var(--kb-text);
    font-weight: 600;
}
.kb-thankyou__details table.shop_table .product-name a {
    color: var(--kb-text);
    text-decoration: none;
}
.kb-thankyou__details table.shop_table .product-name a:hover { color: var(--kb-orange); }
.kb-thankyou__details table.shop_table .product-quantity {
    color: var(--kb-text-muted);
    font-size: 0.88rem;
    margin-left: 4px;
}
.kb-thankyou__details table.shop_table td.product-total {
    color: var(--kb-text);
    text-align: right;
    white-space: nowrap;
}
.kb-thankyou__details table.shop_table .wc-item-meta {
    list-style: none;
    margin: 6px 0 0;
    padding: 0;
    font-size: 0.82rem;
    color: var(--kb-text-muted);
}
.kb-thankyou__details table.shop_table .wc-item-meta li {
    margin: 2px 0;
    padding: 0;
}
.kb-thankyou__details table.shop_table .wc-item-meta strong {
    color: var(--kb-text-muted);
    font-weight: 500;
    margin-right: 4px;
}

.kb-thankyou__details table.shop_table tfoot th,
.kb-thankyou__details table.shop_table tfoot td {
    color: var(--kb-text-muted);
    font-weight: 500;
    text-align: right;
}
.kb-thankyou__details table.shop_table tfoot tr:last-child th,
.kb-thankyou__details table.shop_table tfoot tr:last-child td {
    color: var(--kb-text);
    font-family: var(--kb-font-head);
    font-size: 1.1rem;
    padding-top: 16px !important;
    border-top: 2px solid var(--kb-orange) !important;
}
.kb-thankyou__details table.shop_table tfoot tr:last-child .amount {
    color: var(--kb-orange);
}

/* Customer details — two-column cards */
.kb-thankyou__details .woocommerce-customer-details {
    margin-top: 28px;
    padding-top: 24px;
    border-top: 1px solid var(--kb-border);
}
.kb-thankyou__details .woocommerce-customer-details .col2-set,
.kb-thankyou__details .woocommerce-customer-details .woocommerce-columns--addresses {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 24px;
    margin: 0;
}
.kb-thankyou__details .woocommerce-customer-details .col-1,
.kb-thankyou__details .woocommerce-customer-details .col-2,
.kb-thankyou__details .woocommerce-customer-details .woocommerce-column {
    width: 100%;
    float: none;
    padding: 18px;
    background: rgba(0, 0, 0, 0.25);
    border: 1px solid var(--kb-border);
    border-radius: var(--kb-radius);
}
.kb-thankyou__details .woocommerce-customer-details address {
    font-style: normal;
    color: var(--kb-text);
    line-height: 1.7;
    font-size: 0.92rem;
    border: none;
    padding: 0;
}
.kb-thankyou__details .woocommerce-customer-details .woocommerce-customer-details--phone,
.kb-thankyou__details .woocommerce-customer-details .woocommerce-customer-details--email {
    color: var(--kb-text-muted);
    font-size: 0.85rem;
    margin: 8px 0 0;
}

/* Bank transfer (BACS) callout */
.kb-thankyou .wc-bacs-bank-details-heading {
    font-family: var(--kb-font-head);
    text-transform: uppercase;
    color: var(--kb-text);
    margin: 32px 0 12px;
    font-size: 1.1rem;
}
.kb-thankyou .wc-bacs-bank-details {
    list-style: none;
    padding: 18px 20px;
    margin: 0 0 24px;
    background: rgba(255, 49, 8, 0.06);
    border: 1px solid rgba(255, 49, 8, 0.3);
    border-left: 3px solid var(--kb-orange);
    border-radius: var(--kb-radius);
    color: var(--kb-text);
}
.kb-thankyou .wc-bacs-bank-details li {
    padding: 6px 0;
    border-bottom: 1px dashed rgba(255, 255, 255, 0.08);
}
.kb-thankyou .wc-bacs-bank-details li:last-child { border-bottom: none; }
.kb-thankyou .wc-bacs-bank-details strong { color: var(--kb-orange); }

.kb-thankyou__hero--failed .kb-thankyou__title { color: var(--kb-text); }
.kb-thankyou__hero--failed .kb-thankyou__hero-icon { color: var(--kb-orange); }

@media (max-width: 768px) {
    .kb-thankyou__details .woocommerce-customer-details .col2-set,
    .kb-thankyou__details .woocommerce-customer-details .woocommerce-columns--addresses {
        grid-template-columns: 1fr;
    }
    .kb-checkout__review #place_order {
        padding: 16px 20px !important;
        font-size: 1.05rem !important;
    }
    .kb-checkout__review #payment ul.payment_methods li label {
        padding: 12px;
        font-size: 0.88rem;
    }
    .kb-checkout__review #payment ul.payment_methods li label img {
        height: 18px;
        max-width: 90px;
    }
}

/* ============================================================
   FEATURED — v2 ("Our new design") — Marco handoff design
   Split-panel: artwork left, dark content right. Full-bleed.
   ============================================================ */
.kb-featured.kb-featured--v2 {
    padding: 0;
    background: #000;
    border-top: none;
    border-bottom: none;
    overflow: visible;
    position: relative;
    z-index: 2;
}
.kb-featured--v2 .kb-featured__inner {
    display: grid;
    grid-template-columns: 55fr 45fr;
    gap: 0;
    border-radius: 0;
    min-height: 420px;
    align-items: stretch;
}
.kb-featured--v2 .kb-featured__img-panel {
    position: relative;
    overflow: visible;
    background: #000;
    min-height: 380px;
    display: flex;
    align-items: flex-end;
    justify-content: center;
    border-radius: 0;
}
.kb-featured--v2 .kb-featured__img-panel .kb-featured__photo {
    width: auto;
    height: calc(100% + 60px);
    max-height: 480px;
    display: block;
    object-fit: contain;
    margin-top: -60px;
    position: relative;
    z-index: 3;
    transition: transform 0.5s ease;
    filter: drop-shadow(0 8px 32px rgba(0,0,0,0.6));
}
.kb-featured--v2 .kb-featured__img-panel:hover .kb-featured__photo {
    transform: scale(1.03);
}
.kb-featured--v2 .kb-featured__img-placeholder {
    display: block;
    width: 60%;
    aspect-ratio: 1 / 1;
    margin: 40px auto 0;
    background:
        repeating-linear-gradient(135deg, rgba(255,255,255,0.05) 0 8px, transparent 8px 18px),
        rgba(255,255,255,0.04);
    border: 1px dashed rgba(255,255,255,0.18);
}

.kb-featured--v2 .kb-featured__content {
    padding: clamp(28px, 4vw, 52px);
    display: flex;
    flex-direction: column;
    justify-content: center;
    background: #000;
    color: var(--kb-text);
    gap: 0;
    border-left: 1px solid rgba(255,255,255,0.07);
    box-shadow: none;
    border-radius: 0;
}
.kb-featured--v2 .kb-featured__eyebrow {
    font-family: var(--kb-font-body);
    font-size: 14px;
    font-weight: 600;
    color: var(--kb-text);
    letter-spacing: 0;
    text-transform: none;
    margin: 0 0 8px;
    opacity: 0.9;
    text-align: left;
}
.kb-featured--v2 .kb-featured__title--v2 {
    font-family: var(--kb-font-body);
    font-size: clamp(16px, 1.6vw, 22px);
    font-weight: 700;
    color: var(--kb-text);
    margin: 0 0 16px;
    line-height: 1.2;
    letter-spacing: 0;
    text-transform: none;
}
.kb-featured--v2 .kb-featured__desc {
    font-family: var(--kb-font-body);
    font-size: clamp(13px, 1vw, 15px);
    color: rgba(255,255,255,0.75);
    line-height: 1.7;
    margin: 0 0 18px;
}
.kb-featured--v2 .kb-featured__spotify {
    display: flex;
    align-items: center;
    gap: 8px;
    font-family: var(--kb-font-body);
    font-size: 13px;
    color: rgba(255,255,255,0.6);
    font-style: italic;
    text-decoration: underline;
    text-underline-offset: 3px;
    margin: 0 0 28px;
    cursor: pointer;
}
.kb-featured--v2 a.kb-featured__spotify { color: rgba(255,255,255,0.6); }
.kb-featured--v2 a.kb-featured__spotify:hover { color: #1DB954; }
.kb-featured--v2 .kb-featured__spotify svg { flex-shrink: 0; }
.kb-featured--v2 .kb-featured__cta { align-self: flex-start; }

@media (max-width: 900px) {
    .kb-featured--v2 .kb-featured__inner { grid-template-columns: 1fr; }
    .kb-featured--v2 .kb-featured__img-panel {
        min-height: clamp(260px, 60vw, 380px);
        overflow: visible;
    }
    .kb-featured--v2 .kb-featured__content { border-left: none; border-top: 1px solid rgba(255,255,255,0.07); }
}

/* ============================================
   ABOUT PAGE  (page-about.php)
   Hero re-uses .kb-inspiration__hero styles.
   ============================================ */
.kb-about-page { background: var(--kb-bg-mid); color: var(--kb-text); }

.kb-about-page__hero { min-height: clamp(220px, 26vw, 320px); }

/* Intro: portrait + lead */
.kb-about-page__intro {
    background: var(--kb-bg-mid);
    padding: clamp(40px, 6vw, 80px) 0 clamp(32px, 4vw, 64px);
}
.kb-about-page__intro-grid {
    display: grid;
    grid-template-columns: minmax(280px, 1fr) 1.3fr;
    gap: clamp(28px, 5vw, 64px);
    align-items: center;
}
.kb-about-page__portrait-wrap {
    width: 100%;
    aspect-ratio: 3 / 4;
    background: var(--kb-bg-about);
    border-radius: 6px;
    overflow: hidden;
    position: relative;
    box-shadow: 0 18px 40px rgba(0, 0, 0, 0.35);
}
.kb-about-page__portrait {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.kb-about-page__portrait-placeholder {
    position: absolute; inset: 0;
    display: flex; align-items: center; justify-content: center;
    color: rgba(255, 255, 255, 0.25);
    background: repeating-linear-gradient(45deg, #1a2530 0 10px, #1e2c3a 10px 20px);
}
.kb-about-page__eyebrow {
    font-family: var(--kb-font-head);
    letter-spacing: 0.18em;
    text-transform: uppercase;
    font-size: 14px;
    color: var(--kb-orange);
    margin: 0 0 12px;
}
.kb-about-page__intro-title {
    font-family: var(--kb-font-head);
    font-size: clamp(40px, 6vw, 80px);
    line-height: 0.95;
    letter-spacing: 0.02em;
    color: var(--kb-text);
    margin: 0 0 20px;
    text-transform: uppercase;
}
.kb-about-page__lead {
    font-size: clamp(15px, 1.2vw, 18px);
    line-height: 1.75;
    color: rgba(255, 255, 255, 0.8);
    margin: 0 0 28px;
    max-width: 60ch;
}
.kb-about-page__intro-actions {
    display: flex;
    align-items: center;
    gap: 24px;
    flex-wrap: wrap;
}
.kb-about-page__link {
    color: var(--kb-text);
    font-weight: 600;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    font-size: 14px;
    transition: color 0.2s;
}
.kb-about-page__link:hover { color: var(--kb-orange); }

/* Story blocks — alternating rows */
.kb-about-page__story {
    background: var(--kb-bg);
    padding: clamp(48px, 7vw, 100px) 0;
}
.kb-about-page__block {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: clamp(28px, 5vw, 72px);
    align-items: center;
    padding: clamp(28px, 4vw, 56px) 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}
.kb-about-page__block:last-child { border-bottom: 0; }
.kb-about-page__block.is-reverse .kb-about-page__block-media { order: 2; }
.kb-about-page__block.is-reverse .kb-about-page__block-content { order: 1; }

.kb-about-page__block-media {
    aspect-ratio: 4 / 3;
    background: transparent;
    border-radius: 6px;
    overflow: visible;
    position: relative;
}
.kb-about-page__block-media img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    transition: transform 0.5s ease;
}
.kb-about-page__block:hover .kb-about-page__block-media img { transform: scale(1.03); }
.kb-about-page__block-placeholder {
    position: absolute; inset: 0;
    background: repeating-linear-gradient(45deg, #243040 0 10px, #2a3848 10px 20px);
}
.kb-about-page__block-index {
    font-family: var(--kb-font-head);
    color: var(--kb-orange);
    font-size: clamp(20px, 2vw, 24px);
    letter-spacing: 0.12em;
    margin: 0 0 12px;
}
.kb-about-page__block-title {
    font-family: var(--kb-font-head);
    font-size: clamp(28px, 3.4vw, 48px);
    line-height: 1.05;
    letter-spacing: 0.02em;
    color: var(--kb-text);
    margin: 0 0 16px;
    text-transform: uppercase;
}
.kb-about-page__block-body {
    font-size: clamp(14px, 1.1vw, 17px);
    line-height: 1.75;
    color: rgba(255, 255, 255, 0.72);
    margin: 0;
    max-width: 55ch;
}

/* Closing CTA */
.kb-about-page__cta {
    background: var(--kb-bg-alt);
    padding: clamp(56px, 7vw, 96px) 0;
    position: relative;
    overflow: hidden;
}
.kb-about-page__cta::before {
    content: "";
    position: absolute;
    left: 0; right: 0; top: 0;
    height: 4px;
    background: var(--kb-orange);
    box-shadow: 0 0 24px 4px rgba(255, 49, 8, 0.5);
}
.kb-about-page__cta-inner {
    text-align: center;
    max-width: 720px;
    margin: 0 auto;
}
.kb-about-page__cta-title {
    font-family: var(--kb-font-head);
    font-size: clamp(34px, 5vw, 64px);
    line-height: 1;
    letter-spacing: 0.03em;
    color: var(--kb-text);
    text-transform: uppercase;
    margin: 0 0 16px;
}
.kb-about-page__cta-sub {
    font-size: clamp(14px, 1.2vw, 18px);
    color: rgba(255, 255, 255, 0.7);
    margin: 0 0 32px;
}
.kb-about-page__cta-actions {
    display: flex;
    gap: 16px;
    justify-content: center;
    flex-wrap: wrap;
}

/* Responsive */
@media (max-width: 900px) {
    .kb-about-page__intro-grid { grid-template-columns: 1fr; }
    .kb-about-page__portrait-wrap { max-width: 420px; margin: 0 auto; }
    .kb-about-page__block { grid-template-columns: 1fr; }
    .kb-about-page__block.is-reverse .kb-about-page__block-media { order: 0; }
    .kb-about-page__block.is-reverse .kb-about-page__block-content { order: 0; }
}


/* ============================================================
   MOBILE EXPERIENCE — phase 2
   Shop filter slide-in · single-product swipe gallery ·
   denser cards · sticky cart/checkout action bars ·
   contextual bottombar hiding
   ============================================================ */

/* Defaults: hide mobile-only chrome on desktop */
.kb-shop__filter-fab,
.kb-shop__sidebar-head { display: none; }
.kb-single__dots { display: none; }

@media (max-width: 1024px) {
    /* ── Floating "Filters" FAB ── */
    .kb-shop__filter-fab {
        display: inline-flex;
        align-items: center;
        gap: 8px;
        position: fixed;
        bottom: calc(72px + env(safe-area-inset-bottom));
        right: 16px;
        z-index: 199;
        background: var(--kb-orange);
        color: #fff;
        border: none;
        border-radius: 999px;
        padding: 12px 18px;
        font-family: var(--kb-font-head);
        font-size: 0.95rem;
        text-transform: uppercase;
        letter-spacing: 0.05em;
        cursor: pointer;
        box-shadow: 0 8px 24px -4px rgba(255, 49, 8, 0.55), 0 2px 6px rgba(0, 0, 0, 0.3);
        transition: transform 0.2s ease, background 0.2s ease;
    }
    .kb-shop__filter-fab:hover,
    .kb-shop__filter-fab:active {
        background: var(--kb-orange-h);
        transform: translateY(-2px);
    }
    .kb-shop__filter-fab svg { flex-shrink: 0; }

    /* Sidebar becomes off-canvas slide-in panel */
    .kb-shop__sidebar {
        position: fixed;
        top: 0;
        right: 0;
        bottom: 0;
        width: min(360px, 88vw);
        max-height: 100dvh;
        background: var(--kb-bg-alt);
        border-left: 1px solid var(--kb-border);
        padding: 16px 20px calc(24px + env(safe-area-inset-bottom));
        overflow-y: auto;
        transform: translateX(100%);
        transition: transform 0.28s ease;
        z-index: 220;
        box-shadow: -12px 0 30px -10px rgba(0, 0, 0, 0.5);
        order: 0;
    }
    .kb-shop__sidebar.kb-shop__sidebar--open { transform: translateX(0); }

    .kb-shop__sidebar-head {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 12px;
        padding-bottom: 14px;
        margin-bottom: 14px;
        border-bottom: 1px solid var(--kb-border);
        position: sticky;
        top: 0;
        background: var(--kb-bg-alt);
        z-index: 1;
    }
    .kb-shop__sidebar-head .kb-shop__sidebar-title {
        margin: 0;
        font-family: var(--kb-font-head);
        font-size: 1.1rem;
        text-transform: uppercase;
        color: var(--kb-text);
    }
    .kb-shop__sidebar-close {
        background: none;
        border: none;
        color: var(--kb-text);
        padding: 8px;
        cursor: pointer;
        line-height: 0;
        border-radius: 50%;
        min-width: 44px;
        min-height: 44px;
        display: inline-flex;
        align-items: center;
        justify-content: center;
    }
    .kb-shop__sidebar-close:hover { background: rgba(255, 255, 255, 0.08); }

    /* Suppress the standalone page-title (head version replaces it) */
    .kb-shop__sidebar > .kb-shop__sidebar-title { display: none; }

    /* Backdrop */
    .kb-shop__sidebar-backdrop {
        position: fixed;
        inset: 0;
        background: rgba(0, 0, 0, 0.6);
        z-index: 210;
        opacity: 0;
        transition: opacity 0.25s ease;
    }
    .kb-shop__sidebar-backdrop.is-visible { opacity: 1; }
}

/* ── Single-product gallery: swipe + dot indicators ── */
@media (max-width: 768px) {
    .kb-single__main-img {
        touch-action: pan-y;
        cursor: grab;
        user-select: none;
    }
    .kb-single__main-img .kb-single__photo { pointer-events: none; }
    .kb-single__photo.is-swapping { opacity: 0.4; transition: opacity 0.05s; }

    .kb-single__dots {
        display: flex;
        justify-content: center;
        gap: 8px;
        margin: 12px 0 4px;
    }
    .kb-single__dot {
        width: 8px;
        height: 8px;
        padding: 0;
        border: none;
        border-radius: 50%;
        background: rgba(255, 255, 255, 0.25);
        cursor: pointer;
        transition: background 0.2s, transform 0.2s;
    }
    .kb-single__dot--active {
        background: var(--kb-orange);
        transform: scale(1.3);
    }

    /* Hide thumb strip on mobile — dots + swipe replace it */
    .kb-single__thumbs-wrap { display: none; }
}

/* ── Denser product cards (mobile) ── */
@media (max-width: 768px) {
    .kb-product-card__body { padding: 12px 12px 14px; gap: 8px; }
    .kb-product-card__title { font-size: 0.95rem; line-height: 1.25; }
    .kb-product-card__price { font-size: 0.95rem; }
    .kb-product-card__actions .kb-btn {
        font-size: 0.75rem;
        padding: 8px 10px;
    }
    .kb-shop__products-grid { gap: 12px; }
    .kb-shop__header { padding: 32px 0 16px; }
    .kb-shop__title { font-size: clamp(1.8rem, 8vw, 2.4rem); }
}

@media (max-width: 480px) {
    .kb-product-card__body { padding: 10px 10px 12px; }
    .kb-product-card__title { font-size: 0.88rem; }
    .kb-product-card__price { font-size: 0.88rem; }
    .kb-product-card__actions { flex-wrap: wrap; gap: 6px; }
    .kb-product-card__cart-icon { width: 100%; height: 38px; }
    .kb-shop__products-grid { gap: 10px; }
}

/* ── Cart: sticky summary action bar ── */
@media (max-width: 1024px) {
    .kb-cart__summary {
        position: sticky;
        bottom: calc(64px + env(safe-area-inset-bottom));
        z-index: 50;
        margin-top: 32px;
    }
    .kb-cart__summary-inner {
        box-shadow: 0 -8px 24px -10px rgba(0, 0, 0, 0.6);
    }
}

/* ── Checkout: hide mobilebar (Place Order lives in summary) ── */
@media (max-width: 768px) {
    body.woocommerce-checkout .kb-mobilebar,
    body.woocommerce-order-received .kb-mobilebar { display: none; }
    body.woocommerce-checkout,
    body.woocommerce-order-received { padding-bottom: 0; }

    .kb-checkout__summary {
        position: sticky;
        bottom: 0;
        z-index: 60;
    }
    .kb-checkout__summary-inner {
        box-shadow: 0 -8px 24px -10px rgba(0, 0, 0, 0.7);
    }
}

/* ── Tighter mobile padding for forms ── */
@media (max-width: 480px) {
    .kb-cart__layout { padding: 20px 0; }
    .kb-cart__summary-inner { padding: 18px 14px; }
    .kb-checkout__section-body { padding: 14px; }
    .kb-checkout__summary-inner { padding: 16px 14px; }
}

/* WC notices stay above bottombar on mobile */
@media (max-width: 768px) {
    .woocommerce-notices-wrapper {
        position: relative;
        z-index: 1;
    }
}


/* ============================================================
   MOBILE EXPERIENCE — phase 3
   My Account · Inspiration page · hero typography <360px ·
   footer · topbar safety · misc polish
   ============================================================ */

/* ── My Account: nav as horizontal pill scroller on mobile ── */
@media (max-width: 768px) {
    .woocommerce-account .woocommerce {
        display: flex;
        flex-direction: column;
        gap: 20px;
    }
    .woocommerce-MyAccount-navigation {
        float: none;
        width: 100%;
        margin: 0;
    }
    .woocommerce-MyAccount-navigation ul {
        display: flex;
        flex-wrap: nowrap;
        overflow-x: auto;
        scroll-snap-type: x proximity;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
        background: transparent;
        border-radius: 0;
        gap: 8px;
        padding: 2px 16px 8px;
        margin: 0 -16px;
    }
    .woocommerce-MyAccount-navigation ul::-webkit-scrollbar { display: none; }
    .woocommerce-MyAccount-navigation ul li {
        border: none;
        flex-shrink: 0;
        scroll-snap-align: start;
    }
    .woocommerce-MyAccount-navigation ul li a {
        display: inline-flex;
        align-items: center;
        gap: 6px;
        padding: 10px 16px;
        background: var(--kb-bg-mid);
        border: 1px solid var(--kb-border);
        border-radius: 999px;
        font-family: var(--kb-font-head);
        font-size: 0.82rem;
        text-transform: uppercase;
        letter-spacing: 0.04em;
        color: var(--kb-text);
        white-space: nowrap;
        min-height: 44px;
    }
    .woocommerce-MyAccount-navigation ul li.is-active a {
        background: var(--kb-orange);
        border-color: var(--kb-orange);
        color: #fff;
    }
    .woocommerce-MyAccount-content { float: none; width: 100%; }

    /* Orders table → card list */
    .woocommerce-MyAccount-content table.woocommerce-orders-table,
    .woocommerce-MyAccount-content table.woocommerce-orders-table thead,
    .woocommerce-MyAccount-content table.woocommerce-orders-table tbody,
    .woocommerce-MyAccount-content table.woocommerce-orders-table tr,
    .woocommerce-MyAccount-content table.woocommerce-orders-table td,
    .woocommerce-MyAccount-content table.woocommerce-orders-table th {
        display: block;
        width: 100%;
    }
    .woocommerce-MyAccount-content table.woocommerce-orders-table thead { display: none; }
    .woocommerce-MyAccount-content table.woocommerce-orders-table tr {
        background: var(--kb-bg-alt);
        border: 1px solid var(--kb-border);
        border-radius: var(--kb-radius);
        padding: 14px;
        margin-bottom: 12px;
    }
    .woocommerce-MyAccount-content table.woocommerce-orders-table td {
        padding: 6px 0 !important;
        border: none !important;
        display: flex;
        justify-content: space-between;
        gap: 12px;
        text-align: right;
        background: transparent;
    }
    .woocommerce-MyAccount-content table.woocommerce-orders-table td::before {
        content: attr(data-title);
        font-family: var(--kb-font-head);
        text-transform: uppercase;
        font-size: 0.72rem;
        letter-spacing: 0.06em;
        color: var(--kb-text-muted);
        text-align: left;
    }
    .woocommerce-MyAccount-content table.woocommerce-orders-table td.order-actions {
        flex-direction: column;
        align-items: stretch;
        gap: 6px;
        margin-top: 4px;
        padding-top: 12px !important;
        border-top: 1px solid var(--kb-border) !important;
    }
    .woocommerce-MyAccount-content table.woocommerce-orders-table td.order-actions .button {
        width: 100%;
        text-align: center;
    }
}

/* ── Inspiration page: card grid + hero on small screens ── */
@media (max-width: 768px) {
    .kb-inspiration__hero { padding: 48px 0 32px; }
    .kb-inspiration__hero-inner { padding: 0 16px; }
    .kb-inspiration__hero-robot { display: none; }
    .kb-inspiration__hero-beam { display: none; }
    .kb-inspiration__main { padding: 32px 0 64px; }
    .kb-insp-grid { gap: 12px; }
    .kb-insp-card__body { padding: 12px; }
    .kb-insp-card__artist { font-size: 0.95rem; }
    .kb-insp-card__song { font-size: 0.82rem; }
}

@media (max-width: 480px) {
    .kb-insp-grid { grid-template-columns: 1fr; gap: 14px; }
    .kb-inspiration__hero-title { font-size: clamp(2rem, 11vw, 2.8rem); }
}

/* ── Homepage hero — small phone (<360px) safety net ── */
@media (max-width: 360px) {
    .kb-hero__inner { padding: 24px 12px 16px; }
    .kb-hero__title { font-size: clamp(1.7rem, 13vw, 2.2rem); line-height: 1.05; margin-bottom: 16px; }
    .kb-hero__content p { font-size: 0.85rem; line-height: 1.55; }
    .kb-hero__robot-wrap { width: 78%; opacity: 0.12; }
    .kb-hero .kb-btn { padding: 12px 18px; font-size: 0.85rem; }
    .kb-section__title { font-size: 1.6rem; margin-bottom: 20px; }
    .kb-container { padding-left: 12px; padding-right: 12px; }
    .kb-product-card__title { font-size: 0.82rem; }
    .kb-product-card__price { font-size: 0.82rem; }
    .kb-mobilebar__item { font-size: 0.62rem; padding: 8px 4px; }
    .kb-mobilebar__item svg { width: 20px; height: 20px; }
}

/* ── Footer mobile polish ── */
@media (max-width: 768px) {
    .kb-footer { text-align: center; }
    .kb-footer__col { align-items: center; }
    .kb-footer__logo { margin-left: auto; margin-right: auto; }
    .kb-footer__payment { justify-content: center; }
    .kb-footer__form { width: 100%; max-width: 360px; margin: 0 auto; }
    .kb-footer__bottom {
        flex-direction: column;
        gap: 10px;
        text-align: center;
        font-size: 0.78rem;
    }
}

/* ── Page hero / breadcrumbs: tighter on mobile so it doesn't dominate ── */
@media (max-width: 768px) {
    .kb-shop__filter-bar { padding: 10px 0; }
    .kb-shop__filter-bar .kb-container {
        display: flex;
        overflow-x: auto;
        gap: 8px;
        scrollbar-width: none;
        -webkit-overflow-scrolling: touch;
        padding-bottom: 4px;
    }
    .kb-shop__filter-bar .kb-container::-webkit-scrollbar { display: none; }
    .kb-shop__filters {
        flex-wrap: nowrap;
        flex-shrink: 0;
    }
    .kb-shop__filter-btn {
        white-space: nowrap;
        flex-shrink: 0;
        min-height: 40px;
    }
}

/* ── Disable hover scaling on touch devices (avoids sticky :hover states) ── */
@media (hover: none) {
    .kb-product-card:hover { transform: none; }
    .kb-product-card:hover .kb-product-card__img { transform: none; }
    .kb-cat-card:hover { transform: none; }
    .kb-insp-card:hover { transform: none; }
    .kb-btn:hover { transform: none; }
}

/* ── Honor reduced-motion ── */
@media (prefers-reduced-motion: reduce) {
    .kb-nav,
    .kb-shop__sidebar,
    .kb-shop__sidebar-backdrop,
    .kb-product-card,
    .kb-product-card__img,
    .kb-single__photo,
    .kb-single__dot,
    .kb-shop__filter-fab,
    .kb-checkout__review #place_order,
    .kb-checkout__review #place_order::after {
        transition: none !important;
        animation: none !important;
    }
}

/* ── Header logo sizing fine-tune on very small screens ── */
@media (max-width: 480px) {
    .kb-header__inner { height: 60px; padding: 0 12px; }
    .kb-header__logo-img { height: 44px; max-height: 44px; transform: none; }
    .kb-header__logo { margin-right: 36px; }
}

/* ── Skip-to-content link a11y (helps screen readers and mobile keyboard nav) ── */
.kb-skip-link {
    position: absolute;
    left: -9999px;
    top: 8px;
    background: var(--kb-orange);
    color: #fff;
    padding: 10px 16px;
    border-radius: var(--kb-radius);
    z-index: 1000;
    font-family: var(--kb-font-head);
    text-transform: uppercase;
    font-size: 0.85rem;
}
.kb-skip-link:focus { left: 8px; }

/* Hide default WooCommerce tabs — EasyAccordion shortcode replaces them on the single product template. */
.woocommerce-tabs { display: none; }
