/* === FONTS (self-hosted) === */
@font-face {
  font-family: 'Bellota';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url('/fonts/bellota-300.woff2') format('woff2');
}
@font-face {
  font-family: 'Bellota';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('/fonts/bellota-400.woff2') format('woff2');
}
@font-face {
  font-family: 'Bellota';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url('/fonts/bellota-700.woff2') format('woff2');
}
@font-face {
  font-family: 'Raleway';
  font-style: normal;
  font-weight: 300 700;
  font-display: swap;
  src: url('/fonts/raleway-variable.woff2') format('woff2');
}

/* === RESET & BASE === */
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  font-family: 'Raleway', 'Segoe UI', system-ui, -apple-system, sans-serif;
  font-weight: 400;
  font-size: 16px;
  line-height: 1.8;
  color: #222;
  background: #fff;
  -webkit-font-smoothing: antialiased;
  max-width: 100%;
  overflow-x: hidden;
}
img { max-width: 100%; height: auto; display: block; border: 0; }
a { text-decoration: none; color: #66B0B2; }
a:hover { text-decoration: underline; }
p { margin: 0 0 1em; }
strong { font-weight: 700; }
ul { list-style: none; padding: 0; }

/* === LAYOUT === */
.container { max-width: 1200px; margin: 0 auto; padding: 0 20px; }
.content-width { max-width: 680px; margin: 0 auto; }

/* === TYPOGRAPHY === */
h1, h2 { font-family: 'Bellota', cursive; font-weight: 400; line-height: 1.4; color: #66B0B2; }
h1 { font-size: 32px; margin-bottom: 20px; }
h2 { font-size: 28px; margin-bottom: 20px; }
h3, h4 { font-family: 'Raleway', sans-serif; font-weight: 700; line-height: 1.4; color: #66B0B2; }
h3 { font-size: 20px; margin-bottom: 15px; }
h4 { font-size: 18px; margin-bottom: 10px; }

@media (min-width: 768px) {
  h1 { font-size: 42px; }
  h2 { font-size: 36px; }
}

/* === PHOENIX HEADER (desktop) === */
.header-client-styling .basic-header-styling .header-item-placement { display: flex; align-items: center; width: 100%; }
.header-client-styling .desktop-logo { height: 60px; display: inline-flex; align-items: center; }
.header-client-styling .desktop-logo img { max-height: 60px; object-fit: contain; object-position: left; }
.header-client-styling .menu-bar { display: flex; justify-content: flex-end; align-items: center; width: 100%; }
.header-client-styling .menu-link-styling { color: unset; }
.header-client-styling .menu-item {
  -webkit-touch-callout: none; border-radius: 3px; padding: 15px;
  padding-top: 20px; padding-bottom: 20px; position: relative;
  font-size: 14px; text-align: center; display: inline-flex;
  justify-content: center; align-items: center;
}
.header-client-styling .sub-menu-container {
  padding: 0; position: absolute; top: 58px; background: #323232;
  min-width: 250px; display: none; z-index: 307;
  margin-left: 10px; margin-right: 10px; border-radius: 3px;
  filter: drop-shadow(0 5px 10px rgba(0,0,0,.1));
}
.header-client-styling .sub-menu-container:before {
  width: 0; content: ""; border-style: solid; transform: rotate(180deg);
  border-width: 11px 11px 0; border-color: #323232 transparent transparent;
  position: absolute; top: -10px; left: 20px;
}
.header-client-styling .menu-list { position: relative; float: left; display: inline-block; border-radius: 3px; }
.header-client-styling .sub-menu-item {
  -webkit-touch-callout: none; padding: 25px 25px 20px 25px;
  display: block; text-align: left; color: #fff; position: relative;
  background-color: #323232;
}
.header-client-styling .sub-menu-item:hover { background-color: #444; }
.header-client-styling .sub-menu-triangle { padding-right: 30px; }
.header-client-styling .sub-menu-triangle:before {
  width: 0; height: 0; content: "\25BE"; position: absolute;
  top: 20px; margin: auto; right: 20px;
}
.header-client-styling .preview-header-item {
  display: flex; align-items: center; z-index: 4000;
  position: relative; background: #fff; box-shadow: 0 0 15px rgba(0,0,0,.2);
}
.header-client-styling .small-size-header { height: 84px; }
.header-client-styling .small-size-header .desktop-logo { height: 60px; display: inline-flex; align-items: center; }
.header-client-styling .small-size-header .desktop-logo img { max-height: 60px; object-fit: contain; object-position: left; margin-right: -140px; }
.header-client-styling .cta-header-button {
  box-shadow: rgba(0,0,0,.2) 0 2px 1px; padding: 10px 20px;
  border-radius: 5px; background: #ff9b00; font-weight: 500;
  position: relative; text-decoration: none; display: inline-block;
}
.header-client-styling .normal-width-header { max-width: 1170px; margin: auto; }
.header-client-styling .fixed { position: fixed; width: 100%; z-index: 305; }
.header-client-styling .background-effect {
  padding-top: 13px; padding-bottom: 13px; margin-top: 7px; margin-bottom: 7px;
}
.header-client-styling .background-effect.sub-menu-triangle { padding-right: 30px; }
.header-client-styling .background-effect.sub-menu-triangle:before {
  width: 0; height: 0; content: "\25BE"; position: absolute;
  top: 12px; margin: auto; right: 20px;
}
.header-client-styling .menu-item.has-no-text { padding: 0; min-width: 0; width: 0; }
.header-client-styling .menu-bar { font-family: 'Raleway', sans-serif; }
.header-client-styling .sub-menu-container { background: #323232; top: 44px; }

/* === ACTIEVE PAGINA MARKERING === */
body[data-page="trainingen"] .menu-list[data-nav="trainingen"] .menu-item,
body[data-page="modules"] .menu-list[data-nav="modules"] .menu-item,
body[data-page="workshops"] .menu-list[data-nav="workshops"] .menu-item,
body[data-page="over"] .menu-list[data-nav="over"] .menu-item,
body[data-page="inspiratie"] .menu-list[data-nav="inspiratie"] .menu-item,
body[data-page="studio"] .menu-list[data-nav="studio"] .menu-item {
  color: #66B0B2 !important;
}
body[data-page="trainingen"] [data-nav="trainingen"] .top-level-name,
body[data-page="modules"] [data-nav="modules"] .top-level-name,
body[data-page="workshops"] [data-nav="workshops"],
body[data-page="over"] [data-nav="over"] .top-level-name,
body[data-page="inspiratie"] [data-nav="inspiratie"] .top-level-name,
body[data-page="studio"] [data-nav="studio"] .top-level-name {
  color: #66B0B2 !important;
}

/* Header spacing for fixed nav */
body { padding-top: 84px; }

/* === PHOENIX HEADER (desktop/mobile toggles) === */
@media (min-width: 1024px) {
  .header-client-styling .mobile-header { display: none; }
  .header-client-styling .basic-header-styling { display: block; position: relative; z-index: 305; }
}
@media (max-width: 1023px) {
  .header-client-styling .mobile-header { display: block; width: 100%; height: 64px; position: relative; z-index: 305; }
  .header-client-styling .basic-header-styling { display: none; }
  body { padding-top: 64px; }
}

/* === PHOENIX HEADER (mobile) === */
.header-client-styling .mobile-header-bar {
  display: flex; width: 100%; align-items: center;
  padding: 10px 24px; box-shadow: 0 0 10px rgba(0,0,0,.2);
  position: fixed; z-index: 20;
}
.header-client-styling .mobile-header-menu-bar { display: flex; justify-content: flex-end; align-items: center; width: 100%; }
.header-client-styling .mobile-menu-item-container { display: none; }
.header-client-styling .mobile-menu-item-container .mobile-bottom-flex {
  display: flex; align-items: center; justify-content: space-between;
  border-top: 1px solid rgba(0,0,0,.1);
}
.header-client-styling .mobile-menu-item-container .mobile-cta-button { margin-left: 10px; display: inline-block; }
.header-client-styling .burger-menu-icon {
  -webkit-touch-callout: none; padding: 5px; width: 44px; border-radius: 3px; cursor: pointer;
}
.header-client-styling .burger-menu-icon i { font-size: 30px; position: relative; left: 4px; }
.header-client-styling .mobile-logo img { height: 40px; object-fit: contain; object-position: left; }
@media (max-width: 500px) {
  .header-client-styling .mobile-logo img { max-width: 250px; height: auto; max-height: 40px; }
}
.header-client-styling .top-mobile-template { top: 0; }
.header-client-styling .top-mobile-template .mobile-menu-item-container {
  box-shadow: 0 0 10px rgba(0,0,0,.2); max-width: 100%; margin: auto;
  border-radius: 0; border-top: 2px solid rgba(0,0,0,.2);
  position: fixed; width: 100%; z-index: -1; top: 57px; overflow-y: scroll;
}
@media (max-height: 600px) {
  .header-client-styling .top-mobile-template .mobile-menu-item-container { bottom: 0; }
}
.header-client-styling .top-mobile-template .mobile-menu-item-container .mobile-menu-nav-item {
  -webkit-touch-callout: none; font-size: 15px; padding: 18px 18px 18px 30px;
  border-top: 1px solid rgba(0,0,0,.1); font-weight: 300; cursor: pointer;
}
.header-client-styling .top-mobile-template .mobile-menu-item-container .mobile-menu-nav-item .mobile-submenu-nav-item {
  font-size: 13px; padding: 10px 10px 10px 40px; margin-top: 10px;
}
.header-client-styling .mobile-sub-menu-wrapper { display: none; }
.header-client-styling .mobile-menu-nav-item.has-sub-menu { padding: 0; }
.header-client-styling .mobile-menu-nav-item.has-sub-menu .mobile-sub-menu-wrapper:last-child { padding-bottom: 20px; }
.header-client-styling .mobile-menu-nav-item.has-sub-menu .top-level-name { padding: 18px 18px 18px 30px; cursor: pointer; }
.header-client-styling .mobile-menu-nav-item.has-sub-menu .top-level-name:after { content: "\25BE"; font-weight: 900; margin-left: 10px; }
@media (max-width: 970px) {
  .header-client-styling .mobile-menu-item-container .mobile-cta-button .cta-header-button { font-size: 12px; }
}

/* === PHOENIX FOOTER === */
.footer-wrapper { font-family: 'Raleway', sans-serif; }
.footer-wrapper .footer-row { padding: 30px 0; }
.footer-wrapper .footer-row-inner {
  max-width: 1170px; margin: 0 auto; padding: 0 20px;
  display: flex; gap: 40px;
}
.footer-wrapper .footer-row-inner.align-items-flex-start { align-items: flex-start; }
.footer-wrapper .footer-column { flex: 1; min-width: 0; }
.footer-wrapper .footer-spot { margin-bottom: 15px; }
.footer-wrapper .footer-spot.font-size-small h3 { font-size: 16px; font-family: 'Raleway', sans-serif; color: #FFFFFF; }
.footer-wrapper .footer-spot.font-size-standard .element-menu,
.footer-wrapper .footer-spot.font-size-standard p,
.footer-wrapper .footer-spot.font-size-standard span {
  font-size: 15px; font-family: 'Raleway', sans-serif;
}
.footer-wrapper .footer-spot.font-size-large p { font-size: 18px; }
.footer-wrapper .element-menu ul { list-style: none; padding: 0; margin: 0; }
.footer-wrapper .element-menu li { margin-bottom: 5px; }
.footer-wrapper .element-menu a { color: inherit; text-decoration: none; }
.footer-wrapper .element-menu a:hover { text-decoration: underline; }
.footer-wrapper .element-menu a span { color: inherit; }
.footer-wrapper .element-address ul { list-style: none; padding: 0; }
.footer-wrapper .element-address li { margin-bottom: 8px; display: flex; align-items: center; gap: 10px; }
.footer-wrapper .element-address i { width: 20px; text-align: center; }
.footer-wrapper .element-address a { color: inherit; }
.footer-wrapper .element-social a {
  display: inline-flex; align-items: center; justify-content: center;
  width: 40px; height: 40px; border-radius: 50%; margin-right: 8px;
  font-size: 18px; text-decoration: none;
}
.footer-wrapper .element-search .searchform { display: flex; gap: 0; }
.footer-wrapper .element-search input[type="text"] {
  flex: 1; padding: 8px 12px; border: 1px solid #555;
  background: #444; color: #fff; border-radius: 3px 0 0 3px;
  font-size: 14px;
}
.footer-wrapper .element-search input[type="text"]::placeholder { color: #aaa; }
.footer-wrapper .element-search button {
  padding: 8px 14px; background: #555; color: #fff;
  border: 1px solid #555; border-left: 0; border-radius: 0 3px 3px 0;
  cursor: pointer;
}
.primary-c-bg { background: #66b0b2; color: #fff; }
.secondary-c-bg { background: #7a7a7a; }
.secondary-c-contrast-txt { color: #fff; }

@media (max-width: 767px) {
  .footer-wrapper .footer-row-inner { flex-direction: column; gap: 20px; }
}

/* === SECTIONS (shared) === */
.section { padding: 60px 0; }
.section--grey { background: #F5F5F5; }
.section--white { background: #FFFFFF; }
.text-center { text-align: center; }
