/*
Theme Name: FeltieBuddy Child
Theme URI: https://feltiebuddy.bond/
Description: Child theme for Feltie Buddy WooCommerce storefront design.
Author: Feltie Buddy
Template: blocksy
Version: 0.1.0
Text Domain: feltiebuddy-child
*/

:root {
  --fb-font: "Quattrocento", Georgia, serif;
  --fb-heading-font: "Playfair Display", Georgia, serif;
  --fb-ui-font: "Poppins", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --fb-ink: #414042;
  --fb-muted: #727070;
  --fb-paper: #ffffff;
  --fb-card: #ffffff;
  --fb-soft: #f7fbfb;
  --fb-coral: #67c5af;
  --fb-coral-dark: #017784;
  --fb-moss: #3eb397;
  --fb-sky: #edf8fa;
  --fb-brown: #f0b4ac;
  --fb-line: #e7eeee;
  --fb-fog: #fbfdfd;
  --fb-glass: rgba(255, 255, 255, 0.9);
  --fb-tomato: #da3d16;
  --fb-yellow: #e3d647;
  --fb-blush: #f0b4ac;
}

body {
  font-family: var(--fb-font);
  color: var(--fb-ink);
  background: var(--fb-paper);
  background-size: auto;
  font-size: 16px;
  line-height: 1.62;
  letter-spacing: 0.005em;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

h1,
h2,
h3,
h4,
h5,
h6,
button {
  font-family: var(--fb-ui-font);
}

input,
textarea,
select {
  font-family: var(--fb-font);
}

h1,
h2,
h3 {
  font-family: var(--fb-heading-font);
  font-weight: 900;
  letter-spacing: 0;
}

#header,
.ct-footer,
.entry-header {
  display: none !important;
}

.site-main,
#main,
[data-prefix="single_page"] [class*="ct-container"] {
  margin-top: 0 !important;
}

a {
  color: var(--fb-coral-dark);
}

a:hover {
  color: var(--fb-ink);
}

.wp-block-button__link,
.single_add_to_cart_button,
.checkout-button,
.button {
  font-family: var(--fb-ui-font);
  border-radius: 6px;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.wp-block-button__link,
.single_add_to_cart_button,
.checkout-button,
.woocommerce #respond input#submit,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button {
  background: var(--fb-coral);
  color: var(--fb-paper);
}

.wp-block-button__link:hover,
.single_add_to_cart_button:hover,
.checkout-button:hover,
.woocommerce #respond input#submit:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover {
  background: var(--fb-coral-dark);
  color: var(--fb-paper);
}

.is-style-outline > .wp-block-button__link,
.wp-block-button.is-style-outline .wp-block-button__link {
  background: transparent;
  border-color: var(--fb-coral);
  color: var(--fb-coral-dark);
}

.fb-announcement {
  background: var(--fb-soft);
  color: var(--fb-ink);
  font-size: 14px;
  font-weight: 600;
  padding: 8px 18px;
}

.fb-announcement p {
  margin: 0;
}

.fb-topbar {
  position: relative;
  z-index: 60;
  background: rgba(255, 255, 255, 0.94);
  border-bottom: 1px solid var(--fb-line);
  box-shadow: 0 1px 16px rgba(65, 64, 66, 0.045);
  backdrop-filter: blur(18px) saturate(1.18);
  -webkit-backdrop-filter: blur(18px) saturate(1.18);
  color: var(--fb-ink);
  font-size: 13px;
}

.fb-topbar__inner {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 24px;
  max-width: 1280px;
  margin: 0 auto;
  padding: 9px 24px;
}

.fb-topbar p {
  margin: 0;
  font-weight: 500;
  font-family: var(--fb-ui-font);
  letter-spacing: 0.035em;
  text-transform: uppercase;
}

.fb-region-note {
  justify-self: end;
  font-weight: 500;
}

.fb-socials {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
}

.fb-socials a {
  display: inline-grid;
  width: 24px;
  height: 24px;
  place-items: center;
  color: inherit;
  text-decoration: none;
}

.fb-social-icon {
  display: block;
  width: 18px;
  height: 18px;
  object-fit: contain;
}

.fb-site-header {
  position: sticky;
  top: 0;
  z-index: 55;
  background: #ffffff;
  border-bottom: 1px solid var(--fb-line);
  box-shadow: 0 1px 0 rgba(65, 64, 66, 0.035);
}

.fb-site-header__inner {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 34px;
  max-width: 1280px;
  min-height: 84px;
  margin: 0 auto;
  padding: 0 24px;
}

.fb-primary-nav,
.fb-header-actions {
  display: flex;
  align-items: center;
  gap: 24px;
}

.fb-primary-nav a,
.fb-header-actions a,
.fb-cart-button {
  color: var(--fb-coral-dark);
  font-family: var(--fb-ui-font);
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.1em;
  text-decoration: none;
  text-transform: uppercase;
}

.fb-header-actions {
  justify-content: flex-end;
  gap: 10px;
}

.fb-cart-button,
.fb-icon-link,
.fb-icon-btn {
  display: inline-grid;
  width: 42px;
  height: 42px;
  place-items: center;
  border: 0;
  background: transparent;
  cursor: pointer;
  font: inherit;
}

.fb-icon-btn {
  border: 0;
  background: transparent;
}

.fb-action-icon {
  display: block;
  width: 22px;
  height: 22px;
  object-fit: contain;
}

.fb-cart-button {
  position: relative;
}

.fb-cart-button [data-fb-cart-count] {
  position: absolute;
  top: 2px;
  right: 1px;
  display: grid;
  min-width: 14px;
  height: 14px;
  place-items: center;
  border-radius: 999px;
  background: var(--fb-coral);
  color: var(--fb-paper);
  font-size: 8px;
  font-weight: 600;
  line-height: 1;
  padding: 0 3px;
}

.fb-logo {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--fb-ink);
  text-decoration: none;
}

.fb-logo img {
  display: block;
  width: clamp(150px, 14vw, 240px);
  height: auto;
  max-height: 50px;
  object-fit: contain;
}

.fb-menu-toggle {
  display: none;
  width: 42px;
  height: 42px;
  border: 1px solid var(--fb-line);
  border-radius: 6px;
}

.fb-menu-toggle span {
  display: block;
  width: 18px;
  height: 2px;
  margin: 4px auto;
  background: var(--fb-ink);
}

.fb-mobile-nav {
  display: none;
  border-top: 1px solid var(--fb-line);
  background: var(--fb-card);
  padding: 14px 24px 22px;
}

.fb-mobile-nav a {
  display: block;
  padding: 12px 0;
  border-bottom: 1px solid var(--fb-line);
  color: var(--fb-ink);
  font-weight: 600;
  text-decoration: none;
}

.fb-hero-v2 {
  display: grid;
  grid-template-columns: minmax(0, 0.86fr) minmax(390px, 1.14fr);
  min-height: 720px;
  align-items: center;
  gap: 74px;
  background:
    linear-gradient(90deg, rgba(255, 255, 255, 1), rgba(247, 251, 251, 0.88)),
    linear-gradient(135deg, #ffffff, #fbfdfd);
  padding: 96px max(36px, calc((100vw - 1180px) / 2));
}

.fb-hero-v2 > .wp-block-group__inner-container {
  display: grid;
  grid-template-columns: minmax(0, 0.86fr) minmax(390px, 1.14fr);
  align-items: center;
  gap: 74px;
}

.fb-hero-v2 h1 {
  max-width: 680px;
  margin: 0 0 20px;
  color: var(--fb-ink);
  font-size: clamp(42px, 5.4vw, 74px);
  font-weight: 900;
  line-height: 1.08;
  letter-spacing: 0;
}

.fb-hero-v2 p:not(.fb-kicker) {
  max-width: 590px;
  color: var(--fb-muted);
  font-size: 18px;
  line-height: 1.72;
}

.fb-hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  margin-top: 34px;
}

.fb-button,
.fb-card-link,
.fb-drawer-checkout,
.fb-newsletter-form button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  border: 1px solid var(--fb-coral);
  border-radius: 6px;
  background: var(--fb-coral);
  color: #ffffff;
  font-family: var(--fb-ui-font);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.1em;
  line-height: 1.1;
  padding: 12px 20px;
  text-decoration: none;
  text-transform: uppercase;
}

.wp-block-button.fb-button .wp-block-button__link,
.wp-block-button.fb-card-link .wp-block-button__link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  border: 1px solid var(--fb-coral);
  border-radius: 6px;
  background: var(--fb-coral);
  color: #ffffff;
  font-family: var(--fb-ui-font);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.1em;
  line-height: 1.1;
  padding: 12px 20px;
  text-decoration: none;
  text-transform: uppercase;
}

.fb-button--ghost {
  background: var(--fb-card);
  border-color: var(--fb-line);
  color: var(--fb-coral-dark);
}

.wp-block-button.fb-button--ghost .wp-block-button__link {
  background: var(--fb-card);
  border-color: var(--fb-line);
  color: var(--fb-coral-dark);
}

.fb-hero-v2__visual {
  position: relative;
}

.fb-kit-scene {
  position: relative;
  min-height: 540px;
  border: 1px solid var(--fb-sky);
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(247, 251, 251, 0.96), #ffffff);
  box-shadow: 0 22px 52px rgba(65, 64, 66, 0.06);
  overflow: hidden;
}

.fb-scene-label {
  position: absolute;
  top: 22px;
  left: 22px;
  z-index: 2;
  border-radius: 999px;
  background: var(--fb-card);
  color: var(--fb-coral-dark);
  font-family: var(--fb-ui-font);
  font-size: 13px;
  font-weight: 600;
  padding: 8px 14px;
}

.fb-feltie-face {
  position: absolute;
  top: 118px;
  left: 64px;
  width: 210px;
  height: 210px;
  border-radius: 48% 52% 44% 56%;
  background: var(--fb-card);
  box-shadow: inset -18px -22px 0 rgba(237, 248, 250, 0.82), 0 18px 36px rgba(65, 64, 66, 0.06);
}

.fb-feltie-face::before,
.fb-feltie-face::after {
  position: absolute;
  top: 76px;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: var(--fb-ink);
  content: "";
}

.fb-feltie-face::before {
  left: 70px;
}

.fb-feltie-face::after {
  right: 70px;
}

.fb-feltie-face span {
  position: absolute;
  left: 50%;
  bottom: 72px;
  width: 44px;
  height: 20px;
  border-bottom: 4px solid var(--fb-coral-dark);
  border-radius: 50%;
  transform: translateX(-50%);
}

.fb-kit-box {
  position: absolute;
  right: 52px;
  bottom: 86px;
  width: 230px;
  min-height: 170px;
  border: 1px solid var(--fb-line);
  border-radius: 8px;
  background: #ffffff;
  color: var(--fb-ink);
  font-size: 34px;
  font-weight: 600;
  line-height: 1;
  padding: 28px;
}

.fb-kit-box small {
  font-size: 18px;
}

.fb-wool-dots {
  position: absolute;
  right: 80px;
  top: 110px;
  display: flex;
  gap: 14px;
}

.fb-wool-dots i {
  width: 58px;
  height: 58px;
  border-radius: 50%;
  background: var(--fb-sky);
  box-shadow: inset -10px -8px 0 rgba(65, 64, 66, 0.045);
}

.fb-wool-dots i:nth-child(2) {
  background: var(--fb-moss);
}

.fb-wool-dots i:nth-child(3) {
  background: var(--fb-tomato);
}

.fb-qr-card {
  position: absolute;
  left: 96px;
  bottom: 76px;
  width: 94px;
  height: 94px;
  display: grid;
  place-items: center;
  border: 1px dashed var(--fb-muted);
  border-radius: 8px;
  background: var(--fb-card);
  color: var(--fb-muted);
  font-weight: 600;
  text-align: center;
}

.fb-section-head {
  max-width: 780px;
  margin: 0 auto 54px;
  text-align: center;
}

.fb-section-head h2,
.fb-footer-cta h2 {
  margin: 0 0 12px;
  font-size: clamp(30px, 3.1vw, 44px);
  color: var(--fb-coral-dark);
  font-weight: 900;
  line-height: 1.14;
  letter-spacing: 0;
}

.fb-section-head p {
  color: var(--fb-muted);
  font-size: 18px;
}

.fb-product-showcase {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 34px;
  max-width: 1180px;
  margin: 0 auto;
}

.fb-product-card {
  background: var(--fb-card);
  border: 1px solid var(--fb-line);
  border-radius: 8px;
  padding: 18px 18px 24px;
  text-align: center;
  box-shadow: 0 10px 26px rgba(65, 64, 66, 0.04);
}

.fb-product-card > * {
  margin-left: auto;
  margin-right: auto;
}

.fb-product-card h3 {
  min-height: 58px;
  margin: 18px 0 10px;
  font-size: 18px;
  font-weight: 500;
  line-height: 1.25;
}

.fb-product-card h3 a {
  color: var(--fb-ink);
  text-decoration: none;
}

.fb-product-art {
  position: relative;
  display: grid;
  aspect-ratio: 4 / 5;
  place-items: center;
  border-radius: 8px;
  background:
    linear-gradient(135deg, var(--fb-soft), #ffffff);
  overflow: hidden;
}

.fb-product-art span {
  width: 46%;
  height: 46%;
  border-radius: 46% 54% 50% 50%;
  background: #ffffff;
  box-shadow: inset -12px -14px 0 rgba(237, 248, 250, 0.86), 0 12px 26px rgba(65, 64, 66, 0.06);
}

.fb-product-art--cat span {
  background: #f6d4cf;
  clip-path: polygon(20% 16%, 35% 28%, 50% 20%, 65% 28%, 80% 16%, 82% 55%, 67% 79%, 50% 86%, 33% 79%, 18% 55%);
}

.fb-product-art--chick span {
  background: #f1e98f;
}

.fb-product-art--bundle span {
  width: 58%;
  height: 42%;
  border: 1px solid var(--fb-line);
  border-radius: 8px;
  background: #ffffff;
}

.fb-card-price {
  color: var(--fb-coral-dark);
  font-size: 18px;
  font-weight: 600;
}

.fb-card-link {
  width: 100%;
  min-height: 42px;
}

.wp-block-button.fb-card-link,
.wp-block-button.fb-card-link .wp-block-button__link {
  width: 100%;
}

.fb-stars {
  color: var(--fb-muted);
  font-size: 14px;
  font-weight: 600;
}

.fb-stars span,
.fb-rating-text {
  color: var(--fb-muted);
}

.fb-center {
  margin-top: 30px;
  text-align: center;
}

.fb-how {
  background: #ffffff;
  border-block: 1px solid var(--fb-line);
}

.fb-how-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 34px;
  max-width: 1180px;
  margin: 0 auto;
}

.fb-how-grid article,
.fb-icon-grid article,
.fb-compare-grid article,
.fb-how-grid > .wp-block-group,
.fb-icon-grid > .wp-block-group,
.fb-compare-grid > .wp-block-group {
  border: 1px solid var(--fb-line);
  border-radius: 8px;
  background: var(--fb-card);
  padding: 28px;
}

.fb-step-image {
  display: grid;
  width: 100%;
  aspect-ratio: 4 / 3;
  place-items: center;
  margin-bottom: 22px;
  border-radius: 8px;
  background:
    linear-gradient(135deg, var(--fb-soft), #ffffff);
  color: var(--fb-coral-dark);
  font-family: var(--fb-ui-font);
  font-size: 42px;
  font-weight: 600;
}

.fb-icon-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 34px;
  max-width: 1180px;
  margin: 0 auto;
  text-align: center;
}

.fb-icon-grid span {
  display: grid;
  width: 58px;
  height: 58px;
  place-items: center;
  margin: 0 auto 14px;
  border-radius: 50%;
  background: var(--fb-soft);
  color: var(--fb-coral-dark);
  font-size: 28px;
  font-weight: 600;
}

.fb-icon-grid > .wp-block-group > p:first-child {
  display: grid;
  width: 58px;
  height: 58px;
  place-items: center;
  margin: 0 auto 14px;
  border-radius: 50%;
  background: var(--fb-soft);
  color: var(--fb-coral-dark);
  font-size: 28px;
  font-weight: 600;
}

.fb-icon-grid h3 {
  color: var(--fb-coral-dark);
  font-family: var(--fb-ui-font);
  font-size: 18px;
  line-height: 1.15;
  text-transform: uppercase;
}

.fb-compare {
  background: var(--fb-soft);
}

.fb-compare-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 34px;
  max-width: 980px;
  margin: 0 auto;
}

.fb-compare-grid li {
  margin: 10px 0;
}

.fb-compare-muted {
  opacity: 0.76;
}

.fb-compare-grid h3 {
  color: var(--fb-coral-dark);
}

.fb-compare-grid article:first-child {
  border-color: var(--fb-line);
  box-shadow: 0 12px 30px rgba(65, 64, 66, 0.04);
}

.fb-compare-grid > .wp-block-group:first-child {
  border-color: var(--fb-line);
  box-shadow: 0 12px 30px rgba(65, 64, 66, 0.04);
}

.fb-compare-grid article:first-child li::marker {
  color: var(--fb-coral);
}

.fb-compare-muted {
  background: #ffffff;
  border-color: var(--fb-line);
}

.fb-video-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 34px;
  max-width: 1180px;
  margin: 0 auto;
}

.fb-video-card {
  display: grid;
  min-height: 240px;
  place-items: center;
  border: 1px solid var(--fb-line);
  border-radius: 8px;
  background: #ffffff;
  color: var(--fb-ink);
  cursor: pointer;
}

.fb-video-card span {
  display: grid;
  width: 62px;
  height: 62px;
  place-items: center;
  border-radius: 50%;
  background: var(--fb-coral);
  color: #ffffff;
}

.fb-video-card strong {
  color: var(--fb-coral-dark);
  font-family: var(--fb-ui-font);
  font-size: 13px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.fb-footer-cta {
  min-height: 300px;
  display: grid;
  place-items: center;
  background:
    linear-gradient(135deg, var(--fb-soft), var(--fb-paper));
  color: var(--fb-ink);
  text-align: center;
  padding: 64px 24px;
}

.fb-footer {
  position: relative;
  background: #ffffff;
  color: var(--fb-ink);
  padding: 64px 24px 28px;
}

.fb-footer::before {
  position: absolute;
  inset: 0 0 auto;
  height: 1px;
  background: var(--fb-line);
  content: "";
}

.fb-footer a {
  display: block;
  color: var(--fb-ink);
  text-decoration: none;
}

.fb-footer__grid {
  display: grid;
  grid-template-columns: 1.25fr 0.75fr 0.75fr 1.15fr;
  gap: 40px;
  max-width: 1180px;
  margin: 0 auto;
}

.fb-footer .fb-logo {
  display: inline-flex;
  width: fit-content;
  border-radius: 6px;
  background: rgba(252, 254, 253, 0.72);
  color: var(--fb-ink);
  padding: 6px 8px;
}

.fb-footer .fb-logo img {
  width: 230px;
  max-height: 58px;
  border-radius: 8px;
}

.fb-footer h2 {
  margin: 0 0 16px;
  color: var(--fb-ink);
  font-family: var(--fb-ui-font);
  font-size: 18px;
  font-weight: 500;
}

.fb-footer__newsletter input,
.fb-newsletter-form input {
  width: 100%;
  min-height: 46px;
  border: 1px solid var(--fb-line);
  border-radius: 6px;
  padding: 10px 12px;
}

.fb-footer__newsletter form,
.fb-newsletter-form {
  display: grid;
  gap: 10px;
}

.fb-footer__bottom {
  display: flex;
  justify-content: space-between;
  gap: 24px;
  max-width: 1180px;
  margin: 40px auto 0;
  border-top: 1px solid var(--fb-line);
  padding-top: 18px;
  color: var(--fb-muted);
  font-size: 13px;
}

.fb-cart-drawer,
.fb-newsletter-modal,
.fb-video-modal {
  position: fixed;
  inset: 0;
  z-index: 9999;
  pointer-events: none;
  visibility: hidden;
}

.fb-cart-drawer.is-open,
.fb-newsletter-modal.is-open,
.fb-video-modal.is-open {
  pointer-events: auto;
  visibility: visible;
}

.fb-cart-drawer__overlay,
.fb-newsletter-modal__overlay,
.fb-video-modal__overlay {
  position: absolute;
  inset: 0;
  background: rgba(30, 34, 34, 0.34);
  opacity: 0;
  transition: opacity 0.2s ease;
}

.is-open > .fb-cart-drawer__overlay,
.is-open > .fb-newsletter-modal__overlay,
.is-open > .fb-video-modal__overlay {
  opacity: 1;
}

.fb-cart-drawer__panel {
  position: absolute;
  top: 0;
  right: 0;
  width: min(420px, 92vw);
  height: 100%;
  background: var(--fb-card);
  box-shadow: -14px 0 36px rgba(30, 34, 34, 0.11);
  padding: 28px;
  transform: translateX(100%);
  transition: transform 0.22s ease;
}

.is-open .fb-cart-drawer__panel {
  transform: translateX(0);
}

.fb-drawer-close,
.fb-newsletter-modal__panel > button,
.fb-video-modal__panel > button {
  position: absolute;
  top: 16px;
  right: 16px;
  width: 34px;
  height: 34px;
  border: 1px solid var(--fb-line);
  border-radius: 50%;
  background: var(--fb-card);
  cursor: pointer;
}

.fb-drawer-item,
.fb-drawer-total {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  border-bottom: 1px solid var(--fb-line);
  padding: 14px 0;
}

.fb-drawer-checkout,
.fb-drawer-cart {
  width: 100%;
  margin-top: 14px;
}

.fb-drawer-cart {
  display: block;
  color: var(--fb-coral-dark);
  font-weight: 600;
  text-align: center;
}

.fb-newsletter-modal__panel,
.fb-video-modal__panel {
  position: absolute;
  top: 50%;
  left: 50%;
  width: min(540px, 92vw);
  background: var(--fb-card);
  border-radius: 8px;
  box-shadow: 0 18px 54px rgba(30, 34, 34, 0.13);
  padding: 34px;
  transform: translate(-50%, -45%);
  opacity: 0;
  transition: opacity 0.2s ease, transform 0.2s ease;
}

.is-open .fb-newsletter-modal__panel,
.is-open .fb-video-modal__panel {
  transform: translate(-50%, -50%);
  opacity: 1;
}

.fb-video-modal__panel {
  width: min(820px, 92vw);
}

.fb-video-placeholder {
  display: grid;
  min-height: 360px;
  place-items: center;
  border-radius: 8px;
  background: var(--fb-soft);
  color: var(--fb-ink);
  font-size: 24px;
  font-weight: 600;
}

.fb-modal-open {
  overflow: hidden;
}

.fb-loop-meta {
  display: grid;
  gap: 5px;
  justify-items: center;
  margin: 8px 0;
}

.fb-product-promise {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 10px 0 18px;
}

.fb-product-promise span,
.fb-difficulty {
  display: inline-flex;
  width: fit-content;
  border-radius: 999px;
  background: var(--fb-soft);
  color: var(--fb-coral-dark);
  font-family: var(--fb-ui-font);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.02em;
  padding: 6px 10px;
}

[data-products] .product,
.woocommerce ul.products li.product {
  text-align: center;
}

.woocommerce-shop .page-description,
.term-description {
  max-width: 740px;
  margin-inline: auto;
  color: var(--fb-muted);
  text-align: center;
}

.fb-hero {
  background:
    linear-gradient(90deg, rgba(255, 255, 255, 0.96) 0%, rgba(247, 251, 251, 0.88) 56%, rgba(255, 255, 255, 0.62) 100%),
    linear-gradient(135deg, var(--fb-paper) 0%, var(--fb-card) 100%);
}

.fb-hero h1 {
  max-width: 680px;
  color: var(--fb-ink);
  font-size: clamp(38px, 4.8vw, 62px);
  font-weight: 500;
  line-height: 1.12;
  margin-bottom: 18px;
}

.fb-hero p {
  max-width: 560px;
  color: var(--fb-muted);
}

.fb-kicker,
.fb-sticker {
  display: inline-block;
  width: fit-content;
  border: 1px solid var(--fb-line);
  border-radius: 999px;
  background: var(--fb-card);
  color: var(--fb-coral-dark) !important;
  font-family: var(--fb-ui-font);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.02em;
  padding: 7px 12px;
}

.fb-trustline {
  font-size: 14px;
  font-weight: 600;
  margin-top: 18px;
}

.fb-section {
  padding: 92px 28px;
}

.fb-soft-band,
.fb-feature {
  background: #ffffff;
  border-block: 1px solid var(--fb-line);
}

.fb-paper-card {
  height: 100%;
  background: var(--fb-card);
  border: 1px solid var(--fb-line);
  border-radius: 8px;
  box-shadow: 0 10px 26px rgba(65, 64, 66, 0.035);
  padding: 30px;
}

.fb-paper-card h3 {
  margin-top: 0;
}

.fb-card-grid {
  gap: 34px;
}

.fb-steps h3 {
  color: var(--fb-coral-dark);
  font-size: 20px;
}

.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
  background: var(--fb-card);
  border: 1px solid var(--fb-line);
  border-radius: 8px;
  padding: 16px;
  box-shadow: 0 10px 24px rgba(65, 64, 66, 0.035);
}

.woocommerce ul.products li.product img {
  border-radius: 6px;
  aspect-ratio: 4 / 3;
  object-fit: cover;
}

.woocommerce ul.products li.product .woocommerce-loop-product__title {
  min-height: 2.6em;
  color: var(--fb-ink);
}

.woocommerce div.product div.images img {
  border-radius: 8px;
  background: var(--fb-soft);
}

.woocommerce div.product .product_title {
  font-size: clamp(2rem, 3vw, 3rem);
  font-weight: 500;
  line-height: 1.14;
}

.woocommerce div.product p.price,
.woocommerce div.product span.price {
  color: var(--fb-coral-dark);
}

.fb-trust-strip {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 28px;
  margin: 34px 0;
}

.fb-trust-strip > * {
  border-left: 3px solid var(--fb-coral);
  padding-left: 14px;
}

@media (max-width: 760px) {
  .fb-topbar__inner {
    grid-template-columns: 1fr;
    gap: 6px;
    justify-items: center;
    padding: 8px 16px;
    text-align: center;
  }

  .fb-region-note {
    justify-self: center;
  }

  .fb-site-header__inner {
    grid-template-columns: 44px 1fr auto;
    min-height: 68px;
    padding: 0 16px;
  }

  .fb-primary-nav,
  .fb-icon-link {
    display: none;
  }

  .fb-menu-toggle {
    display: block;
  }

  .fb-mobile-nav.is-open {
    display: block;
  }

  .fb-logo img {
    width: 140px;
    max-height: 38px;
  }

  .fb-hero-v2 {
    grid-template-columns: 1fr;
    min-height: auto;
    gap: 38px;
    padding: 58px 20px;
  }

  .fb-hero-v2 h1 {
    font-size: 48px;
  }

  .fb-hero-v2 p:not(.fb-kicker) {
    font-size: 17px;
  }

  .fb-kit-scene {
    min-height: 360px;
  }

  .fb-feltie-face {
    top: 76px;
    left: 28px;
    width: 170px;
    height: 170px;
  }

  .fb-kit-box {
    right: 20px;
    bottom: 40px;
    width: 170px;
    min-height: 130px;
    font-size: 24px;
    padding: 20px;
  }

  .fb-wool-dots {
    right: 26px;
    top: 78px;
  }

  .fb-wool-dots i {
    width: 38px;
    height: 38px;
  }

  .fb-qr-card {
    left: 32px;
    bottom: 34px;
    width: 74px;
    height: 74px;
    font-size: 13px;
  }

  .fb-product-showcase,
  .fb-how-grid,
  .fb-icon-grid,
  .fb-compare-grid,
  .fb-video-grid,
  .fb-footer__grid {
    grid-template-columns: 1fr;
  }

  .fb-product-card h3 {
    min-height: auto;
  }

  .fb-footer__bottom {
    flex-direction: column;
  }

  .fb-video-placeholder {
    min-height: 220px;
    font-size: 18px;
  }

  .fb-hero {
    min-height: 480px !important;
  }

  .fb-hero h1 {
    font-size: 42px !important;
  }

  .fb-trust-strip {
    grid-template-columns: 1fr;
  }

  .fb-section {
    padding: 58px 18px;
  }
}
