:root {
  --sm-ink: #121826;
  --sm-muted: #667085;
  --sm-red: #cf2e2e;
  --sm-red-dark: #9f1f1f;
  --sm-navy: #0d263b;
  --sm-blue: #eaf4fb;
  --sm-cream: #fff7ec;
  --sm-gold: #ffcc66;
  --sm-white: #ffffff;
  --sm-border: #e6e8ec;
  --sm-shadow: 0 22px 55px rgba(18,24,38,.12);
  --sm-radius: 24px;
  --sm-radius-sm: 14px;
  --sm-container: 1180px;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  color: var(--sm-ink);
  background: #fff;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  line-height: 1.6;
}
a { color: inherit; }
img { max-width: 100%; height: auto; }
.container { width: min(var(--sm-container), calc(100% - 32px)); margin-inline: auto; }
.skip-link { position: absolute; left: -999px; top: 10px; background: var(--sm-ink); color: white; padding: .75rem 1rem; z-index: 50; }
.skip-link:focus { left: 10px; }
.announcement-bar { display: flex; justify-content: center; gap: 1rem; align-items: center; padding: .5rem 1rem; background: var(--sm-navy); color: white; font-size: .92rem; }
.announcement-bar a { color: var(--sm-gold); font-weight: 800; text-decoration: none; }
.site-header { position: sticky; top: 0; z-index: 40; background: rgba(255,255,255,.96); border-bottom: 1px solid var(--sm-border); backdrop-filter: blur(12px); }
.nav-shell { width: min(1280px, calc(100% - 32px)); margin: 0 auto; display: flex; align-items: center; gap: 1.5rem; min-height: 78px; }
.brand-wrap { flex: 0 0 auto; }
.brand-mark { display: inline-flex; align-items: center; gap: .55rem; font-weight: 950; letter-spacing: -.04em; font-size: 1.45rem; text-decoration: none; }
.brand-mark span span { color: var(--sm-red); }
.brand-cross { width: 34px; height: 34px; border-radius: 10px; display: grid; place-items: center; background: var(--sm-red); color: white; font-weight: 950; }
.custom-logo-link img { max-height: 56px; width: auto; }
.primary-nav { flex: 1; }
.primary-nav .menu { display: flex; align-items: center; justify-content: center; gap: .2rem; list-style: none; margin: 0; padding: 0; }
.primary-nav a { display: inline-flex; padding: .65rem .85rem; text-decoration: none; font-weight: 800; border-radius: 999px; color: var(--sm-ink); }
.primary-nav a:hover { background: var(--sm-cream); color: var(--sm-red-dark); }
.nav-actions { display: flex; align-items: center; gap: .75rem; }
.cart-link { font-weight: 900; text-decoration: none; }
.mobile-menu-toggle { display: none; }
.btn, .button, button.button, input[type="submit"], .wp-block-button__link, .woocommerce a.button, .woocommerce button.button, .woocommerce input.button { display: inline-flex; align-items: center; justify-content: center; gap: .5rem; min-height: 48px; padding: .85rem 1.15rem; border-radius: 999px; border: 2px solid var(--sm-ink); background: var(--sm-ink); color: #fff; text-decoration: none; font-weight: 950; cursor: pointer; transition: transform .18s ease, box-shadow .18s ease, background .18s ease; }
.btn:hover, .button:hover, .woocommerce a.button:hover { transform: translateY(-2px); box-shadow: var(--sm-shadow); }
.btn-primary { background: var(--sm-red); border-color: var(--sm-red); color: #fff; }
.btn-primary:hover { background: var(--sm-red-dark); border-color: var(--sm-red-dark); }
.btn-ghost { background: #fff; color: var(--sm-ink); }
.btn-small { min-height: 40px; padding: .6rem .9rem; font-size: .9rem; }
.cta-row { display: flex; flex-wrap: wrap; gap: .85rem; align-items: center; }
.eyebrow { margin: 0 0 .65rem; font-size: .8rem; letter-spacing: .14em; text-transform: uppercase; font-weight: 950; color: var(--sm-red); }
.hero { padding: clamp(3rem, 6vw, 6rem) 0; overflow: hidden; }
.hero-ecom { background: radial-gradient(circle at top right, #ffe6cc 0, transparent 35%), linear-gradient(135deg, var(--sm-cream), #fff); }
.hero-grid { display: grid; grid-template-columns: minmax(0, 1.05fr) minmax(340px, .95fr); gap: clamp(2rem, 6vw, 5rem); align-items: center; }
.hero h1 { margin: 0; max-width: 850px; font-size: clamp(3rem, 8vw, 6.8rem); line-height: .87; letter-spacing: -.085em; font-weight: 1000; }
.hero-lede { max-width: 650px; font-size: clamp(1.1rem, 2vw, 1.35rem); color: #344054; margin: 1.35rem 0 1.65rem; }
.trust-row { display: flex; flex-wrap: wrap; gap: .7rem; margin-top: 1.4rem; }
.trust-row span, .pill { background: #fff; border: 1px solid var(--sm-border); border-radius: 999px; padding: .45rem .75rem; font-weight: 900; font-size: .9rem; }
.hero-card-stack { min-height: 520px; position: relative; }
.hero-product-card { position: absolute; border-radius: 36px; border: 2px solid var(--sm-ink); box-shadow: 12px 12px 0 var(--sm-ink); padding: 1.5rem; background: #fff; }
.hero-product-card.big { width: min(430px, 92%); right: 4%; top: 0; background: var(--sm-red); color: white; }
.hero-product-card.big .pill { display: inline-flex; color: var(--sm-ink); }
.hero-product-card.big .text-link { color: #fff; }
.hero-product-card.accent { width: 270px; left: 0; bottom: 75px; background: var(--sm-gold); }
.hero-product-card.light { width: 270px; right: 0; bottom: 0; background: var(--sm-blue); }
.hero-product-card h2, .hero-product-card h3 { margin: .75rem 0 .5rem; line-height: .9; letter-spacing: -.05em; font-weight: 1000; }
.hero-product-card h2 { font-size: 3.2rem; }
.hero-product-card h3 { font-size: 2rem; }
.text-link { font-weight: 950; color: var(--sm-red-dark); text-underline-offset: 5px; }
.logo-strip { background: var(--sm-ink); color: #fff; padding: 1rem 0; }
.strip-grid { display: flex; gap: 1rem; justify-content: space-between; flex-wrap: wrap; font-weight: 950; text-transform: uppercase; letter-spacing: .08em; font-size: .85rem; }
.section { padding: clamp(3rem, 6vw, 5.8rem) 0; }
.section-heading { max-width: 780px; margin: 0 auto 2rem; text-align: center; }
.section-heading h2, .feature-split h2, .quote-band h2, .footer-cta h2 { margin: 0; font-size: clamp(2.2rem, 5vw, 4.5rem); line-height: .95; letter-spacing: -.065em; font-weight: 1000; }
.section-heading p { color: var(--sm-muted); font-size: 1.1rem; }
.row-heading { max-width: none; text-align: left; display: flex; justify-content: space-between; align-items: end; gap: 1rem; }
.card-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 1rem; }
.card { border: 1px solid var(--sm-border); border-radius: var(--sm-radius); background: #fff; padding: 1.3rem; box-shadow: 0 12px 30px rgba(18,24,38,.06); }
.service-card { min-height: 260px; display: flex; flex-direction: column; }
.service-card h3 { font-size: 1.45rem; line-height: 1.05; margin: 1rem 0 .5rem; }
.service-card p { color: var(--sm-muted); }
.service-card .text-link { margin-top: auto; }
.icon-badge { width: 46px; height: 46px; display: grid; place-items: center; border-radius: 16px; background: var(--sm-red); color: white; font-weight: 1000; }
.band-cream { background: var(--sm-cream); }
.band-dark { background: var(--sm-navy); color: white; }
.feature-split, .split { display: grid; grid-template-columns: minmax(0, 1.2fr) minmax(260px, .8fr); gap: 2rem; align-items: center; }
.check-list { padding: 0; list-style: none; display: grid; gap: .8rem; }
.check-list li { position: relative; padding-left: 2rem; font-weight: 800; }
.check-list li:before { content: '✓'; position: absolute; left: 0; color: var(--sm-red); font-weight: 1000; }
.stacked-feature { display: grid; gap: 1rem; }
.stat-card { background: #fff; border: 2px solid var(--sm-ink); border-radius: 28px; padding: 1.2rem; box-shadow: 8px 8px 0 var(--sm-ink); display: grid; gap: .2rem; }
.stat-card strong { font-size: 3rem; line-height: 1; letter-spacing: -.06em; }
.industry-pills { display: flex; flex-wrap: wrap; gap: .8rem; justify-content: center; }
.industry-pill { padding: .85rem 1rem; border-radius: 999px; border: 2px solid var(--sm-ink); font-weight: 950; text-decoration: none; background: #fff; }
.industry-pill:hover { background: var(--sm-gold); }
.quote-band { background: var(--sm-red); color: white; }
.quote-band .eyebrow { color: var(--sm-gold); }
.quote-band .btn-ghost { color: var(--sm-ink); }
.page-hero { padding: 5rem 0 3rem; background: linear-gradient(135deg, var(--sm-cream), #fff); }
.page-hero.compact h1, .shop-hero h1 { margin: 0; font-size: clamp(2.6rem, 6vw, 5.5rem); line-height: .9; letter-spacing: -.07em; font-weight: 1000; }
.page-content { padding: 3rem 0; max-width: 860px; }
.page-content h2 { font-size: clamp(2rem, 4vw, 3rem); line-height: 1; letter-spacing: -.05em; }
.content-layout { padding: 3rem 0; display: grid; gap: 1rem; }
.post-card h2 { margin-top: 0; }
.featured-image { border-radius: var(--sm-radius); margin-bottom: 1.5rem; }
.site-footer { background: #091725; color: #dce7f2; }
.footer-cta { padding: 3rem 0; border-bottom: 1px solid rgba(255,255,255,.12); }
.footer-cta .eyebrow { color: var(--sm-gold); }
.footer-grid { padding: 3rem 0; display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 2rem; }
.footer-grid a { color: white; }
.footer-grid ul, .footer-menu { padding: 0; list-style: none; display: grid; gap: .45rem; }
.footer-bottom { padding: 1rem 0 2rem; color: #a9b8c7; }
.shop-layout { padding: 2rem 0 4rem; display: grid; grid-template-columns: minmax(0, 1fr) 280px; gap: 2rem; }
.shop-intro { margin-bottom: 1.5rem; padding: 1.5rem; background: var(--sm-cream); border-radius: var(--sm-radius); }
.shop-intro h1 { font-size: clamp(2rem, 4vw, 3.5rem); line-height: .95; letter-spacing: -.05em; margin: 0; }
.woocommerce ul.products li.product, .woocommerce-page ul.products li.product { border: 1px solid var(--sm-border); border-radius: var(--sm-radius); padding: 1rem !important; box-shadow: 0 12px 30px rgba(18,24,38,.06); background: #fff; }
.woocommerce ul.products li.product .woocommerce-loop-product__title { font-size: 1.15rem; font-weight: 950; color: var(--sm-ink); }
.woocommerce ul.products li.product .price { color: var(--sm-red-dark); font-weight: 950; }
.woocommerce div.product .product_title { font-size: clamp(2.2rem, 5vw, 4rem); line-height: .95; letter-spacing: -.06em; }
.search-form { display: flex; gap: .5rem; }
.search-field, input[type="text"], input[type="email"], input[type="tel"], input[type="search"], input[type="password"], textarea, select { width: 100%; border: 1px solid var(--sm-border); border-radius: var(--sm-radius-sm); padding: .85rem 1rem; font: inherit; background: #fff; }
.screen-reader-text { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0,0,0,0); }
@media (max-width: 980px) {
  .mobile-menu-toggle { display: inline-flex; margin-left: auto; background: #fff; border: 2px solid var(--sm-ink); border-radius: 999px; padding: .55rem .85rem; font-weight: 950; }
  .primary-nav { display: none; position: absolute; top: 100%; left: 0; right: 0; background: #fff; border-bottom: 1px solid var(--sm-border); padding: 1rem; }
  .primary-nav.is-open { display: block; }
  .primary-nav .menu { display: grid; justify-content: stretch; }
  .primary-nav a { display: flex; }
  .nav-actions .cart-link { display: none; }
  .hero-grid, .feature-split, .split, .shop-layout { grid-template-columns: 1fr; }
  .hero-card-stack { min-height: auto; display: grid; gap: 1rem; }
  .hero-product-card { position: static; width: auto !important; box-shadow: 8px 8px 0 var(--sm-ink); }
  .card-grid, .footer-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 640px) {
  .announcement-bar { flex-direction: column; gap: .1rem; text-align: center; }
  .nav-shell { min-height: 68px; }
  .nav-actions .btn { display: none; }
  .hero h1 { font-size: clamp(3.2rem, 18vw, 4.8rem); }
  .card-grid, .footer-grid { grid-template-columns: 1fr; }
  .row-heading { display: grid; }
  .cta-row { align-items: stretch; }
  .cta-row .btn { width: 100%; }
}
