/*!
Theme Name: shin
Theme URI: https://zanpress.com/
Author: zanpress
Author URI: https://zanpress.com/
Description: Description
Version: 1.0.0
Tested up to: 5.4
Requires PHP: 5.6
License: GNU General Public License v2 or later
License URI: LICENSE
Text Domain: hgd
Tags: custom-background, custom-logo, custom-menu, featured-images, threaded-comments, translation-ready

This theme, like WordPress, is licensed under the GPL.
Use it to make something cool, have fun, and share what you've learned.

hgd is based on Underscores https://underscores.me/, (C) 2012-2020 Automattic, Inc.
Underscores is distributed under the terms of the GNU GPL v2 or later.

Normalizing styles have been helped along thanks to the fine work of
Nicolas Gallagher and Jonathan Neal https://necolas.github.io/normalize.css/
*/

@import url("https://cdn.jsdelivr.net/gh/orioncactus/pretendard@v1.3.8/dist/web/variable/pretendardvariable.css");
/* @import url('https://fonts.googleapis.com/css2?family=Libre+Baskerville:ital,wght@0,400;0,700;1,400&family=Noto+Sans+KR:wght@100..900&display=swap'); */
:root {
	--white: #ffffff;
	--whitegrey: #f5f5f5;
	--deep: #0e0e0e;
	--black: #222227;
	--blacktr: #22222347;
	--dark: #222223;
	--indigo: #001548;
	--indigodeep: #0f264c;
	--grey: #a8a5b9;
	--greytext: #7f7d8a;
	--linewhite: rgb(255 255 255 / 20%);
	--line: rgb(0 0 0 / 20%);
	--linelight: rgb(0 0 0 / 10%);
	--main: #00aeef;
	--sub: #d7c78f;
	--blue: #2583c1;
	--sky: aliceblue;
	--yellow: #ffce21;
	--sans: 'Pretendard Variable', 'Pretendard', sans-serif;
}
* {
	box-sizing: border-box;
	outline: none;
}
svg.clippathdef{
	position: absolute;
	height: 1px;
	width: 1px;
	margin: 0;
	padding: 0;
	overflow: hidden;
	clip: rect(0 0 0 0);
	clip-path: inset(100%);
	white-space: nowrap;
}
svg{
	width: 24px;
	height: 24px;
}
button svg{
	width: 20px;
	height: 20px;
}
body, input, textarea, button, select, option {
	font-family: var(--sans);
	font-size: 14px;
}
a{
	text-decoration: none;
	color: var(--black);
}
/* Alignments
--------------------------------------------- */
.alignleft {

	/*rtl:ignore*/
	float: left;

	/*rtl:ignore*/
	margin-right: 1.5em;
	margin-bottom: 1.5em;
}

.alignright {

	/*rtl:ignore*/
	float: right;

	/*rtl:ignore*/
	margin-left: 1.5em;
	margin-bottom: 1.5em;
}

.aligncenter {
	clear: both;
	display: block;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 1.5em;
}
body.lock{
	overflow: hidden;
}
body {
	width: 100%;
	background: var(--white);
	color: var(--black);
	font-weight: 400;
	line-height: 1.4;
	padding: 0;
	margin: 0;
}
main{
	min-height: calc(100vh - 150px);
}
h1{
	font-weight: 700;
	font-size: 2.7em;
}
h2{
	font-weight: 700;
}
h2.nt{
	margin-top: 0;
}
h2.sty{
	display: flex;
	align-items: center;
}
h2.sty::before{
	content: '';
	display: flex;
	width: 8px;
	height: 8px;
	background: var(--main);
	transform: rotate(45deg);
	margin-right: 10px;
}
.titlelink{
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: 20px;
}
.titlelink a{
	color: var(--grey);
	display: flex;
	align-items: center;
	font-weight: 300;
}
.titlelink a svg{
	width: 16px;
	height: 16px;
	margin-left: 2px;
}
.titlelink h2{
	margin: 0;
}
h3, h4{
	font-weight: 600;
}
p{
	font-weight: 300;
	color: var(--greytext);
}
.italic{
	font-style: italic;
	font-weight: bold;
	color: var(--main);
}
.empty{
	color: var(--grey);
	padding: 40px;
}
section.slidersection{
	margin-top: -152px;
}
section {
	position: relative;
	padding: 20px;
	width: 100%;
	max-width: 1100px;
	margin: 0 auto;
}
section.wside{
	display: grid;
	grid-template-columns: 230px 1fr;
}
section.mid{
	max-width: 860px;	
}
section.sml{
	max-width: 640px;
}
section.hf{
	max-width: 630px;
}
.bt.onlym{
	display: none;
}
#blk.active{
	display: block;
}
#blk{
	display: none;
	position: fixed;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	background: rgba(0, 0, 0, 0.698);
	z-index: 9999;
}
#mgnbwrp.active{
	transform: translateX(0%);
}
#mgnbwrp{
	position: fixed;	
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	z-index: 99999;
	display: flex;
	transform: translateX(100%);
	transition: transform 0.2s ease-out;
}
#mgnbwrp .exit{
	width: 100%;
	display: flex;
	justify-content: flex-end;
}
#mgnbwrp .exit svg{
	color: var(--white);
	width: 32px;
	height: 32px;
	margin: 10px;
	position: relative;
	top: 30px;
}
#mgnbwrp .mgnb{	
	position: relative;	
	padding: 30px;
	background: var(--white);
	width: 90vh;	
	display: flex;
	flex-direction: column;
}
#mgnbwrp .mgnb .contact{
	border-radius: 30px;
	font-weight: 700;
	margin-top: auto;
}
#mgnbwrp .mgnb .searchwrp{
	width: auto;
	margin: 0 -8px 20px;
}
.mgnb ul{
	list-style-type: none;
	padding: 0;
	margin: 0;
	font-size: 1.45em;
	font-weight: 700;
	display: flex;
	flex-direction: column;
	gap: 10px;
}
.mgnb ul li.current-menu-item a, .mgnb ul li.current_page_item a{
	opacity: 1;
}
.mgnb ul li a{
	display: block;
	padding: 10px 0;
	opacity: 1;
}
header{
	z-index: 999;
	position: sticky;
	top: 0;
	color: var(--black);
	background: var(--white);
	border-bottom: 1px solid var(--line);
}
header.tran{
background: transparent;
}
header section{
	display: flex;
	justify-content: space-between;
	align-items: center;
}
header section .fr, header section .bn{
	display: flex;
	align-items: center;
	gap: 3px;
}
header section .bn .bt{
	cursor: pointer;
	width: 42px;
	height: 42px;
	flex: 0 0 42px;
	background: transparent;
	border: 1px solid var(--linelight);
	border-radius: 8px;
	color: var(--black);
}
header section .bn .bt.contact{
	width: 110px;
	justify-content: center;
	padding: 0 10px;
	font-weight: 700;
	border-radius: 10px;
	background: var(--blacktr);
}
header section .bn .bt svg{	
	height: 24px;
	width: auto;
}
#hisback.onlym{
	display: none;
}
#hisback{
	cursor: pointer;
	display: flex;
	background: transparent;
	border: 0;
	height: 36px;
	align-items: center;
	justify-content: center;
	margin-left: -13px;
	padding: 0 15px;
	z-index: 1;
}
#hisback svg{
	height: 20px;
	width: 20px;
	fill: var(--grey);
}
.sticky{
	position: sticky;
	top: 120px;
}
.sticky.wsubm{
	top: 120px;
}
.site-branding{
	position: relative;
	display: flex;
	align-items: center;
	gap: 6px;
	font-size: 1.6em;
	font-weight: 800;
	height: 50px;
	color: var(--main);
	text-transform: uppercase;
}
.site-branding img, .site-branding svg{
	height: 32px;
	width: auto;
	fill: var(--black);
}
.dropdown{
	font-weight: 500;
	cursor: pointer;
	position: relative;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 15px;
	border: 1px solid var(--line);
	border-radius: 10px;
	height: 42px;
	min-width: 100px;
	padding: 0 20px;
}
.dropdown svg{
	width: 14px;
	height: 14px;
}
.dropdown .site-branding svg{
	height: 14px;
	width: auto;
}
.dropdown.active .dropitems{
	display: block;
}
.dropdown .dropitems.oriright{
	right: 0;
	left: auto;
}
.dropdown .dropitems.bottom{
	top: auto;
	bottom: calc(100% + 10px);	
}
.dropdown .dropitems.minwauto{
	min-width: auto;
}
.dropdown .dropitems{
	display: none;
	position: absolute;
	top: calc(100% + 10px);
	left: 0;
	min-width: 130px;
	width: 100%;
	color: var(--grey);
	background: var(--darksub);
	box-shadow: 4px 12px 30px 6px rgba(0, 0, 0, .05);
	border-radius: 10px;
	padding: 12px 0;
	z-index: 1;
	max-height: 340px;
	overflow-y: scroll;
	overflow: auto;		
	font-size: .95em;
}
.dropdown .dropitems .item.current{
	color: var(--black);
}
.dropdown .dropitems .item.line{
	border-bottom: 1px solid var(--line);
}
.dropdown .dropitems .item:hover{
	color: var(--white);
}
.dropdown .dropitems .item{
	cursor: pointer;
	display: flex;
	font-weight: 600;
	font-size: 1.1em;
	padding: 9px 20px;
	color: var(--grey);	
}
nav .navdrop{
	position: absolute;
	left: 0;
	width: 100%;
	height: 340px;
	padding: 20px 20px 30px;
}
nav .navdrop::before{
	content: '';
	position: absolute;
	top: 0;
	left: 50%;
	margin-left: -50vw;
	width: 100vw;
	height: 100%;
	background: var(--white);
	box-shadow: 0 20px 20px -16px rgba(53, 53, 53, 0.22);
}
.navdroppage{
	position: relative;
	display: grid;
	grid-template-columns: 300px 1fr;
	gap: 12px;
	height: 100%;
}
.navdroptitle{
	overflow: hidden;
	position: relative;
	font-size: 1.5em;
	background: var(--main);
	color: var(--white);
	padding: 30px;
	border-radius: 10px;
}
.navdropitems{
	display: flex;
  gap: 12px;
}
.navdropitems .item{
	width: 100%;
	background: var(--whitegrey);
	padding: 30px;
	border-radius: 10px;
	font-size: .9em;
}
.navdropitems .item h3{
	font-weight: 700;
	margin: 0 0 20px;
	padding: 0 0 20px;
	border-bottom: 1px solid var(--linelight);
}
.navdropitems .item ul{
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 10px;
	font-weight: 600;
	list-style-type: disc;
	list-style-position: inside;
	opacity: .55;
}
nav{
	font-size: 1.25em;
	font-weight: 700;
	margin-left: 50px;
}
nav ul{
	list-style-type: none;
	display: flex;
	align-items: center;
	padding: 0;
	margin: 0;
}
nav ul#primary-menu > li{
	position: relative;
	display: flex;
	align-items: center;
}
nav ul#primary-menu > li:after{
	content: '/';
	margin: 0 18px;
	font-weight: 100;
	opacity: .3;
}
nav ul#primary-menu > li:last-child::after{
	content: '';
	margin: 0;
}
nav ul li a{
	color: var(--black);
	opacity: 1;
	height: 50px;
	display: flex;
	align-items: center;
	justify-content: center;
	white-space: nowrap;
}
nav ul li a:hover, nav ul li.current-menu-item a, nav ul li.current_page_item a,  nav ul li.current_page_parent a, nav ul li.current a{
	opacity: 1;
	color: var(--main);
}
ul.sub-menu{	
	z-index: 1;
	position: absolute;
	left: 0;
	top: 100%;
	font-weight: 600;
	font-size: 1em;
	display: flex;
	flex-direction: column;
	gap: 0;
	align-items: flex-start;
}
ul.sub-menu li a{
	height: auto;
	line-height: 1.2;
}
.bt.mx240{
	max-width: 240px;
}
.bt.pri{
	background: var(--main);
}
.bt.pri.line{
	border: 2px solid var(--main);
	color: var(--white);
	background: transparent;
}
.bt.wicon{
	justify-content: space-between;
	padding: 0 30px;
}
.bt{
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	height: 55px;
	border: 0;
	border-radius: 12px;
	background: var(--indigo);
	color: #fff;
	font-weight: 600;
	width: 100%;
}
.bt svg{
	fill: var(--white);
	height: 16px;
	width: auto;
}
input, textarea{
	font-family: var(--sans);
	color: var(--black);
	border: 1px solid var(--whitegrey);
	background: var(--whitegrey);
	border-radius: 8px;
	width: 100%;
}
input{
	height: 50px;
	padding: 0 18px;
}
textarea{
	resize: vertical;
	padding: 18px;
}
.descsty{
	font-size: 15px;
	word-break: keep-all;
	color: var(--greytext);
}

.checkbox {
	cursor: pointer;
	display: flex;
	align-items: center;
	gap: 8px;
	line-height: normal;
}
.checkbox .check{
	display: flex;
	align-items: center;
	justify-content: center;
	width: 22px;
	height: 22px;
	background: var(--white);
	border: 1px solid var(--line);
	border-radius: 6px;
}
.checkbox.active .check svg{
	display: flex;
}
.checkbox .check svg{
	display: none;
	width: 80%;
	height: auto;
}

.fome_contact input, .fome_contact textarea{
	font-size: 1.1em;
}
.fome_contact{
	display: flex;
	flex-direction: column;
	gap: 16px;
}
.fome_contact .duo{
	display: flex;
	gap: 10px;
}
.fome_contact .submit{
	max-width: 200px;
	margin-left: auto;
}
.fome_contact .terminfo{
	height: 80px;
	overflow-y: auto;
	padding: 20px;
	background: var(--whitegrey);
	color: var(--greytext);
	font-size: .9em;
	border-radius: 8px;
}
.searchwrp{
	position: relative;
}
.searchbig {
	margin-top: -66px;
}
.searchbig form svg{
	height: 24px;
	width: 24px;
}
.searchbig form input{
	height: 55px;
	outline: 2px solid var(--indigo);
	background: var(--white);
	border-radius: 12px;
	font-size: 1.3em;
	font-weight: 500;
	box-shadow: 4px 12px 30px 6px rgba(0, 0, 0, .05);
}
.searchbig form{
	max-width: 600px;
	margin: 0 auto;
}
header .searchwrp input, header .searchwrp .dropdown{
	outline: none;
}
header .searchwrp input, .mgnb .searchwrp input{
	border-radius: 32px;
}
.searchwrp input{
	height: 44px;
	width: 100%;
	border: 0;
	border-radius: 8px;
	padding: 0 56px 0 18px;
	font-size: 1.1em;
	background: var(--whitegrey);
}
.searchwrp button{
	cursor: pointer;
	position: absolute;
	right: 0;
	top: 0;
	background: none;
	border: none;
	height: 100%;
	padding: 0 18px;
	color: var(--black);
	display: flex;
	align-items: center;
	justify-content: center;
}
.cover.withvid{
	margin: -82px 0 30px;
	padding: 162px 0 40px;
}
.cover{
	word-break: keep-all;
	overflow: hidden;
	position: relative;
	padding: 80px 0;
	margin: 0 0 20px;
	background: var(--black);
}
.cover .gra{
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	background: linear-gradient(90deg, rgb(15 38 76 / 100%) 40%, rgb(15 38 76  / 95%) 45%, rgb(15 38 76 / 0%) 80%);
}
.cover video{
	position: absolute;
	left: 40%;
	/* top: 50%;
	transform: translateY(-50%); */
	opacity: .8;
	height: 100%;
	width: 100%;
	max-width: 1200px;
	object-fit: cover;
}
.cover img{
	pointer-events: none;
	position: absolute;
	right: 0;
	top: 50%;	
	opacity: 1;
	height: auto;
	width: 100%;
	height: 100%;
	object-fit: cover;	
	transform: translateY(-50%) scale(1.0);
	/* animation: scaleDown 60s ease-out forwards; */
}
@keyframes scaleDown {
  from {
    transform: translateY(-50%) scale(1.5);
  }
  to {
    transform: translateY(-50%) scale(1);
  }
}
.home .cover img{
	width: 100%;
}
.cover img.grey{
  opacity: .35;
}
.home .cover svg{
	opacity: .6;
}
.cover svg{
	position: absolute;
	left: 50%;
	top: calc(50% + 138px);
	transform: translateY(-50%);
	opacity: .2;
	width: 1500px;
	height: 1500px;
}
.cover.white h1{
	font-size: 4.5em;	
	color: var(--main);
}
.cover.center{
	text-align: center;
}
.home .cover{
	font-size: 17px;
	padding: 180px 0;
	display: flex;
	flex-direction: column;
	justify-content: center;	
	background: var(--black);
	color: var(--white);
	text-align: center;
}
.home .cover .bts{
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 12px;
	margin: 50px 0 0;
}
.home .cover .bt{
	max-width: 200px;
	font-weight: bold;
	height: 58px;
	border-radius: 12px;
}
.home .cover h3{
	margin: 0 0 20px;
	font-size: 1.4em;
	opacity: .8;
}
.home .cover h1{
	position: relative;
}
.gridrightlong{
	display: grid;
	gap: 40px;
	grid-template-columns: repeat(2, 1fr);
}
.frontlist{
	display: grid;
	gap: 1px;
	grid-template-columns: repeat(2, 1fr);
	background: var(--linelight);
	border: 1px solid transparent;
	border-radius: 12px;
	overflow: hidden;
}
.frontlist > .item.focus{
	grid-row: 1 / span 2;
	height: 100%;
}
.frontlist .item h2{
	margin: 0;	
	font-size: 1.3em;
	font-weight: 600;
}
.frontlist .item img, .frontlist .item svg{
	position: absolute;
	right: 20px;
	bottom: 20px;
	width: auto;
	height: 40px;
}
.frontlist .item .inr{
	width: 100%;
	height: 100%; 
	padding: 20px;
}
.frontlist .item{
	position: relative;
	width: 100%;
	height: 100%;
	background: var(--white);
	display: flex;
	align-items: center;
	justify-content: center;
}
.frontlist .item svg .clsb-1, .frontlist .item svg .clsb-2{
	fill: var(--linelight);
}
.frontlist .item:hover svg .clsb-1{
	fill: var(--indigo);
}
.frontlist .item:hover svg .clsb-2{
	fill: var(--main);
}
.slo p{
	display: none;
}
.slo p.active{
	display: block;
}
.slolangset{
	display: flex;
	justify-content: center;
	margin-top: 30px;
	font-weight: 500;
	color: var(--grey);
}
.slolangset div.active{
	color: var(--white);
}
.slolangset div{
	position: relative;
	cursor: pointer;
	padding: 0 20px;
}
.slolangset div:first-child{
	border-right: 1px solid var(--line);
}
.cover h1 span{
	color: var(--main);
}
.cover h1{
	line-height: 1.4;
	margin: 0;
	color: var(--white);
}
.cover.white h2{
	color: var(--main);
}
.cover h2{
	font-weight: 600;
	font-size: 1.6em;
	margin: 0;
	opacity: 0.6;
}
.home .cover p{
	margin: 20px 0 0;
}
.cover p{
	font-weight: 400;
	font-size: 1.3em;
	margin: 10px 0 0;
	color: var(--white);
	opacity: .8;
}
.cover h1 a{
	text-decoration: underline;
}
.cover h1 a:hover{
	text-decoration: none;
}
.pagesubmenu{
	position: sticky;
	top: 82px;
	font-size: 1.2em;
	font-weight: 500;
	border-bottom: 1px solid var(--line);
	background: var(--white);
	margin: -30px 0 30px;
	z-index: 99;
	overflow-x: auto;
}
.pagesubmenu ul{
	list-style-type: none;
	padding: 0;
	margin: 0;
	display: flex;
	align-items: center;
	gap: 20px;	
}
.pagesubmenu ul li{
	padding-right: 20px;
	border-right: 1px solid var(--line);
}
.pagesubmenu ul li:last-child{
	border-right: 0;
}
.pagesubmenu ul li a{
	display: flex;
	align-items: center;
	color: var(--grey);
	white-space: nowrap;	
}
.pagesubmenu ul li.current-menu-item a,
.pagesubmenu ul li.current a{
	color: var(--main);
	font-weight: bold;
}

.sliderwrp{
	position: relative;
	width: 100%;
	margin: 0 0 50px;
}
.swiper {
	position: relative;
  width: 100%;
	height: 100%;
	max-width: 100%;
	border-radius: 12px;
}
.swiper .swiper-wrapper .swiper-slide .item{
	display: block;
	position: relative;
	width: 100%;
	height: 0;
	padding-top: 56.25%;
	border-radius: 12px;
	overflow: hidden;
	/* border: 1px solid rgba(0, 0, 0, 0.05); */
}
.swiper .swiper-wrapper .swiper-slide .item::after{
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;	
	background: rgb(0,0,0);
	background: linear-gradient(188deg, rgba(0, 0, 0, 0) 33%, rgb(0 0 0 / 38%) 76%, rgb(0 0 0 / 75%) 100%);
}
.swiper .swiper-wrapper .swiper-slide .item img{
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.swiper .swiper-wrapper .swiper-slide .item .meta{
	position: absolute;
	left: 0;
	bottom: 0;
	width: 100%;
	z-index: 1;
	color: var(--white);
	padding: 20px;	
	line-height: 1.3;
	font-size: 14px;
	word-break: keep-all;
}
.swiper .swiper-wrapper .swiper-slide .item .meta .title{
	font-size: 1.3em;
	font-weight: 500;
	max-width: 60%;
	line-height: 1.25;
}
.swiper .swiper-wrapper .swiper-slide .item .meta .summary{
	margin-top: 6px;
	max-width: 80%;
	opacity: .9;
	overflow: hidden;
	text-overflow: ellipsis;
}
.sliderbtprev, .sliderbtnext{
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	/* outline: 2px solid rgba(0, 0, 0, 0.05); */
	background: var(--dark);
	color: var(--white);
	height: 40px;
	width: 40px;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	z-index: 9;
}
.sliderbtprev{
	left: -20px;
}
.sliderbtnext{
	right: -20px;
}
.sliderbtprev svg, .sliderbtnext svg{
	width: 16px;
	height: 16px;
	fill: var(--white);
	opacity: .7;
}
video{
	width: 100%;
	height: auto;
}
.netgr svg.logo{
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 100%;
	height: auto;
	max-width: 70%;
	z-index: 1;
	fill: var(--main);
	z-index: 1;
}
.netgr svg.net{
	width: 100%;
	height: 100%;
	fill: var(--line);
}
.netgr{
	position: relative;
	width: 100%;
}
.awdstitle{
	position: relative;
	/* font-family: var(--serif); */
	font-size: 2em;
	font-weight: 700;
	text-align: center;	
	color: var(--black);
	margin: 30px 0 20px;
}
.awdstitle::before{
	content: '';
	position: absolute;
	left: 50%;
	bottom: -10px;
	transform: translateX(-50%);
	width: 100%;
	height: 2px;
	background: rgb(0, 0, 0);
	background: linear-gradient(90deg, rgba(54, 54, 54, 0) 0%, rgb(54, 54, 54) 50%, rgba(54, 54, 54, 0) 100%);
}
.ziglist.vtc .inflex{
	flex-direction: column;	
}
.ziglist.vtc .inflex .pd{
	padding: 0 50px 50px 50px;
	margin-top: -40px;
	z-index: 9;
	position: relative;
}
.ziglist.vtc .part{
	padding: 40px;
}
.greeting{
	max-width: 710px;
	margin: 0 auto;
	padding: 80px 0;
}
.mapswrp{
	width: 100%;
}
.inflex{
	display: flex;
	align-items: center;
	gap: 60px;
}
.inflex.rever .thumb{
	order: 1;
}
.midtitle img{
	position: absolute;
	top: 7px;
	left: 0;
	width: 100%;
	height: auto;
	opacity: .04;
}
.midtitle{	
	position: relative;
	margin: 0 0 20px 0;
}
.midtitle h1{
	margin: 0 0 10px;
	color: var(--main);
}
.midtitle p{
	margin: 0;
	color: var(--grey);
}
.ziglist.vtc .part .inflex .thumb{
	position: relative;
	height: 0;
	padding-top: 46%;
	background: var(--black);
}
.ziglist.vtc .part .inflex .thumb::after{
	content: '';
	position: absolute;
	left: 0;
	bottom: 0;
	width: 100%;
	height: 100%;
	z-index: 1;
	background: var(--black);
	background: linear-gradient(1turn, var(--black) 8.98%, rgba(0, 0, 0, 0) 100%)
}
.ziglist.vtc .part .inflex .tex .thumb img{
	border-radius: 0;
	box-shadow: none;
	opacity: .7;
}
.ziglist.vtc .part .inflex .thumb img{
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	
	object-fit: cover;
}
.ziglist .part .inflex .thumb{
	width: 100%;	
	height: auto;
	/* padding-top: 32%; */
	display: flex;
	position: relative;
}
.ziglist .part .thumb.h250 img{
	max-height: 250px;
}
.ziglist .part .thumb.h600 img{
	max-height: 600px;
}
.ziglist .part .thumb img{
	width: 100%;
	height: auto;
	object-fit: cover;
	/* border-radius: 24px;
	box-shadow: -10px 15px 40px rgb(0 0 0 / 20%); */
	/* position: absolute; */
	top: 0;
	left: 0;
}
.ziglist .part .inflex .tex .key{
	color: var(--main);
	font-weight: 600;
	font-size: 1.05em;
	margin-bottom: 8px;
}
.ziglist.vtc .part .tex{
	border: 1px solid var(--linelight);
	background: var(--black);
	border-radius: 20px;
	overflow: hidden;
}
.ziglist .part .tex .label{
	display: flex;
	align-items: flex-end;
	gap: 10px;	
	color: var(--main);
	margin-top: 1.3em;
}
.ziglist .part .inflex .tex .label h4{
	color: var(--main);
	margin: 0;
	line-height: normal;
}
.texflex{
	display: flex;
	gap: 10px;
	margin: 0 0 30px;
}
.texflex p{
	margin-top: 0;	
	text-align: justify;
	word-break: break-all;
}
.texflex .title h3{
	margin-top: 0;
}
.texflex .title a{
	color: var(--main);
	font-weight: 500;
	font-size: .8em;
	display: flex;
	align-items: center;
	gap: 5px;
}
.texflex .title a svg{
	width: 12px;
	height: 12px;
}
.texflex .title{
	flex: 0 0 150px;
}
.texflex .thumb{
	flex: 0 0 300px;
	padding-left: 40px;
}
.home .tabwrp{
	position: static;
	margin: 0 0 40px;
}
.home .tabwrp .tablink a:hover{
	outline: 3px solid var(--main);
	border-radius: 10px;
}
.tabwrp.vtc{
	position: static;
}
.tabwrp img.grey{
	pointer-events: none;
	position: absolute;
	right: 0;
	top: 50%;
	transform: translateY(-50%);
	opacity: 1;
	height: auto;
	width: 100%;
	height: 100%;
	object-fit: cover;
	opacity: .4;
}
.tabwrp{
	position: sticky;
	top: 91px;
	background: transparent;
	padding: 30px 0 0;
	z-index: 999;
	border-bottom: 3px solid var(--black);
	background: var(--black);
}
.tabwrp section{
	padding: 0 20px;
}
.tabwrp.vtc .tablink{
	flex-direction: column;
}
.tabwrp.vtc .tablink a{
	border-right: 0;
	border-bottom: 1px solid var(--linelight);
	align-items: flex-start;
	padding: 0 30px;
}
.tabwrp.vtc .tablink a:last-child{
	border-bottom: 0;
}
.tablink{
	display: flex;
	border-radius: 8px;
	max-width: 98%;
	margin: 0 auto -3px;
}
.tablink a:last-child{
	border-right: 0;
}
.tablink a.active{	
	border-radius: 19px 19px 0 0;
	border: 3px solid var(--indigo);
	border-bottom-color: var(--white);
	background: var(--white);
	color: var(--black);
}
.tablink a{
	border: 3px solid transparent;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	height: 66px;
	width: 100%;
	font-size: 1.3em;
	font-weight: 600;
	color: var(--white);
	padding-top: 8px;
}
.tablink a small{
	font-weight: 300;
	font-size: .7em;
	opacity: .6;
}
.aboutaddr{
	font-size: .9em;
	list-style-type: none;
}
.aboutaddr li{
	margin: 4px 0;
}
.aboutaddr span{
	margin-right: 16px;
}
.ziglist{
	font-size: 17px;
	display: flex;
	flex-direction: column;
	overflow: hidden;
	gap: 4px;
}
.ziglist.outline{
	overflow: hidden;
	gap: 4px;
}
.ziglist .part{
	padding: 70px;
	outline: none;
}
.ziglist .part.line{
	border-bottom: 1px solid var(--linelight);
}
.ziglist .part.linetop{
	border-top: 1px solid var(--linelight);
}
.ziglist.vtc h2{
	font-size: 1.6em;
}
.ziglist .greeting h2{
	font-size: 1.9em;
}
.ziglist h2{
	word-break: keep-all;
	line-height: 1.45;
	font-size: 1.7em;
	margin: 0;
}
.ziglist small{
	opacity: .4;
}
.ziglist.vtc small{
	opacity: .8;
}
.ziglist ul{
	list-style-type: none;
	list-style-position: inside;
	padding: 0;
	font-weight: 300;
}
.ziglist ul li{
	display: flex;
	align-items: center;
}
.ziglist ul li::before{
	content: '';
	display: inline-flex;
	width: 6px;
	height: 6px;
	flex: 0 0 6px;
	background: var(--main);
	transform: rotate(45deg);
	margin-right: 10px;
}
.ziglist .detail{
	line-height: 1.65;
	font-size: .85em;
	margin: 60px 0 0;
	background: var(--whitegrey);
	color: var(--greytext);
	padding: 40px;
	border-radius: 20px;
}
.ziglist .detail p:first-child{
	margin-top: 0;
}
.ziglist .part ul.companyspec{
	margin: 60px 0 0;
	color: var(--greytext);
	font-size: .9em;
	font-weight: 300;
}
.ziglist .part ul.companyspec li::before{
	display: none;
}
.ziglist .part ul.companyspec li span.label::before{
	content: '';
	display: inline-flex;
	width: 6px;
	height: 6px;
	flex: 0 0 6px;
	background: var(--main);
	transform: rotate(45deg);
	margin-right: 10px;
}
.ziglist .part ul.companyspec li {
	text-align: left;
	padding: 8px 0;
	border-bottom: 1px dotted var(--linelight);
}
.ziglist .part ul.companyspec li:last-child{
	border-bottom: 0;
}
.ziglist .part ul.companyspec li span.label{
	width: 120px;
	color: var(--black);
	font-weight: 500;
	white-space: nowrap;
	display: flex;
	align-items: center;
}
.ziglist .part .tex ul li{
	word-break: keep-all;
	margin: 0 0 5px;
}
.ziglist .part .tex p {
	word-break: keep-all;
	font-weight: 300;
}
.ziglist .part p span{
	font-weight: 500;
	color: var(--main);
}
.ziglist .part p:last-child{
	margin-bottom: 0;
}
.ziglist .part .tex.bold{
	color: var(--black);
	font-weight: 500;
}
.ziglist .part .tex.ilist{
	display: flex;
	flex-direction: column;
}
.ziglist .part .tex.ilist .item h3{
	margin-top: 0;
}
.ziglist .part .tex.ilist .item p{
	font-size: .95em;
}
.ziglist .part .tex.ilist .item{
	border-bottom: 1px solid var(--line);
	padding: 30px;
}
.ziglist .part .tex.ilist .item:last-child{
	border-bottom: 0;
}

.ziglist .part .tex{
	width: 100%;
	margin: 0 auto;
}
.ziglist .part .tex h2.blue{
	color: var(--main);
}
.ziglist .part img{
	width: 100%;
	height: auto;
}
.parts{
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 60px;
}
.parts .part{
	padding: 40px 0;
}
.parts .part:last-child{
	border-right: 0;
	border-bottom: 0;
}
.parts .part a{
	color: var(--main);
	font-weight: 500;
}
.maps{
	display: flex;
	overflow: hidden;
	border-radius: 12px;
}
.maps iframe{
	width: 100%;
	height: 514px;
}
.clist.mlist .item:nth-child(2){
	background: #15469d;
}
.clist.mlist .item:nth-child(3){
	background: #2659b5;
}
.clist.mlist .item:nth-child(4){
	background: #3a67b5;
}
.clist.mlist .item{
	cursor: pointer;
	position: relative;
	background: var(--main);
	color: var(--white);
	overflow: hidden;	
	-webkit-transition: all .3s ease;
	transition: all .3s ease;
}
.clist.mlist .item:hover{
	-webkit-transform: translateY(-5px);
	transform: translateY(-5px);
	-ms-transform: translateY(-5px);
}
.clist.mlist .item img, .clist.mlist .item svg{
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translateX(-50%) translateY(-50%);
	width: 100%;
	height: auto;
	object-fit: cover;
	opacity: .3;
	fill: var(--white);
}
.clist.mlist .item .title{
	position: relative;
	font-size: 1.4em;
	font-weight: bold;
}
.clist.plist{
	grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
	gap: 1px;
	outline: 1px solid var(--line);
	border-radius: 12px;
	overflow: hidden;
}
.clist.plist .item:hover{
	background: var(--white);
}
.clist.plist .item{
	display: flex;
	align-items: center;
	height: auto;
	overflow: hidden;
	border-radius: 0;	
	outline-color: #eee;
	background: #fbfbfb;
}
.clist.plist .item .avatar{
	position: relative;
	flex: 0 0 45%;
	width: 100%;
	height: 0;
	padding-top: 58%;
}
.clist.plist .item .avatar img.default{
	opacity: .45;
}
.clist.plist .item .avatar img{
	position: absolute;
	bottom: 0;
	left: 0;
	width: 170px;
	height: auto;
	object-fit: cover;
}
.clist.plist .item .profile{
	font-size: 13px;
	line-height: 1.3;
	color: var(--indigo);
	width: 100%;
	padding: 16px;
	display: flex;
	flex-direction: column;
	gap: 8px;
	word-break: break-word;
}
.clist.plist .item .profile .name{
	font-size: 1.2em;
	font-weight: bold;
	color: var(--black);
	margin: 0 0 4px;
}
.clist.plist .item:hover .profile .email{
	text-decoration: underline;
}
.clist.plist .item .profile .email{
	color: var(--main);
	font-size: .95em;
	font-weight: 500;	
}
.clist{
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
	gap: 20px;
	margin: 50px 0;
}
.clist.c1{
	grid-template-columns: repeat(1, 1fr);
}
.clist.c2{
	grid-template-columns: repeat(2, 1fr);
}
.clist.c3{
	grid-template-columns: repeat(3, 1fr);
}
.clist.c3.onlythumb.ratio .item{
	position: relative;
	height: 0;
	padding-top: 52%;
	overflow: hidden;
}
.clist.c3.onlythumb .item img{
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.clist.c3 .item{
	flex-direction: column;
	align-items: flex-start;
	justify-content: flex-start;
	height: auto;
	padding: 30px;
}
.clist.c3 .item ul{
	display: flex;
	flex-direction: column;
	gap: 5px;
	margin-right: auto;
	padding: 0;
	font-size: 1.2em;
	font-weight: 500;
}
.clist.c3 .item ul li{
	display: flex;
	align-items: center;
	gap: 5px;
}
.clist.c3 .item ul li label{
	display: flex;
}
.clist.c3 .item ul li label img{
	width: 50px;
	height: auto;
}
.clist.c3 .item .title{
	width: 100%;
	font-size: 1.2em;
	font-weight: bold;
	padding: 0 0 20px;
	margin: 0 0 10px;
	border-bottom: 1px solid var(--line);
}    
.clist.c5{
	grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
	gap: 15px;
}
.clist.c5.ratio .item{
	position: relative;
	height: 120px;
}
.clist.c5.ratio .item img{
	height: 60%;
	width: 60%;
	object-fit: contain;
}
.clist .item{
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: center;		
	outline: 1px solid var(--line);
	border-radius: 10px;
	height: 180px;
}
.clist .item img{
	width: 60%;
	height: 60%;
	object-fit: contain;
}
.archive_title.onlym{
	display: none;
}
.archive_title{
	margin: 0 0 30px;
}
.archive_title h1{
	font-size: 1.6em;
}
.archive_title h1 span{
	color: var(--grey);
	font-weight: 500;
	margin-right: 7px;
	font-size: .8em;
}
.sidewrp.hf{
	grid-template-columns: 300px repeat(1, 1fr);
	gap: 80px;
}
.sidewrp{
	display: grid;
	grid-template-columns: 300px repeat(1, 1fr);
	gap: 40px;
}
.sidebar h2{
	margin: 0 0 25px;
	padding: 0 0 25px;
	border-bottom: 1px solid var(--line);	
}
.sidebar ul{
	list-style-type: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;	
	font-size: 1.2em;
}
.sidebar ul li.current-menu-item a{
	text-decoration: underline;
	font-weight: bold;
}
.sidebar ul li a{
	display: flex;
	padding: 10px 0;
	font-weight: 400;
}
.sidebar ul li a:hover{
	text-decoration: underline;
}
.listwrp#students{
	border-top: 1px solid var(--linelight);
}
.listwrp.sml{
	max-width: 800px;
	margin: 0 auto;
}
.wib{
	padding: 46px;	
	border-radius: 20px;
	outline: 1px solid var(--linelight);
	margin: 0 0 55px;
}
.listtools{
	display: flex;
	gap: 12px;
	margin: -45px 0 20px;
}
.listtools #sortby{
	min-width: 200px;
	height: 50px;
	outline: 2px solid var(--line);
}
.newsletterwrp{	
	position: relative;
	display: flex;
	width: 100%;
}
.newsletterwrp input{
	border-radius: 10px 0 0 10px;
}
.newsletterwrp button{
	cursor: pointer;
	background: var(--main);
	color: var(--white);
	border: 0;
	border-radius: 0 10px 10px 0;
	padding: 0 20px;	
	font-weight: 500;
}
.searchwrp{
	max-width: 300px;
	width: 100%;
	display: flex;
}
/* .listcatswrp{
	border-right: 1px solid var(--linelight);
} */
.listcatswrp section{
	padding-top: 0;
	padding-bottom: 0;
	display: flex;
	align-items: center;
	justify-content: space-around;
	gap: 12px;
}
.listcats.grid{
	position: static;
	display: grid;
	gap: 14px;
	grid-template-columns: repeat(3, 1fr);
	margin: 20px 0 60px;
	overflow: hidden;
}
.listcats.grid .item::before{
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: linear-gradient(120deg, rgb(255 255 255 / 100%) 66%, rgb(255 255 255 / 95%) 68%, rgb(255 255 255 / 0%) 70%);
	z-index: 1;
}
.listcats.grid.catsty1 .item{
	display: block;
	height: auto;
	padding: 0;	
}
.listcats.grid.catsty1 .item .meta{
	padding: 16px 18px 18px;
}
.listcats.grid.catsty1 .item .ratio{
	position: relative;
	width: 100%;
	height: 0;
	padding-top: 66.66%;
	overflow: hidden;
	background: var(--white);
}
.listcats.grid.catsty1 .item img{
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	object-fit: cover;
}
.listcats.grid.catsty1 .item .meta .title{
	color: var(--black);
	font-size: 1em;
	font-weight: 600;
}
.listcats.grid.catsty1 .item::before{
	display: none;
}
.listcats.grid.catsty1 .item .desc{	
	overflow: hidden;
	text-overflow: ellipsis;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	word-wrap: break-word;
	word-break: auto-phrase;
	white-space: normal;
	line-height: 1.3;
	font-weight: 300;
	font-size: .8em;
	margin-top: 6px;	
}
.listcats.grid .item{
	position: relative;
	width: 100%;
	height: 0;
	padding-top: 40%;
	background: var(--white);
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
	border: 1px solid var(--linelight);
	border-radius: 12px;
	/* box-shadow: 0 3px 10px 0px rgb(0 0 0 / 3%); */
}
.listcats.grid .item img{
	position: absolute;
	bottom: 0;
	right: 0;
	width: 50%;
	height: 100%;
	object-fit: cover;
	opacity: 1;
	filter: grayscale(0%);
}
.listcats.grid .item a{
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	padding: 26px;
	color: var(--black);
	z-index: 2;
}
.listcats.grid .item a .titlewrp{
	width: 100%;
}
.listcats.grid .item a .title{
	font-size: 1em;
	font-weight: 600;
}
.listcats.grid .item a .desc{
	font-size: .73em;
	font-weight: 400;
	color: var(--grey);
	overflow: hidden;
	text-overflow: ellipsis;
	width: 59%;
}
.listcats{
	display: grid;
	grid-template-columns: repeat(1, 1fr);
	font-size: 1.22em;
	position: sticky;
  top: 110px;	
	margin: 0 0 40px;
}
.listcats .cat{
	display: flex;
	align-items: center;
}
.listcats .cat:last-child{
	border-bottom: 0;
}
.listcats .cat a::before{
	content: '';
	display: flex;
	width: 6px;
	height: 6px;
	background: var(--grey);
	transform: rotate(45deg);
	margin-right: 8px;
}
.listcats .cat:last-child:after{
	content: '';
	margin: 0;
}
.listcats a{
	width: 100%;
	display: flex;
	align-items: center;
	font-weight: 500;
	font-size: 1.02em;
	white-space: nowrap;
	padding: 11px 6px;
	color: var(--grey);
}
.listcats .cat:first-child a{
	padding-top: 2px;
}
.listcats .cat a.current::before{
	background: var(--black)!important;
}
.listcats a.current span{	
	font-weight: 700;
	color: var(--black)!important;
	/* border-color: var(--main)!important; */
}
.listcats .cat a:hover::before{
	background: var(--black);
}
.listcats a:hover span{
	color: var(--black);
	/* border-color: var(--black); */
}
.listcats a span{
	width: 80%;
	/* border-right: 4px solid var(--white); */
}
.listcats.grid a span{
	width: auto;
	margin-left: auto;
	font-size: .85em;
	color: var(--grey);
	font-weight: 500;
}
.list.dnl{
	grid-template-columns: repeat(2, 1fr);
	gap: 1px;
	background: var(--linelight);
}
.list.front.dnl{
	gap: 0;
	grid-template-columns: repeat(1, 1fr);
	background: var(--white);
}
.list.front.dnl .hentry{
	border-radius: 0;
	margin: 0 0 18px;
	padding: 0 0 18px;
	border-bottom: 1px solid var(--linelight);
}
.list.front.dnl .hentry:last-child{
	margin-bottom: 0;
	padding-bottom: 0;
	border-bottom: 0;
}
.list{
	display: grid;
	gap: 16px;
	grid-template-columns: repeat(3, 1fr);
}
.list.projects{
	display: grid;
	grid-gap: 40px;
	grid-template-columns: repeat(3, 1fr);
}
.list.projects .hentry{
	display: flex;
	flex-direction: column;
	border: 0;
	gap: 10px;
}
.list .hentry:last-child{
	border-bottom: 0;
}
.list.team .hentry{
	grid-template-columns: 100px 1fr;
}
.list.team .hentry .ratio{
	padding-top: 100%;
	clip-path: url(#clipRoundSquare);
}
.sidewrp .list .hentry{
	padding: 26px 0;
}
.sidewrp .list .hentry:first-child{
	padding-top: 0;
}
.sidewrp .list .hentry:last-child{
	padding-bottom: 0;
}
.list .hentry{	
	position: relative;
	width: 100%;
	overflow: hidden;
	display: flex;
	flex-direction: column;
}
.list .hentry .ratio{
	position: relative;
	width: 100%;
	height: 0;
	padding-top: 80%;
	overflow: hidden;
	background: var(--whitegrey);
	border: 1px solid var(--linelight);
	border-radius: 8px;
}
.list .hentry.type-publication .ratio{
	background: #fff;
}
.list .hentry.type-publication .ratio img{
	object-fit: contain;
}
.list .hentry .ratio img{
	opacity: .95;
	position: absolute;
	width: 100%;
	height: 100%;
	object-fit: cover;
	top: 0;
	left: 0;
}
.list.dnl .hentry{
	border-bottom: 0px solid var(--linelight);
	padding: 24px 16px;
	background: var(--white);
}
.list.dnl .hentry:hover .title{
	text-decoration: underline;
}
.list.dnl .hentry .meta > div:last-child{
	border-right: 0;
	padding-right: 0;
	margin-right: 0;
}
.list.dnl .hentry .meta > div{
	border-right: 1px solid var(--line);
	padding-right: 7px;
	margin-right: 7px;
}
.list.dnl .hentry .meta{
	font-weight: 300;
	font-size: .97em;
	display: flex;
	align-items: center;
	line-height: normal;
	margin: 5px 0 0;
	padding: 0;
}
.list.dnl .hentry .title{
	font-weight: 600;
	font-size: 1.15em;
}
.list.dnl.front .hentry .title{
	font-size: 1.1em;
}
.list .hentry .meta {
	word-break: keep-all;
	color: var(--grey);
	padding: 10px 8px;
	margin: 0 0 10px 0;
}
.list .hentry .meta .bt{
	max-width: 110px;
	position: absolute;
	top: 20px;
	right: 30px;
	font-size: 1em;
	height: 40px;
}
.list.team .hentry .meta .bio{
	margin: 0 0 30px;
}
.list.team .hentry .meta .yearwrp{
	display: flex;
	align-items: center;
	margin: 0;
	font-size: .9em;
}
.list.team .hentry .meta .yearwrp a{
	font-weight: 400;
}
.list.team .hentry .meta .yearwrp a:hover{
	text-decoration: underline;
}
.list .hentry .meta .yearwrp .dv{
	content: '';
	display: flex;
	width: 2px;
	height: 2px;
	background: var(--grey);
	border-radius: 50%;
	margin: 0 8px;
}
.list .hentry .meta .yearwrp{
	margin: 10px 0 0;
	color: var(--grey);
	font-size: .9em;
}
.list .hentry .meta .position{
	color: var(--main);
	font-weight: 400;
	font-size: 1.05em;
}
.list .hentry .meta .cats{	
	color: var(--main);
	font-size: .95em;
	display: flex;
	gap: 5px;
	align-items: center;
	flex-wrap: wrap;
}
.list .hentry .meta .cats a{
	color: var(--main);
	font-weight: bold;
}
.list .hentry .meta .cats a:hover{
	text-decoration: underline;
}
.list.nhover .hentry:hover .meta .title{
	color: var(--white);
	text-decoration: none;
}
.list .hentry .meta .title{
	display: flex;
	font-weight: 600;      
	font-size: 1.1em;
	line-height: 1.3;
	color: var(--black);
	margin: 0 0 6px;
}
.list .hentry .meta .desc{
	line-height: 1.25;
	font-size: .9em;
	font-weight: 300;
	overflow: hidden;
	text-overflow: ellipsis;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	word-wrap: break-word;
	word-break: auto-phrase;
}
.list .hentry .meta .bio strong{
	font-weight: 500;
}
.list .hentry .meta .con{
	font-size: 1.15em;
	color: var(--black);
	opacity: .8;
}
.list .hentry .meta .authors{
	font-size: 1em;
}
.list .hentry .meta .authors strong{
	color: var(--sub);
}
.list .hentry .meta .exc{
	overflow: hidden;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	word-break: keep-all;
	margin: 5px 0;
	line-height: 1.5;
}
.list .hentry.type-publication .meta .date{
	display: inline-block;
}
footer .sitename{
	font-size: 1.2em;
	font-weight: 600;
	color: var(--white);
	margin: 0 0 15px;
}
footer .sitename svg .cls-1{
	fill: var(--white);
}
footer .sitename svg{
	height: 14px;
	width: auto;
}
footer img.grey{
	pointer-events: none;
	position: absolute;
	right: 0;
	top: 50%;
	transform: translateY(-50%);
	opacity: 1;
	height: auto;
	width: 100%;
	height: 100%;
	object-fit: cover;
	opacity: .25;
}
footer{
	position: relative;
	padding: 40px 0;
	margin: 60px 0 0;
	line-height: 1.6;	
	word-break: keep-all;
	color: var(--grey);
	background: var(--indigo);
}
footer .dnb{
	display: flex;
}
footer .dv{
	border-right: 1px solid var(--linewhite);
	margin: 0 8px;
}
footer .copyright{
	font-size: .9em;
	margin: 14px 0 0;
}
footer .foolist{
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 40px;
	margin: 0 0 40px;	
}
footer .foolist .part{
	border-right: 1px solid var(--line);
	padding-right: 40px;
}
footer .foolist .part:last-child{
	border-right: 0;
}
footer a{
	color: var(--grey);
}
footer .foolist .dnb a::after{
	content: '/';
	margin: 0 12px;
}
footer .foolist .dnb a:last-child::after{
	display: none;
}
footer .foolist .dnb a span{
	font-weight: 500;
}
footer .foolist .dnb a:hover span{
	text-decoration: underline;
}
footer h3{
	font-weight: 600;
	font-family: var(--sans);
}
.single_thumbnail{
	position: relative;
	display: flex;
	width: 100%;
	height: 0;
	padding-top: 56.25%;
	overflow: hidden;
  background: var(--whitegrey);
  border-radius: 12px;
}
.single_thumbnail img{
	width: 100%;
	height: 100%;
	position: absolute;
	object-fit: cover;
	left: 0;
	top: 0;
}
.single_tags{
	color: var(--blue);
	margin: 60px 0 0;
}
.single_tags a::before{
	content: '#';
}
.single_tags a{
	font-weight: 500;
	color: var(--main);
	background: var(--dark);
	border-radius: 30px;
	padding: 6px 12px;
	margin: 0 10px 0 0;
}
.single_metawrp{
	margin: 20px 0 30px;
}
.single_meta{
	position: relative;
	display: flex;
	border-bottom: 2px solid var(--black);
	padding-bottom: 20px;
}
.single_meta .item{
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	height: 55px;
	border-right: 1px solid var(--linelight);
	font-weight: 700;
	font-size: 1.1em;
}
.single_meta .item:last-child{
	border-right: 0;
}
.single_meta #share{
	cursor: pointer;
	position: absolute;
	right: -13px;
	top: 50%;
	transform: translateY(-50%);
	width: 52px;
	height: 52px;
	display: flex;
	align-items: center;
	justify-content: center;
}
.bread_cats{
	color: var(--grey);
	display: flex;
	align-items: center;
	padding: 0 30px;
	margin-top: 60px;
	font-size: 1.05em;
}
.bread_cats .sec svg{
	height: 16px;
	width: auto;
	opacity: .55;
}
.bread_cats .sec{
	display: flex;
	align-items: center;
	margin: 0 4px;
}
.bread_cats a{
	color: var(--grey);
}
.bread_cats a.current{
	color: var(--black);
	font-weight: 600;
}
.single_date{
	color: var(--grey);
}
.single_title{
	word-break: keep-all;
	padding: 30px;
}
.single_title h1{
	margin: 0;
	line-height: 1.2;
}
.single_title p{
	font-weight: 500;
	font-size: 1.3em;
	margin: 10px 0 0;
	color: var(--grey);
}
.single_content{
	font-size: 1.1em;
}
.single_content .item h3{
	margin-top: 0;
	font-weight: 700;
}
body.single-dnl .single_content .item{
	padding: 20px 30px;
}
.single_content .item{
	padding: 30px;
}
.single_content .item .con iframe{
	width: 100%;
	height: 440px;
}
.single_content .item .con img{
	width: 100%;
	height: auto;
}
.single_content .item:last-child{
	border-bottom: 0;
}
.single_content .item ul.spec.dnl a{
	white-space: nowrap;
  max-width: calc(100% - 150px);
  overflow: hidden;
  text-overflow: ellipsis;
}
.single_content .item ul.spec{
	list-style-position: inside;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	color: var(--greytext);
}
.single_content .item ul.spec li:last-child{
	border-bottom: 0;
}
.single_content .item ul.spec li{
	display: flex;
	border-bottom: 1px solid var(--linelight);
	padding: 8px 0;	
	font-weight: 300;
}
.single_content .item ul.spec strong{
	font-weight: 500;
	width: 150px;
}
.single_content p:last-child{
	margin-bottom: 0;
}
.single_content img{
	max-width: 100%;
	height: auto;
}
.single_content a{
	color: var(--blue);
}
#pagination {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: space-around;
	gap: 20px;
	padding: 20px 0;
	margin: 20px auto 0;
	width: 100%;
}
#pagination .arrows {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 12px;
	order: 2;
}
#pagination .page-numbers.current {
	display: none;
}
#pagination button {
	cursor: pointer;
	height: 55px;
	width: 170px;
	font-weight: 600;
	color: var(--white);
	background: var(--indigo);
	border: 1px solid var(--indigo);
	border-radius: 12px;
	display: flex;
	align-items: center;
	justify-content: space-around;
}
#pagination button svg {
	height: 20px;
	width: auto;
}
#pagination .counts {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 9px;
	font-size: 1em;
	color: var(--grey);
}
#pagination .counts #pagego{
	cursor: pointer;
	display: none;
	align-items: center;
	justify-content: center;
	height: 26px;
	padding: 0 10px;
	flex: 0 0 auto;
	font-weight: 500;
	background: var(--black);
	color: var(--white);
	border-radius: 4px;
	font-size: .95em;
}
#pagination .counts input {
	text-align: center;
	height: 26px;
	font-size: 1em;
	padding: 4px;
	width: 40px;
}
#pagination .counts input::-webkit-inner-spin-button,
#pagination .counts input::-webkit-outer-spin-button {
	-webkit-appearance: none;
	appearance: none;
	margin: 0;
}
#pagination .counts .total{
	color: var(--grey);
}
#movetop{
  position: fixed;
  right: 20px;
  bottom: 20px;
  width: 55px;
  height: 55px;
  background-color: var(--white);
	box-shadow: 4px 12px 30px 6px rgba(0, 0, 0, .05);
  border-radius: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 0.2s linear 0s;
  transform: translateY(84px);
  z-index: 999;
}
#movetop svg{
  width: 24px;
  height: auto;
}
.otherpost{
	display: flex;
	flex-direction: column;
	font-size: 1.1em;
	margin: 60px 0 0;
}
.otherpost a{
	cursor: pointer;
	width: 100%;
	font-weight: 600;
	border-bottom: 1px solid var(--linelight);
	padding: 20px 30px;	
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	color: var(--grey);
}
.otherpost a:last-child{
	border-bottom: 0;
}
.otherpost a:hover{
	color: var(--black);
}
.otherpost a:hover svg{
	fill: var(--black);
}
.otherpost a svg{	
	height: 18px;
	width: auto;
	fill: var(--grey);
}
.otherpost a .arrow{
	display: flex;
	align-items: center;
	gap: 8px;
	margin-right: 14px;
}
.otherpost .title{
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;	
	max-width: calc(100% - 80px);	
}
#alert{
	opacity: 0;
	position: fixed;
	bottom: 10vh;
	left: 50%;
	transform: translateX(-50%) translateY(20vh);
	background: var(--black);
	color: var(--white);
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 32px;
	padding: 0 25px;
	height: 58px;	
	white-space: nowrap;
	transition: opacity .3s;
	/* transition: all 0.2s linear 0s; */
}

@media screen and (max-width: 1024px){
	nav{
		margin-left: 10px;
	}
	nav ul{
		gap: 20px;
	}
	.site-branding img, .site-branding svg{
		height: 24px;
		width: auto;
	}
	.site-branding{
		font-size: 1.5em;
	}
	#movetop{
		right: 13px;
		bottom: 13px;
	}
}
@media screen and (max-width: 1080px){

	nav, .searchwrp.onlyd, header section .bn .bt.contact, header .searchwrp{
		display: none;
	}
	.bt.onlym, #hisback.onlym{
		display: flex;		
	}	
	#hisback.onlym{
		margin-left: -20px;
	}

	.archive_title.onlym{
		display: block;
	}

}
@media screen and (max-width: 768px){	
	body{
		font-size: 12px;
	}
	header{		
		padding: 0;
		margin: 0;
	}	
	footer .dnb{
		margin: 12px 0;		
		flex-direction: column;
		gap: 2px;
	}
	footer .foolist{
		grid-template-columns: repeat(1, 1fr);
		gap: 25px;
	}
	footer .foolist .part{
		border-right: 0;
		padding-right: 0;
	}
	header section{
		padding: 10px 20px;
	}

	section.wside{
		grid-template-columns: repeat(1, 1fr);
	}

	.list{
		grid-template-columns: repeat(2, 1fr);
		gap: 10px;
	}

	.gridrightlong{
		grid-template-columns: repeat(1, 1fr);
	}

	.listcatswrp section{
		flex-direction: column;
		align-items: flex-start;
	}
	.listcatswrp section .searchwrp{
		max-width: 100%;
	}
	.listcats a{
		height: auto;
	}
	
	.listcats .cat::after{
		margin: 0 13px;
	}

	.listcats.grid{
		gap: 6px;
		grid-template-columns: repeat(2, 1fr);
		margin: 20px -10px 34px;
	}
	.listcats.grid .item{
		padding-top: 50%;
	}
	.listcats.grid .item a{
		padding: 14px;
	}
	.frontlist{
		margin: 0 -10px;
	}
	.frontlist .item{
		height: 80px;
	}
	.frontlist .item .inr{
		padding: 12px;
	}
	.frontlist .item h2{
		font-size: 1.2em;
	}

	.tabwrp{
		top: 71px;
	}
	.tablink a{
		height: 55px;
	}
	.cover{
		padding: 30px 0;
	}
	.cover.withvid{
		padding: 78px 0 10px;
		margin: -68px 0 0;
	}
	.midtitle h1{
		font-size: 1.7em;
	}
	.pagesubmenu{
		top: 68px;
		margin: 0 0 20px;
	}
	.cover section{
		justify-content: flex-start;
	}
	.cover.center{
		text-align: left;
		padding: 30px 30px 15px;
	}	
	.home .cover{
		font-size: 15px;
		margin: 0;
		padding: 30px 0;
	}
	h1{
		font-size: 1.7em;
	}
	.single_title h1{
		font-size: 2em;
	}
	.cover h2{
		font-size: 1.3em;
	}
	.cover h1 br{
		display: none;
	}
	.cover p{
		font-size: 1.15em;
	}
	.home .cover .bt{
		height: 55px;
	}
	.home .cover .bts{
		margin-top: 30px;
	}
	.wib{
    padding: 30px 20px;
    margin: 0 -20px 50px;
    border-radius: 0;
	}
	section.slidersection{
		margin-top: -85px;
	}
	.sliderwrp{
		margin: 0 0 15px;
	}
	.swiper .swiper-wrapper .swiper-slide .item .meta .title{
		max-width: 90%;
		font-size: 1.2em;
	}
	.sliderbtprev, .sliderbtnext{
		display: none;
	}
	.swiper .swiper-wrapper .swiper-slide .item .meta{
		padding: 12px;
		font-size: 12px;
	}
	.clist .item{
		height: 150px;
	}
	.clist.plist .item{
		border-radius: 10px;
	}
	.clist.plist{
		grid-template-columns: repeat(1, 1fr);
		outline: none;
		overflow: visible;
		gap: 12px;
	}
	.clist.plist .item .avatar{
		padding-top: 48%;
	}
	.clist.plist .item .avatar img{
		width: 151px;
	}
	.clist.plist .item .profile{
		font-size: 12px;
	}
	.clist.c2, .clist.c3{
		grid-template-columns: repeat(1, 1fr);
		gap: 12px;
	}
	.clist, .clist.c5{
		grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
    gap: 10px;
		margin: 30px 0;
	}
	.ziglist .detail{
		font-size: 1em;
    margin: 20px 30px 0;
    padding: 0;
		background: transparent;
	}
	.midtitle{
		margin: 0;
	}
	.inflex{
		flex-direction: column;
		align-items: flex-start;
		gap: 0px;
	}
	.inflex.rever .thumb{
		order: -1;
	}
	.inflex > div{
		padding: 20px 10px;
	}
	.texflex{
		flex-direction: column;
		margin: 0 0 20px;
	}
	.texflex .title{
		flex: 0 0 auto;
	}
	.texflex .thumb{
		flex: 0 0 auto;
		padding: 0;
	}
	.ziglist.outline{
		outline: none;
		background: transparent;
		gap: 50px;
	}
	.ziglist.vtc .part{
		padding: 0;
	}
	.ziglist .part{
		padding: 0;
		background: transparent;
		outline: none;
	}
	.ziglist .part .inflex .thumb .counts{
		grid-template-columns: repeat(2, 1fr);
	}
	.ziglist .part .inflex .thumb .counts .pub{
		grid-column: span 2;		
	}
	.ziglist{
		font-size: 14px;
		gap: 50px;
	}
	.ziglist.vtc .part .tex{
		padding: 0;
	}
	.ziglist.vtc .inflex .pd{
		padding: 0 30px 30px 30px;
	}
	.ziglist .part .tex{
		max-width: 100%;
		padding: 0 30px;
	}
	.ziglist .part .tex.ilist .item{
		padding: 30px 0;
	}	

	.sidewrp, .sidewrp.hf{
		grid-template-columns: 1fr;
		gap: 10px;
	}
	.sidebar ul{
		font-size: 13px;
		padding: 0 10px;
	}
	.listtools{
		flex-direction: column;
	}
	.list .hentry .meta{
		max-width: 100%;
	}	
	.list .hentry .meta .bt{
		position: static;
		margin: 15px 0 0;
		max-width: 100%;
	}
	.list.team .hentry{
		gap: 15px;
		grid-template-columns: 64px 1fr;
	}
	.list .hentry .meta .cats::after{
		display: none;
	}
	.list .hentry .meta .yearwrp .date{
		margin: 5px 0 0;
		font-size: 1em;
	}
	#pagination {
		flex-direction: column;
	}
	.parts{
		grid-template-columns: repeat(1, 1fr);
		font-size: 13px;
	}
	.parts .part{
		padding: 0;
	}
	footer{
		padding: 20px 10px;
	}
	.list.team .hentry .meta .yearwrp .dv{
		display: none;
	}
	.list.team .hentry .meta .yearwrp{
		flex-direction: column;
		align-items: flex-start;
	}
	.tabwrp.vtc section{
		padding: 0;
	}
	.tablink.mlt{
		display: grid;
    grid-template-columns: repeat(1, 1fr);
	}
	.tablink.mlt a{
		border-bottom: 1px solid var(--linelight);
	}	
	.tablink.mlt a:nth-last-child(-n+1) {
		border-bottom: 0;
	}
	.tablink.mlt a{
		border-right: 0;
	}
	/* .tablink.mlt a:nth-child(odd){
		border-right: 1px solid var(--line);
	} */
	.ziglist .part ul.companyspec li{
    flex-direction: column;
    align-items: flex-start;
    gap: 4px;
    padding: 10px 0;
	}
	.ziglist .part ul.companyspec li span.val{
		padding-left: 15px;
	}

	.maps iframe{
		height: 250px;
	}

	.listcats{
		grid-template-columns: repeat(2, 1fr);
	}

	.bread_cats{
		padding: 0 0px 20px;
		margin-top: 0;
	}
	.single_title{
		padding: 20px 0;
	}
	.single_content .item{
		padding: 30px 0;
	}
	body.single-dnl .single_content .item{
		padding: 10px 0;
	}
	body.single-dnl .single_title{
		padding: 10px 0;
	}
	.searchbig{
		margin-top: -64px;
	}
	.searchbig form input{
		height: 50px;
	}
	.fome_contact .submit{
		max-width: 100%;
	}

	.single_content .item ul.spec strong{
		width: 100px;
	}
	.otherpost a{
		padding: 16px 6px;
	}
	.list.dnl.front{
		margin: 0;
	}
	.list.dnl.front .hentry .meta{
		flex-direction: row;
	}
	.list.dnl.front .hentry .meta > div{
    border-right: 1px solid var(--line);
    padding-right: 7px;
    margin-right: 7px;
	}
	.list.dnl{
		margin: 0 -20px;
	}
	.list.dnl .hentry{
		padding: 24px 20px;
	}
	.list.dnl .hentry .meta{
		flex-direction: column;
		align-items: flex-start;
	}
	.list.dnl .hentry .meta > div, .list.dnl.front .hentry .meta > div:last-child{
		border-right: 0;
		padding-right: 0;
		margin-right: 0;
	}

}