// <weight>: Use a value from 400 to 900
// <uniquifier>: Use a unique and descriptive class name
/* .besley-font-fam {
  font-family: "Besley", serif;
  font-optical-sizing: auto;
  font-weight: <weight>;
  font-style: normal;
} */

*, *:after, *:before {
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
}

/* —————————————————————————————————————————————————— */
/* BASE */

:root {
    --bgBrown: rgba(112,55,2,1);
    --bgOffWhite: rgba(249, 248, 247, 1);
    --bgTrans: transparent;
    --bgWhite: rgba(255,255,255,1);
    --fgBlack: rgba(112,55,2,1);
    --fgBlackLight: rgba(112,55,2,.2);
    --fgWhite: rgba(255,255,255,1);
    --fgBlack: rgba(0,0,0,1);
    --fgYellow: #f7d47c;
    --fillBrown: rgba(112,55,2,1);
    --fillWhite: rgba(255,255,255,1);
    --fillTrans: transparent;

    --strokeBrown: rgba(112,55,2,1);
    --strokeWhite: rgba(255,255,255,1);
    --fillTrans: transparent;

    --nav-max: 1512px;
    --nav-pad-x: 32px;
    --nav-pad-y: 24px;

    --pill-radius: 999px;
    --pill-pad-y: 8px;
    --pill-pad-x: 14px;
    --pill-font-size: 14px;

    --pill-bg: #f2f2f2;		/* default gray */
    --pill-text: #111;

    --pill-home: #f2f2f2;
    --pill-about: #fbf2d7;		/* warm/yellow */
    --pill-offerings: #f6d7ad;	/* deeper warm */
    --pill-vision: #e7ecff;		/* cool/lavender */
    --pill-journal: #ecdeff;

    --focus: #2f6dff;
}

html {
  font-size: 10px;
}

body {
    background: var(--bgWhite);
    color: var(--fgBlack);
    font-family: "Besley", Times, serif;
    margin: 0;
    padding: 0;
    width: 100%;
    height: auto;

    text-rendering: optimizeLegibility;
    -webkit-font-smoothing: antialiased;
    font-smoothing: antialiased;
}

/* —————————————————————————————————————————————————— */
/* TYPOGRAPHY */

p {
    font-size: 3rem;
    line-height: 1.2;
    /* margin-bottom: 0;
    text-indent: 4rem; */
}

p sub {
    font-family: "Besley", Times, serif;
    font-size: 2rem;
    line-height: 1;
    position: relative;
    vertical-align: baseline;
}

.session p,
.post-desc p,
.event p {
    font-family: "Besley", Times, serif;
    font-size: 2.2rem;
}

.single .entry p {
    font-family: "Besley", Times, serif;
    font-size: 2.2rem;
    line-height: 1.2;
}

.footer p {
    text-indent: 0;
    font-family: "Besley", Times, serif;
    font-size: 2.2rem;
}

.entry ul li, .entry ol li {
    font-size: 2.2rem;
    line-height: 1.2;
}

.entry ol {
    margin: 0;
    padding: 0;
}

.single h1+p, h2+p, h3+p, .entry blockquote+p, .entry ul+p, .entry p:first-child {
    text-indent: 0;
}

p strong {
    font-family: 'texgyreheros-bold', arial, sans-serif;
    font-weight: normal;
}

a {
    text-decoration: underline;
    cursor: pointer;
    color: var(--fgBlack);
}

a:hover {
    color: var(--fgBlack);
}

.footer a {
    font-size: 2.2rem;
    line-height: 1.2;
    margin-left: 2rem;
}

h1, h2, h3, h4, h5, h6 {
    font-family: "Besley", serif;
    font-size: 2.2rem;
    line-height: 1.2;
    padding: 1.5rem 0 1rem;
    font-weight: normal;
    display: inline-block;
}

h1, h2 {
  font-size: 5rem;
  margin: 0;
  padding: 0;
}

h1 {
  color: var(--fgBlack);
}

h2 {
  /* color: var(--fgYellow); */
}

.text-col h3 {
  font-family: "Besley", serif;
  font-weight: bold;
  font-size: 2.4rem;
  line-height: 1.2;
  width: 100%;
  text-align: center;
  margin-bottom: 1.5rem;
}

a:focus {
    color: var(--fgBlack);
}

.container-fluid {
    position: relative;
    margin-right: auto;
    margin-left: auto;
    padding: 0;
    background-color: var(--bgOffWhite);
    z-index: 0;
}

.home .container-fluid {
    margin-bottom: calc(100vh - 15rem);
}

@media only screen and (max-width: 767px) {
    .home .container-fluid {
        margin-bottom: 0;
    }
    /* h2.off_screen {
        position: relative;
        left: inherit;
        top: inherit;
        width: auto;
        height: auto;
        overflow: visible;
        padding: 0;
        margin: 0 0 2rem 0;
        text-align: center;
        width: 100%;
        font-weight: normal;
    } */
}

.off_screen {
    position: absolute;
    left: -10000px;
    top: auto;
    width: 1px;
    height: 1px;
    overflow: hidden;
    padding: .5em;
    margin: .5em;
}

.off_screen:focus {
    position: static;
    width: auto;
    height: auto;
}

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

input[type=text]:focus, textarea:focus, a:focus, button:focus, button.js-accordion__header:focus, section:focus, select:focus {
    outline: none !important;
    border-color: transparent;
    box-shadow: white;
}

hr, .wp-block-separator {
    margin-top: 2rem;
    margin-bottom: 0;
    padding: 1rem 0;
    border: 0;
    border-top: 1px solid var(--fgBlack);
    position: relative;
    display: block;
    width: 100%;
    float: left;
}

.single-events hr {
    border-top: 1px solid var(--fgBlackLight);
}


.hero-img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100vh;
    overflow: hidden;
    z-index: 0;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;

    background-repeat: no-repeat;
    background-position: center;

    background-color: var(--bgOffWhite);
}
.hero-img .img {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%,-50%);
    z-index: 0;
    width: 100%;
    height: 100%;

    background-position-y: 1%;
    background-position-x: 50%;
    background-size: cover;
    background-repeat: no-repeat;

    filter:blur(20px);
    -webkit-filter: blur(20px);
    -moz-filter: blur(20px);
    -o-filter: blur(20px);
    -ms-filter: blur(20px);
    opacity: .2;
    -webkit-transition: all 4s ease-out;
    -moz-transition: all 4s ease-out;
    -o-transition: all 4s ease-out;
    transition: all 4s ease-out;
}

.hero-img img {
    width: 100%;
}

.hero-img:after {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    z-index: 0;
    width: 100%;
    height: 100%;
    -webkit-transition: opacity 5s cubic-bezier(.57,.06,.05,.95);
    transition: opacity 5s cubic-bezier(.57,.06,.05,.95);
    opacity: .1;
    mix-blend-mode: multiply;
    background: transparent;
    background: -webkit-radial-gradient(center,ellipse cover,transparent 47%,#000 100%);
    background: -webkit-radial-gradient(center,ellipse,transparent 47%,#000 100%);
    background: radial-gradient(ellipse at center,transparent 47%,#000 100%);
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr="transparent",endColorstr="#dcdcdc",GradientType=1);
}

.hero-img.active:after {
    opacity: 1;
}

.hero-img.active .img {
    filter:blur(0px);
    -webkit-filter: blur(0px);
    -moz-filter: blur(0px);
    -o-filter: blur(0px);
    -ms-filter: blur(0px);
    opacity: 1;
}

/* —————————————————————————————————————————————————— */
/* HEADER & NAV
   Notes:
   - Keeps your sticky/opacity/stick behavior.
   - Replaces the “5 equal columns” layout with pill links and a left + right grouping.
   - Preserves the useful mobile horizontal-scroll pattern. */

nav.navbar {
  align-items: center;
  background: var(--bgTrans);
  border: none;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: center;
  overflow: hidden;
  padding: 0;
  position: sticky;
  top: -1px;
  width: 100%;
  max-width: 100vw;
  z-index: 10;

  opacity: 0;
  transition: all .5s ease-out;
}

nav.navbar.active {
  opacity: 1;
}

nav.navbar.stick {
  background: var(--bgOffWhite);
}

nav.navbar.active.stick ul > li > a {
  color: var(--fgBlack);
  text-shadow: none;
}

nav.navbar.active.stick ul > li > a:hover {
  color: var(--fgBlack);
}

/* Make the collapse act like a centered container */
nav.navbar > .navbar-collapse {
  width: 100%;
  background: var(--bgTrans);
  padding: var(--nav-pad-y) var(--nav-pad-x);
  max-width: var(--nav-max);
  margin: 0 auto;

  display: flex;
  align-items: center;
  justify-content: space-between;
}

.navbar-collapse.collapse {
  display: none;
  width: 100%;
}

.navbar-collapse.collapse.in {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

/* UL layout (replace the old space-around + 20% columns) */
nav.navbar ul.navbar-nav,
nav.navbar ul#menu-global-menu {
  margin: 0;
  padding: 0;
  list-style: none;

  display: flex;
  align-items: center;
  gap: 10px;

  width: 100%;
}

/* Kill the old 20% width columns */
nav.navbar ul > li {
  float: none;
  width: auto;
  padding: 0;
  display: flex;
}

/* Pill links (new) */
nav.navbar ul > li > a {
  display: inline-flex;
  align-items: center;
  justify-content: center;

  padding: var(--pill-pad-y) var(--pill-pad-x);
  border-radius: var(--pill-radius);

  font-family: "Inter", sans-serif;
  font-optical-sizing: auto;
  font-weight: normal;
  font-style: normal;

  font-size: var(--pill-font-size);
  line-height: 1;
  white-space: nowrap;

  text-decoration: none;
  border-bottom: 0;
  border: 1px solid rgba(0, 0, 0, 0);
  background: var(--pill-gray, #f2f2f2);
  color: var(--fgBlack);

  transition: transform 120ms ease, background-color 120ms ease, box-shadow 120ms ease;
  z-index: 1001;
}

nav.navbar ul > li > a:hover {
  text-decoration: none;
  transform: translateY(-1px);
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.08);
  background-color: inherit;
}

nav.navbar ul > li > a:active {
  transform: translateY(0);
  box-shadow: 0 3px 10px rgba(0, 0, 0, 0.10);
}

/* WP “current” classes */
nav.navbar ul > li.current-menu-item > a,
nav.navbar ul > li.current_page_item > a,
nav.navbar ul > li.active > a {
  /* box-shadow: 0 0 0 2px rgba(0, 0, 0, 0.06) inset; */
  border: 1px solid rgba(0, 0, 0, 0.06);
}

/* Per-item colors using your existing li classes */
nav.navbar ul > li.home-btn > a {
  background: var(--pill-home, #f2f2f2);
}

nav.navbar ul > li.about-btn > a {
  background: var(--pill-about, #fbf2d7);
}

nav.navbar ul > li.offerings-btn > a {
  background: var(--pill-offerings, #f6d7ad);
}

nav.navbar ul > li.journal-btn > a {
  background: var(--pill-journal, #ecdeff);
}

nav.navbar ul > li.vision-btn > a {
  background: var(--pill-vision, #e7ecff);
}

nav.navbar ul > li.connect-btn > a {
  background: var(--pill-home, #f2f2f2);
}

/* Push Journal, Vision + Connect to the right (assumes they are last two items) */
nav.navbar ul > li.journal-btn {
  margin-left: auto;
}

/* Keep your submenu/dropdown rules as-is (they’re fine),
   but ensure they don’t inherit pill spacing weirdly */
nav.navbar ul.sub-menu {
  position: absolute;
  top: 100%;
  left: 0;
  z-index: 1000;
  display: none;
  float: left;
  min-width: 160px;
  padding: 5px 0;
  margin: 2px 0 0;
  font-size: 14px;
  text-align: left;
  list-style: none;
  background-color: #fff;
  background-clip: padding-box;
  border: 1px solid rgba(0, 0, 0, .15);
  border-radius: 4px;
}

nav.navbar ul.sub-menu > li > a {
  display: block;
  padding: 3px 20px;
  clear: both;
  font-weight: 400;
  line-height: 1.42857143;
  color: #333;
  white-space: nowrap;
  background: transparent;
  box-shadow: none;
  transform: none;
  border-radius: 0;
}

.nav-btn {
  display: none;
}

/* —————————————————————————————————————————————————— */
/* MOBILE: keep the horizontal scroll menu you already had,
   but stop inflating link font size to 2.25rem (it breaks the pill look). */

@media only screen and (max-width: 767px) {
     .nav-btn {
       display: flex;
       position: absolute;
       right: 2rem;
       top: 2rem;
       z-index: 1002;
     }

     .navbar-toggle {
       padding: var(--pill-pad-y) var(--pill-pad-x);
        border-radius: var(--pill-radius);
        font-family: "Inter", sans-serif;
        font-optical-sizing: auto;
        font-weight: normal;
        font-style: normal;
        font-size: var(--pill-font-size);
        line-height: 1;
        white-space: nowrap;
        text-decoration: none;
        border-bottom: 0;
        border: 1px solid rgba(0, 0, 0, 0);
        background: var(--pill-gray, #f2f2f2);
        color: var(--fgBlack);
        transition: transform 120ms ease, background-color 120ms ease, box-shadow 120ms ease;
     }

     .close-txt {
       display: none;
     }

     nav.navbar {
       min-height: 6rem;
       max-width: 100vw;
       overflow: hidden;
     }

     nav.navbar > .navbar-collapse {
       display: none;
       padding: 7rem 2rem 2rem;
       max-width: none;
       width: 100%;
     }

     nav.navbar > .navbar-collapse.in {
       display: flex;
       flex-direction: column;
       align-items: stretch;
       justify-content: center;
       height: 100svh;
       padding: 0;

       background: rgba(255,255,255,.7);
       -webkit-backdrop-filter: blur(20px);
       backdrop-filter: blur(20px);
     }

     nav.navbar ul.navbar-nav,
     nav.navbar ul#menu-global-menu {
       flex-direction: column;
       align-items: center;
       gap: 12px;
       width: 100%;
       padding: 0;
     }

     nav.navbar ul > li {
       width: auto;
     }

     nav.navbar ul > li.journal-btn {
       margin-left: 0;
     }

     nav.navbar ul > li > a {
       width: 100%;
       justify-content: flex-start;
       font-size: 2.6rem;
     }
   }

/* —————————————————————————————————————————————————— */
/* HEADER & NAV */

header {
    position: relative;
    background: transparent;
}

.super-hero {
  position: relative;
  width: 100%;
  min-height: 200svh;
  margin: 0;
  padding: 0;
}

.child-hero {
  min-height: 200svh;
}

.hero {
    position: relative;
    height: calc(100vh - 1.875rem);
}

.btn.scroll-to {
  font-family: "Inter", sans-serif;

  position: absolute;
  top: 92vh;
  left: 50%;
  transform: translate(-50%,0px);
  z-index: 2;

  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: var(--pill-pad-y) var(--pill-pad-x);
  border-radius: var(--pill-radius);
  font-family: "Inter", sans-serif;
  font-optical-sizing: auto;
  font-weight: normal;
  font-style: normal;
  font-size: var(--pill-font-size);
  line-height: 1;
  white-space: nowrap;
  text-decoration: none;
  border-bottom: 0;
  background: rgba(255,255,255,.8);
  color: var(--fgBlack);
  transition: transform 120ms ease, background-color 120ms ease, box-shadow 120ms ease;
}

.third {
  opacity: 0;
  visibility: hidden;
  transition: all 1.5s ease-out !important;
}

.third.loaded {
  opacity: 1;
  visibility: visible;
}

.btn.scroll-to:hover {
    text-decoration: none;
    transform: translate(-50%,-1px) !important;
    box-shadow: 0 6px 18px rgba(0, 0, 0, 0.08);
    background: rgba(255,255,255,1);
}

.header-wrapper {
  display: flex;
  flex-flow: column nowrap;
  justify-content: center;
  align-items: center;
}

header h1 {
    font-family: "Besley", Times, serif;
    font-weight: normal;
    font-size: 5.2rem;
    line-height: 1;
    padding: .875rem;
    margin: 0;
    text-align: center;
    position: relative;
    z-index: 1;
}

header h1 .ellipsis {
    letter-spacing: -4px;
}

header h1 .line-break {
    display: block;
}

header.fixed {
    position: fixed;
    top: 0;
    right: 0;
    left: 0;
    z-index: 1060;
    background: var(--bgTrans);
}

.page-i-remember-that-day-well header.fixed {
  z-index: 5;
}

header h1, header .header-logo .wordmark, header .header-contact, nav.nav ul>li>a {
    /* color: var(--fgWhite); */
    color: var(--fgBlack);
}

header .header-logo:hover, header .header-contact:hover {
    color: var(--fgWhite);
    text-decoration: underline;
    border: none;
}

@media only screen and (max-width: 767px) {
  header.fixed {
    z-index: 2001;
  }
  .page-i-remember-that-day-well .front > section:not(#hero) > .header-wrapper {
    margin-bottom: 0;
  }
}

/* —————————————————————————————————————————————————— */
/* GENERAL */

input:focus::-webkit-input-placeholder {
    color: transparent;
}

input:focus:-moz-placeholder {
    color: transparent;
}

/* Firefox 18- */
input:focus::-moz-placeholder {
    color: transparent;
}

/* Firefox 19+ */
input:focus:-ms-input-placeholder {
    color: transparent;
}

/* oldIE ;) */
.affix {
    position: fixed;
    top: 0;
    right: 0;
    left: 0;
    z-index: 1060;
    background: white;
}

/* —————————————————————————————————————————————————— */
/* GRID */

.two-col {
  display: grid;
  gap: 1rem;
  grid-template-columns: 1fr;
  align-items: start;
  padding-block: 2rem;

  grid-template-columns: repeat(4, 1fr);
  padding: 2rem 1rem;
}

.one-col {
  display: grid;
  gap: 1rem;
  padding: 2rem 1rem;
}

.one-col > .single-col {
  width: min(50%, 720px);
  justify-self: center;
}

/* Sticky image column inside your 2-col grid */
.two-col {
  align-items: start;
}

/* Make the whole column sticky */
.two-col .img-col {
  position: sticky;
  top: 8rem;
  align-self: start;
  z-index: 2;
}

.front .about > .two-col {
  padding-top: 0 !important;
}

/* If you want the image itself to be what sticks, do this instead:
.two-col .img-col .image-wrapper {
  position: sticky;
  top: 2rem;
}
*/

.single-col {
  grid-column: span 2;
}

.col-1 {
    width: 14.285714285714286%;
}

.col-2 {
    width: 28.571428571428572%;
}

.col-3 {
    width: 42.857142857142857%;
}

.col-33 {
    width: 33%;
}

.col-4 {
    width: 57.142857142857144%;
}

.col-5 {
    width: 71.42857142857143%;
    padding-left: 1.5em;
}

.col-50 {
    width: 50%;
}

.col-5 {
    width: calc(71% - 2.5em);
    position: relative;
    display: block;
    float: left;
}

.col-6 {
    width: 85.714285714285716%;
}

.col-100 {
    width: 100%;
}

@media only screen and (max-width: 767px) {
  .two-col {
    grid-template-columns: 1fr;
  }
  .col-3, .col-4 {
      width: 100%;
  }
  .col-33 {
      width: 100%;
  }
  .two-col .img-col {
    position: relative;
    top: inherit;
  }
  .one-col > .single-col {
    width: min(90%, 720px);
  }
}

.image-wrapper {
    min-height: 20rem;
    height: calc(100svh - 11rem);
    width: 80%;
    margin: 0 auto;
    border-radius: 4rem;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}


.bkg-image {
    height: 100%;
    width: 100%;
    background-attachment: fixed;
    background-repeat: no-repeat;
    background-size: cover;
    background-position: 50% 50%;
    background-color: black;
}

.dt {
    display: inline-block;
}

.mo {
    display: none;
}

@media only screen and (max-width: 767px) {
    .dt {
        display: none;
    }

    .mo {
        display: flex;
    }
    .entry ol li {
        margin: 0 0 0 2.5rem;
    }
    h1, h2, h3, h4, h5, h6, p, .entry ul li, .footer a, .entry ol li, .musings-posts li p, .session p, .post-desc p, .event p, .event-header-wrapper .date-wrapper time, .single .entry p, .single .entry p strong, .footer p, .super-hero .with, .child-hero .with {
        font-size: 1.675rem !important;
    }
    h1, .super-hero .with, .child-hero .with {
      font-size: 2.5rem !important;
    }
    p sub {
        font-size: 1.375rem;
    }
    p {
        font-size: 1.875rem;
    }
    .image-wrapper {
      min-height: 20rem;
      height: calc(70svh - 11rem);
      width: calc(100% - 4rem);
      padding: 2rem;
    }
}

/* —————————————————————————————————————————————————— */
/* HOME */

/* section {
    min-height: 100vh;
    width: 100%;
    position: relative;
    z-index: 0;
    padding: 10rem 3rem 0;

    display: flex;
} */

@media only screen and (max-width: 767px) {
    section {
        padding: 4rem 2rem 0;
        min-height: 90vh;
    }
    section.events {
        min-height: initial;
    }
    section.mobile-h1 {
        padding: 2rem 2rem 0;
        min-height: initial;
        justify-content: center;
    }
    section.mobile-h1 h1 {
        letter-spacing: -.25px;
    }
    .img-caption {
        display: none;
    }
    section h2.off_screen {
        opacity: 1;
        -webkit-transition: all .2s ease;
        -o-transition: all .2s ease;
        transition: all .2s ease;
    }
    section:focus h2.off_screen {
        opacity: 0;
    }
    /* .line-break {
        display: block;
    } */
}

/* —————————————————————————————————————————————————— */
/* INVITATION */

.invitation {
    flex-direction: column;
    flex-wrap: nowrap;
}

.row {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    margin: 0;
}

.invitation .row {
    padding-bottom: 10rem;
}

.img-caption, .swiper-pagination {
    font-size: 1.6rem;
    padding: .5rem 0;
    text-align: left;
    align-self: flex-start;
    text-indent: 0;
}

.img-caption {
    opacity: 0;
}

.play-button {
    -webkit-appearance: none;
    background: transparent;
    border: none;
    cursor: pointer;
    line-height: normal;
    margin: 0;
    margin-top: -6rem;
    padding: 0;
    width: auto;
    -webkit-appearance: button;
    font-size: 2rem;
    font-style: normal;
    opacity: .9;
    overflow: visible;
    transition: opacity .3s linear 0s;
}

.player-fixed {
    position: fixed;
    bottom: 2rem;
    right: 2rem;
}

.play-button-inner {
     align-items: center;
     display: flex;
     overflow: visible;
     flex-direction: row;
}

.play-button-icon {
     height: 53px;
     min-width: 53px;
     transition: transform .3s ease-in-out 0s;
     width: 53px;
     margin-right: 14px;
}

.play-button-icon-play, .play-button-pause-path {
    fill: var(    --fgBlack);
}

.play-button-pause-path {
    display: none;
    transform: scale(.7);
    transform-origin: center;
}

.playing .play-button-icon-play {
    display: none;
}

.playing .play-button-pause-path {
    display: block;
}

.play-button-icon-circle {
    stroke: var(    --fgBlack);
    opacity: .2;
    transition: opacity .3s linear 0s;
}

.play-button-icon-progress {
    display: none;
}

.play-button-text {
     align-items: flex-start;
     display: flex;
     flex-direction: column;
     transition: opacity .3s linear 0s;
}

.play-button-title {
    text-transform: uppercase;
}

.play-button-subtitle {
    text-align: left;
}

.play-button:hover .play-button-icon {
    transform: scale(1.1);
}

.play-button:hover .play-button-icon-circle {
    opacity: 1;
}

@media only screen and (max-width: 767px) {
    .invitation .row {
        flex-direction: column;
        padding-bottom: 4rem;
    }
    .play-button {
        margin: 4rem 0;
        font-size: 1.675rem;
    }
}



.embed-container {
    min-height: 100vh;
    max-height: 100vh;
    width: 100%;
    object-fit: contain;
    position: relative;
    overflow: hidden;
}

.embed-container iframe {
    min-height: 165%;
    width: 100%;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

.footer-video .embed-container iframe {
    min-height: 120%;
    width: 110%;
}

@media only screen and (max-width: 767px) {
    .embed-container {
        min-height: 70vh;
    }
}

.animate-fade {
    -webkit-animation: fadeIn 0.125s ease forwards;
    animation: fadeIn 0.125s ease forwards;
}

@-webkit-keyframes fadeIn {
    0% {}

    100% {
        opacity: 1;
    }
}

@keyframes fadeIn {
    0% {}

    100% {
        opacity: 1;
    }
}

/* images with captions */
.wp-caption {
    /* Force the box to be 100% */
    width: 100% !important;
}

/* —————————————————————————————————————————————————— */
/* ABOUT */

.front > section.about {
  padding-bottom: 12rem !important;
}

.single-col.text-col {
  padding-right: 2rem;
}

/* —————————————————————————————————————————————————— */
/* REMEMBER */

.front > section.remember:not(#hero) {
  display: flex;
  flex-flow: column nowrap;
  padding: 2rem;
  min-height: initial;
}

.big-remember {
  min-height: 20rem;
  height: calc(100svh - 4rem);
  width: 100%;
  margin: 0;
  padding: 0;
  padding-top: 0 !important;
  border-radius: 4rem;
  background-size: 100% 100%;
  background-position: center;
  background-repeat: no-repeat;
  text-align: center;

  display: flex;
  flex-flow: column nowrap;
  justify-content: center;
  align-items: center;

  text-decoration: none;
}

.big-remember {
  position: relative;
  overflow: hidden;
  border-radius: 4rem; /* keep your rounding on the clipping parent */
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

.big-remember::before {
  content: "";
  position: absolute;
  inset: 0;
  background: inherit;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  transform: translateY(0) scale(1);
  transition: transform 2000ms ease;
  will-change: transform;
  z-index: 0;
}

.big-remember:hover::before,
.big-remember:focus-visible::before {
  transform: translateY(-4%) scale(1.03);
}

.big-remember .big-message {
  position: relative;
  z-index: 1;
}

.big-remember .text-message {
  color: var(--fgWhite);
  font-size: 5rem;
  display: block;
  margin-bottom: .5rem;
}

.message-btn {
  z-index: 2;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: var(--pill-pad-y) var(--pill-pad-x);
  border-radius: var(--pill-radius);
  font-family: "Inter", sans-serif;
  font-optical-sizing: auto;
  font-weight: normal;
  font-style: normal;
  font-size: var(--pill-font-size);
  line-height: 1;
  white-space: nowrap;
  text-decoration: none;
  border-bottom: 0;
  background: rgba(255, 255, 255, .8);
  color: var(--fgBlack);
  transition: transform 120ms ease, background-color 120ms ease, box-shadow 120ms ease;
}

.message-btn:hover {
  background: rgba(255, 255, 255, 1);
}

.one-col > .single-img-col {
    width: min(60%, 920px);
    justify-self: center;
    grid-column: span 2;
}

.body-image {
    min-height: 20rem;
    height: calc(100svh - 4rem);
    width: 100%;
    margin: 0;
    padding: 0;
    padding-top: 0 !important;
    border-radius: 4rem;
    background-size: 100% 100%;
    background-position: center;
    background-repeat: no-repeat;
    text-align: center;
    display: flex;
    flex-flow: column nowrap;
    justify-content: center;
    align-items: center;
    text-decoration: none;
}

.body-image {
    position: relative;
    overflow: hidden;
    border-radius: 4rem;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}

@media only screen and (max-width: 767px) {
  .big-remember {
    min-height: 20rem;
    height: calc(90svh - 4rem);
  }
  .big-remember .text-message {
    font-size: 2.875rem;
    line-height: 1;
  }
  .page-template-page-vision .big-remember {
    height: calc(70svh - 4rem);
  }
  .body-image {
    height: calc(40svh - 4rem);
  }
  .one-col > .single-img-col {
    width: min(90%, 920px);
  }
}

/* —————————————————————————————————————————————————— */
/* VISION */

.page-template-page-vision .big-remember {
  border-radius: 50rem;
}

.page-template-page-vision .one-col h2 {
  margin-bottom: 3rem;
  line-height: 1;
  text-align: center;
  width: 100%;
}

/* .page-template-page-vision .one-col h3 {
  font-size: 5rem;
  margin: 0;
  margin-bottom: 3rem;
  line-height: 1;
  padding: 0;
  text-align: center;
  font-weight: normal;
} */

/* —————————————————————————————————————————————————— */
/* JOURNAL */

section.journal,
.front > section.journal:not(#hero) {
  padding: 2rem 2rem 10rem;
}

section.journal ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

section.journal li {
  width: 80%;
  padding: 2rem;
  margin: 0 auto;
}

section.journal .journal-link {
  display: grid;
  grid-template-columns: 440px 1fr;
  grid-template-rows: auto auto;
  gap: 2.5rem 4rem;
  align-items: center;

  padding: 3rem 4rem;
  border-radius: 5rem;
  background: var(--fgWhite);
  text-decoration: none;

  position: relative;
  overflow: hidden;
}

/* top-right arrow icon */
/* section.journal .journal-link::after {
  content: "";
  position: absolute;
  top: 4rem;
  right: 4rem;

  width: 2rem;
  height: 2rem;

  background-color: var(--fgBlack);
  opacity: .85;

  -webkit-mask-image: url("../images/arrow-up-right.svg");
  -webkit-mask-repeat: no-repeat;
  -webkit-mask-position: center;
  -webkit-mask-size: contain;

  mask-image: url("../images/arrow-up-right.svg");
  mask-repeat: no-repeat;
  mask-position: center;
  mask-size: contain;

  pointer-events: none;
} */

section.journal .journal-link img {
  grid-column: 1;
  grid-row: 1 / span 2;

  width: 100%;
  height: 260px;
  object-fit: cover;

  border-radius: 2.2rem;
  display: block;
}

section.journal .journal-link .link-title {
  grid-column: 2;
  grid-row: 1;

  font-family: "Besley", serif;
  font-size: 3.1rem;
  line-height: 1.25;
  letter-spacing: -0.01em;

  color: var(--fgBlack);
  max-width: 90%;
}

section.journal .journal-link .context {
  grid-column: 2;
  grid-row: 2;

  justify-self: start;
  margin-top: 1rem;
}

/* hover/focus */
section.journal .journal-link:hover,
section.journal .journal-link:focus-visible {
  transform: translateY(-1px);
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.08);
}

/* keep your .context hover behavior intact; just make it feel clickable */
section.journal .journal-link:hover .context,
section.journal .journal-link:focus-visible .context {
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.08);
  transform: translateY(-1px);
}

/* responsive */
@media only screen and (max-width: 1024px) {
  section.journal .journal-link {
    grid-template-columns: 420px 1fr;
    border-radius: 4rem;
    padding: 4rem;
  }

  section.journal .journal-link::after {
    top: 3rem;
    right: 3rem;
  }

  section.journal .journal-link .link-title {
    font-size: 4.2rem;
    max-width: 28ch;
  }
}

@media only screen and (max-width: 767px) {
  section.journal {
    padding: 2rem;
  }
  section.journal li {
    width: 100%;
    margin: 0 0 2rem;
    padding: 0;
  }
  section.journal .journal-link {
    grid-template-columns: 1fr;
    grid-template-rows: auto auto auto;
    gap: 2rem;

    padding: 2.5rem;
    border-radius: 3rem;
  }

  section.journal .journal-link::after {
    top: 2rem;
    right: 2rem;
    font-size: 2.4rem;
  }

  section.journal .journal-link img {
    grid-column: 1;
    grid-row: 1;
    height: 210px;
    border-radius: 2rem;
  }

  section.journal .journal-link .link-title {
    grid-column: 1;
    grid-row: 2;
    font-size: 3rem;
    line-height: 1.12;
    max-width: none;
  }

  section.journal .journal-link .context {
    grid-column: 1;
    grid-row: 3;
  }
}

.context {
    z-index: 2;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: var(--pill-pad-y) var(--pill-pad-x);
    border-radius: var(--pill-radius);
    font-family: "Inter", sans-serif;
    font-optical-sizing: auto;
    font-weight: normal;
    font-style: normal;
    font-size: var(--pill-font-size);
    line-height: 1;
    white-space: nowrap;
    text-decoration: none;
    border-bottom: 0;
    background: rgba(255, 255, 255, .8);
    border: 1px solid black;
    color: var(--fgBlack);
    transition: transform 120ms ease, background-color 120ms ease, box-shadow 120ms ease;
}


/* —————————————————————————————————————————————————— */
/* OFFERINGS */

.front > section.offerings:not(#hero) {
  padding: 2rem 0 6rem;
}

section.offerings ul {
  list-style: none;
  margin: 0;
  padding: 0 10% !important;
}

section.offerings li {
  position: relative;
  background: #fff;
  border-radius: 4.5rem;
  padding: 3.5rem 4rem 2.5rem;
  position: relative;
  overflow: hidden;
  margin-bottom: 4rem;
}

section.offerings li:hover {
    transform: translateY(-1px);
    box-shadow: 0 10px 24px rgba(0, 0, 0, 0.08);
}

/* header */
section.offerings .offering-header {
  text-align: center;
  font-family: "Besley", serif;
  font-size: 4rem;
  line-height: 1.05;
  letter-spacing: -0.01em;
  color: var(--fgBlack);

  display: flex;
  flex-flow: column nowrap;
  align-items: center;
}

section.offerings .offering-subheader {
  display: block;
  margin-top: 1.75rem;
  max-width: 30ch;

  font-family: "Inter", sans-serif;
  font-size: 2.4rem;
  line-height: 1.2;
  letter-spacing: 0;
  opacity: .9;
}

/* body columns */
section.offerings .two-col {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 5rem;
  align-items: start;

  margin-top: 4.5rem;
}

/* OFFERINGS grid fix: stop global .single-col spanning */
section.offerings .two-col > .single-col {
  grid-column: auto;
}

/* be explicit (optional but clearer) */
section.offerings .two-col > .orb-col {
  grid-column: 1;
}

section.offerings .two-col > .text-col {
  grid-column: 2;
}

/* orb column */
section.offerings .orb-col {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 480px;
}

section.offerings .orb-col .orbs {
  position: relative;
  pointer-events: none;
}

section.offerings .orb-col .orbs:not(.orbs--mini) .orb {
  position: absolute;
  inset: 0;
  border-radius: 9999px;
  filter: blur(28px);
  opacity: .95;
  transform: translateZ(0);
}

/* text column */
section.offerings .text-col {
  max-width: 55ch;
}

section.offerings .text-col p {
  font-family: "Besley", serif;
  font-size: 2.4rem;
  line-height: 1.25;
  margin: 0;
  color: var(--fgBlack);
}

section.offerings .text-col p + p {
  margin-top: 2.75rem;
}

/* footer buttons */
section.offerings .offering-footer {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 2.5rem;

  margin: 2rem 0 4rem;
}

section.offerings .offering-footer .incl-toggle,
section.offerings .offering-footer .big-button {
  font-family: "Inter", sans-serif;
  appearance: none;
  background: transparent;
  border: 1px solid rgba(0, 0, 0, 0.75);
  color: var(--fgBlack);
  border-radius: 9999px;

  padding: 1.5rem 3.25rem;
  font-size: 3.2rem;
  line-height: 1;
  letter-spacing: -0.01em;

  cursor: pointer;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;

  transition: transform .15s ease, box-shadow .15s ease, background-color .15s ease;
}

section.offerings .offering-footer .incl-toggle:hover,
section.offerings .offering-footer .big-button:hover {
  transform: translateY(-1px);
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.08);
}

#medium-reading,
#reading-healing,
#speaking-engagements {
  scroll-margin-top: 60px;
}

/* responsive */
@media only screen and (max-width: 1024px) {
  section.offerings li {
    border-radius: 3.5rem;
    padding: 4.5rem 4rem 4rem;
  }

  section.offerings .offering-header {
    font-size: 5rem;
  }

  section.offerings .two-col {
    grid-template-columns: 340px 1fr;
    gap: 3.5rem;
  }

  section.offerings .orb-col {
    min-height: 420px;
  }

  section.offerings .text-col p {
    font-size: 2.25rem;
  }
}

@media only screen and (max-width: 767px) {
  section.offerings {
    padding: 2rem;
  }
  section.offerings ul {
    padding: 0 2rem !important;
  }
  section.offerings li {
    padding: 3rem .5rem 3rem;
    border-radius: 3rem;
  }

  section.offerings .offering-header {
    font-size: 2.675rem;
  }

  section.offerings .offering-subheader,
  section.offerings .offering-modal li {
    font-size: 2rem;
  }

  section.offerings .two-col {
    grid-template-columns: 1fr;
    gap: 2.5rem;
    margin-top: 3rem;
  }

  section.offerings .two-col > .orb-col,
  section.offerings .two-col > .text-col {
    grid-column: auto;
  }

  section.offerings .orb-col {
    min-height: 0;
  }

  section.offerings .orb-col .orbs {
    margin: 0 auto;
  }

  section.offerings .text-col {
    max-width: none;
  }

  section.offerings .text-col p {
    font-size: 2.05rem;
  }

  section.offerings .offering-footer {
    flex-direction: column;
    align-items: center;
    gap: 1.5rem;
    margin-top: 3rem;
  }

  section.offerings .offering-footer .incl-toggle,
  section.offerings .offering-footer .big-button,
  section.offerings .offering-modal .big-button,
  .close-offering {
    width: auto;
    max-width: 420px;
    align-self: center;

    font-size: 1.6rem;
    padding: 1.35rem 2.5rem;
  }

}

/* —————————————————————————————————————————————————— */
/* OFFERING MODAL */

.offering-modal {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 3001;
  width: 100%;
  height: 100%;

  display: none;
  flex-flow: column nowrap;
  justify-content: flex-end;

  background: rgba(255,255,255,.7);
  -webkit-backdrop-filter: blur(20px);
  backdrop-filter: blur(20px);
}

.offering-modal.is-open {
  display: flex;
}


.offering-modal-wrapper {
  width: min(100%, 72rem);
  margin: 0 auto;
  padding: 10rem;
}

.offering-modal .offering-subheader {
  width: 100%;
    display: block;
    margin-top: 1.75rem;
    max-width: 30ch;
    font-family: "Inter", sans-serif;
    font-size: 2.4rem;
    line-height: 1.2;
    letter-spacing: 0;
    opacity: .9;
    text-align: center;
    margin: 0 auto 2rem;
}

section.offerings .offering-modal li {
  overflow: visible;
  background: transparent;
  border-radius: 0;
  padding: 0;
  margin-bottom: 0;

  font-family: "Besley", serif;
  font-size: 2.4rem;
  line-height: 1.25;
  margin: 0;
  color: var(--fgBlack);

  list-style: initial;
}

section.offerings .offering-modal li:hover {
    transform: translateY(0);
    box-shadow: none;
}

section.offerings .offering-modal .big-button {
    font-family: "Inter", sans-serif;
    appearance: none;
    background: transparent;
    border: 1px solid rgba(0, 0, 0, 0.75);
    color: var(--fgBlack);
    border-radius: 9999px;
    padding: 1.5rem 3.25rem;
    margin: 1rem auto;
    font-size: 3.2rem;
    line-height: 1;
    letter-spacing: -0.01em;
    cursor: pointer;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: transform .15s ease, box-shadow .15s ease, background-color .15s ease;
}

section.offerings .offering-modal .big-button:hover {
    transform: translateY(-1px);
    box-shadow: 0 10px 24px rgba(0, 0, 0, 0.08);
}

.close-offering {
    position: absolute;
    bottom: 7rem;
    left: 50%;
    transform: translateX(-50%);
    /* border: 1px solid black; */
    border: none;
    border-radius: 50%;

    padding: 1.5rem 1.75rem;

    background: transparent;
    z-index: 2;
    cursor: pointer;

    display: flex;
    flex-flow: column nowrap;
    justify-content: center;
}

.close-offering:hover {
  transform: translate(-50%, -1px);
    box-shadow: 0 10px 24px rgba(0, 0, 0, 0.08);
}

@media only screen and (max-width: 767px) {
  .offering-modal-wrapper {
    width: min(88%, 72rem);
    padding: 10rem 2rem;
  }
  section.offerings .offering-modal li {
    font-size: 2rem;
  }
  section.offerings .offering-footer .big-button, section.offerings .offering-modal .big-button, .close-offering {
    width: auto;
    max-width: 420px;
    align-self: center;
    font-size: 1.6rem;
    padding: 1.35rem 2.5rem;
  }
}

/* —————————————————————————————————————————————————— */
/* AUDIO */

.gd-bar {
  display:flex;
  align-items:center;
  gap:20px;
  padding:18px 28px;
  border-radius:999px;
  /* background: linear-gradient(90deg, #24ff2d, #9eff8f, #f5f39c, #ffe7b5); */
  background: rgba(255,255,255,.875);
  -webkit-backdrop-filter: blur(20px);
  backdrop-filter: blur(20px);
  background-size:400% 400%;
  /* box-shadow:0 4px 22px rgba(0,0,0,0.25); */
  width: 50vw;
  max-width:1200px;
  margin:auto;
  margin-top:10px;
}

.gd-bar:hover {
  box-shadow:0 4px 22px rgba(0,0,0,0.25);
}

@keyframes gdBarShift {0%{background-position:0% 50%;}50%{background-position:100% 50%;}100%{background-position:0% 50%;}}

/* MOBILE */
@media(max-width:640px){
  .page-i-remember-that-day-well .front > section:not(#hero) > .header-wrapper, .single-post .front > section:not(#hero) > .header-wrapper {
    top: 1.5rem;
  }
  .remember-text .header-wrapper {
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: stretch;
    gap: 2rem;
  }
  .gd-bar {
    width: 88%;
    margin-top: 3rem;
    gap: 1rem;
  }
  .gd-times {
    display: none !important;
  }
  .gd-bar { flex-wrap:wrap; padding:16px 20px; }
  .gd-meta { flex-basis:100%; order:3; margin-top:1px; text-align:left; padding-right: .5rem; }
  .gd-times { flex-basis:100%; order:4; display:flex; justify-content:flex-start; gap:12px; font-size:12px; margin-top:8px; }
}

.gd-toggle {
  position:relative; width:64px; height:64px;
  background:#000; border-radius:50%; border:none; cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  outline:none;
}
.gd-toggle:hover { transform:scale(1.08); transition:transform 0.25s cubic-bezier(0.22,1,0.36,1); }
.gd-toggle:focus-visible {
  outline:3px solid #fff;
  outline-offset:4px; /* Material-ish */
}

.gd-play { width:0;height:0;border-top:12px solid transparent;border-bottom:12px solid transparent;border-left:20px solid #fff;margin-left:4px; }
.gd-pause { display:flex; gap:6px; }
.gd-pause div { width:6px; height:24px; background:#fff; }

.gd-ring circle { transition: stroke-dashoffset 0.25s linear; }

.gd-meta { display:flex; flex-direction:column; line-height:1.2; flex:1; min-width:0; font-family: "Inter", sans-serif;font-size: var(--pill-font-size); }
.gd-title { color:#000; font-size:16px; font-weight:600; }
.gd-subtitle { font-size:13px; color:rgba(0,0,0,0.75); margin-top:2px; }

.gd-times { display:flex; gap:14px; font-size:13px; color:#000; font-family: "Inter", sans-serif;font-size: var(--pill-font-size);}
.gd-times .gd-duration { opacity:0.7; }


/* —————————————————————————————————————————————————— */
/* SLIDER */

.swiper, .swiper2 {
    position: relative;
    width: 100%;
    height: 100%;
}

.swiper2 {
    padding: 10rem 0 0;
    overflow-x: hidden;
}

.about-us .swiper .swiper-button-prev, .about-us .swiper .swiper-button-next {
    display: none;
}

.about-us .swiper .swiper-pagination.swiper-pagination-fraction.swiper-pagination-horizontal {
    padding: 0;
}

.swiper .swiper-slide {
    text-align: center;
    background: transparent;
    display: flex;
    justify-content: center;
    align-items: center;
    border-radius: 2rem;
    overflow: hidden;
    padding: 0 0 2.5rem 0;

    width: 100%;
    height: 100vh;
    max-height: 100vh;
    max-height: calc(100vh - 12rem);
    overflow: hidden;
    background-size: 100%;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    -o-background-size: cover;
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center center;
    border-radius: 2rem;
    overflow: hidden;
}

.swiper-wrapper {
    padding-bottom: 3rem;
    max-height: calc(100vh - 2rem);
}

.swiper2 .swiper-slide {
    text-align: center;
    background: transparent;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    padding: 0 0 2rem 0;

    width: 100%;
    height: 100vh;
    max-height: 100vh;
    max-height: calc(100vh - 2rem);
    overflow: hidden;
    background-size: 100%;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    -o-background-size: cover;
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center center;
}

.swiper-pagination.swiper-pagination-fraction.swiper-pagination-horizontal {
    bottom: 0;
}

.swiper-slide img {
    display: block;
    width: 100%;
    height: 100%;
    max-height: calc(100vh - 12rem);

    object-fit: cover;

    border-radius: 2rem;
    overflow: hidden;
}

.swiper2 .swiper-slide img {
    display: block;
    width: 100%;
    height: 100%;
    max-height: calc(100vh - 2rem);

    object-fit: cover;

    border-radius: 0;
    overflow: hidden;
}

.swiper2 .swiper-pagination {
    width: auto;
    /* left: calc(100% - 5rem); */
    left: 50%;
    transform: translateX(-50%);
    /* padding-bottom: 2.5rem; */
    min-width: 5rem;
    text-align: right;
}

.swiper2 .swiper-button-prev, .swiper2 .swiper-button-next {
    color: var(--bgOffWhite);
}

@media only screen and (max-width: 767px) {
    .swiper2 .swiper-button-prev, .swiper2 .swiper-button-next {
        display: none;
    }
    .swiper .swiper-slide {
        max-height: 70vh;
    }
    .swiper2 {
        padding: 2rem 0 0;
    }
    .swiper2 .swiper-slide {
        max-height: calc(60vw - 2rem);
    }
    .swiper2 .swiper-pagination {
        text-align: center;
    }
}

/* —————————————————————————————————————————————————— */
/* SESSIONS */



/* —————————————————————————————————————————————————— */
/* MAILCHIMP */

.wpcf7-checkbox label {
    display: flex;
    flex-direction: row;
    justify-content: flex-start;
    font-size: 2.2rem;
    font-weight: normal;
}

.wpcf7-checkbox label input {
    width: auto;
    width: 20px;
    height: 20px;
    margin-right: 1rem;
    border-radius: 50%;
    transition: box-shadow .3s;
    background: lightgrey;
    cursor: pointer;
    border: 0;
    appearance: none;
    -webkit-appearance: none;
}

.wpcf7-checkbox label input:hover,
.wpcf7-checkbox label input:checked,
.wpcf7-checkbox label input:focus {
    box-shadow: inset 0 0 0 20px var(--fgBlack);
}

.wpcf7-checkbox .wpcf7-list-item {
    display: flex;
    flex-direction: column;
    margin: 0;
}

.mc-field-group {
    margin-bottom: 2rem;
}

.mc-field-group label {
    display: flex;
    flex-direction: row;
}

#mc_embed_signup form input[type="submit"] {
    padding: 1rem 2rem 1rem;
}

@media only screen and (max-width: 767px) {
    .wpcf7-checkbox label input {
        width: 14px;
        height: 14px;
    }
    .wpcf7-checkbox label input:hover,
    .wpcf7-checkbox label input:checked,
    .wpcf7-checkbox label input:focus {
        box-shadow: inset 0 0 0 14px var(--fgBlack);
    }
    .session-img-wrapper label {
        font-size: 1.275rem;
        left: 1.25rem;
        top: 1.25rem;
    }
}

/* —————————————————————————————————————————————————— */
/* FORMS */

form input, form textarea, form select {
    width: 100%;
    background: white;
    padding:  0.5rem 1rem 1rem;
    border: 1px solid rgb(204, 197, 185);
    border-radius: .5rem;
    transition: 0.2s;
    font-size: 2.2rem;
    line-height: 1.5;
}

form select {
  padding: 1rem 2rem .875rem 1rem;
}

form input:focus, form input[type=text]:focus, form textarea:focus, form select:focus {
    background: white;
    border: 1px solid black;
    outline: none;
    box-shadow: 0 3px 10px rgb(0 0 0 / 0.2);
}

form label, label {
    display: flex;
    flex-direction: column;
    font-size: 1.6rem;
    font-weight: normal;
}

form .wpcf7-form-control-wrap {
    margin-top: .5rem;
    display: block;
    width: 100%;
}

form .wpcf7-form-control-wrap input {
  width: 100%;
  box-sizing: border-box;
}

form p {
    text-indent: 0;
    margin-bottom: 1.5rem;
}

form input[type="submit"] {
    font-family: "Besley", Times, serif;
    font-size: 2.2rem;
    line-height: 1.2;
    padding: 0.5rem 2rem 1rem;
    width: auto;
    border: 1px solid;
    border-radius: 3rem;
    text-decoration: none;
    margin: 0 auto;
    background: transparent;
}

form input[type="submit"]:hover {
    background: var(--bgBrown);
    color: var(--fgWhite);
    border: 1px solid var(--bgBrown);
    box-shadow: 0 3px 10px rgb(0 0 0 / 0.2);
}

form .wpcf7-response-output {
    font-size: 2.2rem;
    line-height: 1.2;
    text-align: center;
    padding: 3rem 3rem;
    color: var(--fgWhite);
    background: var(--bgBrown);
    border-color: var(--bgBrown) !important;
}

.wpcf7 form.invalid .wpcf7-response-output, .wpcf7 form.unaccepted .wpcf7-response-output, .wpcf7 form.payment-required .wpcf7-response-output {
    border: red;
    background: red;
    color: white;
    font-size: 2.2rem;
    line-height: 1.2;
    margin: 2rem 0.5rem 1rem;
    padding: 3rem 3rem;
    text-align: center;
}

@media only screen and (max-width: 767px) {
    form input, form textarea, form select, form input[type="submit"] {
        font-size: 1.675rem;
    }
    form .wpcf7-form-control-wrap {
      display: flex;
      flex-flow: row nowrap;
    }
    form input, form textarea, form select {
      width: inherit;
    }
}

/* —————————————————————————————————————————————————— */
/* TESTIMONIALS */

.testimonials ul.testimonial-list {
    display: flex;
    flex-direction: column;
    width: 100%;
    padding: 0;
    margin: 0;
}

.testimonials ul li {
    list-style: none;
    background: var(--bgWhite);
    border: 1px solid transparent;
    border-radius: 1.5rem;
    padding: 6rem;
    margin-bottom: 3rem;
    -webkit-transition: all .5s ease-out;
    -moz-transition: all .5s ease-out;
    -o-transition: all .5s ease-out;
    transition: all .5s ease-out;
    border: 1px solid gray;
}

.testimonials ul li:nth-child(even) {
    width: 80%;
    align-self: flex-end;
    margin-right: 1rem;
}

.testimonials ul li:nth-child(odd) {
    width: 80%;
    align-self: flex-start;
    margin-left: 1rem;
}

.testimonials ul li:first-child {
    width: 80%;
    align-self: center;
}

.testimonials ul li .quote {
    font-family: times, serif;
    font-size: 3rem;
    text-indent: -1.25rem;
    margin-bottom: 0;
    padding-bottom: 0;
}

/* .testimonials ul li .quote:first-child:last-child {
    margin-bottom: 0;
    padding-bottom: 0;
} */

.testimonials ul li .quote::before {
    content: '\201c';
}

.testimonials ul li .quote::after {
    content: '\201d';
}

@media only screen and (max-width: 767px) {
    .testimonials {
        flex-direction: column;
        padding: 4rem 2rem;
    }
    .testimonials h2 {
        margin: 0 0 2rem 0;
    }
    .testimonials ul li {
        padding: 3rem;
    }
    .testimonials ul li .quote {
        font-size: 2.125rem;
        line-height: 1.1;
    }
    .testimonials ul li:nth-child(even) {
        width: 80%;
        align-self: flex-end;
    }

    .testimonials ul li:nth-child(odd) {
        width: 80%;
        align-self: flex-start;
    }

    .testimonials ul li:first-child {
        width: 80%;
        align-self: flex-start;
    }
}

/* —————————————————————————————————————————————————— */
/* CONNECT */

.connect-modal,
.scrim {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 600ms ease;
}

.connect-modal.is-open,
.connect-modal.is-animating,
.scrim.is-open,
.scrim.is-animating {
  visibility: visible;
}

.connect-modal.is-open,
.scrim.is-open {
  opacity: 1;
  pointer-events: auto;
}

.connect-modal.is-animating:not(.is-open),
.scrim.is-animating:not(.is-open) {
  opacity: 0;
  pointer-events: none;
}

body.modal-open {
  overflow: hidden;
}

.connect-modal {
  position: fixed;
  inset: 0;
  z-index: 2001;
  width: 100%;
  height: 100%;
  overflow-y: auto;
  overflow-x: hidden;
  -webkit-overflow-scrolling: touch;
  padding: 0;
}

.close-connect {
  position: fixed;
  top: 8rem;
  right: 8rem;
  background: transparent;
  border: none;
  z-index: 4;
  cursor: pointer;
}

.connect-modal .two-col {
  position: relative;

  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 5rem;
  align-items: start;

  min-height: 100dvh;
  height: auto;
  margin-top: 0;
  padding: 4rem 8rem;

  background: rgba(170, 214, 255, .45);
  box-shadow: 0 0 25px 25px rgba(170, 214, 255, .5);
  -webkit-backdrop-filter: blur(20px);
  backdrop-filter: blur(20px);
  border-radius: 0;

  opacity: 0;
  transform: translateY(10px);
  transition:
    opacity 2200ms ease,
    transform 2600ms ease;

  will-change: opacity, transform;
  backface-visibility: hidden;
  -webkit-font-smoothing: antialiased;
}

.connect-modal .two-col::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;

  background: rgba(170, 214, 255, .45);
  box-shadow: 0 0 25px 25px rgba(170, 214, 255, .5);

  filter: blur(40px);
  opacity: 1;

  transition:
    filter 2200ms ease,
    opacity 2200ms ease;

  will-change: filter, opacity;
  backface-visibility: hidden;
}

.connect-modal.is-open .two-col {
  opacity: 1;
  transform: translateY(0);
}

.connect-modal.is-open .two-col::before {
  filter: blur(0);
  opacity: 0;
}

.connect-modal.is-animating:not(.is-open) .two-col {
  opacity: 0;
  transform: translateY(10px);
}

.connect-modal.is-animating:not(.is-open) .two-col::before {
  filter: blur(40px);
  opacity: 1;
}

.connect-modal .two-col > .img-col {
  position: sticky;
  top: 10rem;

  display: flex;
  align-items: center;
  justify-content: center;

  grid-column: 1;
  align-self: start;

  min-height: 400px;
  max-height: calc(100dvh - 8rem);
  max-width: 90%;
  margin: 0 auto;

  border-radius: 5rem;
  overflow: hidden;
  -webkit-backdrop-filter: blur(20px);
  backdrop-filter: blur(20px);

  opacity: .85;
}

.connect-modal .two-col > .img-col img {
  display: block;
  width: 100%;
  height: auto;
  filter: grayscale(100%);
  mix-blend-mode: multiply;
  opacity: 1;
}

.connect-modal .text-col {
  grid-column: 2;
  align-self: start;
  max-width: 60ch;
  min-width: 0;
  padding-top: 4rem;
  padding-right: 0;
}

@media only screen and (max-width: 767px) {
  .connect-modal {
    padding: 0;
  }

  .close-connect {
    top: 2rem;
    right: 2rem;
  }

  .connect-modal .two-col {
    grid-template-columns: 1fr;
    gap: 2.5rem;
    min-height: 100dvh;
    padding: 8rem 2rem 3rem;
  }

  .connect-modal .two-col > .img-col {
    position: relative;
    top: auto;
    grid-column: auto;
    max-width: 100%;
    max-height: none;
    min-height: 0;
    border-radius: 3rem;
  }

  .connect-modal .text-col {
    grid-column: auto;
    max-width: none;
    padding-top: 0;
  }
}

/* —————————————————————————————————————————————————— */
/* FOOTER */

.footer {
    flex-direction: column;
    width: 100%;
}

.footer-video {
    position: fixed;
    left: 0;
    bottom: -6rem;
    width: 100%;
    height: 100vh;
    z-index: -2;
    opacity: 0;
}

.footer-video.in-viewport {
    opacity: 1;
}

/* section.footer {
    margin-top: 10rem;
} */

.logo-wrapper {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    flex: 1;
    width: 100%;
}

.footer-links {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    width: 100%;
    padding: 3rem 0;
}

.footer-links .location {
    display: flex;
    flex-direction: row;
    justify-content: flex-start;
}

footer .big-button {
    font-family: "Inter", sans-serif;
    appearance: none;
    background: transparent;
    border: 1px solid rgba(0, 0, 0, 0.75);
    color: var(--fgBlack);
    border-radius: 9999px;
    padding: 1.5rem 3.25rem;
    font-size: 3.2rem;
    line-height: 1;
    letter-spacing: -0.01em;
    cursor: pointer;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: transform .15s ease, box-shadow .15s ease, background-color .15s ease;
}

footer .big-button:hover {
    transform: translateY(-1px);
    box-shadow: 0 10px 24px rgba(0, 0, 0, 0.08);
}

footer .big-button.vision-btn {
  background: #E4E8FF;
  border-color: #E4E8FF;
}

footer .big-button.connect-btn {
  background: #F5F5F5;
  border-color: #F5F5F5;
}

footer .big-button.offering-btn {
  background: #F5DDA1;
  border-color: #F5DDA1;
}

.footer-links .location a .directions-link {
    opacity: 0;
}

.footer-links .location a:hover .directions-link {
    opacity: 1;
}

.footer-links .center {
    display: flex;
    flex-direction: row;
    justify-content: center;
}

.footer-links .social {
    display: flex;
    flex-direction: row;
    justify-content: flex-end;
}

.footer-links ul {
    display: flex;
    flex-direction: row;
    margin: 0;
    padding: 0;
}

.story-content.watch {
    position: relative;
    width: 100%;
    height: 100%;
}

.scrim {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 1061;
}

.story-content.watch .embed-container {
    z-index: 0;
}

.footer-links ul li {
    list-style: none;
}

@media only screen and (max-width: 767px) {
  footer section {
    min-height: inherit;
    padding: 0;
  }
  footer .big-button {
    font-size: 2.6rem;
    padding: var(--pill-pad-y) var(--pill-pad-x);
    border-radius: var(--pill-radius);
    font-family: "Inter", sans-serif;
    font-optical-sizing: auto;
    font-weight: normal;
    font-style: normal;
    line-height: 1;
    white-space: nowrap;
    text-decoration: none;
    margin-left: 0;
  }
    .footer-links ul {
        flex-direction: column;
        align-items: center;
        gap: 1rem;
    }
    .footer-links .location, .footer-links .newsletter, .footer-links .social {
        justify-content: center;
        margin-top: 1rem;
    }
    .footer-video .embed-container {
        min-height: 160vh;
        max-height: 160vh;
        width: 160%;
        display: none;
    }
    .footer .facebook a, .footer .newsletter a, .footer .footer-contact a {
        margin-left: 1rem;
    }
}