/**
Theme Name: CUTPro
Author: Sorvus Media
Version: 1.0.1
**/

/**
Fonts
**/
/* geologica-100 - greek_latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Geologica';
  font-style: normal;
  font-weight: 100;
  src: url('fonts/geologica-v5-greek_latin-100.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* geologica-300 - greek_latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Geologica';
  font-style: normal;
  font-weight: 300;
  src: url('fonts/geologica-v5-greek_latin-300.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* geologica-regular - greek_latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Geologica';
  font-style: normal;
  font-weight: 400;
  src: url('fonts/geologica-v5-greek_latin-regular.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* geologica-700 - greek_latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Geologica';
  font-style: normal;
  font-weight: 700;
  src: url('fonts/geologica-v5-greek_latin-700.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* geologica-900 - greek_latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Geologica';
  font-style: normal;
  font-weight: 900;
  src: url('fonts/geologica-v5-greek_latin-900.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}

/**
Css Reset
**/
a, a:after, a:before{
	text-decoration:none;
	color:inherit;
	-webkit-transition: all 0.2s ease-in-out 0s;
	-moz-transition: all 0.2s ease-in-out 0s;
	-o-transition: all 0.2s ease-in-out 0s;
	-ms-transition: all 0.2s ease-in-out 0s;
	transition: all 0.2s ease-in-out 0s;
}

html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed, 
figure, figcaption, footer, header, hgroup, 
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	font-size: 100%;
	font: inherit;
}
table {border-collapse: collapse;border-spacing: 0;}
* { box-sizing: border-box;	-moz-box-sizing: border-box; -webkit-box-sizing: border-box;}
a {outline : none; color:inherit; text-decoration:none;}
a img {outline : none;}
img {border : 0; display:block;}
strong, b{	font-weight:600;}
::selection {
	background: #102237; /* WebKit/Blink Browsers */
	color:#F5F5F5;
}
::-moz-selection {
	color:#F5F5F5;
	background: #102237; /* Gecko Browsers */
}


.mob_only{
	display:none;
}


/**
Root Variables
**/
:root{
	--clr_grey:#E7E7E7;
}

/**
Variables
**/
body, html{
	font-family: 'Geologica';
	font-weight: 400;
	font-style: normal;
	font-size:16px;
	background:#ffffff;
	color:#000000;
}

body{
	width:100%;
    overflow-x:hidden;
}

.wrapper{
    width:95%;
	max-width:1360px;
    display: block;
    margin:0 auto;
}

section{
	position:relative;
	float:left;
	width:100%;
}

section,
div{
	scroll-margin-top: 100px;
	background-repeat: no-repeat;
	background-position: center; 
	-webkit-background-size: cover;
	-moz-background-size: cover;
	-o-background-size: cover;
	background-size: cover;
}

/**
Columns
**/
[class*="col-"] {
	float:left;
}

.col-D {width:3.5%;height:10px;}
.col-0 {width:31%;}
.col-1 {width: 8.33%;}
.col-2 {width: 16.66%;}
.col-20 {width:20%;}
.col-3 {width: 25%;}
.col-4 {width: 33.33%;}
.col-5 {width: 41.66%;}
.col-6 {width: 50%;}
.col-7 {width: 58.33%;}
.col-8 {width: 66.66%;}
.col-9 {width: 75%;}
.col-10 {width: 83.33%;}
.col-11 {width: 91.66%;}
.col-12 {width: 100%;}

/**
Grid
**/
[class*="grid-"] {
	display: grid;
	grid-template-rows: 1fr;
    grid-column-gap: 20px;
    grid-row-gap: 20px;
}	

.grid-2{
    grid-template-columns: repeat(2, 1fr);
}
.grid-3{
    grid-template-columns: repeat(3, 3fr);
}
.grid-4{
    grid-template-columns: repeat(4, 1fr);
}
.grid-5{
    grid-template-columns: repeat(5, 1fr);
}

.grid-more-space{
    grid-column-gap: 105px;
}

/**
Floats & Aligns
**/
.txt-center{
	text-align:center;
}

.txt-left{
	text-align:left;
}

.txt-right{
	text-align:right;
}

.float-left{
	float:left;
}

.float-right{
	float:right;
}

.empty{
    min-height: 1px;
}

/**
Header
**/
header{
    position: relative;
    width:100%;
    padding:60px 0px 140px;
}

.navTrigger{
    float: left;
    width:40px;
    height:20px;
    display: flex;
	flex-direction: column;
	flex-wrap: nowrap;
	justify-content: center;
	align-items: flex-start;
	align-content: stretch;
    cursor: pointer;
}

.navTriggerLine{
    height:1px;
    width:60%;
    background:#000;
    margin:2px 0px;
}
.header_logo,
.header_logo_Tag{
    float:left;
    margin-right: 20px;
}

.header_logo svg,
.header_logo_Tag svg{
    float:left;
}

.header_logo svg{
    height: 20px;
    width:auto;
}

.header_logo a:hover svg{
    opacity: .6
}

.header_logo_Tag svg{
    height:14px;
    width: auto;
    margin-top: 4px
}

.header_nav{
    float:right;
}

.header_nav ul{
    list-style: none;
}

.header_nav ul li{
    float:left;
    margin-left:20px;
    line-height: 20px;
    font-weight: 300;
    letter-spacing: 0.02em;
}

.header_nav ul li a{
    float: left;
    position: relative;
    display: inline-block;
}

.header_nav ul li a:before{
    position: absolute;
    left:0;
    bottom:-10px;
    width:0%;
    height:2px;
    background:#000;
    content:"";
}

.header_nav ul li a:hover:before{
    width:100%;
}


.sliderCategoriesMain{
    position: relative;
    background:var(--clr_grey);
    padding:50px 8% 50px 50px;
    height: 500px;
    display: flex;
	flex-direction: column;
	flex-wrap: nowrap;
	justify-content: flex-end;
	align-items: flex-start;
	align-content: stretch;
}

.sliderCategoriesMain:after{
    content:"";
    position: absolute;
    top:0;
    right:0;
    bottom:0;
    width:30px;
    background:#fff;
}

.sliderCategoriesMain{
    z-index: 100;
}

.sliderCategoriesMain:before{
    position: absolute;
    right:100%;
    top:-10px;
    bottom:-10px;
    content:"";
    background:#fff;
    width:200vw;
    pointer-events:none;
}

.sliderCategoriesMain h1{
    font-weight: 700;
    font-size: 2em;
    line-height: 1.2em;
    padding-bottom: 25px;
}

.sliderCategoriesMain p{
    font-weight: 100;
    font-size: 1.1em;
    padding-bottom:30px;
}

.sliderCategoriesBtns{
    display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: flex-start;
	align-items: center;
	align-content: stretch;
}

.sliderCategoriesBtns div{
    margin-right: 10px;
}

.sliderCategoriesBtns div:last-child{
    margin-left:10px;
}

.sliderCategoriesFooter{
    margin-top:20px;
    padding-top:20px;
}

.sliderCategoriesFooter_Logo{
    display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: flex-start;
	align-items: center;
	align-content: stretch;
}

.sliderCategoriesFooter_Logo span{
    font-size: 0.8em;
    margin-right:20px;
}

.sliderCategoriesFooter_cta{
    text-align: right;
}

.sliderBtn{
    cursor: pointer;
}

.sliderBtn svg{
    float:left;
    height:30px;
    width:auto;
}

/**
Product Card
**/
.ProductCard{
    position: relative;
    display: inline-block;
    width:100%;
    height:500px;
    background-repeat: no-repeat;
	background-position: center; 
	-webkit-background-size: cover;
	-moz-background-size: cover;
	-o-background-size: cover;
	background-size: cover;
}

.ProductCard{
    filter: saturate(0);
}

.ProductCard:hover{
    filter: saturate(1);
}

.ProductCard span{
    position: absolute;
    right:50px;
    bottom:50px;
    font-size: 1.2em;
    font-weight: 100;
    color:#fff;
    z-index: 10;
}

.ProductCard span:after{
    content:"PRO";
    font-weight: 800;
}

.ProductCard:before{
    content:"";
    position: absolute;
    left:0; right:0;
    bottom:0; top:0;
    background:#000;
    z-index: 1;
    opacity: .3;
}

/**
Buttons
**/
.cta_01{
    display: inline-block;
    background:#000;
    color:#fff;
    font-weight: 700;
    padding:10px 20px;
}

/**
Page
**/
.PageTitle{
    font-weight: 700;
    font-size: 1.8em;
    line-height: 1.2em;
    padding-bottom: 25px;
}

.PageCat{
    padding-bottom: 15px;
    margin-bottom: 15px;
    border-bottom: 1px solid var(--clr_grey);
    font-weight: 100;
}

.content p{
    padding-bottom: 15px;
}

.content{
    padding-bottom: 15px;
    font-weight: 100;
    line-height: 1.5em;
    text-align: justify;
    font-size: 1.1em;
}

.content strong{
    font-weight: 300;
}

.content ol,
.content ul{
    margin-left:45px;
    padding-bottom: 15px;
}

.content li{
    margin-bottom: 10px;
}

/**
Courses Grid
**/
.CategoryCourses{
    
}

.CategoryCourses_head{
    padding-bottom: 25px;
}

.CategoryCourses_head h2{
    font-size: 1.6em;
    font-weight: 700;
}

.CourseCard{
    background:#000;
    color:#fff;
    padding:50px;
    height:450px;
    display: flex;
	flex-direction: column;
	flex-wrap: nowrap;
	justify-content: space-between;
	align-items: stretch;
	align-content: stretch;
}

.CourseCard:hover{
    background:#FFEE00;
    color:#000;
}

.CourseCard svg{
    fill:#fff;
}

.CourseCard:hover svg{
    fill:#000;
}

.CourseCard_category{
    font-weight: 100;
    padding-bottom: 15px;
}

.CourseCard_title{
    font-weight: 700;
    font-size: 1.6em;
}

.CourseCard_Footer{
    border-top:1px solid;
    padding-top:25px;
}

.CourseCard_Footer span{
    display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: flex-start;
	align-items: stretch;
	align-content: stretch;
    line-height: 20px;
}

.CourseCard_Footer span svg{
    height:20px;
    width:auto;
    margin-right: 10px;
}

.CourseCard_Footer span.CourseCard_link{
    display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: flex-end;
	align-items: stretch;
	align-content: stretch;
}

.PageCategory{
    font-weight: 100;
    padding-bottom: 15px;
    margin-bottom: 15px;
    border-bottom:1px solid var(--clr_grey);
    display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: flex-start;
	align-items: center;
	align-content: stretch;
}

.PageCategory a{
    display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: flex-start;
	align-items: center;
	align-content: stretch;
}

.PageCategory a svg{
    height:5px;
    width:auto;
    margin-right: 10px;
}

.PageTitle h1{
    max-width: 350px;
}

.PageContentImage{
    display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: center;
	align-items: center;
	align-content: stretch;
    height:350px;
    overflow: hidden;
    margin-bottom: 50px;
}

.PageContentImage img{
    width:100%;
    height:auto;
}

/**
Course 
**/
.CourseInfoCard{
    border: 1px solid var(--clr_grey);
}

.CourseInfoRow{
    border-bottom: 1px solid var(--clr_grey);
    padding:10px 15px;
}

.CourseInfoRow span{
    width:100%;
    float:left;
    font-size: .8em;
    font-weight: 100;
}

.SingleCourseTeacher_list{
    background: var(--clr_grey);
    padding:15px;
    
    overflow: hidden;
}

.TeacherCard{
    display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: flex-start;
	align-items: center;
	align-content: stretch;
}

.TeacherCard_image{
    width:150px;
    height:150px;
    overflow: hidden;
    display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: center;
	align-items: center;
	align-content: stretch;
    border-radius: 20%;
    margin-right: 25px;
    box-shadow:  10px 10px 20px #cfcdcd;
}

.TeacherCard_image img{
    width:100%;
    height:auto;
}

.TeacherCard_Details{
    width:calc(100% - 175px);
    overflow: hidden;
}

.TeacherCard_Details h4{
    font-weight: 100;
    font-size: .9em;
    padding-bottom: 25px;
}

.TeacherCard_Details a{
    font-size: .7em;
    display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: flex-start;
	align-items: center;
	align-content: stretch;
}

.TeacherCard_Details a svg{
    margin-right: 10px;
    height:10px;
    width:auto;
}
@media (max-width: 1260px) and (min-width: 0px) { 

body{
	width:90%;
}

[class*="col-"] {
	width:100%;
}

[class*="grid-"] {
	grid-template-columns: repeat(1, 1fr);
}


.header_nav, .header_logo_Tag{
    display: none;
}

}