/* =========================================================================
   SBC Modern Store — main stylesheet
   White background • SBC logo blues + orange accents • mobile-first
   Brand palette sampled directly from the SBC logo (cropped-Group-17.png):
     navy #14176b · royal blue #0a52a8 · sky #0a9bdc · orange #f07800
   All accent colours are CSS variables and are overridable from the
   Customizer (see inc/customizer.php) via inline :root output.
   ========================================================================= */

/* ----------------------------------------------------------------- Tokens */
:root{
  /* Brand (defaults — Customizer overrides these at runtime) */
  --sbc-navy:#14176b;
  --sbc-blue:#0a52a8;
  --sbc-blue-600:#0a4794;
  --sbc-sky:#0a9bdc;
  --sbc-orange:#f07800;
  --sbc-orange-600:#e95d2a;

  /* Surfaces — bright commercial marketplace (Electro/SwiftCart style) */
  --sbc-bg:#ffffff;
  --sbc-card:#ffffff;
  --sbc-bg-soft:#f4f6f9;     /* light grey panels */
  --sbc-bg-tint:#eaf1fb;     /* pale blue tint */
  --sbc-line:#e7eaf0;        /* hairline borders */
  --sbc-deal:#e23b3b;        /* deal / sale red */
  --sbc-yellow:#ffc833;      /* marketplace highlight (department btn) */

  /* Ink */
  --sbc-ink:#1c2533;         /* primary text */
  --sbc-ink-soft:#5d6b7e;    /* secondary text */
  --sbc-ink-faint:#90a0b3;

  /* Feedback */
  --sbc-sale:#e23b3b;
  --sbc-success:#1a9d57;

  /* Gradients derived from the logo squircle */
  --sbc-grad:linear-gradient(135deg,var(--sbc-sky) 0%,var(--sbc-blue) 48%,var(--sbc-navy) 100%);
  --sbc-grad-soft:linear-gradient(135deg,#eef4fd 0%,#eaf0fb 100%);

  /* Shape & depth — premium minimal: soft, neutral, low-contrast shadows */
  --sbc-radius:16px;
  --sbc-radius-sm:12px;
  --sbc-radius-lg:24px;
  --sbc-shadow-sm:0 1px 2px rgba(16,32,44,.04);
  --sbc-shadow:0 8px 30px rgba(16,32,44,.06);
  --sbc-shadow-lg:0 24px 70px rgba(16,32,44,.10);

  /* Layout — airier */
  --sbc-max:1440px;
  --sbc-gap:clamp(18px,2.4vw,30px);
  --sbc-header-h:118px;

  --sbc-font:'Inter',system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --sbc-font-head:'Plus Jakarta Sans','Inter',system-ui,sans-serif;

  --sbc-ease:cubic-bezier(.22,.61,.36,1);

  /* cart glyph used as a CSS mask for the compact icon-only add-to-cart button */
  --sbc-cart-ico:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='9' cy='21' r='1.6'/%3E%3Ccircle cx='18' cy='21' r='1.6'/%3E%3Cpath d='M2 3h3l2.4 13.2A2 2 0 0 0 9.4 18h8.5a2 2 0 0 0 2-1.6L21.5 7H6'/%3E%3C/svg%3E");
}

/* ------------------------------------------------------------------ Reset */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;background:var(--sbc-bg);color:var(--sbc-ink);
  font-family:var(--sbc-font);font-size:16px;line-height:1.6;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
}
h1,h2,h3,h4,h5{font-family:var(--sbc-font-head);line-height:1.15;margin:0 0 .5em;color:var(--sbc-navy);font-weight:700;letter-spacing:-.01em}
h1{font-size:clamp(2rem,4.4vw,3.2rem);font-weight:800}
h2{font-size:clamp(1.5rem,3vw,2.1rem);font-weight:700}
h3{font-size:clamp(1.1rem,1.6vw,1.3rem);font-weight:700}
p{margin:0 0 1rem}
a{color:var(--sbc-blue);text-decoration:none;transition:color .2s var(--sbc-ease)}
a:hover{color:var(--sbc-orange-600)}
img{max-width:100%;height:auto;display:block}
ul{margin:0;padding:0;list-style:none}

/* Global icon sizing — every sbc_icon() SVG gets a sane default so it never
   balloons to the SVG intrinsic size. Context rules below override as needed. */
.sbc-ico{width:1.2em;height:1.2em;flex:0 0 auto;display:inline-block;vertical-align:middle}
button{font-family:inherit}
:focus-visible{outline:3px solid var(--sbc-sky);outline-offset:2px;border-radius:4px}

/* ---------------------------------------------------------------- Layout */
.sbc-container{width:100%;max-width:var(--sbc-max);margin-inline:auto;padding-inline:clamp(16px,4vw,32px)}
.sbc-section{padding-block:clamp(40px,5vw,72px)}
.sbc-section--tint{background:var(--sbc-bg-soft)}
/* editorial header: eyebrow + heading on the left, optional action on the right,
   a hairline rule beneath spanning the section width */
.sbc-section-head{text-align:left;max-width:none;margin:0 0 clamp(30px,3.6vw,48px);
  display:grid;grid-template-columns:1fr auto;align-items:end;gap:8px 24px;
  border-bottom:1px solid var(--sbc-line);padding-bottom:clamp(18px,2vw,26px)}
.sbc-section-head h2{grid-column:1;margin:0}
.sbc-section-head .sbc-eyebrow{grid-column:1}
.sbc-section-head p{grid-column:1;color:var(--sbc-ink-soft);margin:.5rem 0 0;font-size:1.05rem;max-width:60ch}
.sbc-section-head__action{grid-column:2;grid-row:1/3;align-self:center;white-space:nowrap}
.sbc-eyebrow{display:inline-block;font-family:var(--sbc-font-head);font-weight:600;font-size:.72rem;
  letter-spacing:.2em;text-transform:uppercase;color:var(--sbc-ink-faint);margin-bottom:.7rem}
.sbc-divider{display:none}
@media (max-width:640px){.sbc-section-head{grid-template-columns:1fr}.sbc-section-head__action{grid-column:1;grid-row:auto;align-self:start;margin-top:8px}}
.skip-link{position:absolute;left:-999px;top:0;background:var(--sbc-navy);color:#fff;padding:10px 16px;z-index:1000;border-radius:0 0 8px 0}
.skip-link:focus{left:0;color:#fff}
.screen-reader-text{position:absolute!important;width:1px;height:1px;overflow:hidden;clip:rect(1px,1px,1px,1px);white-space:nowrap}

/* --------------------------------------------------------------- Buttons */
.sbc-btn{
  --b:var(--sbc-navy);--bh:#0d0f4d;
  display:inline-flex;align-items:center;gap:.5em;justify-content:center;
  font-family:var(--sbc-font);font-weight:600;font-size:.95rem;line-height:1;letter-spacing:-.005em;
  padding:1em 1.7em;border-radius:999px;border:1px solid transparent;cursor:pointer;
  background:var(--b);color:#fff;transition:transform .25s var(--sbc-ease),background .25s,box-shadow .25s,border-color .25s;
  box-shadow:none;text-align:center;white-space:nowrap;
}
.sbc-btn .sbc-ico{width:1.1em;height:1.1em}
.sbc-btn:hover{background:var(--bh);color:#fff;transform:translateY(-1px)}
.sbc-btn:active{transform:translateY(0)}
.sbc-btn--blue{--b:var(--sbc-blue);--bh:var(--sbc-blue-600)}
.sbc-btn--orange{--b:var(--sbc-orange);--bh:var(--sbc-orange-600)}
.sbc-btn--ghost{background:transparent;color:var(--sbc-navy);border-color:var(--sbc-line)}
.sbc-btn--ghost:hover{background:transparent;color:var(--sbc-navy);border-color:var(--sbc-navy)}
.sbc-btn--lg{font-size:1.02rem;padding:1.1em 2em}
.sbc-btn--sm{font-size:.85rem;padding:.7em 1.2em}
.sbc-btn--block{display:flex;width:100%}

/* =====================================================================
   HEADER
   ===================================================================== */
.sbc-header{position:relative;z-index:90;background:#fff;border-bottom:1px solid var(--sbc-line)}

/* top utility bar */
.sbc-topbar{background:var(--sbc-navy);color:#cdd5e8;font-size:.8rem}
.sbc-topbar .sbc-container{display:flex;align-items:center;justify-content:space-between;gap:16px;min-height:38px}
.sbc-topbar__msg{display:inline-flex;align-items:center;gap:.5em}
.sbc-topbar__msg .sbc-ico{width:16px;height:16px;color:var(--sbc-yellow)}
.sbc-topbar__nav{display:flex;gap:18px}
.sbc-topbar a{color:#cdd5e8;display:inline-flex;align-items:center;gap:.4em}
.sbc-topbar a:hover{color:#fff}
.sbc-topbar a .sbc-ico{width:15px;height:15px}

/* main header row: logo | big search | actions */
.sbc-mid__row{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:clamp(16px,3vw,40px);padding-block:16px}
.sbc-logo{display:flex;align-items:center}
.sbc-logo img{max-height:48px;width:auto}
.sbc-logo__text{font-family:var(--sbc-font-head);font-weight:800;font-size:1.2rem;color:var(--sbc-navy);line-height:1.04}
.sbc-logo__text small{display:block;font-size:.58rem;letter-spacing:.18em;text-transform:uppercase;color:var(--sbc-ink-faint);font-weight:600}

.sbc-csearch{display:flex;align-items:stretch;max-width:680px;width:100%;margin:0 auto;border:2px solid var(--sbc-navy);border-radius:10px;overflow:hidden;background:#fff}
.sbc-csearch__cat{border:0;border-right:1px solid var(--sbc-line);background:var(--sbc-bg-soft);padding:0 .9em;font-weight:600;color:var(--sbc-navy);font-size:.88rem;max-width:160px;cursor:pointer}
.sbc-csearch input[type=search]{flex:1;min-width:0;border:0;padding:.85em 1em;font-size:.95rem;color:var(--sbc-ink)}
.sbc-csearch input:focus{outline:none}
.sbc-csearch button{border:0;background:var(--sbc-navy);color:#fff;padding:0 1.3em;cursor:pointer;display:flex;align-items:center;transition:background .2s}
.sbc-csearch button:hover{background:var(--sbc-blue)}
.sbc-csearch button .sbc-ico{width:22px;height:22px;color:#fff}

.sbc-acts{display:flex;align-items:center;gap:clamp(12px,1.6vw,22px)}
.sbc-act{position:relative;display:inline-flex;align-items:center;gap:.5em;color:var(--sbc-navy);font-size:.82rem;font-weight:600}
.sbc-act .sbc-ico{width:24px;height:24px}
.sbc-act:hover{color:var(--sbc-orange-600)}
.sbc-act__ic{position:relative;display:inline-flex}
.sbc-action__count{position:absolute;top:-7px;right:-9px;min-width:18px;height:18px;padding:0 4px;border-radius:999px;background:var(--sbc-orange);color:#fff;font-size:.64rem;line-height:18px;text-align:center;font-weight:800}
.sbc-action__count.is-pulse{animation:sbc-pop .4s var(--sbc-ease)}

/* department + nav bar */
.sbc-navbar{border-top:1px solid var(--sbc-line)}
.sbc-navbar__row{display:flex;align-items:stretch;gap:24px}
.sbc-dept{position:relative;display:flex}
.sbc-megabtn{display:inline-flex;align-items:center;gap:.6em;background:var(--sbc-orange);color:#fff;font-family:var(--sbc-font-head);font-weight:700;font-size:.95rem;padding:.95em 1.4em;border:0;cursor:pointer;white-space:nowrap}
.sbc-megabtn .sbc-ico{width:18px;height:18px}
.sbc-caret{width:7px;height:7px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(45deg) translateY(-2px);display:inline-block}
.sbc-mainnav{flex:1;display:flex;align-items:center}
.sbc-mainnav__menu{display:flex;flex-wrap:wrap;gap:2px}
.sbc-mainnav__menu a{display:block;padding:.95em .9em;font-family:var(--sbc-font-head);font-weight:600;font-size:.95rem;color:var(--sbc-ink)}
.sbc-mainnav__menu a:hover,.sbc-mainnav__menu .current-menu-item>a{color:var(--sbc-orange-600)}
.sbc-navbar__deal{margin-left:auto;display:inline-flex;align-items:center;gap:.5em;font-size:.85rem;font-weight:600;color:var(--sbc-blue);white-space:nowrap}
.sbc-navbar__deal .sbc-ico{width:18px;height:18px}

/* department mega panel */
.sbc-mega{position:absolute;top:100%;left:0;width:min(820px,92vw);background:#fff;border:1px solid var(--sbc-line);border-top:0;
  box-shadow:var(--sbc-shadow-lg);border-radius:0 0 14px 14px;padding:18px;z-index:95;display:none;grid-template-columns:repeat(3,1fr);gap:2px 16px}
.sbc-mega.is-open{display:grid;animation:sbc-fade-up .2s}
.sbc-mega a{display:flex;align-items:center;gap:10px;padding:.55em .7em;border-radius:8px;color:var(--sbc-ink-soft);font-size:.92rem;line-height:1.2}
.sbc-mega a:hover{background:var(--sbc-bg-soft);color:var(--sbc-navy)}
.sbc-mega a span{margin-left:auto;font-size:.72rem;color:var(--sbc-ink-faint);flex:0 0 auto}

/* Mobile menu */
.sbc-burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.sbc-burger span{width:26px;height:3px;border-radius:3px;background:var(--sbc-navy);transition:transform .3s,opacity .3s}
.sbc-burger.is-open span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.sbc-burger.is-open span:nth-child(2){opacity:0}
.sbc-burger.is-open span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}
.sbc-drawer{position:fixed;inset:0 0 0 auto;width:min(86vw,360px);background:#fff;z-index:200;transform:translateX(100%);
  transition:transform .32s var(--sbc-ease);box-shadow:var(--sbc-shadow-lg);overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:6px}
.sbc-drawer.is-open{transform:translateX(0)}
.sbc-drawer__head{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.sbc-drawer a{display:block;padding:.85em .4em;font-weight:600;color:var(--sbc-ink);border-bottom:1px solid var(--sbc-line)}
.sbc-drawer__close{background:none;border:0;font-size:1.6rem;line-height:1;cursor:pointer;color:var(--sbc-navy)}
.sbc-overlay{position:fixed;inset:0;background:rgba(20,23,107,.42);z-index:150;opacity:0;visibility:hidden;transition:opacity .3s}
.sbc-overlay.is-open{opacity:1;visibility:visible}

/* =====================================================================
   HERO
   ===================================================================== */
/* MARKETPLACE hero — departments sidebar + slider + side promo banners */
.sbc-hero{padding-top:clamp(16px,2vw,26px)}
.sbc-hero__grid{display:grid;grid-template-columns:1fr 320px;gap:18px;align-items:stretch}

/* departments sidebar */
.sbc-depts{background:#fff;border:1px solid var(--sbc-line);border-radius:var(--sbc-radius);overflow:hidden;display:flex;flex-direction:column}
.sbc-depts__head{display:flex;align-items:center;gap:.6em;background:var(--sbc-navy);color:#fff;font-family:var(--sbc-font-head);font-weight:700;font-size:.95rem;padding:.95em 1.1em}
.sbc-depts__head .sbc-ico{width:18px;height:18px}
.sbc-depts__list{flex:1;overflow:auto;max-height:430px}
.sbc-depts__list li a{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:.6em 1.1em;font-size:.9rem;color:var(--sbc-ink);border-bottom:1px solid var(--sbc-line);transition:padding .2s,background .2s,color .2s}
.sbc-depts__list li a:hover{background:var(--sbc-bg-soft);color:var(--sbc-orange-600);padding-left:1.4em}
.sbc-depts__list li a span{font-size:.74rem;color:var(--sbc-ink-faint)}
.sbc-depts__all a{font-weight:700;color:var(--sbc-blue)!important;justify-content:flex-start!important}

/* slider */
.sbc-slider{position:relative;border-radius:var(--sbc-radius);overflow:hidden;background:var(--sbc-grad-soft)}
.sbc-slider__track{position:relative}
.sbc-slide{position:absolute;inset:0;display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:20px;padding:clamp(24px,3vw,48px);opacity:0;visibility:hidden;transition:opacity .5s}
.sbc-slide.is-active{opacity:1;visibility:visible;position:relative}
.sbc-slide__eyebrow{font-family:var(--sbc-font-head);font-weight:700;font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--sbc-orange-600)}
.sbc-slide__title{font-size:clamp(1.6rem,2.6vw,2.7rem);font-weight:800;color:var(--sbc-navy);margin:.4em 0;line-height:1.1}
.sbc-slide__sub{color:var(--sbc-ink-soft);margin:0 0 1.4rem;max-width:34ch}
.sbc-slide__img{display:grid;place-items:center}
.sbc-slide__img img{max-height:300px;width:auto;object-fit:contain}
.sbc-slider__nav{position:absolute;top:50%;transform:translateY(-50%);width:42px;height:42px;border-radius:50%;background:#fff;border:1px solid var(--sbc-line);color:var(--sbc-navy);font-size:1.4rem;cursor:pointer;display:grid;place-items:center;box-shadow:var(--sbc-shadow-sm);z-index:3;opacity:0;transition:.25s}
.sbc-slider:hover .sbc-slider__nav{opacity:1}
.sbc-slider__nav--prev{left:14px}.sbc-slider__nav--next{right:14px}
.sbc-slider__nav:hover{background:var(--sbc-navy);color:#fff}
.sbc-slider__dots{position:absolute;bottom:14px;left:50%;transform:translateX(-50%);display:flex;gap:7px;z-index:3}
.sbc-slider__dot{width:9px;height:9px;border-radius:50%;background:var(--sbc-line);border:0;cursor:pointer;transition:.2s;padding:0}
.sbc-slider__dot.is-active{background:var(--sbc-orange);width:24px;border-radius:5px}

/* side promo banners */
.sbc-promos{display:grid;grid-template-rows:1fr 1fr;gap:18px}
.sbc-promo{position:relative;border-radius:var(--sbc-radius);overflow:hidden;background-size:cover;background-position:center;padding:20px;display:flex;flex-direction:column;justify-content:center;color:#fff;min-height:180px;transition:transform .3s}
.sbc-promo:hover{transform:translateY(-3px)}
.sbc-promo__kicker{font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;font-weight:600;opacity:.92}
.sbc-promo__title{font-family:var(--sbc-font-head);font-weight:700;font-size:1.2rem;line-height:1.15;margin:.3em 0 .5em;color:#fff}
.sbc-promo__cta{font-weight:700;font-size:.85rem;color:#fff}

/* service strip */
.sbc-services{margin-top:18px}
.sbc-services__row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;background:#fff;border:1px solid var(--sbc-line);border-radius:var(--sbc-radius);padding:18px 22px}
.sbc-service{display:flex;align-items:center;gap:12px}
.sbc-service .sbc-ico{width:30px;height:30px;color:var(--sbc-blue);flex:0 0 auto}
.sbc-service b{display:block;font-size:.92rem;color:var(--sbc-navy)}
.sbc-service span{font-size:.78rem;color:var(--sbc-ink-soft)}

/* deals header + countdown */
.sbc-section-head--deal{display:flex!important;align-items:center;justify-content:space-between;gap:16px 24px;flex-wrap:wrap}
.sbc-countdown{display:inline-flex;align-items:center;gap:6px;font-family:var(--sbc-font-head);font-weight:700;color:var(--sbc-navy)}
.sbc-countdown__label{font-size:.8rem;color:var(--sbc-ink-soft);margin-right:4px;font-weight:600}
.sbc-countdown__box{background:var(--sbc-navy);color:#fff;border-radius:6px;padding:.3em .45em;min-width:2.1em;text-align:center;font-variant-numeric:tabular-nums}

/* promo banner grid (mid-page) */
.sbc-bnr-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.sbc-bnr{position:relative;border-radius:var(--sbc-radius);overflow:hidden;background-size:cover;background-position:center;color:#fff;
  padding:clamp(26px,3vw,44px);min-height:220px;display:flex;flex-direction:column;justify-content:center;align-items:flex-start;transition:transform .3s}
.sbc-bnr:hover{transform:translateY(-4px)}
.sbc-bnr__kicker{font-size:.74rem;text-transform:uppercase;letter-spacing:.08em;font-weight:700;opacity:.95}
.sbc-bnr__title{font-family:var(--sbc-font-head);font-weight:800;font-size:clamp(1.4rem,2vw,1.9rem);line-height:1.1;margin:.3em 0;color:#fff}
.sbc-bnr__text{font-size:.92rem;color:rgba(255,255,255,.92);margin:0 0 1.2rem;max-width:34ch}
.sbc-bnr .sbc-btn{--b:#fff;--bh:#fff;color:var(--sbc-navy)!important}

@media (max-width:1024px){.sbc-hero__grid{grid-template-columns:1fr}.sbc-promos{display:none}}
@media (max-width:880px){
  .sbc-hero__grid{grid-template-columns:1fr}
  .sbc-slide{grid-template-columns:1fr;text-align:center}.sbc-slide__img{display:none}
  .sbc-services__row{grid-template-columns:repeat(2,1fr);gap:18px}
  .sbc-bnr-grid{grid-template-columns:1fr}
}

/* =====================================================================
   CATEGORY DISCOVERY
   ===================================================================== */
/* circular category icons (SwiftCart style) */
.sbc-catrow{display:grid;grid-template-columns:repeat(8,1fr);gap:clamp(10px,1.4vw,22px) clamp(6px,1vw,14px)}
.sbc-catcircle{display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center;text-decoration:none}
.sbc-catcircle__img{width:clamp(92px,8.5vw,140px);aspect-ratio:1;border-radius:50%;background:var(--sbc-bg-soft);
  display:grid;place-items:center;overflow:hidden;transition:transform .3s var(--sbc-ease),box-shadow .3s}
.sbc-catcircle:hover .sbc-catcircle__img{transform:translateY(-6px);box-shadow:0 16px 36px rgba(16,32,44,.12)}
.sbc-catcircle__img img{width:74%;height:74%;object-fit:contain;mix-blend-mode:multiply}
.sbc-catcircle__img .sbc-ico{width:40%;height:40%;color:var(--sbc-blue)}
.sbc-catcircle__name{font-family:var(--sbc-font-head);font-weight:700;font-size:clamp(.9rem,1vw,1.02rem);color:var(--sbc-navy);line-height:1.2}
.sbc-catcircle:hover .sbc-catcircle__name{color:var(--sbc-orange-600)}
.sbc-catcircle__count{font-size:.76rem;color:var(--sbc-ink-faint);margin-top:-6px}
@media (max-width:1100px){.sbc-catrow{grid-template-columns:repeat(6,1fr)}}
@media (max-width:760px){.sbc-catrow{grid-template-columns:repeat(4,1fr)}}
@media (max-width:460px){.sbc-catrow{grid-template-columns:repeat(3,1fr)}}

.sbc-cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:var(--sbc-gap)}
.sbc-cat-card{position:relative;display:block;background:#fff;border:1px solid var(--sbc-line);border-radius:var(--sbc-radius);
  overflow:hidden;box-shadow:var(--sbc-shadow-sm);transition:transform .28s var(--sbc-ease),box-shadow .28s,border-color .28s}
.sbc-cat-card:hover{transform:translateY(-6px);box-shadow:var(--sbc-shadow-lg);border-color:var(--sbc-sky)}
.sbc-cat-card__media{display:block;aspect-ratio:4/3;background:var(--sbc-grad-soft);overflow:hidden}
.sbc-cat-card__media img{display:block;width:100%;height:100%;object-fit:cover;transition:transform .4s var(--sbc-ease)}
.sbc-cat-card:hover .sbc-cat-card__media img{transform:scale(1.07)}
.sbc-cat-card__body{display:block;padding:14px 16px 18px}
.sbc-cat-card__count{display:block;margin-top:2px}
.sbc-cat-card__body h3{font-size:1.02rem;margin:0 0 2px;color:var(--sbc-navy)}
.sbc-cat-card__count{font-size:.78rem;font-weight:700;color:var(--sbc-orange-600)}
.sbc-cat-card__desc{font-size:.82rem;color:var(--sbc-ink-soft);margin:.4em 0 0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

/* =====================================================================
   COLLECTIONS (tabs)
   ===================================================================== */
.sbc-tabs{display:flex;gap:clamp(14px,2vw,28px);flex-wrap:wrap;justify-content:flex-start;margin-bottom:24px;border-bottom:1px solid var(--sbc-line)}
.sbc-tab{border:0;background:none;color:var(--sbc-ink-faint);font-family:var(--sbc-font-head);
  font-weight:700;font-size:clamp(.85rem,1vw,1rem);padding:.7em .1em;cursor:pointer;position:relative;transition:color .2s}
.sbc-tab:hover{color:var(--sbc-navy)}
.sbc-tab.is-active{color:var(--sbc-navy)}
.sbc-tab.is-active::after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:3px;background:var(--sbc-orange);border-radius:3px}
.sbc-tab-panel{display:none}
.sbc-tab-panel.is-active{display:block;animation:sbc-fade-up .3s var(--sbc-ease)}

/* =====================================================================
   PRODUCT GRID / CARDS  (also styles WooCommerce loop)
   ===================================================================== */
.sbc-products,
ul.products{display:grid!important;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:var(--sbc-gap);margin:0;padding:0}
/* WooCommerce core adds ::before/::after clearfix on ul.products. In a CSS grid
   those pseudo-elements become grid items and steal the first cell(s), which
   pushes/hides the first product. Neutralise them. */
.woocommerce ul.products::before,.woocommerce ul.products::after,
.sbc-products::before,.sbc-products::after,
ul.products::before,ul.products::after{content:none!important;display:none!important}
/* Cancel WooCommerce's nth-child clearing/margins that assume a float layout. */
ul.products li.product{clear:none!important}
.sbc-product,
ul.products li.product{position:relative;background:#fff;border:1px solid var(--sbc-line);border-radius:var(--sbc-radius);
  overflow:hidden;box-shadow:var(--sbc-shadow-sm);transition:transform .26s var(--sbc-ease),box-shadow .26s,border-color .26s;
  width:auto!important;margin:0!important;float:none!important;display:flex;flex-direction:column}
.sbc-product:hover,
ul.products li.product:hover{transform:translateY(-6px);box-shadow:var(--sbc-shadow-lg);border-color:var(--sbc-sky)}
/* whole card is clickable: the product link is stretched over the card, while
   the Add-to-cart button + wishlist sit above it and stay independently clickable */
ul.products li.product > a:first-child::after{content:"";position:absolute;inset:0;z-index:1}
ul.products li.product .button,
ul.products li.product .added_to_cart,
ul.products li.product .sbc-product__rail{position:relative;z-index:3}
.sbc-product__media{position:relative;aspect-ratio:1/1;background:var(--sbc-bg-soft);overflow:hidden}
.sbc-product__media img{width:100%;height:100%;object-fit:contain;margin:0;padding:10px;transition:transform .4s var(--sbc-ease);background:#fff}
.sbc-product:hover .sbc-product__media img{transform:scale(1.05)}

/* WooCommerce loop card: make the whole <a> a flex column and give the image
   a fixed square box so every card is the same shape regardless of the source
   image aspect ratio. Price + button get pinned to the bottom for alignment. */
ul.products li.product > a:first-child{display:flex!important;flex-direction:column;flex:0 0 auto;color:inherit}
/* compact: product image in a soft tile. 14px inset on both sides so the image
   left edge aligns with the title/category/price. Less inner padding = bigger product. */
ul.products li.product img{width:calc(100% - 28px)!important;aspect-ratio:1/1;height:auto!important;object-fit:contain;
  margin:14px 14px 8px!important;padding:6px;background:var(--sbc-bg-soft);border-radius:12px;
  transition:transform .4s var(--sbc-ease)}
ul.products li.product:hover img{transform:scale(1.05)}

/* Homepage product grids: compact rows, 5 per row on desktop (wide enough that
   the price never truncates). Shop/archive pages keep the auto-fill grid above. */
.sbc-home ul.products{grid-template-columns:repeat(5,1fr)!important;gap:16px!important}
@media (max-width:1180px){.sbc-home ul.products{grid-template-columns:repeat(4,1fr)!important}}
@media (max-width:900px){.sbc-home ul.products{grid-template-columns:repeat(3,1fr)!important}}
@media (max-width:560px){.sbc-home ul.products{grid-template-columns:repeat(2,1fr)!important}}
.sbc-product__body{padding:12px 14px 16px;display:flex;flex-direction:column;gap:6px;flex:1}
.sbc-product__cat{font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;color:var(--sbc-ink-faint);font-weight:700}
.sbc-product__title,
ul.products li.product .woocommerce-loop-product__title{font-family:var(--sbc-font-head);font-size:.92rem!important;font-weight:600;
  color:var(--sbc-ink)!important;line-height:1.35;margin:0!important;padding:0!important;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:2.6em}
.sbc-product__title a{color:inherit}
.sbc-product__price,
ul.products li.product .price{font-family:var(--sbc-font-head);font-weight:800;color:var(--sbc-navy)!important;font-size:1.02rem!important;margin:0!important}
.sbc-product__price del,
ul.products li.product .price del{color:var(--sbc-ink-faint)!important;font-weight:500;font-size:.85em;margin-right:.4em;opacity:.8}
.sbc-product__price ins,
ul.products li.product .price ins{text-decoration:none;color:var(--sbc-orange-600)!important}
.sbc-product__foot{margin-top:auto;padding-top:6px}
/* compact: title clamped to exactly 2 lines so every card is the same height.
   padding has !important to beat WooCommerce's `.woocommerce …__title{padding:.5em 0}`
   which otherwise zeroes the left padding and pushes the title out of alignment. */
ul.products li.product .woocommerce-loop-product__title{margin:4px 0 6px!important;padding:0 14px!important;font-size:.82rem!important;
  font-family:var(--sbc-font)!important;font-weight:600!important;line-height:1.32!important;color:var(--sbc-ink)!important;
  display:-webkit-box!important;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
  height:2.64em!important;min-height:2.64em}
/* price ALWAYS on a single inline row: struck original + sale price side by side.
   nowrap is essential — otherwise the narrow compact card wraps it to 2 lines. */
ul.products li.product .price{margin:0!important;padding:0!important;font-size:.92rem!important;font-family:var(--sbc-font)!important;
  min-height:0;display:flex!important;flex-direction:row;flex-wrap:nowrap!important;align-items:baseline;
  gap:6px;line-height:1.2;white-space:nowrap!important}
ul.products li.product .price del,
ul.products li.product .price ins,
ul.products li.product .price .amount,
ul.products li.product .price .woocommerce-Price-amount{white-space:nowrap!important;flex:0 0 auto}

/* Footer row: price (left, flexible) + cart icon button (right). Flexbox keeps
   them apart so they never overlap, regardless of card width. */
.sbc-home ul.products li.product{display:flex!important;flex-direction:column}
.sbc-home ul.products li.product .sbc-loop-foot{
  display:flex!important;align-items:center;justify-content:space-between;gap:8px;
  margin-top:auto;padding:8px 14px 16px}
.sbc-home ul.products li.product .sbc-loop-foot .price{
  flex:1 1 auto;min-width:0;padding:0!important;margin:0!important;
  overflow:hidden;text-overflow:ellipsis}
/* unified 14px inner inset so text lines up with the image edge */
ul.products li.product .sbc-product__cat,
ul.products li.product .woocommerce-loop-product__title,
ul.products li.product .star-rating{padding-left:14px;padding-right:14px}
ul.products li.product .price{padding-left:14px!important}
/* category: quieter than the title — lighter weight, tighter tracking, smaller */
ul.products li.product .sbc-product__cat{padding-top:2px;font-size:.62rem!important;font-weight:600!important;
  letter-spacing:.03em!important;color:var(--sbc-ink-faint)!important}
/* COMPACT (homepage only): Add-to-cart becomes a small round icon button pinned
   bottom-right. Label text hidden visually but kept for screen readers. Scoped
   to .sbc-home so shop/category pages keep full text buttons. */
.sbc-home ul.products li.product{text-align:left!important}
.sbc-home ul.products li.product > a:first-child{text-align:left!important}
.sbc-home ul.products li.product .button{
  flex:0 0 auto;z-index:4;
  width:36px!important;height:36px!important;min-width:0!important;
  margin:0!important;padding:0!important;border-radius:50%!important;
  display:flex!important;align-items:center;justify-content:center;
  font-size:0!important;line-height:0!important;text-indent:-9999px;overflow:hidden;
  box-shadow:0 4px 10px rgba(240,120,0,.28)!important}
.sbc-home ul.products li.product .button::before{
  content:""!important;width:17px!important;height:17px!important;background:#fff!important;text-indent:0;flex:0 0 auto;
  -webkit-mask:var(--sbc-cart-ico) center/contain no-repeat;mask:var(--sbc-cart-ico) center/contain no-repeat}
.sbc-home ul.products li.product .added_to_cart{display:none!important} /* hide WC "View cart" link */

/* ELECTRO-style card: category + title ABOVE the image; flat bordered cell. */
.sbc-home ul.products li.product{border:1px solid var(--sbc-line);border-radius:10px;box-shadow:none;transition:box-shadow .25s,transform .25s}
.sbc-home ul.products li.product:hover{box-shadow:var(--sbc-shadow);transform:translateY(-2px);border-color:var(--sbc-line)}
.sbc-home ul.products li.product > a:first-child{padding-top:14px}
.sbc-home ul.products li.product .sbc-product__cat{display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden;color:var(--sbc-ink-soft)!important;font-weight:600!important;letter-spacing:0!important;text-transform:none!important;font-size:.72rem!important}
.sbc-home ul.products li.product .woocommerce-loop-product__title{color:var(--sbc-blue)!important;margin:5px 0 8px!important;min-height:2.6em}
.sbc-home ul.products li.product:hover .woocommerce-loop-product__title{color:var(--sbc-navy)!important}
.sbc-home ul.products li.product .star-rating{margin:0 0 6px 14px!important}
.sbc-home ul.products li.product img{background:#fff!important;border-radius:0!important;
  margin:6px auto 6px!important;padding:0!important;width:calc(100% - 28px)!important;mix-blend-mode:multiply}
/* sale price in red (Electro) */
.sbc-home ul.products li.product .price ins,
.sbc-home ul.products li.product .price ins .amount{color:var(--sbc-deal)!important}

/* Badges */
.sbc-badge{position:absolute;z-index:3;top:10px;left:10px;font-family:var(--sbc-font-head);font-weight:800;font-size:.68rem;
  letter-spacing:.03em;padding:.34em .7em;border-radius:999px;color:#fff;box-shadow:var(--sbc-shadow-sm)}
.sbc-badge--sale,
ul.products li.product .onsale{background:var(--sbc-sale)!important;color:#fff!important;position:absolute!important;top:12px!important;right:12px!important;left:auto!important;bottom:auto!important;
  min-height:0!important;min-width:0!important;border-radius:999px!important;padding:.24em .58em!important;margin:0!important;font-weight:700!important;font-size:.58rem!important;line-height:1.5!important;box-shadow:0 2px 6px rgba(226,59,59,.3);z-index:5}
.sbc-badge--new{background:var(--sbc-success);top:10px;right:10px;left:auto}
.sbc-badge--out{background:var(--sbc-ink-soft)}

/* Card hover action rail (wishlist / quick view) */
.sbc-product__rail{position:absolute;top:10px;right:10px;z-index:3;display:flex;flex-direction:column;gap:8px;
  opacity:0;transform:translateX(8px);transition:.25s var(--sbc-ease)}
.sbc-product:hover .sbc-product__rail,
ul.products li.product:hover .sbc-product__rail{opacity:1;transform:translateX(0)}
.sbc-iconbtn{width:38px;height:38px;border-radius:50%;background:#fff;border:1px solid var(--sbc-line);display:grid;place-items:center;
  color:var(--sbc-navy);cursor:pointer;box-shadow:var(--sbc-shadow-sm);transition:.2s}
.sbc-iconbtn:hover{background:var(--sbc-navy);color:#fff;border-color:var(--sbc-navy)}
.sbc-iconbtn svg{width:18px;height:18px}

/* WooCommerce add-to-cart button inside cards */
ul.products li.product .button,
.sbc-product .button{display:inline-flex!important;align-items:center;justify-content:center;gap:.5em;width:100%;
  background:var(--sbc-orange)!important;color:#fff!important;font-family:var(--sbc-font-head);font-weight:700!important;
  border-radius:999px!important;padding:.72em 1em!important;margin:0!important;font-size:.86rem!important;border:0!important;
  transition:background .2s,transform .18s!important;box-shadow:0 4px 12px rgba(240,120,0,.24)}
ul.products li.product .button:hover,
.sbc-product .button:hover{background:var(--sbc-orange-600)!important;transform:translateY(-1px)}
ul.products li.product .added_to_cart{display:none!important}
.star-rating{color:var(--sbc-orange)!important;margin:0 0 2px!important}

/* =====================================================================
   BULK ORDER CTA
   ===================================================================== */
/* horizontal orange bulk banner */
.sbc-bulkcta{position:relative;overflow:hidden;border-radius:var(--sbc-radius-lg);
  background:linear-gradient(120deg,var(--sbc-orange),var(--sbc-orange-600));color:#fff;
  display:grid;grid-template-columns:1.6fr auto;align-items:center;gap:clamp(24px,4vw,56px);padding:clamp(28px,4vw,52px)}
.sbc-bulkcta::before{content:"";position:absolute;inset:0;background:radial-gradient(60% 130% at 100% 0%,rgba(255,255,255,.18),transparent 55%)}
.sbc-bulkcta>*{position:relative;z-index:1}
.sbc-bulkcta__main .sbc-eyebrow{color:rgba(255,255,255,.8)}
.sbc-bulkcta__main h2{color:#fff;margin:0 0 .4em}
.sbc-bulkcta__main p{color:rgba(255,255,255,.92);margin:0 0 1.1rem;max-width:54ch}
.sbc-bulkcta__chips{display:flex;flex-wrap:wrap;gap:8px}
.sbc-bulkcta__chips li{display:flex;align-items:center;gap:.4em;background:rgba(255,255,255,.16);padding:.4em .9em;border-radius:999px;font-size:.85rem;font-weight:600}
.sbc-bulkcta__chips .sbc-ico{width:15px;height:15px}
.sbc-bulkcta__action{display:flex;flex-direction:column;align-items:flex-start;gap:16px}
.sbc-bulkcta__action .sbc-btn{--b:#fff;--bh:#fff;color:var(--sbc-orange-600)!important}
.sbc-bulkcta__notes{display:flex;flex-direction:column;gap:8px;font-size:.88rem}
.sbc-bulkcta__notes a,.sbc-bulkcta__notes span{display:flex;align-items:center;gap:.5em;color:#fff}
.sbc-bulkcta__notes .sbc-ico{width:16px;height:16px;opacity:.9}
@media (max-width:760px){.sbc-bulkcta{grid-template-columns:1fr}.sbc-bulkcta__action{align-items:stretch}}

.sbc-bulk{position:relative;overflow:hidden;border-radius:var(--sbc-radius-lg);background:var(--sbc-grad);color:#fff;
  padding:clamp(30px,5vw,60px);display:grid;grid-template-columns:1.4fr 1fr;gap:30px;align-items:center}
.sbc-bulk::before{content:"";position:absolute;inset:0;background:radial-gradient(60% 120% at 100% 0%,rgba(255,255,255,.18),transparent 60%)}
.sbc-bulk>*{position:relative;z-index:1}
.sbc-bulk h2{color:#fff}
.sbc-bulk p{color:rgba(255,255,255,.9)}
.sbc-bulk__points{display:flex;flex-wrap:wrap;gap:10px;margin:1.2rem 0}
.sbc-bulk__points li{display:flex;align-items:center;gap:.5em;background:rgba(255,255,255,.14);padding:.45em .9em;border-radius:999px;font-size:.85rem;font-weight:600}
.sbc-bulk .sbc-btn{--b:#fff;--bh:#fff;color:var(--sbc-navy)!important;box-shadow:0 8px 22px rgba(0,0,0,.18)}
.sbc-bulk .sbc-btn:hover{color:var(--sbc-blue)!important}
.sbc-bulk__card{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.25);border-radius:var(--sbc-radius);padding:22px;backdrop-filter:blur(4px)}

/* =====================================================================
   LEGACY
   ===================================================================== */
/* full-width legacy brand band */
.sbc-legacy-band{position:relative;overflow:hidden;border-radius:var(--sbc-radius-lg);background:var(--sbc-grad);color:#fff;
  padding:clamp(28px,4vw,52px)}
.sbc-legacy-band::before{content:"";position:absolute;inset:0;background:radial-gradient(70% 130% at 100% 0%,rgba(255,255,255,.16),transparent 55%)}
.sbc-legacy-band>*{position:relative;z-index:1}
.sbc-legacy-band__head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;flex-wrap:wrap}
.sbc-legacy-band__copy{max-width:62ch}
.sbc-legacy-band__copy .sbc-eyebrow{color:rgba(255,255,255,.7)}
.sbc-legacy-band__copy h2{color:#fff;margin:0 0 .5em}
.sbc-legacy-band__copy p{color:rgba(255,255,255,.9);margin:0;line-height:1.6}
.sbc-legacy-band__head .sbc-btn{--b:#fff;--bh:#fff;color:var(--sbc-navy)!important;flex:0 0 auto}
.sbc-legacy-band__stats{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:clamp(24px,3vw,40px);
  padding-top:clamp(20px,2.5vw,32px);border-top:1px solid rgba(255,255,255,.2)}
.sbc-legacy-band__stat b{display:block;font-family:var(--sbc-font-head);font-weight:800;font-size:clamp(1.6rem,2.6vw,2.4rem);line-height:1;color:#fff}
.sbc-legacy-band__stat span{font-size:.84rem;color:rgba(255,255,255,.82);margin-top:6px;display:block}
@media (max-width:680px){.sbc-legacy-band__stats{grid-template-columns:repeat(2,1fr);gap:22px 18px}}

.sbc-legacy{display:grid;grid-template-columns:1fr 1fr;gap:clamp(24px,4vw,56px);align-items:center}
/* No overflow:hidden here — it would clip the year seal at the rounded corner.
   The image rounds itself instead, so the seal stays fully visible. */
.sbc-legacy__media{position:relative;border-radius:var(--sbc-radius-lg);box-shadow:var(--sbc-shadow-lg);aspect-ratio:4/3;background:var(--sbc-grad)}
.sbc-legacy__media img{width:100%;height:100%;object-fit:cover;border-radius:var(--sbc-radius-lg)}
.sbc-legacy__seal{position:absolute;right:20px;bottom:20px;background:#fff;border-radius:50%;width:104px;height:104px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px;text-align:center;box-shadow:var(--sbc-shadow);line-height:1.05}
.sbc-legacy__seal b{font-family:var(--sbc-font-head);font-size:1.7rem;line-height:1;color:var(--sbc-orange-600);display:block;margin:0}
.sbc-legacy__seal span{font-size:.62rem;line-height:1;text-transform:uppercase;letter-spacing:.1em;color:var(--sbc-ink-soft)}
.sbc-legacy__stats{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-top:1.6rem}
.sbc-legacy__stat{background:var(--sbc-bg-soft);border:1px solid var(--sbc-line);border-radius:var(--sbc-radius);padding:14px 16px}
.sbc-legacy__stat b{font-family:var(--sbc-font-head);font-size:1.5rem;color:var(--sbc-navy);display:block}
.sbc-legacy__stat span{font-size:.8rem;color:var(--sbc-ink-soft)}

/* =====================================================================
   BRANDS carousel
   ===================================================================== */
.sbc-marquee{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.sbc-marquee__track{display:flex;gap:46px;width:max-content;animation:sbc-marquee 32s linear infinite}
.sbc-marquee:hover .sbc-marquee__track{animation-play-state:paused}
.sbc-marquee__item{flex:0 0 auto;height:54px;display:grid;place-items:center;filter:grayscale(1);opacity:.6;transition:.3s}
.sbc-marquee__item:hover{filter:grayscale(0);opacity:1}
.sbc-marquee__item img{max-height:54px;width:auto;object-fit:contain}
.sbc-marquee__item span{font-family:var(--sbc-font-head);font-weight:800;color:var(--sbc-navy);font-size:1.3rem;white-space:nowrap}

/* =====================================================================
   TESTIMONIALS
   ===================================================================== */
/* even 3-column grid of testimonial cards */
.sbc-testi{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sbc-gap)}
.sbc-testi__card{background:#fff;border:1px solid var(--sbc-line);border-radius:var(--sbc-radius);padding:28px;position:relative;
  display:flex;flex-direction:column;box-shadow:var(--sbc-shadow-sm);transition:transform .25s var(--sbc-ease),box-shadow .25s}
.sbc-testi__card:hover{transform:translateY(-4px);box-shadow:var(--sbc-shadow)}
.sbc-testi__card::before{content:"\201C";position:absolute;top:10px;right:22px;font-family:var(--sbc-font-head);font-size:3.4rem;color:var(--sbc-bg-tint);line-height:1}
.sbc-testi__stars{color:var(--sbc-orange);letter-spacing:2px;margin-bottom:.7rem}
.sbc-testi__text{color:var(--sbc-ink);position:relative;z-index:1;line-height:1.6}
.sbc-testi__who{display:flex;align-items:center;gap:12px;margin-top:auto;padding-top:1.2rem}
@media (max-width:900px){.sbc-testi{grid-template-columns:repeat(2,1fr)}}
@media (max-width:600px){.sbc-testi{grid-template-columns:1fr}}
.sbc-testi__avatar{width:44px;height:44px;border-radius:50%;background:var(--sbc-grad);color:#fff;display:grid;place-items:center;font-family:var(--sbc-font-head);font-weight:800}
.sbc-testi__who b{display:block;color:var(--sbc-navy);font-size:.92rem}
.sbc-testi__who span{font-size:.78rem;color:var(--sbc-ink-soft)}

/* =====================================================================
   WHY SHOP
   ===================================================================== */
/* ruled editorial grid — hairline-separated cells, no boxes */
.sbc-why{display:grid;grid-template-columns:repeat(3,1fr);gap:0;
  border-top:1px solid var(--sbc-line);border-left:1px solid var(--sbc-line);border-radius:var(--sbc-radius);overflow:hidden;background:#fff}
.sbc-why__card{background:none;border:0;border-right:1px solid var(--sbc-line);border-bottom:1px solid var(--sbc-line);
  border-radius:0;padding:clamp(26px,3vw,42px);transition:background .28s var(--sbc-ease)}
.sbc-why__card:hover{transform:none;box-shadow:none;background:var(--sbc-bg-soft)}
.sbc-why__icon{width:50px;height:50px;border-radius:14px;background:var(--sbc-grad-soft);color:var(--sbc-blue);display:grid;place-items:center;margin-bottom:20px;transition:transform .28s var(--sbc-ease)}
.sbc-why__card:hover .sbc-why__icon{transform:scale(1.08)}
.sbc-why__icon svg{width:24px;height:24px}
.sbc-why__card h3{font-size:1.12rem;margin:0 0 .45em}
.sbc-why__card p{font-size:.9rem;color:var(--sbc-ink-soft);margin:0;line-height:1.55}

/* =====================================================================
   ABOUT PAGE
   ===================================================================== */
.sbc-about-hero{background:var(--sbc-grad-soft);border-bottom:1px solid var(--sbc-line);padding-block:clamp(40px,6vw,84px);text-align:center}
.sbc-about-hero h1{margin:.25em auto .3em;max-width:20ch}
.sbc-about-hero p{color:var(--sbc-ink-soft);max-width:62ch;margin:0 auto;font-size:1.08rem;line-height:1.65}
.sbc-about-story{display:grid;grid-template-columns:1.5fr 1fr;gap:clamp(28px,4vw,60px);align-items:center}
.sbc-about-story__text p{color:var(--sbc-ink-soft);line-height:1.7}
.sbc-about-story__media{position:relative;border-radius:var(--sbc-radius-lg);aspect-ratio:4/3;background:var(--sbc-grad-soft)}
.sbc-about-story__media img{width:100%;height:100%;object-fit:cover;border-radius:var(--sbc-radius-lg)}
.sbc-about-story__ph{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;
  background:var(--sbc-grad);color:#fff;border-radius:var(--sbc-radius-lg);text-align:center}
.sbc-about-story__ph strong{font-family:var(--sbc-font-head);font-size:3rem;line-height:1}
.sbc-about-story__ph em{opacity:.85;font-style:normal;font-size:.9rem;margin-top:8px}
.sbc-about-seal{width:clamp(180px,22vw,240px);aspect-ratio:1;border-radius:50%;background:var(--sbc-grad);color:#fff;
  display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;box-shadow:var(--sbc-shadow-lg)}
.sbc-about-seal b{font-family:var(--sbc-font-head);font-weight:800;font-size:clamp(2.4rem,5vw,3.6rem);line-height:1}
.sbc-about-seal span{font-size:.82rem;opacity:.9;margin-top:8px;max-width:12ch;line-height:1.3}
/* seal as a small badge overlapping the image corner */
.sbc-about-seal--badge{position:absolute;right:-16px;bottom:-16px;width:clamp(96px,11vw,128px);max-width:128px;
  border:5px solid var(--sbc-bg)}
.sbc-about-seal--badge b{font-size:clamp(1.4rem,2.4vw,1.9rem)}
.sbc-about-seal--badge span{font-size:.6rem;margin-top:2px;letter-spacing:.06em;text-transform:uppercase}
/* vertical alternating (zig-zag) timeline with scroll-reveal */
.sbc-timeline{position:relative;max-width:960px;margin:0 auto}
.sbc-timeline::before{content:"";position:absolute;left:50%;top:8px;bottom:8px;width:2px;background:var(--sbc-line);transform:translateX(-50%)}
.sbc-timeline__item{position:relative;width:50%;box-sizing:border-box;padding:6px 50px 40px}
.sbc-timeline__item:nth-child(odd){text-align:right}
.sbc-timeline__item:nth-child(even){margin-left:50%}
.sbc-timeline__dot{position:absolute;top:2px;width:40px;height:40px;border-radius:50%;background:var(--sbc-orange);color:#fff;
  display:grid;place-items:center;font-family:var(--sbc-font-head);font-weight:800;box-shadow:0 0 0 6px var(--sbc-bg-soft);z-index:1}
.sbc-timeline__item:nth-child(odd) .sbc-timeline__dot{right:-20px}
.sbc-timeline__item:nth-child(even) .sbc-timeline__dot{left:-20px}
.sbc-timeline__year{display:block;font-size:.76rem;text-transform:uppercase;letter-spacing:.08em;color:var(--sbc-orange-600);font-weight:700;margin-bottom:.3em}
.sbc-timeline__item h3{margin:0 0 .3em}
.sbc-timeline__item p{font-size:.92rem;color:var(--sbc-ink-soft);margin:0;line-height:1.6}
/* scroll-reveal: slide in from each side */
.sbc-timeline__item[data-sbc-reveal]{opacity:0;transition:opacity .6s var(--sbc-ease),transform .6s var(--sbc-ease)}
.sbc-timeline__item:nth-child(odd)[data-sbc-reveal]{transform:translateX(-34px)}
.sbc-timeline__item:nth-child(even)[data-sbc-reveal]{transform:translateX(34px)}
.sbc-timeline__item[data-sbc-reveal].is-in{opacity:1;transform:none}
/* leadership */
.sbc-leaders{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(16px,2vw,28px)}
.sbc-leader{background:#fff;border:1px solid var(--sbc-line);border-radius:var(--sbc-radius);padding:28px 20px;text-align:center;
  box-shadow:var(--sbc-shadow-sm);transition:transform .25s var(--sbc-ease),box-shadow .25s}
.sbc-leader:hover{transform:translateY(-4px);box-shadow:var(--sbc-shadow)}
.sbc-leader__avatar{width:88px;height:88px;border-radius:50%;margin:0 auto 16px;background:var(--sbc-grad);color:#fff;
  display:grid;place-items:center;font-family:var(--sbc-font-head);font-weight:800;font-size:2rem;overflow:hidden}
.sbc-leader__avatar img{width:100%;height:100%;object-fit:cover}
.sbc-leader h3{margin:0 0 .2em;font-size:1.1rem}
.sbc-leader__role{font-size:.85rem;color:var(--sbc-orange-600);font-weight:600}
@media (max-width:760px){.sbc-leaders{grid-template-columns:repeat(2,1fr)}}

@media (max-width:760px){
  .sbc-about-story{grid-template-columns:1fr}
  .sbc-timeline{max-width:none}
  .sbc-timeline::before{left:20px}
  .sbc-timeline__item,.sbc-timeline__item:nth-child(even){width:100%;margin-left:0;text-align:left;padding:6px 0 30px 56px}
  .sbc-timeline__item .sbc-timeline__dot,
  .sbc-timeline__item:nth-child(odd) .sbc-timeline__dot,
  .sbc-timeline__item:nth-child(even) .sbc-timeline__dot{left:0;right:auto}
  .sbc-timeline__item:nth-child(odd)[data-sbc-reveal],
  .sbc-timeline__item:nth-child(even)[data-sbc-reveal]{transform:translateY(24px)}
}

/* =====================================================================
   CONTACT PAGE
   ===================================================================== */
.sbc-contact-methods{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.sbc-cmethod{display:flex;flex-direction:column;gap:5px;background:#fff;border:1px solid var(--sbc-line);border-radius:var(--sbc-radius);
  padding:22px;text-decoration:none;transition:transform .25s,box-shadow .25s,border-color .25s}
a.sbc-cmethod:hover{transform:translateY(-3px);box-shadow:var(--sbc-shadow);border-color:var(--sbc-sky)}
.sbc-cmethod__ic{width:46px;height:46px;border-radius:12px;background:var(--sbc-grad-soft);color:var(--sbc-blue);display:grid;place-items:center;margin-bottom:8px}
.sbc-cmethod__ic .sbc-ico{width:22px;height:22px}
.sbc-cmethod__label{font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:var(--sbc-ink-faint);font-weight:700}
.sbc-cmethod__val{font-family:var(--sbc-font-head);font-weight:700;color:var(--sbc-navy);font-size:.98rem;line-height:1.3}

.sbc-contact-grid{display:grid;grid-template-columns:1.5fr 1fr;gap:clamp(24px,3vw,44px);align-items:start}
.sbc-contact-form h2{margin:0 0 .3em}
.sbc-contact-form__sub{color:var(--sbc-ink-soft);margin:0 0 1.4rem}
.sbc-contact-note{font-size:.85rem;color:var(--sbc-ink-faint);margin-top:1rem}

/* Contact Form 7 + fallback form styling */
.sbc-contact-form .wpcf7 input[type=text],.sbc-contact-form .wpcf7 input[type=email],.sbc-contact-form .wpcf7 input[type=tel],
.sbc-contact-form .wpcf7 textarea,.sbc-contact-form .wpcf7 select,
.sbc-fallback-form input,.sbc-fallback-form textarea{
  width:100%;border:1px solid var(--sbc-line);border-radius:10px;padding:.85em 1em;font-family:inherit;font-size:.95rem;
  background:#fff;color:var(--sbc-ink);margin-bottom:14px;transition:border-color .2s,box-shadow .2s}
.sbc-contact-form .wpcf7 input:focus,.sbc-contact-form .wpcf7 textarea:focus,
.sbc-fallback-form input:focus,.sbc-fallback-form textarea:focus{outline:none;border-color:var(--sbc-sky);box-shadow:0 0 0 3px rgba(10,155,220,.14)}
.sbc-contact-form .wpcf7 textarea,.sbc-fallback-form textarea{resize:vertical;min-height:140px}
.sbc-contact-form .wpcf7 input[type=submit],.sbc-fallback-form .sbc-btn{
  background:var(--sbc-orange);color:#fff;border:0;border-radius:999px;font-family:var(--sbc-font-head);font-weight:700;
  padding:.85em 1.8em;cursor:pointer;font-size:.95rem;transition:background .2s,transform .18s}
.sbc-contact-form .wpcf7 input[type=submit]:hover,.sbc-fallback-form .sbc-btn:hover{background:var(--sbc-orange-600);transform:translateY(-1px)}
.sbc-ff-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.sbc-ff-row input{margin-bottom:0}

.sbc-contact-card{background:#fff;border:1px solid var(--sbc-line);border-radius:var(--sbc-radius);padding:26px;margin-bottom:18px}
.sbc-contact-card h3{margin:0 0 1rem}
.sbc-contact-card .sbc-footer__contact li,.sbc-contact-card .sbc-footer__contact a{color:var(--sbc-ink)}
.sbc-contact-card .sbc-footer__contact a:hover{color:var(--sbc-orange-600)}
.sbc-contact-card .sbc-footer__contact svg{color:var(--sbc-blue)}
.sbc-social--ink a{background:var(--sbc-bg-soft);color:var(--sbc-navy)}
.sbc-social--ink a:hover{background:var(--sbc-orange);color:#fff}
.sbc-contact-map{border-radius:var(--sbc-radius);overflow:hidden;border:1px solid var(--sbc-line);aspect-ratio:4/3}
.sbc-contact-map iframe{width:100%;height:100%;border:0;display:block}
@media (max-width:880px){.sbc-contact-methods{grid-template-columns:repeat(2,1fr)}.sbc-contact-grid{grid-template-columns:1fr}}
@media (max-width:480px){.sbc-contact-methods{grid-template-columns:1fr}.sbc-ff-row{grid-template-columns:1fr}}

/* =====================================================================
   FOOTER
   ===================================================================== */
.sbc-footer{background:var(--sbc-navy);color:#cfd6ea;margin-top:60px}
.sbc-footer a{color:#cfd6ea}
.sbc-footer a:hover{color:#fff}
.sbc-footer__top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:clamp(22px,3vw,44px);padding-block:clamp(40px,5vw,64px)}
.sbc-footer__brand img{max-height:48px;margin-bottom:14px;filter:brightness(0) invert(1)}
.sbc-footer__brand p{color:#aab3d0;font-size:.9rem;max-width:34ch}
.sbc-footer h4{color:#fff;font-size:1rem;margin:0 0 1rem;font-family:var(--sbc-font-head)}
.sbc-footer ul li{margin-bottom:.6em;font-size:.9rem}
.sbc-footer__contact li{display:flex;gap:.6em;align-items:flex-start;color:#aab3d0;margin-bottom:.8em;font-size:.9rem}
.sbc-footer__contact svg{width:18px;height:18px;color:var(--sbc-sky);flex-shrink:0;margin-top:2px}
.sbc-social{display:flex;gap:10px;margin-top:14px}
.sbc-social a{width:38px;height:38px;border-radius:10px;background:rgba(255,255,255,.08);display:grid;place-items:center;transition:.2s}
.sbc-social a:hover{background:var(--sbc-orange);transform:translateY(-2px)}
.sbc-social svg{width:18px;height:18px}
.sbc-footer__pay{border-top:1px solid rgba(255,255,255,.12);padding-block:18px}
.sbc-footer__pay .sbc-container{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;font-size:.82rem;color:#aab3d0}
.sbc-footer__pay .sbc-trust__item{color:#aab3d0}
.sbc-footer__pay .sbc-trust__item svg{color:var(--sbc-sky)}

/* =====================================================================
   WOOCOMMERCE PAGE CHROME (shop / archive / single / cart / account)
   ===================================================================== */
.sbc-shop-head{background:var(--sbc-grad-soft);border-bottom:1px solid var(--sbc-line)}
.sbc-shop-head .sbc-container{padding-block:clamp(24px,4vw,46px)}
.sbc-breadcrumb,.woocommerce-breadcrumb{font-size:.82rem;color:var(--sbc-ink-soft);margin-bottom:.6rem}
.sbc-breadcrumb a,.woocommerce-breadcrumb a{color:var(--sbc-blue)}
.sbc-shop-layout{display:grid;grid-template-columns:262px 1fr;gap:clamp(20px,3vw,40px);align-items:start}
.sbc-shop-layout--full{grid-template-columns:1fr}
.sbc-shop-main{order:2;min-width:0}
.sbc-sidebar{order:1;position:sticky;top:16px}
.sbc-widget{background:#fff;border:1px solid var(--sbc-line);border-radius:var(--sbc-radius);padding:18px;margin-bottom:18px}
.sbc-widget .widget-title,.sbc-widget h2,.sbc-widget h3{font-size:1rem;margin:0 0 .8rem;color:var(--sbc-navy)}
.sbc-widget ul li{padding:.36em 0;border-bottom:1px solid var(--sbc-line);font-size:.9rem}
.sbc-widget ul li:last-child{border-bottom:0}
/* category navigation list */
.sbc-shopcats li{padding:0;border:0}
.sbc-shopcats li a{display:flex;justify-content:space-between;align-items:center;gap:8px;padding:.55em .15em;font-size:.92rem;
  color:var(--sbc-ink);border-bottom:1px solid var(--sbc-line);transition:color .2s,padding .2s}
.sbc-shopcats li:last-child a{border-bottom:0}
.sbc-shopcats li a span{font-size:.74rem;color:var(--sbc-ink-faint)}
.sbc-shopcats li a:hover{color:var(--sbc-orange-600);padding-left:.5em}
.sbc-shopcats li.is-active>a{color:var(--sbc-orange-600);font-weight:700}
/* sidebar bulk promo */
.sbc-shop-promo{display:block;background:var(--sbc-grad);color:#fff;border-radius:var(--sbc-radius);padding:22px;text-decoration:none;box-shadow:var(--sbc-shadow-sm)}
.sbc-shop-promo .sbc-ico{width:26px;height:26px;margin-bottom:10px;color:#fff}
.sbc-shop-promo strong{display:block;font-family:var(--sbc-font-head);font-size:1.08rem;margin-bottom:2px}
.sbc-shop-promo span{font-size:.85rem;color:rgba(255,255,255,.9)}

/* shop filters (WooCommerce price slider + layered nav) */
.sbc-filter .price_slider_wrapper{margin-top:8px}
.sbc-filter .ui-slider{position:relative;height:5px;background:var(--sbc-line);border-radius:5px;margin:20px 0 16px}
.sbc-filter .ui-slider .ui-slider-range{position:absolute;height:5px;background:var(--sbc-orange);border-radius:5px}
.sbc-filter .ui-slider .ui-slider-handle{position:absolute;top:-6px;width:16px;height:16px;background:#fff;border:3px solid var(--sbc-orange);border-radius:50%;margin-left:-8px;cursor:pointer;box-shadow:var(--sbc-shadow-sm)}
.sbc-filter .price_slider_amount{display:flex;align-items:center;flex-wrap:wrap;gap:10px;font-size:.85rem}
.sbc-filter .price_slider_amount .price_label{color:var(--sbc-ink-soft);order:2;flex:1}
.sbc-filter .price_slider_amount .button{order:1;background:var(--sbc-navy)!important;color:#fff!important;border-radius:999px!important;
  padding:.5em 1.3em!important;font-size:.82rem!important;border:0!important;cursor:pointer;font-family:var(--sbc-font-head);font-weight:700}
.sbc-filter .price_slider_amount .button:hover{background:var(--sbc-blue)!important}
.sbc-filter .woocommerce-widget-layered-nav-list,.sbc-filter ul{list-style:none;margin:0;padding:0}
.sbc-filter .woocommerce-widget-layered-nav-list li{padding:.42em 0;border-bottom:1px solid var(--sbc-line);font-size:.9rem}
.sbc-filter .woocommerce-widget-layered-nav-list li:last-child{border-bottom:0}
.sbc-filter .woocommerce-widget-layered-nav-list li a{color:var(--sbc-ink)}
.sbc-filter .woocommerce-widget-layered-nav-list li a:hover{color:var(--sbc-orange-600)}
.sbc-filter .woocommerce-widget-layered-nav-list li.chosen a{color:var(--sbc-orange-600);font-weight:700}
.sbc-filter .woocommerce-widget-layered-nav-list li .count{float:right;color:var(--sbc-ink-faint);font-size:.78rem}
.sbc-filter .woocommerce-widget-layered-nav-list li.chosen>a::before{content:"×";margin-right:6px;font-weight:700;color:var(--sbc-orange-600)}
/* active filters chips */
.sbc-filter .woocommerce-widget-layered-nav-list--active{display:flex;flex-wrap:wrap;gap:8px}
.sbc-filter .woocommerce-widget-layered-nav-list--active li{border:0;padding:0}
.sbc-filter .woocommerce-widget-layered-nav-list--active li a{display:inline-flex;align-items:center;gap:6px;background:var(--sbc-bg-tint);color:var(--sbc-navy);padding:.3em .7em;border-radius:999px;font-size:.82rem;font-weight:600}

/* non-home product cards (shop/category/search): gap after price + smaller,
   inset Add-to-cart button */
body:not(.sbc-home) ul.products li.product .sbc-loop-foot{padding:0 14px 16px}
body:not(.sbc-home) ul.products li.product .sbc-loop-foot .price{margin:6px 0 14px!important;padding:0!important}
body:not(.sbc-home) ul.products li.product .sbc-loop-foot .button{padding:.5em 1em!important;font-size:.8rem!important;border-radius:9px!important;box-shadow:0 3px 9px rgba(240,120,0,.22)!important}

/* toolbar: result count (left) + ordering (right) */
.sbc-shop-main .woocommerce-result-count{float:left;margin:0 0 14px;color:var(--sbc-ink-soft);font-size:.88rem;line-height:40px}
.sbc-shop-main .woocommerce-ordering{float:right;margin:0 0 14px}
.woocommerce-ordering select{border:1px solid var(--sbc-line);border-radius:999px;padding:.55em 1em;font-family:inherit;background:#fff;font-size:.9rem}
.sbc-shop-main ul.products{clear:both}
/* shop grid: smaller, denser cards so they aren't too wide */
.sbc-shop-main ul.products{grid-template-columns:repeat(4,1fr)!important;gap:16px!important}
@media (min-width:1200px){.sbc-shop-main ul.products{grid-template-columns:repeat(5,1fr)!important}}
@media (max-width:920px){
  .sbc-shop-layout,.sbc-shop-layout--full{display:block}
  .sbc-sidebar{position:static;margin-top:30px;display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px;align-items:start}
  .sbc-shop-main ul.products{grid-template-columns:repeat(4,1fr)!important}
}
@media (max-width:680px){.sbc-shop-main ul.products{grid-template-columns:repeat(3,1fr)!important}}
@media (max-width:480px){.sbc-shop-main ul.products{grid-template-columns:repeat(2,1fr)!important}}

/* Single product (PDP) — 2-column gallery + summary */
.sbc-pdp-crumbs{margin-bottom:18px}
.woocommerce div.product{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:clamp(28px,4vw,56px);align-items:start;margin-bottom:50px}
.woocommerce div.product .woocommerce-product-gallery{width:auto!important;float:none!important;margin:0!important;opacity:1!important}
.woocommerce div.product .summary{width:auto!important;float:none!important;margin:0!important}
.woocommerce div.product .woocommerce-tabs,
.woocommerce div.product .related,
.woocommerce div.product .upsells{grid-column:1/-1}
.woocommerce div.product div.images img{border-radius:var(--sbc-radius);border:1px solid var(--sbc-line)}
.woocommerce div.product .product_title{color:var(--sbc-navy);font-size:clamp(1.5rem,2.4vw,2.1rem);margin:.1em 0 .35em;line-height:1.2}
.woocommerce div.product .woocommerce-product-rating{margin-bottom:1em}
.woocommerce div.product p.price,.woocommerce div.product span.price{color:var(--sbc-navy);font-family:var(--sbc-font-head);font-weight:800;font-size:1.8rem}
.woocommerce div.product p.price del{color:var(--sbc-ink-faint);font-weight:500;font-size:.58em}
.woocommerce div.product p.price ins{color:var(--sbc-deal)}
.woocommerce div.product .woocommerce-product-details__short-description{color:var(--sbc-ink-soft);line-height:1.7;margin:1.1em 0;padding:1.1em 0;border-top:1px solid var(--sbc-line);border-bottom:1px solid var(--sbc-line)}
.woocommerce div.product form.cart{margin:1.4em 0;display:flex;flex-wrap:wrap;gap:12px;align-items:center}
.woocommerce div.product form.cart .single_add_to_cart_button{height:50px;padding:0 2.2em!important;font-size:1rem!important}
.woocommerce div.product .product_meta{font-size:.85rem;color:var(--sbc-ink-soft);border-top:1px solid var(--sbc-line);padding-top:1.1em;margin-top:1.1em}
.woocommerce div.product .product_meta>span{display:block;margin-bottom:.4em}
.woocommerce div.product .product_meta a{color:var(--sbc-blue)}
/* trust badges */
.sbc-pdp-trust{display:grid;grid-template-columns:repeat(2,1fr);gap:10px 18px;margin:1.4em 0;padding:1.2em 1.3em;background:var(--sbc-bg-soft);border-radius:var(--sbc-radius)}
.sbc-pdp-trust span{display:flex;align-items:center;gap:.55em;font-size:.86rem;color:var(--sbc-ink);font-weight:500}
.sbc-pdp-trust .sbc-ico{width:20px;height:20px;color:var(--sbc-blue);flex:0 0 auto}
/* tabs → underline style */
.woocommerce div.product .woocommerce-tabs ul.tabs{padding:0;margin:0;border-bottom:1px solid var(--sbc-line);display:flex;gap:6px;flex-wrap:wrap}
.woocommerce div.product .woocommerce-tabs ul.tabs::before{display:none}
.woocommerce div.product .woocommerce-tabs ul.tabs li{background:none;border:0;border-radius:0;padding:0;margin:0}
.woocommerce div.product .woocommerce-tabs ul.tabs li::before,
.woocommerce div.product .woocommerce-tabs ul.tabs li::after{display:none}
.woocommerce div.product .woocommerce-tabs ul.tabs li a{padding:.8em 1.1em;font-family:var(--sbc-font-head);font-weight:700;color:var(--sbc-ink-faint);font-size:.95rem;position:relative}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a,.woocommerce div.product .woocommerce-tabs ul.tabs li a:hover{color:var(--sbc-navy)}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a::after{content:"";position:absolute;left:1.1em;right:1.1em;bottom:-1px;height:3px;background:var(--sbc-orange);border-radius:3px}
.woocommerce div.product .woocommerce-tabs .panel{padding-top:1.6em;color:var(--sbc-ink-soft);line-height:1.7}
.woocommerce div.product .related>h2,.woocommerce div.product .upsells>h2{font-size:clamp(1.3rem,2vw,1.7rem);margin-bottom:1rem}
@media (max-width:880px){.woocommerce div.product{grid-template-columns:1fr}}
/* buy box card around price + add-to-cart + trust */
.woocommerce div.product .sbc-buybox{border:1px solid var(--sbc-line);border-radius:var(--sbc-radius);padding:clamp(20px,2vw,28px);background:#fff;box-shadow:var(--sbc-shadow-sm);margin-top:.5em}
.woocommerce div.product .sbc-buybox>.price{margin:0 0 .5em!important}
.woocommerce div.product .sbc-buybox .woocommerce-product-details__short-description{border-top:0;border-bottom:1px solid var(--sbc-line);padding-top:0;margin-top:0}
.woocommerce div.product .sbc-buybox .sbc-pdp-trust{margin-bottom:0}
/* gallery on a soft panel */
.woocommerce div.product .woocommerce-product-gallery{background:var(--sbc-bg-soft);border-radius:var(--sbc-radius-lg);padding:clamp(14px,2vw,26px)}
.woocommerce div.product div.images img{background:#fff}
/* sticky add-to-cart bar */
.sbc-stickybar{position:fixed;left:0;right:0;bottom:0;z-index:120;background:#fff;border-top:1px solid var(--sbc-line);
  box-shadow:0 -6px 24px rgba(16,32,44,.08);transform:translateY(110%);transition:transform .3s var(--sbc-ease)}
.sbc-stickybar.is-shown{transform:none}
.sbc-stickybar__row{display:flex;align-items:center;justify-content:space-between;gap:18px;padding-block:12px}
.sbc-stickybar__info{display:flex;flex-direction:column;min-width:0;line-height:1.25}
.sbc-stickybar__info strong{font-family:var(--sbc-font-head);color:var(--sbc-navy);font-size:.98rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sbc-stickybar__price{font-weight:700;color:var(--sbc-navy);font-size:.95rem}
.sbc-stickybar__price del{color:var(--sbc-ink-faint);font-weight:400;font-size:.85em;margin-right:.3em}
.sbc-stickybar__price ins{text-decoration:none;color:var(--sbc-deal)}
.sbc-stickybar__cta{flex:0 0 auto}
@media (max-width:560px){.sbc-stickybar__info strong{display:none}}
.woocommerce #respond input#submit,.woocommerce a.button,.woocommerce button.button,.woocommerce input.button,
.woocommerce #respond input#submit.alt,.woocommerce a.button.alt,.woocommerce button.button.alt,.woocommerce input.button.alt{
  background:var(--sbc-orange)!important;color:#fff!important;border-radius:999px!important;font-family:var(--sbc-font-head);
  font-weight:700!important;padding:.8em 1.6em!important;border:0!important;transition:background .2s,transform .18s!important}
.woocommerce #respond input#submit:hover,.woocommerce a.button:hover,.woocommerce button.button:hover,
.woocommerce input.button:hover,.woocommerce a.button.alt:hover,.woocommerce button.button.alt:hover{
  background:var(--sbc-orange-600)!important;transform:translateY(-1px)}
.woocommerce .quantity .qty{border:1px solid var(--sbc-line);border-radius:999px;padding:.6em;text-align:center}
.woocommerce span.onsale{background:var(--sbc-sale);border-radius:999px}
.woocommerce-tabs ul.tabs li.active{border-bottom-color:var(--sbc-orange)}
.woocommerce nav.woocommerce-pagination ul li a,.woocommerce nav.woocommerce-pagination ul li span{border-radius:8px}
.woocommerce nav.woocommerce-pagination ul li span.current{background:var(--sbc-blue);color:#fff;border-radius:8px}
.woocommerce .star-rating span::before{color:var(--sbc-orange)}

/* Cart / checkout / account accents */
.woocommerce-cart table.cart,.woocommerce table.shop_table{border-radius:var(--sbc-radius);overflow:hidden;border:1px solid var(--sbc-line)}
.woocommerce-info,.woocommerce-message{border-top-color:var(--sbc-blue)!important}
.woocommerce-message::before{color:var(--sbc-success)!important}
.woocommerce-MyAccount-navigation ul li.is-active a{color:var(--sbc-orange-600);font-weight:700}
.select2-container--default .select2-results__option--highlighted[aria-selected]{background:var(--sbc-blue)}

/* WooCommerce pages (cart/checkout/account) render full-width, not narrow prose */
.sbc-wc-page{width:100%;max-width:none}

/* CART page — 2-column: items + coupon (left) · cart totals (right) */
.woocommerce-cart .woocommerce{display:grid;grid-template-columns:minmax(0,1fr) 360px;gap:clamp(24px,3vw,44px);align-items:start}
.woocommerce-cart .woocommerce-notices-wrapper{grid-column:1/-1}
.woocommerce-cart .woocommerce-cart-form{grid-column:1;margin:0!important}
.woocommerce-cart .cart-collaterals{grid-column:2;width:auto!important;float:none!important;margin:0!important}
.woocommerce-cart .cart-collaterals .cross-sells{display:none}
.woocommerce-cart .cart-collaterals .cart_totals{width:auto!important;float:none!important}
.woocommerce-cart .cart_totals>h2{font-size:1.4rem;margin:0 0 1rem}
.woocommerce-cart .cart_totals table.shop_table{background:#fff}
.woocommerce-cart .cart_totals th{font-weight:700;color:var(--sbc-navy)}
.woocommerce-cart .wc-proceed-to-checkout{padding-top:16px!important}
.woocommerce-cart .wc-proceed-to-checkout .checkout-button{width:100%;display:flex!important;align-items:center;justify-content:center;height:52px;font-size:1.02rem!important}
.woocommerce-cart table.cart td.product-thumbnail img{width:56px!important;height:auto;border-radius:8px;border:1px solid var(--sbc-line)}
.woocommerce-cart table.cart td.product-name a{color:var(--sbc-blue);font-weight:600}
.woocommerce-cart table.cart .product-remove a{color:var(--sbc-sale);font-size:1.3rem;text-decoration:none}
.woocommerce-cart .actions .coupon{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.woocommerce-cart .actions .coupon .input-text{height:46px;width:220px!important;max-width:60vw;min-width:160px;
  border:1px solid var(--sbc-line)!important;border-radius:999px!important;padding:0 1.2em!important;font-size:.92rem;box-sizing:border-box}
.woocommerce-cart .actions .coupon .button{height:46px}
@media (max-width:880px){.woocommerce-cart .woocommerce{grid-template-columns:1fr}}

/* CHECKOUT page — form (left) + order-review sidebar (right) */
.woocommerce-checkout form.checkout{display:grid;grid-template-columns:minmax(0,1fr) 400px;gap:clamp(24px,3vw,44px);align-items:start}
.woocommerce-checkout #customer_details{grid-column:1;grid-row:1/span 2}
.woocommerce-checkout #order_review_heading{grid-column:2;grid-row:1;margin:0 0 1rem!important;font-size:1.35rem}
.woocommerce-checkout #order_review{grid-column:2;grid-row:2}
/* stack billing + shipping in the left column */
.woocommerce-checkout .col2-set{display:block}
.woocommerce-checkout .col2-set .col-1,.woocommerce-checkout .col2-set .col-2{width:auto!important;float:none!important;margin-bottom:1.6em}
.woocommerce-checkout h3{font-size:1.2rem;color:var(--sbc-navy)}
/* form fields */
.woocommerce-checkout .form-row{margin-bottom:14px}
.woocommerce-checkout .form-row input.input-text,.woocommerce-checkout .form-row textarea,.woocommerce-checkout select:not([class*=wc-block]){
  border:1px solid var(--sbc-line)!important;border-radius:10px!important;padding:.7em .9em!important;min-height:46px;line-height:normal}

/* ---- WooCommerce BLOCKS checkout — floating-label select (Country/State) ----
   The block floats the label over the field, so the <select> needs top padding
   to keep the value clear of the label. My generic select rule was wiping that
   padding out (value rode up under the label). Restore proper spacing. */
.wc-blocks-components-select__select,.wc-block-components-select__select,
.woocommerce-checkout select[class*=wc-block]{
  height:54px!important;min-height:54px!important;
  padding:26px 12px 4px!important;line-height:1.2!important;
  border-radius:10px!important;border-color:var(--sbc-line)!important}
.wc-blocks-components-select__label,.wc-block-components-select__label{line-height:1.2}
/* block text inputs (First name, Address…) keep their own floating-label
   spacing — give them only the theme's rounded border */
.wc-block-components-text-input input,.wc-blocks-components-text-input input{border-radius:10px}
/* Force the label ABOVE the field with a clear gap — works even if a plugin
   floats the label over the field. Scoped to rows that contain a text input or
   select so checkbox/radio rows are untouched. */
.woocommerce-checkout .form-row:has(.input-text),
.woocommerce-checkout .form-row:has(select),
.woocommerce-checkout .form-row:has(.select2){display:flex;flex-direction:column}
.woocommerce-checkout .form-row:has(.input-text)>label,
.woocommerce-checkout .form-row:has(select)>label,
.woocommerce-checkout .form-row:has(.select2)>label{order:-1;display:block!important;position:static!important;transform:none!important;
  font-weight:600;color:var(--sbc-navy);font-size:.9rem;margin:0 0 8px!important;line-height:1.3;padding:0!important;background:none!important;width:auto!important}
.woocommerce-checkout .form-row:has(.input-text)>.woocommerce-input-wrapper,
.woocommerce-checkout .form-row:has(select)>.woocommerce-input-wrapper,
.woocommerce-checkout .form-row:has(.select2)>.woocommerce-input-wrapper{order:1}
/* select2 dropdowns (country / state) — size the proper select2 parts so the
   value is vertically centred and the arrow lines up */
.woocommerce-checkout .select2-container--default .select2-selection--single{height:46px!important;border:1px solid var(--sbc-line)!important;border-radius:10px!important}
.woocommerce-checkout .select2-container--default .select2-selection--single .select2-selection__rendered{line-height:44px!important;padding-left:.9em!important;padding-right:2em;color:var(--sbc-ink)}
.woocommerce-checkout .select2-container--default .select2-selection--single .select2-selection__arrow{height:44px!important;top:1px;right:10px}
.woocommerce-checkout .select2-container--default.select2-container--focus .select2-selection--single,
.woocommerce-checkout .select2-container--default.select2-container--open .select2-selection--single{border-color:var(--sbc-sky)!important;box-shadow:0 0 0 3px rgba(10,155,220,.14)}
/* order-review card */
.woocommerce-checkout #order_review{background:#fff;border:1px solid var(--sbc-line);border-radius:var(--sbc-radius);padding:22px;box-shadow:var(--sbc-shadow-sm)}
.woocommerce-checkout #order_review table.shop_table{border:0!important;margin:0}
.woocommerce-checkout #order_review .cart-subtotal th,.woocommerce-checkout #order_review .order-total th{color:var(--sbc-navy);font-weight:700}
.woocommerce-checkout #payment{background:transparent!important;border-radius:0}
.woocommerce-checkout #payment ul.payment_methods{border:0;padding:1em 0}
.woocommerce-checkout #place_order{width:100%;height:54px;font-size:1.05rem!important;margin-top:6px}
@media (max-width:880px){
  .woocommerce-checkout form.checkout{grid-template-columns:1fr}
  .woocommerce-checkout #customer_details,
  .woocommerce-checkout #order_review_heading,
  .woocommerce-checkout #order_review{grid-column:1;grid-row:auto}
}

/* =====================================================================
   GENERIC PAGE / BLOG / 404 / SEARCH
   ===================================================================== */
.sbc-page{padding-block:clamp(30px,5vw,64px)}
.sbc-page__hero{background:var(--sbc-grad-soft);border-bottom:1px solid var(--sbc-line);padding-block:clamp(30px,5vw,56px);text-align:center}
.sbc-prose{max-width:760px;margin-inline:auto}
.sbc-prose img{border-radius:var(--sbc-radius);margin-block:1.2em}
.sbc-prose h2,.sbc-prose h3{margin-top:1.6em}
.sbc-blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--sbc-gap)}
.sbc-post-card{background:#fff;border:1px solid var(--sbc-line);border-radius:var(--sbc-radius);overflow:hidden;box-shadow:var(--sbc-shadow-sm);transition:.26s var(--sbc-ease);display:flex;flex-direction:column}
.sbc-post-card:hover{transform:translateY(-5px);box-shadow:var(--sbc-shadow-lg)}
.sbc-post-card__media{aspect-ratio:16/9;overflow:hidden;background:var(--sbc-bg-soft)}
.sbc-post-card__media img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.sbc-post-card:hover .sbc-post-card__media img{transform:scale(1.05)}
.sbc-post-card__body{padding:18px;flex:1;display:flex;flex-direction:column}
.sbc-post-card__meta{font-size:.76rem;color:var(--sbc-ink-faint);margin-bottom:.5em}
.sbc-post-card h3{font-size:1.1rem}
.sbc-post-card__more{margin-top:auto;font-weight:700;color:var(--sbc-orange-600);font-size:.88rem}
.sbc-404{text-align:center;padding-block:clamp(50px,8vw,110px)}
.sbc-404 .code{font-family:var(--sbc-font-head);font-size:clamp(5rem,18vw,11rem);line-height:1;
  background:var(--sbc-grad);-webkit-background-clip:text;background-clip:text;color:transparent;font-weight:800}

/* =====================================================================
   SCROLL ANIMATIONS / KEYFRAMES
   ===================================================================== */
[data-sbc-reveal]{opacity:0;transform:translateY(24px);transition:opacity .6s var(--sbc-ease),transform .6s var(--sbc-ease)}
[data-sbc-reveal].is-in{opacity:1;transform:none}
@keyframes sbc-fade-up{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
@keyframes sbc-float{0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)}}
@keyframes sbc-morph{0%,100%{border-radius:38% 62% 58% 42%/45% 40% 60% 55%}50%{border-radius:55% 45% 42% 58%/55% 58% 42% 45%}}
@keyframes sbc-marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@keyframes sbc-pop{0%{transform:scale(1)}40%{transform:scale(1.5)}100%{transform:scale(1)}}

/* =====================================================================
   RESPONSIVE
   ===================================================================== */
@media (max-width:1024px){
  .sbc-footer__top{grid-template-columns:1fr 1fr}
  .sbc-bulk{grid-template-columns:1fr}
  .sbc-why,.sbc-testi{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:880px){
  :root{--sbc-header-h:64px}
  .sbc-topbar__nav{display:none}
  .sbc-mid__row{display:flex;flex-wrap:wrap;align-items:center;gap:12px}
  .sbc-logo{margin-right:auto}
  .sbc-csearch{order:3;flex:1 1 100%;max-width:none;margin-top:4px}
  .sbc-navbar{display:none}
  .sbc-burger{display:flex}
  .sbc-acts .sbc-act span{display:none}
  .sbc-legacy{grid-template-columns:1fr}
}
@media (max-width:560px){
  .sbc-products,ul.products{grid-template-columns:repeat(2,1fr);gap:12px}
  .sbc-cat-grid{grid-template-columns:repeat(2,1fr);gap:12px}
  .sbc-why,.sbc-testi,.sbc-footer__top,.sbc-shop-layout{grid-template-columns:1fr}
  .sbc-shop-layout{display:block}
  .sbc-sidebar{position:static;margin-bottom:20px}
}

/* Reduced motion */
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  [data-sbc-reveal]{opacity:1;transform:none}
}
