/* 
  Theme Name: Cut School 
  Author: Luuk Kloosterboer - zesvoetvier based on a design by undog
  Author URI: http://www.zesvoetvier.nl
  Version: 1.0

*/
/* basic less set-up */
@font-face {
  font-family: 'Rhode';
  /* A name you choose for your font */
  src: url('./type/rhode-mediumcondensed.otf') format('opentype'), /* Path to your OTF file */ url('./type/rhode-mediumcondensed.ttf') format('truetype');
  /* Path to your TTF file */
  font-weight: normal;
  /* Define the weight (e.g., normal, bold, 400, 700) */
  font-style: normal;
  /* Define the style (e.g., normal, italic) */
}
/* font face */
.hidden {
  -ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=0) !important;
  filter: alpha(opacity=0) !important;
  -webkit-opacity: 0 !important;
  -moz-opacity: 0 !important;
  opacity: 0 !important;
  pointer-events: none;
}
.shown {
  -ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=100) !important;
  filter: alpha(opacity=100) !important;
  -webkit-opacity: 1 !important;
  -moz-opacity: 1 !important;
  opacity: 1 !important;
  pointer-events: auto;
}
.mobile-only {
  display: none;
}
.tablet-only {
  display: none;
}
/* basic set-up */
body {
  background-color: #F2EAC5;
  color: #000000;
  font-family: Georgia, serif;
  font-weight: 300;
  font-style: normal;
  font-weight: 16px;
  line-height: 1.7em;
  margin: 0;
  text-align: left;
  width: 100%;
}
img,
img a {
  border: none;
  border-style: none;
  box-shadow: none;
}
p {
  margin: 0 0 1.2em 0;
}
a img {
  border: none;
  border-style: none;
  background: none;
  box-shadow: none;
}
a {
  color: #000000;
  font-weight: bold;
}
a:hover {
  animation: flicker 1.5s ease-in-out 1 forwards;
}
a:active,
a:focus,
input {
  outline: none;
}
h1 {
  font-family: Rhode, serif;
  font-style: normal;
  font-size: 3em;
  line-height: 1em;
  font-weight: normal;
}
h2 {
  font-family: Georgia, serif;
  font-weight: 600;
  font-style: normal;
  font-weight: normal;
  font-size: 1.083em;
}
td,
tr,
table {
  border: none;
}
img.alignright {
  float: right;
  margin: 0 0 1em 2em;
}
img.alignleft {
  float: left;
  margin: 0 2em 1em 0;
}
img.aligncenter {
  display: block;
  margin-left: auto;
  margin-right: auto;
}
.alignright {
  float: right;
}
.alignleft {
  float: left;
}
.aligncenter {
  display: block;
  margin-left: auto;
  margin-right: auto;
}
/*************************/
/* Basic structure       */
/*************************/
.wrapper-colored,
.wrapper-solution {
  width: 100%;
  position: relative;
  overflow: auto;
}
.color-yellow {
  background-color: #F2EAC5;
}
.color-yellow .control-button {
  color: #F2EAC5;
}
.color-blue {
  background-color: #95D5F1;
}
.color-blue .control-button {
  color: #95D5F1;
}
.color-green {
  background-color: #C4E9C9;
}
.color-green .control-button {
  color: #C4E9C9;
}
.wrapper-solution {
  background-color: #FFD7C8 !important;
}
.wrapper-solution {
  background-color: #FFD7C8 !important;
}
/*************************/
/* Layout header & menu  */
/*************************/
#header-container {
  font-family: Rhode, serif;
  font-style: normal;
  width: 100%;
  display: block;
  padding-top: 40px;
  background-color: #F2EAC5;
  z-index: 100;
}
#header-container .logo {
  background-image: url('images/CutSchool-logo.png');
  background-repeat: no-repeat;
  background-size: 100% auto;
  width: 30%;
  aspect-ratio: 4 / 1;
  margin: 0 auto;
}
#header-container .tagline {
  width: 30%;
  font-size: calc(100vw / (1440 / 15.8));
  margin: 0 auto 20px;
}
#header-container .tagline a {
  color: #000000;
  text-decoration: none;
}
#header-container .tagline a.intro-underline {
  border-bottom: 5px solid #000000;
}
#header-container .tagline a.intro-underline:hover {
  animation: flicker 1.5s ease-in-out 1 forwards;
}
@keyframes flicker {
  0%,
  100% {
    color: black;
    border-color: black;
  }
  10%,
  30%,
  50%,
  60% {
    color: white;
    border-color: white;
  }
  20%,
  40%,
  55%,
  90% {
    color: black;
    border-color: black;
  }
  80% {
    color: white;
    border-color: white;
  }
}
@keyframes flickerHover {
  0%,
  100% {
    color: black;
    border-color: black;
  }
  10%,
  30%,
  50%,
  60% {
    color: white;
    border-color: white;
  }
  20%,
  40%,
  55%,
  90% {
    color: black;
    border-color: black;
  }
  80% {
    color: white;
    border-color: white;
  }
}
#header-container .devider {
  width: 40%;
  margin: 0 auto;
  border-top: 11px solid #000000;
}
/***************************/
/* Layout center           */
/***************************/
/***************************/
/* Layout side items       */
/***************************/
.side-container {
  position: fixed;
  width: 24%;
  right: 3%;
  top: 0;
  min-height: 600px;
  z-index: 50;
}
.side-container .solution-rectangle {
  position: absolute;
  top: 220px;
  background-color: #000000;
  color: #FFFFFF;
  padding: 20px;
  display: inline-block;
  width: calc(100% - 40px);
}
.side-container .solution-rectangle .solution-button {
  font-family: Rhode, serif;
  font-style: normal;
  font-size: clamp(16px, 2.35vw, 36px);
  color: #FFFFFF;
  cursor: pointer;
  padding-top: 4px;
  padding-bottom: 20px;
  border-bottom: 8px solid #FFFFFF;
}
.side-container .solution-quote-wrapper {
  position: relative;
  min-height: 2em;
  width: 100%;
}
.side-container .solution-quote-wrapper .solution-quote {
  display: block;
  font-size: clamp(16px, 2.35vw, 36px);
  line-height: 1.1em;
  opacity: 0;
  pointer-events: none;
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  transform: translateY(-30px);
  transition: all 0.4s ease;
  border-bottom: 10px solid #000000;
  padding-bottom: 10px;
}
.side-container .solution-quote-wrapper .solution-quote.active {
  opacity: 1;
  pointer-events: auto;
}
.side-container .solution-quote-wrapper .solution-quote.slide-in-top {
  transform: translateY(0);
}
.side-container .solution-quote-wrapper .solution-quote.fading-out {
  opacity: 0;
  transform: translateY(10px);
}
.solution-container-mobile {
  position: relative;
  width: 90%;
  max-width: 500px;
  margin: 50px auto;
  padding-bottom: 20px;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
}
.solution-container-mobile .solution-rectangle {
  position: relative;
  background-color: #000000;
  color: #FFFFFF;
  padding: 20px;
  display: inline-block;
}
.solution-container-mobile .solution-rectangle .solution-button {
  font-family: Rhode, serif;
  font-style: normal;
  font-size: clamp(16px, 8.8vw, 50px);
  text-align: center;
  color: #FFFFFF;
  cursor: pointer;
  padding-bottom: 20px;
  padding-top: 4px;
  border-bottom: 8px solid #FFFFFF;
}
.solution-container-mobile .solution-quote-wrapper {
  width: 98%;
  margin-top: 10px;
  margin-left: 1%;
}
.solution-container-mobile .solution-quote-wrapper .solution-quote-container {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.4s ease;
}
.solution-container-mobile .solution-quote-wrapper .solution-quote-container .solution-quote {
  position: relative;
  display: block;
  font-size: 2em;
  line-height: 1.2em;
  opacity: 0;
  transform: translateY(-20px);
  transition: all 0.4s ease;
  pointer-events: none;
  border-bottom: 10px solid #000000;
  padding-bottom: 10px;
}
.solution-container-mobile .solution-quote-wrapper .solution-quote-container .solution-quote.active {
  opacity: 1;
  pointer-events: auto;
}
.solution-container-mobile .solution-quote-wrapper .solution-quote-container .solution-quote.slide-in-top {
  transform: translateY(0);
}
.solution-container-mobile .solution-quote-wrapper .solution-quote-container .solution-quote.fading-out {
  opacity: 0;
  transform: translateY(10px);
}
.solution-container-mobile .solution-quote-wrapper .solution-quote-container.active {
  max-height: 200px;
}
.solution-contact {
  display: none;
}
/***************************/
/* Layout blog-item        */
/***************************/
.content-outer-container {
  width: 40%;
  max-width: 800px;
  margin: 0 auto;
  padding: 70px 0 50px;
  position: relative;
}
.content-outer-container .title-container {
  text-align: center;
}
.content-outer-container .title-container .quote {
  font-size: 3em;
  font-family: Rhode, serif;
  font-style: normal;
}
.content-outer-container .title-container h1 {
  margin-top: 2px;
  font-size: 3em;
}
.content-outer-container .subtitle-container {
  text-align: center;
  font-family: Georgia, serif;
  font-weight: 600;
  font-style: normal;
  margin: 20px 0px;
}
.content-outer-container .subtitle-container:before {
  content: '_';
  font-family: Georgia, serif;
  font-weight: 300;
  font-style: normal;
}
.content-outer-container .devider {
  width: 100%;
  border-top: 2.5px solid #000000;
  margin-bottom: 20px;
}
.content-outer-container .content-container .text {
  text-align: justify;
}
.content-outer-container .content-container .video-container {
  margin-bottom: 20px;
  position: relative;
}
.content-outer-container .content-container .video-container .embed-container {
  clear: both;
  position: relative;
  width: 100%;
}
.content-outer-container .content-container .video-container .embed-container.square {
  padding-bottom: 100%;
}
.content-outer-container .content-container .video-container .embed-container.landscape {
  padding-bottom: 56.25%;
}
.content-outer-container .content-container .video-container .embed-container iframe,
.content-outer-container .content-container .video-container .embed-container object,
.content-outer-container .content-container .video-container .embed-container embed,
.content-outer-container .content-container .video-container .embed-container img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.content-outer-container .content-container .video-container .control-buttons-container {
  position: absolute;
  z-index: 10;
  width: 100%;
  height: 100%;
  left: 0px;
  top: 0px;
  display: flex;
  justify-content: center;
  align-items: center;
}
.content-outer-container .content-container .video-container .control-buttons-container .control-button {
  position: absolute;
  display: block;
  cursor: pointer;
  font-size: 5em;
  text-align: center;
  transition: all 0.3s ease;
  -webkit-transition: all 0.3s ease;
  -moz-transition: all 0.3s ease;
  -o-transition: all 0.3s ease;
}
.content-outer-container .content-container .video-container .control-buttons-container .control-button.pause {
  -ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=0);
  filter: alpha(opacity=0);
  -webkit-opacity: 0;
  -moz-opacity: 0;
  opacity: 0;
  transition: all 0.3s ease;
  -webkit-transition: all 0.3s ease;
  -moz-transition: all 0.3s ease;
  -o-transition: all 0.3s ease;
  left: unset;
}
.content-outer-container .content-container .video-container.playing:hover .control-buttons-container .control-button.pause {
  -ms-filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=100);
  filter: alpha(opacity=100);
  -webkit-opacity: 1;
  -moz-opacity: 1;
  opacity: 1;
}
/***************************/
/* Layout footer           */
/***************************/
#footer-container {
  background-color: #95D5F1;
  width: 100%;
  overflow: auto;
}
/*************************/
/* Adjustments 4 tablet  */
/*************************/
body.device-tablet.landscape .solution-button {
  font-size: clamp(16px, 2.26vw, 25px);
  padding-top: 0px;
  padding-bottom: 10px;
}
body.device-tablet.landscape .solution-quote-wrapper .solution-quote {
  font-size: clamp(16px, 2.26vw, 25px);
}
body.device-tablet.portrait #header-container .logo {
  margin-left: 12.5%;
  width: 50%;
}
body.device-tablet.portrait #header-container .tagline {
  margin-left: 12.5%;
  width: 50%;
  font-size: calc(100vw / (1440 / 26.2));
}
body.device-tablet.portrait #header-container .devider {
  width: 60%;
  margin-left: 5%;
}
body.device-tablet.portrait .side-container {
  width: calc(35% - 60px);
  right: 0px;
  padding: 0 30px;
}
body.device-tablet.portrait .side-container .solution-rectangle {
  padding: 15px;
  width: calc(100% - 90px);
}
body.device-tablet.portrait .side-container .solution-rectangle .solution-button {
  font-size: clamp(16px, 4vw, 21px);
  padding-top: 0px;
  padding-bottom: 10px;
  width: 100%;
}
body.device-tablet.portrait .side-container .solution-quote-wrapper .solution-quote {
  font-size: 2em;
}
body.device-tablet.portrait .content-outer-container {
  width: 60%;
  margin-left: 5%;
}
/*************************/
/* Adjustments 4 mobile  */
/*************************/
body.device-smartphone .mobile-only {
  display: block;
}
body.device-smartphone #header-container .logo,
body.device-smartphone #header-container .tagline {
  width: 65%;
}
body.device-smartphone #header-container .tagline {
  font-size: calc(100vw / (1440 / 34.1));
}
body.device-smartphone #header-container .devider {
  width: 80%;
}
body.device-smartphone .side-container {
  display: none;
}
body.device-smartphone .content-outer-container {
  width: 80%;
}
body.device-smartphone .content-outer-container .content-container .video-container .control-buttons-container .control-button.pause {
  display: block;
  width: 100%;
  height: 100%;
}
body.device-smartphone .content-outer-container .content-container .video-container .control-buttons-container .control-button.pause .fa-pause {
  display: none;
}
body.device-smartphone.portrait #header-container {
  height: 150px;
}
body.device-smartphone.portrait #header-container .logo,
body.device-smartphone.portrait #header-container .tagline {
  width: 75%;
}
body.device-smartphone.portrait #header-container .tagline {
  font-size: calc(100vw / (1440 / 39.5));
}
body.device-smartphone.portrait #header-container .devider {
  width: 90%;
}
body.device-smartphone.portrait .content-outer-container {
  width: 90%;
  padding: 40px 0 30px;
}
body.device-smartphone.portrait .content-outer-container .title-container .quote {
  font-size: 2.5em;
}
body.device-smartphone.portrait .content-outer-container .title-container h1 {
  font-size: 2.5em;
}
