@charset "UTF-8";
/*!
* Theme Name: Myrvann
* Template: ousia
*/
:root {
  --min-font: 17;
  --max-font: 19;
  --inline-width: 42;
  --inline-wide: 62;
  --min-fluid-width: 390;
  --max-fluid-width: 1920;
  --wide-width: min(95vw, var(--font-size)* var(--inline-wide));
  --footer-canopy-height: 80px;
  --border-radius: 3px;
  --color-brown-900: hsl(22, 56%, 13%);
  --color-brown-800: hsl(24, 52%, 18%);
  --color-brown-700: hsl(26, 50%, 24%);
  --color-brown-600: hsl(22, 46%, 28%);
  --color-brown-500: hsl(28, 50%, 35%);
  --color-brown-400: hsl(30, 30%, 32%);
  --color-cream-50: hsl(0, 0%, 100%);
  --color-cream-100: hsl(38, 80%, 97%);
  --color-cream-200: hsl(40, 70%, 94%);
  --color-cream-300: hsl(42, 55%, 91%);
  --color-cream-400: hsl(40, 48%, 87%);
  --color-cream-500: hsl(38, 45%, 82%);
  --color-cream-600: hsl(36, 42%, 76%);
  --color-cream-700: hsl(35, 40%, 68%);
  --color-cream-800: hsl(34, 38%, 56%);
  --color-cream-900: hsl(32, 30%, 46%);
  --color-editor-cream: #f0eada;
  --color-editor-coffee: #4a443f;
  --color-editor-sage: #a0afa5;
  --color-border-light: hsl(38, 38%, 82%);
  --text-color: var(--color-brown-700);
  --text-color-dark: var(--color-brown-900);
  --text-color-muted: var(--color-brown-400);
  --link-color: var(--color-brown-500);
  --accent-color: hsl(24, 60%, 23%);
  --accent-color-hover: hsl(24, 60%, 18%);
  --bg-color: var(--color-cream-50);
  --bg-color-light: var(--color-cream-200);
  --bg-color-hover: var(--color-cream-600);
  --bg-color-selected: var(--color-cream-700);
  --bg-color-alt: var(--color-cream-100);
  --border-color: var(--color-brown-600);
  --border-color-light: var(--color-border-light);
  --border-color-divider: var(--color-cream-900);
  --border-color-inset: hsla(29, 53%, 36%, 0.2);
  --decorative-gold: var(--color-cream-800);
  --decorative-underline: var(--color-brown-500);
  --shadow-color: hsla(24, 48%, 28%, 0.07);
  --shadow-color-medium: hsla(33, 25%, 28%, 0.08);
  --shadow-color-dark: hsla(0, 0%, 0%, 0.1);
  --shadow-color-heavy: hsla(0, 0%, 0%, 0.2);
  --gradient-button: linear-gradient(145deg, var(--border-color) 0%, var(--link-color) 100%);
  --gradient-button-hover: linear-gradient(145deg, var(--text-color) 0%, var(--link-color) 100%);
  --gradient-button-active: linear-gradient(145deg, var(--color-brown-800) 0%, var(--border-color) 100%);
  --gradient-button-submit: linear-gradient(to bottom, var(--link-color) 0%, var(--border-color) 100%);
  --gradient-button-submit-hover: linear-gradient(to bottom, hsl(29, 45%, 42%) 0%, hsl(24, 40%, 35%) 100%);
  --gradient-card: linear-gradient(to bottom, var(--bg-color-light) 0%, var(--color-cream-400) 100%);
  --gradient-decorative: linear-gradient(to right, var(--border-color), transparent);
  --gradient-divider: linear-gradient(to right, transparent, var(--border-color), transparent);
  --glow-cream-subtle: hsla(42, 100%, 95%, 0.2);
  --glow-cream-medium: hsla(42, 100%, 95%, 0.3);
  --glow-cream-strong: hsla(42, 100%, 95%, 0.7);
  --glow-cream-solid: hsla(42, 100%, 95%, 0.9);
  --glow-white: hsla(0, 0%, 100%, 0.2);
  --glow-gold-faint: hsla(40, 55%, 78%, 0.08);
  --glow-gold-light: hsla(40, 55%, 78%, 0.3);
  --glow-gold-medium: hsla(40, 55%, 78%, 0.5);
  --overlay-stripe: hsla(0, 0%, 0%, 0.05);
  --shadow-color-subtle: hsla(0, 0%, 0%, 0.03);
  --bg-hover-neutral: hsl(0, 0%, 92%);
  --border-input-neutral: hsl(0, 0%, 75%);
  --bg-code: hsl(22, 11%, 95%);
  --border-faq-light: hsla(24, 48%, 80%, 0.3);
  --border-faq-medium: hsla(24, 48%, 80%, 0.5);
  --gradient-fade-out: linear-gradient(to bottom, hsla(24, 48%, 95%, 0) 0%, hsla(30, 43%, 100%, 0.55) 55%, hsla(30, 43%, 100%, 1) 100%);
  --wc-inline-desc-fade-out-ms: 120ms;
  --wc-inline-desc-fade-out-stagger-ms: 20ms;
  --wc-inline-desc-fade-out-tail-ms: 20ms;
  --wc-inline-desc-fade-in-ms: 150ms;
  --wc-inline-desc-fade-in-stagger-ms: 18ms;
  --wc-inline-desc-fade-in-grow-ratio: 0.28;
  --color-terracotta-light: hsl(14, 45%, 72%);
  --color-terracotta: hsl(12, 50%, 48%);
  --color-terracotta-dark: hsl(10, 48%, 34%);
  --color-sage-light: hsl(145, 18%, 76%);
  --color-sage: hsl(150, 16%, 52%);
  --color-sage-dark: hsl(155, 20%, 34%);
  --color-spice-light: hsl(42, 65%, 74%);
  --color-spice: hsl(38, 60%, 52%);
  --color-spice-dark: hsl(34, 55%, 38%);
  --color-berry-light: hsl(340, 22%, 72%);
  --color-berry: hsl(345, 25%, 42%);
  --color-berry-dark: hsl(348, 30%, 28%);
  --color-clay-light: hsl(28, 12%, 72%);
  --color-clay: hsl(25, 10%, 52%);
  --color-clay-dark: hsl(22, 12%, 36%);
  --gradient-cacao-origin: linear-gradient(
  	135deg,
  	var(--color-brown-800) 0%,
  	var(--color-terracotta-dark) 50%,
  	var(--color-terracotta) 100%
  );
  --gradient-plantation: linear-gradient(
  	to bottom,
  	var(--color-cream-200) 0%,
  	var(--color-sage-light) 60%,
  	var(--color-sage) 100%
  );
  --gradient-harvest: linear-gradient(
  	to right,
  	var(--color-spice-dark) 0%,
  	var(--color-spice) 40%,
  	var(--color-spice-light) 100%
  );
  --gradient-fermented: linear-gradient(
  	160deg,
  	var(--color-berry-dark) 0%,
  	var(--color-berry) 45%,
  	var(--color-brown-500) 100%
  );
  --gradient-earth-leaf: radial-gradient(
  	ellipse at 30% 50%,
  	var(--color-sage-light) 0%,
  	var(--color-clay-light) 50%,
  	var(--color-cream-400) 100%
  );
  --gradient-golden-hour: linear-gradient(
  	to bottom right,
  	hsla(38, 60%, 52%, 0.25) 0%,
  	hsla(42, 65%, 74%, 0.12) 40%,
  	transparent 100%
  );
  --gradient-cacao-shimmer: linear-gradient(
  	145deg,
  	var(--color-brown-700) 0%,
  	var(--color-spice-dark) 30%,
  	var(--color-cream-700) 55%,
  	var(--color-spice-dark) 75%,
  	var(--color-brown-700) 100%
  );
}

@font-face {
  font-family: "new-spirit";
  src: url("https://use.typekit.net/af/73dea6/00000000000000007735c4b8/30/l?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n3&v=3") format("woff2"), url("https://use.typekit.net/af/73dea6/00000000000000007735c4b8/30/d?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n3&v=3") format("woff"), url("https://use.typekit.net/af/73dea6/00000000000000007735c4b8/30/a?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n3&v=3") format("opentype");
  font-display: auto;
  font-style: normal;
  font-weight: 300;
  font-stretch: normal;
}
@font-face {
  font-family: "new-spirit";
  src: url("https://use.typekit.net/af/69c2f9/00000000000000007735c4ba/30/l?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n4&v=3") format("woff2"), url("https://use.typekit.net/af/69c2f9/00000000000000007735c4ba/30/d?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n4&v=3") format("woff"), url("https://use.typekit.net/af/69c2f9/00000000000000007735c4ba/30/a?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n4&v=3") format("opentype");
  font-display: auto;
  font-style: normal;
  font-weight: 400;
  font-stretch: normal;
}
@font-face {
  font-family: "new-spirit";
  src: url("https://use.typekit.net/af/de4bea/00000000000000007735c4bc/30/l?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n5&v=3") format("woff2"), url("https://use.typekit.net/af/de4bea/00000000000000007735c4bc/30/d?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n5&v=3") format("woff"), url("https://use.typekit.net/af/de4bea/00000000000000007735c4bc/30/a?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n5&v=3") format("opentype");
  font-display: auto;
  font-style: normal;
  font-weight: 500;
  font-stretch: normal;
}
@font-face {
  font-family: "new-spirit";
  src: url("https://use.typekit.net/af/5d8142/00000000000000007735c4c0/30/l?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n7&v=3") format("woff2"), url("https://use.typekit.net/af/5d8142/00000000000000007735c4c0/30/d?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n7&v=3") format("woff"), url("https://use.typekit.net/af/5d8142/00000000000000007735c4c0/30/a?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n7&v=3") format("opentype");
  font-display: auto;
  font-style: normal;
  font-weight: 700;
  font-stretch: normal;
}
@font-face {
  font-family: "new-spirit-condensed";
  src: url("https://use.typekit.net/af/61aee1/00000000000000007735c4bb/30/l?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n4&v=3") format("woff2"), url("https://use.typekit.net/af/61aee1/00000000000000007735c4bb/30/d?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n4&v=3") format("woff"), url("https://use.typekit.net/af/61aee1/00000000000000007735c4bb/30/a?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n4&v=3") format("opentype");
  font-display: auto;
  font-style: normal;
  font-weight: 400;
  font-stretch: normal;
}
@font-face {
  font-family: "new-spirit-condensed";
  src: url("https://use.typekit.net/af/bf43e2/00000000000000007735c4bd/30/l?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n5&v=3") format("woff2"), url("https://use.typekit.net/af/bf43e2/00000000000000007735c4bd/30/d?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n5&v=3") format("woff"), url("https://use.typekit.net/af/bf43e2/00000000000000007735c4bd/30/a?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n5&v=3") format("opentype");
  font-display: auto;
  font-style: normal;
  font-weight: 500;
  font-stretch: normal;
}
@font-face {
  font-family: "new-spirit-condensed";
  src: url("https://use.typekit.net/af/aeb63d/00000000000000007735c4bf/30/l?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n6&v=3") format("woff2"), url("https://use.typekit.net/af/aeb63d/00000000000000007735c4bf/30/d?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n6&v=3") format("woff"), url("https://use.typekit.net/af/aeb63d/00000000000000007735c4bf/30/a?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n6&v=3") format("opentype");
  font-display: auto;
  font-style: normal;
  font-weight: 600;
  font-stretch: normal;
}
@font-face {
  font-family: "roca";
  src: url("https://use.typekit.net/af/eb9e59/00000000000000007750b2f3/30/l?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n8&v=3") format("woff2"), url("https://use.typekit.net/af/eb9e59/00000000000000007750b2f3/30/d?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n8&v=3") format("woff"), url("https://use.typekit.net/af/eb9e59/00000000000000007750b2f3/30/a?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n8&v=3") format("opentype");
  font-display: auto;
  font-style: normal;
  font-weight: 800;
  font-stretch: normal;
}
@font-face {
  font-family: "roca";
  src: url("https://use.typekit.net/af/fb6fcc/00000000000000007750b2f4/30/l?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n7&v=3") format("woff2"), url("https://use.typekit.net/af/fb6fcc/00000000000000007750b2f4/30/d?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n7&v=3") format("woff"), url("https://use.typekit.net/af/fb6fcc/00000000000000007750b2f4/30/a?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n7&v=3") format("opentype");
  font-display: auto;
  font-style: normal;
  font-weight: 700;
  font-stretch: normal;
}
@font-face {
  font-family: "roca";
  src: url("https://use.typekit.net/af/cb4325/00000000000000007750b2f7/30/l?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n3&v=3") format("woff2"), url("https://use.typekit.net/af/cb4325/00000000000000007750b2f7/30/d?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n3&v=3") format("woff"), url("https://use.typekit.net/af/cb4325/00000000000000007750b2f7/30/a?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n3&v=3") format("opentype");
  font-display: auto;
  font-style: normal;
  font-weight: 300;
  font-stretch: normal;
}
@font-face {
  font-family: "roca";
  src: url("https://use.typekit.net/af/7339d8/00000000000000007750b2f9/30/l?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n4&v=3") format("woff2"), url("https://use.typekit.net/af/7339d8/00000000000000007750b2f9/30/d?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n4&v=3") format("woff"), url("https://use.typekit.net/af/7339d8/00000000000000007750b2f9/30/a?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n4&v=3") format("opentype");
  font-display: auto;
  font-style: normal;
  font-weight: 400;
  font-stretch: normal;
}
@font-face {
  font-family: "roca";
  src: url("https://use.typekit.net/af/7cb092/00000000000000007750b2fc/30/l?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n1&v=3") format("woff2"), url("https://use.typekit.net/af/7cb092/00000000000000007750b2fc/30/d?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n1&v=3") format("woff"), url("https://use.typekit.net/af/7cb092/00000000000000007750b2fc/30/a?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n1&v=3") format("opentype");
  font-display: auto;
  font-style: normal;
  font-weight: 100;
  font-stretch: normal;
}
.tk-new-spirit {
  font-family: "new-spirit", serif;
}

.tk-new-spirit-condensed {
  font-family: "new-spirit-condensed", serif;
}

.tk-roca {
  font-family: "roca", sans-serif;
}

strong {
  font-weight: 400;
}

body {
  font-family: "new-spirit", serif;
  font-weight: 100;
  font-style: normal;
  line-height: 1.4;
  text-rendering: geometricPrecision;
}

h1,
h2,
h3,
h4 {
  margin-top: 1.2em;
  margin-bottom: 0.1em;
  font-weight: 500;
  font-family: Roca;
}

#header {
  color: var(--text-color);
  background-color: var(--bg-color);
  transition: background-color, box-shadow var(--time);
  box-shadow: 0 0.1em 0.4em -0.08em var(--shadow-color-dark);
}

#header-inner {
  height: var(--header-height);
  max-width: min(100% - var(--margin) * 2, 30em + var(--magic));
}

#header nav .menu-item > a {
  color: var(--text-color);
  transition: border var(--timing-swift) var(--time);
  border-top: 0px solid;
}

#header nav .menu-item > a:hover {
  color: var(--accent-color);
}

#header svg {
  fill: unset;
}

#header nav#menu > div {
  background-color: var(--bg-color);
  z-index: 10;
}

#header svg {
  fill: var(--text-color);
  z-index: 15;
  width: 1.2em;
}

#header a {
  color: var(--link-color);
}

#branding h4 {
  color: var(--text-color);
  font-size: 2em;
  text-transform: uppercase;
  font-weight: 200;
  padding-left: 0.2em;
}

#branding svg {
  width: auto;
  height: 2.5em;
}

#branding svg#logotype {
  margin-left: 0.5em;
  height: 2.2em;
}

main.home {
  margin-top: -1em;
}

/* Home page menu */
.home #header,
.home #header-inner,
.home #header nav#menu > div {
  background-color: unset;
  box-shadow: unset;
  transition: transform, background-color, box-shadow var(--time);
}

.home #header svg {
  fill: var(--bg-color);
}

.home main {
  margin-top: -1em;
}

@media (prefers-color-scheme: dark) {
  .home #header svg {
    fill: var(--bg-color);
  }
  .home #header a {
    color: var(--bg-color) !important;
  }
  .home #header nav li.menu-item-featured:hover a {
    color: var(--text-color) !important;
  }
}
/* Menu Hover FX */
li.menu-item {
  position: relative;
}
li.menu-item::before, li.menu-item::after {
  content: "";
  position: absolute;
  width: 10px;
  height: 10px;
  border: 2px solid var(--border-color);
  transition: all 0.3s ease;
  opacity: 0;
}
li.menu-item::before {
  top: 5px;
  border-right: none;
  border-bottom: none;
  transform: translate(-10px, -10px);
}
li.menu-item::after {
  right: 0;
  bottom: 5px;
  border-left: none;
  border-top: none;
  transform: translate(10px, 10px);
}
li.menu-item:hover::before, li.menu-item:hover::after {
  opacity: 0.6;
  transform: translate(0, 0);
}

#header {
  background: linear-gradient(175deg, var(--color-cream-200) 0%, var(--color-cream-400) 100%);
  border-bottom: 1px solid var(--border-color-light);
  box-shadow: inset 0 -3px 0 -2px var(--border-color-divider), 0 1px 4px -1px var(--shadow-color);
}

#header nav#menu > div {
  background: linear-gradient(175deg, var(--color-cream-200) 0%, var(--color-cream-400) 100%);
}

#branding a {
  border-right: 1px solid var(--border-color-divider);
  padding-right: 1em;
  margin-right: 0.5em;
}

#header li.menu-item::before, #header li.menu-item::after {
  width: 14%;
  height: 6px;
  border-width: 4px;
}
#header li.menu-item::before {
  border-top-style: double;
}
#header li.menu-item::after {
  border-bottom-style: double;
}
#header li.menu-item::before, #header li.menu-item::after {
  transition: all 0.2s ease-out;
}
#header li.menu-item:hover::before, #header li.menu-item:hover::after {
  opacity: 0.7;
  transform: translate(0, 0);
}

#header nav .menu-item-has-children > a::after {
  content: " ◢";
  font-size: 0.4em;
  opacity: 0.35;
  vertical-align: super;
  margin-left: 0.3em;
}

#header li.current-menu-item > a,
#header li.current-menu-ancestor > a {
  background-image: linear-gradient(90deg, transparent 0%, transparent 15%, var(--border-color) 15%, var(--border-color) 35%, transparent 35%, transparent 65%, var(--border-color) 65%, var(--border-color) 85%, transparent 85%);
  background-size: 100% 2px;
  background-position: bottom;
  background-repeat: no-repeat;
}

.home #header {
  background: transparent;
  border-bottom: none;
  box-shadow: none;
}

.home #header nav#menu > div {
  background: transparent;
}

.home #branding a {
  border-right-color: transparent;
}

@media (max-width: 768px) {
  #header {
    background: var(--color-cream-200);
    border-bottom: 1px solid var(--border-color-light);
    box-shadow: 0 1px 3px -1px var(--shadow-color);
  }
  #branding a {
    border-right: none;
    padding-right: 0;
    margin-right: 0;
  }
  #header li.menu-item::before, #header li.menu-item::after {
    width: 4px;
    height: 4px;
  }
}
@property --grain-opacity {
  syntax: "<number>";
  inherits: false;
  initial-value: 0.45;
}
@keyframes grain-breathe {
  0%, 100% {
    --grain-opacity: 0.4;
  }
  50% {
    --grain-opacity: 0.55;
  }
}
main#content > article:last-child > :last-child,
main#primary > article:last-child > :last-child {
  padding-bottom: var(--footer-canopy-height);
}

#footer {
  --footer-ink: hsl(38, 26%, 84%);
  --footer-ink-dim: hsl(32, 14%, 54%);
  --footer-ink-weak: hsl(28, 10%, 38%);
  --footer-bone: hsl(36, 38%, 88%);
  --footer-ember: hsl(22, 62%, 46%);
  --footer-bark: hsl(22, 30%, 10%);
  --footer-bark-deep:hsl(20, 35%, 6%);
  --footer-rule: hsla(34, 28%, 62%, 0.22);
  --footer-seal: hsl(34, 50%, 62%);
  position: relative;
  overflow: hidden;
  color: var(--footer-ink);
  margin-top: calc(-1 * var(--footer-canopy-height));
  padding-top: 0;
  z-index: 2;
  animation: grain-breathe 14s ease-in-out infinite;
  -webkit-clip-path: polygon(0% 100%, 100% 100%, 100% 12px, 99% 33.6px, 97.5% 14.4px, 96% 44px, 94.5% 22.4px, 93% 57.6px, 91.5% 38.4px, 90% 24px, 88% 12px, 87% 30.4px, 85.5% 49.6px, 84% 65.6px, 82.5% 44px, 81% 28px, 79% 17.6px, 77.5% 32px, 76% 22.4px, 74% 38.4px, 72% 52px, 70.5% 33.6px, 69% 56px, 67% 30.4px, 65% 14.4px, 63.5% 41.6px, 62% 62.4px, 60% 70.4px, 58.5% 57.6px, 57% 68px, 55% 48px, 53% 28px, 51.5% 44px, 50% 20px, 48% 36px, 46.5% 16px, 45% 46.4px, 43% 24px, 41% 54.4px, 39.5% 36px, 38% 60px, 36% 40px, 34.5% 25.6px, 33% 44px, 31% 22.4px, 29% 12px, 27.5% 33.6px, 26% 48px, 24% 62.4px, 22.5% 41.6px, 21% 25.6px, 19% 38.4px, 17% 17.6px, 15.5% 44px, 14% 57.6px, 12% 30.4px, 10.5% 46.4px, 9% 20px, 7% 36px, 5.5% 14.4px, 4% 40px, 2.5% 22.4px, 1% 33.6px, 0% 16px);
  clip-path: polygon(0% 100%, 100% 100%, 100% 12px, 99% 33.6px, 97.5% 14.4px, 96% 44px, 94.5% 22.4px, 93% 57.6px, 91.5% 38.4px, 90% 24px, 88% 12px, 87% 30.4px, 85.5% 49.6px, 84% 65.6px, 82.5% 44px, 81% 28px, 79% 17.6px, 77.5% 32px, 76% 22.4px, 74% 38.4px, 72% 52px, 70.5% 33.6px, 69% 56px, 67% 30.4px, 65% 14.4px, 63.5% 41.6px, 62% 62.4px, 60% 70.4px, 58.5% 57.6px, 57% 68px, 55% 48px, 53% 28px, 51.5% 44px, 50% 20px, 48% 36px, 46.5% 16px, 45% 46.4px, 43% 24px, 41% 54.4px, 39.5% 36px, 38% 60px, 36% 40px, 34.5% 25.6px, 33% 44px, 31% 22.4px, 29% 12px, 27.5% 33.6px, 26% 48px, 24% 62.4px, 22.5% 41.6px, 21% 25.6px, 19% 38.4px, 17% 17.6px, 15.5% 44px, 14% 57.6px, 12% 30.4px, 10.5% 46.4px, 9% 20px, 7% 36px, 5.5% 14.4px, 4% 40px, 2.5% 22.4px, 1% 33.6px, 0% 16px);
}
#footer .mvn-mark, #footer .mvn-word {
  fill: hsl(16, 35%, 10%);
  filter: drop-shadow(2px 3px 1px hsl(353, 43%, 44%));
}
#footer {
  background: linear-gradient(180deg, var(--footer-bark) 0%, var(--footer-bark-deep) 100%);
}
#footer::after {
  content: "";
  position: absolute;
  inset: 0;
  opacity: var(--grain-opacity);
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E");
  background-size: 200px 200px;
  mix-blend-mode: overlay;
  pointer-events: none;
  z-index: 1;
}
#footer h2, #footer h3, #footer h4 {
  font-family: Roca, sans-serif;
  font-weight: 800;
  color: var(--footer-bone);
  margin: 0 0 1em;
  font-size: 0.78em;
  letter-spacing: 0.22em;
  text-transform: uppercase;
}
#footer a {
  color: var(--footer-ink);
  text-decoration: none;
  transition: color 0.3s ease, letter-spacing 0.4s ease;
  position: relative;
}
#footer ul {
  list-style: none;
  padding: 0;
  margin: 0;
}
#footer li {
  font-family: "new-spirit", serif;
  font-weight: 300;
  font-size: 0.95em;
}

.footer-sigil {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1.5em;
  padding: 7em var(--margin, 1.5rem) 0.5em;
  opacity: 0;
  transform: translateY(20px);
}
.footer-revealed .footer-sigil {
  opacity: 1;
  transform: none;
}

.sigil-stamp {
  position: relative;
  width: clamp(10rem, 22vw, 14rem);
  aspect-ratio: 1/1;
  filter: drop-shadow(0 1px 0 hsla(0, 0%, 0%, 0.35));
}

.sigil-ring {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  animation: sigil-spin 240s linear infinite;
}
.sigil-ring circle {
  fill: none;
  stroke: var(--footer-seal);
}
.sigil-ring .sigil-ring-outer {
  stroke-width: 1.5;
  opacity: 0.6;
}
.sigil-ring .sigil-ring-mid {
  stroke-width: 0.5;
  opacity: 0.5;
  stroke-dasharray: 2 4;
}
.sigil-ring .sigil-ring-inner {
  stroke-width: 1;
  opacity: 0.4;
}
.sigil-ring .sigil-legend {
  font-family: Roca, sans-serif;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.32em;
  fill: var(--footer-seal);
  text-transform: uppercase;
}

@keyframes sigil-spin {
  to {
    transform: rotate(360deg);
  }
}
.sigil-center {
  position: absolute;
  inset: 22%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.1em;
  text-align: center;
}

.sigil-moon {
  font-size: clamp(1.6rem, 3.4vw, 2.3rem);
  line-height: 1;
  filter: grayscale(1) sepia(0.8) hue-rotate(-15deg) brightness(1.05) contrast(1.1);
  user-select: none;
}

.sigil-batch {
  font-family: Roca, sans-serif;
  font-weight: 800;
  font-size: 0.62em;
  letter-spacing: 0.24em;
  color: var(--footer-seal);
  text-transform: uppercase;
  margin-top: 0.5em;
  white-space: nowrap;
}

.sigil-week {
  font-family: Roca, sans-serif;
  font-weight: 300;
  font-size: 0.48em;
  letter-spacing: 0.32em;
  color: var(--footer-ink-dim);
  text-transform: uppercase;
  white-space: nowrap;
}

.sigil-incantation {
  position: relative;
  margin: 0.75em 0 0;
  padding: 0;
  max-width: 28em;
  text-align: center;
  font-family: Roca, sans-serif;
  font-weight: 800;
  font-size: clamp(1.05rem, 2.4vw, 1.75rem);
  line-height: 1.25;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--footer-bone);
}
.sigil-incantation .sigil-words {
  display: inline;
  background-image: linear-gradient(to right, transparent 0%, var(--footer-ember) 40%, var(--footer-ember) 60%, transparent 100%);
  background-repeat: no-repeat;
  background-size: 100% 1px;
  background-position: 0 100%;
  padding-bottom: 0.15em;
}
.sigil-incantation .sigil-quote {
  display: inline-block;
  font-family: "new-spirit", serif;
  font-weight: 300;
  font-style: italic;
  color: var(--footer-ember);
  font-size: 1.4em;
  line-height: 0;
  margin: 0 0.25em;
  transform: translateY(0.08em);
  letter-spacing: 0;
}

.footer-rule {
  position: relative;
  z-index: 2;
  width: calc(100% - 2 * var(--margin, 1.5rem));
  max-width: min(95vw, 64em);
  margin: 2em auto 1em;
  height: 0;
  border: none;
  border-top: 2px solid var(--footer-ink);
  opacity: 0.85;
}
.footer-rule::after {
  content: "";
  display: block;
  height: 0;
  border-top: 1px solid var(--footer-rule);
  margin-top: 4px;
}
.footer-rule--top {
  margin-top: 3em;
}
.footer-rule--bottom {
  margin-bottom: 0;
}

.footer-columns {
  position: relative;
  z-index: 2;
  display: grid;
  gap: 2.5em 4em;
  padding: 2em var(--margin, 1.5rem);
  max-width: min(95vw, 64em);
  margin: 0 auto;
  grid-template-columns: 1fr;
}
@media (min-width: 540px) {
  .footer-columns {
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 14em), 1fr));
  }
}
.footer-columns {
  opacity: 0;
  transform: translateY(30px);
  transition: none;
}
.footer-revealed .footer-columns {
  opacity: 1;
  transform: none;
}

.footer-col,
#footer .widget {
  position: relative;
  text-align: center;
  padding: 0;
  background: none;
  border: none;
  border-radius: 0;
  backdrop-filter: none;
}
@media (min-width: 540px) {
  .footer-col,
  #footer .widget {
    text-align: left;
  }
}
.footer-col::before, .footer-col::after,
#footer .widget::before,
#footer .widget::after {
  content: none;
}

#footer .menu {
  display: flex;
  flex-direction: column;
  gap: 0;
}
#footer .menu li {
  margin: 0;
  border-bottom: 1px solid var(--footer-rule);
  overflow: hidden;
}
#footer .menu li:last-child {
  border-bottom: none;
}
#footer .menu a {
  display: flex;
  align-items: baseline;
  padding: 0.75em 0;
  gap: 0.8em;
  font-family: Roca, sans-serif;
  font-weight: 700;
  font-size: 0.78em;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--footer-ink);
  transition: color 0.3s ease, letter-spacing 0.5s cubic-bezier(0.22, 1, 0.36, 1);
}
#footer .menu a::before {
  content: "·";
  display: block;
  width: 0.8em;
  min-width: 0.8em;
  color: var(--footer-ember);
  font-weight: 900;
  font-size: 1.4em;
  line-height: 0.6;
  transition: color 0.3s ease, transform 0.4s cubic-bezier(0.22, 1, 0.36, 1);
}
#footer .menu a:hover {
  color: var(--footer-bone);
  letter-spacing: 0.26em;
}
#footer .menu a:hover::before {
  color: var(--footer-bone);
  transform: translateX(0.15em) scale(1.3);
}
#footer .menu a::after {
  display: none;
}
#footer .menu li {
  opacity: 0;
  transform: translateX(-16px);
}
.footer-revealed #footer .menu li {
  opacity: 1;
  transform: none;
}

.footer-wordmark {
  position: relative;
  z-index: 2;
  display: block;
  margin: 0.5em 0 0;
  padding: 0;
  text-align: center;
  white-space: nowrap;
  overflow: hidden;
  user-select: none;
  pointer-events: none;
  max-width: unset;
}
.footer-wordmark svg {
  color: transparent;
  background: linear-gradient(180deg, hsl(32, 22%, 20%) 0%, hsl(24, 28%, 12%) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  text-shadow: 0 1px 0 hsla(38, 30%, 50%, 0.08), 0 -1px 0 hsla(0, 0%, 0%, 0.4);
  border-top: 1px solid var(--footer-rule);
  padding-top: 0.12em;
}

#copyright {
  position: relative;
  z-index: 2;
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  justify-content: center;
  gap: 0 0.7em;
  padding: 1.5em var(--margin, 1.5rem) 2.5em;
  font-family: Roca, sans-serif;
  font-weight: 300;
  font-size: 0.72em;
  text-transform: uppercase;
  letter-spacing: 0.24em;
  color: var(--footer-ink-weak);
  opacity: 0;
  transform: translateY(10px);
}
.footer-revealed #copyright {
  opacity: 1;
  transform: none;
}
#copyright .copyright-sep {
  color: var(--footer-ember);
  opacity: 0.7;
}
#copyright .copyright-mantra {
  font-family: "new-spirit", serif;
  font-weight: 300;
  font-style: italic;
  text-transform: none;
  letter-spacing: 0.04em;
  color: var(--footer-ink-dim);
}
#copyright::before, #copyright::after {
  content: none;
}

@media (max-width: 539px) {
  .footer-sigil {
    padding-top: 6em;
  }
  .footer-columns {
    gap: 1.8em;
    padding-inline: 2em;
  }
  .footer-wordmark span {
    letter-spacing: -0.04em;
  }
  #copyright {
    flex-direction: column;
    gap: 0.4em;
    letter-spacing: 0.18em;
  }
  #copyright .copyright-sep {
    display: none;
  }
}
@media (prefers-reduced-motion: reduce) {
  #footer {
    animation: none;
  }
  .sigil-ring {
    animation: none;
  }
  .footer-sigil,
  .footer-columns,
  #copyright,
  #footer .menu li {
    opacity: 1;
    transform: none;
  }
}
/* blocks */
.wc-block-components-review-list-item__image {
  align-items: unset !important;
}

.wp-block-columns.alignfull {
  max-width: unset;
  margin: 0;
}

.wp-block-media-text.is-image-fill > .wp-block-media-text__media {
  background-size: cover;
  height: 100%;
  min-height: 50vh;
}

/* 
.wp-block-columns,
.wp-block-embed,
.wp-block-group {
	margin-bottom: 4em;
} */
/* merge fix */
.alignfull:not(.wp-block-columns, p, h1) img {
  height: 100%;
}

.wp-block-cover {
  aspect-ratio: unset;
}

.alignfull .wp-block-cover__inner-container > * {
  margin-left: 1.2rem;
  margin-right: 1.2rem;
  max-width: var(--max-width);
}

.soppkolonner .wp-block-column > *:not(figure) {
  padding: 0 2rem;
  font-size: 0.8em;
}

/*!
* Theme Name: Myrvann
* Template: ousia
*/
.has-cream-color {
  color: var(--color-editor-cream);
}

.has-cream-background-color {
  background-color: var(--color-editor-cream);
}

.has-coffee-color {
  color: var(--color-editor-coffee);
}

.has-coffee-background-color {
  background-color: var(--color-editor-coffee);
}

.has-sage-color {
  color: var(--color-editor-sage);
}

.has-sage-background-color {
  background-color: var(--color-editor-sage);
}

.has-coffee-to-sage-gradient-background {
  background: linear-gradient(135deg, var(--color-editor-coffee) 0%, var(--color-editor-sage) 100%);
}

.has-cream-to-sage-gradient-background {
  background: linear-gradient(135deg, var(--color-editor-cream) 0%, var(--color-editor-sage) 100%);
}

.has-coffee-to-cream-gradient-background {
  background: linear-gradient(135deg, var(--color-editor-coffee) 0%, var(--color-editor-cream) 100%);
}

body {
  --margin-top: 10rem;
  --margin-bottom: 10rem;
}

#fjell {
  --margin-top: 10rem;
  --margin-bottom: 12rem;
}

#tregrensa {
  --margin-top: 14rem;
  --margin-bottom: 8rem;
}

.wp-block-media-text__content > :last-child,
.wp-block-cover__inner-container > :last-child {
  margin-bottom: var(--margin-bottom);
}

.wp-block-media-text__content > :first-child,
.wp-block-cover__inner-container > :first-child {
  margin-top: var(--margin-top);
}

.soppkolonner {
  gap: 0;
  padding: 0;
}

.soppkolonner figure.wp-block-image.alignfull {
  height: 15em;
}

.soppkolonner h2 {
  margin-left: 1rem;
}

.soppkolonner p {
  margin-left: 1rem;
}

/* forest theme */
#himmel .wp-block-cover__inner-container {
  mix-blend-mode: overlay;
  fill: white;
  transform: translate(calc(0.15 * var(--drift)), calc(11 * var(--drift)));
  z-index: 1;
}

#himmel + div {
  mask-image: url(/wp-content/themes/myrvann/img/fjellmaske.svg);
  mask-size: cover;
  mask-repeat: no-repeat;
  margin-top: -7em; /* Adjust to make sections overlap slightly */
  margin-bottom: -6em;
  z-index: 1;
  position: relative;
}

#himmel:before {
  content: "";
  position: absolute;
  background-color: black;
  z-index: 1;
  width: 119%;
  height: 5em;
  bottom: 10em;
  right: 0em;
  mask-image: url(/wp-content/themes/myrvann/img/fjellmaske.svg);
  mask-size: 100% auto;
  mask-repeat: no-repeat;
  margin-top: -7em;
  margin-bottom: -6em;
  opacity: 0.2;
}

#himmel:before, #himmel:after {
  content: "";
  position: absolute;
  background-color: black;
  z-index: 1;
  mask-image: url(/wp-content/themes/myrvann/img/fjellmaske.svg);
  mask-size: 100% auto;
  mask-repeat: no-repeat;
  opacity: 0.2;
  background-blend-mode: multiply;
  mix-blend-mode: overlay;
}

#himmel:after {
  z-index: 0;
  width: 198%;
  height: 11em;
  bottom: 11em;
  margin-top: -7em;
  margin-bottom: -10em;
  transform: translate(calc(0.25 * var(--drift)), calc(1 * var(--drift)));
}

#himmel:before {
  z-index: 1;
  width: 119%;
  height: 10em;
  bottom: 9em;
  margin-top: -9em;
  margin-bottom: -8em;
  transform: translate(calc(0.4 * var(--drift)), calc(1.4 * var(--drift)));
}

@media (max-width: 768px) {
  #himmel:after {
    width: 156%;
    height: 21%;
    bottom: 0;
    margin-bottom: 0%;
    transform: translate(calc(0.15 * var(--drift)), calc(1.4 * var(--drift)));
  }
  #himmel:before {
    width: 200%;
    height: 15%;
    bottom: 0em;
    margin-bottom: 0;
    transform: translate(calc(0.25 * var(--drift)), calc(1 * var(--drift)));
  }
  #himmel + .wp-block-media-text {
    mask-size: 130%;
    margin-top: -3em;
  }
}
#tregrensa {
  mask-image: url(https://staging.myrvann.no/wp-content/uploads/2024/10/tremaske.png);
  mask-size: cover;
  mask-repeat: no-repeat;
  margin-top: -10em; /* Adjust to make sections overlap slightly */
  z-index: 1;
  position: relative;
}

#ohm {
  display: flex;
  justify-content: center;
}
#ohm svg {
  width: 40%;
  height: auto;
  min-width: 15em;
}

/* forest theme end */
ul.wc-block-review-list.wc-block-components-review-list {
  padding: 0;
}

.alignwide .wc-block-components-review-list-item__item {
  padding: 1.5em;
  box-shadow: 0em 0em 1em 0px var(--shadow-color-subtle);
}

.wc-block-components-review-list-item__meta {
  justify-content: space-between;
}

li.wc-block-review-list-item__item.wc-block-components-review-list-item__item {
  max-width: 40%;
}

.hide {
  display: none;
}

@media (min-width: 768px) {
  .sticky-cart.variations_form {
    font-size: 1em;
    height: 4.5rem;
  }
  .alignfull .wp-block-cover__inner-container > * {
    margin-left: auto;
    margin-right: auto;
  }
  ul.wc-block-review-list.wc-block-components-review-list {
    display: flex;
    flex-direction: row;
    gap: 1em;
  }
  .products > .product a.woocommerce-LoopProduct-link {
    display: block;
  }
  /* .woocommerce-product-gallery__wrapper div a img {
      height: 100%;
      width: 100%;
      object-fit: cover;
      object-position: 28%;
      min-height: 50vmax;
  } */
}
/* ingredient list */
.ingredienser {
  background: var(--bg-color-alt);
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 8px 32px var(--shadow-color-medium);
  margin: 3rem 0;
  border: 1px solid var(--glow-gold-light);
  position: relative;
}
.ingredienser::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--bg-color-selected), var(--decorative-gold), var(--bg-color-selected));
  background-size: 200% 100%;
  animation: gradient 8s ease infinite;
}
.ingredienser .wp-block-media-text__content {
  padding: 3.5rem 3rem 3rem;
  position: relative;
  background: radial-gradient(circle at 90% 10%, var(--glow-gold-faint) 0%, transparent 25%), radial-gradient(circle at 10% 90%, var(--glow-gold-faint) 0%, transparent 25%);
}
.ingredienser .wp-block-media-text__content h2 {
  color: var(--text-color-dark);
  font-size: 2.5rem;
  margin: 0 0 2.5rem;
  position: relative;
  display: flex;
  align-items: center;
  font-weight: 700;
  letter-spacing: -0.5px;
  text-transform: uppercase;
  font-family: "Playfair Display", serif;
}
.ingredienser .wp-block-media-text__content h2::before, .ingredienser .wp-block-media-text__content h2::after {
  content: "";
  flex: 1;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--bg-color-selected), var(--decorative-gold), var(--bg-color-selected), transparent);
  margin: 0 15px;
}
.ingredienser .wp-block-media-text__content h2::before {
  margin-left: 0;
}
.ingredienser .wp-block-media-text__content h2::after {
  margin-right: 0;
}
.ingredienser .wp-block-media-text__content p {
  color: var(--text-color-muted);
  margin-bottom: 2rem;
  line-height: 1.7;
  font-size: 1.1rem;
  max-width: 90%;
}
.ingredienser .wp-block-media-text__content #ingredienser {
  margin: 2rem 0 0;
  gap: 3rem;
}
.ingredienser .wp-block-media-text__content #ingredienser .wp-block-column {
  margin: 0;
  position: relative;
}
.ingredienser .wp-block-media-text__content #ingredienser .wp-block-column::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: -1.5rem;
  width: 1px;
  background: linear-gradient(to bottom, transparent, var(--shadow-color), transparent);
}
.ingredienser .wp-block-media-text__content #ingredienser .wp-block-column:first-child::before {
  display: none;
}
.ingredienser .wp-block-media-text__content #ingredienser .wp-block-column ul {
  list-style: none;
  padding: 0;
  margin: 0;
  counter-reset: ingredient;
}
.ingredienser .wp-block-media-text__content #ingredienser .wp-block-column ul li {
  position: relative;
  padding: 0.9rem 0 0.9rem 2.2rem;
  color: var(--text-color-dark);
  font-size: 1.15rem;
  font-weight: 500;
  margin-bottom: 0.5rem;
}
.ingredienser .wp-block-media-text__content #ingredienser .wp-block-column ul li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%) rotate(45deg);
  width: 1.2rem;
  height: 1.2rem;
  background: var(--bg-color-selected);
  border: 2px solid var(--decorative-gold);
  box-shadow: 0 2px 4px var(--shadow-color-dark);
  transition: all 0.3s ease;
}
.ingredienser .wp-block-media-text__content #ingredienser .wp-block-column ul li::after {
  content: "";
  position: absolute;
  left: 0.4rem;
  top: 50%;
  transform: translateY(-50%);
  width: 0.4rem;
  height: 0.8rem;
  border: solid var(--text-color-dark);
  border-width: 0 2px 2px 0;
  transform: translateY(-60%) rotate(45deg);
  opacity: 0;
  transition: all 0.3s ease;
}
.ingredienser .wp-block-media-text__content #ingredienser .wp-block-column ul li:nth-child(odd)::before {
  background: var(--color-cream-500);
}
.ingredienser .wp-block-media-text__content #ingredienser .wp-block-column ul li:not(:last-child) {
  border-bottom: 1px solid var(--glow-gold-medium);
}
.ingredienser::after {
  content: "";
  position: absolute;
  bottom: 2rem;
  right: 2rem;
  width: 150px;
  height: 150px;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23E6D2AA'%3E%3Cpath d='M12 2L15.09 8.26 22 9.27 17 14.14 18.18 21.02 12 17.77 5.82 21.02 7 14.14 2 9.27 8.91 8.26 12 2z'/%3E%3C/svg%3E") no-repeat center/contain;
  opacity: 0.1;
  z-index: 0;
  animation: float 6s ease-in-out infinite;
}
@keyframes float {
  0%, 100% {
    transform: translateY(0) rotate(0deg);
  }
  50% {
    transform: translateY(-10px) rotate(2deg);
  }
}
@media (max-width: 768px) {
  .ingredienser .wp-block-media-text__content {
    padding: 2.5rem 1.5rem 2rem;
  }
  .ingredienser .wp-block-media-text__content::before {
    height: 3px;
  }
  .ingredienser .wp-block-media-text__content h2 {
    font-size: 1.8rem;
    margin: 0.5rem 0 1.5rem;
  }
  .ingredienser .wp-block-media-text__content h2::after {
    bottom: -10px;
    height: 3px;
  }
  .ingredienser .wp-block-media-text__content p {
    font-size: 1rem;
    max-width: 100%;
  }
  .ingredienser .wp-block-media-text__content #ingredienser {
    flex-direction: column;
    gap: 1.5rem;
    margin-top: 1.5rem;
  }
  .ingredienser .wp-block-media-text__content #ingredienser .wp-block-column {
    flex-basis: 100% !important;
    padding-left: 0;
  }
  .ingredienser .wp-block-media-text__content #ingredienser .wp-block-column::before {
    display: none;
  }
  .ingredienser .wp-block-media-text__content #ingredienser .wp-block-column ul li {
    padding: 0.8rem 0 0.8rem 2.2rem;
    font-size: 1.05rem;
  }
  .ingredienser .wp-block-media-text__content #ingredienser .wp-block-column ul li::before {
    width: 1rem;
    height: 1rem;
    left: 0.3rem;
  }
  .ingredienser .wp-block-media-text__content #ingredienser .wp-block-column ul li::after {
    left: 0.6rem;
    width: 0.3rem;
    height: 0.6rem;
  }
}
@keyframes gradient {
  0% {
    background-position: 0% 50%;
  }
  50% {
    background-position: 100% 50%;
  }
  100% {
    background-position: 0% 50%;
  }
}

@media (max-width: 768px) {
  .summary.entry-summary {
    max-width: max(360px, 80%);
    margin: -5em auto 3em auto;
  }
}
@media (min-width: 1280px) and (max-width: 2879px) {
  main .product .summary {
    width: min(30em, 100% - 4em - var(--magic));
    margin: 2em;
    min-width: unset;
  }
}
.single-product .product_meta {
  display: none;
  visibility: hidden;
}

.variations th.label {
  display: flex;
  align-items: center;
}

/* 
.quantity .qty {
    max-width: 2em;
    }

button.single_add_to_cart_button.button.alt.disabled.wc-variation-selection-needed:hover {
	outline-offset: -2.8em;
	outline: 1.4em solid hsl(24deg 100% 50% / 0%);
	animation-fill-mode: forwards;
	animation: myanim 0.2s 1 forwards;
}
@keyframes myanim {
	100% {
		outline-offset: -0.6em;
		outline: 1em solid hsl(24deg 100% 50% / 65%);
	}
} 

.woocommerce .summary {
	padding: 0em 2em;
}

*/
/* Gallery thumbs */
.flex-control-nav {
  gap: 0.5em;
}

.woocommerce-product-gallery > ol > li img {
  max-height: 6em;
}

.woocommerce-product-gallery > ol > li img {
  max-height: 6em;
}

.woocommerce-product-gallery__wrapper div a img {
  height: auto;
}

figure.woocommerce-product-gallery__wrapper {
  margin: 0;
}

.woocommerce-product-gallery__image {
  overflow: hidden;
}

/* 
form.variations_form.cart:not(.sticky-cart),
.woocommerce-product-details__short-description {
max-width: 18em;
}

.cart:not(.sticky-cart) .variations tr {
display: flex;
flex-direction: row;
justify-content: space-between;
width: 18em;
}

.variations_form .woocommerce-variation-add-to-cart .button {
width: 14em;
}



.variations .label {
	padding-right: 0.5em;
}
 */
em.woocommerce-review__verified.verified {
  display: none;
}

strong.woocommerce-review__author {
  text-transform: capitalize;
}

#description h2:first-of-type {
  visibility: unset !important;
  font-size: revert !important;
}

#description > h2:first-of-type {
  visibility: unset;
  font-size: 1em;
  display: none;
}

ol, ul {
  box-sizing: unset;
}

section ul > li {
  margin-block: 1em;
}

section ul > li li {
  margin-block: 0.5em;
}

.wc-block-components-review-list-item__rating > .wc-block-components-review-list-item__rating__stars {
  font-family: star !important;
}

/* temp */
.show-menu {
  overflow: auto;
}

.star-rating {
  margin: 0 0.3em 0.3em 0;
}

#ingredienser .wp-block-column {
  flex-basis: unset !important;
}

@media (max-width: 1070px) {
  .alignwide > .wp-block-column > *:not(figure) {
    padding-left: var(--font-size);
    padding-right: var(--font-size);
  }
}
@media (max-width: 768px) {
  .home #menu-container li {
    background-color: var(--bg-color);
  }
}
#additional_information {
  display: none;
}

/* Product Summary Box Integration */
.summary.entry-summary {
  background: var(--gradient-card);
  padding: 2.5em;
  border: 1px solid var(--border-color-light);
  border-radius: var(--border-radius);
  box-shadow: 0 10px 30px var(--shadow-color);
  position: relative;
  overflow: hidden;
  /* Enhanced corner elements */
}
.summary.entry-summary::before, .summary.entry-summary::after {
  content: "";
  position: absolute;
  width: 40px;
  height: 40px;
  border: 2px solid var(--border-color);
  opacity: 0.3;
  pointer-events: none;
}
.summary.entry-summary::before {
  top: 10px;
  left: 10px;
  border-right: none;
  border-bottom: none;
}
.summary.entry-summary::after {
  bottom: 10px;
  right: 10px;
  border-left: none;
  border-top: none;
}
.summary.entry-summary {
  /* Decorative pattern overlay */
  /*   &::after {
    content: "";
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    background: 
      linear-gradient(45deg, rgba(107, 66, 38, 0.05) 25%, transparent 25%) 0 0/20px 20px,
      linear-gradient(-45deg, rgba(107, 66, 38, 0.05) 25%, transparent 25%) 0 0/20px 20px;
    opacity: 0.3;
    pointer-events: none;
  } */
}
@media (max-width: 768px) {
  .summary.entry-summary {
    padding: 1.5em;
  }
}

/* Product title styling */
.product_title.entry-title {
  color: var(--color-brown-800);
  font-weight: 600;
  margin-bottom: 1.2rem;
  position: relative;
  padding-bottom: 1rem;
  letter-spacing: 0.5px;
}
.product_title.entry-title::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100px;
  height: 2px;
  background: var(--gradient-decorative);
}
@media (max-width: 768px) {
  .product_title.entry-title {
    font-size: 1.8em;
  }
}

/* Price Display Enhancement */
.price {
  color: var(--border-color);
  font-size: 1.5em;
  margin: 1.5em 0;
  font-weight: 500;
}

@media (min-width: 1024px) {
  /* Short description styling */
  .woocommerce-product-details__short-description {
    color: var(--text-color);
    font-size: 1.15em;
    line-height: 1.7;
    margin-bottom: 2em;
    position: relative;
    padding-left: 1em;
    border-left: 2px solid var(--border-color-inset);
  }
  .woocommerce-product-details__short-description a {
    color: var(--link-color);
    text-decoration: none;
    border-bottom: 1px solid var(--border-color-inset);
    transition: border-color 0.2s ease;
  }
  .woocommerce-product-details__short-description a:hover {
    border-color: var(--link-color);
  }
}
/* Product rating styling */
.woocommerce-product-rating {
  display: none;
  margin-bottom: 1em;
}

.woocommerce-review-link {
  color: var(--link-color);
  font-size: 0.9em;
  text-decoration: none;
  opacity: 0.8;
  transition: opacity 0.2s ease;
}
.woocommerce-review-link:hover {
  opacity: 1;
}

/* Enhanced Focus States */
button:focus,
input:focus,
select:focus {
  outline: none;
  box-shadow: 0 0 6px -1px var(--border-color-inset) inset;
}

/* Product Meta Information */
.product_meta {
  margin-top: 2em;
  padding-top: 1.5em;
  border-top: 1px solid var(--border-color-inset);
  font-size: 0.9em;
  color: var(--link-color);
}
.product_meta > span {
  display: block;
  margin-bottom: 0.5em;
}
.product_meta a {
  color: var(--border-color);
  text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: border-color 0.2s ease;
}
.product_meta a:hover {
  border-color: var(--border-color);
}

/* Animations */
@keyframes borderPulse {
  0% {
    border-color: var(--glow-cream-strong);
  }
  100% {
    border-color: var(--glow-cream-solid);
  }
}
table.variations {
  min-width: -webkit-fit-content;
}
table.variations th.label label {
  color: var(--text-color);
  font-weight: 600;
  margin-bottom: 0.75em;
  display: block;
  position: relative;
  text-transform: capitalize;
}
table.variations th.label label::after {
  content: "";
  position: absolute;
  bottom: -8px;
  left: 0;
  width: 60px;
  height: 2px;
  background: var(--decorative-underline);
}
table.variations td.value label {
  position: relative;
  cursor: pointer;
  display: inline-block;
  margin: 0.5em;
  transition: transform 0.3s ease;
  height: -webkit-fit-content;
  font-family: "mendl-sans-variable", sans-serif;
  font-weight: 400;
}
table.variations td.value label div {
  padding: 0.75em 1.25em;
  border: 2px solid var(--border-color);
  border-radius: 0;
  background-color: var(--bg-color-light);
  position: relative;
  transition: all 0.3s ease;
  font-size: 0.9em;
  color: var(--text-color);
  height: -webkit-fit-content;
  min-height: 1.5em;
  display: flex;
  align-items: center;
  text-align: center;
  justify-content: center;
}
table.variations td.value input[type=radio] {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
}
table.variations td.value input[type=radio]:checked + div {
  background-color: var(--bg-color-selected);
  color: var(--text-color-dark);
  position: relative;
  /*                 font-weight: 400; */
}
table.variations .attribute-pa_opprinnelse td.value {
  display: grid;
  grid-template-columns: 50% 50%;
  gap: 0em;
  align-items: center;
}
table.variations .attribute-pa_opprinnelse td.value label div::before, table.variations .attribute-pa_opprinnelse td.value label div::after,
table.variations .attribute-pa_opprinnelse td.value label div span::before,
table.variations .attribute-pa_opprinnelse td.value label div span::after {
  content: "";
  position: absolute;
  width: 10px;
  height: 10px;
  border: 2px solid var(--border-color);
  transition: all 0.3s ease;
}
table.variations .attribute-pa_opprinnelse td.value label div::before {
  top: -5px;
  left: -5px;
  border-right: none;
  border-bottom: none;
}
table.variations .attribute-pa_opprinnelse td.value label div::after {
  bottom: -5px;
  right: -5px;
  border-left: none;
  border-top: none;
}
table.variations .attribute-pa_opprinnelse td.value label div span::before {
  top: -5px;
  right: -5px;
  border-left: none;
  border-bottom: none;
}
table.variations .attribute-pa_opprinnelse td.value label div span::after {
  bottom: -5px;
  left: -5px;
  border-right: none;
  border-top: none;
}
table.variations .attribute-pa_opprinnelse td.value label:hover div {
  background-color: var(--bg-color-hover);
}
table.variations .attribute-pa_opprinnelse td.value label:hover div::before {
  transform: translate(-2px, -2px) scale(1.2);
}
table.variations .attribute-pa_opprinnelse td.value label:hover div::after {
  transform: translate(2px, 2px) scale(1.2);
}
table.variations .attribute-pa_opprinnelse td.value label:hover div span::before {
  transform: translate(2px, -2px) scale(1.2);
}
table.variations .attribute-pa_opprinnelse td.value label:hover div span::after {
  transform: translate(-2px, 2px) scale(1.2);
}
table.variations .attribute-pa_opprinnelse td.value input[type=radio]:checked + div::before,
table.variations .attribute-pa_opprinnelse td.value input[type=radio]:checked + div span::before,
table.variations .attribute-pa_opprinnelse td.value input[type=radio]:checked + div span::after {
  border-color: var(--text-color);
  width: 12px;
  height: 12px;
  border-width: 3px;
}
table.variations .attribute-pa_opprinnelse td.value input[type=radio]:checked + div::before {
  top: -6px;
  left: -6px;
}
table.variations .attribute-pa_opprinnelse td.value input[type=radio]:checked + div span::before {
  top: -6px;
  right: -6px;
}
table.variations .attribute-pa_opprinnelse td.value input[type=radio]:checked + div span::after {
  bottom: -6px;
  left: -6px;
}
table.variations .pill.variety, table.variations .pill.altitude {
  border: 1px solid var(--border-color-divider);
  background: var(--bg-color);
  box-shadow: -3px -3px 2px var(--color-cream-400) inset;
  border-radius: 3px;
  padding-inline: 0.4em;
  padding-block: 0.1em;
  margin-inline: 0.1em;
}
table.variations .wc-ras-origin-modal .pill img, table.variations .wc-ras-origin-modal .pill svg, table.variations .flag-img {
  height: 1.5em;
  border-radius: 5px;
  border: 1px solid white;
  filter: sepia(0.5);
}
table.variations .origin-pills {
  display: flex;
  align-items: center;
  gap: 0.4em;
  margin-block-end: 0.5em;
}
table.variations .attribute-pa_mengde td.value {
  padding: 0;
  margin: 0.5em 0 1em 0;
  background-color: var(--bg-color-light);
  display: flex;
  flex-wrap: nowrap;
  border: 1px inset var(--border-color-inset);
  background-color: var(--bg-color-light);
  border-radius: var(--border-radius);
  width: 100%;
  box-sizing: border-box;
}
table.variations .attribute-pa_mengde td.value::before, table.variations .attribute-pa_mengde td.value::after {
  content: none;
}
table.variations .attribute-pa_mengde td.value label {
  position: relative;
  margin: 0;
  z-index: 2;
  flex: 1 1 0;
  width: 50%;
  max-width: 50%;
  min-width: 0;
}
table.variations .attribute-pa_mengde td.value label:hover div {
  background-color: var(--bg-color-hover);
}
table.variations .attribute-pa_mengde td.value label {
  /*             &:not(:last-child) div {
                  border-right-color: var(--border-color-divider);
              } */
}
table.variations .attribute-pa_mengde td.value label div {
  width: 100%;
  border: 2px solid transparent;
  box-sizing: border-box;
  border-radius: 0;
  background: transparent;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 400;
  font-size: 0.9em;
  color: var(--text-color);
  position: relative;
  cursor: pointer;
  padding: 0.75em 0;
  opacity: 0.7;
}
table.variations .attribute-pa_mengde td.value input[type=radio]:checked + div {
  background-color: var(--bg-color-selected);
  font-weight: 500;
  opacity: 1;
}
table.variations .attribute-pa_mengde td.value input[type=radio]:checked + div::before, table.variations .attribute-pa_mengde td.value input[type=radio]:checked + div::after {
  content: "";
  position: absolute;
  width: 8px;
  height: 8px;
  border-color: var(--border-color);
  border-style: solid;
}
table.variations .attribute-pa_mengde td.value input[type=radio]:checked + div::before {
  top: 2px;
  left: 2px;
  border-width: 2px 0 0 2px;
}
table.variations .attribute-pa_mengde td.value input[type=radio]:checked + div::after {
  bottom: 2px;
  right: 2px;
  border-width: 0 2px 2px 0;
}

tr.wc-ras-inline-description-row {
  display: block;
  padding-top: 0.8em;
}

.woocommerce-variation-description {
  color: var(--text-color);
  background-color: var(--bg-color-light);
  position: relative;
  padding: 1em 0em 0em 1em;
  border: 1px inset var(--border-color-inset);
  margin-bottom: 1em;
  border-radius: var(--border-radius);
}
.woocommerce-variation-description p {
  margin-bottom: 1em;
  padding-right: 1em;
}

tr.variation-description-row td {
  padding: 1em 0;
  display: block;
}
tr.variation-description-row td .woocommerce-variation-description {
  margin-bottom: 0;
}

p.term-page-link-wrapper {
  float: right;
  position: relative;
  border-inline: 1px inset var(--border-color-inset);
  background-color: var(--bg-color-light);
  padding-inline: 1em;
  margin-right: 1em;
  border-block-end: 1px inset var(--border-color-inset);
  padding-block-end: 0.3em;
  font-size: 0.8em;
  border-radius: 0 0 var(--border-radius) var(--border-radius);
}
p.term-page-link-wrapper::before {
  content: "";
  width: 100%;
  height: 25px;
  position: absolute;
  left: 0;
  right: 0;
  top: -10px;
  display: block;
  background-color: var(--bg-color-light);
  z-index: -1;
}

.single_variation_wrap .single_add_to_cart_button {
  position: relative;
  overflow: hidden;
}
.single_variation_wrap .single_add_to_cart_button::after {
  content: "";
  position: absolute;
  top: -50%;
  left: -50%;
  width: 200%;
  height: 200%;
  background: radial-gradient(circle, var(--glow-white) 0%, transparent 60%);
  transform: scale(0);
  opacity: 0;
  transition: transform 0.5s ease, opacity 0.5s ease;
}
.single_variation_wrap .single_add_to_cart_button:hover::after {
  transform: scale(1);
  opacity: 1;
}

/* Subscription Options Styling - Rustic Cacao Theme */
.wcsatt-options-wrapper {
  position: relative;
  border-top: 1px solid var(--border-color-inset);
  width: 50%;
}
.wcsatt-options-wrapper .wcsatt-options-prompt-text {
  background-color: var(--bg-color-light);
  padding: 1em 1.25em;
  border: 2px solid var(--border-color);
  border-radius: var(--border-radius);
  margin-bottom: 1.5em;
  position: relative;
}
.wcsatt-options-wrapper .wcsatt-options-prompt-text .wcsatt-options-prompt-text-label {
  color: var(--text-color);
  font-weight: 600;
  font-size: 1.1em;
  display: block;
  position: relative;
  padding-bottom: 0;
  margin-bottom: 0;
  letter-spacing: 0.3px;
}
.wcsatt-options-wrapper .wcsatt-options-prompt-text .wcsatt-options-prompt-text-label::after {
  display: none;
}
.wcsatt-options-wrapper .wcsatt-options-product-prompt {
  background: var(--gradient-card);
  padding: 1.5em;
  border: 1px solid var(--border-color-light);
  border-radius: var(--border-radius);
  position: relative;
}
.wcsatt-options-wrapper .wcsatt-options-product-prompt::before, .wcsatt-options-wrapper .wcsatt-options-product-prompt::after {
  content: "";
  position: absolute;
  width: 35px;
  height: 35px;
  border: 2px solid var(--border-color);
  opacity: 0.4;
  pointer-events: none;
}
.wcsatt-options-wrapper .wcsatt-options-product-prompt::before {
  top: 8px;
  left: 8px;
  border-right: none;
  border-bottom: none;
}
.wcsatt-options-wrapper .wcsatt-options-product-prompt::after {
  bottom: 8px;
  right: 8px;
  border-left: none;
  border-top: none;
}
.wcsatt-options-wrapper .wcsatt-options-product-wrapper {
  position: relative;
}
.wcsatt-options-wrapper {
  /* Hide the dropdown, we'll use our custom styling instead */
}
.wcsatt-options-wrapper .wcsatt-options-product-dropdown {
  display: none;
}
.wcsatt-options-wrapper {
  /* Display the custom option list - Horizontal toggle style matching Mengde */
}
.wcsatt-options-wrapper .wcsatt-options-product {
  list-style: none;
  margin: 2px 0;
  padding: 0;
  display: flex !important;
  background-color: var(--bg-color-light);
  /* border: 2px solid var(--border-color); */
  border-radius: 0;
  /* overflow: hidden; */
  position: relative;
  flex-direction: column;
  min-width: 100%;
}
.wcsatt-options-wrapper .wcsatt-options-product::before, .wcsatt-options-wrapper .wcsatt-options-product::after {
  content: none;
}
.wcsatt-options-wrapper .subscription-option {
  flex: 1;
  border-bottom: none;
  border-right: 1px solid var(--border-color-divider);
  position: relative;
  transition: all 0.3s ease;
}
.wcsatt-options-wrapper .subscription-option:last-child {
  border-right: none;
}
.wcsatt-options-wrapper .subscription-option label {
  display: block;
  margin: 0;
  padding: 0;
  cursor: pointer;
  position: relative;
  height: 100%;
  transition: all 0.3s ease;
}
.wcsatt-options-wrapper .subscription-option label:hover .subscription-option-details {
  background-color: var(--bg-color-hover);
}
.wcsatt-options-wrapper .subscription-option input[type=radio] {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
}
.wcsatt-options-wrapper .subscription-option input[type=radio]:checked + .subscription-option-details {
  background-color: var(--bg-color-selected);
  color: var(--text-color-dark);
  position: relative;
  border: none;
  opacity: 1;
  font-weight: 500;
}
.wcsatt-options-wrapper .subscription-option input[type=radio]:checked + .subscription-option-details .subscription-details {
  color: var(--text-color-dark);
  font-weight: 600;
}
.wcsatt-options-wrapper .subscription-option input[type=radio]:checked + .subscription-option-details {
  /* Decorative corner elements - matching .attribute-pa_mengde style */
}
.wcsatt-options-wrapper .subscription-option input[type=radio]:checked + .subscription-option-details::before, .wcsatt-options-wrapper .subscription-option input[type=radio]:checked + .subscription-option-details::after {
  display: block;
  content: "";
  position: absolute;
  border-color: var(--text-color-dark);
  border-style: solid;
  width: 8px;
  height: 8px;
  opacity: 1;
}
.wcsatt-options-wrapper .subscription-option input[type=radio]:checked + .subscription-option-details::before {
  top: -2px;
  left: -2px;
  border-width: 2px 0 0 2px;
}
.wcsatt-options-wrapper .subscription-option input[type=radio]:checked + .subscription-option-details::after {
  bottom: -2px;
  right: -2px;
  border-width: 0 2px 2px 0;
}
.wcsatt-options-wrapper .subscription-option .subscription-option-details {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  padding: 1em 0.75em;
  box-sizing: border-box;
  background: transparent;
  border: none;
  border-radius: 0;
  transition: all 0.3s ease;
  position: relative;
  opacity: 0.7;
  text-align: center;
}
.wcsatt-options-wrapper .subscription-option .subscription-option-details .subscription-details {
  color: var(--text-color);
  font-size: 0.9em;
  font-weight: 400;
  transition: all 0.3s ease;
  display: inline-block;
}
.wcsatt-options-wrapper .subscription-option .subscription-option-details {
  /* Hide corner decorations in default state */
}
.wcsatt-options-wrapper .subscription-option .subscription-option-details::before, .wcsatt-options-wrapper .subscription-option .subscription-option-details::after {
  display: none;
}

/* Integrated Quantity Selector */
.quantity {
  height: -webkit-fit-content;
  position: relative;
  display: inline-flex;
  align-items: center;
  margin-right: 1em;
  border: 1px solid var(--border-color-light);
  background: var(--bg-color-light);
  overflow: hidden;
  border-radius: var(--border-radius);
  /* Hide default number input controls */
}
.quantity input.qty {
  width: 100%;
  height: 3em;
  border: none;
  background: transparent;
  text-align: center;
  font-weight: 600;
  color: var(--text-color);
  -moz-appearance: textfield;
  appearance: textfield;
  padding: 0;
}
.quantity input.qty::-webkit-outer-spin-button, .quantity input.qty::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}
.quantity {
  /* Decorative elements for quantity */
}
.quantity::before, .quantity::after {
  content: "";
  position: absolute;
  width: 8px;
  height: 8px;
  border: 2px solid var(--border-color);
  pointer-events: none;
}
.quantity::before {
  top: -4px;
  left: -4px;
  border-right: none;
  border-bottom: none;
}
.quantity::after {
  bottom: -4px;
  right: -4px;
  border-left: none;
  border-top: none;
}

/* Add to Cart Button - Magnificent Design */
.single_add_to_cart_button {
  background: var(--gradient-button);
  color: var(--bg-color-light);
  padding: 1em 1.5em;
  font-weight: 600;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  position: relative;
  cursor: pointer;
  overflow: hidden;
  width: calc(100% - 5em);
  font-family: "mendl-sans-variable", sans-serif;
  text-align: center;
  transition: all 0.2s ease;
  min-height: 4em;
  height: 4em;
  border-style: hidden;
  /* Subtle border */
}
.single_add_to_cart_button::before {
  content: "";
  position: absolute;
  top: 5px;
  left: 5px;
  right: 5px;
  bottom: 5px;
  border: 1px solid var(--glow-cream-strong);
  pointer-events: none;
  transition: all 0.2s ease;
}
.single_add_to_cart_button {
  /* Background accent */
}
.single_add_to_cart_button::after {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at top left, var(--glow-cream-subtle) 0%, transparent 40%), radial-gradient(circle at bottom right, var(--glow-cream-subtle) 0%, transparent 40%);
  opacity: 0.6;
  z-index: -1;
  transition: all 0.2s ease;
}
.single_add_to_cart_button {
  /* Hover effect */
}
.single_add_to_cart_button:hover {
  border-style: none;
  background: var(--gradient-button-hover);
  box-shadow: 0 4px 8px var(--shadow-color-heavy);
}
.single_add_to_cart_button:hover::before {
  top: 4px;
  left: 4px;
  right: 4px;
  bottom: 4px;
  border: 2px solid var(--glow-cream-solid);
  border-inline-style: double;
  border-inline-width: 6px;
  animation: borderPulse 1.5s infinite alternate;
}
.single_add_to_cart_button:hover::after {
  opacity: 1;
  background: radial-gradient(circle at top left, var(--glow-cream-medium) 0%, transparent 50%), radial-gradient(circle at bottom right, var(--glow-cream-medium) 0%, transparent 50%), repeating-linear-gradient(90deg, transparent 0px, transparent 4px, var(--overlay-stripe) 4px, var(--overlay-stripe) 8px);
}
.single_add_to_cart_button {
  /* Active state */
}
.single_add_to_cart_button:active {
  background: var(--gradient-button-active);
  box-shadow: 0 2px 4px var(--shadow-color-heavy);
  transform: translateY(1px);
}
.single_add_to_cart_button:active::before {
  top: 6px;
  left: 6px;
  right: 6px;
  bottom: 6px;
}

/* Button and quantity layout */
.woocommerce-variation-add-to-cart {
  display: flex;
  align-items: center;
  margin-top: 1em;
  flex-wrap: nowrap;
}
@media (max-width: 768px) {
  .woocommerce-variation-add-to-cart .quantity {
    width: 3em;
  }
  .woocommerce-variation-add-to-cart .single_add_to_cart_button {
    width: 100%;
  }
}

/* Reviews Section */
section#reviews {
  margin-top: 3em;
  padding-top: 2em;
  position: relative;
}
section#reviews div#reviews {
  max-width: calc(100% - 2em);
}
section#reviews .commentlist {
  column-width: 18em;
  column-gap: 1em;
  /*   display: grid;
  grid-template-columns: repeat(auto-fill, minmax(15em, 1fr));
  grid-auto-rows: minmax(100px, auto);
  gap: 20px;
  grid-auto-flow: dense;
  align-items: center; */
}
section#reviews .review {
  break-inside: avoid;
}
section#reviews::before {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 50px;
  height: 1px;
  background: var(--gradient-divider);
}
section#reviews h2 {
  color: var(--color-brown-800);
  text-align: center;
  font-size: 1.8em;
  margin-bottom: 2em;
  font-weight: 600;
}
section#reviews {
  /*   ol.commentlist {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(15em, 1fr));
    grid-auto-rows: minmax(100px, auto);
    gap: 20px;
    grid-auto-flow: dense;
    align-items: center;
  } */
}
section#reviews .review {
  margin-bottom: 2em;
  position: relative;
  break-inside: avoid;
}
section#reviews .review .avatar {
  margin-bottom: unset;
}
section#reviews .children li {
  list-style-type: disclosure-closed;
  list-style-image: url(https://staging.myrvann.no/wp-content/themes/myrvann/img/ohm.svg);
}
section#reviews .comment_container {
  background-color: var(--bg-color-light);
  border: 1px solid var(--border-color-light);
  border-radius: var(--border-radius);
  position: relative;
}
@media (max-width: 768px) {
  section#reviews .comment_container {
    flex-direction: column;
  }
}
section#reviews .avatar {
  border-radius: 50%;
  border: 1px solid var(--border-color-light);
  margin-right: 1.2em;
}
@media (max-width: 768px) {
  section#reviews .avatar {
    margin-right: 0;
    margin-bottom: 1em;
  }
}
section#reviews .comment-text {
  flex: 1;
  padding: 1.5em;
}
section#reviews .meta {
  font-size: 0.9em;
  color: var(--link-color);
  position: relative;
  display: grid;
  grid-template-columns: auto 1fr;
  column-gap: 1em;
  row-gap: 0.3em;
  align-items: start;
  margin-bottom: unset;
}
section#reviews .meta > img {
  grid-row: 1/span 4;
}
section#reviews .meta > strong, section#reviews .meta > em, section#reviews .meta > span, section#reviews .meta > time {
  grid-column: 2;
}
section#reviews .woocommerce-review__author {
  color: var(--color-brown-800);
  font-weight: 500;
  font-size: 1em;
}
section#reviews .woocommerce-review__verified {
  font-style: italic;
  color: var(--link-color);
  opacity: 0.8;
  font-size: 0.85em;
}
section#reviews .woocommerce-review__published-date {
  color: var(--link-color);
  font-size: 0.85em;
}
section#reviews .description {
  color: var(--text-color);
  font-size: 1em;
  line-height: 1.6;
  margin-bottom: 1.2em;
  border-bottom: 1px solid var(--border-color-inset);
}
section#reviews .star-rating {
  overflow: hidden;
  position: relative;
  height: 1.2em;
  line-height: 1;
  font-size: 1em;
  width: 5.4em;
  margin-bottom: 0.5em;
  color: var(--border-color);
}
section#reviews .star-rating::before {
  content: "★★★★★";
  float: left;
  top: 0;
  left: 0;
  position: absolute;
  opacity: 0.3;
}
section#reviews .star-rating span {
  overflow: hidden;
  float: left;
  top: 0;
  left: 0;
  position: absolute;
  padding-top: 1.5em;
}
section#reviews .star-rating span::before {
  content: "★★★★★";
  top: 0;
  position: absolute;
  left: 0;
}

/* Review Form */
#review_form_wrapper {
  margin-top: 2.5em;
  padding: 1.5em;
  background-color: var(--bg-color-light);
  border: 1px solid var(--border-color-light);
  border-radius: var(--border-radius);
  max-width: var(--max-width);
  margin: auto;
}

.comment-reply-title {
  font-size: 1.6em;
  font-weight: 400;
  margin-bottom: 0.5em;
  display: block;
}

#review_form .comment-form-rating label,
#review_form .comment-form-comment label {
  color: var(--color-brown-800);
  font-weight: 600;
  margin-bottom: 0.5em;
}
#review_form textarea,
#review_form input {
  width: 100%;
  padding: 0.8em;
  border: 1px solid var(--border-color-light);
  border-radius: var(--border-radius);
  background-color: var(--color-cream-100);
  color: var(--text-color);
  transition: border-color 0.2s ease;
}
#review_form textarea:focus,
#review_form input:focus {
  border-color: var(--link-color);
  outline: none;
}
#review_form .form-submit input[type=submit] {
  background: var(--gradient-button-submit);
  color: var(--bg-color-light);
  border: none;
  padding: 0.8em 1.5em;
  font-weight: 600;
  font-size: 1em;
  border-radius: var(--border-radius);
  cursor: pointer;
  transition: all 0.2s ease;
}
#review_form .form-submit input[type=submit]:hover {
  background: var(--gradient-button-submit-hover);
}

/* Styling for specific blocks marked with id or class */
@media (max-width: 768px) {
  #sopp {
    width: 100%;
    margin-right: 0;
    margin-left: 0;
    max-width: 100%;
  }
  #soppscroll .wp-block-image {
    opacity: 0.15;
    position: absolute;
    bottom: -10em;
    min-width: 160vw;
    left: -15em;
  }
}
#sopp {
  min-height: 100vh;
}

#sopper {
  flex-wrap: nowrap !important;
  margin-left: 0.2rem;
  margin-right: 0.2rem;
  max-width: unset;
  gap: 0;
  position: sticky;
  top: var(--header-height);
  top: 0;
  background-color: var(--bg-color);
  margin-bottom: 0;
}
#sopper img {
  transition: outline 0.3s ease;
}
#sopper img.active {
  outline: 1em solid var(--color-cream-700);
  border-radius: 14em;
}
#sopper img {
  /*         &:hover {
      outline: 1.2em solid hsl(25 61% 8   8% / 1);
      border-radius: 14em;
  } */
}
#sopper h3 {
  font-size: 1em;
  margin-top: 0.5em;
}
#sopper figure {
  margin-bottom: 0em;
}

div#soppscroll {
  flex-wrap: nowrap !important;
  overflow-x: scroll;
  overflow-y: hidden;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  scroll-snap-points-x: repeat(100%);
  margin: 0;
  padding: 0;
  max-width: unset;
  user-select: none;
  -webkit-user-select: none;
  height: 80vh;
}
div#soppscroll p:first-of-type {
  backdrop-filter: brightness(1.12) blur(2px) saturate(0.7);
  -webkit-backdrop-filter: brightness(1.12) blur(2px) saturate(0.7);
  padding: 1em;
  border: 1px solid var(--color-cream-700);
  box-shadow: 1px 1px 7px -2px var(--shadow-color-medium);
}
div#soppscroll .wp-block-column {
  flex: 0 0 75%;
  flex-basis: 75% !important;
  scroll-snap-align: center;
  scroll-snap-stop: always;
  background-color: var(--bg-color-light);
  background: var(--gradient-card);
  border-radius: var(--border-radius);
  padding-inline: 3em;
  border: 1px solid var(--border-color-light);
  box-shadow: 0 10px 11px -6px var(--shadow-color-medium);
  position: relative;
  background-blend-mode: multiply;
  overflow: hidden;
  z-index: -1;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
div#soppscroll .wp-block-column::before {
  content: "";
  position: absolute;
  inset: 0;
  background: url("https://staging.myrvann.no/wp-content/uploads/2025/04/3e50d0fb-b2cb-47b3-87d6-c458fa7cb591.png") center/cover repeat;
  mix-blend-mode: luminosity; /* multiply to pop warmer; */
  opacity: 0.3;
  pointer-events: none;
  z-index: -1;
  background-size: auto;
}
div#soppscroll .wp-block-column .wp-block-image {
  opacity: 0.15;
  position: absolute;
  bottom: -10em;
  min-width: 160vw;
  left: -15em;
}
div#soppscroll .wp-block-column img {
  pointer-events: none;
  -webkit-user-select: none;
}
div#soppscroll .wp-block-column a {
  text-decoration: dashed underline overline;
  text-decoration-thickness: 0.8px;
}

/* New Archive Grid */
.woocommerce-products-header h1.woocommerce-products-header__title {
  padding-block: 1em;
}

nav.woocommerce-pagination, form.woocommerce-ordering {
  display: none;
}

.archive #main .products {
  grid-template-columns: repeat(auto-fit, minmax(360px, 1fr));
  gap: 1em;
  /*     max-width: min(100%, 1440px); */
}

.products > .product a.woocommerce-LoopProduct-link {
  color: unset;
  text-decoration: none;
  align-items: left;
}

.products > .product a .attachment-woocommerce_thumbnail {
  object-fit: cover;
  aspect-ratio: 3/4;
}

.products > .product a h2.woocommerce-loop-product__title {
  text-align: initial;
  font-size: 1.4em;
  margin-top: 0.4em;
}

.products > .product a .star-rating, .lesmer {
  display: none;
}

.products > .product a p.category_desc {
  height: 90%;
  font-weight: 200;
  margin-left: 0.5em;
  display: none;
}

/**/
.products > .product a.woocommerce-LoopProduct-link {
  color: unset;
  text-decoration: none;
  align-items: left;
}

.products > .product a.woocommerce-LoopProduct-link:hover .woocommerce-loop-product__title {
  text-decoration: underline;
}

.products > .product a.woocommerce-LoopProduct-link:hover:after {
  content: ">";
  position: absolute;
  right: 0.051em;
  bottom: 0.25em;
  font-size: 6em;
  color: var(--bg-color);
  font-weight: 400;
}

.products > .product a .attachment-woocommerce_thumbnail {
  object-fit: cover;
  height: 100%;
  aspect-ratio: 3/4;
}

.products > .product a h2.woocommerce-loop-product__title {
  text-align: initial;
  font-size: 1.4em;
  margin-top: 0.4em;
  height: 4em;
  background: white;
  position: absolute;
  bottom: 2em;
  right: 1.5em;
  height: unset;
  clip-path: polygon(4% 15%, 13% 9%, 50% 11%, 78% 8%, 98% 24%, 93% 89%, 54% 87%, 45% 94%, 17% 89%, 9% 93%, 0% 58%);
  padding-inline: 1em;
  padding-block: 0.5em;
}

.products > .product a {
  padding-bottom: 0;
}

span.woocommerce-input-wrapper {
  grid-column: 2;
}

h3#ship-to-different-address {
  font-size: 1em;
  padding-top: 2em;
}

.order-review {
  font-size: 0.8em;
}

.woocommerce-checkout ul.woocommerce-error {
  list-style: none;
  padding: 1em;
  border: 0.5em dashed var(--accent-color);
  background-color: hsl(33, 50%, 95%);
  box-shadow: 1em 1em 4em 5em hsl(33, 50%, 85%);
  z-index: 9999;
  position: fixed;
}

@media (min-width: 55em) {
  .woocommerce-checkout .woocommerce:after {
    content: "";
    position: absolute;
    inset: 0 0 0 50vw;
    background-color: hsl(33, 50%, 95%);
    z-index: -9;
    height: 250%;
  }
  .woocommerce-checkout .woocommerce-form-login-toggle {
    background-color: hsl(33, 50%, 95%);
  }
  .woocommerce-checkout h1 {
    background-color: var(--bg-color);
    width: 4em;
  }
  .woocommerce-checkout form.woocommerce-form.woocommerce-form-login.login {
    padding: 1em 1.5rem;
    max-width: 24em;
    background-color: var(--bg-color);
    margin-bottom: 2em;
  }
}
.woocommerce-checkout h3 {
  padding-bottom: 1em;
}

.woocommerce-checkout .order-review table.shop_table {
  width: 100%;
  padding: 0;
  border: unset;
}

.woocommerce-checkout fieldset {
  border: unset;
  padding: 0;
}

main > .woocommerce {
  max-width: var(--max-width);
  margin-left: 1.5rem;
  margin-right: 1.5rem;
  margin-inline-start: auto;
  margin-inline-end: auto;
}

html body img.inline.vipps-logo {
  max-width: unset;
}

/* Frictionless thank you start */
.woocommerce-order {
  padding-top: 2em;
}

@media (min-width: 692px) {
  section.woocommerce-customer-address {
    display: flex;
    justify-content: center;
  }
  section > address {
    margin: 0;
    width: calc(50% + 4em);
  }
  section > address:last-of-type {
    width: calc(50% - 4em);
  }
}
/* Frictionless thank you end */
p.form-row.form-row-wide.wfacp-form-control-wrapper.wfacp-col-full.wfacp-anim-wrap {
  display: block !important;
  width: 100%;
}

#customer_details .woocommerce-billing-fields__field-wrapper > .form-row:last-of-type {
  display: block;
}

/* 
 * My Account Page Styling
 * Mobile-first responsive styling for WooCommerce My Account page
 */
.woocommerce-account .woocommerce {
  display: block;
}
@media (min-width: 768px) {
  .woocommerce-account .woocommerce {
    display: grid;
    grid-template-columns: 1fr 2fr;
    gap: 2rem;
  }
}
@media (min-width: 1024px) {
  .woocommerce-account .woocommerce {
    grid-template-columns: 1fr 3fr;
  }
}
.woocommerce-account .header {
  margin-bottom: 1rem;
}
.woocommerce-account .header .entry-title {
  font-size: 1.5rem;
  font-weight: 600;
  color: var(--text-color);
}
@media (min-width: 768px) {
  .woocommerce-account .header .entry-title {
    font-size: 2rem;
    margin-bottom: 2rem;
  }
}

.woocommerce-MyAccount-navigation {
  background-color: var(--bg-color);
  border-radius: var(--border-radius);
  margin-bottom: 1.5rem;
}
.woocommerce-MyAccount-navigation ul {
  list-style: none;
  padding: 0;
  margin: 0;
}
.woocommerce-MyAccount-navigation li {
  margin: 0;
  border-bottom: 1px solid var(--border-color-light);
}
.woocommerce-MyAccount-navigation li:last-child {
  border-bottom: none;
}
.woocommerce-MyAccount-navigation li.is-active {
  background-color: white;
}
.woocommerce-MyAccount-navigation li.is-active a {
  color: var(--accent-color);
  font-weight: 600;
}
@media (min-width: 768px) {
  .woocommerce-MyAccount-navigation li.is-active a {
    border-left: 3px solid var(--accent-color);
  }
}
.woocommerce-MyAccount-navigation a {
  display: block;
  padding: 0.75rem 1rem;
  color: var(--link-color);
  text-decoration: none;
  transition: all 0.3s ease;
  border-left: none;
}
@media (min-width: 768px) {
  .woocommerce-MyAccount-navigation a {
    padding: 1rem 1.5rem;
    border-left: 3px solid transparent;
  }
}
.woocommerce-MyAccount-navigation a:hover {
  background-color: white;
  color: var(--accent-color);
}
@media (min-width: 768px) {
  .woocommerce-MyAccount-navigation {
    box-shadow: 0 2px 5px var(--shadow-color-dark);
    margin-bottom: 0;
  }
}

.woocommerce-MyAccount-content {
  background-color: white;
  padding: 1rem;
  border-radius: var(--border-radius);
}
@media (min-width: 768px) {
  .woocommerce-MyAccount-content {
    padding: 2rem;
    box-shadow: 0 2px 5px var(--shadow-color-dark);
  }
}
.woocommerce-MyAccount-content p {
  margin-bottom: 1rem;
  line-height: 1.6;
}
@media (min-width: 768px) {
  .woocommerce-MyAccount-content p {
    margin-bottom: 1.5rem;
  }
}
.woocommerce-MyAccount-content a:not(.button) {
  color: var(--accent-color);
  text-decoration: none;
  transition: all 0.3s ease;
}
.woocommerce-MyAccount-content a:not(.button):hover {
  text-decoration: underline;
}
.woocommerce-MyAccount-content strong {
  font-weight: 600;
  color: var(--text-color);
}
.woocommerce-MyAccount-content table.woocommerce-orders-table,
.woocommerce-MyAccount-content table.woocommerce-table--order-details,
.woocommerce-MyAccount-content table.woocommerce-table--order-downloads {
  width: 100%;
  border-collapse: collapse;
  margin-bottom: 1rem;
  display: block;
  overflow-x: auto;
  white-space: nowrap;
}
@media (min-width: 768px) {
  .woocommerce-MyAccount-content table.woocommerce-orders-table,
  .woocommerce-MyAccount-content table.woocommerce-table--order-details,
  .woocommerce-MyAccount-content table.woocommerce-table--order-downloads {
    display: table;
    overflow-x: visible;
    white-space: normal;
    margin-bottom: 2rem;
  }
}
.woocommerce-MyAccount-content table.woocommerce-orders-table th, .woocommerce-MyAccount-content table.woocommerce-orders-table td,
.woocommerce-MyAccount-content table.woocommerce-table--order-details th,
.woocommerce-MyAccount-content table.woocommerce-table--order-details td,
.woocommerce-MyAccount-content table.woocommerce-table--order-downloads th,
.woocommerce-MyAccount-content table.woocommerce-table--order-downloads td {
  padding: 0.5rem;
  text-align: left;
  border-bottom: 1px solid var(--border-color-light);
}
@media (min-width: 768px) {
  .woocommerce-MyAccount-content table.woocommerce-orders-table th, .woocommerce-MyAccount-content table.woocommerce-orders-table td,
  .woocommerce-MyAccount-content table.woocommerce-table--order-details th,
  .woocommerce-MyAccount-content table.woocommerce-table--order-details td,
  .woocommerce-MyAccount-content table.woocommerce-table--order-downloads th,
  .woocommerce-MyAccount-content table.woocommerce-table--order-downloads td {
    padding: 1rem;
  }
}
.woocommerce-MyAccount-content table.woocommerce-orders-table th,
.woocommerce-MyAccount-content table.woocommerce-table--order-details th,
.woocommerce-MyAccount-content table.woocommerce-table--order-downloads th {
  font-weight: 600;
  background-color: var(--bg-color);
  font-size: 0.9rem;
}
@media (min-width: 768px) {
  .woocommerce-MyAccount-content table.woocommerce-orders-table th,
  .woocommerce-MyAccount-content table.woocommerce-table--order-details th,
  .woocommerce-MyAccount-content table.woocommerce-table--order-downloads th {
    font-size: 1rem;
  }
}
.woocommerce-MyAccount-content table.woocommerce-orders-table tr:last-child td,
.woocommerce-MyAccount-content table.woocommerce-table--order-details tr:last-child td,
.woocommerce-MyAccount-content table.woocommerce-table--order-downloads tr:last-child td {
  border-bottom: none;
}
.woocommerce-MyAccount-content table.woocommerce-orders-table .button,
.woocommerce-MyAccount-content table.woocommerce-table--order-details .button,
.woocommerce-MyAccount-content table.woocommerce-table--order-downloads .button {
  padding: 0.25rem 0.5rem;
  background-color: var(--bg-color);
  color: var(--link-color);
  border-radius: var(--border-radius);
  text-decoration: none;
  display: inline-block;
  transition: all 0.3s ease;
  border: 1px solid var(--border-color-light);
  font-size: 0.8rem;
}
@media (min-width: 768px) {
  .woocommerce-MyAccount-content table.woocommerce-orders-table .button,
  .woocommerce-MyAccount-content table.woocommerce-table--order-details .button,
  .woocommerce-MyAccount-content table.woocommerce-table--order-downloads .button {
    padding: 0.5rem 1rem;
    font-size: 1rem;
  }
}
.woocommerce-MyAccount-content table.woocommerce-orders-table .button:hover,
.woocommerce-MyAccount-content table.woocommerce-table--order-details .button:hover,
.woocommerce-MyAccount-content table.woocommerce-table--order-downloads .button:hover {
  background-color: var(--bg-hover-neutral);
  text-decoration: none;
}
.woocommerce-MyAccount-content table.woocommerce-orders-table .button.view,
.woocommerce-MyAccount-content table.woocommerce-table--order-details .button.view,
.woocommerce-MyAccount-content table.woocommerce-table--order-downloads .button.view {
  margin-right: 0.25rem;
}
@media (min-width: 768px) {
  .woocommerce-MyAccount-content table.woocommerce-orders-table .button.view,
  .woocommerce-MyAccount-content table.woocommerce-table--order-details .button.view,
  .woocommerce-MyAccount-content table.woocommerce-table--order-downloads .button.view {
    margin-right: 0.5rem;
  }
}
.woocommerce-MyAccount-content form .form-row {
  margin-bottom: 1rem;
}
@media (min-width: 768px) {
  .woocommerce-MyAccount-content form .form-row {
    margin-bottom: 1.5rem;
  }
}
.woocommerce-MyAccount-content form .form-row label {
  display: block;
  margin-bottom: 0.5rem;
  font-weight: 500;
  font-size: 0.9rem;
}
@media (min-width: 768px) {
  .woocommerce-MyAccount-content form .form-row label {
    font-size: 1rem;
  }
}
.woocommerce-MyAccount-content form .form-row input, .woocommerce-MyAccount-content form .form-row textarea, .woocommerce-MyAccount-content form .form-row select {
  width: 100%;
  padding: 0.5rem;
  border: 1px solid var(--border-color-light);
  border-radius: var(--border-radius);
  transition: all 0.3s ease;
  font-size: 1rem;
}
@media (min-width: 768px) {
  .woocommerce-MyAccount-content form .form-row input, .woocommerce-MyAccount-content form .form-row textarea, .woocommerce-MyAccount-content form .form-row select {
    padding: 0.75rem;
  }
}
.woocommerce-MyAccount-content form .form-row input:focus, .woocommerce-MyAccount-content form .form-row textarea:focus, .woocommerce-MyAccount-content form .form-row select:focus {
  outline: none;
  border-color: var(--accent-color);
  box-shadow: 0 0 0 2px var(--shadow-color);
}
.woocommerce-MyAccount-content form button, .woocommerce-MyAccount-content form .button {
  background-color: var(--accent-color);
  color: white;
  border: none;
  padding: 0.75rem 1rem;
  border-radius: var(--border-radius);
  cursor: pointer;
  transition: all 0.3s ease;
  font-size: 1rem;
  width: 100%;
}
@media (min-width: 768px) {
  .woocommerce-MyAccount-content form button, .woocommerce-MyAccount-content form .button {
    width: auto;
    padding: 0.75rem 1.5rem;
  }
}
.woocommerce-MyAccount-content form button:hover, .woocommerce-MyAccount-content form .button:hover {
  background-color: var(--accent-color-hover);
}

/* Side cart */
body #fkcart-floating-toggler {
  bottom: 1em;
  right: 1em;
}

#fkcart-floating-toggler #fkit-floating-count {
  top: -5px;
  left: -5px;
  min-width: 24px;
  height: 24px;
  border-radius: 100%;
  font-weight: 600;
  font-size: 0.9em;
  padding: 2px;
  box-shadow: 0px 0px 0px 4px var(--fkcart-toggle-bg-color);
}

/* Vipps */
.vipps-info.vipps-banner.vipps-checkout {
  padding: 0.5em 1em 0.5em 2.5em;
  font-size: 0.8em;
}

.vipps-banner.vipps-info::before, .woocommerce-error::before, .woocommerce-noreviews::before, p.no-comments::before {
  top: 0.55em;
  left: 1em;
}

.woocommerce-info.vipps-info {
  background-color: #fe5b24;
  padding: 1em;
  border-radius: 1em;
  max-width: max-content;
  margin: 5em auto 1em auto;
}

a.button.vipps-express-checkout {
  border: unset;
}

html body img.inline.vipps-logo {
  max-width: unset;
}

html body img.inline.vipps-logo {
  height: 1em;
  margin: 0 0.2em -0.2em;
}

/* Optin */
.woofunnels-primary {
  /*max-width: 20rem;
     margin: 0 auto;*/
  --max-width: 47rem;
  --font-size: calc(22px + 6 * ((100vw - 320px) / 680));
  font-family: MagicMushroom;
  font-weight: 300;
  background: linear-gradient(345deg, #ffe7ab, #f9e9b4, #f4eabd, #efeac5, #eae8cd, #e6e6d4);
}

.woofunnels-primary h1 {
  padding: 0 1rem;
}

.woofunnels-primary p,
.woofunnels-primary .bwfac_form_sec {
  padding: 0 1rem 2rem;
}

button#wffn_custom_optin_submit {
  width: 100%;
}

.bwfac_forms_outer .bwfac_form_sec,
.bwfac_forms_outer .bwfac_form_sec label,
.bwfac_forms_outer .bwfac_form_sec input,
.bwfac_forms_outer .bwfac_form_sec textarea,
.bwfac_forms_outer .bwfac_form_sec select {
  font-size: 1em !important;
}

.woofunnels-primary .alignfull {
  left: 0;
  right: 0;
}

.woofunnels-container {
  margin-top: 0;
}

.woofunnels-primary {
  padding-top: 2em;
}

.bwfac_form_sec input[type=text],
.bwfac_form_sec input[type=email],
.bwfac_form_sec input[type=tel],
.bwfac_form_sec select,
.bwfac_form_sec textarea {
  width: 100%;
}

.bwfac_form_sec input,
.bwfac_form_sec select,
.bwfac_form_sec textarea {
  position: relative;
  overflow: hidden;
  background-color: var(--color-cream-50);
  border: 1px solid #d3d3d3;
  border-radius: 4px;
  box-sizing: border-box;
  color: #333;
  cursor: default;
  outline: none;
  -webkit-transition: all 0.4s ease;
  transition: all 0.4s ease;
  cursor: text;
}

.bwfac_form_sec input:focus,
.bwfac_form_sec select:focus,
.bwfac_form_sec textarea:focus {
  border-color: #61bdf7 !important;
}

.bwfac_forms_outer[data-field-size=e_large] .bwfac_form_sec input:not(.wfop_submit_btn),
.bwfac_forms_outer[data-field-size=e_large] .bwfac_form_sec select,
.bwfac_forms_outer[data-field-size=e_large] .bwfac_form_sec textarea {
  padding: 0.5em;
}

.bwfac_forms_outer input::placeholder {
  opacity: 0.7;
}

.bwf_pp_overlay {
  display: none;
}

p.form-row.wfacp-col-full {
  width: 40%;
}

@media (min-width: 692px) {
  p.form-row.wfacp-col-full {
    width: 70%;
  }
}
/* Mix and Match Products */
.summary .mnm_form .product-details .price,
.summary .mnm_form .product-details .stock,
.summary .mnm_form .summary > .price,
.summary .mnm_form h4.woocommerce-loop-product__title {
  display: none;
}

.mnm_message.woocommerce-message {
  padding: 1em;
  width: unset;
  max-width: unset;
  margin-bottom: 1em;
  border: 1px solid var(--color-cream-600);
  background-color: var(--bg-color-light);
}

.product-type-mix-and-match #reviews {
  display: none;
}

.product-type-mix-and-match form.cart:not(.variations_form) {
  display: block;
  max-width: var(--max-width);
  height: unset !important;
}

.summary-add-to-cart-form.summary-add-to-cart-form-mnm {
  max-width: var(--max-width);
  margin-inline: auto;
}

.mnm_form.layout_grid .products.has-flex {
  display: grid;
  max-width: var(--max-width);
  margin-left: auto;
  margin-right: auto;
  margin-inline-start: auto;
  margin-inline-end: auto;
  width: 100em;
  justify-content: space-evenly;
  grid-template-columns: repeat(auto-fit, minmax(11em, 1fr));
  padding: 0;
  justify-items: center;
}

.mnm_form.layout_tabular table dl {
  font-size: unset;
}
.mnm_form.layout_tabular table.shop_table td {
  padding-block: 0em;
}

.product-type-mix-and-match del .woocommerce-Price-amount {
  display: inline;
}

.product-type-mix-and-match dt {
  display: none;
}

.product-type-mix-and-match dd {
  margin-inline-start: 0;
  font-weight: 400;
}

.product-type-mix-and-match a {
  padding-bottom: 0em !important;
  align-items: unset !important;
}

@media screen and (min-width: 568px) {
  .mnm-mobile-container .column.col-2 .single_add_to_cart_button,
  .mnm-mobile-container .column.col-2 .wc-mnm-edit-subscription-actions {
    display: inline-block;
    width: auto;
    margin-right: 5em;
  }
}
.woocommerce-mix-and-match-add-to-cart.mnm_button_wrap.add_to_cart_button_wrap {
  display: flex;
  gap: 0.4em;
}

.woocommerce-mix-and-match-add-to-cart .quantity {
  display: none;
}

.mnm_form .quantity {
  border: unset;
}

.mnm_form.has-plus-minus-buttons .qty {
  font-size: 0.8em !important;
}

.mnm_form.layout_grid .products .product {
  max-width: 11em;
}

.mnm_form.layout_grid .products .product .product-details {
  width: 100%;
  margin-bottom: 0;
}

.product-type-mix-and-match .summary .price {
  display: none;
}

.mnm_message.woocommerce-message.woocommerce-error {
  display: flex !important;
  align-items: flex-start;
  max-width: unset;
  padding: unset;
  border: unset;
  text-align: unset;
}

ul.msg.mnm_message_content {
  padding: 0;
}

button.mnm_reset.button.wp-element-button {
  background: url();
  border: unset;
  color: inherit;
  text-transform: none;
  padding: 0 !important;
  margin: 0 !important;
}

/* flex layout */
.mnm_item.child-item {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}

.mnm-child-item-short-description {
  font-size: 0.8em;
  width: 100%;
  padding-inline: 0.5em;
  padding-block-end: 1em;
  background-color: var(--bg-color-light);
}
.mnm-child-item-short-description p {
  margin: 0.6em 1em 0em 0em;
}

.faq-schema-item {
  position: relative;
  padding: 0.9rem 1.2rem;
  background: var(--bg-color-light);
  border: 1px solid var(--border-color-light);
  border-radius: var(--border-radius);
  box-shadow: 0 4px 14px var(--shadow-color);
}
.faq-schema-item::before, .faq-schema-item::after {
  content: "";
  position: absolute;
  width: 11px;
  height: 11px;
  border: 1px solid var(--border-color);
  opacity: 0.45;
  pointer-events: none;
}
.faq-schema-item::before {
  top: 7px;
  left: 7px;
  border-right: 0;
  border-bottom: 0;
}
.faq-schema-item::after {
  right: 7px;
  bottom: 7px;
  border-left: 0;
  border-top: 0;
}
.faq-schema-item input[type=checkbox] {
  display: none;
}
.faq-schema-item .faq-schema-question {
  display: block;
  margin: 0;
  padding: 0.2rem 2rem 0.2rem 0;
  cursor: pointer;
  position: relative;
  color: var(--text-color-dark);
  font-weight: 400;
  line-height: 1.4;
  transition: color 0.2s ease;
}
.faq-schema-item .faq-schema-question strong {
  font-weight: 600;
}
.faq-schema-item .faq-schema-question::after {
  content: "+";
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  font-size: 1.35em;
  line-height: 1;
  color: var(--border-color);
  transition: color 0.2s ease;
}
.faq-schema-item .faq-schema-question:hover {
  color: var(--link-color);
}
.faq-schema-item .faq-schema-question:hover::after {
  color: var(--link-color);
}
.faq-schema-item input[type=checkbox]:checked ~ .faq-schema-question::after {
  content: "−";
}
.faq-schema-item .faq-schema-answer {
  max-height: 0;
  opacity: 0;
  overflow: hidden;
  padding-top: 0;
  margin-top: 0;
  border-top: 0;
  transition: max-height 0.35s ease, opacity 0.2s ease, margin-top 0.2s ease, padding-top 0.2s ease;
}
.faq-schema-item .faq-schema-answer > * {
  margin-top: 0;
  margin-bottom: 0.9rem;
}
.faq-schema-item .faq-schema-answer > *:last-child {
  margin-bottom: 0;
}
.faq-schema-item .faq-schema-answer p,
.faq-schema-item .faq-schema-answer li {
  color: var(--text-color);
  line-height: 1.6;
}
.faq-schema-item .faq-schema-answer ul,
.faq-schema-item .faq-schema-answer ol {
  padding-left: 1.25rem;
}
.faq-schema-item .faq-schema-answer a {
  color: var(--link-color);
  text-decoration: none;
  border-bottom: 1px solid var(--border-color-inset);
}
.faq-schema-item .faq-schema-answer a:hover {
  border-bottom-color: var(--link-color);
}
.faq-schema-item .faq-schema-answer code {
  background: var(--bg-code);
  border: 1px solid var(--border-color-light);
  border-radius: 2px;
  padding: 0.1rem 0.3rem;
  font-size: 0.9em;
}
.faq-schema-item input[type=checkbox]:checked ~ .faq-schema-answer {
  max-height: 2000px;
  opacity: 1;
  margin-top: 0.55rem;
  padding-top: 0.7rem;
  border-top: 1px solid var(--border-faq-medium);
}
.faq-schema-item input[type=checkbox]:focus-visible ~ .faq-schema-question {
  outline: 2px solid var(--border-color);
  outline-offset: 2px;
}

.faq-schema-item + .faq-schema-item {
  margin-top: 0.65rem;
}

.wp-block-group:has(.faq-schema-item) .faq-schema-item:first-of-type,
.entry-content:has(.faq-schema-item) .faq-schema-item:first-of-type {
  margin-top: 1.5rem;
}
.wp-block-group:has(.faq-schema-item) .faq-schema-item:last-of-type,
.entry-content:has(.faq-schema-item) .faq-schema-item:last-of-type {
  margin-bottom: 2.5rem;
}

@media (max-width: 768px) {
  .faq-schema-item {
    padding: 0.8rem 1rem;
  }
  .faq-schema-item .faq-schema-question {
    font-size: 1rem;
  }
}
/**
 * Retail Locations - Myrvann Theme Overrides
 */
/* ==========================================================================
   Map Canvas
   ========================================================================== */
.retail-locations-map::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  box-shadow: inset 0 0 50px var(--shadow-color);
  border-radius: var(--border-radius);
}

.retail-locations-map-canvas {
  filter: hue-rotate(21deg) sepia(0.321) saturate(1.5);
  border: 1px solid var(--border-color-light);
  border-radius: var(--border-radius);
}

/* ==========================================================================
   Locations List Container
   ========================================================================== */
.retail-locations-list {
  background: var(--gradient-card);
  padding: 1.5em;
  border: 1px solid var(--border-color-light);
  border-radius: var(--border-radius);
  box-shadow: 0 10px 30px var(--shadow-color);
  position: relative;
  width: 80%;
}
.retail-locations-list::before, .retail-locations-list::after {
  content: "";
  position: absolute;
  width: 30px;
  height: 30px;
  border: 2px solid var(--border-color);
  opacity: 0.25;
  pointer-events: none;
}
.retail-locations-list::before {
  top: 8px;
  left: 8px;
  border-right: none;
  border-bottom: none;
}
.retail-locations-list::after {
  bottom: 8px;
  right: 8px;
  border-left: none;
  border-top: none;
}
@media (max-width: 768px) {
  .retail-locations-list {
    padding: 1em;
  }
  .retail-locations-list::before, .retail-locations-list::after {
    width: 20px;
    height: 20px;
  }
}

/* ==========================================================================
   Regional Group Headers
   ========================================================================== */
.retail-locations-group {
  margin-bottom: 0.5em;
}
.retail-locations-group:last-child {
  margin-bottom: 0;
}

.retail-locations-group-title {
  font-size: 1.25em;
  font-weight: 600;
  color: var(--text-color-dark);
  padding-bottom: 0.5em;
  margin-bottom: 0;
  border-bottom: 1px solid var(--border-color-light);
  position: relative;
  max-width: none;
}
.retail-locations-group-title::before {
  content: "";
  position: absolute;
  bottom: -1px;
  left: 0;
  width: 60px;
  height: 2px;
  background: var(--gradient-decorative);
}
.retail-locations-group-title[data-lat] {
  cursor: pointer;
  transition: color 0.2s ease;
}
.retail-locations-group-title[data-lat]:hover {
  color: var(--link-color);
  opacity: 1;
}

/* Accordion toggle */
.retail-locations-list[data-collapsible=yes] .retail-locations-group-title {
  cursor: pointer;
  user-select: none;
  display: flex;
  justify-content: space-between;
  align-items: center;
  transition: color 0.2s ease;
}
.retail-locations-list[data-collapsible=yes] .retail-locations-group-title:hover {
  background-color: transparent;
  color: var(--link-color);
  opacity: 1;
}
.retail-locations-list[data-collapsible=yes] .retail-locations-group-title::after {
  content: "+";
  font-weight: 300;
  font-size: 1.4em;
  line-height: 1;
  color: var(--border-color);
  transition: color 0.2s ease;
  flex-shrink: 0;
  margin-left: 0.5em;
}

.retail-locations-group:not(.is-collapsed) > .retail-locations-group-title::after {
  content: "−";
  color: var(--link-color);
}

/* ==========================================================================
   Location Item Cards
   ========================================================================== */
.retail-location-item {
  padding: 0.85em 1em;
  margin: 0;
  position: relative;
  border-bottom: 1px solid var(--border-color-light);
  transition: background-color 0.2s ease, box-shadow 0.2s ease;
  cursor: pointer;
  border-left: 2px solid transparent;
}
.retail-location-item:last-child {
  border-bottom: none;
  padding-bottom: 0;
}
.retail-location-item:first-child {
  padding-top: 1em;
}
.retail-location-item:hover {
  background-color: var(--bg-color-alt);
  border-left-color: var(--border-color);
}

/* ==========================================================================
   Store Title
   ========================================================================== */
.retail-location-title {
  font-size: 1.05em;
  font-weight: 600;
  color: var(--color-brown-800);
  margin: 0 0 0.35em;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5em;
}
.retail-location-title a {
  color: inherit;
  text-decoration: none;
  transition: color 0.2s ease;
}
.retail-location-title a:hover {
  color: var(--link-color);
}

/* ==========================================================================
   Category Tags
   ========================================================================== */
.retail-location-tags {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 0.3em;
}

.retail-location-tag {
  display: inline-block;
  padding: 0.1em 0.45em;
  font-size: 0.6em;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--text-color-muted);
  background: var(--bg-color-alt);
  border: 1px solid var(--border-color-light);
  border-radius: var(--border-radius);
  vertical-align: middle;
}

/* ==========================================================================
   Address & Links
   ========================================================================== */
.retail-location-address {
  display: flex;
  align-items: flex-start;
  gap: 0.4em;
  margin-bottom: 0.4em;
  font-size: 0.9em;
  color: var(--text-color);
}
.retail-location-address .retail-locations-icon {
  color: var(--link-color);
  flex-shrink: 0;
  margin-top: 0.1em;
}
.retail-location-address a {
  color: inherit;
  text-decoration: none;
  transition: color 0.2s ease;
}
.retail-location-address a:hover {
  color: var(--accent-color);
}

.retail-location-links {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75em;
  margin-bottom: 0.5em;
}

.retail-location-link {
  display: inline-flex;
  align-items: center;
  gap: 0.3em;
  color: var(--link-color);
  text-decoration: none;
  font-size: 0.85em;
  border-bottom: 1px solid var(--border-color-inset);
  padding-bottom: 1px;
  transition: border-color 0.2s ease, color 0.2s ease;
}
.retail-location-link .retail-locations-icon {
  width: 0.9em;
  height: 0.9em;
}
.retail-location-link:hover {
  color: var(--accent-color);
  border-color: var(--link-color);
}

/* ==========================================================================
   Opening Hours
   ========================================================================== */
.retail-location-hours {
  display: flex;
  align-items: flex-start;
  gap: 0.5em;
  font-size: 0.85em;
  margin-top: 0.5em;
  padding: 0.75em;
  background: var(--bg-color-alt);
  border-left: 2px solid var(--border-color-inset);
  border-radius: 0 var(--border-radius) var(--border-radius) 0;
}
.retail-location-hours > .retail-locations-icon {
  color: var(--link-color);
  flex-shrink: 0;
  margin-top: 0.15em;
}

.retail-location-hours-list {
  flex: 1;
}

.retail-location-hour {
  display: flex;
  gap: 1em;
  margin-bottom: 0.15em;
  justify-content: space-between;
}
.retail-location-hour .hour-day {
  font-weight: 600;
  color: var(--text-color-dark);
}

/* ==========================================================================
   Description & Contacts
   ========================================================================== */
.retail-location-description {
  margin-bottom: 0.5em;
  font-size: 0.9em;
  color: var(--text-color);
  line-height: 1.5;
}

.retail-location-contacts {
  margin-bottom: 0.5em;
  font-size: 0.85em;
}
.retail-location-contacts .contact-label {
  font-weight: 600;
  color: var(--text-color-dark);
  margin-right: 0.3em;
}

/* ==========================================================================
   Map Popup/Info Window
   ========================================================================== */
.retail-locations-info {
  background: var(--gradient-card);
  padding: 0.85em;
  max-width: 20em;
  border: 1px solid var(--border-color-light);
  border-radius: var(--border-radius);
  position: relative;
}
.retail-locations-info h4 {
  font-size: 1.05em;
  font-weight: 600;
  color: var(--color-brown-800);
  margin: 0 0 0.4em;
  line-height: 1.3;
}
.retail-locations-info .retail-locations-info-map-icon {
  color: var(--link-color);
  text-decoration-color: var(--accent-color);
}

.retail-locations-info-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.25em;
  margin-bottom: 0.4em;
}

.retail-locations-info-tag {
  display: inline-block;
  padding: 0.1em 0.45em;
  font-size: 0.7em;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.3px;
  color: var(--text-color-muted);
  background: var(--bg-color-alt);
  border: 1px solid var(--border-color-light);
  border-radius: var(--border-radius);
}

.retail-locations-info-address {
  margin: 0 0 0.4em;
  font-size: 0.85em;
  color: var(--text-color);
}

.retail-locations-info-hours {
  margin-bottom: 0.5em;
  font-size: 0.8em;
  background: var(--bg-color-alt);
  padding: 0.5em;
  border-left: 2px solid var(--border-color-inset);
}

.retail-locations-info-hour {
  display: flex;
  gap: 0.5em;
  justify-content: space-between;
}
.retail-locations-info-hour .hour-day {
  font-weight: 600;
  color: var(--text-color-dark);
}

.retail-locations-info-actions {
  display: flex;
  align-items: center;
  margin-top: 0.5em;
  gap: 0.5em;
}

.retail-locations-info-link {
  display: inline-block;
  padding: 0.4em 0.85em;
  background: var(--gradient-button);
  color: var(--bg-color-light);
  text-decoration: none;
  font-size: 0.8em;
  font-weight: 500;
  letter-spacing: 0.3px;
  border-radius: var(--border-radius);
  transition: all 0.2s ease;
}
.retail-locations-info-link:hover {
  background: var(--gradient-button-hover);
  box-shadow: 0 2px 6px var(--shadow-color-medium);
  text-decoration: none;
}

.retail-locations-info-link-secondary {
  color: var(--link-color);
  font-size: 0.8em;
  text-decoration: none;
  border-bottom: 1px solid var(--border-color-inset);
  transition: border-color 0.2s ease;
}
.retail-locations-info-link-secondary:hover {
  border-color: var(--link-color);
}

/* ==========================================================================
   SVG Icons
   ========================================================================== */
.retail-locations-icon {
  display: inline-block;
  vertical-align: middle;
  width: 1em;
  height: 1em;
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  color: var(--accent-color);
}

/* ==========================================================================
   Focus Location (Clickable to map)
   ========================================================================== */
.js-focus-location {
  cursor: pointer;
}

/* ==========================================================================
   Grid Layout Adjustments
   ========================================================================== */
.retail-locations-list.layout-grid2 .retail-location-item,
.retail-locations-list.layout-grid3 .retail-location-item,
.retail-locations-list.layout-grid4 .retail-location-item {
  margin: 0;
}

/* Grouped layouts */
.retail-locations-list.grouped-by-area .retail-locations-group,
.retail-locations-list.grouped-by-category .retail-locations-group {
  display: block;
}
.retail-locations-list.grouped-by-area.layout-grid2 .retail-location-item, .retail-locations-list.grouped-by-area.layout-grid3 .retail-location-item,
.retail-locations-list.grouped-by-category.layout-grid2 .retail-location-item,
.retail-locations-list.grouped-by-category.layout-grid3 .retail-location-item {
  display: inline-block;
  vertical-align: top;
  margin-bottom: 1.5em;
}
.retail-locations-list.grouped-by-area.layout-grid2 .retail-location-item,
.retail-locations-list.grouped-by-category.layout-grid2 .retail-location-item {
  width: calc(50% - 0.75em);
}
.retail-locations-list.grouped-by-area.layout-grid3 .retail-location-item,
.retail-locations-list.grouped-by-category.layout-grid3 .retail-location-item {
  width: calc(33.333% - 1em);
}

/* ==========================================================================
   Responsive
   ========================================================================== */
@media (max-width: 768px) {
  .retail-locations-group-title {
    font-size: 1.15em;
  }
  .retail-location-item {
    padding: 0.75em;
  }
  .retail-location-title {
    font-size: 1em;
  }
  .retail-locations-list.grouped-by-area.layout-grid2 .retail-location-item, .retail-locations-list.grouped-by-area.layout-grid3 .retail-location-item,
  .retail-locations-list.grouped-by-category.layout-grid2 .retail-location-item,
  .retail-locations-list.grouped-by-category.layout-grid3 .retail-location-item {
    display: block;
    width: 100%;
  }
}
body.page-id-7320 .entry-header {
  display: none;
}
body.page-id-7320 .entry-content > .alignfull {
  margin-top: 0;
  margin-bottom: 0;
}
body.page-id-7320 .entry-content > .alignfull + .alignfull {
  margin-top: 0;
}
body.page-id-7320 .entry-content > :first-child {
  margin-top: 0;
}
body.page-id-7320 .wp-block-cover#fjell {
  min-height: 100vh;
  display: flex;
  align-items: flex-end;
  position: relative;
  overflow: hidden;
}
body.page-id-7320 .wp-block-cover#fjell::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at 80% 20%, hsla(38, 60%, 52%, 0.08) 0%, transparent 60%), radial-gradient(ellipse at 20% 80%, hsla(12, 50%, 48%, 0.06) 0%, transparent 50%);
  z-index: 1;
  pointer-events: none;
}
body.page-id-7320 .wp-block-cover#fjell .wp-block-cover__inner-container {
  position: relative;
  z-index: 2;
  max-width: 900px;
  margin-left: auto;
  padding: 6rem 3rem 5rem;
}
body.page-id-7320 .wp-block-cover#fjell h2.wp-block-heading {
  font-family: karmina, serif;
  font-size: clamp(1.6rem, 4vw, 2.8rem);
  font-weight: 400;
  line-height: 1.45;
  letter-spacing: 0.01em;
  color: var(--color-cream-200);
  text-shadow: 0 2px 30px hsla(0, 0%, 0%, 0.15);
}
body.page-id-7320 .wp-block-cover#fjell h2.wp-block-heading strong {
  font-weight: 400;
  color: var(--color-cream-50);
}
body.page-id-7320 .wp-block-cover#fjell h2.wp-block-heading em {
  font-style: italic;
  color: var(--color-spice-light);
}
body.page-id-7320 .wp-block-cover#fjell h2.wp-block-heading br {
  display: block;
  content: "";
}
body.page-id-7320 .wp-block-cover#fjell .wp-block-olympus-google-fonts-google-fonts {
  font-family: karmina, serif;
  color: var(--color-spice-light);
  font-size: clamp(2.5rem, 6vw, 5rem) !important;
  line-height: 1.1;
  margin-top: 2rem;
  opacity: 0.15;
  font-weight: 700;
  letter-spacing: -0.02em;
}
body.page-id-7320 .wp-block-cover#tregrensa {
  min-height: 100vh;
  position: relative;
}
body.page-id-7320 .wp-block-cover#tregrensa::after {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at center, transparent 40%, hsla(0, 0%, 0%, 0.35) 100%);
  pointer-events: none;
  z-index: 1;
}
body.page-id-7320 .wp-block-cover#tregrensa .wp-block-cover__inner-container {
  position: relative;
  z-index: 2;
}
body.page-id-7320 .wp-block-cover#tregrensa h2.wp-block-heading {
  font-family: am-augusta, serif;
  font-size: clamp(3rem, 10vw, 7rem);
  font-weight: 400;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  line-height: 0.95;
  text-shadow: 0 4px 60px hsla(0, 0%, 0%, 0.4);
}
body.page-id-7320 .wp-block-cover#tregrensa h2.wp-block-heading::before {
  content: "";
  display: block;
  width: 3rem;
  height: 2px;
  background: currentColor;
  margin: 0 auto 1.5rem;
  opacity: 0.5;
}
body.page-id-7320 .wp-block-cover#tregrensa .wp-block-column p {
  font-family: new-spirit, serif;
  font-weight: 300;
  font-size: 0.75rem;
  line-height: 1.6;
  letter-spacing: 0.03em;
  max-width: 28ch;
}
body.page-id-7320 .wp-block-media-text[style*="background-color:#4a443f"] {
  position: relative;
  overflow: hidden;
}
body.page-id-7320 .wp-block-media-text[style*="background-color:#4a443f"]::after {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  width: 60%;
  background: linear-gradient(135deg, hsla(30, 10%, 25%, 0) 0%, hsla(30, 20%, 20%, 0.4) 100%);
  pointer-events: none;
  z-index: 0;
}
body.page-id-7320 .wp-block-media-text[style*="background-color:#4a443f"] .wp-block-media-text__content {
  position: relative;
  z-index: 1;
  padding: 5rem 4rem;
}
body.page-id-7320 .wp-block-media-text[style*="background-color:#4a443f"] h2.wp-block-heading {
  font-family: ff-cocon-pro, sans-serif;
  font-weight: 700;
  letter-spacing: -0.01em;
  line-height: 1.15;
}
body.page-id-7320 .wp-block-media-text[style*="background-color:#4a443f"] h2.wp-block-heading:first-child {
  font-size: clamp(2rem, 5vw, 3.2rem);
}
body.page-id-7320 .wp-block-media-text[style*="background-color:#4a443f"] h2.has-fit-text {
  opacity: 0.25;
  font-size: clamp(1.4rem, 3.5vw, 2.2rem) !important;
  margin-top: 0.3em;
  margin-bottom: 0;
  line-height: 1.2;
  transition: opacity 0.3s ease;
}
body.page-id-7320 .wp-block-media-text[style*="background-color:#4a443f"] h2.has-fit-text:hover {
  opacity: 0.7;
}
body.page-id-7320 .wp-block-media-text[style*="background-color:#4a443f"] .wp-block-media-text__content > p {
  font-family: new-spirit, serif;
  font-weight: 300;
  font-size: 1.05rem;
  line-height: 1.65;
  max-width: 48ch;
}
body.page-id-7320 .wp-block-media-text[style*="background-color:#4a443f"] .wp-block-columns.is-not-stacked-on-mobile {
  margin-top: 2.5rem;
  padding-top: 2rem;
  border-top: 1px solid hsla(38, 45%, 82%, 0.15);
}
body.page-id-7320 .wp-block-media-text[style*="background-color:#4a443f"] .wp-block-columns.is-not-stacked-on-mobile p {
  font-family: new-spirit-condensed, serif;
  font-weight: 500;
  font-size: 0.9rem;
  letter-spacing: 0.04em;
  line-height: 2;
  color: var(--color-cream-400);
}
body.page-id-7320 .wp-block-media-text[style*="background-color:#4a443f"] .wp-block-columns.is-not-stacked-on-mobile p strong {
  color: var(--color-cream-200);
  font-weight: 600;
}
body.page-id-7320 .wp-block-media-text[style*="background-color:#4a443f"] .wp-block-olympus-google-fonts-google-fonts {
  opacity: 0.2;
  margin-top: 0.2em;
  margin-bottom: 0;
  line-height: 1.1;
}
body.page-id-7320 .wp-block-media-text[style*="background-color:#4a443f"] .wp-block-media-text__media img {
  transition: transform 8s cubic-bezier(0.25, 0.1, 0.25, 1);
}
body.page-id-7320 .wp-block-media-text[style*="background-color:#4a443f"]:hover .wp-block-media-text__media img {
  transform: scale(1.03);
}
body.page-id-7320 .wp-block-media-text.has-media-on-the-right[style*="background-color:#f0eada"] .wp-block-media-text__content {
  padding: 5rem 4rem;
}
body.page-id-7320 .wp-block-media-text.has-media-on-the-right[style*="background-color:#f0eada"] h2.wp-block-heading {
  font-family: roca, sans-serif;
  font-weight: 800;
  font-size: clamp(2.2rem, 5vw, 3.5rem);
  line-height: 1.1;
  letter-spacing: -0.02em;
  color: var(--color-brown-800);
}
body.page-id-7320 .wp-block-media-text.has-media-on-the-right[style*="background-color:#f0eada"] h2.wp-block-heading::after {
  content: "";
  display: block;
  width: 4rem;
  height: 3px;
  background: var(--gradient-harvest);
  margin-top: 0.8rem;
  border-radius: 2px;
}
body.page-id-7320 .wp-block-media-text.has-media-on-the-right[style*="background-color:#f0eada"] p {
  font-family: new-spirit, serif;
  font-weight: 300;
  font-size: 1.05rem;
  line-height: 1.7;
  color: var(--color-brown-700);
  max-width: 50ch;
}
body.page-id-7320 .wp-block-media-text#planter {
  position: relative;
}
body.page-id-7320 .wp-block-media-text#planter .wp-block-media-text__content {
  padding: 5rem 4rem;
}
body.page-id-7320 .wp-block-media-text#planter h2.wp-block-heading {
  font-family: laca-variable, sans-serif;
  font-weight: 700;
  font-size: clamp(2.4rem, 6vw, 4rem);
  line-height: 1.05;
  letter-spacing: -0.02em;
  color: var(--color-brown-900);
}
body.page-id-7320 .wp-block-media-text#planter h2.wp-block-heading::after {
  content: "— Gudenes føde";
  display: block;
  font-family: new-spirit, serif;
  font-weight: 300;
  font-style: italic;
  font-size: 0.45em;
  letter-spacing: 0.06em;
  color: var(--color-brown-600);
  margin-top: 0.6em;
  opacity: 0.7;
}
body.page-id-7320 .wp-block-media-text#planter p {
  font-family: new-spirit, serif;
  font-weight: 300;
  font-size: 1.05rem;
  line-height: 1.7;
  color: var(--color-brown-800);
  max-width: 50ch;
}
body.page-id-7320 .wp-block-media-text.has-media-on-the-right[style*="background-color:#4a443f"] .wp-block-media-text__content {
  padding: 5rem 4rem;
}
body.page-id-7320 .wp-block-media-text.has-media-on-the-right[style*="background-color:#4a443f"] h2.wp-block-heading:first-child {
  font-family: highgate-variable, sans-serif;
  font-weight: 700;
  font-size: clamp(3rem, 8vw, 5.5rem);
  line-height: 0.95;
  letter-spacing: -0.03em;
  color: var(--color-cream-100);
  margin-bottom: 0.4em;
}
body.page-id-7320 .wp-block-media-text.has-media-on-the-right[style*="background-color:#4a443f"] p {
  font-family: new-spirit, serif;
  font-weight: 300;
}
body.page-id-7320 .wp-block-media-text.has-media-on-the-right[style*="background-color:#4a443f"] a {
  text-decoration-color: var(--color-spice);
  text-underline-offset: 3px;
  transition: text-decoration-color 0.3s ease;
}
body.page-id-7320 .wp-block-media-text.has-media-on-the-right[style*="background-color:#4a443f"] a:hover {
  text-decoration-color: var(--color-spice-light);
}
body.page-id-7320 .soppkolonner.wp-block-columns {
  gap: 0;
  padding: 0;
  position: relative;
}
body.page-id-7320 .soppkolonner.wp-block-columns::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(to right, var(--color-spice-dark), var(--color-spice), var(--color-sage), var(--color-berry));
  z-index: 2;
}
body.page-id-7320 .soppkolonner.wp-block-columns .wp-block-column {
  padding: 0 0 3rem;
  position: relative;
  transition: background-color 0.4s ease;
}
body.page-id-7320 .soppkolonner.wp-block-columns .wp-block-column:hover {
  background-color: hsla(0, 0%, 100%, 0.04);
}
body.page-id-7320 .soppkolonner.wp-block-columns .wp-block-column + .wp-block-column::before {
  content: "";
  position: absolute;
  top: 2rem;
  bottom: 2rem;
  left: 0;
  width: 1px;
  background: linear-gradient(to bottom, transparent, hsla(38, 45%, 82%, 0.2), transparent);
}
body.page-id-7320 .soppkolonner.wp-block-columns figure.wp-block-image {
  height: 18em;
  overflow: hidden;
}
body.page-id-7320 .soppkolonner.wp-block-columns figure.wp-block-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: contrast(1.05) saturate(0.9);
  transition: transform 6s cubic-bezier(0.25, 0.1, 0.25, 1), filter 0.6s ease;
}
body.page-id-7320 .soppkolonner.wp-block-columns figure.wp-block-image:hover img {
  transform: scale(1.06);
  filter: contrast(1.1) saturate(1);
}
body.page-id-7320 .soppkolonner.wp-block-columns h2.wp-block-heading {
  font-family: mendl-sans-variable, sans-serif;
  font-weight: 700;
  font-size: 1.3rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  margin: 1.5rem 1.2rem 0.8rem;
  color: var(--color-cream-100);
}
body.page-id-7320 .soppkolonner.wp-block-columns h2.wp-block-heading::before {
  content: "●";
  display: inline-block;
  font-size: 0.4em;
  vertical-align: middle;
  margin-right: 0.6em;
  color: var(--color-spice);
}
body.page-id-7320 .soppkolonner.wp-block-columns p {
  font-family: new-spirit, serif;
  font-weight: 300;
  font-size: 0.92rem;
  line-height: 1.65;
  margin: 0 1.2rem;
  color: var(--color-cream-400);
}
body.page-id-7320 .wp-block-media-text[style*="background-color:#f0eada"]:not(.has-media-on-the-right) {
  position: relative;
}
body.page-id-7320 .wp-block-media-text[style*="background-color:#f0eada"]:not(.has-media-on-the-right)::before {
  content: "";
  position: absolute;
  inset: 0;
  background: var(--gradient-golden-hour);
  pointer-events: none;
  z-index: 0;
}
body.page-id-7320 .wp-block-media-text[style*="background-color:#f0eada"]:not(.has-media-on-the-right) .wp-block-media-text__content {
  position: relative;
  z-index: 1;
  padding: 5rem 4rem;
}
body.page-id-7320 .wp-block-media-text[style*="background-color:#f0eada"]:not(.has-media-on-the-right) h2.wp-block-heading {
  font-family: am-augusta, serif;
  font-weight: 400;
  font-size: clamp(2.5rem, 6vw, 4.5rem);
  line-height: 1;
  letter-spacing: 0.02em;
  color: var(--color-brown-900);
}
body.page-id-7320 .wp-block-media-text[style*="background-color:#f0eada"]:not(.has-media-on-the-right) p {
  font-family: new-spirit, serif;
  font-weight: 300;
  font-size: 1.05rem;
  line-height: 1.75;
  color: var(--color-brown-700);
}
body.page-id-7320 .wp-block-media-text[style*="background-color:#f0eada"]:not(.has-media-on-the-right) p em {
  font-style: italic;
  color: var(--color-brown-600);
}
body.page-id-7320 .wp-block-media-text[style*="background-color:#f0eada"]:not(.has-media-on-the-right) p:last-child {
  font-weight: 500;
  font-size: 0.95rem;
  letter-spacing: 0.08em;
  margin-top: 2rem;
  color: var(--color-brown-800);
}
body.page-id-7320 .wp-block-media-text[style*="background-color:#f0eada"]:not(.has-media-on-the-right) p:last-child::before {
  content: "— ";
}
body.page-id-7320 > .entry-content > figure.wp-block-image.alignfull {
  position: relative;
  margin-top: 0;
  margin-bottom: 0;
}
body.page-id-7320 > .entry-content > figure.wp-block-image.alignfull img {
  filter: contrast(1.05) saturate(0.85);
}
body.page-id-7320 > .entry-content > figure.wp-block-image.alignfull figcaption {
  position: absolute;
  bottom: 2rem;
  left: 2rem;
  font-family: new-spirit-condensed, serif;
  font-weight: 500;
  font-size: 0.8rem;
  letter-spacing: 0.06em;
  color: var(--color-cream-200);
  text-shadow: 0 1px 8px hsla(0, 0%, 0%, 0.5);
}
body.page-id-7320 > .entry-content > figure.wp-block-image.alignfull figcaption a {
  color: inherit;
  text-decoration-color: var(--color-spice);
}
body.page-id-7320 .wp-block-group.alignwide {
  padding: 5rem 2rem;
  position: relative;
}
body.page-id-7320 .wp-block-group.alignwide::before {
  content: "";
  display: block;
  width: 5rem;
  height: 2px;
  background: var(--gradient-divider);
  margin: 0 auto 3rem;
}
body.page-id-7320 > .entry-content > .wp-block-paragraph:last-child {
  text-align: center;
  font-family: new-spirit-condensed, serif;
  font-weight: 500;
  font-size: 0.8rem;
  letter-spacing: 0.1em;
  color: var(--color-brown-400);
  padding: 3rem 2rem;
  border-top: 1px solid var(--color-cream-400);
}
@media (max-width: 782px) {
  body.page-id-7320 .wp-block-cover#fjell {
    min-height: 85vh;
  }
  body.page-id-7320 .wp-block-cover#fjell .wp-block-cover__inner-container {
    padding: 4rem 1.5rem 3rem;
  }
  body.page-id-7320 .wp-block-cover#fjell h2.wp-block-heading {
    text-align: left !important;
    font-size: clamp(1.3rem, 5vw, 1.8rem);
  }
  body.page-id-7320 .wp-block-cover#tregrensa {
    min-height: 70vh;
  }
  body.page-id-7320 .wp-block-cover#tregrensa h2.wp-block-heading {
    font-size: clamp(2.2rem, 12vw, 3.5rem);
  }
  body.page-id-7320 .wp-block-media-text .wp-block-media-text__content {
    padding: 3rem 1.5rem !important;
  }
  body.page-id-7320 .soppkolonner.wp-block-columns {
    flex-direction: column;
  }
  body.page-id-7320 .soppkolonner.wp-block-columns .wp-block-column + .wp-block-column::before {
    display: none;
  }
  body.page-id-7320 .soppkolonner.wp-block-columns figure.wp-block-image {
    height: 14em;
  }
}

/*# sourceMappingURL=style.css.map */
