/*
Theme Name: Hajupala
Theme URI: https://hajupala.fi
Description: hajupala.fi (Scentbit Oy) -verkkokaupan lapsiteema. Pohjana Storefront. Tekninen, rauhallinen ja moderni ilme koirien hajukoulutuksen tuotteille. Ks. docs/brand-guidelines.md.
Author: Scentbit Oy
Author URI: https://hajupala.fi
Template: storefront
Version: 0.13.0
Requires PHP: 7.4
Text Domain: hajupala
*/

/* ==========================================================================
   DESIGN TOKENS — brändin värit & typografia (docs/brand-guidelines.md)
   ========================================================================== */
:root {
  /* Värit */
  --hp-teal-dark:   #0F3439;
  --hp-teal-deep:   #1E5964;
  --hp-turquoise:   #56A7A7;
  --hp-graphite:    #3A3F43;
  --hp-silver:      #E5E8E9;
  --hp-beige:       #F5F2EF;
  --hp-white:       #FFFFFF;

  /* Johdetut roolit */
  --hp-bg:          var(--hp-beige);
  --hp-surface:     var(--hp-white);
  --hp-text:        var(--hp-graphite);
  --hp-heading:     var(--hp-teal-dark);
  --hp-link:        var(--hp-teal-deep);
  --hp-link-hover:  var(--hp-turquoise);
  --hp-border:      var(--hp-silver);

  /* Typografia */
  --hp-font-head:   "Manrope", system-ui, -apple-system, "Segoe UI", sans-serif;
  --hp-font-body:   "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;

  /* Mitat */
  --hp-radius:      16px;
  --hp-radius-md:   14px;
  --hp-radius-sm:   8px;
  --hp-shadow:      0 1px 2px rgba(15,52,57,.04), 0 10px 30px rgba(15,52,57,.06);
  --hp-shadow-lg:   0 16px 40px rgba(15,52,57,.12);
  --hp-maxread:     720px;
}

/* ==========================================================================
   PERUSTA — typografia & taustat
   ========================================================================== */
body,
.site {
  background-color: var(--hp-bg);
}

body {
  font-family: var(--hp-font-body);
  color: var(--hp-text);
  line-height: 1.65;
}

h1, h2, h3, h4, h5, h6,
.site-title,
.entry-title,
.widget-title,
.wp-block-heading {
  font-family: var(--hp-font-head);
  color: var(--hp-heading);
  font-weight: 700;
  letter-spacing: -0.015em;
  line-height: 1.2;
}

a {
  color: var(--hp-link);
  text-decoration-thickness: 1px;
  text-underline-offset: 2px;
}
a:hover,
a:focus {
  color: var(--hp-link-hover);
}

/* Storefrontin oletus: poista sisällön ympäriltä valkoinen "kortti", jotta
   osiot voivat hengittää beigellä taustalla. (Tuotekortit tyylitellään erikseen.) */
.hentry,
.page .hentry {
  background: transparent;
  border: 0;
  border-radius: 0;
}

/* Piilota turha "Etusivu"-otsikko etusivulta */
.home.page .entry-header,
.home.page .entry-title {
  display: none;
}

/* Mukava lukuleveys leipätekstille (poislukien layout-lohkot) */
.entry-content > p {
  max-width: var(--hp-maxread);
}

/* ==========================================================================
   HEADER & NAVIGAATIO
   ========================================================================== */
.site-header {
  background-color: var(--hp-teal-dark);
  border-bottom: 1px solid rgba(255, 255, 255, 0.07);
}
.site-header,
.site-header a,
.site-header .site-title a,
.site-branding .site-description {
  color: var(--hp-white);
}
.site-header a:hover { color: var(--hp-turquoise); }

.main-navigation ul li a,
.site-header-cart .cart-contents,
.storefront-handheld-footer-bar a {
  color: var(--hp-white);
  font-family: var(--hp-font-head);
  font-weight: 600;
}
.main-navigation ul li a:hover,
.site-header-cart .cart-contents:hover {
  color: var(--hp-turquoise);
}
.main-navigation ul li.current-menu-item > a {
  color: var(--hp-turquoise);
}

/* ==========================================================================
   PAINIKKEET — Storefront, WooCommerce & Gutenberg-lohkot
   ========================================================================== */
button,
input[type="button"],
input[type="reset"],
input[type="submit"],
.button,
.added_to_cart,
.woocommerce #respond input#submit,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.wp-block-button__link.wp-element-button,
.wp-block-button .wp-block-button__link {
  background-color: var(--hp-teal-deep);
  color: var(--hp-white);
  border: 2px solid var(--hp-teal-deep);
  border-radius: var(--hp-radius-sm);
  font-family: var(--hp-font-head);
  font-weight: 600;
  padding: 0.7em 1.5em;
  transition: background-color .15s ease, border-color .15s ease, color .15s ease, transform .12s ease;
}

button:hover,
input[type="submit"]:hover,
.button:hover,
.added_to_cart:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.wp-block-button__link.wp-element-button:hover,
.wp-block-button .wp-block-button__link:hover {
  background-color: var(--hp-teal-dark);
  border-color: var(--hp-teal-dark);
  color: var(--hp-white);
  transform: translateY(-1px);
}

/* WooCommercen korostuspainike (esim. "lisää koriin") */
.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce input.button.alt,
.woocommerce #respond input#submit.alt {
  background-color: var(--hp-turquoise);
  border-color: var(--hp-turquoise);
  color: var(--hp-teal-dark);
}
.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover,
.woocommerce input.button.alt:hover {
  background-color: var(--hp-teal-deep);
  border-color: var(--hp-teal-deep);
  color: var(--hp-white);
}

/* ==========================================================================
   ETUSIVU — HERO (.sb-hero)
   ========================================================================== */
.sb-hero {
  background: linear-gradient(135deg, var(--hp-teal-dark) 0%, var(--hp-teal-deep) 100%);
  color: var(--hp-white);
  border-radius: var(--hp-radius);
  padding: clamp(2.75rem, 6vw, 5.5rem) clamp(1.5rem, 5vw, 4rem);
  text-align: center;
  margin-block: 0 3.5rem;
  box-shadow: var(--hp-shadow);
}
.sb-hero h1 {
  color: var(--hp-white);
  font-size: clamp(2rem, 1.2rem + 3vw, 3.25rem);
  font-weight: 800;
  margin: 0 auto .75rem;
  max-width: 16ch;
}
.sb-hero p {
  color: rgba(255, 255, 255, 0.88);
  font-size: clamp(1.05rem, 1rem + .4vw, 1.25rem);
  max-width: 52ch;
  margin: 0 auto 2rem;
}
.sb-hero .wp-block-buttons {
  justify-content: center;
  gap: .9rem;
}
/* Hero: ensimmäinen painike täysi, toinen "ghost"/outline */
.sb-hero .wp-block-button:first-child .wp-block-button__link {
  background-color: var(--hp-turquoise);
  border-color: var(--hp-turquoise);
  color: var(--hp-teal-dark);
}
.sb-hero .wp-block-button:first-child .wp-block-button__link:hover {
  background-color: var(--hp-white);
  border-color: var(--hp-white);
  color: var(--hp-teal-dark);
}
.sb-hero .wp-block-button:nth-child(2) .wp-block-button__link {
  background-color: transparent;
  border-color: rgba(255, 255, 255, 0.55);
  color: var(--hp-white);
}
.sb-hero .wp-block-button:nth-child(2) .wp-block-button__link:hover {
  background-color: rgba(255, 255, 255, 0.10);
  border-color: var(--hp-white);
  color: var(--hp-white);
}

/* ==========================================================================
   ETUSIVU — HYÖTYKORTIT (.sb-card-grid / .sb-card)
   ========================================================================== */
.sb-card-grid {
  gap: 1.5rem;
  margin-block: 0 3.5rem;
  /* Tasakorkeat kortit desktopilla: korkeus määräytyy korkeimman kortin mukaan.
     stretch venyttää lyhyemmät samaan korkeuteen (sisältö ladotaan ylhäältä,
     jolloin aksenttiviivat pysyvät linjassa). Mobiilissa kortit ovat allekkain,
     joten venytystä ei tapahdu. !important ohittaa WP-ytimen align-items-säännön. */
  align-items: stretch !important;
}

/* Storefront-yhteensopivuus: sen gutenberg-blocks.css nollaa ei-viimeisten
   sarakkeiden padding-rightin ja lisää margin-rightin (>=782px), mikä teki
   korttien oikeasta reunasta epätasaisen ja toi tuplavälistyksen flex-gapin
   kanssa. Palautetaan tasainen padding ja annetaan flex-gapin hoitaa välit. */
.sb-card-grid .wp-block-column {
  margin-left: 0 !important;
  margin-right: 0 !important;
  padding-left: 2.25rem !important;
  padding-right: 2.25rem !important;
}
@media (max-width: 768px) {
  .sb-card-grid .wp-block-column {
    padding-left: 1.5rem !important;
    padding-right: 1.5rem !important;
  }
}
.sb-card {
  background: var(--hp-surface);
  border: 1px solid var(--hp-border);
  border-radius: var(--hp-radius-md);
  padding: 2.5rem 2.25rem;
  box-shadow: var(--hp-shadow);
  transition: transform .15s ease, box-shadow .15s ease;
}
.sb-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--hp-shadow-lg);
}
/* Pieni aksenttiviiva otsikon ylle */
.sb-card h3 {
  margin: 0 0 .75rem;
  color: var(--hp-teal-dark);
  font-size: 1.2rem;
  padding-top: .85rem;
  border-top: 3px solid var(--hp-turquoise);
  display: inline-block;
}
.sb-card p {
  margin: 0;
  font-size: .98rem;
}
/* Korttiotsikon linkki (esim. Treenivinkit-landing) perii otsikkovärin */
.sb-card h3 a {
  color: inherit;
  text-decoration: none;
}
.sb-card h3 a:hover { color: var(--hp-teal-deep); }

/* ==========================================================================
   ETUSIVU — TUOTENOSTO (.sb-product-highlight)
   ========================================================================== */
.sb-product-highlight {
  background: var(--hp-surface);
  border: 1px solid var(--hp-border);
  border-radius: var(--hp-radius);
  padding: clamp(1.75rem, 4vw, 3rem);
  margin-block: 0 3.5rem;
  box-shadow: var(--hp-shadow);
}
.sb-product-highlight .sb-ph-cols {
  gap: clamp(1.5rem, 4vw, 3rem);
  align-items: center;
}
.sb-product-highlight h2 {
  margin: 0 0 .75rem;
  font-size: clamp(1.5rem, 1.2rem + 1.5vw, 2.1rem);
}
.sb-product-highlight p {
  max-width: 52ch;
  margin: 0 0 1.75rem;
}
.sb-product-highlight .sb-product-image { margin: 0; }
.sb-product-highlight .sb-product-image img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: var(--hp-radius-md);
  box-shadow: var(--hp-shadow);
}

/* ==========================================================================
   ETUSIVU — INFO-OSIO (.sb-info-section)
   ========================================================================== */
.sb-info-section {
  max-width: var(--hp-maxread);
  margin: 0 auto 3rem;
  padding-top: .5rem;
}
.sb-info-section h2 {
  font-size: clamp(1.5rem, 1.2rem + 1.5vw, 2.1rem);
  margin-bottom: 1rem;
}
.sb-info-section p { margin-bottom: 1.1rem; }

/* ==========================================================================
   WOOCOMMERCE — TUOTEKORTIT & HINNAT
   ========================================================================== */
.woocommerce ul.products li.product {
  background: var(--hp-surface);
  border: 1px solid var(--hp-border);
  border-radius: var(--hp-radius-md);
  padding: 1rem 1rem 1.25rem;
  box-shadow: var(--hp-shadow);
  transition: transform .15s ease, box-shadow .15s ease;
}
.woocommerce ul.products li.product:hover {
  transform: translateY(-3px);
  box-shadow: var(--hp-shadow-lg);
}
.woocommerce ul.products li.product .price,
.price,
.woocommerce div.product p.price,
.woocommerce div.product span.price {
  color: var(--hp-teal-deep);
  font-family: var(--hp-font-head);
  font-weight: 700;
}

/* ==========================================================================
   FOOTER
   ========================================================================== */
.site-footer {
  background-color: var(--hp-teal-dark);
  color: var(--hp-silver);
}
.site-footer a { color: var(--hp-turquoise); }
.site-footer a:hover { color: var(--hp-white); }

/* ==========================================================================
   RESPONSIIVISUUS
   ========================================================================== */
@media (max-width: 768px) {
  .sb-card { padding: 1.75rem 1.5rem; }
  .sb-hero .wp-block-buttons { flex-direction: column; align-items: center; }
}

/* ==========================================================================
   WOOCOMMERCE — KAUPPA-, TUOTE- JA KORISIVU
   ========================================================================== */

/* --- Otsikot & lajittelu (arkisto/kauppa) --- */
.woocommerce-products-header__title,
.woocommerce .page-title {
  font-family: var(--hp-font-head);
  color: var(--hp-heading);
}
.woocommerce .woocommerce-result-count {
  color: var(--hp-text);
}
.woocommerce .woocommerce-ordering select {
  border: 1px solid var(--hp-border);
  border-radius: var(--hp-radius-sm);
  background-color: var(--hp-white);
  color: var(--hp-text);
  padding: .45em .7em;
}

/* --- Tuotekortit (kauppa-arkisto) --- */
.woocommerce ul.products li.product .woocommerce-loop-product__title {
  font-family: var(--hp-font-head);
  font-weight: 600;
  color: var(--hp-heading);
  font-size: 1.05rem;
}
.woocommerce ul.products li.product a img {
  border-radius: var(--hp-radius-sm);
  background: var(--hp-white);
}

/* --- Tuotesivu: variaatiotaulukko & lomakekentät --- */
.woocommerce .variations th.label,
.woocommerce .variations th.label label {
  font-family: var(--hp-font-head);
  font-weight: 600;
  color: var(--hp-heading);
}
.woocommerce .variations td,
.woocommerce .variations th {
  padding-bottom: .9rem;
  vertical-align: middle;
}
.woocommerce .variations select,
.woocommerce .quantity .qty,
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row select {
  border: 1px solid var(--hp-border);
  border-radius: var(--hp-radius-sm);
  background-color: var(--hp-white);
  color: var(--hp-text);
  padding: .55em .75em;
  line-height: 1.4;
}
.woocommerce .variations select:focus,
.woocommerce .quantity .qty:focus,
.woocommerce form .form-row input.input-text:focus {
  border-color: var(--hp-turquoise);
  outline: 3px solid rgba(86, 167, 167, .25);
  outline-offset: 0;
}
.woocommerce a.reset_variations {
  color: var(--hp-link);
  font-size: .9em;
}

/* Valitun variaation hinta */
.woocommerce div.product .woocommerce-variation-price .price,
.woocommerce .single_variation .price {
  color: var(--hp-teal-deep);
  font-family: var(--hp-font-head);
  font-weight: 700;
}

/* Pääpainike "Lisää ostoskoriin" — korostettu, brändinvärinen */
.woocommerce div.product form.cart .button.single_add_to_cart_button,
.woocommerce .single_add_to_cart_button.button.alt {
  background-color: var(--hp-teal-deep);
  border-color: var(--hp-teal-deep);
  color: var(--hp-white);
  padding: .85em 2.2em;
  font-size: 1.05rem;
}
.woocommerce div.product form.cart .button.single_add_to_cart_button:hover,
.woocommerce .single_add_to_cart_button.button.alt:hover {
  background-color: var(--hp-teal-dark);
  border-color: var(--hp-teal-dark);
  color: var(--hp-white);
}

/* Varastotila */
.woocommerce div.product .stock.in-stock {
  color: var(--hp-teal-deep);
  font-weight: 600;
}

/* --- Välilehdet (kuvaus / lisätiedot / arviot) --- */
.woocommerce-tabs ul.tabs li a {
  font-family: var(--hp-font-head);
  font-weight: 600;
  color: var(--hp-graphite);
}
.woocommerce-tabs ul.tabs li.active a,
.woocommerce-tabs ul.tabs li a:hover {
  color: var(--hp-teal-dark);
}
.woocommerce-tabs .panel h2 {
  color: var(--hp-heading);
}

/* --- Lisätiedot-taulukko (attribuutit) --- */
.woocommerce table.shop_attributes {
  border: 1px solid var(--hp-border);
  border-radius: var(--hp-radius-sm);
  overflow: hidden;
}
.woocommerce table.shop_attributes th {
  font-family: var(--hp-font-head);
  color: var(--hp-heading);
  background: var(--hp-beige);
}

/* --- Liittyvät tuotteet --- */
.woocommerce .related.products > h2,
.woocommerce .upsells.products > h2 {
  font-family: var(--hp-font-head);
  color: var(--hp-heading);
}

/* --- Ostoskori- ja kassalohko (uusi Cart/Checkout block) --- */
.wc-block-components-button:not(.is-link),
.wp-block-woocommerce-cart .wc-block-cart__submit-button,
.wc-block-cart__submit-button,
.wc-block-components-totals-coupon__button {
  background-color: var(--hp-teal-deep) !important;
  border-color: var(--hp-teal-deep) !important;
  color: var(--hp-white) !important;
  border-radius: var(--hp-radius-sm) !important;
}
.wc-block-components-button:not(.is-link):hover {
  background-color: var(--hp-teal-dark) !important;
  border-color: var(--hp-teal-dark) !important;
}

/* --- Ilmoitukset (lisätty koriin / virheet) --- */
.woocommerce-message,
.woocommerce-info {
  border-top-color: var(--hp-turquoise);
}
.woocommerce-message::before,
.woocommerce-info::before {
  color: var(--hp-turquoise);
}

/* ==========================================================================
   USEIN KYSYTTYÄ — haitari (Details-lohkot)
   ========================================================================== */
.sb-faq {
  max-width: var(--hp-maxread);
  margin-inline: auto;
}
.sb-faq h2 {
  margin-top: 2.5rem;
  margin-bottom: 1rem;
  font-size: clamp(1.3rem, 1.1rem + 1vw, 1.7rem);
}
.sb-faq-item {
  background: var(--hp-surface);
  border: 1px solid var(--hp-border);
  border-radius: var(--hp-radius-sm);
  margin-bottom: .75rem;
  padding: 0 1.25rem;
  transition: border-color .15s ease, box-shadow .15s ease;
}
.sb-faq-item[open] {
  border-color: var(--hp-turquoise);
  box-shadow: var(--hp-shadow);
}
.sb-faq-item summary {
  cursor: pointer;
  list-style: none;
  position: relative;
  padding: 1rem 2rem 1rem 0;
  font-family: var(--hp-font-head);
  font-weight: 600;
  color: var(--hp-heading);
}
.sb-faq-item summary::-webkit-details-marker { display: none; }
.sb-faq-item summary::after {
  content: "+";
  position: absolute;
  right: .1rem;
  top: 50%;
  transform: translateY(-50%);
  font-size: 1.5rem;
  line-height: 1;
  color: var(--hp-turquoise);
}
.sb-faq-item[open] summary::after { content: "−"; }
.sb-faq-item summary:hover { color: var(--hp-teal-deep); }
.sb-faq-item p {
  margin: 0 0 1rem;
}
.sb-faq-item .sb-faq-ref {
  font-size: .85rem;
  color: #6b7177;
  border-left: 3px solid var(--hp-border);
  padding-left: .85rem;
}

/* ==========================================================================
   BLOGIARTIKKELI (single post) — luettava, tasattu sarake
   Kuva, otsikko ja teksti samaan leveyteen ja keskitettynä.
   ========================================================================== */
.single-post .hentry {
  max-width: 800px;
  margin-inline: auto;
}
/* Kumotaan globaali kappaleiden kavennus postauksissa, jotta teksti tasautuu
   kuvan ja otsikoiden kanssa samaan leveyteen. */
.single-post .entry-content > p,
.single-post .entry-content > ul,
.single-post .entry-content > ol {
  max-width: none;
}
.single-post .post-thumbnail img,
.single-post .entry-content img {
  border-radius: var(--hp-radius-sm);
}

/* ==========================================================================
   OTA YHTEYTTÄ — yhteystiedot & lomake (Contact Form 7)
   ========================================================================== */
.sb-contact {
  max-width: 920px;
  margin-inline: auto;
}
.sb-contact-cols {
  gap: clamp(1.5rem, 4vw, 3rem);
  margin-top: 1.5rem;
}
.sb-contact-cols h2 {
  margin-top: 0;
  font-size: clamp(1.3rem, 1.1rem + 1vw, 1.6rem);
}

/* Lomakekentät */
.wpcf7-form .sb-field { margin-bottom: 1.1rem; }
.wpcf7-form label {
  display: block;
  font-family: var(--hp-font-head);
  font-weight: 600;
  color: var(--hp-heading);
}
.wpcf7-form .req { color: var(--hp-turquoise); }
.wpcf7-form input[type="text"],
.wpcf7-form input[type="email"],
.wpcf7-form textarea {
  width: 100%;
  margin-top: .35rem;
  padding: .6em .75em;
  font: inherit;
  color: var(--hp-text);
  background: var(--hp-white);
  border: 1px solid var(--hp-border);
  border-radius: var(--hp-radius-sm);
}
.wpcf7-form input:focus,
.wpcf7-form textarea:focus {
  border-color: var(--hp-turquoise);
  outline: 3px solid rgba(86, 167, 167, .25);
  outline-offset: 0;
}
.wpcf7-form textarea { min-height: 160px; resize: vertical; }
.wpcf7-form .sb-acceptance {
  font-size: .92rem;
  color: var(--hp-text);
}

/* Lähetä-painike */
.wpcf7-form .wpcf7-submit {
  background-color: var(--hp-teal-deep);
  color: var(--hp-white);
  border: 2px solid var(--hp-teal-deep);
  border-radius: var(--hp-radius-sm);
  font-family: var(--hp-font-head);
  font-weight: 600;
  padding: .7em 1.9em;
  cursor: pointer;
  transition: background-color .15s ease, border-color .15s ease;
}
.wpcf7-form .wpcf7-submit:hover {
  background-color: var(--hp-teal-dark);
  border-color: var(--hp-teal-dark);
}

/* Validointi & ilmoitukset */
.wpcf7-not-valid-tip { color: #b3261e; font-size: .9rem; }
.wpcf7 .wpcf7-response-output {
  border-radius: var(--hp-radius-sm);
  margin: 1rem 0 0;
}

/* ==========================================================================
   LAKISÄÄTEISET SIVUT (toimitus, palautukset, tietosuoja)
   ========================================================================== */
.sb-legal {
  max-width: 800px;
  margin-inline: auto;
}
.sb-legal h2 {
  margin-top: 2.25rem;
  font-size: clamp(1.25rem, 1.1rem + .8vw, 1.55rem);
}
.sb-legal h2:first-of-type { margin-top: 1.5rem; }
.sb-legal ul { margin-bottom: 1.1rem; }

/* ==========================================================================
   FOOTER-VALIKKO & CREDIT
   ========================================================================== */
.site-footer .hp-footer-nav { text-align: center; }
.hp-footer-menu {
  list-style: none;
  margin: 0 auto 1rem;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: .5rem 1.75rem;
}
.hp-footer-menu a {
  color: var(--hp-silver);
  font-family: var(--hp-font-head);
  font-weight: 600;
  text-decoration: none;
}
.hp-footer-menu a:hover,
.hp-footer-menu .current-menu-item > a { color: var(--hp-turquoise); }
.site-footer .site-info {
  text-align: center;
  color: var(--hp-silver);
}
.site-footer .site-info a { color: var(--hp-turquoise); }
.site-footer .site-info a:hover { color: var(--hp-white); }
/* Footer-linkkien hover (riittävä spesifisyys voittaa Storefrontin
   Customizer-säännön .site-footer a:not(.button):not(.components-button)). */
.site-footer a:not(.button):not(.components-button):hover {
  color: var(--hp-white);
}

/* ==========================================================================
   TOIMITUSAIKA-INDIKAATTORI (tuotesivu, variaation valinta)
   ========================================================================== */
.sb-delivery {
  display: flex;
  align-items: baseline;
  gap: .55rem;
  margin: .5rem 0 0;
  font-size: .95rem;
  color: var(--hp-text);
}
.sb-delivery::before {
  content: "";
  flex: 0 0 auto;
  width: .6rem;
  height: .6rem;
  border-radius: 50%;
  transform: translateY(1px);
  background: var(--hp-silver);
}
.sb-delivery.is-instock::before { background: #2e9e5b; } /* vihreä: varastossa */
.sb-delivery.is-soon::before    { background: #d8a200; } /* keltainen: 5–14 vrk */
.sb-delivery.is-later::before   { background: #c2541f; } /* oranssi: 14–22 vrk */
