@charset "UTF-8";
.skew-up {
  font-kerning: none;
  overflow: hidden; }

.skew-up .line {
  clip-path: polygon(0 0, 100% 0, 100% 100%, 0% 100%); }

.skew-up .word {
  transform: translateY(100px); }

* {
  font-variant-ligatures: none; }

html {
  line-height: 1.6em;
  -webkit-text-size-adjust: 100%;
  scroll-behavior: auto; }

body {
  margin: 0; }

main {
  display: block; }

hr {
  box-sizing: content-box;
  height: 0;
  overflow: visible; }

a {
  background-color: transparent;
  text-decoration: none; }

abbr[title] {
  border-bottom: none; }

b,
strong {
  font-weight: bold; }

.italic {
  font-style: italic; }

pre,
code,
kbd,
samp {
  font-family: monospace, monospace;
  font-size: 1em; }

small {
  font-size: 80%; }

sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline; }

sub {
  bottom: -0.25em;
  font-size: 50%; }

sup {
  top: -0.5em;
  font-size: 50%; }

img,
iframe {
  border-style: none; }

img {
  width: 100%;
  height: auto; }

button,
input,
optgroup,
select,
textarea {
  font-family: inherit;
  font-size: 100%;
  line-height: 1.15;
  margin: 0; }

button,
input {
  overflow: visible; }

button,
select {
  text-transform: none; }

button,
[type="button"],
[type="reset"],
[type="submit"] {
  -webkit-appearance: button;
  appearance: button; }

button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
  border-style: none;
  padding: 0; }

button:-moz-focusring,
[type="button"]:-moz-focusring,
[type="reset"]:-moz-focusring,
[type="submit"]:-moz-focusring {
  outline: 1px dotted ButtonText; }

fieldset {
  padding: 0.35em 0.75em 0.625em; }

legend {
  box-sizing: border-box;
  color: inherit;
  display: table;
  max-width: 100%;
  padding: 0;
  white-space: normal; }

progress {
  vertical-align: baseline; }

textarea {
  overflow: auto; }

[type="checkbox"],
[type="radio"] {
  box-sizing: border-box;
  padding: 0; }

[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button {
  height: auto; }

[type="search"] {
  -webkit-appearance: textfield;
  appearance: textfield;
  outline-offset: -2px; }

[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none; }

::-webkit-file-upload-button {
  -webkit-appearance: button;
  font: inherit; }

details {
  display: block; }

summary {
  display: list-item; }

template,
[hidden] {
  display: none; }

.clear {
  clear: both; }

.clear-left {
  clear: left; }

.clear-float {
  clear: right; }

p,
h1,
h2,
h3,
h4,
h5,
h6,
ul,
li {
  margin: 0;
  padding: 0; }

h1:where(.wp-block-heading).has-background,
h2:where(.wp-block-heading).has-background,
h3:where(.wp-block-heading).has-background,
h4:where(.wp-block-heading).has-background,
h5:where(.wp-block-heading).has-background,
h6:where(.wp-block-heading).has-background {
  padding: 0; }

p.has-background {
  padding: 0; }

/* =========================================================
   SWEET & BREW — COLOUR SYSTEM
   Clean • Semantic • Expandable
========================================================= */
/* =================================
   CORE (Brand + Neutrals)
================================= */
/* =================================
   CATEGORY (Product Families)
================================= */
/* =================================
   STATUS
================================= */
/* =================================
   DERIVATIVES
================================= */
/* =========================================================
   CSS VARIABLES (Runtime Tokens)
========================================================= */
:root {
  /* Core */
  --sb-white: #ffffff;
  --sb-black: #000000;
  --sb-yellow: #f4b011;
  --sb-slate: #2b2b2b;
  --sb-cream: #fffaf2;
  --sb-oat: #efe7dd;
  --sb-lightgrey: #f3f3f3;
  --sb-midgrey: #9ca3af;
  /* Brand */
  --brand: var(--sb-yellow);
  --brand-contrast: #111;
  --text-strong: var(--sb-slate);
  --text-body: #333;
  --text-muted: #666;
  --bg-page: var(--sb-cream);
  --bg-panel: var(--sb-white);
  --bg-subtle: var(--sb-oat);
  /* Category */
  --accent-tea: #3a7d44;
  --accent-coffee: #5c3b2e;
  --accent-spice: #c45a1c;
  --accent-sweet: #a23c63;
  /* Category variants */
  --accent-tea-100: #bce0c2;
  --accent-tea-900: #224928;
  --accent-coffee-100: #d0ada0;
  --accent-coffee-900: #291a15;
  --accent-sweet-100: #efd4df;
  --accent-sweet-900: #6a2741;
  --accent-yellow-100: #fef9ec;
  --accent-yellow-900: #b07e08;
  /* Status */
  --status-success: #2e7d32;
  --status-warning: #f59c25;
  --status-error: #c62828;
  --status-info: #0288d1;
  /* =================================
     GUTENBERG PRESET MAPPING
  ================================= */
  --wp--preset--color--black: var(--sb-black);
  --wp--preset--color--white: var(--sb-white);
  --wp--preset--color--sb-yellow: var(--sb-yellow);
  --wp--preset--color--sb-yellow-100: var(--accent-yellow-100);
  --wp--preset--color--sb-yellow-900: var(--accent-yellow-900);
  --wp--preset--color--sb-slate: var(--sb-slate);
  --wp--preset--color--sb-cream: var(--sb-cream);
  --wp--preset--color--sb-oat: var(--sb-oat);
  --wp--preset--color--sb-lightgrey: var(--sb-lightgrey);
  --wp--preset--color--sb-midgrey: var(--sb-midgrey);
  --wp--preset--color--accent-tea: var(--accent-tea);
  --wp--preset--color--accent-coffee: var(--accent-coffee);
  --wp--preset--color--accent-spice: var(--accent-spice);
  --wp--preset--color--accent-sweet: var(--accent-sweet); }

/* =========================================================
   GUTENBERG COLOR CLASS GENERATOR
========================================================= */
.has-black-color {
  color: var(--sb-black) !important; }

.has-black-background-color {
  background-color: var(--sb-black) !important; }

.has-black-border-color {
  border-color: var(--sb-black) !important; }

.has-white-color {
  color: var(--sb-white) !important; }

.has-white-background-color {
  background-color: var(--sb-white) !important; }

.has-white-border-color {
  border-color: var(--sb-white) !important; }

.has-sb-yellow-color {
  color: var(--sb-yellow) !important; }

.has-sb-yellow-background-color {
  background-color: var(--sb-yellow) !important; }

.has-sb-yellow-border-color {
  border-color: var(--sb-yellow) !important; }

.has-sb-yellow-100-color {
  color: var(--accent-yellow-100) !important; }

.has-sb-yellow-100-background-color {
  background-color: var(--accent-yellow-100) !important; }

.has-sb-yellow-100-border-color {
  border-color: var(--accent-yellow-100) !important; }

.has-sb-yellow-900-color {
  color: var(--accent-yellow-900) !important; }

.has-sb-yellow-900-background-color {
  background-color: var(--accent-yellow-900) !important; }

.has-sb-yellow-900-border-color {
  border-color: var(--accent-yellow-900) !important; }

.has-sb-slate-color {
  color: var(--sb-slate) !important; }

.has-sb-slate-background-color {
  background-color: var(--sb-slate) !important; }

.has-sb-slate-border-color {
  border-color: var(--sb-slate) !important; }

.has-sb-cream-color {
  color: var(--sb-cream) !important; }

.has-sb-cream-background-color {
  background-color: var(--sb-cream) !important; }

.has-sb-cream-border-color {
  border-color: var(--sb-cream) !important; }

.has-sb-oat-color {
  color: var(--sb-oat) !important; }

.has-sb-oat-background-color {
  background-color: var(--sb-oat) !important; }

.has-sb-oat-border-color {
  border-color: var(--sb-oat) !important; }

.has-sb-lightgrey-color {
  color: var(--sb-lightgrey) !important; }

.has-sb-lightgrey-background-color {
  background-color: var(--sb-lightgrey) !important; }

.has-sb-lightgrey-border-color {
  border-color: var(--sb-lightgrey) !important; }

.has-sb-midgrey-color {
  color: var(--sb-midgrey) !important; }

.has-sb-midgrey-background-color {
  background-color: var(--sb-midgrey) !important; }

.has-sb-midgrey-border-color {
  border-color: var(--sb-midgrey) !important; }

.has-accent-tea-color {
  color: var(--accent-tea) !important; }

.has-accent-tea-background-color {
  background-color: var(--accent-tea) !important; }

.has-accent-tea-border-color {
  border-color: var(--accent-tea) !important; }

.has-accent-coffee-color {
  color: var(--accent-coffee) !important; }

.has-accent-coffee-background-color {
  background-color: var(--accent-coffee) !important; }

.has-accent-coffee-border-color {
  border-color: var(--accent-coffee) !important; }

.has-accent-spice-color {
  color: var(--accent-spice) !important; }

.has-accent-spice-background-color {
  background-color: var(--accent-spice) !important; }

.has-accent-spice-border-color {
  border-color: var(--accent-spice) !important; }

.has-accent-sweet-color {
  color: var(--accent-sweet) !important; }

.has-accent-sweet-background-color {
  background-color: var(--accent-sweet) !important; }

.has-accent-sweet-border-color {
  border-color: var(--accent-sweet) !important; }

.has-status-success-color {
  color: var(--status-success) !important; }

.has-status-success-background-color {
  background-color: var(--status-success) !important; }

.has-status-success-border-color {
  border-color: var(--status-success) !important; }

.has-status-warning-color {
  color: var(--status-warning) !important; }

.has-status-warning-background-color {
  background-color: var(--status-warning) !important; }

.has-status-warning-border-color {
  border-color: var(--status-warning) !important; }

.has-status-error-color {
  color: var(--status-error) !important; }

.has-status-error-background-color {
  background-color: var(--status-error) !important; }

.has-status-error-border-color {
  border-color: var(--status-error) !important; }

.has-status-info-color {
  color: var(--status-info) !important; }

.has-status-info-background-color {
  background-color: var(--status-info) !important; }

.has-status-info-border-color {
  border-color: var(--status-info) !important; }

/* Preserve link inheritance */
.has-text-color a {
  color: inherit; }

/* =========================================
   SWEET & BREW — TYPOGRAPHY SYSTEM
========================================= */
:root {
  /* Font families */
  --font-display: "Playfair Display", Georgia, serif;
  --font-serif: "Playfair Display", Georgia, serif;
  --font-sans: "Manrope", -apple-system, BlinkMacSystemFont,
               "Segoe UI", Roboto, Arial, sans-serif;
  /* Type scale */
  --fs-h1: clamp(2.2rem, 2.6vw + 1.2rem, 3.4rem);
  --fs-h2: clamp(1.8rem, 1.9vw + 1.0rem, 2.6rem);
  --fs-h3: clamp(1.4rem, 1.1vw + .9rem, 1.9rem);
  --fs-h4: clamp(1.15rem, .6vw + .95rem, 1.35rem);
  --fs-body: clamp(1rem, .2vw + .95rem, 1.06rem); }

/* ===============================
   BODY
=============================== */
body {
  font-family: var(--font-sans);
  font-weight: 400;
  font-size: 18px;
  line-height: 1.6;
  /* was 1.2 — too tight */
  letter-spacing: 0.2px;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility; }

/* ===============================
   HEADINGS
=============================== */
h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: var(--font-display);
  font-weight: 600;
  /* was 300 — too thin for web */
  line-height: 1.25;
  letter-spacing: 0.3px; }
  h1.bold,
  h1 strong,
  h2.bold,
  h2 strong,
  h3.bold,
  h3 strong,
  h4.bold,
  h4 strong,
  h5.bold,
  h5 strong,
  h6.bold,
  h6 strong {
    font-weight: 700; }
  h1.bolder,
  h2.bolder,
  h3.bolder,
  h4.bolder,
  h5.bolder,
  h6.bolder {
    font-weight: 800; }

/* ===============================
   GUTENBERG HEADING OVERRIDE
=============================== */
h2.wp-block-heading {
  font-size: 48px;
  line-height: 1.2;
  font-weight: 600; }
  @media (max-width: 700px) {
    h2.wp-block-heading {
      font-size: 34px;
      line-height: 1.25; } }

/* ===============================
   PARAGRAPH SPACING
=============================== */
p {
  margin: 0; }
  p + p {
    margin-top: 20px; }

/* ===============================
   TEXT UTILITIES
=============================== */
.xs-text {
  font-size: 12px; }

.small-text {
  font-size: 14px; }

.mid-text {
  font-size: 18px; }

.large-text {
  font-size: 24px;
  line-height: 1.4; }
  @media (max-width: 900px) {
    .large-text {
      font-size: 22px; } }
  @media (max-width: 700px) {
    .large-text {
      font-size: 20px; } }

/* ===============================
   HEADER UTILITIES
=============================== */
.xs-header {
  font-size: 22px;
  line-height: 1.3; }

.small-header {
  font-size: 26px;
  line-height: 1.3; }
  @media (max-width: 700px) {
    .small-header {
      font-size: 22px; } }

.mid-header {
  font-size: 34px;
  line-height: 1.25; }
  @media (max-width: 700px) {
    .mid-header {
      font-size: 28px; } }

.big-header {
  font-size: 52px;
  line-height: 1.15; }
  @media (max-width: 700px) {
    .big-header {
      font-size: 38px; } }

/* ===============================
   ACCESSIBILITY MODE
=============================== */
body.font-size-large {
  font-size: 22px;
  line-height: 1.7; }
  body.font-size-large .mid-text {
    font-size: 22px; }
  body.font-size-large .large-text {
    font-size: 28px; }
  body.font-size-large .mid-header {
    font-size: 40px; }

/* =========================================
   KICKER (Refined for Sweet & Brew)
========================================= */
.sh-paragraph-kicker {
  display: flex;
  align-items: center;
  gap: 14px;
  text-transform: uppercase;
  font-size: 13px;
  letter-spacing: 1.4px;
  font-weight: 500;
  color: var(--text-muted); }
  .sh-paragraph-kicker.sh-paragraph-kicker--inline {
    flex-direction: row; }
  .sh-paragraph-kicker.sh-paragraph-kicker--stacked {
    flex-direction: column;
    align-items: center;
    text-align: center; }
    .sh-paragraph-kicker.sh-paragraph-kicker--stacked .sh-paragraph-kicker__textwrap {
      order: 1; }
    .sh-paragraph-kicker.sh-paragraph-kicker--stacked .sh-paragraph-kicker__decor {
      order: 2;
      margin-top: 5px; }
    .sh-paragraph-kicker.sh-paragraph-kicker--stacked .sh-paragraph-kicker__line {
      width: 80px; }

.sh-paragraph-kicker__dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--sb-yellow);
  /* brand accent */ }

.sh-paragraph-kicker__line {
  width: 100px;
  height: 2px;
  background: var(--sb-yellow); }

.sh-paragraph-kicker__textwrap p {
  margin: 0; }

/**
 * Containers (parent wrapper approach)
 * Usage:
 * <div class="container"><div class="grid">...</div></div>
 * <div class="container-lg"><div class="grid">...</div></div>
 * <div class="container-xxl"><div class="grid">...</div></div>
 * <div class="container-sm container-flush"><div class="grid">...</div></div>
 */
.container,
.container-sm,
.container-lg,
.container-xxl {
  width: 100%;
  margin-left: auto;
  margin-right: auto;
  box-sizing: border-box;
  padding-left: 24px;
  padding-right: 24px; }
  @media (max-width: 900px) {
    .container,
    .container-sm,
    .container-lg,
    .container-xxl {
      padding-left: 18px;
      padding-right: 18px; } }
  @media (max-width: 600px) {
    .container,
    .container-sm,
    .container-lg,
    .container-xxl {
      padding-left: 14px;
      padding-right: 14px; } }

.container {
  max-width: 1200px; }

.container-sm {
  max-width: 920px; }

.container-lg {
  max-width: 1440px; }

.container-xxl {
  max-width: 1640px; }

.container-flush {
  padding-left: 0 !important;
  padding-right: 0 !important; }

/**
 * Grid System
 */
.grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr); }
  .grid.align-top {
    align-items: start; }
  .grid.align-center {
    align-items: center; }
  .grid.align-bottom {
    align-items: end; }
  .grid.justify-start {
    text-align: left; }
  .grid.justify-center {
    text-align: center; }
  .grid.justify-end {
    text-align: right; }
  .grid > .column.align-top {
    align-self: start; }
  .grid > .column.align-center {
    align-self: center; }
  .grid > .column.align-bottom {
    align-self: end; }
  .grid > .column.justify-start {
    text-align: left; }
  .grid > .column.justify-center {
    text-align: center; }
  .grid > .column.justify-end {
    text-align: right; }
  .grid > .column.width-1 {
    grid-column: span 1; }
  .grid > .column.width-2 {
    grid-column: span 2; }
  .grid > .column.width-3 {
    grid-column: span 3; }
  .grid > .column.width-4 {
    grid-column: span 4; }
  .grid > .column.width-5 {
    grid-column: span 5; }
  .grid > .column.width-6 {
    grid-column: span 6; }
  .grid > .column.width-7 {
    grid-column: span 7; }
  .grid > .column.width-8 {
    grid-column: span 8; }
  .grid > .column.width-9 {
    grid-column: span 9; }
  .grid > .column.width-10 {
    grid-column: span 10; }
  .grid > .column.width-11 {
    grid-column: span 11; }
  .grid > .column.width-12 {
    grid-column: span 12; }
  .grid > .column.order-0 {
    order: 0; }
  .grid > .column.order-1 {
    order: 1; }
  .grid > .column.order-2 {
    order: 2; }
  .grid > .column.order-3 {
    order: 3; }
  .grid > .column.order-4 {
    order: 4; }
  .grid > .column.order-5 {
    order: 5; }
  .grid > .column.order-6 {
    order: 6; }
  @media (max-width: 1800px) {
    .grid > .column.width-1800-1 {
      grid-column: span 1; }
    .grid > .column.width-1800-2 {
      grid-column: span 2; }
    .grid > .column.width-1800-3 {
      grid-column: span 3; }
    .grid > .column.width-1800-4 {
      grid-column: span 4; }
    .grid > .column.width-1800-5 {
      grid-column: span 5; }
    .grid > .column.width-1800-6 {
      grid-column: span 6; }
    .grid > .column.width-1800-7 {
      grid-column: span 7; }
    .grid > .column.width-1800-8 {
      grid-column: span 8; }
    .grid > .column.width-1800-9 {
      grid-column: span 9; }
    .grid > .column.width-1800-10 {
      grid-column: span 10; }
    .grid > .column.width-1800-11 {
      grid-column: span 11; }
    .grid > .column.width-1800-12 {
      grid-column: span 12; }
    .grid > .column.order-1800-0 {
      order: 0; }
    .grid > .column.order-1800-1 {
      order: 1; }
    .grid > .column.order-1800-2 {
      order: 2; }
    .grid > .column.order-1800-3 {
      order: 3; }
    .grid > .column.order-1800-4 {
      order: 4; }
    .grid > .column.order-1800-5 {
      order: 5; }
    .grid > .column.order-1800-6 {
      order: 6; } }
  @media (max-width: 1700px) {
    .grid > .column.width-1700-1 {
      grid-column: span 1; }
    .grid > .column.width-1700-2 {
      grid-column: span 2; }
    .grid > .column.width-1700-3 {
      grid-column: span 3; }
    .grid > .column.width-1700-4 {
      grid-column: span 4; }
    .grid > .column.width-1700-5 {
      grid-column: span 5; }
    .grid > .column.width-1700-6 {
      grid-column: span 6; }
    .grid > .column.width-1700-7 {
      grid-column: span 7; }
    .grid > .column.width-1700-8 {
      grid-column: span 8; }
    .grid > .column.width-1700-9 {
      grid-column: span 9; }
    .grid > .column.width-1700-10 {
      grid-column: span 10; }
    .grid > .column.width-1700-11 {
      grid-column: span 11; }
    .grid > .column.width-1700-12 {
      grid-column: span 12; }
    .grid > .column.order-1700-0 {
      order: 0; }
    .grid > .column.order-1700-1 {
      order: 1; }
    .grid > .column.order-1700-2 {
      order: 2; }
    .grid > .column.order-1700-3 {
      order: 3; }
    .grid > .column.order-1700-4 {
      order: 4; }
    .grid > .column.order-1700-5 {
      order: 5; }
    .grid > .column.order-1700-6 {
      order: 6; } }
  @media (max-width: 1600px) {
    .grid > .column.width-1600-1 {
      grid-column: span 1; }
    .grid > .column.width-1600-2 {
      grid-column: span 2; }
    .grid > .column.width-1600-3 {
      grid-column: span 3; }
    .grid > .column.width-1600-4 {
      grid-column: span 4; }
    .grid > .column.width-1600-5 {
      grid-column: span 5; }
    .grid > .column.width-1600-6 {
      grid-column: span 6; }
    .grid > .column.width-1600-7 {
      grid-column: span 7; }
    .grid > .column.width-1600-8 {
      grid-column: span 8; }
    .grid > .column.width-1600-9 {
      grid-column: span 9; }
    .grid > .column.width-1600-10 {
      grid-column: span 10; }
    .grid > .column.width-1600-11 {
      grid-column: span 11; }
    .grid > .column.width-1600-12 {
      grid-column: span 12; }
    .grid > .column.order-1600-0 {
      order: 0; }
    .grid > .column.order-1600-1 {
      order: 1; }
    .grid > .column.order-1600-2 {
      order: 2; }
    .grid > .column.order-1600-3 {
      order: 3; }
    .grid > .column.order-1600-4 {
      order: 4; }
    .grid > .column.order-1600-5 {
      order: 5; }
    .grid > .column.order-1600-6 {
      order: 6; } }
  @media (max-width: 1500px) {
    .grid > .column.width-1500-1 {
      grid-column: span 1; }
    .grid > .column.width-1500-2 {
      grid-column: span 2; }
    .grid > .column.width-1500-3 {
      grid-column: span 3; }
    .grid > .column.width-1500-4 {
      grid-column: span 4; }
    .grid > .column.width-1500-5 {
      grid-column: span 5; }
    .grid > .column.width-1500-6 {
      grid-column: span 6; }
    .grid > .column.width-1500-7 {
      grid-column: span 7; }
    .grid > .column.width-1500-8 {
      grid-column: span 8; }
    .grid > .column.width-1500-9 {
      grid-column: span 9; }
    .grid > .column.width-1500-10 {
      grid-column: span 10; }
    .grid > .column.width-1500-11 {
      grid-column: span 11; }
    .grid > .column.width-1500-12 {
      grid-column: span 12; }
    .grid > .column.order-1500-0 {
      order: 0; }
    .grid > .column.order-1500-1 {
      order: 1; }
    .grid > .column.order-1500-2 {
      order: 2; }
    .grid > .column.order-1500-3 {
      order: 3; }
    .grid > .column.order-1500-4 {
      order: 4; }
    .grid > .column.order-1500-5 {
      order: 5; }
    .grid > .column.order-1500-6 {
      order: 6; } }
  @media (max-width: 1400px) {
    .grid > .column.width-1400-1 {
      grid-column: span 1; }
    .grid > .column.width-1400-2 {
      grid-column: span 2; }
    .grid > .column.width-1400-3 {
      grid-column: span 3; }
    .grid > .column.width-1400-4 {
      grid-column: span 4; }
    .grid > .column.width-1400-5 {
      grid-column: span 5; }
    .grid > .column.width-1400-6 {
      grid-column: span 6; }
    .grid > .column.width-1400-7 {
      grid-column: span 7; }
    .grid > .column.width-1400-8 {
      grid-column: span 8; }
    .grid > .column.width-1400-9 {
      grid-column: span 9; }
    .grid > .column.width-1400-10 {
      grid-column: span 10; }
    .grid > .column.width-1400-11 {
      grid-column: span 11; }
    .grid > .column.width-1400-12 {
      grid-column: span 12; }
    .grid > .column.order-1400-0 {
      order: 0; }
    .grid > .column.order-1400-1 {
      order: 1; }
    .grid > .column.order-1400-2 {
      order: 2; }
    .grid > .column.order-1400-3 {
      order: 3; }
    .grid > .column.order-1400-4 {
      order: 4; }
    .grid > .column.order-1400-5 {
      order: 5; }
    .grid > .column.order-1400-6 {
      order: 6; } }
  @media (max-width: 1300px) {
    .grid > .column.width-1300-1 {
      grid-column: span 1; }
    .grid > .column.width-1300-2 {
      grid-column: span 2; }
    .grid > .column.width-1300-3 {
      grid-column: span 3; }
    .grid > .column.width-1300-4 {
      grid-column: span 4; }
    .grid > .column.width-1300-5 {
      grid-column: span 5; }
    .grid > .column.width-1300-6 {
      grid-column: span 6; }
    .grid > .column.width-1300-7 {
      grid-column: span 7; }
    .grid > .column.width-1300-8 {
      grid-column: span 8; }
    .grid > .column.width-1300-9 {
      grid-column: span 9; }
    .grid > .column.width-1300-10 {
      grid-column: span 10; }
    .grid > .column.width-1300-11 {
      grid-column: span 11; }
    .grid > .column.width-1300-12 {
      grid-column: span 12; }
    .grid > .column.order-1300-0 {
      order: 0; }
    .grid > .column.order-1300-1 {
      order: 1; }
    .grid > .column.order-1300-2 {
      order: 2; }
    .grid > .column.order-1300-3 {
      order: 3; }
    .grid > .column.order-1300-4 {
      order: 4; }
    .grid > .column.order-1300-5 {
      order: 5; }
    .grid > .column.order-1300-6 {
      order: 6; } }
  @media (max-width: 1200px) {
    .grid > .column.width-1200-1 {
      grid-column: span 1; }
    .grid > .column.width-1200-2 {
      grid-column: span 2; }
    .grid > .column.width-1200-3 {
      grid-column: span 3; }
    .grid > .column.width-1200-4 {
      grid-column: span 4; }
    .grid > .column.width-1200-5 {
      grid-column: span 5; }
    .grid > .column.width-1200-6 {
      grid-column: span 6; }
    .grid > .column.width-1200-7 {
      grid-column: span 7; }
    .grid > .column.width-1200-8 {
      grid-column: span 8; }
    .grid > .column.width-1200-9 {
      grid-column: span 9; }
    .grid > .column.width-1200-10 {
      grid-column: span 10; }
    .grid > .column.width-1200-11 {
      grid-column: span 11; }
    .grid > .column.width-1200-12 {
      grid-column: span 12; }
    .grid > .column.order-1200-0 {
      order: 0; }
    .grid > .column.order-1200-1 {
      order: 1; }
    .grid > .column.order-1200-2 {
      order: 2; }
    .grid > .column.order-1200-3 {
      order: 3; }
    .grid > .column.order-1200-4 {
      order: 4; }
    .grid > .column.order-1200-5 {
      order: 5; }
    .grid > .column.order-1200-6 {
      order: 6; } }
  @media (max-width: 1100px) {
    .grid > .column.width-1100-1 {
      grid-column: span 1; }
    .grid > .column.width-1100-2 {
      grid-column: span 2; }
    .grid > .column.width-1100-3 {
      grid-column: span 3; }
    .grid > .column.width-1100-4 {
      grid-column: span 4; }
    .grid > .column.width-1100-5 {
      grid-column: span 5; }
    .grid > .column.width-1100-6 {
      grid-column: span 6; }
    .grid > .column.width-1100-7 {
      grid-column: span 7; }
    .grid > .column.width-1100-8 {
      grid-column: span 8; }
    .grid > .column.width-1100-9 {
      grid-column: span 9; }
    .grid > .column.width-1100-10 {
      grid-column: span 10; }
    .grid > .column.width-1100-11 {
      grid-column: span 11; }
    .grid > .column.width-1100-12 {
      grid-column: span 12; }
    .grid > .column.order-1100-0 {
      order: 0; }
    .grid > .column.order-1100-1 {
      order: 1; }
    .grid > .column.order-1100-2 {
      order: 2; }
    .grid > .column.order-1100-3 {
      order: 3; }
    .grid > .column.order-1100-4 {
      order: 4; }
    .grid > .column.order-1100-5 {
      order: 5; }
    .grid > .column.order-1100-6 {
      order: 6; } }
  @media (max-width: 1000px) {
    .grid > .column.width-1000-1 {
      grid-column: span 1; }
    .grid > .column.width-1000-2 {
      grid-column: span 2; }
    .grid > .column.width-1000-3 {
      grid-column: span 3; }
    .grid > .column.width-1000-4 {
      grid-column: span 4; }
    .grid > .column.width-1000-5 {
      grid-column: span 5; }
    .grid > .column.width-1000-6 {
      grid-column: span 6; }
    .grid > .column.width-1000-7 {
      grid-column: span 7; }
    .grid > .column.width-1000-8 {
      grid-column: span 8; }
    .grid > .column.width-1000-9 {
      grid-column: span 9; }
    .grid > .column.width-1000-10 {
      grid-column: span 10; }
    .grid > .column.width-1000-11 {
      grid-column: span 11; }
    .grid > .column.width-1000-12 {
      grid-column: span 12; }
    .grid > .column.order-1000-0 {
      order: 0; }
    .grid > .column.order-1000-1 {
      order: 1; }
    .grid > .column.order-1000-2 {
      order: 2; }
    .grid > .column.order-1000-3 {
      order: 3; }
    .grid > .column.order-1000-4 {
      order: 4; }
    .grid > .column.order-1000-5 {
      order: 5; }
    .grid > .column.order-1000-6 {
      order: 6; } }
  @media (max-width: 900px) {
    .grid > .column.width-900-1 {
      grid-column: span 1; }
    .grid > .column.width-900-2 {
      grid-column: span 2; }
    .grid > .column.width-900-3 {
      grid-column: span 3; }
    .grid > .column.width-900-4 {
      grid-column: span 4; }
    .grid > .column.width-900-5 {
      grid-column: span 5; }
    .grid > .column.width-900-6 {
      grid-column: span 6; }
    .grid > .column.width-900-7 {
      grid-column: span 7; }
    .grid > .column.width-900-8 {
      grid-column: span 8; }
    .grid > .column.width-900-9 {
      grid-column: span 9; }
    .grid > .column.width-900-10 {
      grid-column: span 10; }
    .grid > .column.width-900-11 {
      grid-column: span 11; }
    .grid > .column.width-900-12 {
      grid-column: span 12; }
    .grid > .column.order-900-0 {
      order: 0; }
    .grid > .column.order-900-1 {
      order: 1; }
    .grid > .column.order-900-2 {
      order: 2; }
    .grid > .column.order-900-3 {
      order: 3; }
    .grid > .column.order-900-4 {
      order: 4; }
    .grid > .column.order-900-5 {
      order: 5; }
    .grid > .column.order-900-6 {
      order: 6; } }
  @media (max-width: 800px) {
    .grid > .column.width-800-1 {
      grid-column: span 1; }
    .grid > .column.width-800-2 {
      grid-column: span 2; }
    .grid > .column.width-800-3 {
      grid-column: span 3; }
    .grid > .column.width-800-4 {
      grid-column: span 4; }
    .grid > .column.width-800-5 {
      grid-column: span 5; }
    .grid > .column.width-800-6 {
      grid-column: span 6; }
    .grid > .column.width-800-7 {
      grid-column: span 7; }
    .grid > .column.width-800-8 {
      grid-column: span 8; }
    .grid > .column.width-800-9 {
      grid-column: span 9; }
    .grid > .column.width-800-10 {
      grid-column: span 10; }
    .grid > .column.width-800-11 {
      grid-column: span 11; }
    .grid > .column.width-800-12 {
      grid-column: span 12; }
    .grid > .column.order-800-0 {
      order: 0; }
    .grid > .column.order-800-1 {
      order: 1; }
    .grid > .column.order-800-2 {
      order: 2; }
    .grid > .column.order-800-3 {
      order: 3; }
    .grid > .column.order-800-4 {
      order: 4; }
    .grid > .column.order-800-5 {
      order: 5; }
    .grid > .column.order-800-6 {
      order: 6; } }
  @media (max-width: 700px) {
    .grid > .column.width-700-1 {
      grid-column: span 1; }
    .grid > .column.width-700-2 {
      grid-column: span 2; }
    .grid > .column.width-700-3 {
      grid-column: span 3; }
    .grid > .column.width-700-4 {
      grid-column: span 4; }
    .grid > .column.width-700-5 {
      grid-column: span 5; }
    .grid > .column.width-700-6 {
      grid-column: span 6; }
    .grid > .column.width-700-7 {
      grid-column: span 7; }
    .grid > .column.width-700-8 {
      grid-column: span 8; }
    .grid > .column.width-700-9 {
      grid-column: span 9; }
    .grid > .column.width-700-10 {
      grid-column: span 10; }
    .grid > .column.width-700-11 {
      grid-column: span 11; }
    .grid > .column.width-700-12 {
      grid-column: span 12; }
    .grid > .column.order-700-0 {
      order: 0; }
    .grid > .column.order-700-1 {
      order: 1; }
    .grid > .column.order-700-2 {
      order: 2; }
    .grid > .column.order-700-3 {
      order: 3; }
    .grid > .column.order-700-4 {
      order: 4; }
    .grid > .column.order-700-5 {
      order: 5; }
    .grid > .column.order-700-6 {
      order: 6; } }
  @media (max-width: 600px) {
    .grid > .column.width-600-1 {
      grid-column: span 1; }
    .grid > .column.width-600-2 {
      grid-column: span 2; }
    .grid > .column.width-600-3 {
      grid-column: span 3; }
    .grid > .column.width-600-4 {
      grid-column: span 4; }
    .grid > .column.width-600-5 {
      grid-column: span 5; }
    .grid > .column.width-600-6 {
      grid-column: span 6; }
    .grid > .column.width-600-7 {
      grid-column: span 7; }
    .grid > .column.width-600-8 {
      grid-column: span 8; }
    .grid > .column.width-600-9 {
      grid-column: span 9; }
    .grid > .column.width-600-10 {
      grid-column: span 10; }
    .grid > .column.width-600-11 {
      grid-column: span 11; }
    .grid > .column.width-600-12 {
      grid-column: span 12; }
    .grid > .column.order-600-0 {
      order: 0; }
    .grid > .column.order-600-1 {
      order: 1; }
    .grid > .column.order-600-2 {
      order: 2; }
    .grid > .column.order-600-3 {
      order: 3; }
    .grid > .column.order-600-4 {
      order: 4; }
    .grid > .column.order-600-5 {
      order: 5; }
    .grid > .column.order-600-6 {
      order: 6; } }
  @media (max-width: 500px) {
    .grid > .column.width-500-1 {
      grid-column: span 1; }
    .grid > .column.width-500-2 {
      grid-column: span 2; }
    .grid > .column.width-500-3 {
      grid-column: span 3; }
    .grid > .column.width-500-4 {
      grid-column: span 4; }
    .grid > .column.width-500-5 {
      grid-column: span 5; }
    .grid > .column.width-500-6 {
      grid-column: span 6; }
    .grid > .column.width-500-7 {
      grid-column: span 7; }
    .grid > .column.width-500-8 {
      grid-column: span 8; }
    .grid > .column.width-500-9 {
      grid-column: span 9; }
    .grid > .column.width-500-10 {
      grid-column: span 10; }
    .grid > .column.width-500-11 {
      grid-column: span 11; }
    .grid > .column.width-500-12 {
      grid-column: span 12; }
    .grid > .column.order-500-0 {
      order: 0; }
    .grid > .column.order-500-1 {
      order: 1; }
    .grid > .column.order-500-2 {
      order: 2; }
    .grid > .column.order-500-3 {
      order: 3; }
    .grid > .column.order-500-4 {
      order: 4; }
    .grid > .column.order-500-5 {
      order: 5; }
    .grid > .column.order-500-6 {
      order: 6; } }
  @media (max-width: 400px) {
    .grid > .column.width-400-1 {
      grid-column: span 1; }
    .grid > .column.width-400-2 {
      grid-column: span 2; }
    .grid > .column.width-400-3 {
      grid-column: span 3; }
    .grid > .column.width-400-4 {
      grid-column: span 4; }
    .grid > .column.width-400-5 {
      grid-column: span 5; }
    .grid > .column.width-400-6 {
      grid-column: span 6; }
    .grid > .column.width-400-7 {
      grid-column: span 7; }
    .grid > .column.width-400-8 {
      grid-column: span 8; }
    .grid > .column.width-400-9 {
      grid-column: span 9; }
    .grid > .column.width-400-10 {
      grid-column: span 10; }
    .grid > .column.width-400-11 {
      grid-column: span 11; }
    .grid > .column.width-400-12 {
      grid-column: span 12; }
    .grid > .column.order-400-0 {
      order: 0; }
    .grid > .column.order-400-1 {
      order: 1; }
    .grid > .column.order-400-2 {
      order: 2; }
    .grid > .column.order-400-3 {
      order: 3; }
    .grid > .column.order-400-4 {
      order: 4; }
    .grid > .column.order-400-5 {
      order: 5; }
    .grid > .column.order-400-6 {
      order: 6; } }
  .grid.gap-25 {
    gap: 25px; }
  .grid.gap-50 {
    gap: 50px; }

/**
 * Spacing Utilities
 */
.mt0 {
  margin-top: 0px !important; }

.mb0 {
  margin-bottom: 0px !important; }

.pt0 {
  padding-top: 0px !important; }

.pb0 {
  padding-bottom: 0px !important; }

.pl0 {
  padding-left: 0px !important; }

.pr0 {
  padding-right: 0px !important; }

.mt10 {
  margin-top: 10px !important; }

.mb10 {
  margin-bottom: 10px !important; }

.pt10 {
  padding-top: 10px !important; }

.pb10 {
  padding-bottom: 10px !important; }

.pl10 {
  padding-left: 10px !important; }

.pr10 {
  padding-right: 10px !important; }

.mt20 {
  margin-top: 20px !important; }

.mb20 {
  margin-bottom: 20px !important; }

.pt20 {
  padding-top: 20px !important; }

.pb20 {
  padding-bottom: 20px !important; }

.pl20 {
  padding-left: 20px !important; }

.pr20 {
  padding-right: 20px !important; }

.mt25 {
  margin-top: 25px !important; }

.mb25 {
  margin-bottom: 25px !important; }

.pt25 {
  padding-top: 25px !important; }

.pb25 {
  padding-bottom: 25px !important; }

.pl25 {
  padding-left: 25px !important; }

.pr25 {
  padding-right: 25px !important; }

.mt30 {
  margin-top: 30px !important; }

.mb30 {
  margin-bottom: 30px !important; }

.pt30 {
  padding-top: 30px !important; }

.pb30 {
  padding-bottom: 30px !important; }

.pl30 {
  padding-left: 30px !important; }

.pr30 {
  padding-right: 30px !important; }

.mt40 {
  margin-top: 40px !important; }

.mb40 {
  margin-bottom: 40px !important; }

.pt40 {
  padding-top: 40px !important; }

.pb40 {
  padding-bottom: 40px !important; }

.pl40 {
  padding-left: 40px !important; }

.pr40 {
  padding-right: 40px !important; }

.mt50 {
  margin-top: 50px !important; }

.mb50 {
  margin-bottom: 50px !important; }

.pt50 {
  padding-top: 50px !important; }

.pb50 {
  padding-bottom: 50px !important; }

.pl50 {
  padding-left: 50px !important; }

.pr50 {
  padding-right: 50px !important; }

.mt60 {
  margin-top: 60px !important; }

.mb60 {
  margin-bottom: 60px !important; }

.pt60 {
  padding-top: 60px !important; }

.pb60 {
  padding-bottom: 60px !important; }

.pl60 {
  padding-left: 60px !important; }

.pr60 {
  padding-right: 60px !important; }

.mt70 {
  margin-top: 70px !important; }

.mb70 {
  margin-bottom: 70px !important; }

.pt70 {
  padding-top: 70px !important; }

.pb70 {
  padding-bottom: 70px !important; }

.pl70 {
  padding-left: 70px !important; }

.pr70 {
  padding-right: 70px !important; }

.mt80 {
  margin-top: 80px !important; }

.mb80 {
  margin-bottom: 80px !important; }

.pt80 {
  padding-top: 80px !important; }

.pb80 {
  padding-bottom: 80px !important; }

.pl80 {
  padding-left: 80px !important; }

.pr80 {
  padding-right: 80px !important; }

.mt90 {
  margin-top: 90px !important; }

.mb90 {
  margin-bottom: 90px !important; }

.pt90 {
  padding-top: 90px !important; }

.pb90 {
  padding-bottom: 90px !important; }

.pl90 {
  padding-left: 90px !important; }

.pr90 {
  padding-right: 90px !important; }

.mt100 {
  margin-top: 100px !important; }

.mb100 {
  margin-bottom: 100px !important; }

.pt100 {
  padding-top: 100px !important; }

.pb100 {
  padding-bottom: 100px !important; }

.pl100 {
  padding-left: 100px !important; }

.pr100 {
  padding-right: 100px !important; }

.mt120 {
  margin-top: 120px !important; }

.mb120 {
  margin-bottom: 120px !important; }

.pt120 {
  padding-top: 120px !important; }

.pb120 {
  padding-bottom: 120px !important; }

.pl120 {
  padding-left: 120px !important; }

.pr120 {
  padding-right: 120px !important; }

.mt140 {
  margin-top: 140px !important; }

.mb140 {
  margin-bottom: 140px !important; }

.pt140 {
  padding-top: 140px !important; }

.pb140 {
  padding-bottom: 140px !important; }

.pl140 {
  padding-left: 140px !important; }

.pr140 {
  padding-right: 140px !important; }

.mt160 {
  margin-top: 160px !important; }

.mb160 {
  margin-bottom: 160px !important; }

.pt160 {
  padding-top: 160px !important; }

.pb160 {
  padding-bottom: 160px !important; }

.pl160 {
  padding-left: 160px !important; }

.pr160 {
  padding-right: 160px !important; }

.mt180 {
  margin-top: 180px !important; }

.mb180 {
  margin-bottom: 180px !important; }

.pt180 {
  padding-top: 180px !important; }

.pb180 {
  padding-bottom: 180px !important; }

.pl180 {
  padding-left: 180px !important; }

.pr180 {
  padding-right: 180px !important; }

.mt200 {
  margin-top: 200px !important; }

.mb200 {
  margin-bottom: 200px !important; }

.pt200 {
  padding-top: 200px !important; }

.pb200 {
  padding-bottom: 200px !important; }

.pl200 {
  padding-left: 200px !important; }

.pr200 {
  padding-right: 200px !important; }

/* =========================================================
   GUTENBERG → FRAMEWORK BRIDGE
   Scope: ONLY column parents
========================================================= */
/**
 * Base Gutenberg columns reset
 */
.wp-block-columns {
  width: 100%;
  box-sizing: border-box; }

/**
 * Parent-controlled column width system
 * This class is the explicit opt-in
 */
.parent-columns-width {
  margin-left: auto;
  margin-right: auto;
  width: 100%;
  box-sizing: border-box;
  padding-left: 24px;
  padding-right: 24px; }
  @media (max-width: 900px) {
    .parent-columns-width {
      padding-left: 18px;
      padding-right: 18px; } }
  @media (max-width: 600px) {
    .parent-columns-width {
      padding-left: 14px;
      padding-right: 14px; } }

/* ===============================
   WIDTH MODES
=============================== */
/* STANDARD (default container) */
.parent-columns-width:not(.wide-width):not(.small-width):not(.xs-width):not(.full-width) {
  max-width: 1200px; }

/* WIDE */
.parent-columns-width.wide-width {
  max-width: 1440px; }

/* SMALL */
.parent-columns-width.small-width {
  max-width: 920px; }

/* EXTRA SMALL */
.parent-columns-width.xs-width {
  max-width: 920px; }

/* FULL WIDTH (edge-to-edge) */
.parent-columns-width.full-width {
  max-width: none;
  padding-left: 0;
  padding-right: 0; }

/* ===============================
   COLUMN GAPS
=============================== */
/**
 * Gutenberg columns gap alignment
 * Mirrors your grid gap logic
 */
.parent-columns-width > .wp-block-column {
  box-sizing: border-box; }

/* Default gap */
.wp-block-columns {
  gap: 24px; }

/* Tablet */
@media (max-width: 900px) {
  .wp-block-columns {
    gap: 18px; } }
/* Mobile */
@media (max-width: 600px) {
  .wp-block-columns {
    gap: 14px; } }
/* ===============================
   OPTIONAL: ALIGNMENTS
=============================== */
.wp-block-columns.align-top {
  align-items: flex-start; }

.wp-block-columns.align-center {
  align-items: center; }

.wp-block-columns.align-bottom {
  align-items: flex-end; }

body {
  color: var(--text-body);
  background: var(--bg-subtle); }

/* Optional UI helpers */
.bg-panel {
  background: var(--bg-panel); }

.bg-subtle {
  background: var(--bg-subtle); }

/* =========================================================
   HEADER
========================================================= */
.header {
  position: fixed;
  top: 20px;
  left: 32px;
  right: 32px;
  z-index: 999;
  padding-inline: 20px;
  background-color: var(--sb-white);
  border-radius: 15px;
  transition: all .5s ease; }
  .header.sticky {
    left: 10px;
    right: 10px;
    background-color: rgba(255, 255, 255, 0.5);
    backdrop-filter: blur(10px);
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.2); }
  .header .brand a,
  .header .brand a:visited {
    color: var(--sb-slate);
    text-decoration: none;
    padding: 0 15px; }
  .header .brand svg {
    padding: 8px 10px; }

/* =========================================================
   NAVIGATION
========================================================= */
.nav-container {
  max-width: 100%;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between; }

#menu-main-navigation {
  margin-right: 20px; }

.nav-extra {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-right: 20px; }

/* =========================================================
   CONTACT BUTTON
========================================================= */
.contact-button {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 18px;
  border-radius: 30px;
  background: var(--brand);
  color: var(--brand-contrast);
  font-weight: 600;
  text-decoration: none;
  transition: opacity .3s ease; }
  .contact-button:hover {
    opacity: .75; }

.contact-icon {
  display: inline-block;
  vertical-align: middle; }

/* =========================================================
   NAV LIST
========================================================= */
.nav-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  justify-content: flex-end; }
  .nav-list li {
    position: relative; }
    .nav-list li a,
    .nav-list li a:visited {
      display: block;
      padding: 0 20px;
      line-height: 70px;
      color: var(--sb-slate);
      text-decoration: none;
      transition: color .3s ease, opacity .3s ease; }
      .nav-list li a:hover,
      .nav-list li a:visited:hover {
        color: var(--sb-yellow); }

/* =========================================================
   DROPDOWN
========================================================= */
.nav-dropdown {
  position: absolute;
  display: none;
  z-index: 10;
  padding: 0;
  list-style: none;
  background: var(--sb-slate);
  box-shadow: 0 3px 12px rgba(0, 0, 0, 0.15); }
  .nav-dropdown li {
    min-width: 190px; }
    .nav-dropdown li a {
      padding: 15px;
      line-height: 20px;
      color: var(--sb-white) !important; }
      .nav-dropdown li a:hover {
        opacity: .8; }

li.menu-item .dropdown-arrow {
  position: absolute;
  top: 23px;
  right: 5px; }

.dropdown-arrow {
  color: var(--sb-midgrey); }

/* =========================================================
   MOBILE NAV TOGGLE
========================================================= */
.nav-mobile {
  display: none;
  position: absolute;
  top: 0;
  right: 0;
  height: 70px;
  width: 70px; }
  .nav-mobile button {
    background: none;
    border: 0;
    height: 100%;
    width: 100%;
    cursor: pointer; }
    .nav-mobile button:focus {
      outline: none; }

#nav-toggle {
  position: relative;
  width: 35px;
  height: 25px;
  margin: auto; }
  #nav-toggle span,
  #nav-toggle span::before,
  #nav-toggle span::after {
    position: absolute;
    content: "";
    width: 100%;
    height: 4px;
    border-radius: 2px;
    background: var(--sb-slate);
    transition: all 300ms ease-in-out; }
  #nav-toggle span {
    top: 50%;
    transform: translateY(-50%); }
  #nav-toggle span::before {
    top: -10px; }
  #nav-toggle span::after {
    bottom: -10px; }
  #nav-toggle.active span {
    background: transparent; }
    #nav-toggle.active span::before {
      transform: rotate(45deg);
      top: 0; }
    #nav-toggle.active span::after {
      transform: rotate(-45deg);
      bottom: 0; }

/* =========================================================
   LANGUAGE SWITCHER
========================================================= */
.lang-switcher {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  line-height: 1; }
  .lang-switcher span {
    color: var(--sb-slate);
    opacity: .35; }
  .lang-switcher a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: 32px;
    min-width: 38px;
    padding: 0 10px;
    border-radius: 20px;
    border: 1px solid rgba(0, 0, 0, 0.12);
    font-weight: 600;
    font-size: 14px;
    text-decoration: none;
    color: var(--sb-slate);
    transition: all .2s ease; }
    .lang-switcher a.active {
      background: var(--brand);
      color: var(--brand-contrast);
      border-color: transparent; }
    .lang-switcher a:not(.active):hover {
      background: rgba(0, 0, 0, 0.06); }

.header.sticky .lang-switcher a {
  border-color: rgba(0, 0, 0, 0.2); }
.header.sticky .lang-switcher span {
  opacity: .5; }

/* =========================================================
   RESPONSIVE
========================================================= */
/******* ANIMATING **********/
.animating {
  opacity: 0;
  transform: translate(0, 50px);
  transition: all 1.2s; }
  .animating.in-view {
    opacity: 1;
    transform: translate(0, 0); }
    .animating.in-view.delay1 {
      transition-delay: 300ms; }
    .animating.in-view.delay2 {
      transition-delay: 600ms; }
    .animating.in-view.delay3 {
      transition-delay: 900ms; }
    .animating.in-view.delay4 {
      transition-delay: 1200ms; }
    .animating.in-view.delay5 {
      transition-delay: 1500ms; }
    .animating.in-view.delay6 {
      transition-delay: 1800ms; }
    .animating.in-view.delay7 {
      transition-delay: 2100ms; }
    .animating.in-view.delay8 {
      transition-delay: 2400ms; }
    .animating.in-view.delay9 {
      transition-delay: 2700ms; }
    .animating.in-view.delay10 {
      transition-delay: 3000ms; }
    .animating.in-view.delay11 {
      transition-delay: 3300ms; }
    .animating.in-view.delay12 {
      transition-delay: 3600ms; }

/* Lenis */
html.lenis,
html.lenis body {
  height: auto; }

.lenis.lenis-smooth {
  scroll-behavior: auto !important; }
  .lenis.lenis-smooth [data-lenis-prevent] {
    overscroll-behavior: contain; }
  .lenis.lenis-smooth iframe {
    pointer-events: none; }
.lenis.lenis-stopped {
  overflow: hidden; }

/* Animations */
@keyframes header {
  0% {
    transform: scaleY(0);
    transform-origin: 100% 0;
    opacity: 1; }
  100% {
    transform: scaleY(1);
    transform-origin: 100% 0;
    opacity: 1; } }
@keyframes waves {
  0% {
    transform: scale(0.2);
    opacity: 0; }
  50% {
    opacity: .9; }
  100% {
    transform: scale(0.9);
    opacity: 0; } }
html.lenis,
html.lenis body {
  height: auto; }

.lenis.lenis-smooth {
  scroll-behavior: auto !important; }

.lenis.lenis-smooth [data-lenis-prevent] {
  overscroll-behavior: contain; }

.lenis.lenis-stopped {
  overflow: hidden; }

.lenis.lenis-smooth iframe {
  pointer-events: none; }

/* =========================================================
   sb BUTTON (global, CSS-variable driven)
   Used everywhere, including Gravity Forms
========================================================= */
.sb-btn {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 15px 25px;
  background: var(--sb-btn-bg);
  border: 2px solid var(--sb-btn-border);
  color: var(--sb-btn-text);
  font-size: 14px;
  text-transform: uppercase;
  font-weight: 600;
  cursor: pointer;
  text-decoration: none;
  -webkit-appearance: none;
  appearance: none;
  transition: border-color 0.3s ease;
  /* Corner details */ }
  .sb-btn:hover {
    border-color: var(--sb-btn-border-hover); }
  .sb-btn::before, .sb-btn::after {
    content: "";
    position: absolute;
    inset: -2px;
    pointer-events: none; }
  .sb-btn::before {
    background: linear-gradient(var(--sb-btn-corner), var(--sb-btn-corner)) 0 0/6px 2px no-repeat, linear-gradient(var(--sb-btn-corner), var(--sb-btn-corner)) 0 0/2px 6px no-repeat, linear-gradient(var(--sb-btn-corner), var(--sb-btn-corner)) 100% 0/6px 2px no-repeat, linear-gradient(var(--sb-btn-corner), var(--sb-btn-corner)) 100% 0/2px 6px no-repeat; }
  .sb-btn::after {
    background: linear-gradient(var(--sb-btn-corner), var(--sb-btn-corner)) 0 100%/6px 2px no-repeat, linear-gradient(var(--sb-btn-corner), var(--sb-btn-corner)) 0 100%/2px 6px no-repeat, linear-gradient(var(--sb-btn-corner), var(--sb-btn-corner)) 100% 100%/6px 2px no-repeat, linear-gradient(var(--sb-btn-corner), var(--sb-btn-corner)) 100% 100%/2px 6px no-repeat; }
  .sb-btn .content {
    position: relative;
    overflow: hidden;
    font-size: inherit;
    line-height: 1.2em;
    height: 1.2em; }
  .sb-btn .text,
  .sb-btn .hover-text {
    display: block;
    transition: transform 300ms cubic-bezier(0.16, 1, 0.3, 1); }
  .sb-btn:hover .vertical .text, .sb-btn:hover .vertical .hover-text {
    transform: translateY(-100%); }
  .sb-btn .hover-text {
    position: absolute;
    left: 0;
    bottom: -100%; }
  @media (max-width: 768px) {
    .sb-btn {
      padding: 22px 50px;
      font-size: 22px; } }

/* =========================================================
   GRAVITY FORMS VARIANT
========================================================= */
.sb-btn--gf {
  /* Bronze theme for GF buttons */
  --sb-btn-bg: transparent;
  --sb-btn-border: var(--bronze);
  --sb-btn-border-hover: var(--bronze);
  --sb-btn-text: var(--bronze);
  --sb-btn-corner: var(--bronze); }

/* Layout for submit button */
.sb-btn.sb-btn--gf {
  width: 100%;
  margin: 30px auto 0;
  display: flex; }

/* Center inside Gravity Forms footer */
.gform_footer,
.gform_page_footer {
  text-align: center; }

.gform_footer,
.gform_footer.top_label {
  position: relative;
  z-index: 10;
  padding: 0 !important;
  margin: 0 !important;
  line-height: 0 !important; }

/* Prevent weird overflow from wrappers */
.gform_wrapper .gform_footer,
.gform_wrapper .gform_page_footer {
  overflow: visible !important; }

.gform_footer,
.gform_footer *:not(button) {
  pointer-events: none; }

button.sb-btn {
  pointer-events: auto; }

/* ==========================================================================
   STATIONERS' HALL — Gravity Forms Styling
   ========================================================================== */
.sh-form,
.gform_wrapper {
  --form-border: #FFFFFF;
  --form-bg: #ffffff;
  --form-text: #4A4A4A;
  --form-placeholder: #A8A8A8;
  font-family: inherit; }

/* ---------------------------------------------
   GLOBAL FIELD SPACING
--------------------------------------------- */
.gform_wrapper .gfield {
  margin-bottom: 5px; }

.gform_wrapper .gfield_label {
  font-size: 15px;
  font-weight: 500;
  text-transform: none;
  color: var(--form-text);
  margin-bottom: 0; }

.gform_required_legend {
  display: none; }

.gform_wrapper.gravity-theme .ginput_container_date input {
  width: 100%; }

/* ---------------------------------------------
   INPUT + TEXTAREA
--------------------------------------------- */
.gform_wrapper input[type="text"],
.gform_wrapper input[type="email"],
.gform_wrapper input[type="tel"],
.gform_wrapper input[type="number"],
.gform_wrapper input[type="url"],
.gform_wrapper select,
.gform_wrapper textarea {
  width: 100%;
  background: var(--form-bg);
  border: 1px solid var(--form-border);
  padding: 14px 16px !important;
  font-size: 16px;
  color: var(--form-text);
  border-radius: 0;
  outline: none;
  appearance: none; }

.gform_wrapper input::placeholder,
.gform_wrapper textarea::placeholder {
  color: var(--form-placeholder); }

/* ---------------------------------------------
   TWO-COLUMN LAYOUT (like your screenshot)
--------------------------------------------- */
.gform_wrapper .gform_fields {
  display: grid !important;
  grid-template-columns: 1fr 1fr;
  gap: 24px 40px; }

.gform_wrapper .gfield.gfield--width-full {
  grid-column: 1 / 3; }

/* force email, phone etc. into two columns */
.gform_wrapper .left-half,
.gform_wrapper .right-half {
  grid-column: span 1; }

/* ---------------------------------------------
   SECTION TITLES — matches kicker-stacked style
--------------------------------------------- */
.gform_wrapper .gsection_title {
  position: relative;
  display: flex;
  align-items: center;
  gap: 14px;
  font-size: 15px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--bronze);
  margin: 40px 0 20px; }

/* decorative line + dots */
.gform_wrapper .gsection_title::before,
.gform_wrapper .gsection_title::after {
  content: '';
  display: inline-block;
  width: 60px;
  height: 2px;
  background: var(--bronze); }

.gform_wrapper .gsection_title::before {
  margin-right: 8px; }

.gform_wrapper .gsection_title::after {
  margin-left: 8px;
  border-radius: 50%;
  width: 6px;
  height: 6px; }

/* ---------------------------------------------
   SELECT FIELD — custom arrow
--------------------------------------------- */
.gform_wrapper select {
  background-image: linear-gradient(45deg, transparent 50%, var(--bronze) 50%), linear-gradient(135deg, var(--bronze) 50%, transparent 50%);
  background-position: calc(100% - 18px) calc(1em - 3px), calc(100% - 13px) calc(1em - 3px);
  background-size: 5px 5px, 5px 5px;
  background-repeat: no-repeat; }

/* ---------------------------------------------
   SUBMIT BUTTON
--------------------------------------------- */
.gform_wrapper .gform_footer input[type="submit"] {
  display: block;
  width: 100%;
  background: transparent;
  border: 1px solid var(--bronze);
  padding: 16px 22px;
  text-align: center;
  font-size: 16px;
  letter-spacing: 0.06em;
  color: var(--bronze);
  text-transform: uppercase;
  cursor: pointer;
  transition: 0.25s ease; }

.gform_wrapper .gform_footer input[type="submit"]:hover {
  background: var(--bronze);
  color: #fff; }

/* ---------------------------------------------
   CHECKBOX + CONSENT (matches screenshot)
--------------------------------------------- */
.gform_wrapper .ginput_container_consent input[type="checkbox"] {
  width: 16px;
  height: 16px;
  border: 1px solid var(--bronze);
  margin-right: 10px;
  appearance: none;
  cursor: pointer;
  position: relative; }

.gform_wrapper .ginput_container_consent input[type="checkbox"]:checked::after {
  content: "";
  position: absolute;
  width: 10px;
  height: 10px;
  background: var(--bronze);
  top: 2px;
  left: 2px; }

.gform_wrapper .ginput_container_consent label {
  display: flex;
  align-items: center;
  line-height: 1.4;
  cursor: pointer; }

/* ---------------------------------------------
   HR separator
--------------------------------------------- */
.gform_wrapper .gsection {
  border-top: 1px solid var(--bronze);
  padding-top: 20px; }

.gform_footer,
.gform_page_footer {
  position: relative;
  z-index: 20;
  overflow: visible !important;
  /* IMPORTANT */
  line-height: normal !important;
  /* Fix collapsed box */
  min-height: auto !important;
  /* Ensures natural height */
  padding: 20px 0 !important;
  /* Gives breathing room */ }

.gform_footer,
.gform_footer *:not(button) {
  pointer-events: none; }

.sh-btn.sh-btn--gf {
  position: relative;
  z-index: 50;
  /* Bring above GF wrappers */ }

.geo-button-block {
  display: flex;
  flex-wrap: wrap;
  gap: var(--btn-gap); }
  .geo-button-block.is-align-left {
    justify-content: flex-start; }
  .geo-button-block.is-align-center {
    justify-content: center; }
  .geo-button-block.is-align-right {
    justify-content: flex-end; }

.woocommerce div.product div.images {
  float: none;
  width: 100%; }
  .woocommerce div.product div.images img {
    border-radius: 12px;
    width: 100%;
    height: auto;
    object-fit: cover; }

/* =========================================================
   FAMILY ACCENT SYSTEM
========================================================= */
.sb-family-tea {
  --sb-accent: var(--accent-tea);
  --sb-accent-soft: var(--accent-tea-100); }

.sb-family-coffee {
  --sb-accent: var(--accent-coffee);
  --sb-accent-soft: var(--accent-coffee-100); }

.sb-family-spices {
  --sb-accent: var(--accent-spice);
  --sb-accent-soft: color-mix(in oklab, var(--accent-spice) 20%, white); }

.sb-family-sweets {
  --sb-accent: var(--accent-sweet);
  --sb-accent-soft: var(--accent-sweet-100); }

/* =========================================================
   SINGLE PRODUCT
========================================================= */
.single-product-wrapper {
  padding-top: 60px; }

.single-product-inner {
  background: var(--sb-white);
  border-radius: 16px;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.12);
  margin: 0 24px; }

.single-product-base-content {
  padding: 6px 0 10px; }
  .single-product-base-content .product_title {
    font-family: var(--font-display, Georgia, serif);
    font-weight: 700;
    font-size: clamp(1.6rem, calc(1.5vw + 1.1rem), 2.4rem);
    line-height: 1.15;
    margin-bottom: 8px;
    letter-spacing: .2px; }
  .single-product-base-content .sb-family-tea .product_title,
  .single-product-base-content .sb-family-coffee .product_title,
  .single-product-base-content .sb-family-spices .product_title,
  .single-product-base-content .sb-family-sweets .product_title {
    color: var(--sb-accent); }
  .single-product-base-content .product-short-desc {
    color: #444;
    font-size: 1.1rem;
    line-height: 1.55; }
  .single-product-base-content .posted_in {
    margin: 10px 0 14px;
    color: rgba(0, 0, 0, 0.65);
    font-size: .95rem; }

/* Reset Woo image floats */
.woocommerce div.product div.images {
  float: none;
  width: 100%; }
  .woocommerce div.product div.images img {
    border-radius: 12px;
    width: 100%;
    height: auto;
    object-fit: cover; }

/* =========================================================
   PRICE AREA
========================================================= */
.sb-price-meta-row {
  margin: 10px 0 14px; }
  .sb-price-meta-row .price {
    font-size: clamp(1.6rem, calc(2vw + 1rem), 2.4rem);
    font-weight: 800;
    color: var(--sb-accent, var(--brand-yellow)); }

.sb-price-line {
  display: flex;
  align-items: baseline;
  gap: .5rem; }

.sb-sale-badge {
  display: inline-block;
  padding: .15rem .5rem;
  border-radius: 999px;
  font-size: .9rem;
  font-weight: 700;
  background: #ffefcc;
  border: 1px solid color-mix(in oklab, #f4b011 70%, #000);
  color: #332600; }

.sb-meta-line {
  opacity: .75; }

/* =========================================================
   CUSTOM WEIGHT FORM
========================================================= */
.custom-weight-form .sb-buy-row {
  display: flex;
  align-items: center;
  gap: .75rem 1rem;
  margin: .75rem 0 .5rem; }
.custom-weight-form .sb-label {
  font-weight: 600;
  font-size: .95rem; }
.custom-weight-form select,
.custom-weight-form .sb-select {
  height: 40px;
  padding: 6px 12px;
  border: 1px solid var(--sb-mild-ash, #d6d3cc);
  border-radius: 10px;
  background: #fff;
  font-size: .95rem; }
.custom-weight-form .sb-price-hint {
  opacity: .8;
  font-size: .92rem;
  margin-bottom: .35rem; }
.custom-weight-form .sb-total-preview {
  font-weight: 700;
  font-size: 1.1rem;
  color: #332600;
  margin-bottom: .5rem; }
.custom-weight-form .sb-add-to-cart-row {
  margin-top: .35rem; }
.custom-weight-form .single_add_to_cart_button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 40px;
  padding: 0 18px;
  border-radius: 999px;
  font-weight: 700;
  background: var(--sb-accent);
  border: 1px solid color-mix(in oklab, var(--sb-accent) 70%, #000);
  color: #fff; }
  .custom-weight-form .single_add_to_cart_button:hover {
    background: color-mix(in oklab, var(--sb-accent) 85%, #000); }

/* =========================================================
   WOO NOTICES
========================================================= */
.woocommerce-notices-wrapper {
  margin-top: 60px; }

.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
  margin: 30px 23px;
  padding: 16px 18px 16px 56px;
  position: relative;
  background: var(--sb-white, #fff);
  border-radius: 20px;
  box-shadow: 0 8px 22px rgba(0, 0, 0, 0.08);
  color: #4a4a4a;
  display: flex;
  align-items: center;
  gap: 16px; }
  .woocommerce-message::before,
  .woocommerce-info::before,
  .woocommerce-error::before {
    content: "✓";
    position: absolute;
    left: 16px;
    top: 50%;
    transform: translateY(-50%);
    width: 26px;
    height: 26px;
    border-radius: 50%;
    display: grid;
    place-items: center;
    font-weight: 700;
    background: var(--brand-yellow, #f4b011);
    color: #fff;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.12); }

/* =========================================================
   WOO BUTTON SYSTEM
========================================================= */
:root {
  --sb-btn-radius: 20px;
  --sb-btn-bg: var(--brand-yellow, #f4b011);
  --sb-btn-text: #111;
  --sb-btn-border: color-mix(in oklab, var(--sb-btn-bg) 70%, #000); }

.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.woocommerce .button,
.woocommerce .single_add_to_cart_button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .5rem;
  font-family: var(--font-display, Georgia, serif);
  font-weight: 600;
  height: 44px;
  padding: 0 18px;
  border-radius: var(--sb-btn-radius);
  background: var(--sb-btn-bg);
  color: var(--sb-btn-text);
  border: 1px solid var(--sb-btn-border);
  transition: all .25s ease; }
  .woocommerce a.button:hover,
  .woocommerce button.button:hover,
  .woocommerce input.button:hover,
  .woocommerce #respond input#submit:hover,
  .woocommerce .button:hover,
  .woocommerce .single_add_to_cart_button:hover {
    background: color-mix(in oklab, var(--sb-btn-bg) 85%, #000);
    transform: translateY(-1px); }
  .woocommerce a.button:active,
  .woocommerce button.button:active,
  .woocommerce input.button:active,
  .woocommerce #respond input#submit:active,
  .woocommerce .button:active,
  .woocommerce .single_add_to_cart_button:active {
    transform: translateY(0); }
  .woocommerce a.button:disabled, .woocommerce a.button.disabled,
  .woocommerce button.button:disabled,
  .woocommerce button.button.disabled,
  .woocommerce input.button:disabled,
  .woocommerce input.button.disabled,
  .woocommerce #respond input#submit:disabled,
  .woocommerce #respond input#submit.disabled,
  .woocommerce .button:disabled,
  .woocommerce .button.disabled,
  .woocommerce .single_add_to_cart_button:disabled,
  .woocommerce .single_add_to_cart_button.disabled {
    opacity: .55 !important;
    pointer-events: none;
    transform: none; }
.woocommerce a.added_to_cart {
  margin-left: .5rem;
  font-weight: 600;
  color: var(--sb-btn-bg); }
  .woocommerce a.added_to_cart:hover {
    text-decoration: underline; }

/* =========================================================
   PRODUCT INFO CARDS
========================================================= */
.sb-cards-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 16px; }

.sb-card {
  background: var(--sb-white, #fff);
  border-radius: 20px;
  padding: 16px 18px;
  display: flex;
  flex-direction: column;
  min-height: 220px;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.12); }
  .sb-card-head {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 10px;
    padding: 10px;
    border-radius: 16px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04); }
  .sb-card-title {
    margin: 0;
    font-family: var(--font-display, Georgia, serif);
    font-weight: 700;
    font-size: 1.15rem; }
  .sb-card-body {
    font-size: 15px;
    padding: 10px 15px 10px 15px; }
    .sb-card-body ul, .sb-card-body ol {
      padding-left: 20px;
      margin: 0; }
    .sb-card-body h4 {
      margin: 10px 0; }
  .sb-card:hover .sb-card-icon i {
    transform: translateY(-1px); }

.sb-card-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: var(--sb-white, #fff);
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.06); }
  .sb-card-icon i {
    font-size: 22px;
    line-height: 1;
    color: #332600; }

/* =========================================================
   CARD COLOR VARIANTS
========================================================= */
:root {
  --card-ingredients: #FFF4E3;
  --card-brewing_instructions: #FFF6E8;
  --card-brewing_tips: #EAF7F2;
  --card-summer_recipes: #FFEFF6;
  --card-cold_brew: #EAF3FF;
  --card-taste_aroma: #F3F0FF;
  --card-what_makes_special: #FFF8EA;
  --card-good_to_know: #F2FFF6;
  --card-allergens_nutrition: #FFECEF; }

.sb-card--ingredients .sb-card-head {
  background: var(--card-ingredients); }

.sb-card--brewing_instructions .sb-card-head {
  background: var(--card-brewing_instructions); }

.sb-card--brewing_tips .sb-card-head {
  background: var(--card-brewing_tips); }

.sb-card--summer_recipes .sb-card-head {
  background: var(--card-summer_recipes); }

.sb-card--cold_brew .sb-card-head {
  background: var(--card-cold_brew); }

.sb-card--taste_aroma .sb-card-head {
  background: var(--card-taste_aroma); }

.sb-card--what_makes_special .sb-card-head {
  background: var(--card-what_makes_special); }

.sb-card--good_to_know .sb-card-head {
  background: var(--card-good_to_know); }

.sb-card--allergens_nutrition .sb-card-head {
  background: var(--card-allergens_nutrition); }
