/*!
Theme Name: BCC Norge Skoleinfo
Theme URI: https://skoleinfo.bcc.no
Description: BCC Skoleinfo theme — Vue to WordPress conversion with custom Gutenberg blocks.
Version: 1.0.0
Author: BCC Norge
Author URI: https://bccnorge.no
Text Domain: bcc-norge-skoleinfo
*/

/* =========================================
   GOOGLE FONTS – Archivo
   ========================================= */
@import url('https://fonts.googleapis.com/css2?family=Archivo:wght@400;500;600&display=swap');

/* =========================================
   DESIGN TOKENS
   ========================================= */
:root {
  /* Colors – Brown scale */
  --color-brown-100: #f9faf4;
  --color-brown-200: #ece8dc;
  --color-brown-300: #d1c5b0;
  --color-brown-500: #a98c66;
  --color-brown-700: #6e5232;

  /* Colors – Brand */
  --color-brand-700:  #0c625c;
  --color-brand-800:  #014d49;
  --color-brand-900:  #0b3633;
  --color-brand-1000: #012320;

  /* Colors – Neutral */
  --color-neutral-0: #ffffff;

  /* Colors – Text */
  --color-text-default:       #292a2e;
  --color-text-subtle:        #505258;
  --color-text-subtlest:      #7d818a;
  --color-text-inverse:       #ffffff;
  --color-text-brand-default: #014d49;

  /* Colors – Icons */
  --color-icon-default: #1e1f21;
  --color-icon-inverse: #ffffff;

  /* Colors – Borders */
  --color-border-default:      rgba(11,18,14,0.14);
  --color-border-accent-brown: #8b6d45;

  /* Spacing */
  --space-a: clamp(4rem, calc(1.088vw + 3.694rem), 5rem);
  --space-b: clamp(2.5rem, calc(0.544vw + 2.347rem), 3rem);
  --space-c: clamp(1.5rem, calc(0.544vw + 1.347rem), 2rem);
  --space-d: clamp(1rem, calc(0.544vw + 0.847rem), 1.5rem);
  --space-0:   0px;
  --space-1:   4px;
  --space-1-5: 6px;
  --space-2:   8px;
  --space-2-5: 10px;
  --space-3:   12px;
  --space-4:   16px;
  --space-5:   20px;
  --space-6:   24px;
  --space-8:   32px;
  --space-9:   36px;
  --space-10:  40px;
  --space-11:  44px;
  --space-12:  48px;
  --space-14:  56px;
  --space-16:  64px;
  --space-20:  80px;

  /* Typography */
  --font-family-archivo: 'Archivo', system-ui, -apple-system, sans-serif;
  --font-size-xs:  12px;
  --font-size-sm:  14px;
  --font-size-md:  16px;
  --font-size-lg:  20px;
  --font-size-xl:  24px;
  --font-size-2xl: 32px;
  --font-size-3xl: 36px;
  --font-size-4xl: 48px;
  --font-size-5xl: 56px;

  --line-height-lg:  20px;
  --line-height-xl:  24px;
  --line-height-2xl: 28px;
  --line-height-4xl: 36px;
  --line-height-5xl: 40px;
  --line-height-7xl: 64px;

  --font-weight-regular:  400;
  --font-weight-medium:   500;
  --font-weight-semibold: 600;

  /* Icon sizes */
  --icon-size-xs: 16px;
  --icon-size-sm: 20px;
  --icon-size-md: 24px;
  --icon-size-lg: 32px;
  --icon-size-xl: 48px;

  /* Border radius */
  --border-radius-sm: 6px;
  --border-radius-md: 8px;
  --border-radius-lg: 12px;
  --border-radius-xl: 16px;

  /* Legacy aliases */
  --bcc-sand:       var(--color-brown-200);
  --bcc-sand-deep:  #dfd9c4;
  --bcc-brown:      var(--color-brown-700);
  --bcc-brown-soft: var(--color-border-accent-brown);
  --bcc-teal:       var(--color-brand-800);
  --bcc-ink:        var(--color-text-default);
  --bcc-muted:      rgba(80,82,88,0.19);
  --bcc-text:       var(--color-text-subtle);
  --bcc-border:     var(--color-border-default);
}

/* =========================================
   BASE RESET
   ========================================= */
*,
*::before,
*::after {
  box-sizing: border-box;
}

html,
body {
  margin: 0;
  padding: 0;
  font-family: var(--font-family-archivo);
  background-color: var(--color-brown-100);
  color: var(--color-text-default);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

html {
  scrollbar-gutter: stable;
}

body {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  overflow-x: hidden;
}

#main {
  width: 100%;
  max-width: 859px;
  margin: 0 auto;
  flex: 1;
}

/* Backup padding-inline solution */
#main > p,
#main > ul,
#main > ol,
#main > h1,
#main > h2,
#main > h3,
#main > h4,
#main > h5,
#main > span,
#main > .section--faq,
#main > blockquote,
#main > figure,
#main > .content-carousel,
#main > .section--themes {
  padding-inline: var(--space-11);
}
#main > button,
#main > hr,
#main > .content-cta {
  margin-inline: var(--space-11);
}

#main > *:first-child:not(.wp-block-group) {
  margin-top: var(--space-a);
}

#main > *:last-child:not(.wp-block-group) {
  margin-bottom: var(--space-a);
}

/* --- wp:group --- */
.wp-block-group {
  max-width: 859px;
  width: 100%;
  margin-left: auto;
  margin-right: auto;
}

.wp-block-group.is-style-full-width {
  width: 100vw;
  max-width: 100vw;
  margin-left: calc(-50vw + 50%);
  margin-right: calc(-50vw + 50%);
  padding: 0;
  position: relative;
}

.wp-block-group.is-style-wider-width {
  width: 955px;
  max-width: 100vw;
  margin-left: calc((100% - 955px) / 2);
  margin-right: calc((100% - 955px) / 2);
}

.app-header__inner,
.hero__inner,
.content-hero__inner,
.contact__inner,
.app-footer__inner,
.wp-block-group.is-style-full-width .section__inner,
.wp-block-group.is-style-wider-width .section__inner {
  padding-inline: var(--space-11);
}

.wp-block-group > .wp-block-group__inner-container > .wp-block-group > .wp-block-group__inner-container {
  padding-block: var(--space-11);
}

.wp-block-group:not(.is-style-full-width):not(.is-style-wider-width) {
  margin-block: var(--space-a);
}

.wp-block-group:not(.is-style-full-width):not(.is-style-wider-width) .wp-block-group__inner-container {
  padding-inline: var(--space-11);
}

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

.wp-block-image {
  margin-block: var(--space-c) var(--space-b);
}

.wp-block-image img {
  width: 100%;
  border-radius: var(--border-radius-md);
}

.wp-element-caption {
  font-size: var(--font-size-md);
  line-height: var(--line-height-xl);
  margin-top: var(--space-2);
}

.wp-block-group.is-style-full-width .wp-block-image {
  margin-bottom: 0;
}

h1 {
  font-size: var(--font-size-5xl);
  line-height: var(--line-height-7xl);
  margin-block: var(--space-b) var(--space-c);
}

h2 {
  color: var(--color-brown-700);
  font-size: var(--font-size-3xl);
  font-weight: var(--font-weight-semibold);
  line-height: var(--line-height-5xl);
  margin-block: var(--space-b) var(--space-c);
}

h3 {
  color: var(--color-brown-700);
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-semibold);
  line-height: var(--line-height-3xl);
  margin-block: var(--space-b) var(--space-c);
}

h4 {
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-semibold);
  line-height: var(--line-height-2xl);
  margin-block: var(--space-b) var(--space-c);
}

h5 {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-semibold);
  line-height: var(--line-height-xl);
  margin-block: var(--space-b) var(--space-c);
}

p {
  font-size: var(--font-size-md);
  line-height: var(--line-height-xl);
  margin-block: var(--space-c);
}

.wp-block-paragraph {
  min-height: 1px;
}

a {
  color: inherit;
}

.wp-block-paragraph a {
  color: var(--color-brand-700);
  font-weight: var(--font-weight-semibold);
  transition: 300ms ease color;
}

.wp-block-paragraph a:hover {
  color: var(--color-brand-900);
}

hr {
  margin: var(--space-a) 0;
  color: var(--color-border-default);
}

#main .wp-block-list {
  margin: var(--space-8) var(--space-2);
}
#main ul.wp-block-list {
  margin-left: var(--space-2-5);
}

button {
  font-family: inherit;
}

.hidden {
  display: none !important;
}

@media (max-width: 955px) {
  .wp-block-group.is-style-wider-width {
    width: 100%;
    margin-left: 0;
    margin-right: 0;
  }
}

@media (max-width: 781px) {
  .wp-block-group:not(.is-style-full-width):not(.is-style-wider-width) .wp-block-group__inner-container {
    gap: var(--space-0);
  }
}

@media (max-width: 640px) {
  .wp-block-group > .wp-block-group__inner-container > .wp-block-group > .wp-block-group__inner-container {
    padding-block: var(--space-c);
  }

  .app-header__inner,
  .hero__inner,
  .content-hero__inner,
  .contact__inner,
  .app-footer__inner,
  .wp-block-group.is-style-full-width .section__inner,
  .wp-block-group.is-style-wider-width .section__inner,
  .wp-block-group:not(.is-style-full-width):not(.is-style-wider-width) .wp-block-group__inner-container {
    padding-inline: var(--space-6);
  }

  /* Backup padding-inline solution */
  #main > p,
  #main > ul,
  #main > ol,
  #main > h1,
  #main > h2,
  #main > h3,
  #main > h4,
  #main > h5,
  #main > span,
  #main > .section--faq,
  #main > blockquote,
  #main > figure,
  #main > .content-carousel,
  #main > .section--themes {
    padding-inline: var(--space-6);
  }
  #main > button,
  #main > hr,
  #main > .content-cta {
    margin-inline: var(--space-6);
  }

  h1 {
    font-size: var(--font-size-3xl);
    line-height: var(--line-height-5xl);
  }

  h2 {
    font-size: var(--font-size-2xl);
    line-height: var(--line-height-3xl);
  }

  h3 {
    font-size: var(--font-size-xl);
    line-height: var(--line-height-2xl);
  }

  h4 {
    font-size: var(--font-size-lg);
    line-height: var(--line-height-xl);
  }

  h5 {
    font-size: var(--font-size-md);
    line-height: var(--line-height-xl);
  }
}

@media (max-width: 480px) {
  .wp-block-group > .wp-block-group__inner-container > .wp-block-group > .wp-block-group__inner-container {
    padding-block: var(--space-4);
  }

  .app-header__inner,
  .hero__inner,
  .content-hero__inner,
  .contact__inner,
  .app-footer__inner,
  .wp-block-group.is-style-full-width .section__inner,
  .wp-block-group.is-style-wider-width .section__inner,
  .wp-block-group:not(.is-style-full-width):not(.is-style-wider-width) .wp-block-group__inner-container {
    padding-inline: var(--space-c);
  }

  /* Backup padding-inline solution */
  #main > p,
  #main > ul,
  #main > ol,
  #main > h1,
  #main > h2,
  #main > h3,
  #main > h4,
  #main > h5,
  #main > span,
  #main > .section--faq,
  #main > blockquote,
  #main > figure,
  #main > .content-carousel,
  #main > .section--themes {
    padding-inline: var(--space-c);
  }
  #main > button,
  #main > hr,
  #main > .content-cta {
    margin-inline: var(--space-c);
  }
}

/* =========================================
   BUTTONS
   ========================================= */
.btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: var(--space-2-5) var(--space-5);
  font-family: var(--font-family-archivo);
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-medium);
  line-height: var(--line-height-xl);
  border-radius: var(--border-radius-md);
  cursor: pointer;
  text-decoration: none;
  transition: background-color 150ms ease, color 150ms ease, border-color 150ms ease;
  border: 1px solid transparent;
  margin-bottom: var(--space-c);
  text-align: left;
}

.section--video .video-caption__actions .btn {
  margin-bottom: 0;
}

.btn > a {
  display: contents;
  color: inherit;
  text-decoration: none;
}

.btn--lg {
  padding: var(--space-3) var(--space-6);
}

.btn--primary {
  background-color: var(--color-brand-800);
  color: var(--color-text-inverse);
  border-color: var(--color-brand-800);
}

.btn--primary:hover,
.btn--primary:focus-visible {
  background-color: var(--color-brand-900);
  border-color: var(--color-brand-900);
}

.btn--primary-outlined {
  background-color: transparent;
  color: var(--color-brand-800);
  border-color: var(--color-brand-800);
}

.btn--primary-outlined:hover,
.btn--primary-outlined:focus-visible {
  background-color: var(--color-brand-800);
  color: var(--color-text-inverse);
}

.btn--contrast {
  background-color: var(--color-neutral-0);
  color: var(--color-text-default);
  border-color: var(--color-neutral-0);
  border-radius: 9999px;
}

.btn--contrast:hover {
  background-color: rgba(255,255,255,0.9);
}

.btn svg {
  width: var(--icon-size-sm);
  height: var(--icon-size-sm);
  flex-shrink: 0;
}

.btn--icon-right svg {
  order: 1;
}

/* =========================================
   FORM ELEMENTS
   ========================================= */
.form-input,
.form-textarea {
  width: 100%;
  font-family: var(--font-family-archivo);
  font-size: var(--font-size-md);
  line-height: var(--line-height-xl);
  color: var(--color-text-default);
  padding: 10px 14px;
  background-color: var(--color-neutral-0);
  border: 1px solid var(--color-border-default);
  border-radius: var(--border-radius-sm);
  box-shadow: 0 1px 2px rgba(18,18,23,0.05);
  outline: none;
  appearance: none;
  transition: border-color 150ms ease, box-shadow 150ms ease;
}

.form-input {
  height: 44px;
  padding-block: var(--space-2-5);
}

.form-textarea {
  resize: vertical;
  padding-block: var(--space-2-5);
}

.form-input:focus,
.form-textarea:focus {
  border-color: var(--color-brand-800);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-brand-800) 15%, transparent);
}

.form-label {
  display: block;
  font-size: var(--font-size-sm);
  line-height: var(--line-height-lg);
  color: var(--color-text-default);
  margin-bottom: var(--space-1-5);
}

/* =========================================
   ACCORDION
   ========================================= */
.accordion {
  width: 100%;
}

.accordion__panel {
  transition: 300ms ease;
  border-bottom: 1px solid var(--color-border-default);
}

.accordion__panel:last-child {
  border-bottom: none;
}

.accordion__wrapper.has-opened .accordion__panel:not(.is-open):not(:hover) {
  opacity: 0.5;
}

.accordion__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: var(--space-5) var(--space-c);
  background: transparent;
  border: none;
  cursor: pointer;
  font-family: var(--font-family-archivo);
  font-size: var(--font-size-lg);
  line-height: var(--line-height-xl);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-default);
  text-align: left;
  gap: var(--space-4);
}

.accordion__icon {
  flex-shrink: 0;
  width: 32px;
  height: 32px;
  color: var(--color-brand-1000);
  transition: transform 200ms ease;
}

.accordion__icon svg {
  width: 100%;
  height: 100%;
}

.accordion__panel.is-open .accordion__icon {
  transform: rotate(180deg);
}

.accordion__content {
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows 280ms cubic-bezier(0.4, 0, 0.2, 1);
}

.accordion__content-inner {
  overflow: hidden;
  min-height: 0;
  margin-right: var(--space-11);
  padding-inline: var(--space-c);
  padding-block: 0;
  transition: padding-block 280ms cubic-bezier(0.4, 0, 0.2, 1);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.accordion__content-inner p {
  line-height: var(--line-height-xl);
  margin-block: 0;
}

.accordion__content-inner ul {
  list-style: none;
  padding: 0;
  margin: 0 var(--space-2);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.accordion__content-inner ul li {
  font-size: var(--font-size-md);
  line-height: var(--line-height-xl);
  color: var(--color-text-default);
}

.accordion__content-inner ul li::before {
  content: '';
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background-color: var(--color-brown-700);
  margin-top: var(--space-2);
  margin-right: var(--space-4);
  vertical-align: top;
}

.accordion__content-inner ol {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  counter-reset: skoleinfo-list;
}

.accordion__content-inner ol li {
  font-size: var(--font-size-md);
  line-height: var(--line-height-xl);
  color: var(--color-text-default);
  counter-increment: skoleinfo-list;
}

.accordion__content-inner ol li::before {
  content: counter(skoleinfo-list) '.';
  font-size: var(--font-size-lg);
  line-height: var(--line-height-xl);
  font-weight: var(--font-weight-semibold);
  color: var(--color-brown-700);
  flex-shrink: 0;
  min-width: 24px;
  margin-right: var(--space-2);
}

.accordion__content-inner a {
  color: var(--color-brand-800);
}

.accordion__panel.is-open .accordion__content {
  grid-template-rows: 1fr;
}

.accordion__panel.is-open .accordion__content-inner {
  padding-block: var(--space-3) var(--space-8);
}

/* =========================================
   APP HEADER
   ========================================= */
.app-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background-color: color-mix(in srgb, var(--color-brown-200) 72%, transparent);
  backdrop-filter: blur(12px) saturate(140%);
  -webkit-backdrop-filter: blur(12px) saturate(140%);
  border-bottom: 1px solid var(--color-border-default);
}

body.admin-bar .app-header {
  top: 32px;
}

.app-header__inner {
  max-width: 1400px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  gap: 4rem;
  min-height: 64px;
}

.app-header__logo {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  text-decoration: none;
}

.app-header__logo img {
  height: 32px;
  width: auto;
  display: block;
}

/* --- Desktop Nav --- */
.app-header__nav-wrap {
  flex: 1;
  min-width: 0;
}

.app-header__nav {
  display: flex;
  align-items: center;
  gap: 32px;
  list-style: none;
  margin: 0;
  padding: 0;
}

.app-header__nav-item {
  position: relative;
  display: flex;
  align-items: center;
  list-style: none;
}

.app-header__nav.has-active .app-header__nav-item:not(.is-active) > a {
  opacity: 0.5;
}

.app-header__nav-item > a {
  font-size: var(--font-size-md);
  line-height: var(--line-height-xl);
  font-weight: var(--font-weight-medium);
  color: var(--color-text-default);
  text-decoration: none;
  white-space: nowrap;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 20px 0;
  transition: 300ms ease;
}

.app-header__nav-item > a.current-menu-item {
  font-weight: var(--font-weight-semibold);
}

.app-header__nav-caret {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
  transition: transform 150ms ease;
}

.app-header__nav-item.is-open .app-header__nav-caret {
  transform: rotate(180deg);
}

/* --- Dropdown submenu --- */
.app-header__submenu {
  display: flex;
  flex-direction: column;
  gap: var(--space-2-5);
  position: absolute;
  top: 50px;
  left: -16px;
  margin: 0;
  padding: var(--space-4);
  list-style: none;
  min-width: 240px;
  background-color: var(--color-brown-100);
  border: 1px solid var(--color-border-default);
  border-top: none;
  border-radius: var(--border-radius-lg);
  box-shadow: 0 8px 24px rgba(11,18,14,0.12), 0 0 1px rgba(11,18,14,0.18);
  opacity: 0;
  visibility: hidden;
  transform: translateY(4px);
  transition: opacity 150ms ease, transform 150ms ease, visibility 150ms ease;
  z-index: 60;
}

.app-header__nav-item.is-open .app-header__submenu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.app-header__submenu li {
  margin: 0;
  list-style: none;

}

.app-header__submenu a {
  display: block;
  font-size: var(--font-size-md);
  line-height: var(--line-height-xl);
  color: var(--color-text-default);
  text-decoration: none;
  white-space: nowrap;
  transition: 300ms ease;
}

.app-header__submenu.has-active li:not(.is-active) a {
  opacity: 0.5;
}

/* --- Header Right --- */
.app-header__right {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  flex-shrink: 0;
  position: relative;
}

/* --- Search --- */
.app-header__search {
  width: 0;
  opacity: 0;
  overflow: hidden;
  transition: width 260ms cubic-bezier(0.4,0,0.2,1), opacity 200ms ease;
  pointer-events: none;
  position: absolute;
  right: 3rem;
}

.app-header__search.is-open {
  width: 260px;
  opacity: 1;
  pointer-events: auto;
}

.app-header__search input {
  width: 100%;
  height: 40px;
  padding: 0 var(--space-4);
  font-family: var(--font-family-archivo);
  font-size: var(--font-size-md);
  border: 1px solid var(--color-border-default);
  border-radius: var(--border-radius-sm);
  background-color: var(--color-neutral-0);
  outline: none;
}

.app-header__search input:focus {
  border-color: var(--color-brand-800);
}

.app-header__search-toggle,
.app-header__mobile-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 9999px;
  background: transparent;
  border: none;
  cursor: pointer;
  color: var(--color-text-default);
  transition: opacity 150ms ease;
}

.app-header__search-toggle svg,
.app-header__mobile-toggle svg {
  width: var(--icon-size-md);
  height: var(--icon-size-md);
}

.app-header__mobile-toggle svg {
  width: var(--icon-size-lg);
  height: var(--icon-size-lg);
}

.app-header__mobile-toggle {
  display: none;
}

/* --- Mobile Menu --- */
.app-header__mobile {
  position: fixed;
  top: 64px;
  left: 0;
  right: 0;
  height: calc(100vh - 64px);
  background-color: var(--color-brown-200);
  overflow-y: auto;
  opacity: 0;
  visibility: hidden;
  transition: opacity 200ms ease, visibility 200ms ease;
  z-index: 40;
  display: flex;
  flex-direction: column;
}

.app-header__mobile.is-open {
  opacity: 1;
  visibility: visible;
}

.app-header__mobile-nav {
  border-top: 1px solid var(--color-border-default);
  padding: var(--space-11);
}

.app-header__mobile-nav ul,
.app-header__mobile-sublist {
  list-style: none;
  margin: 0;
  padding: 0;
}

.app-header__mobile-nav > ul {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.app-header__mobile-item {
  display: flex;
  flex-direction: column;
}

.app-header__mobile-link {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  width: 100%;
  font-family: inherit;
  font-size: var(--font-size-xl);
  line-height: var(--line-height-4xl);
  font-weight: var(--font-weight-medium);
  color: var(--color-text-default);
  text-decoration: none;
  text-align: left;
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
}

.app-header__mobile-link:hover,
.app-header__mobile-link:focus-visible {
  outline: none;
}

.app-header__mobile-caret {
  width: 32px;
  height: 32px;
  flex-shrink: 0;
  transition: transform 150ms ease;
}

.app-header__mobile-item.is-open .app-header__mobile-caret {
  transform: rotate(180deg);
}

.app-header__mobile-sublist-wrap {
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows 280ms cubic-bezier(0.4, 0, 0.2, 1);
}

.app-header__mobile-item.is-open .app-header__mobile-sublist-wrap {
  grid-template-rows: 1fr;
}

.app-header__mobile-sublist {
  display: flex;
  flex-direction: column;
  overflow: hidden;
  min-height: 0;
  padding-left: var(--space-6) !important;
  transition: padding-top 280ms cubic-bezier(0.4, 0, 0.2, 1);
}

.app-header__mobile-item.is-open .app-header__mobile-sublist {
  padding-top: var(--space-4);
}

.app-header__mobile-sublink {
  display: block;
  padding-bottom: var(--space-1-5);
  font-size: var(--font-size-md);
  line-height: var(--line-height-xl);
  font-weight: var(--font-weight-regular);
  color: var(--color-text-default);
  text-decoration: none;
}

.app-header__mobile-sublink:hover,
.app-header__mobile-sublink:focus-visible {
  color: var(--color-text-brand-default);
  outline: none;
}

.app-header__mobile-search {
  padding: var(--space-4) var(--space-6);
  background-color: var(--color-brown-300);
}

.app-header__mobile-search-form {
  position: relative;
}

.app-header__mobile-search-icon {
  position: absolute;
  top: 50%;
  left: var(--space-4);
  transform: translateY(-50%);
  color: var(--color-text-subtlest);
  pointer-events: none;
  z-index: 1;
  display: inline-flex;
}

.app-header__mobile-search-icon svg {
  width: 20px;
  height: 20px;
}

.app-header__mobile-search input {
  width: 100%;
  height: 48px;
  padding-left: 3rem;
  padding-right: var(--space-4);
  font-family: var(--font-family-archivo);
  font-size: var(--font-size-md);
  background-color: var(--color-neutral-0);
  border: 1px solid var(--color-border-default);
  border-radius: var(--border-radius-sm);
  outline: none;
}

@media (max-width: 960px) {
  .app-header__inner {
    justify-content: space-between;
  }

  .app-header__nav {
    display: none;
  }

  .app-header__mobile-toggle {
    display: inline-flex;
  }

  .app-header__search {
    right: 6rem;
  }

  .app-header__search.is-open {
    width: 220px;
  }
}

@media (max-width: 782px) {
  body.admin-bar .app-header {
    top: 46px;
  }
}

@media (max-width: 640px) {
  .app-header__mobile-nav {
    padding: var(--space-c);
  }
}

@media (max-width: 600px) {
  body.admin-bar .app-header {
    top: 0;
  }
}

/* =========================================
   APP FOOTER
   ========================================= */
.app-footer {
  background-color: var(--color-brand-900);
  color: var(--color-neutral-0);
  position: relative;
  overflow: hidden;
}

.app-footer__inner {
  max-width: 1400px;
  margin: 0 auto;
  padding-block: var(--space-16) var(--space-6);
  position: relative;
  z-index: 1;
}

.app-footer__top {
  display: grid;
  grid-template-columns: minmax(0,1fr) minmax(0,2.4fr) minmax(0,1fr);
  align-items: start;
}

.app-footer__brand {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  max-width: 227px;
}

.app-footer__logo {
  display: inline-flex;
  text-decoration: none;
}

.app-footer__logo img {
  height: 48px;
  width: auto;
  filter: brightness(0) invert(1);
}

.app-footer__columns {
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: var(--space-10);
}

.app-footer__column ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-2-5);
}

.app-footer__heading {
  margin: 0 0 var(--space-3);
  font-size: var(--font-size-md);
  line-height: var(--line-height-xl);
  font-weight: var(--font-weight-medium);
  color: var(--color-brown-500);
  text-transform: uppercase;
}

.app-footer__column a {
  font-size: var(--font-size-md);
  line-height: var(--line-height-xl);
  color: var(--color-text-inverse);
  text-decoration: none;
  transition: 300ms ease;
}

.app-footer__column a:hover {
  color: var(--color-text-inverse);
}

.app-footer *::selection,
.contact *::selection,
.content-cta *::selection,
.btn--primary::selection,
.btn--primary *::selection {
  background-color: Highlight;
  color: HighlightText;
}

.app-footer__columns.has-active li:not(.is-active) a {
  opacity: 0.5;
}

.app-footer__bottom {
  margin-top: var(--space-14);
  padding-top: var(--space-6);
  border-top: 1px solid color-mix(in srgb, var(--color-text-inverse) 16%, transparent);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-6);
  flex-wrap: wrap;
}

.app-footer__bottom p {
  margin: 0;
  font-size: var(--font-size-md);
  line-height: var(--line-height-xl);
  color: var(--color-neutral-0);
}

.app-footer__figure {
  position: absolute;
  top: 0.75rem;
  right: 1rem;
  height: 235px;
  width: auto;
}

.app-footer__figure path {
  fill: var(--color-brand-800);
}

.app-footer__social {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.app-footer__social-label {
  font-size: var(--font-size-md);
  line-height: var(--line-height-xl);
}

.app-footer__social ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.app-footer__social a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  color: var(--color-icon-inverse);
  transition: opacity 150ms ease;
}

.app-footer__social a:hover,
.app-footer__social a:focus-visible {
  opacity: 0.8;
}

@media (max-width: 960px) {
  .app-footer__top {
    grid-template-columns: 1fr;
    gap: var(--space-8);
  }

  .app-footer__columns {
    grid-template-columns: repeat(2, minmax(0,1fr));
  }

  .app-footer__column--desktop-only {
    display: none;
  }
}

@media (max-width: 480px) {
  .app-footer__inner {
    padding-top: var(--space-10);
  }

  .app-footer__top {
    gap: var(--space-10);
  }

  .app-footer__bottom {
    margin-top: var(--space-10);
    flex-direction: column;
    text-align: center;
    gap: var(--space-2-5);
  }

  .app-footer__social {
    order: -1;
  }
}

/* =========================================
   BCC FIGURE (decorative SVG)
   ========================================= */
.bcc-figure {
  display: block;
  pointer-events: none;
}

/* =========================================
   HERO SECTION (Homepage)
   ========================================= */
.hero {
  background: url(assets/images/hero.png) var(--color-brown-200) no-repeat 140% 90%;
  overflow: hidden;
  background-size: auto 47vw;
  min-height: 400px;
  display: flex;
  position: relative;
  justify-content: center;
}

.hero__inner {
  width: 100%;
  max-width: 1400px;
  padding-block: var(--space-a);
  align-content: flex-end;
  z-index: 1;
}

.hero__caption {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
  max-width: 520px;
}

.hero__title {
  margin: 0;
  font-size: var(--font-size-3xl);
  line-height: var(--line-height-5xl);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-default);
}

.hero__eyebrow {
  margin: 0;
  font-size: var(--font-size-lg);
  line-height: var(--line-height-2xl);
  font-weight: var(--font-weight-semibold);
  text-transform: uppercase;
  color: var(--color-brown-700);
  max-width: 400px;
}

.hero__description {
  margin: 0;
  font-size: var(--font-size-md);
  line-height: var(--line-height-xl);
  color: var(--color-brown-700);
}

.hero__form {
  position: relative;
  margin-top: var(--space-2);
  max-width: 480px;
}

.hero__form-icon {
  position: absolute;
  top: 50%;
  left: var(--space-4);
  transform: translateY(-50%);
  color: var(--color-text-subtlest);
  pointer-events: none;
  z-index: 1;
  display: inline-flex;
}

.hero__form-icon svg {
  width: 20px;
  height: 20px;
}

.hero__form input {
  width: 100%;
  padding-left: 3rem;
  padding-right: var(--space-4);
  height: 48px;
  background-color: var(--color-neutral-0);
  border: 1px solid var(--color-border-default);
  border-radius: var(--border-radius-sm);
  font-family: var(--font-family-archivo);
  font-size: var(--font-size-md);
  outline: none;
}

.hero__form input:focus {
  border-color: var(--color-brand-800);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-brand-800) 15%, transparent);
}

@media (max-width: 1024px) {
  .hero {
    background-position: -160% bottom;
    background-size: 120% auto;
  }
}

@media (max-width: 480px) {
  .hero {
    display: flex;
    align-items: flex-end;
    background-position: 5% 80%;
    background-size: 280% auto;
  }

  .hero__inner {
    width: 100%;
    padding-bottom: var(--space-a);
  }

  .hero__title {
    max-width: 324px;
  }
}

/* =========================================
   CONTENT HERO (page hero with breadcrumb)
   ========================================= */
.content-hero {
  width: 100vw;
  position: relative;
  background: url(assets/images/hero.png) var(--color-brown-200) no-repeat 140% 90%;
  background-size: auto 47vw;
  display: flex;
  min-height: 400px;
}

.hero::before,
.content-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(270deg, rgba(236, 232, 220, 0.00) 0%, var(--color-brown-200) 100%);
  z-index: 0;
}

.hero.has-custom-image,
.content-hero.has-featured-image {
  background-position: var(--hero-focal-point, center);
  background-size: cover;
}

.content-hero__inner {
  position: relative;
  z-index: 1;
  max-width: 1400px;
  width: 100%;
  margin: 0 auto;
  display: flex;
  justify-content: flex-end;
  flex-direction: column;
  gap: var(--space-4);
  padding-block: var(--space-a);
}

.content-hero__breadcrumb {
  display: flex;
  align-items: center;
  gap: var(--space-1);
  flex-wrap: wrap;
}

.content-hero__crumb {
  font-size: var(--font-size-xs);
  line-height: 16px;
  font-weight: var(--font-weight-regular);
  color: var(--color-text-subtle);
  text-decoration: none;
}

.content-hero__crumb--current {
  color: var(--color-text-default);
}

a.content-hero__crumb:hover {
  color: var(--color-text-brand-default);
  text-decoration: underline;
}

.content-hero__crumb-sep {
  width: 16px;
  height: 16px;
  color: var(--color-text-subtle);
  flex-shrink: 0;
}

.content-hero__title {
  margin: 0;
  font-size: var(--font-size-5xl);
  line-height: var(--line-height-7xl);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-default);
  max-width: 644px;
}

.content-hero__subtitle {
  margin: 0;
  font-size: var(--font-size-lg);
  line-height: var(--line-height-2xl);
  font-weight: var(--font-weight-regular);
  color: var(--color-text-subtle);
  max-width: 480px;
}

@media (max-width: 1024px) {
  .content-hero {
    background-position: -160% bottom;
    background-size: 120% auto;
  }
}

@media (max-width: 960px) {
  .content-hero__title {
    font-size: var(--font-size-4xl);
    line-height: var(--line-height-5xl);
  }
}

@media (max-width: 480px) {
  .content-hero {
    background-position: 5% 80%;
    background-size: 280% auto;
  }

  .hero::before,
  .content-hero::before {
    background: linear-gradient(270deg, rgba(236, 232, 220, 0.00) 0%, var(--color-brown-200) 70%);
  }

  .content-hero__title {
    font-size: var(--font-size-3xl);
    line-height: var(--line-height-5xl);
  }

  .content-hero__subtitle {
    font-size: var(--font-size-md);
  }
}

/* =========================================
   CONTENT ARTICLE
   ========================================= */
.content-article {
  max-width: 771px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: var(--space-8);
}

.content-article__lead {
  margin: 0;
  font-size: var(--font-size-lg);
  line-height: var(--line-height-xl);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-default);
}

.content-article__body {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.content-article__body p {
  margin: 0;
  font-size: var(--font-size-md);
  line-height: var(--line-height-xl);
  font-weight: var(--font-weight-regular);
  color: var(--color-text-default);
}

.content-article h2 {
  margin: 0;
  font-size: var(--font-size-3xl);
  line-height: var(--line-height-5xl);
  font-weight: var(--font-weight-semibold);
  color: var(--color-brown-700);
}

.content-article h3 {
  margin: 0;
  font-size: var(--font-size-2xl);
  line-height: 32px;
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-default);
}

.content-article h4 {
  margin: 0;
  font-size: var(--font-size-xl);
  line-height: var(--line-height-2xl);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-default);
}

.content-article h5 {
  margin: 0;
  font-size: var(--font-size-lg);
  line-height: var(--line-height-xl);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-default);
}

.content-article hr {
  border: none;
  border-top: 2px solid var(--color-border-default);
  margin: 0;
}

.content-article a {
  font-weight: var(--font-weight-semibold);
  color: var(--color-brand-800);
  text-decoration: underline;
}

.content-article ol,
.content-article ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.content-article__featured-text {
  margin: 0;
  border-left: 2px solid var(--color-brown-700);
  padding-left: var(--space-6);
  font-size: var(--font-size-xl);
  line-height: var(--line-height-2xl);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-default);
}

.content-article blockquote {
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-2-5);
  position: relative;
  padding-inline: var(--space-10);
}

.content-article blockquote p {
  margin: 0;
  font-size: var(--font-size-xl);
  line-height: var(--line-height-2xl);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-default);
}

.content-article blockquote cite {
  font-size: var(--font-size-md);
  line-height: var(--line-height-xl);
  font-weight: var(--font-weight-regular);
  color: var(--color-brown-700);
  font-style: normal;
}

/* Article FAQ inside content */
.content-article__faq {
  background-color: var(--color-brown-200);
  border: 1px solid var(--color-border-default);
  border-radius: var(--border-radius-xl);
  padding: var(--space-5) var(--space-4);
}

.content-article__faq .accordion__header {
  padding: var(--space-5) 0;
}

@media (max-width: 480px) {
  .content-article h2 {
    font-size: var(--font-size-2xl);
  }

  .content-article h3 {
    font-size: var(--font-size-xl);
  }

  .content-article__faq {
    padding: 0;
    margin: 0 calc(var(--space-4) * -1);
    border-radius: 0;
    border-bottom: none;
  }
}

/* =========================================
   TWO COLUMN
   ========================================= */
.two-col {
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: center;
  background-color: var(--color-brown-200);
}

.two-col--img-right .two-col__image-wrap {
  order: 2;
}

.two-col--img-right .two-col__content {
  order: 1;
}

.two-col__image-wrap {
  position: relative;
  overflow: hidden;
  aspect-ratio: 720 / 440;
}

.two-col__image-wrap--video {
  padding: 0;
  border: 0;
  background: none;
  cursor: pointer;
  display: block;
  width: 100%;
  height: 100%;
}

.two-col__image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.two-col__image-overlay {
  position: absolute;
  inset: 0;
  background-color: color-mix(in srgb, var(--color-brown-500) 40%, transparent);
  transition: background-color 200ms ease;
}

.two-col__image-wrap--video:hover .two-col__image-overlay,
.two-col__image-wrap--video:focus-visible .two-col__image-overlay {
  background-color: color-mix(in srgb, var(--color-brown-500) 60%, transparent);
}

.two-col__image-play {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  color: var(--color-text-inverse);
  display: flex;
  pointer-events: none;
  transition: transform 200ms ease;
}

.two-col__image-wrap--video:hover .two-col__image-play,
.two-col__image-wrap--video:focus-visible .two-col__image-play {
  transform: translate(-50%, -50%) scale(1.1);
}

.two-col__image-play svg {
  width: 48px;
  height: 48px;
  filter: drop-shadow(0 2px 12px rgba(0,0,0,0.5));
}

.two-col__content {
  padding: var(--space-16);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.two-col__heading {
  margin: 0;
  font-size: var(--font-size-3xl);
  line-height: var(--line-height-5xl);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-default);
}

.two-col__body {
  margin: 0;
  font-size: var(--font-size-md);
  line-height: var(--line-height-xl);
  font-weight: var(--font-weight-regular);
  color: var(--color-text-default);
}

.two-col__btn-link {
  text-decoration: none;
  align-self: flex-start;
  margin-bottom: var(--space-0);
}

.two-col__quote {
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-2-5);
  position: relative;
  padding-inline: var(--space-10);
}

.two-col__quote-wrapper {
  display: flex;
  flex-direction: row;
  gap: var(--space-4);
  position: relative;
}

.two-col__quote-mark {
  position: absolute;
  left: -3rem;
  font-size: var(--font-size-5xl);
  font-weight: var(--font-weight-semibold);
  color: var(--color-brown-700);
  line-height: 1;
}

.two-col__quote-text {
  margin: 0;
  font-size: var(--font-size-xl);
  line-height: var(--line-height-2xl);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-default);
}

.two-col__quote-source {
  font-size: var(--font-size-md);
  line-height: var(--line-height-xl);
  font-weight: var(--font-weight-regular);
  color: var(--color-brown-700);
  font-style: normal;
  margin-top: var(--space-2);
}

@media (max-width: 768px) {
  .two-col {
    grid-template-columns: 1fr;
  }

  .two-col--img-right .two-col__image-wrap,
  .two-col--img-right .two-col__content {
    order: unset;
  }

  .two-col__image-wrap {
    aspect-ratio: 16 / 9;
  }

  .two-col__content {
    padding: var(--space-11);
  }

  .two-col__heading {
    font-size: var(--font-size-2xl);
  }

  .two-col__quote {
    padding-inline: 0;
  }

  .two-col__quote-mark {
    position: relative;
    left: 0;
  }

  .two-col__quote-source {
    margin-top: 0;
    margin-left: var(--space-10);
  }
}

@media (max-width: 640px) {
  .two-col__content {
    padding: var(--space-8);
  }
}

@media (max-width: 480px) {
  .two-col__content {
    padding: var(--space-6) var(--space-4);
  }

  .two-col__heading {
    font-size: var(--font-size-xl);
  }

  .two-col__quote-wrapper {
    gap: var(--space-2);
  }

  .two-col__quote-mark {
    font-size: var(--font-size-3xl);
  }

  .two-col__quote-source {
    margin-left: var(--space-6);
  }
}

/* =========================================
   CONTENT CAROUSEL
   ========================================= */
.content-carousel {
  margin-block: var(--space-a);
}

.content-carousel__inner {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
}

.content-carousel__title {
  margin: 0;
  font-size: var(--font-size-xl);
  line-height: var(--line-height-2xl);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-default);
}

.content-carousel__wrapper {
  position: relative;
  display: flex;
  align-items: center;
  gap: var(--space-4);
  margin-right: calc((100vw - 100%) / 2 * -1);
}

.content-carousel__arrows {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  position: absolute;
  left: -4rem;
}

.content-carousel__arrow {
  flex-shrink: 0;
  width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  background-color: var(--color-brown-200);
  border: 1px solid var(--color-border-default);
  border-radius: var(--border-radius-sm);
  cursor: pointer;
  color: var(--color-text-default);
  transition: background-color 0.15s ease;
}

.content-carousel__arrow:hover {
  background-color: var(--color-brown-500);
  color: var(--color-text-inverse);
}

.content-carousel__arrow svg {
  width: var(--icon-size-md);
  height: var(--icon-size-md);
}

.content-carousel__track {
  display: flex;
  flex-direction: row;
  gap: var(--space-d);
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scrollbar-width: none;
  -ms-overflow-style: none;
  flex: 1;
  min-width: 0;
  width: 100%;
}

.content-carousel__track::-webkit-scrollbar {
  display: none;
}

.content-carousel__card {
  flex: 0 0 calc(771px / 3 - var(--space-d) * 2 / 3);
  height: calc(771px / 3 - var(--space-d) * 2 / 3);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: var(--space-4);
  background-color: var(--color-neutral-0);
  border: 1px solid var(--color-border-accent-brown);
  border-radius: 12px;
  text-decoration: none;
  color: inherit;
  scroll-snap-align: start;
  transition: box-shadow 0.15s ease, transform 0.15s ease;
  position: relative;
}

.content-carousel__card:hover {
  box-shadow: 0 4px 18px color-mix(in srgb, var(--color-brown-700) 12%, transparent);
}

.content-carousel__card.empty {
  flex: 0 0 0;
  border: none;
  background: none;
  padding: 0;
  box-shadow: none;
}
.content-carousel__card.empty:first-child {
  display: none;
}

.content-carousel__card-icon {
  width: var(--icon-size-xl);
  height: var(--icon-size-xl);
  border-radius: var(--border-radius-sm);
  background-color: var(--color-brown-200);
  color: var(--color-brown-700);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.content-carousel__card-icon svg {
  width: var(--icon-size-md);
  height: var(--icon-size-md);
}

.content-carousel__card-body {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-1);
  text-align: center;
}

.content-carousel__card-title {
  font-size: var(--font-size-xl);
  line-height: var(--line-height-2xl);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-default);
}

.content-carousel__card-desc {
  font-size: var(--font-size-sm);
  line-height: var(--line-height-lg);
  font-weight: var(--font-weight-regular);
  color: var(--color-text-subtle);
}

.content-carousel__card-arrow {
  position: absolute;
  bottom: var(--space-2);
  right: var(--space-2);
  width: var(--icon-size-md);
  height: var(--icon-size-md);
}

@media (max-width: 955px) {
  .content-carousel__wrapper {
    margin-left: calc((100vw - 100%) / 2 * -1);
  }

  .content-carousel__arrows {
    display: none;
  }

  .content-carousel__card.empty:first-child {
    display: flex;
  }
}

@media (max-width: 640px) {
  .content-carousel__card.empty {
    flex: 0 0 var(--space-2);
  }
}

@media (max-width: 480px) {
  .content-carousel__inner {
    margin-inline: calc(var(--space-4) * -1);
  }

  .content-carousel__title {
    padding: 0 var(--space-4);
  }
}

/* =========================================
   CONTENT CTA
   ========================================= */
.content-cta {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-6);
  padding: var(--space-c);
  background-color: #0c625c;
  border: 1px solid var(--color-border-default);
  border-radius: var(--border-radius-xl);
  max-width: 771px;
  margin-block: var(--space-b);
}

.content-cta__text {
  margin: 0;
  font-size: var(--font-size-lg);
  line-height: var(--line-height-xl);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-inverse);
  max-width: 435px;
}

.content-cta__btn-link {
  text-decoration: none;
  flex-shrink: 0;
  margin-bottom: var(--space-0);
}

.content-cta .btn--contrast {
  flex-shrink: 0;
}

@media (max-width: 640px) {
  .content-cta {
    flex-direction: column;
    align-items: stretch;
    padding: var(--space-5) var(--space-4);
    gap: var(--space-4);
  }

  .content-cta .btn--contrast {
    align-self: flex-start;
  }
}

/* =========================================
   CONTENT GRID
   ========================================= */
.content-grid {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
  width: 100%;
  max-width: 771px;
}

.content-grid__title {
  margin: 0;
  font-size: var(--font-size-xl);
  line-height: var(--line-height-2xl);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-default);
}

.content-grid__items {
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: var(--space-c);
}

.content-grid__card {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-5);
  background-color: var(--color-neutral-0);
  border: 1px solid var(--color-border-accent-brown);
  border-radius: 12px;
  text-decoration: none;
  color: inherit;
  transition: box-shadow 0.15s ease, transform 0.15s ease;
}

.content-grid__card:hover {
  box-shadow: 0 4px 18px color-mix(in srgb, var(--color-brown-700) 12%, transparent);
  transform: translateY(-1px);
}

.content-grid__card-icon {
  flex-shrink: 0;
  width: var(--icon-size-xl);
  height: var(--icon-size-xl);
  border-radius: var(--border-radius-sm);
  background-color: var(--color-brown-200);
  color: var(--color-brown-700);
  display: flex;
  align-items: center;
  justify-content: center;
}

.content-grid__card-icon svg {
  width: var(--icon-size-md);
  height: var(--icon-size-md);
}

.content-grid__card-body {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  flex: 1;
  min-width: 0;
}

.content-grid__card-title {
  font-size: var(--font-size-xl);
  line-height: var(--line-height-2xl);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-default);
}

.content-grid__card-desc {
  font-size: var(--font-size-sm);
  line-height: var(--line-height-lg);
  font-weight: var(--font-weight-regular);
  color: var(--color-text-subtle);
}

.content-grid__card-arrow {
  flex-shrink: 0;
  color: var(--color-icon-default);
  display: flex;
  align-items: center;
}

.content-grid__card-arrow svg {
  width: var(--icon-size-lg);
  height: var(--icon-size-lg);
}

@media (max-width: 640px) {
  .content-grid__items {
    grid-template-columns: 1fr;
  }
}

/* =========================================
   CONTENT SIDEBAR
   ========================================= */
body.has-content-sidebar #main {
  padding-bottom: 76px;
}

.content-sidebar {
  width: 320px;
  z-index: 40;
  border-radius: 0 16px 0 0;
  border: 1px solid rgba(11,18,14,0.14);
  overflow: hidden;
  background-color: var(--color-neutral-0);
  bottom: 0;
  left: 0;
}

.content-sidebar--fixed {
  position: fixed;
}

.content-sidebar--absolute {
  position: absolute;
  bottom: -76px;
}

.content-sidebar__overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0,0,0,0.4);
  z-index: -1;
  display: none;
}

.content-sidebar__header {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: 16px 24px;
  background-color: var(--color-brown-200);
  border: none;
  cursor: pointer;
  text-align: left;
  gap: var(--space-4);
}

.content-sidebar__title-stack {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.content-sidebar__eyebrow {
  font-family: Inter, sans-serif;
  font-size: 12px;
  line-height: 16px;
  font-weight: 400;
  color: var(--color-text-subtle);
}

.content-sidebar__section-name {
  font-size: var(--font-size-lg);
  line-height: var(--line-height-xl);
  font-weight: var(--font-weight-semibold);
  color: #553d28;
}

.content-sidebar__icon {
  flex-shrink: 0;
  width: 24px;
  height: 24px;
  color: var(--color-text-default);
}

.content-sidebar__body {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 0 24px;
  background-color: var(--color-neutral-0);
  max-height: 0;
  overflow: auto;
  transform: translateY(-6px);
  transition: max-height 350ms ease, transform 300ms ease, padding 350ms ease;
}

.content-sidebar.is-open .content-sidebar__body {
  max-height: 500px;
  transform: translateY(0);
  padding: 16px 24px;
}

.content-sidebar__link {
  font-size: var(--font-size-md);
  line-height: var(--line-height-xl);
  font-weight: var(--font-weight-regular);
  color: var(--color-text-default);
  text-decoration: none;
  transition: 300ms ease;
}


.content-sidebar__body.has-active .content-sidebar__link:not(.is-active) {
  opacity: 0.5;
}

@media (max-width: 480px) {
  body.has-content-sidebar #main {
    padding-bottom: 0;
  }

  .content-sidebar {
    width: 100%;
    border-radius: 0;
    border-left: none;
    border-right: none;
    border-bottom: none;
  }

  .content-sidebar.is-open .content-sidebar__overlay {
    display: block;
  }
}

/* =========================================
   VIDEO MODAL (using <dialog>)
   ========================================= */
.video-modal-dialog {
  padding: 0;
  border: none;
  background: #000;
  border-radius: 12px;
  max-width: min(960px, 92vw);
  width: 100%;
  overflow: hidden;
}

.video-modal-dialog::backdrop {
  background: rgba(0,0,0,0.72);
}

.video-modal__close {
  position: absolute;
  top: 12px;
  right: 12px;
  z-index: 2;
  width: 36px;
  height: 36px;
  padding: 0;
  border-radius: 9999px;
  background-color: rgba(0,0,0,0.55);
  border: none;
  color: var(--color-icon-inverse);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background-color 150ms ease;
}

.video-modal__close:hover,
.video-modal__close:focus-visible {
  background-color: rgba(0,0,0,0.85);
  outline: none;
}

.video-modal__close svg {
  width: 20px;
  height: 20px;
}

.video-modal__frame {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
}

.video-modal__frame iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
}

/* =========================================
   HOMEPAGE SECTIONS
   ========================================= */
.home-page {
  background-color: var(--color-brown-100);
  color: var(--color-text-default);
}

.section {
  margin-block: var(--space-b);
}

.home .section {
  margin-block: var(--space-a);
}

.section__inner {
  max-width: 1400px;
  margin: 0 auto;
}

.section-heading {
  display: flex;
  align-items: center;
  gap: var(--space-12);
  margin-bottom: var(--space-12);
}

.section-heading__title {
  font-size: var(--font-size-3xl);
  line-height: var(--line-height-5xl);
  font-weight: var(--font-weight-semibold);
  color: var(--color-brown-700);
  margin: 0;
  flex-shrink: 0;
}


/* =========================================
   GUTENBERG CORE BLOCKS — LISTS & QUOTES
   ========================================= */

/* --- Bullet list (core/list, unordered) --- */
ul.wp-block-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

ul.wp-block-list li {
  font-size: var(--font-size-md);
  line-height: var(--line-height-xl);
  color: var(--color-text-default);
}

ul.wp-block-list li::before {
  content: '';
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background-color: var(--color-brown-700);
  margin-top: var(--space-2);
  margin-right: 15.5px;
  vertical-align: top;
}

/* --- Ordered list (core/list, ordered) --- */
ol.wp-block-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  counter-reset: skoleinfo-list;
}

ol.wp-block-list li {
  font-size: var(--font-size-md);
  line-height: var(--line-height-xl);
  color: var(--color-text-default);
  counter-increment: skoleinfo-list;
}

ol.wp-block-list li::before {
  content: counter(skoleinfo-list) '.';
  font-size: var(--font-size-lg);
  line-height: var(--line-height-xl);
  font-weight: var(--font-weight-semibold);
  color: var(--color-brown-700);
  flex-shrink: 0;
  min-width: 24px;
  margin-right: var(--space-2);
}

/* --- Inline Number format (skoleinfo/number) --- */
.inline-number {
  font-size: var(--font-size-lg);
  line-height: var(--line-height-xl);
  font-weight: var(--font-weight-semibold);
  color: var(--color-brown-700);
  margin-right: var(--space-2);
}

/* --- Quote: shared text styles --- */
.wp-block-quote {
  margin: var(--space-b) 0 !important;
}

.wp-block-quote p {
  margin: 0;
  font-size: var(--font-size-xl);
  line-height: var(--line-height-2xl);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-default);
}

.page .wp-block-quote cite,
.page .wp-block-quote footer {
  font-size: var(--font-size-md);
  line-height: var(--line-height-xl);
  font-weight: var(--font-weight-regular);
  color: var(--color-brown-700);
  font-style: normal;
  display: block;
  margin-top: var(--space-2);
}

/* --- Quote: With line (is-style-with-line) --- */
.wp-block-quote.is-style-with-line {
  margin: 0;
  border-left: 2px solid var(--color-brown-700);
  padding-left: var(--space-6);
}

/* --- Quote: With quotes (is-style-with-quotes) --- */
/* Desktop: absolute " mark to the left, content stacked below */
.wp-block-quote.is-style-with-quotes {
  margin: 0;
  padding: 0;
  border: none;
  display: flex;
  flex-direction: column;
  gap: var(--space-2-5);
  position: relative;
}

.wp-block-quote.is-style-with-quotes::before {
  content: '\201C';
  position: absolute;
  left: -3rem;
  top: 0;
  font-size: var(--font-size-5xl);
  font-weight: var(--font-weight-semibold);
  color: var(--color-brown-700);
  line-height: 1;
}

.wp-block-paragraph.is-style-featured-text {
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-semibold);
  line-height: var(--line-height-2xl);
  margin-block: var(--space-b);
}

@media (max-width: 1024px) {
  .wp-block-quote.is-style-with-quotes {
    flex-direction: row;
    flex-wrap: wrap;
    align-items: flex-start;
    padding-inline: 0;
    column-gap: var(--space-4);
    row-gap: var(--space-2-5);
  }

  .wp-block-quote.is-style-with-quotes::before {
    position: static;
    flex-shrink: 0;
  }

  .wp-block-quote.is-style-with-quotes p {
    flex: 1;
    min-width: 0;
  }

  .wp-block-quote.is-style-with-quotes cite {
    width: 100%;
    margin-top: 0;
    margin-left: calc(var(--space-10) + 4px);
  }
}

@media (max-width: 480px) {
  .wp-block-quote.is-style-with-quotes::before {
    font-size: var(--font-size-3xl);
  }

  .wp-block-quote.is-style-with-quotes cite {
    margin-left: calc(var(--space-8));
  }

  .wp-block-paragraph.is-style-featured-text {
    font-size: var(--font-size-lg);
    line-height: var(--line-height-xl);
  }
}

/* --- Video block on homepage --- */
.video-block {
  display: grid;
  grid-template-columns: minmax(0, 644fr) minmax(0, 588fr);
  gap: var(--space-20);
  align-items: center;
}

.video-poster {
  position: relative;
  display: block;
  border-radius: var(--border-radius-xl);
  overflow: hidden;
  aspect-ratio: 644 / 416;
  padding: 0;
  border: 0;
  background: none;
  width: 100%;
  cursor: pointer;
  transition: transform 200ms ease;
  color: var(--color-text-inverse);
}

.video-poster:hover .video-poster__play,
.video-poster:focus-visible .video-poster__play {
  transform: translate(-50%, -50%) scale(1.08);
}

.video-poster__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.video-poster__play {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  color: var(--color-icon-inverse);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform 200ms ease;
}

.video-poster__play svg {
  width: var(--font-size-4xl);
  height: var(--font-size-4xl);
}

.video-caption {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
}

.video-caption__text {
  margin: 0;
  font-size: var(--font-size-2xl);
  line-height: var(--line-height-5xl);
  font-weight: var(--font-weight-regular);
  color: var(--color-text-default);
  max-width: 418px;
}

.video-caption__desc {
  margin: 0;
  font-size: var(--font-size-md);
  line-height: var(--line-height-xl);
  color: var(--color-text-subtle);
  max-width: 418px;
}

.video-caption__actions {
  display: flex;
  gap: var(--space-4);
  align-self: flex-start;
}

/* --- Theme cards on homepage --- */
.theme-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-d);
}

.theme-card {
  display: flex;
  align-items: flex-start;
  gap: var(--space-4);
  padding: var(--space-5);
  background-color: var(--color-neutral-0);
  border: 1px solid var(--color-border-accent-brown);
  border-radius: 12px;
  text-decoration: none;
  color: inherit;
  transition: box-shadow 0.15s ease, transform 0.15s ease;
}

.theme-card:hover {
  box-shadow: 0 4px 18px color-mix(in srgb, var(--color-brown-700) 12%, transparent);
  transform: translateY(-1px);
}

.theme-card__icon {
  flex-shrink: 0;
  width: var(--icon-size-xl);
  height: var(--icon-size-xl);
  border-radius: var(--border-radius-sm);
  background-color: var(--color-brown-200);
  color: var(--color-brown-700);
  display: flex;
  align-items: center;
  justify-content: center;
}

.theme-card__icon svg {
  width: var(--icon-size-md);
  height: var(--icon-size-md);
}

.theme-card__body {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  flex: 1;
  min-width: 0;
}

.theme-card__title {
  font-size: var(--font-size-xl);
  line-height: var(--line-height-2xl);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-default);
}

.theme-card__description {
  font-size: var(--font-size-md);
  line-height: var(--line-height-lg);
  font-weight: var(--font-weight-regular);
  color: var(--color-text-subtle);
}

.theme-card__arrow {
  flex-shrink: 0;
  color: var(--color-icon-default);
  display: flex;
  align-items: center;
  justify-content: center;
}

.theme-card__arrow svg {
  width: var(--icon-size-lg);
  height: var(--icon-size-lg);
}

/* --- FAQ card on homepage --- */
.faq-card {
  margin: 0 auto;
  background-color: var(--color-brown-200);
  border: 1px solid var(--color-border-default);
  border-radius: var(--border-radius-xl);
  padding: var(--space-11);
}

.accordion__wrapper {
  display: flex;
  flex-direction: column;
}

.faq-card__actions {
  padding-top: var(--space-8);
  display: flex;
  align-self: flex-start;
}

.faq-card__actions-link {
  text-decoration: none;
  margin-bottom: 0;
}

@media (max-width: 1024px) {
  .video-block {
    grid-template-columns: 1fr;
    gap: var(--space-8);
  }

  .video-caption__text {
    font-size: var(--font-size-xl);
    line-height: var(--space-8);
  }

  .theme-grid {
    grid-template-columns: 1fr;
  }

  .section-heading {
    gap: var(--space-6);
  }
}

@media (max-width: 640px) {
  .section-heading {
    margin-bottom: var(--space-8);
  }

  .section-heading__title {
    font-size: var(--font-size-2xl);
    line-height: var(--line-height-3xl);
  }

  .faq-card {
    padding: var(--space-1) var(--space-0) var(--space-0);
  }

  .faq-card__actions {
    padding-block: var(--space-8);
    justify-content: center;
  }
}

@media (max-width: 480px) {
  .home .section--faq {
    margin-block: var(--space-0);
  }

  .section--faq,
  .section--faq .section__inner {
    padding-inline: var(--space-0) !important;
  }

  .home-page {
    padding-bottom: 0;
  }

  .theme-grid {
    gap: var(--space-4);
  }

  .video-block {
    gap: var(--space-4);
  }

  .video-caption__text {
    font-size: var(--font-size-lg);
    color: var(--color-text-subtle);
    line-height: var(--line-height-2xl);
  }

  .section--faq .section-heading {
    padding: var(--space-0) var(--space-c);
  }

  .faq-card {
    border-radius: 0;
  }
}

/* =========================================
   CONTENT PAGE LAYOUT
   ========================================= */
.content-page {
  position: relative;
}

.content-page__article-wrap {
  background-color: #fff;
  padding: var(--space-16) var(--space-6);
  position: relative;
}

.content-page__figure {
  position: absolute;
  top: calc(100% - 4rem);
  left: 0.75rem;
  width: 160px;
  height: 235px;
  display: block;
}

.content-page__figure path {
  fill: var(--color-brown-300);
}

.content-page__blocks {
  background-color: var(--color-brown-100);
}

.content-page__section {
  display: flex;
  justify-content: center;
  background-color: var(--color-brown-100);
  padding: var(--space-4) var(--space-6);
}

.content-page__section--grid {
  padding-bottom: var(--space-16);
}

@media (max-width: 1024px) {
  .content-page__figure {
    display: none;
  }
}

@media (max-width: 768px) {
  .content-page__article-wrap {
    padding: var(--space-8) var(--space-4);
  }
}

@media (max-width: 480px) {
  .content-page__section {
    padding: var(--space-4);
  }
}

/* =========================================
   SEARCH PAGE
   ========================================= */
.search-page__hero {
  position: relative;
}

.search-page__hero .content-hero {
  min-height: 320px;
}

.search-page__input-wrap {
  max-width: 859px;
  margin: 0 auto;
  padding: var(--space-8) var(--space-11) var(--space-2);
}

.search-page__form {
  display: flex;
  align-items: center;
  position: relative;
}

.search-page__input-icon {
  position: absolute;
  left: var(--space-3);
  top: 50%;
  transform: translateY(-50%);
  color: var(--color-text-subtle);
  pointer-events: none;
  display: flex;
}

.search-page__input-icon svg {
  width: 20px;
  height: 20px;
}

.search-page__input {
  flex: 1;
  height: 44px;
  padding: var(--space-2) var(--space-3) var(--space-2) 2.75rem;
  font-family: var(--font-family-archivo);
  font-size: var(--font-size-md);
  line-height: var(--line-height-xl);
  color: var(--color-text-default);
  background-color: var(--color-neutral-0);
  border: 1px solid var(--color-text-subtle);
  border-radius: var(--border-radius-sm);
  box-shadow: 0 1px 2px rgba(18,18,23,0.05);
  outline: none;
  appearance: none;
}

.search-page__input:focus {
  border-color: var(--color-text-brand-default);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-text-brand-default) 15%, transparent);
}

.search-page__input::-webkit-search-cancel-button {
  display: none;
}

.search-page__results-wrap {
  max-width: 859px;
  margin: 0 auto;
  padding: var(--space-8) var(--space-11);
}

.search-page__results-label {
  margin: 0 0 var(--space-4);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-default);
}

.search-page__no-results {
  margin: 0;
  padding: var(--space-6) var(--space-11);
  border-block: 1px solid rgba(11,18,14,0.14);
  font-size: var(--font-size-md);
  line-height: var(--line-height-xl);
  color: var(--color-text-default);
  text-align: center;
}

.search-page__list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.search-page__item {
  display: flex;
  flex-direction: row;
  align-items: flex-start;
  gap: var(--space-3);
  padding: var(--space-6) 0;
  border-top: 1px solid rgba(11,18,14,0.14);
}

.search-page__item-body {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-1-5);
}

.search-page__item-title-row {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.search-page__item-title {
  font-size: var(--font-size-lg);
  line-height: var(--line-height-xl);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-default);
  text-decoration: none;
}

.search-page__item-title:hover {
  color: var(--color-text-brand-default);
  text-decoration: underline;
}

.search-page__item-ext-icon {
  flex-shrink: 0;
  width: 20px;
  height: 20px;
  color: var(--color-text-subtle);
}

.search-page__item-url {
  font-size: var(--font-size-sm);
  line-height: var(--line-height-lg);
  color: var(--color-text-subtlest);
  display: flex;
  flex-direction: row;
  align-items: center;
}

.search-page__item-url svg {
  width: 14px;
  height: 14px;
}

.search-page__item-snippet {
  margin: 0;
  font-size: var(--font-size-sm);
  line-height: var(--line-height-lg);
  color: var(--color-text-subtle);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.search-page__item-thumb {
  flex-shrink: 0;
  width: 108px;
  height: 108px;
  object-fit: cover;
  border-radius: 12px;
}

.search-page__pagination {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  gap: var(--space-2-5);
  padding: var(--space-2-5) 0;
  border-top: 1px solid rgba(11,18,14,0.14);
  margin-top: var(--space-4);
}

/* Inner nav-links becomes the flex row of page items */
.search-page__pagination .nav-links {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: var(--space-2-5);
  flex-wrap: wrap;
}

.search-page__pagination .page-numbers {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 36px;
  height: 36px;
  padding: 0 var(--space-2);
  font-family: var(--font-family-archivo);
  font-size: 20px;
  font-weight: var(--font-weight-semibold);
  line-height: 24px;
  color: var(--color-text-subtlest);
  text-decoration: none;
  background: none;
  border: none;
  cursor: pointer;
  transition: color 0.15s ease;
}

.search-page__pagination .page-numbers:hover:not(.current) {
  color: var(--color-text-default);
}

.search-page__pagination .page-numbers.current {
  color: #292a2e;
}

.search-page__pagination .page-numbers.dots {
  cursor: default;
}

.search-page__section {
  padding: var(--space-16) var(--space-6);
  max-width: 1200px;
  margin: 0 auto;
  width: 100%;
  box-sizing: border-box;
}

@media (max-width: 640px) {
  .search-page__input-wrap,
  .search-page__results-wrap {
    padding-inline: var(--space-8);
  }

  .search-page__item-thumb {
    width: 72px;
    height: 72px;
  }

  .search-page__section {
    padding: 0 var(--space-4) var(--space-8);
  }
}

@media (max-width: 480px) {
  .search-page__input-wrap,
  .search-page__results-wrap {
    padding-inline: var(--space-4);
  }
}

/* =========================================
   CONTACT SECTION
   ========================================= */
.contact {
  background-color: var(--color-brand-800);
  color: var(--color-text-inverse);
  padding-block: var(--space-20);
}

.contact__inner {
  max-width: 1400px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: minmax(0,1fr) minmax(0,1fr);
  gap: var(--space-16);
  align-items: center;
  justify-items: center;
}

.contact__caption {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.contact__title {
  margin: 0;
  font-size: var(--font-size-3xl);
  line-height: var(--line-height-5xl);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-inverse);
}

.contact__sub {
  margin: 0;
  font-size: var(--font-size-md);
  line-height: var(--line-height-xl);
  color: color-mix(in srgb, var(--color-text-inverse) 78%, transparent);
}

.contact__info {
  margin: var(--space-2) 0 0;
  padding: 0;
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--font-size-md);
  line-height: var(--line-height-xl);
  color: var(--color-text-inverse);
  margin-left: 20px;
}

.contact__info a {
  color: var(--color-text-inverse);
  text-decoration: none;
}

.contact__info-icon {
  flex-shrink: 0;
  width: 20px;
  height: 20px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--color-icon-inverse);
}

.contact__info-icon svg {
  width: 20px;
  height: 20px;
}

.contact__form {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  background-color: var(--color-neutral-0);
  border: 1px solid var(--color-border-default);
  border-radius: var(--border-radius-xl);
  padding: var(--space-8);
  color: var(--color-text-default);
  width: 100%;
  max-width: 480px;
}

.contact__form form {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.contact__field {
  display: flex;
  flex-direction: column;
}

.contact__label {
  display: block;
  font-size: var(--font-size-sm);
  line-height: var(--line-height-lg);
  color: var(--color-text-default);
  margin-bottom: var(--space-1-5);
}

.contact__textarea {
  width: 100%;
  font-family: var(--font-family-archivo);
  font-size: var(--font-size-md);
  line-height: var(--line-height-xl);
  color: var(--color-text-default);
  padding: var(--space-2-5) 14px;
  background-color: var(--color-neutral-0);
  border: 1px solid var(--color-border-default);
  border-radius: var(--border-radius-sm);
  box-shadow: 0 1px 2px rgba(18,18,23,0.05);
  outline: none;
  resize: vertical;
  transition: border-color 150ms ease, box-shadow 150ms ease;
}

.contact__textarea:focus {
  border-color: var(--color-brand-800);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-brand-800) 15%, transparent);
}

.contact__actions {
  display: flex;
  position: relative;
} 

.contact__actions [type="submit"] {
  flex: 1;
  margin-bottom: 0;
}

.contact__actions .wpcf7-spinner {
  background-color: var(--color-brand-700);
  position: absolute;
  right: var(--space-5);
  top: 0;
  bottom: 0;
  margin: auto 0;
}

.contact__notice {
  padding: var(--space-3) var(--space-4);
  border-radius: var(--border-radius-sm);
  font-size: var(--font-size-sm);
  line-height: var(--line-height-lg);
}

.contact__notice--success {
  background-color: color-mix(in srgb, #22c55e 12%, transparent);
  color: #15803d;
  border: 1px solid #bbf7d0;
}

.contact__notice--error {
  background-color: color-mix(in srgb, #ef4444 12%, transparent);
  color: #b91c1c;
  border: 1px solid #fecaca;
}

/* CF7 integration */
.contact__form .wpcf7 {
  width: 100%;
}

.contact__form .wpcf7-form {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.contact__form .wpcf7-form-control-wrap {
  display: block;
}

.contact__form .wpcf7-not-valid-tip {
  font-size: var(--font-size-sm);
  color: #b91c1c;
  margin-top: var(--space-1);
}

.contact__form .wpcf7-response-output {
  padding: var(--space-3) var(--space-4);
  border-radius: var(--border-radius-sm);
  font-size: var(--font-size-sm);
  line-height: var(--line-height-lg);
  margin: 0 !important;
}

.contact__form .wpcf7-mail-sent-ok {
  background-color: color-mix(in srgb, #22c55e 12%, transparent);
  color: #15803d;
  border: 1px solid #bbf7d0;
}

.contact__form .wpcf7-validation-errors,
.contact__form .wpcf7-acceptance-missing,
.contact__form .wpcf7-mail-sent-ng,
.contact__form .wpcf7-aborted {
  background-color: color-mix(in srgb, #ef4444 12%, transparent);
  color: #b91c1c;
  border: 1px solid #fecaca;
}

@media (max-width: 1024px) {
  .contact {
    padding-block: var(--space-10);
  }

  .contact__inner {
    grid-template-columns: 1fr;
    gap: var(--space-8);
  }

  .contact__caption {
    text-align: center;
  }

  .contact__info {
    justify-content: center;
    margin-left: var(--space-0);
  }
}

@media (max-width: 480px) {
  .contact__title {
    font-size: var(--font-size-xl);
    line-height: var(--line-height-2xl);
  }

  .contact__caption {
    text-align: left;
  }

  .contact__info {
    justify-content: flex-start;
    margin-left: 20px;
  }
}

/* =========================================
   404 PAGE
   ========================================= */
.error-404 {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-height: 60vh;
  padding: var(--space-16) var(--space-6);
  text-align: center;
  background-color: var(--color-brown-100);
}

.error-404__code {
  font-size: 120px;
  font-weight: var(--font-weight-semibold);
  color: var(--color-brown-200);
  line-height: 1;
  margin: 0;
}

.error-404__title {
  margin: var(--space-4) 0 var(--space-2);
  font-size: var(--font-size-3xl);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-default);
}

.error-404__text {
  margin: 0 0 var(--space-8);
  font-size: var(--font-size-lg);
  color: var(--color-text-subtle);
}

/* =========================================
   UTILITY
   ========================================= */
.visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0,0,0,0);
  white-space: nowrap;
  border: 0;
}

/* =========================================
   Wordpress
   ========================================= */
.wp-block-columns {
  margin-block: var(--space-c);
  gap: var(--space-c);
}

.wp-block-columns .wp-block-image {
  margin: 0;
}

.wp-block-columns > .wp-block-column {
  line-height: var(--line-height-xl);
}

/* --- Column: Centered (core/column, is-style-centered) --- */
.wp-block-column.is-style-centered {
  align-content: center;
}

@media (max-width: 781px) {
  .wp-block-columns:not(.is-not-stacked-on-mobile)>.wp-block-column {
    justify-items: center;
  }

  .contact--local-churches {
    gap: var(--space-0);
  }

  .contact--local-churches .wp-block-column p {
    margin-block: 0;
  }
}

.skoleinfo-gallery {
  padding: var(--space-8) 0 !important;
}

.skoleinfo-gallery.swiper-horizontal>.swiper-pagination-bullets {
  bottom: var(--space-4);
}

.skoleinfo-gallery .swiper-button-prev {
  color: var(--color-brown-700);
  left: var(--space-4);
}

.skoleinfo-gallery .swiper-button-next {
  color: var(--color-brown-700);
  right: var(--space-4);
}

.skoleinfo-gallery .swiper-pagination-bullet-active {
  background-color: var(--color-brown-700);
}

@media (max-width: 480px) {
  .mobile--no-top-margin {
    margin-top: 0 !important;
  }
}

/* Admin Dashboard */
.wp-admin h1,
.wp-admin h2,
.wp-admin h3,
.wp-admin h4,
.wp-admin h5,
.wp-admin h6,
.wp-admin p {
  font-size: inherit;
  font-weight: inherit;
  margin: inherit;
}

.wp-block-group.is-style-full-width .block-editor-block-list__layout .block-editor-block-list__block,
.wp-block-group.is-style-wider-width .block-editor-block-list__layout .block-editor-block-list__block {
  max-width: 100%;
}

.block-editor-block-list__layout .block-editor-block-list__block.wp-block-list-item {
  display: flex;
  margin-left: 0;
}