@import url('https://fonts.googleapis.com/css2?family=Vollkorn:wght@500;600;700;800&family=Work+Sans:wght@400;500;600&display=swap');

:root {
  --c-canvas-1: #120b23;
  --c-canvas-2: #1c1438;
  --c-canvas-3: #251b45;

  --c-violet: #8d7bf5;
  --c-violet-deep: #6152c9;
  --c-violet-soft: #c3b8fb;

  --c-amber: #e8935a;
  --c-amber-soft: #f2b587;

  --c-cream: #faf6ef;
  --c-cream-2: #f1e9db;

  --c-ink: #221c37;
  --c-ink-soft: #4d4665;
  --c-mist: #a89fc9;

  --c-light-text: #f2eef9;
  --c-light-muted: #bcb3db;

  --r-sm: .6rem;
  --r-md: 1rem;
  --r-lg: 1.6rem;
  --r-xl: 2.2rem;
  --r-2xl: 3rem;
  --r-pill: 999px;

  --sh-sm: 0 2px 8px rgba(15,10,28,.16);
  --sh-md: 0 10px 26px rgba(15,10,28,.22), 0 3px 8px rgba(15,10,28,.14);
  --sh-lg: 0 26px 64px rgba(15,10,28,.38), 0 10px 22px rgba(15,10,28,.22);

  --glow-violet: 0 0 0 1px rgba(141,123,245,.28), 0 22px 55px -14px rgba(141,123,245,.6);
  --glow-amber: 0 0 0 1px rgba(232,147,90,.28), 0 22px 50px -14px rgba(232,147,90,.6);

  --dur-1: .22s;
  --dur-2: .35s;
  --dur-3: .55s;
  --ease-out: cubic-bezier(.16,1,.3,1);
  --ease-in: cubic-bezier(.7,0,.84,0);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }

body {
  margin: 0;
  font-family: 'Work Sans', sans-serif;
  color: var(--c-ink);
  background:
    radial-gradient(60rem 40rem at 85% -10%, rgba(141,123,245,.16), transparent 60%),
    radial-gradient(50rem 36rem at -10% 30%, rgba(232,147,90,.10), transparent 60%),
    linear-gradient(180deg, var(--c-canvas-1), var(--c-canvas-2) 35%, var(--c-canvas-3) 62%, var(--c-canvas-2));
  overflow-x: hidden;
  line-height: 1.6;
}

h1, h2, h3, h4 {
  font-family: 'Vollkorn', serif;
  color: var(--c-ink);
  line-height: 1.18;
  margin: 0 0 1rem;
  font-weight: 700;
}

p { margin: 0 0 1rem; color: var(--c-ink-soft); }
a { text-decoration: none; color: inherit; transition: color var(--dur-1) var(--ease-out); }
img { max-width: 100%; display: block; }

.u-container { width: 100%; max-width: 1180px; margin: 0 auto; padding: 0 1.5rem; }
.u-text-center { text-align: center; }
.u-hidden { display: none !important; }

.c-eyebrow {
  display: inline-block;
  font-size: .8rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--c-violet-deep);
  margin-bottom: .75rem;

  &.c-eyebrow--light { color: var(--c-violet-soft); }
}

.c-badge {
  display: inline-block;
  padding: .5rem 1.1rem;
  border-radius: var(--r-pill);
  background: rgba(141,123,245,.16);
  border: 1px solid rgba(141,123,245,.35);
  color: var(--c-light-text);
  font-size: .82rem;
  font-weight: 600;
  margin-bottom: 1.2rem;
  backdrop-filter: blur(6px);
}

.c-btn {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  padding: .95rem 1.7rem;
  border-radius: var(--r-pill);
  font-weight: 600;
  font-size: .96rem;
  border: 1px solid transparent;
  cursor: pointer;
  transition: transform var(--dur-1) var(--ease-out), box-shadow var(--dur-2) var(--ease-out), background var(--dur-2) var(--ease-out), color var(--dur-2) var(--ease-out), border-color var(--dur-2) var(--ease-out);
  min-height: 48px;

  &.c-btn--primary {
    background: linear-gradient(135deg, var(--c-violet), var(--c-violet-deep));
    color: #fff;
    box-shadow: var(--glow-violet);
    &:hover { transform: translateY(-3px); box-shadow: 0 0 0 1px rgba(141,123,245,.4), 0 30px 65px -12px rgba(141,123,245,.75); }
    &:active { transform: translateY(-1px); }
  }
  &.c-btn--ghost {
    background: transparent;
    color: var(--c-violet-deep);
    border-color: rgba(34,28,55,.25);
    &:hover { border-color: var(--c-violet); color: var(--c-violet-deep); transform: translateY(-2px); box-shadow: var(--sh-sm); }
    &.c-btn--on-dark { color: var(--c-light-text); border-color: rgba(242,238,249,.3); &:hover { border-color: var(--c-amber-soft); color: var(--c-amber-soft); } }
  }
  &.c-btn--text {
    background: transparent;
    color: var(--c-ink-soft);
    padding: .6rem .8rem;
    &:hover { color: var(--c-violet-deep); }
  }
  &.c-btn--sm { padding: .65rem 1.1rem; font-size: .85rem; min-height: 40px; }
}


.c-nav {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 200;
  transition: background var(--dur-2) var(--ease-out), box-shadow var(--dur-2) var(--ease-out), backdrop-filter var(--dur-2);

  & .c-nav__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1.1rem 1.5rem;
  }

  & .c-nav__brand {
    display: flex;
    align-items: center;
    gap: .6rem;
    font-family: 'Vollkorn', serif;
    font-weight: 700;
    font-size: 1.25rem;
    color: var(--c-light-text);
    transition: color var(--dur-2);
  }
  & .c-nav__logo { width: 34px; height: 34px; }

  & .c-nav__links {
    display: flex;
    align-items: center;
    gap: 1.9rem;
  }
  & .c-nav__link {
    font-size: .95rem;
    font-weight: 500;
    color: var(--c-light-text);
    position: relative;
    padding: .3rem 0;
    transition: color var(--dur-2) var(--ease-out);
    &::after {
      content: '';
      position: absolute; left: 0; bottom: -2px;
      width: 0; height: 2px;
      background: var(--c-amber);
      transition: width var(--dur-2) var(--ease-out);
    }
    &:hover::after, &.is-active::after { width: 100%; }
    &:hover { color: var(--c-amber-soft); }
  }
  & .c-nav__link--cta {
    border: 1px solid rgba(242,238,249,.4);
    border-radius: var(--r-pill);
    padding: .55rem 1.2rem;
    &:hover { background: rgba(232,147,90,.15); border-color: var(--c-amber); }
    &::after { display: none; }
  }

  & .c-nav__toggle {
    display: none;
    flex-direction: column;
    gap: 5px;
    background: none;
    border: none;
    cursor: pointer;
    padding: .5rem;
    min-width: 44px;
    min-height: 44px;
    align-items: center;
    justify-content: center;
    & span {
      width: 24px; height: 2px;
      background: var(--c-light-text);
      border-radius: 2px;
      transition: all var(--dur-2) var(--ease-out);
    }
  }

  & .c-nav__panel {
    max-height: 0;
    overflow: hidden;
    background: rgba(18,11,35,.97);
    backdrop-filter: blur(14px);
    transition: max-height var(--dur-3) var(--ease-out);
    display: flex;
    flex-direction: column;
  }
  & .c-nav__panel-link {
    padding: 1rem 1.5rem;
    color: var(--c-light-text);
    font-weight: 500;
    border-top: 1px solid rgba(255,255,255,.08);
    transition: background var(--dur-1), color var(--dur-1), padding-left var(--dur-1);
    &:hover { background: rgba(141,123,245,.15); color: var(--c-amber-soft); padding-left: 2rem; }
  }

  &.is-on-light {
    background: rgba(250,246,239,.82);
    box-shadow: var(--sh-sm);
    backdrop-filter: blur(14px);
    & .c-nav__brand, & .c-nav__link { color: var(--c-ink); }
    & .c-nav__link:hover { color: var(--c-violet-deep); }
    & .c-nav__link--cta { border-color: rgba(34,28,55,.3); &:hover { background: rgba(141,123,245,.12); border-color: var(--c-violet); } }
    & .c-nav__toggle span { background: var(--c-ink); }
  }
  &.is-on-dark {
    background: rgba(18,11,35,.35);
    backdrop-filter: blur(14px);
    & .c-nav__brand, & .c-nav__link { color: var(--c-light-text); }
  }
}


.s-hero {
  position: relative;
  padding: 9.5rem 0 2rem;
  overflow: hidden;

  & .s-hero__inner {
    display: grid;
    grid-template-columns: 1.05fr .95fr;
    gap: 3rem;
    align-items: center;
    padding-bottom: 4rem;
  }

  & .s-hero__title {
    font-size: clamp(2.4rem, 5vw, 3.6rem);
    color: var(--c-light-text);
    margin-bottom: 1.3rem;
    & span { color: var(--c-amber-soft); }
  }
  & .s-hero__lead {
    color: var(--c-light-muted);
    font-size: 1.08rem;
    max-width: 46ch;
    margin-bottom: 2rem;
  }
  & .s-hero__actions { display: flex; gap: 1rem; flex-wrap: wrap; }

  & .s-hero__mosaic {
    position: relative;
    height: 460px;
  }
  & .s-hero__img {
    position: absolute;
    object-fit: cover;
    border-radius: var(--r-xl);
    box-shadow: var(--sh-lg);
    transition: transform var(--dur-3) var(--ease-out), box-shadow var(--dur-3) var(--ease-out);
    &--1 { width: 56%; height: 280px; top: 0; left: 4%; transform: rotate(-6deg); box-shadow: var(--glow-violet); z-index: 3; }
    &--2 { width: 42%; height: 210px; top: 10%; right: 0; transform: rotate(5deg); box-shadow: var(--sh-lg); z-index: 2; }
    &--3 { width: 40%; height: 200px; bottom: 0; left: 0; transform: rotate(4deg); box-shadow: var(--glow-amber); z-index: 2; }
    &--4 { width: 46%; height: 230px; bottom: -4%; right: 6%; transform: rotate(-4deg); box-shadow: var(--sh-lg); z-index: 1; }
    &:hover { transform: scale(1.04) rotate(0deg); z-index: 5; }
  }
}

.c-wave {
  position: relative;
  line-height: 0;
  margin-top: -2px;
  & svg { width: 100%; height: 90px; display: block; }
  & path { fill: var(--c-cream); }
}


.s-intro { padding: 1rem 0 5rem; }
.s-sessions { padding: 6rem 0 5rem; }
.s-pillars { padding: 5rem 0; }
.s-audience { padding: 2rem 0 6rem; }
.s-cta { padding: 2rem 0 7rem; }
.s-page-hero { padding: 9.5rem 0 5rem; position: relative; }
.s-team, .s-philosophy, .s-space, .s-contact, .s-legal, .s-timeline, .s-logistics, .s-stories, .s-thanks { padding: 5rem 0; }

.c-card {
  border-radius: var(--r-2xl);
  padding: clamp(2rem, 4vw, 3.2rem);
  position: relative;
  transition: transform var(--dur-2) var(--ease-out), box-shadow var(--dur-2) var(--ease-out);

  &.c-card--light {
    background: var(--c-cream);
    box-shadow: var(--sh-lg);
    & h2, & h3 { color: var(--c-ink); }
  }
  &.c-card--dark {
    background: linear-gradient(160deg, #241b42, #180f30);
    box-shadow: var(--sh-lg);
    color: var(--c-light-muted);
    & h3 { color: var(--c-light-text); }
  }
  &.c-card--tint {
    background: linear-gradient(160deg, #f4eefe, #ede4fb);
    box-shadow: var(--sh-md);
  }
  &.c-card--cta {
    background: linear-gradient(135deg, #2b1f4d, #1a1130);
    box-shadow: var(--glow-violet);
    text-align: center;
    & h2 { color: var(--c-light-text); }
    & p { color: var(--c-light-muted); max-width: 55ch; margin-left: auto; margin-right: auto; }
  }
  &.c-card--glow {
    background: rgba(255,255,255,.03);
    border: 1px solid rgba(255,255,255,.08);
    backdrop-filter: blur(10px);
    color: var(--c-light-muted);
    & h3 { color: var(--c-light-text); }
    &:hover { transform: translateY(-6px); }
    &.c-card--violet { box-shadow: var(--glow-violet); &:hover { box-shadow: 0 0 0 1px rgba(141,123,245,.45), 0 30px 65px -10px rgba(141,123,245,.75); } }
    &.c-card--amber { box-shadow: var(--glow-amber); &:hover { box-shadow: 0 0 0 1px rgba(232,147,90,.45), 0 30px 65px -10px rgba(232,147,90,.75); } }
  }
  & .c-card__num {
    display: inline-block;
    font-family: 'Vollkorn', serif;
    font-size: 1.6rem;
    font-weight: 700;
    color: var(--c-amber-soft);
    margin-bottom: .8rem;
  }
  & .c-card__icon {
    width: 52px; height: 52px;
    display: flex; align-items: center; justify-content: center;
    border-radius: var(--r-md);
    background: linear-gradient(135deg, var(--c-violet), var(--c-violet-deep));
    color: #fff;
    font-size: 1.3rem;
    margin-bottom: 1.1rem;
    box-shadow: var(--glow-violet);
  }
}

.s-intro__grid, .s-team__grid {
  display: grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 3rem;
  align-items: center;
}
.s-team__grid--reverse { direction: rtl; & > * { direction: ltr; } }
.s-intro__image img, .s-team__image img { border-radius: var(--r-xl); box-shadow: var(--sh-lg); width: 100%; height: 100%; object-fit: cover; aspect-ratio: 4/3; }

.s-sessions__title { color: var(--c-light-text); font-size: clamp(1.9rem, 3.5vw, 2.6rem); }
.s-sessions__lead { color: var(--c-light-muted); max-width: 60ch; margin-bottom: 3rem; }
.s-sessions__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.6rem;
  margin-bottom: 3rem;
}

.s-pillars__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.6rem; margin-top: 2.5rem; }
.s-audience__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1.6rem; }

.c-list {
  list-style: none;
  padding: 0;
  margin: 1rem 0;
  & li {
    position: relative;
    padding-left: 1.6rem;
    margin-bottom: .8rem;
    color: var(--c-ink-soft);
    &::before {
      content: '\f00c';
      font-family: 'Font Awesome 6 Free';
      font-weight: 900;
      position: absolute; left: 0; top: .15rem;
      color: var(--c-violet-deep);
      font-size: .8rem;
    }
  }
  &.c-list--on-dark li { color: var(--c-light-muted); &::before { color: var(--c-amber-soft); } }
}

.s-cta__actions { display: flex; justify-content: center; gap: 1rem; flex-wrap: wrap; margin-top: 1.5rem; }

.c-divider-dots {
  display: flex;
  justify-content: center;
  gap: 1.4rem;
  padding: 2.5rem 0;
  & span {
    width: 10px; height: 10px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--c-violet), var(--c-amber));
    box-shadow: 0 0 14px rgba(141,123,245,.6);
    opacity: .55;
    animation: dot-pulse 3.2s ease-in-out infinite;
  }
  & span:nth-child(odd) { animation-delay: .3s; }
  & span:nth-child(3n) { animation-delay: .6s; background: linear-gradient(135deg, var(--c-amber), var(--c-violet)); }
}
@keyframes dot-pulse {
  0%, 100% { transform: scale(1); opacity: .45; }
  50% { transform: scale(1.5); opacity: 1; }
}


.s-philosophy__title { color: var(--c-light-text); font-size: clamp(1.9rem, 3.5vw, 2.6rem); }
.s-philosophy__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.5rem; margin-top: 2.5rem; }
.s-philosophy__grid .c-card i { font-size: 1.6rem; color: var(--c-amber-soft); margin-bottom: 1rem; display: block; }


.c-timeline {
  position: relative;
  padding-left: 2.4rem;
  &::before {
    content: '';
    position: absolute; left: 8px; top: 0; bottom: 0;
    width: 2px;
    background: linear-gradient(180deg, var(--c-violet), var(--c-amber));
    opacity: .4;
  }
  & .c-timeline__item {
    position: relative;
    margin-bottom: 2.6rem;
  }
  & .c-timeline__marker {
    position: absolute;
    left: -2.4rem;
    top: 0;
    width: 34px; height: 34px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--c-violet), var(--c-violet-deep));
    color: #fff;
    display: flex; align-items: center; justify-content: center;
    font-size: .75rem;
    font-weight: 700;
    box-shadow: var(--glow-violet);
  }
  & .c-timeline__date {
    position: absolute;
    left: -2.55rem;
    top: 0;
    transform: translateX(-100%);
    font-size: .78rem;
    font-weight: 600;
    color: var(--c-violet-deep);
    white-space: nowrap;
    background: var(--c-cream-2);
    padding: .3rem .7rem;
    border-radius: var(--r-pill);
    display: none;
  }
  & .c-timeline__image { border-radius: var(--r-lg); margin-top: 1.2rem; box-shadow: var(--sh-md); width: 100%; aspect-ratio: 16/9; object-fit: cover; }

  &.c-timeline--legal .c-timeline__item::before {
    content: '';
    position: absolute;
    left: -2.4rem; top: 6px;
    width: 16px; height: 16px;
    border-radius: 50%;
    background: var(--c-amber);
    box-shadow: var(--glow-amber);
  }
  &.c-timeline--legal .c-timeline__date {
    display: inline-block;
    position: static;
    transform: none;
    margin-bottom: .8rem;
  }
  &.c-timeline--compact .c-timeline__item { margin-bottom: 1.6rem; }
  &.c-timeline--compact .c-card { padding: 1.6rem 2rem; }
}


.s-stories__item {
  display: grid;
  grid-template-columns: .8fr 1.2fr;
  gap: 2.5rem;
  align-items: center;
  margin-bottom: 2.5rem;
  &--reverse { direction: rtl; & > * { direction: ltr; } }
}
.s-stories__image img { border-radius: var(--r-xl); box-shadow: var(--sh-lg); width: 100%; aspect-ratio: 4/3; object-fit: cover; }
.s-stories__note { margin-bottom: 2rem; }


.s-contact__grid { display: grid; grid-template-columns: 1.3fr .9fr; gap: 2.2rem; align-items: start; margin-bottom: 3rem; }
.s-contact__side { display: flex; flex-direction: column; gap: 1.6rem; }
.s-map { margin-top: 0; }
.s-map__frame { border-radius: var(--r-lg); overflow: hidden; box-shadow: var(--sh-md); margin-top: 1rem; }

.c-form {
  display: flex;
  flex-direction: column;
  gap: 1.3rem;
  margin-top: 1.5rem;
  & .c-form__group { display: flex; flex-direction: column; gap: .5rem; }
  & .c-form__label { font-weight: 600; font-size: .92rem; color: var(--c-ink); }
  & .c-form__input, & .c-form__select, & .c-form__textarea {
    padding: .9rem 1.1rem;
    border-radius: var(--r-md);
    border: 1.5px solid rgba(34,28,55,.15);
    background: #fff;
    font-family: 'Work Sans', sans-serif;
    font-size: .96rem;
    color: var(--c-ink);
    transition: border-color var(--dur-2) var(--ease-out), box-shadow var(--dur-2) var(--ease-out);
    &:focus { outline: none; border-color: var(--c-violet); box-shadow: 0 0 0 4px rgba(141,123,245,.18); }
  }
  & .c-form__textarea { resize: vertical; min-height: 120px; }
  & .c-form__checkbox-group {
    display: flex;
    align-items: flex-start;
    gap: .7rem;
    font-size: .88rem;
    color: var(--c-ink-soft);
    & input { margin-top: .3rem; width: 20px; height: 20px; accent-color: var(--c-violet); flex-shrink: 0; }
    & a { color: var(--c-violet-deep); text-decoration: underline; }
  }
  & .c-form__submit { align-self: flex-start; margin-top: .5rem; }
}


.s-thanks__card {
  max-width: 600px;
  margin: 0 auto;
  text-align: center;
}
.s-thanks__icon {
  font-size: 3.5rem;
  color: var(--c-violet-deep);
  margin-bottom: 1.2rem;
}


.c-footer {
  background: linear-gradient(160deg, #17102c, #0f0a1e);
  color: var(--c-light-muted);
  padding: 4rem 0 1.5rem;
  margin-top: 4rem;

  & .c-footer__inner {
    display: grid;
    grid-template-columns: 1.4fr 1fr 1fr 1.1fr;
    gap: 2.5rem;
    padding-bottom: 2.5rem;
    border-bottom: 1px solid rgba(255,255,255,.08);
  }
  & .c-footer__brand { display: flex; flex-direction: column; gap: 1rem; }
  & .c-footer__brand p { color: var(--c-light-muted); font-size: .9rem; }
  & .c-nav__logo { width: 34px; height: 34px; }
  & .c-footer__col {
    display: flex;
    flex-direction: column;
    gap: .7rem;
    & h4 { color: var(--c-light-text); font-family: 'Vollkorn', serif; font-size: 1.05rem; margin-bottom: .3rem; }
    & a, & p { color: var(--c-light-muted); font-size: .9rem; transition: color var(--dur-1); }
    & a:hover { color: var(--c-amber-soft); }
  }
  & .c-footer__bottom { padding-top: 1.5rem; font-size: .82rem; text-align: center; color: var(--c-mist); }
}


.c-cookie {
  position: fixed;
  right: 1.5rem;
  bottom: 1.5rem;
  z-index: 300;
  width: 320px;
  max-width: calc(100vw - 2rem);
  background: linear-gradient(160deg, #241b42, #180f30);
  border-radius: var(--r-xl);
  padding: 1.6rem;
  box-shadow: var(--glow-violet);
  border: 1px solid rgba(255,255,255,.08);
  transform: translateY(140%);
  opacity: 0;
  transition: transform var(--dur-3) var(--ease-out), opacity var(--dur-3) var(--ease-out);

  &.is-visible { transform: translateY(0); opacity: 1; }

  & .c-cookie__icon {
    width: 46px; height: 46px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--c-amber), var(--c-violet));
    display: flex; align-items: center; justify-content: center;
    color: #fff;
    font-size: 1.2rem;
    margin-bottom: 1rem;
    box-shadow: var(--glow-amber);
  }
  & .c-cookie__msg { color: var(--c-light-muted); font-size: .88rem; margin-bottom: 1.1rem; }
  & .c-cookie__actions { display: flex; flex-direction: column; gap: .6rem; }
  & .c-btn--sm { width: 100%; justify-content: center; }

  & .c-cookie__panel {
    max-height: 0;
    overflow: hidden;
    transition: max-height var(--dur-3) var(--ease-out), margin-top var(--dur-3) var(--ease-out);
    display: flex;
    flex-direction: column;
    gap: .7rem;
  }
  &.is-expanded .c-cookie__panel { max-height: 260px; margin-top: 1rem; }

  & .c-cookie__toggle {
    display: flex;
    align-items: center;
    gap: .6rem;
    font-size: .85rem;
    color: var(--c-light-muted);
    & input { width: 18px; height: 18px; accent-color: var(--c-amber); }
  }
}


.c-reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity .8s var(--ease-out), transform .8s var(--ease-out);
  &.is-visible { opacity: 1; transform: translateY(0); }
}

@keyframes hero-fade {
  from { opacity: 0; transform: translateY(30px); }
  to { opacity: 1; transform: translateY(0); }
}
.s-hero__content, .s-hero__mosaic { animation: hero-fade 1s var(--ease-out) both; }
.s-hero__mosaic { animation-delay: .15s; }


@media (max-width: 980px) {
  .c-nav__links { display: none; }
  .c-nav__toggle { display: flex; }
  .s-hero__inner, .s-intro__grid, .s-team__grid, .s-contact__grid, .s-audience__grid, .s-stories__item { grid-template-columns: 1fr; }
  .s-team__grid--reverse, .s-stories__item--reverse { direction: ltr; }
  .s-sessions__grid, .s-pillars__grid { grid-template-columns: repeat(2, 1fr); }
  .s-philosophy__grid { grid-template-columns: repeat(2, 1fr); }
  .s-hero__mosaic { height: 360px; margin-top: 2rem; }
  .c-footer__inner { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 620px) {
  .s-hero { padding-top: 8rem; }
  .s-sessions__grid, .s-pillars__grid, .s-philosophy__grid { grid-template-columns: 1fr; }
  .c-footer__inner { grid-template-columns: 1fr; }
  .c-timeline { padding-left: 2rem; }
  .c-timeline .c-timeline__date { position: static; transform: none; display: inline-block; margin-bottom: .6rem; }
  .s-hero__mosaic { height: 300px; }
  .s-hero__img--1 { width: 62%; height: 190px; }
  .s-hero__img--2 { width: 50%; height: 150px; }
  .s-hero__img--3 { width: 46%; height: 140px; }
  .s-hero__img--4 { width: 52%; height: 160px; }
  .c-cookie { right: .8rem; left: .8rem; bottom: .8rem; width: auto; }
  .s-page-hero { padding-top: 7.5rem; }
}