@charset "UTF-8";
/* --------------------------------------------------
CranfordTeague
theme.css
Last Updated By: JCT
Date: 23 March 2023
-------------------------------------------------- */
/* Page widths */
/* module widths */
/* Component Heights */
/* Primariy Colors */
/* Secondary Colors */
/* Neutral  Colors */
/* Link Colors */
/* Alert Colors */
/* Gradients */
/* Font Stack */
/* Font Size */
/* Font Weight */
/* line-height */
/* Letter Spacing */
/* Spacing */
/* border-width */
/* Drop Shadows */
/* Transitions */
/* Foundation: Typography */
@import url("https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined");
@import url("https://fonts.googleapis.com/css2?family=Josefin+Sans:ital,wght@0,600;0,700;1,500;1,600;1,700&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Sofia+Sans+Condensed:ital,wght@0,300;0,800;1,300;1,800&family=Sofia+Sans:ital,wght@0,1;0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;0,1000;1,1;1,100;1,200;1,300;1,400;1,500;1,600;1,700;1,800;1,900;1,1000&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Brygada+1918:ital,wght@0,400..700;1,400..700&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,100..900;1,9..144,100..900&display=swap");
/**animation**/
@keyframes fadeIn {
  0% {
    opacity: 0; }
  100% {
    opacity: 1; } }

@keyframes fadeOut {
  0% {
    opacity: 1; }
  100% {
    opacity: 0; } }

@-webkit-keyframes spin {
  0% {
    -webkit-transform: rotate(0deg);
    /* Chrome, Opera 15+, Safari 3.1+ */
    -ms-transform: rotate(0deg);
    /* IE 9 */
    transform: rotate(0deg);
    /* Firefox 16+, IE 10+, Opera  */ }
  100% {
    -webkit-transform: rotate(360deg);
    /* Chrome, Opera 15+, Safari 3.1+ */
    -ms-transform: rotate(360deg);
    /* IE 9 */
    transform: rotate(360deg);
    /* Firefox 16+, IE 10+, Opera  */ } }

@keyframes spin {
  0% {
    -webkit-transform: rotate(0deg);
    /* Chrome, Opera 15+, Safari 3.1+ */
    -ms-transform: rotate(0deg);
    /* IE 9 */
    transform: rotate(0deg);
    /* Firefox 16+, IE 10+, Opera  */ }
  100% {
    -webkit-transform: rotate(360deg);
    /* Chrome, Opera 15+, Safari 3.1+ */
    -ms-transform: rotate(360deg);
    /* IE 9 */
    transform: rotate(360deg);
    /* Firefox 16+, IE 10+, Opera  */ } }

/** Base Styles **/
* {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-size: 100%;
  vertical-align: baseline;
  text-decoration: none;
  font-smoothing: always;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  scrollbar-width: 12px;
  scrollbar-color: #191736 #b1afcf;
  scroll-behavior: smooth;
  box-sizing: inherit;
  /* Works on Chrome, Edge, and Safari */ }
  *:before, *:after {
    box-sizing: inherit; }
  *::-webkit-scrollbar {
    width: 12px; }
  *::-webkit-scrollbar-track {
    background-color: transparent; }
  *::-webkit-scrollbar-thumb {
    background-color: #3c3960;
    border-radius: 12px;
    border: 2px solid #1e1d30; }
    *::-webkit-scrollbar-thumb:hover {
      background-color: #cc3300; }

html {
  scroll-behavior: smooth;
  font-family: "Sofia Sans", sans-serif;
  font-size: calc(12px + .5vw);
  background-color: #b1afcf;
  overflow: hidden;
  position: relative;
  height: 100vh;
  padding: 1vw;
  box-sizing: border-box; }

body {
  background-color: #f6f5f9;
  color: #1e1d30;
  font-family: "Sofia Sans", sans-serif;
  font-size: calc(12px + .5vw);
  box-sizing: border-box;
  overflow-x: hidden;
  padding: calc(1vw + 20px);
  width: 100%;
  height: 100%;
  max-width: 1440px;
  overflow: auto;
  margin: 0 auto;
  position: relative;
  margin: 0 auto;
  box-shadow: 0 0 1vw rgba(0, 0, 0, 0.6);
  border-radius: 1vw; }

header {
  overflow: visible; }

h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: "Sofia Sans Condensed", sans-serif;
  text-transform: uppercase;
  color: #3a367d;
  line-height: 1;
  letter-spacing: .025em;
  padding: 0 0 10px 0;
  margin: 25px 0 0.5em 0;
  border-color: #b1afcf;
  border-style: solid;
  clear: both; }

h1 {
  font-size: 3rem;
  font-variation-settings: 'wght' 800;
  margin: 0 0 .75em 0;
  padding: 0; }

h2 {
  font-size: 2rem;
  font-variation-settings: 'wght' 400;
  border-bottom-width: 1px;
  margin: .5rem 0 0 0; }

h3 {
  font-size: 1.5rem;
  font-variation-settings: 'wght' 500;
  border-bottom-width: 1px; }

h4 {
  font-size: 1.25rem;
  font-variation-settings: 'wght' 600;
  border-bottom-width: 1px; }

h5 {
  font-size: calc(12px + .5vw);
  font-variation-settings: 'wght' 700;
  border-bottom-width: 1px; }

h6 {
  font-size: 0.875rem;
  font-variation-settings: 'wght' 800;
  border-bottom-width: 1px; }

figure {
  text-align: center;
  margin: 0;
  padding: 3em 0 0 0;
  width: 100%;
  max-width: 33vw;
  overflow: visible;
  position: relative; }
  figure figcaption {
    display: none;
    width: 100%;
    overflow-x: clip;
    overflow-y: clip;
    white-space: nowrap;
    text-overflow: ellipsis;
    clear: both;
    font-family: "Sofia Sans Condensed", sans-serif;
    font-size: 1.25rem;
    font-weight: 800;
    color: #3a367d;
    text-align: center;
    text-transform: uppercase;
    padding: 0;
    margin: 0;
    caption-side: top; }

section {
  padding: 0; }
  section div {
    position: relative; }

article {
  margin: 0 auto; }

p,
li {
  color: black;
  font-size: calc(12px + .5vw);
  font-size: clamp(16px, calc(12px + .5vw), 18px);
  font-variation-settings: 'wght' 500;
  position: relative;
  margin: 0 0 .75em 0;
  font-variation-settings: 'wght' 300;
  width: 100%;
  max-width: 45em; }

a {
  color: #cc3300;
  font-variation-settings: 'wght' 600;
  padding-bottom: 1px;
  transition: 0.2s ease-in;
  vertical-align: middle; }
  a[href*="http://"], a[href*="https://"] {
    display: inline-block;
    vertical-align: bottom; }
  a[href*="http://"]::after, a[href*="https://"]::after {
    transition: left .1s ease-in;
    display: inline-block;
    position: relative;
    font-family: "Material Symbols Outlined", sans-serif;
    color: #cc3300;
    content: "\e89e";
    margin-left: 6px;
    vertical-align: bottom;
    left: 0;
    top: -.05em; }
  a:hover {
    color: #ff6633; }
    a:hover:after {
      color: #ff6633 !important; }
    a:hover[href*="http://"]::before, a:hover[href*="https://"]::before {
      transition: color .1s;
      color: #cc3300; }

p a {
  color: #cc3300;
  padding-bottom: 1px;
  position: relative;
  text-decoration: none; }

p + ul li {
  margin-left: 3em; }

p {
  hyphens: auto;
  text-align: justify;
  text-justify: inter-character;
  line-height: 1.35; }

ul {
  list-style: none;
  list-style-position: outside;
  margin-bottom: 25px; }
  ul li {
    font-size: 0.875rem;
    margin-left: 2em;
    margin-bottom: 1em;
    line-height: 1.2;
    font-size: 0.875rem;
    max-width: 42em; }
    ul li::before {
      font-family: "Material Symbols Outlined", sans-serif;
      content: "\e937";
      color: #64609f;
      display: block;
      position: absolute;
      left: -1.75em;
      width: 1.2em;
      height: 1.2em;
      padding: 0;
      text-align: center;
      align-content: center; }
  ul.compact li {
    margin-bottom: .1em !important;
    font-size: smaller; }

ol {
  list-style: none;
  list-style-position: inside;
  counter-reset: listCounter; }
  ol li {
    font-size: 0.875rem;
    margin-left: 2em;
    margin-bottom: 1.2em;
    max-width: calc(100% - 3em);
    line-height: 1.1;
    counter-increment: listCounter; }
    ol li::before {
      display: block;
      position: absolute;
      left: -1.75em;
      width: 1.2em;
      height: 1.2em;
      padding: 0;
      background-color: #64609f;
      color: white;
      font-weight: 900;
      border-radius: 2em;
      text-align: center;
      align-content: center;
      font-variation-settings: 'wght' 900;
      content: counter(listCounter); }
  ol.compact li {
    margin-bottom: .1em !important;
    font-size: smaller; }

blockquote {
  padding: 0 .25em 1em .25em;
  margin: 0 0 1em 0;
  border-bottom: 1px solid #b1afcf; }
  blockquote p {
    color: #3c3960;
    font-size: 0.75rem;
    line-height: 1.5;
    font-variation-settings: 'wght' 400;
    padding: 0 10px; }
    blockquote p.font-larger {
      font-size: 1.25rem; }
  blockquote cite {
    display: block;
    text-align: right;
    padding: 0;
    color: #5a568f;
    font-size: 0.75rem;
    font-variation-settings: 'wght' 800;
    font-style: normal;
    width: 100%;
    margin-top: .25em; }
    blockquote cite:before {
      content: "— "; }
  blockquote:last-of-type {
    border-bottom: 0 !important; }

/* INLINE STYLES */
strong {
  font-variation-settings: 'wght' 800;
  color: #3a367d; }

em {
  font-style: italic;
  font-variation-settings: 'wght' 600;
  color: #3a367d; }

/**page loader**/
#loader-wrapper {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  z-index: 100000; }

#loader-logo {
  display: block;
  position: absolute;
  left: 50%;
  top: 50%;
  right: 50%;
  bottom: 50%;
  width: 75px;
  height: 75px;
  margin: -36px 0 0 -36px;
  z-index: 99999;
  animation-name: fadeOut;
  animation-duration: 1s;
  animation-delay: 1s;
  transition-timing-function: ease-out;
  animation-fill-mode: both; }

#loader {
  display: block;
  position: relative;
  left: 50%;
  top: 50%;
  width: 150px;
  height: 150px;
  margin: -75px 0 0 -75px;
  border-radius: 50%;
  border: 3px solid transparent;
  border-top-color: #3a367d;
  -webkit-animation: spin 2s linear infinite;
  /* Chrome, Opera 15+, Safari 5+ */
  animation: spin 2s linear infinite;
  /* Chrome, Firefox 16+, IE 10+, Opera */
  z-index: 1001; }
  #loader:before {
    content: "";
    position: absolute;
    top: 5px;
    left: 5px;
    right: 5px;
    bottom: 5px;
    border-radius: 50%;
    border: 3px solid transparent;
    border-top-color: #645eba;
    -webkit-animation: spin 3s linear infinite;
    /* Chrome, Opera 15+, Safari 5+ */
    animation: spin 3s linear infinite;
    /* Chrome, Firefox 16+, IE 10+, Opera */ }
  #loader:after {
    content: "";
    position: absolute;
    top: 15px;
    left: 15px;
    right: 15px;
    bottom: 15px;
    border-radius: 50%;
    border: 3px solid transparent;
    border-top-color: #a9a6d9;
    -webkit-animation: spin 1.5s linear infinite;
    /* Chrome, Opera 15+, Safari 5+ */
    animation: spin 1.5s linear infinite;
    /* Chrome, Firefox 16+, IE 10+, Opera */ }

#loader-wrapper .loader-section {
  position: fixed;
  top: 0;
  width: 51%;
  height: 100%;
  background: #191736;
  z-index: 1000; }
  #loader-wrapper .loader-section.section-left {
    left: 0; }
  #loader-wrapper .loader-section.section-right {
    right: 0; }

.loaded #loader-wrapper .loader-section.section-left {
  -webkit-transform: translateX(-100%);
  /* Chrome, Opera 15+, Safari 3.1+ */
  -ms-transform: translateX(-100%);
  /* IE 9 */
  transform: translateX(-100%);
  /* Firefox 16+, IE 10+, Opera  */
  -webkit-transition: all 0.7s 0.3s cubic-bezier(0.645, 0.045, 0.355, 1);
  /* Android 2.1+, Chrome 1-25, iOS 3.2-6.1, Safari 3.2-6  */
  transition: all 0.7s 0.3s cubic-bezier(0.645, 0.045, 0.355, 1);
  /* Chrome 26, Firefox 16+, iOS 7+, IE 10+, Opera, Safari 6.1+  */ }

.loaded #loader-wrapper .loader-section.section-right {
  -webkit-transform: translateX(100%);
  /* Chrome, Opera 15+, Safari 3.1+ */
  -ms-transform: translateX(100%);
  /* IE 9 */
  transform: translateX(100%);
  /* Firefox 16+, IE 10+, Opera  */
  -webkit-transition: all 0.7s 0.3s cubic-bezier(0.645, 0.045, 0.355, 1);
  /* Android 2.1+, Chrome 1-25, iOS 3.2-6.1, Safari 3.2-6  */
  transition: all 0.7s 0.3s cubic-bezier(0.645, 0.045, 0.355, 1);
  /* Chrome 26, Firefox 16+, iOS 7+, IE 10+, Opera, Safari 6.1+  */ }

.loaded #loader {
  opacity: 0;
  -webkit-transition: all 0.3s ease-out;
  /* Android 2.1+, Chrome 1-25, iOS 3.2-6.1, Safari 3.2-6  */
  transition: all 0.3s ease-out;
  /* Chrome 26, Firefox 16+, iOS 7+, IE 10+, Opera, Safari 6.1+  */ }

.loaded #loader-wrapper {
  visibility: hidden;
  -webkit-transform: translateY(-100%);
  /* Chrome, Opera 15+, Safari 3.1+ */
  -ms-transform: translateY(-100%);
  /* IE 9 */
  transform: translateY(-100%);
  /* Firefox 16+, IE 10+, Opera  */
  -webkit-transition: all 0.3s 1s ease-out;
  /* Android 2.1+, Chrome 1-25, iOS 3.2-6.1, Safari 3.2-6  */
  transition: all 0.3s 1s ease-out;
  /* Chrome 26, Firefox 16+, iOS 7+, IE 10+, Opera, Safari 6.1+  */ }

/** UI **/
.hide-remove {
  display: none; }

.float-right {
  float: right !important; }

.float-left {
  float: left !important; }

.float-clear {
  clear: both; }

.short {
  width: 50%; }

.border-top-none {
  border-top: none !important; }

.border-top-one {
  border-top: 1px solid #64609f !important;
  padding-top: 12px !important;
  margin-top: 8px !important; }

.border-bottom-none {
  border-bottom: none !important; }

.border-bottom-one {
  border-bottom: 1px solid #64609f !important; }

.border-right-none {
  border-right: none !important; }

.border-right-one {
  border-right: 1px solid #64609f !important; }

.border-left-none {
  border-left: none !important; }

.border-left-one {
  border-left: 1px solid #64609f !important; }

/* PADDING */
.padding-tiny {
  padding: 1px !important; }

.padding-xxsmall {
  padding: 2px !important; }

.padding-xsmall {
  padding: 3px !important; }

.padding-small {
  padding: 4px !important; }

.padding-normal {
  padding: 5px !important; }

.padding-medium {
  padding: 6px !important; }

.padding-large {
  padding: 8px !important; }

.padding-xlarge {
  padding: 10px !important; }

.padding-xxlarge {
  padding: 12px !important; }

.padding-huge {
  padding: 25px !important; }

.padding-xhuge {
  padding: 50px !important; }

.padding-xxhuge {
  padding: 100px !important; }

.padding-top-tiny {
  padding-top: 1px !important; }

.padding-top-xxsmall {
  padding-top: 2px !important; }

.padding-top-xsmall {
  padding-top: 3px !important; }

.padding-top-small {
  padding-top: 4px !important; }

.padding-top-normal {
  padding-top: 5px !important; }

.padding-top-medium {
  padding-top: 6px !important; }

.padding-top-large {
  padding-top: 8px !important; }

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

.padding-top-xxlarge {
  padding-top: 12px !important; }

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

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

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

.padding-right-tiny {
  padding-right: 1px !important; }

.padding-right-xxsmall {
  padding-right: 2px !important; }

.padding-right-xsmall {
  padding-right: 3px !important; }

.padding-right-small {
  padding-right: 4px !important; }

.padding-right-normal {
  padding-right: 5px !important; }

.padding-right-medium {
  padding-right: 6px !important; }

.padding-right-large {
  padding-right: 8px !important; }

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

.padding-right-xxlarge {
  padding-right: 12px !important; }

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

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

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

.padding-bottom-tiny {
  padding-bottom: 1px !important; }

.padding-bottom-xxsmall {
  padding-bottom: 2px !important; }

.padding-bottom-xsmall {
  padding-bottom: 3px !important; }

.padding-bottom-small {
  padding-bottom: 4px !important; }

.padding-bottom-normal {
  padding-bottom: 5px !important; }

.padding-bottom-medium {
  padding-bottom: 6px !important; }

.padding-bottom-large {
  padding-bottom: 8px !important; }

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

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

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

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

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

.padding-left-tiny {
  padding-left: 1px !important; }

.padding-left-xxsmall {
  padding-left: 2px !important; }

.padding-left-xsmall {
  padding-left: 3px !important; }

.padding-left-small {
  padding-left: 4px !important; }

.padding-left-normal {
  padding-left: 5px !important; }

.padding-left-medium {
  padding-left: 6px !important; }

.padding-left-large {
  padding-left: 8px !important; }

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

.padding-left-xxlarge {
  padding-left: 12px !important; }

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

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

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

/* MARGIN */
.margin-none {
  margin: 0 !important; }

.margin-tiny {
  margin: 1px !important; }

.margin-xxsmall {
  margin: 2px !important; }

.margin-xsmall {
  margin: 3px !important; }

.margin-small {
  margin: 4px !important; }

.margin-normal {
  margin: 5px !important; }

.margin-medium {
  margin: 6px !important; }

.margin-large {
  margin: 8px !important; }

.margin-xlarge {
  margin: 10px !important; }

.margin-xxlarge {
  margin: 12px !important; }

.margin-huge {
  margin: 25px !important; }

.margin-xhuge {
  margin: 50px !important; }

.margin-xxhuge {
  margin: 100px !important; }

.margin-top-none {
  margin-top: 0 !important; }

.margin-top-tiny {
  margin-top: 1px !important; }

.margin-top-xxsmall {
  margin: 2px !important; }

.margin-top-xsmall {
  margin-top: 3px !important; }

.margin-top-small {
  margin-top: 4px !important; }

.margin-top-normal {
  margin-top: 5px !important; }

.margin-top-medium {
  margin-top: 6px !important; }

.margin-top-large {
  margin-top: 8px !important; }

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

.margin-top-xxlarge {
  margin-top: 12px !important; }

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

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

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

.margin-right-none {
  margin-right: 0 !important; }

.margin-right-tiny {
  margin-right: 1px !important; }

.margin-right-xxsmall {
  margin-right: 2px !important; }

.margin-right-xsmall {
  margin-right: 3px !important; }

.margin-right-small {
  margin-right: 4px !important; }

.margin-right-normal {
  margin-right: 5px !important; }

.margin-right-medium {
  margin-right: 6px !important; }

.margin-right-large {
  margin-right: 8px !important; }

.margin-right-xlarge {
  margin-right: 10px !important; }

.margin-right-xxlarge {
  margin-right: 12px !important; }

.margin-right-huge {
  margin-right: 25px !important; }

.margin-right-xhuge {
  margin-right: 50px !important; }

.margin-right-xxhuge {
  margin-right: 100px !important; }

.margin-bottom-none {
  margin-bottom: 0 !important; }

.margin-bottom-tiny {
  margin-bottom: 1px !important; }

.margin-bottom-xxsmall {
  margin-bottom: 2px !important; }

.margin-bottom-xsmall {
  margin-bottom: 3px !important; }

.margin-bottom-small {
  margin-bottom: 4px !important; }

.margin-bottom-normal {
  margin-bottom: 5px !important; }

.margin-bottom-medium {
  margin-bottom: 6px !important; }

.margin-bottom-large {
  margin-bottom: 8px !important; }

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

.margin-bottom-xxlarge {
  margin-bottom: 12px !important; }

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

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

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

.margin-left-none {
  margin-left: 0 !important; }

.margin-left-tiny {
  margin-left: 1px !important; }

.margin-left-xxsmall {
  margin-left: 2px !important; }

.margin-left-xsmall {
  margin-left: 3px !important; }

.margin-left-small {
  margin-left: 4px !important; }

.margin-left-normal {
  margin-left: 5px !important; }

.margin-left-medium {
  margin-left: 6px !important; }

.margin-left-large {
  margin-left: 8px !important; }

.margin-left-xlarge {
  margin-left: 10px !important; }

.margin-left-xxlarge {
  margin-left: 12px !important; }

.margin-left-huge {
  margin-left: 25px !important; }

.margin-left-xhuge {
  margin-left: 50px !important; }

.margin-left-xxhuge {
  margin-left: 100px !important; }

/*** Icons ***/
.phone::after {
  font-family: "Material Symbols Outlined", sans-serif;
  color: #b83d14;
  content: "\e0b0";
  margin-left: 4px;
  vertical-align: tbottom; }

.email::after {
  font-family: "Material Symbols Outlined", sans-serif;
  color: #b83d14;
  content: "\e158";
  margin-left: 6px;
  vertical-align: bottom; }

.schedule::after {
  font-family: "Material Symbols Outlined", sans-serif;
  color: #b83d14;
  content: "\ebcc";
  margin-left: 6px;
  vertical-align: bottom; }

.more-info,
.more-external {
  display: inline-block;
  vertical-align: bottom; }
  .more-info::after,
  .more-external::after {
    transition: left .1s ease-in;
    display: inline-block;
    position: relative;
    font-family: "Material Symbols Outlined", sans-serif;
    color: #cc3300;
    content: "\e5c8";
    margin-left: 6px;
    vertical-align: bottom;
    left: 0;
    top: -.05em; }
  .more-info:hover::after,
  .more-external:hover::after {
    transition: all .2s ease-out;
    left: 6px;
    color: #ff6633 !important; }
  .more-info.button:hover::after,
  .more-external.button:hover::after {
    color: #ffd9cc !important; }

.more-info {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 90%; }

.more-external::after {
  content: "\e89e"; }

/*** Buttons ***/
a.button {
  transition: all .2s ease-out;
  display: inline-block;
  margin: 1em auto 0 auto;
  padding: .5em 1em;
  text-decoration: none;
  color: #cc3300;
  background-color: white;
  border: 1px solid #b83d14;
  border-radius: 2em;
  width: 100%;
  min-width: fit-content;
  max-width: 200px;
  text-align: center;
  text-transform: uppercase;
  font-size: 0.75rem;
  font-variation-settings: 'wght' 800;
  overflow-x: clip;
  overflow-y: clip;
  white-space: nowrap;
  text-overflow: ellipsis; }
  a.button:hover {
    transition: all .1s ease-in;
    color: white;
    background-color: #ff6633;
    border-color: #ff6633; }
  a.button:active {
    transition: all .1s ease-in;
    color: #cc3300;
    background-color: #ffd9cc;
    border-color: #ffd9cc; }

.description-service.button-bottom {
  display: block;
  position: relative; }

.button-link {
  display: block;
  width: auto;
  text-align: center;
  margin: 0 auto 25px auto; }
  .button-link a.button {
    display: block; }

/*** SVG Styles ***/
.stage {
  position: relative;
  z-index: 99;
  margin: 0 auto;
  overflow: hidden; }
  .stage.small {
    width: 200px !important;
    height: 200px !important; }
  .stage .figure {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    overflow: visible; }
    .stage .figure svg {
      position: absolute;
      right: 0;
      top: 0;
      width: 100%;
      height: 100%;
      overflow: visible; }
  .stage .shape {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    overflow: visible; }
    .stage .shape svg {
      position: absolute;
      right: 0;
      top: 0;
      width: 100%;
      height: 100%;
      overflow: visible; }
  .stage .illustration {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    overflow: visible; }
    .stage .illustration svg,
    .stage .illustration img {
      position: absolute;
      right: 0;
      top: 0;
      width: 100%;
      height: 100%;
      overflow: visible;
      pointer-events: all; }

.stroke circle,
.stroke path,
.stroke rect,
.stroke polygon,
.stroke ellipse {
  stroke: black;
  stroke-width: 2px; }

.fill-black circle,
.fill-black path,
.fill-black rect,
.fill-black polygon,
.fill-black ellipse {
  fill: black; }

.fill-white circle,
.fill-white path,
.fill-white rect,
.fill-white polygon,
.fill-white ellipse {
  fill: white; }

.fill-none circle,
.fill-none path,
.fill-none rect,
.fill-none polygon,
.fill-none ellipse {
  fill: transparent; }

.fill-primary-1 circle,
.fill-primary-1 path,
.fill-primary-1 rect,
.fill-primary-1 polygon,
.fill-primary-1 ellipse {
  fill: #dddbf0; }

.fill-primary-2 circle,
.fill-primary-2 path,
.fill-primary-2 rect,
.fill-primary-2 polygon,
.fill-primary-2 ellipse {
  fill: #a9a6d9; }

.fill-primary-3 circle,
.fill-primary-3 path,
.fill-primary-3 rect,
.fill-primary-3 polygon,
.fill-primary-3 ellipse {
  fill: #645eba; }

.fill-primary-4 circle,
.fill-primary-4 path,
.fill-primary-4 rect,
.fill-primary-4 polygon,
.fill-primary-4 ellipse {
  fill: #3a367d; }

.fill-primary-5 circle,
.fill-primary-5 path,
.fill-primary-5 rect,
.fill-primary-5 polygon,
.fill-primary-5 ellipse {
  fill: #191736; }

.fill-secondary-1 circle,
.fill-secondary-1 path,
.fill-secondary-1 rect,
.fill-secondary-1 polygon,
.fill-secondary-1 ellipse {
  fill: #d8d6f5; }

.fill-secondary-2 circle,
.fill-secondary-2 path,
.fill-secondary-2 rect,
.fill-secondary-2 polygon,
.fill-secondary-2 ellipse {
  fill: #9e99e6; }

.fill-secondary-3 circle,
.fill-secondary-3 path,
.fill-secondary-3 rect,
.fill-secondary-3 polygon,
.fill-secondary-3 ellipse {
  fill: #5147d1; }

.fill-secondary-4 circle,
.fill-secondary-4 path,
.fill-secondary-4 rect,
.fill-secondary-4 polygon,
.fill-secondary-4 ellipse {
  fill: #2b248f; }

.fill-secondary-5 circle,
.fill-secondary-5 path,
.fill-secondary-5 rect,
.fill-secondary-5 polygon,
.fill-secondary-5 ellipse {
  fill: #120f3d; }

.fill-gradient-1 circle,
.fill-gradient-1 path,
.fill-gradient-1 rect,
.fill-gradient-1 polygon,
.fill-gradient-1 ellipse {
  fill: linear-gradient(to bottom, black, white); }

.opacity-0 circle,
.opacity-0 path,
.opacity-0 rect,
.opacity-0 polygon,
.opacity-0 ellipse {
  opacity: .0; }

.opacity-1 circle,
.opacity-1 path,
.opacity-1 rect,
.opacity-1 polygon,
.opacity-1 ellipse {
  opacity: .2; }

.opacity-2 circle,
.opacity-2 path,
.opacity-2 rect,
.opacity-2 polygon,
.opacity-2 ellipse {
  opacity: .2; }

.opacity-3 circle,
.opacity-3 path,
.opacity-3 rect,
.opacity-3 polygon,
.opacity-3 ellipse {
  opacity: .3; }

.opacity-4 circle,
.opacity-4 path,
.opacity-4 rect,
.opacity-4 polygon,
.opacity-4 ellipse {
  opacity: .4; }

.opacity-5 circle,
.opacity-5 path,
.opacity-5 rect,
.opacity-5 polygon,
.opacity-5 ellipse {
  opacity: .5; }

.opacity-6 circle,
.opacity-6 path,
.opacity-6 rect,
.opacity-6 polygon,
.opacity-6 ellipse {
  opacity: .6; }

.opacity-7 circle,
.opacity-7 path,
.opacity-7 rect,
.opacity-7 polygon,
.opacity-7 ellipse {
  opacity: .7; }

.opacity-8 circle,
.opacity-8 path,
.opacity-8 rect,
.opacity-8 polygon,
.opacity-8 ellipse {
  opacity: .8; }

.opacity-9 circle,
.opacity-9 path,
.opacity-9 rect,
.opacity-9 polygon,
.opacity-9 ellipse {
  opacity: .9; }

.opacity-10 circle,
.opacity-10 path,
.opacity-10 rect,
.opacity-10 polygon,
.opacity-10 ellipse {
  opacity: 1; }

.rotate-0 circle,
.rotate-0 path,
.rotate-0 rect,
.rotate-0 polygon,
.rotate-0 ellipse {
  transform: rotate(0deg);
  transform-origin: center center; }

.rotate-45 circle,
.rotate-45 path,
.rotate-45 rect,
.rotate-45 polygon,
.rotate-45 ellipse {
  transform: rotate(45deg);
  transform-origin: center center; }

.rotate-90 circle,
.rotate-90 path,
.rotate-90 rect,
.rotate-90 polygon,
.rotate-90 ellipse {
  transform: rotate(90deg);
  transform-origin: center center; }

.rotate-135 circle,
.rotate-135 path,
.rotate-135 rect,
.rotate-135 polygon,
.rotate-135 ellipse {
  transform: rotate(135deg);
  transform-origin: center center; }

.rotate-180 circle,
.rotate-180 path,
.rotate-180 rect,
.rotate-180 polygon,
.rotate-180 ellipse {
  transform: rotate(180deg);
  transform-origin: center center; }

.rotate-225 circle,
.rotate-225 path,
.rotate-225 rect,
.rotate-225 polygon,
.rotate-225 ellipse {
  transform: rotate(225deg);
  transform-origin: center center; }

.rotate-270 circle,
.rotate-270 path,
.rotate-270 rect,
.rotate-270 polygon,
.rotate-270 ellipse {
  transform: rotate(270deg);
  transform-origin: center center; }

.rotate-315 circle,
.rotate-315 path,
.rotate-315 rect,
.rotate-315 polygon,
.rotate-315 ellipse {
  transform: rotate(4315deg);
  transform-origin: center center; }

.rotate-360 circle,
.rotate-360 path,
.rotate-360 rect,
.rotate-360 polygon,
.rotate-360 ellipse {
  transform: rotate(360deg);
  transform-origin: center center; }

.scale-0 svg {
  overflow: visible;
  transform: scale(0);
  transform-origin: center center; }

.scale-1 svg {
  overflow: visible;
  transform: scale(0.1);
  transform-origin: center center; }

.scale-2 svg {
  overflow: visible;
  transform: scale(0.2);
  transform-origin: center center; }

.scale-3 svg {
  overflow: visible;
  transform: scale(0.3);
  transform-origin: center center; }

.scale-4 svg {
  overflow: visible;
  transform: scale(0.4);
  transform-origin: center center; }

.scale-5 svg {
  overflow: visible;
  transform: scale(0.5);
  transform-origin: center center; }

.scale-6 svg {
  overflow: visible;
  transform: scale(0.6);
  transform-origin: center center; }

.scale-7 svg {
  overflow: visible;
  transform: scale(0.7);
  transform-origin: center center; }

.scale-8 svg {
  overflow: visible;
  transform: scale(0.8);
  transform-origin: center center; }

.scale-9 svg {
  overflow: visible;
  transform: scale(0.9);
  transform-origin: center center; }

.scale-10 svg {
  overflow: visible;
  transform: scale(1);
  transform-origin: center center; }

.scale-125 svg {
  overflow: visible;
  transform: scale(1.25);
  transform-origin: center center; }

.scale-15 svg {
  overflow: visible;
  transform: scale(1.5);
  transform-origin: center center; }

.scale-165 svg {
  overflow: visible;
  transform: scale(1.65);
  transform-origin: center center; }

.scale-175 svg {
  overflow: visible;
  transform: scale(1.75);
  transform-origin: center center; }

.scale-20 svg {
  overflow: visible;
  transform: scale(2);
  transform-origin: center center; }

/** Layout **/
body #page {
  animation-name: fadeIn;
  animation-duration: 1.25s;
  animation-delay: .35s;
  transition-timing-function: ease-in-out;
  animation-fill-mode: both;
  margin-top: 6vw; }

header.page {
  display: grid;
  width: 100%;
  grid-template-columns: 75% 25%;
  border-bottom: 1px solid #b1afcf;
  overflow: visible;
  position: relative;
  padding-bottom: 0;
  vertical-align: top; }

header #contact-global {
  overflow: visible;
  position: relative;
  top: -24px; }
  header #contact-global h2,
  header #contact-global h3 {
    font-size: calc(12px + .5vw);
    text-align: right; }
  header #contact-global nav {
    text-align: right; }
    header #contact-global nav a {
      font-size: 0.875rem;
      display: block;
      margin: 0 0 6px 0; }
      header #contact-global nav a .icon {
        color: #ffd9cc;
        margin-right: .25em;
        vertical-align: bottom; }

figure#figure-strategy {
  top: 2vh;
  width: 100%;
  max-width: 30vw;
  padding: 0 !important;
  margin: 0 auto !important;
  overflow: visible; }

#hero-inner {
  height: 45vh;
  width: calc(100% + 1vw); }

#hero-image {
  width: 40%;
  height: 100%;
  position: relative;
  top: -.5vw;
  z-index: -1;
  overflow: visible; }

#nav-global {
  margin: 6px auto;
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  align-content: center;
  text-transform: uppercase;
  vertical-align: middle; }
  #nav-global div {
    text-align: center;
    flex: auto;
    font-size: 1.25rem;
    font-variation-settings: 'wght' 700;
    border-bottom: 1px solid #b1afcf; }
    #nav-global div a {
      display: block;
      width: 100%;
      text-align: center;
      letter-spacing: .01em;
      position: relative;
      font-size: calc(12px + .5vw);
      font-family: "Sofia Sans Condensed", sans-serif;
      color: #cc3300; }
      #nav-global div a:hover {
        color: #ff6633; }
    #nav-global div:hover {
      border-bottom-color: #cc3300; }

#page-welcome .recommend#recommend-consulting-1, #page-welcome .recommend#recommend-coaching-1, #page-welcome .recommend#recommend-teaching-1 {
  display: block !important; }

#page-consulting .recommend#recommend-consulting-1, #page-consulting .recommend#recommend-consulting-2, #page-consulting .recommend#recommend-consulting-3, #page-consulting .recommend#recommend-consulting-4 {
  display: block !important; }

#page-coaching .recommend#recommend-coaching-2, #page-coaching .recommend#recommend-coaching-3, #page-coaching .recommend#recommend-coaching-4, #page-coaching .recommend#recommend-coaching-5, #page-coaching .recommend#recommend-coaching-6, #page-coaching .recommend#recommend-coaching-7, #page-coaching .recommend#recommend-coaching-8, #page-coaching .recommend#recommend-coaching-9, #page-coaching .recommend#recommend-coaching-10 {
  display: block !important; }

#page-learning .recommend#recommend-teaching-2, #page-learning .recommend#recommend-teaching-3, #page-learning .recommend#recommend-teaching-4 {
  display: block !important; }

#page-meeting .recommend#recommend-consulting-1, #page-meeting .recommend#recommend-coaching-1, #page-meeting .recommend#recommend-teaching-1 {
  display: block !important; }

#page-about .recommend#recommend-coaching-11, #page-about .recommend#recommend-coaching-12, #page-about .recommend#recommend-consulting-3, #page-about .recommend#recommend-consulting-4, #page-about .recommend#recommend-teaching-3, #page-about .recommend#recommend-teaching-4 {
  display: block !important; }

#page-welcome nav.global .page-welcome,
#page-consulting nav.global .page-consulting,
#page-coaching nav.global .page-coaching,
#page-learning nav.global .page-learning,
#page-connect nav.global .page-connect,
#page-about nav.global .page-about {
  border-bottom: 4px solid #b1afcf;
  pointer-events: none; }
  #page-welcome nav.global .page-welcome a,
  #page-consulting nav.global .page-consulting a,
  #page-coaching nav.global .page-coaching a,
  #page-learning nav.global .page-learning a,
  #page-connect nav.global .page-connect a,
  #page-about nav.global .page-about a {
    color: #2b248f;
    pointer-events: none; }
  #page-welcome nav.global .page-welcome:hover,
  #page-consulting nav.global .page-consulting:hover,
  #page-coaching nav.global .page-coaching:hover,
  #page-learning nav.global .page-learning:hover,
  #page-connect nav.global .page-connect:hover,
  #page-about nav.global .page-about:hover {
    color: #ffd9cc;
    border-bottom-color: #b83d14; }

@media (any-hover: hover) {
  #services .description-service .figure {
    filter: opacity(1);
    -webkit-transition: all 0.2s ease-in;
    -moz-transition: all 0.2s ease-in;
    -ms-transition: all 0.2s ease-in;
    -o-transition: all 0.2s ease-in; }
  #services .description-service:hover .figure {
    filter: opacity(0.2);
    -webkit-transition: all 0.2s ease-in;
    -moz-transition: all 0.2s ease-in;
    -ms-transition: all 0.2s ease-in;
    -o-transition: all 0.2s ease-in; } }

.caption-show figure figcaption {
  display: block; }

.description-service figure figcaption {
  position: absolute;
  top: 0; }

blockquote.pullquote {
  padding: .5em .25em;
  margin: .5em auto;
  max-width: 80%;
  border-top: 1px solid #b1afcf;
  border-bottom: 1px solid #b1afcf; }
  blockquote.pullquote p {
    font-style: italic; }
  blockquote.pullquote cite {
    font-style: italic;
    font-size: 0.75rem; }

.service:before {
  content: "";
  display: block;
  width: 100%;
  height: fit-content;
  background-color: #f6f5f9;
  padding: 4px 4px 3px 10px;
  border: 0;
  border-radius: 2em;
  margin: 10px 0;
  font-size: 0.6rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: #1e1d30; }

.service__consulting:before {
  content: "consulting"; }

.service__coaching:before {
  content: "coaching"; }

.service__teaching:before {
  content: "learning"; }

#clients .client-list {
  display: grid;
  width: 100%;
  gap: 6px;
  border: 0;
  vertical-align: middle;
  align-content: center;
  align-items: center;
  align-self: center;
  grid-template-rows: repeat(1, 1fr); }
  #clients .client-list .logo-client {
    width: 100%;
    float: left;
    padding: 6px;
    box-sizing: border-box;
    width: 100%;
    border: none !important;
    transition: all .2s ease-in;
    text-align: center;
    vertical-align: middle;
    display: none; }
    #clients .client-list .logo-client img {
      text-align: center;
      max-width: 95%;
      vertical-align: middle;
      filter: grayscale(1);
      transform: scale(1);
      transition: .6s all ease-in-out;
      margin: 1em auto;
      padding: 6px;
      vertical-align: middle;
      opacity: .6; }
    #clients .client-list .logo-client:hover img {
      opacity: 1;
      transition: .6s all ease-in-out;
      transform: scale(1.02);
      filter: grayscale(0); }

#clients .col-1 .client-list {
  grid-template-columns: 100%; }

#clients .col-2 .client-list {
  grid-template-columns: 50% 50%; }

#clients .col-3 .client-list {
  grid-template-columns: 33% 33% 33%; }

#clients .col-4 .client-list {
  grid-template-columns: 25% 25% 25% 25%; }

#clients .col-5 .client-list {
  grid-template-columns: 20% 20% 20% 20% 20%; }

#page-welcome .logo-client.show-welcome {
  display: inline-block !important; }

#page-strategy .logo-client.show-strategy {
  display: inline-block !important; }

#page-advice .logo-client.show-advice {
  display: inline-block !important; }

#page-training .logo-client.show-training {
  display: inline-block !important; }

#page-about .logo-client {
  display: inline-block !important; }

.tagline strong {
  font-variation-settings: 'wght' 800; }

.tagline-sub {
  display: block;
  margin: 0 0 -.1em 0;
  display: block;
  font-size: 1.5rem;
  font-variation-settings: 'wght' 300; }

.col-flex {
  align-content: center;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  margin: 0 auto;
  width: 100%;
  gap: 12px; }
  .col-flex div {
    margin: 0 auto;
    flex: 1;
    flex-grow: initial;
    flex-shrink: initial;
    flex-basis: 11.5%;
    width: 100%;
    min-width: 100px; }
    .col-flex div img {
      margin: 0 0 8px 0; }

.col-grid {
  display: grid;
  align-items: stretch;
  width: 100%;
  grid-template-rows: auto;
  transition: all .2s ease-in-out;
  transition-property: all;
  transition-timing-function: ease-in-out;
  transition-duration: 0.2s;
  overflow: hidden; }
  .col-grid > div {
    padding: 25px;
    border-right: 1px solid #b1afcf;
    border-bottom: 1px solid #b1afcf;
    gap: 0; }
    .col-grid > div .stage {
      width: 100%;
      max-width: 400px;
      aspect-ratio: 1 / 1; }
    .col-grid > div.span-col-2 {
      grid-column-end: span 2 !important; }
    .col-grid > div.span-col-3 {
      grid-column-end: span 3 !important; }
      .col-grid > div.span-col-3 .copy-body {
        margin: 5% 5% 0 0; }
    .col-grid > div.span-col-4 {
      grid-column-end: span 4; }
      .col-grid > div.span-col-4 .stage {
        width: 35vw;
        height: 100%; }
    .col-grid > div.span-row-2 {
      grid-row-end: span 2 !important; }
    .col-grid > div.span-row-3 {
      grid-row-end: span 3; }
    .col-grid > div.span-row-4 {
      grid-row-end: span 4; }
    .col-grid > div.span-row-5 {
      grid-row-end: span 5; }
    .col-grid > div.span-row-6 {
      grid-row-end: span 6; }
    .col-grid > div.span-row-7 {
      grid-row-end: span 7; }
  .col-grid__columns-2 {
    grid-template-columns: 50% 50%; }
    .col-grid__columns-2 > div:nth-child(2) {
      border-right: none; }
    .col-grid__columns-2 > div.span-col-2 + div:nth-child(1) {
      border-right: none; }
  .col-grid__columns-3 {
    grid-template-columns: 33% 33% 33%;
    transition-property: all;
    transition-timing-function: ease-in-out;
    transition-duration: 0.2s;
    transition-delay: 0.1s; }
    .col-grid__columns-3 p {
      max-width: 38em;
      font-size: 0.875rem;
      margin: .875em 0; }
    .col-grid__columns-3 > div:nth-child(3) {
      border-right: none; }
    .col-grid__columns-3 > div.span-col-2 + div:nth-child(2) {
      border-right: none; }
    .col-grid__columns-3 > div.span-col-3 + div:nth-child(1) {
      border-right: none; }
    .col-grid__columns-3:has(div#cell1:hover) {
      grid-template-columns: 50% 25% 25%;
      transition-property: all;
      transition-timing-function: ease-in-out;
      transition-duration: 0.2s;
      transition-delay: 0.2s; }
    .col-grid__columns-3:has(div#cell2:hover) {
      grid-template-columns: 25% 50% 25%;
      transition-property: all;
      transition-timing-function: ease-in-out;
      transition-duration: 0.2s;
      transition-delay: 0.2s; }
    .col-grid__columns-3:has(div#cell3:hover) {
      grid-template-columns: 25% 25% 50%;
      transition-property: all;
      transition-timing-function: ease-in-out;
      transition-duration: 0.2s; }
    .col-grid__columns-3 div:hover .content-teaser {
      opacity: 1;
      z-index: 1000;
      transition-property: all;
      transition-timing-function: ease-in-out;
      transition-duration: 0.2s;
      transition-delay: 0.35s; }
  .col-grid__columns-4 {
    grid-template-columns: 25% 25% 25% 25%; }
    .col-grid__columns-4 > div:nth-child(4) {
      border-right: none; }
    .col-grid__columns-4 > div.span-col-2 + div:nth-child(3) {
      border-right: none; }
    .col-grid__columns-4 > div.span-col-2 + div.span-col-2 {
      border-right: none; }
    .col-grid__columns-4 > div.span-col-3 + div:nth-child(2),
    .col-grid__columns-4 > div:nth-child(2).span-col-3 {
      border-right: none; }
    .col-grid__columns-4 > div.span-col-4 + div:nth-child(1) {
      border-right: none; }
  .col-grid__columns-5 {
    grid-template-columns: repeat(5, 1fr); }
  .col-grid__columns-6 {
    grid-template-columns: repeat(6, 1fr); }
  .col-grid__columns-7 {
    grid-template-columns: repeat(7, 1fr); }
  .col-grid__columns-8 {
    grid-template-columns: repeat(8, 1fr); }

.col-grid-2 {
  display: grid;
  grid-template-columns: 50% 50%; }
  .col-grid-2 div {
    align-content: center;
    width: 100%;
    padding: 0;
    margin: 0;
    border: none; }

.columns-2 {
  columns: 2; }
  .columns-2 li {
    break-inside: avoid; }

.description-service {
  position: relative; }
  @media (any-hover: hover) {
    .description-service .figure {
      filter: opacity(0.6);
      -webkit-transition: all 0.2s ease-in;
      -moz-transition: all 0.2s ease-in;
      -ms-transition: all 0.2s ease-in;
      -o-transition: all 0.2s ease-in; }
    .description-service:hover .figure {
      filter: opacity(1);
      -webkit-transition: all 0.2s ease-in;
      -moz-transition: all 0.2s ease-in;
      -ms-transition: all 0.2s ease-in;
      -o-transition: all 0.2s ease-in; } }

.recommend {
  display: none; }
  .recommend.show {
    display: block; }

.sidebar p,
.sidebar li {
  font-size: 0.875rem;
  line-height: 1.2; }

footer.page .subscribe {
  height: fit-content;
  width: 100%;
  margin-top: -10px; }
  footer.page .subscribe iframe {
    width: 100%;
    height: 300px;
    margin-top: 0; }
  footer.page .subscribe h2,
  footer.page .subscribe h3 {
    font-size: 1.5rem;
    padding: .5em 0 .25em 0;
    margin: 0;
    width: 100%;
    background-color: #3a367d;
    color: white;
    text-align: center;
    border: none; }
  footer.page .subscribe h3 {
    font-size: calc(12px + .5vw);
    color: #d8d6f5;
    padding-top: 0; }

article.copy-body {
  position: relative; }

article.content-teaser {
  opacity: 0;
  position: absolute;
  top: 0;
  right: 0;
  padding: 50px;
  background-color: rgba(255, 255, 255, 0);
  width: 100%;
  height: 100%;
  min-height: fit-content;
  transition-property: all;
  transition-timing-function: ease-in-out;
  transition-duration: 0.2s; }
  article.content-teaser h3 {
    text-align: center; }

header.page #ct-logo img {
  width: 25vw;
  vertical-align: middle; }

article.page {
  max-width: 100vw; }

footer.module {
  border-top: 1px solid #b1afcf !important;
  padding-top: 5px !important;
  margin-top: 10px !important;
  font-size: 0.875rem; }

footer.page {
  display: block;
  height: fit-content;
  width: 100%;
  max-width: unset;
  overflow: hidden;
  position: relative;
  margin-top: 0;
  padding-top: 6px;
  clear: both; }
  footer.page p {
    font-size: .75rem;
    text-align: center;
    width: fit-content;
    max-width: unset;
    margin: 0 auto; }

/*********** RESPONSIVE ***************/
#header-global-mobile,
#toggle-mobile {
  display: none; }

@media screen {
  body #page {
    overflow-x: hidden; }
  body.menu-closed article#page {
    opacity: 1 !important; }
  body.menu-closed #header-global-mobile {
    width: 0;
    opacity: 0;
    left: unset;
    transition-delay: opacity;
    pointer-events: none; }
  body.menu-open {
    overflow: hidden; }
    body.menu-open article#page {
      opacity: .8 !important; }
    body.menu-open #toggle-mobile {
      background-color: transparent;
      border-color: transparent;
      border-bottom-width: 0;
      border-left-width: 0;
      border-top-width: 60px;
      border-right-width: 60px;
      box-shadow: none;
      pointer-events: all;
      transition: all .2s ease-out; }
      body.menu-open #toggle-mobile:before {
        content: "\e5cd"; }
  #toggle-mobile {
    position: fixed;
    z-index: 1000;
    display: block;
    top: 1vw;
    right: calc((100vw - 1440px)/2);
    cursor: pointer;
    width: 0;
    height: 0;
    background-color: #f6f5f9;
    border-bottom: #f6f5f9 30px solid;
    border-left: #f6f5f9 30px solid;
    border-top: white 30px solid;
    border-right: white 30px solid;
    border-radius: 0 1vw;
    box-shadow: 0 0 5px rgba(0, 0, 0, 0.8); }
    #toggle-mobile:before {
      font-family: "Material Symbols Outlined", sans-serif;
      font-size: 140%;
      content: "\e9bd";
      position: fixed;
      top: 1.25vw;
      right: calc((100vw - 1430px)/2);
      color: #cc3300;
      z-index: 1001;
      pointer-events: none;
      background-color: transparent; }
  #header-global {
    position: fixed;
    top: 2.5vw;
    left: calc((100vw - 1440px)/2);
    z-index: 100;
    width: fit-content;
    height: auto;
    background-color: rgba(246, 245, 249, 0.6);
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px);
    padding: 6px 2vw;
    border: 1px solid #f6f5f9;
    border-radius: 0 5em 5em 0;
    text-align: center; }
    #header-global h1 {
      width: 100%;
      font-size: 0;
      text-align: center; }
    #header-global #ct-logo img {
      position: relative;
      right: 8px;
      width: 25vw;
      max-width: 500px;
      min-width: 50%;
      margin: 0 auto; }
    #header-global #contact {
      display: none; }
  #header-global-mobile {
    position: fixed;
    top: 1vw;
    right: calc((100vw - 1440px)/2);
    left: unset;
    z-index: 99;
    pointer-events: all;
    opacity: 1;
    display: block;
    width: 100%;
    max-width: 1440px;
    height: calc(100% - 2vw);
    overflow: scroll;
    background-color: rgba(255, 255, 255, 0.8);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
    padding: 3vh 6vw 0 6vw;
    border: none;
    border-radius: 2vw;
    transition: all .3s ease-out;
    overflow-x: hidden; }
    #header-global-mobile #nav-global {
      display: block;
      margin: 5vw 0 100px 0;
      flex-direction: column;
      font-variation-settings: 'wght' 400; }
      #header-global-mobile #nav-global div {
        width: 100%;
        text-align: left;
        margin: 1em auto; }
        #header-global-mobile #nav-global div a {
          display: block;
          font-family: "Sofia Sans Condensed", sans-serif;
          width: 100%;
          text-align: left;
          position: relative;
          font-size: 1.5rem;
          font-variation-settings: 'wght' 300; }
          #header-global-mobile #nav-global div a:hover {
            color: #ff6633; }
        #header-global-mobile #nav-global div:hover {
          border-bottom-color: #cc3300; }
    #header-global-mobile #contact {
      display: block;
      width: 100%;
      overflow-x: hidden; }
      #header-global-mobile #contact h2 {
        margin-bottom: 6px;
        text-align: right;
        font-variation-settings: 'wght' 300; }
      #header-global-mobile #contact nav {
        text-align: right; }
        #header-global-mobile #contact nav a {
          font-family: "Sofia Sans Condensed", sans-serif;
          font-size: 1.25rem;
          display: block;
          margin: 10px 0 10px 0;
          line-height: 1; }
          #header-global-mobile #contact nav a .icon {
            font-size: 1.25rem;
            color: #64609f; }
  #nav-global {
    display: none; } }

@media screen and (max-width: 1470px) {
  #header-global {
    left: 1vw; }
  #toggle-mobile {
    right: 1vw; }
    #toggle-mobile:before {
      right: calc(1vw + .25em); } }

@media screen and (max-width: 1112px) {
  .description-service .figure {
    filter: brightness(1) !important; }
  .col-flex div {
    flex-basis: 33%; } }

@media screen and (max-width: 1024px) {
  #header-global #ct-logo img {
    width: 40vw; }
  article .description-service {
    border-right: none;
    grid-column-end: span 3;
    width: 100%; }
    article .description-service .stage {
      text-align: center;
      margin: 0 auto;
      z-index: 0;
      float: none; }
      article .description-service .stage .figure {
        opacity: 1;
        filter: brightness(1) !important; }
  article .content-teaser {
    display: block !important;
    opacity: 1;
    z-index: 99; }
  #services .description-service .stage .figure {
    opacity: .25 !important; }
  .col-grid__columns-4 {
    grid-template-columns: 33% 33% 33%; }
    .col-grid__columns-4 > div {
      grid-column-end: span 1 !important; }
      .col-grid__columns-4 > div.span-col-2 {
        grid-column-end: span 1 !important; }
  #clients .logo-client {
    opacity: 1;
    filter: none; }
    #clients .logo-client img {
      opacity: 1 !important;
      filter: none !important; }
  .page .col-grid-2 {
    grid-template-columns: 100%; }
    .page .col-grid-2 h1 {
      text-align: center; }
    .page .col-grid-2 .bg-figure {
      width: fit-content;
      margin: 0 auto 2em auto; }
  .footer-padding {
    display: block;
    height: 100px; }
  .col-grid div.span-col-3 .stage,
  .col-grid div.span-col-4 .stage {
    width: 50vw;
    height: 50vw;
    margin: 0 auto 25px auto; }
  .button-link a.button {
    padding-left: 1em;
    padding-right: 1em;
    margin: .5em auto;
    font-size: 1.25rem; } }

@media screen and (max-width: 855px) {
  .page .col-grid {
    grid-template-columns: 100%; }
    .page .col-grid .sidebar p,
    .page .col-grid .sidebar li {
      font-size: calc(12px + .5vw); }
    .page .col-grid #aside-2 {
      order: 4; }
    .page .col-grid div.span-col-2 {
      grid-column-end: unset !important; }
    .page .col-grid div.span-col-3 {
      grid-column-end: unset !important; }
    .page .col-grid div.span-col-4 {
      grid-column-end: unset !important; }
    .page .col-grid div.span-row-2 {
      grid-row-end: unset !important; }
    .page .col-grid div.span-row-3 {
      grid-row-end: unset !important; }
    .page .col-grid div.span-row-4 {
      grid-row-end: unset !important; }
    .page .col-grid div.span-row-5 {
      grid-row-end: unset !important; }
  footer.module {
    margin: 8px 0 25px 0; } }

@media screen and (max-width: 768px) {
  #hero #hero-inner {
    height: fit-content;
    width: 100%; }
  #hero #hero-image {
    display: block !important;
    float: none !important;
    height: fit-content; }
  #hero #hero-message {
    width: 100%;
    height: auto;
    padding-right: 0; } }

@media screen and (max-width: 640px) {
  .col-grid div.span-col-3 .stage {
    width: 60vw;
    height: 60vw;
    margin: 0 auto 25px auto; }
  .col-grid div.span-col-4 .stage {
    width: 90vw;
    height: 90vw;
    margin: 0 auto 25px auto; }
  .page .description-service .stage {
    float: unset;
    clear: both; }
  .col-grid div.span-col-4 .stage {
    width: 80vw;
    height: 80vw; } }

@media screen and (max-width: 520px) {
  .col-grid div.span-col-4 .stage {
    width: 80vw;
    height: 80vw;
    margin: 0 auto 25px auto; }
  #teaser {
    font-size: 6rem; }
  .button-link a.button {
    padding-left: 2em;
    padding-right: 2em;
    margin: .5em auto;
    font-size: 1.25rem; } }
