




/*------------------------------------*\
  NORMALIZE
\*------------------------------------*/


html {
  line-height: 1.15;
  -webkit-text-size-adjust: 100%;
}
body {
  margin: 0;
}
main {
  display: block;
}

h1 {
  font-size: 2em;
  margin: 0.67em 0;
}
hr {
  box-sizing: content-box;
  height: 0;
  overflow: visible;
}
pre {
  font-family: monospace, monospace;
  font-size: 1em;
}
a {
  background-color: transparent;
}
abbr[title] {
  border-bottom: none;
  text-decoration: underline;
  text-decoration: underline dotted;
}
b, strong {
  font-weight: bolder;
}
code, kbd, samp {
  font-family: monospace, monospace;
  font-size: 1em;
}
small {
  font-size: 80%;
}
sub, sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}
sub {
  bottom: -0.25em;
}
sup {
  top: -0.5em;
}
img {
	display: block;
  border-style: none;
}
button, input, optgroup, select, textarea {
  font-family: inherit;
  font-size: 100%;
  line-height: 1.15;
  margin: 0;
}
button, input {
  overflow: visible;
}
button, select {
  text-transform: none;
}
button, [type="button"], [type="reset"], [type="submit"] {
  -webkit-appearance: button;
}
button::-moz-focus-inner, [type="button"]::-moz-focus-inner, 
[type="reset"]::-moz-focus-inner, [type="submit"]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}
button:-moz-focusring, [type="button"]:-moz-focusring,
[type="reset"]:-moz-focusring, [type="submit"]:-moz-focusring {
  outline: 1px dotted ButtonText;
}
fieldset {
  padding: 0.35em 0.75em 0.625em;
}
legend {
  box-sizing: border-box;
  color: inherit;
  display: table;
  max-width: 100%;
  padding: 0;
  white-space: normal;
}
progress {
  vertical-align: baseline;
}
textarea {
  overflow: auto;
}
[type="checkbox"], [type="radio"] {
  box-sizing: border-box;
  padding: 0;
}
[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button {
  height: auto;
}
[type="search"] {
  -webkit-appearance: textfield;
  outline-offset: -2px;
}
[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none;
}
::-webkit-file-upload-button {
  -webkit-appearance: button;
  font: inherit;
}
details {
  display: block;
}
summary {
  display: list-item;
}
template {
  display: none;
}
[hidden] {
  display: none;
}





/*------------------------------------*\
  RESET
\*------------------------------------*/


*, *::before, *::after {
	box-sizing: border-box;
}
a {
	text-decoration: none;
	color: inherit;
	cursor: pointer;
}
button {
	color: inherit;
	background-color: transparent;
	padding: 0;
	border-width: 0;
	cursor: pointer;
}
img {
	width: 100%;
	height: auto;
}
figure {
	margin: 0;
}
input::-moz-focus-inner {
	padding: 0;
	border: 0;
	margin: 0;
}
ul, ol, dd {
	list-style: none;
	padding: 0;
	margin: 0;
}
h1, h2, h3, h4, h5, h6 {
	font-size: inherit; 
	font-weight: inherit;
	margin: 0; 
}
p {
	margin: 0;
}

::placeholder {
  color: #e1e9ef;
  opacity: 1;
}
:-ms-input-placeholder {
  color: #e1e9ef;
}
::-ms-input-placeholder {
  color: #e1e9ef;
}

input[type=radio],
input[type=checkbox],
select {
	-webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
}










/*------------------------------------*\
  #GLOBAL
\*------------------------------------*/


/*

Roc Grotesk Wide

font-family: roc-grotesk-wide, sans-serif;
font-weight: 400;
font-weight: 500;
font-weight: 600;

*/


:root {
  --ivory: #fcfae8;
  --violet: #612e4f;
  --gray: #808080;
  --green: #c2f2ba;
  --red: #f24d29;
  --blue: #61d1f0;
  --yellow: #ffe05c;
  --pink: #ffabf2;
}





/*------------------------------------*\
  #LAYOUT
\*------------------------------------*/


body {
  height: 100vh;
}

.page {
  display: flex;
  flex-direction: column;
  background: var(--ivory);
}
.page--login {
  display: block;
  background: var(--green);
}

.container {
  position: relative;
  width: 90%;
  max-width: 1500px;
  margin: 0 auto;
}


@media screen and (max-width: 1400px) {
  .container {
    width: 94%;
  }
}





/*------------------------------------*\
  #HEADER
\*------------------------------------*/


.page-head {
  position: sticky;
  width: 100%;
  top: 0;
  background: var(--ivory);
  padding: 0.8em 0;
  transition: box-shadow 0.3s ease-in-out;
  z-index: 999;
}

.page-head .container {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.page-head__logo {
  width: 2.5em;
}

.shadow {
  box-shadow: 0 8px 5px -5px rgba(128,128,128, 0.1);
}

.page--login .page-head {
  background: none;
}
.page--login .shadow {
  box-shadow: none;
}





/*------------------------------------*\
  #TYPE
\*------------------------------------*/


body {
  font-family: roc-grotesk-wide, sans-serif;
  font-size: 100%;
  font-weight: 400;
  color: var(--gray);
}

.page-content h1 {
  font-size: 2.5em;
  font-weight: 700;
  line-height: 1.2;
  color: var(--violet);
}
.page-content h2 {
  font-size: 1.6em;
  font-weight: 700;
  line-height: 1.2;
}
.page-content h3 {
  font-size: 1em;
  font-weight: 700;
  line-height: 1.2;
  color: #000;
}
.page-content p {
  font-size: 1em;
  line-height: 1.6;
}


@media screen and (max-width: 1200px) {
  .page-content h1 {
    font-size: 2.2em;
  }
}

@media screen and (max-width: 900px) {
  .page-content h1 {
    font-size: 2em;
  }
}

@media screen and (max-width: 600px) {
  .page-content h1 {
    font-size: 1.8em;
  }
}










/*------------------------------------*\
  #COMMON
\*------------------------------------*/


.button {
	font-size: 0.9em;
	font-weight: 600;
	line-height: 1;
	text-transform: uppercase;
	color: #fff;
  background: #000;
	padding: 0.8em 1.2em 0.6em;
	border-radius: 25px;
	cursor: pointer;
	transition: background 0.5s ease;
}
.button:hover {
	background: var(--red);
}


@media screen and (max-width: 600px) {
	.button {
		font-size: 0.8em;
	}
}





/*------------------------------------*\
  #BANNER
\*------------------------------------*/


.banner {
  width: 100%;
  background: var(--blue);
  margin: 0;
}

.banner__inner {
  position: relative;
  text-align: center;
  padding: 5em 0;
}

.banner__graphic {
  position: absolute;
  width: auto;
  height: 70%;
  top: 0;
  left: 5%;
  bottom: 0;
  margin: auto 0;
}

.banner__inner h1 {
  position: relative;
  z-index: 99;
}
.banner__inner h1 span {
  color: var(--ivory);
}


@media screen and (max-width: 1400px) {
  .banner__graphic {
    left: 0;
  }
}

@media screen and (max-width: 1200px) {
	.banner__inner {
	  padding: 4em 0;
	}
  .banner__inner h1 span {
    display: block;
  }
}

@media screen and (max-width: 900px) {
	.banner__inner {
	  padding: 3em 0;
	}
  .banner__graphic {
    height: 60%;
    left: 0;
  }
}

@media screen and (max-width: 600px) {
	.banner__inner {
	  padding: 2em 0;
	}
  .banner__graphic {
    left: -5%;
  }
}

@media screen and (max-width: 400px) {
  .banner__graphic {
    bottom: -20%;
  }
}





/*------------------------------------*\
  #SLIDE-HEADER
\*------------------------------------*/


.slide__header {
	background: var(--violet);
	padding: 1.8em 0;
}

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

.slide__header p {
	font-size: 1.8em;
	font-weight: 700;
  line-height: 1.2;
	text-transform: uppercase;
  color: #fff;
  text-align: center;
  padding: 0 2em;
	margin: 0;
}

.info-link {
	display: flex;
	font-size: 1.1em;
	font-weight: 700;
	line-height: 1.2;
	text-transform: uppercase;
	color: #fff;
	cursor: pointer;
  transition: color 0.5s ease;
}
.info-link svg {
	width: 1em;
	fill: #fff;
  transition: fill 0.5s ease;
}
.prev svg {
	margin-right: 0.5em;
}
.next svg {
	margin-left: 0.5em;
}

.info-link:hover {
	color: var(--red);
}
.info-link:hover svg {
	fill: var(--red);
}


@media screen and (max-width: 1200px) {
  .slide__header {
    padding: 1.5em 0;
  }
	.slide__header p {
		font-size: 1.6em;
	}
  .info-link {
    font-size: 1em;
  }
}

@media screen and (max-width: 900px) {
  .slide__header {
    padding: 1.2em 0;
  }
  .slide__header p {
    font-size: 1.4em;
  }
  .info-link {
    font-size: 0.9em;
  }
  .info-link svg {
    width: 0.9em;
  }
}

@media screen and (max-width: 600px) {
	.slide__header {
		padding: 1em 0;
	}
	.slide__header p {
		font-size: 1.2em;
	}
}





/*------------------------------------*\
  #BLOCK
\*------------------------------------*/


.slide__content {
	display: flex;
	justify-content: space-between;
	margin: 3em auto 10em;
}

.block {
	display: flex;
	flex-direction: column;
	width: 18%;
	min-height: 280px;
  background: #fff;
}
.block__date,
.block__content {
	padding: 1.5em;
}

.block__date {
	background: var(--red);
}
.block__date h2,
.block__date p {
	color: var(--ivory);
}
.block__date h2 {
  margin-bottom: 0.2em;
}
.block__date p {
	font-size: 1em;
	font-weight: 400;
	line-height: 1.2;
	text-transform: uppercase;
	margin: 0;
}

.block__content {
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	height: 100%;
	border-bottom: 10px solid var(--red);
}
.block__content h3 {
	margin-top: 1em;
}

.button--edit {
	display: inline-block;
}

.block--office .block__date h2,
.block--office .block__date p,
.block--holiday .block__date h2,
.block--holiday .block__date p {
  color: var(--violet);
}

.block--office .block__content {
  border-color: var(--green);
}
.block--office .block__date,
.block--office .button--edit:hover {
	background: var(--green);
}

.block--holiday .block__content {
  border-color: var(--yellow);
}
.block--holiday .block__date,
.block--holiday .button--edit:hover {
  background: var(--yellow);
}

.block--wfh .block__content {
  border-color: var(--blue);
}
.block--wfh .block__date,
.block--wfh .button--edit:hover {
  background: var(--blue);
}

.block--pto .block__content {
  border-color: var(--pink);
}
.block--pto .block__date,
.block--pto .button--edit:hover {
	background: var(--pink);
}

.block--nwd .block__content {
  border-color: var(--gray);
}
.block--nwd .block__date,
.block--nwd .button--edit:hover {
  background: var(--gray);
}

.block--oscl .block__content {
  border-color: var(--violet);
}
.block--oscl .block__date,
.block--oscl .button--edit:hover {
  background: var(--violet);
}


@media screen and (max-width: 1500px) {
	.block {
		width: 18.5%;
	}
	.block__date,
	.block__content {
		padding: 1.2em;
	}
}

@media screen and (max-width: 1300px) {
	.slide__content {
		flex-wrap: wrap;
		max-width: 800px;
	}
	.block {
		width: 48%;
		min-height: 250px;
		margin-bottom: 4%;
	}
  .block__content h3 {
    margin-top: 0.8em;
  }
}

@media screen and (max-width: 900px) {
  .block {
    width: 48.5%;
    margin-bottom: 3%;
  }
}

@media screen and (max-width: 600px) {
	.slide__content {
		flex-wrap: wrap;
		max-width: 300px;
		margin: 2.5em auto 5em;
	}
	.block {
		width: 100%;
		min-height: 230px;
		margin-bottom: 1.5em;
	}
  .block__content h3 {
    margin-top: 0.5em;
  }
}





/*------------------------------------*\
  #SELECT
\*------------------------------------*/


select {
	background: var(--ivory);
  background-image: none;
  outline: 0;
  border-radius: 0;
  box-shadow: none;
  -webkit-appearance: none;
  	 -moz-appearance: none;
      -ms-appearance: none;
  				appearance: none;
}
select::-ms-expand {
  display: none;
}

select {
  flex: 1;
  font-family: roc-grotesk-wide, sans-serif;
  font-size: 0.9em;
  font-weight: 600;
  line-height: 1;
  color: var(--gray);
  padding: 1em 1em 0.9em;
  border: 1px solid #000;
  cursor: pointer;
  transition: border-color 0.3s ease;
}
select:hover {
  border: 1px solid var(--red);
}

.select {
  position: relative;
  display: flex;
  width: 100%;
  height: 2.8em;
  background: #000;
  overflow: hidden;
}
.select::before {
  position: absolute;
  content: url(../img/arrow.svg);
  width: 2.8em;
  height: 2.8em;
  top: 0;
  right: 0;
  bottom: 0;
  background: #000;
  padding: 0.8em;
  cursor: pointer;
  pointer-events: none;
  transform: rotate(-90deg);
  transition: 0.3s all ease;
}
.select:hover::before {
  background: var(--red);
}


@media screen and (max-width: 1500px) {
  select {
    color: var(--gray);
    padding: 0.8em 0.8em 0.7em;
  }
	.select {
	  height: 2.5em;
	}
  .select::before {
    width: 2.5em;
    height: 2.5em;
  }
}











/*------------------------------------*\
  #LOGIN
\*------------------------------------*/


.login--banner {
	position: relative;
  width: 100%;
  height: 100vh;
  background: var(--green);
  margin: 0;
}
.login--banner::after {
  position: absolute;
  content: url(../img/graphic-welcome.svg);
  width: 35%;
  height: auto;
  right: 5%;
  bottom: 5%;
}

.login__inner {
	display: flex;
  flex-direction: column;
	align-items: center;
	height: 100%;
	padding: 8%;
}

.login__logo {
  position: relative;
  width: 7em;
  margin: 0 auto 3em;
  z-index: 99;
}

.login__form {
  position: relative;
	width: 100%;
	max-width: 425px;
  padding: 3em 2.5em;
  background: #fcfae8;
  margin: 0 auto;
  z-index: 99;
}
.login__form h1 {
	font-size: 1.8em;
	text-align: center;
	margin-bottom: 0.8em;
}

.form__input input { 
  width: 100%;
  font-family: roc-grotesk-wide, sans-serif;
  font-size: 1em;
  font-weight: 400;
  line-height: 1;
  color: var(--gray);
  background: #fff;
  padding: 1em 1.2em 0.9em;
  border: 1px solid var(--red);
  outline: none;
  margin-bottom: 1em;
  -webkit-transition: border ease 0.5s;
          transition: border ease 0.5s;
}
.form__input input:focus {
  border: 1px solid var(--violet);
}

::placeholder { 
  color: var(--gray);
}
:-ms-input-placeholder { 
  color: var(--gray);
}
::-webkit-input-placeholder {
  color: var(--gray);
}

.login__form input[type=submit] {
  display: block;
  width: 100%;
  font-size: 1.3em;
  font-weight: 600;
  line-height: 1;
  text-transform: uppercase;
  color: #fff;
  padding: 1em 1.2em 0.9em;
  background: #000;
  border: none;
  border-radius: 50px;
  outline: none;
  margin-top: 0.5em;
  cursor: pointer;
  transition: background ease 0.5s, color ease 0.5s;
}
.login__form input[type=submit]:hover {
	color: #fff;
  background: var(--red);
}

.form__error {
  margin-bottom: 1.5em;
}
.form__error p {
	font-size: 1em;
	font-weight: 700;
  line-height: 1.4;
  color: var(--red);
  margin: 0;
}


@media screen and (max-width: 1200px) {
	.login--banner::after {
    width: 45%;
  }
}

@media screen and (max-width: 900px) {
  .login--banner::after {
    width: 55%;
  }
	.login__inner {
    padding: 5%;
  }
  .login__logo {
    width: 6em;
  }
  .login__form {
    max-width: 400px;
  }
  .login__form h1 {
    font-size: 1.5em;
    margin-bottom: 1em;
  }
  .login__form input[type=submit] {
    font-size: 1.1em;
  }
}

@media screen and (max-width: 600px) {
  .login--banner::after {
    width: 70%;
    right: 1em;
    bottom: 1em;
  }
  .login__logo {
    width: 5em;
    margin: 2.5em auto;
  }
  .login__inner {
    padding: 0 5%;
  }
  .login__form {
    max-width: 375px;
    padding: 2.5em 2em;
  }
}





/*------------------------------------*\
  #SLICK-SETUP
\*------------------------------------*/


.slick-slider {
  display: block;
  position: relative;
  box-sizing: border-box;
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
  -webkit-touch-callout: none;
     -khtml-user-select: none;
  -ms-touch-action: pan-y;
      touch-action: pan-y;
  -webkit-tap-highlight-color: transparent;
}
.slick-list {
  display: block;
  position: relative;
  margin: 0;
  padding: 0;
  overflow: hidden;
}
.slick-list:focus {
  outline: none;
}
.slick-list.dragging {
  cursor: pointer;
  cursor: hand;
}
.slick-slider .slick-track,
.slick-slider .slick-list {
  -webkit-transform: translate3d(0, 0, 0);
          transform: translate3d(0, 0, 0);
}
.slick-track {
  display: flex;
  position: relative;
  top: 0;
  left: 0;
  margin-left: auto;
  margin-right: auto;
}
.slick-track:before,
.slick-track:after {
  display: table;
  content: '';
}
.slick-track:after {
  clear: both;
}
.slick-loading .slick-track{
  visibility: hidden;
}
.slick-slide {
  display: none;
  float: left;
  height: inherit;
  min-height: 1px;
}
[dir='rtl'] .slick-slide {
  float: right;
}
.slick-slide img {
  display: block;
}
.slick-slide.slick-loading img {
  display: none;
}
.slick-slide.dragging img {
  pointer-events: none;
}
.slick-initialized .slick-slide {
  display: block;
}
.slick-loading .slick-slide {
  visibility: hidden;
}
.slick-vertical .slick-slide {
  display: block;
  height: auto;
  border: 1px solid transparent;
}
.slick-arrow.slick-hidden {
  display: none;
}

.slick-disabled {
  opacity: 0;
  pointer-events: none;
}


.slider .slide,
.slider-nav .slide {
  display: none;
}
.slider.slick-initialized .slide,
.slider-nav.slick-initialized .slide {
  display: block;
}






/*------------------------------------*\
  #FOOTER
\*------------------------------------*/


.page-foot {
  background: #000;
  padding: 1em 0;
  margin-top: auto;
}

.page-foot p {
  font-size: 0.9em;
  font-weight: 400;
  line-height: 1.2;
  color: #fff;
}


@media screen and (max-width: 600px) {
  .page-foot p {
    font-size: 0.8em;
  }
}









