/*!
Theme Name: lawofficebs
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: wpx
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.

wpx 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://fonts.googleapis.com/css2?family=Google+Sans:ital,opsz,wght@0,17..18,400..700;1,17..18,400..700&family=Noto+Sans+KR:wght@100..900&display=swap'); */
:root {	
	--blacktr: rgb(0 0 0 / 40%);
	--white: #fff;

	--text: #474644;
	--textgrey: #808f99;
	--textgreylt: #bdbbb8;
	--textplace: #dee2e6;
	--textblue: #15152d;

	--line: #ebe9e7;

	--main: #353566;
	--sub: #272653;
	--darkfocus: radial-gradient(circle, rgb(76 76 135) 0%, rgb(2 2 11) 100%);

	--bg: #ffffff;
	--grey: #f6f6f5;
	--greyblue: #dfeeff;	
	--light: #f8fafd;
	--input: #ffffff;

	--gold: #d5b87f;
	--goldlt: #ece6dc;
	--kakao: #fae100;
	--red: #d95735;

	--shadow: 0 0 3px 0 rgb(0 0 0 / 15%);
	--shadowline: 0 0 0px 1px var(--line);
	--font: "Pretendard Variable", -apple-system, system-ui, "Helvetica Neue", "Segoe UI", sans-serif;	
}
* {
	box-sizing: border-box;
	outline: none;
	direction: ltr;
	-webkit-font-smoothing: antialiased;
	-webkit-tap-highlight-color: transparent;
}
body {
	width: 100%;
	background: var(--bg);
	color: var(--text);
	font-size: 17px;
	font-weight: 400;
	line-height: normal;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
}
img{
	pointer-events: none;
	max-width: 100%;
	height: auto;
}
dl, dt, dd{
	margin: 0;
	padding: 0;
}
dl dt{
	font-weight: 700;
}

body,
input,
textarea,
button,
select,
option {
	font-family: var(--font);
}
input::placeholder,
textarea::placeholder {
	color: var(--textplace);
}
input:read-only,
textarea:read-only,
select:read-only {
	background: var(--light);
	color: var(--textgrey);
}
input:read-only:focus {
	border-color: var(--line);
}

input:focus,
textarea:focus,
select:focus {
	border-color: var(--main);
}
/* Chrome, Safari, Edge, Opera */
input[type=number]::-webkit-outer-spin-button,
input[type=number]::-webkit-inner-spin-button {
	-webkit-appearance: none;
	margin: 0;
}
/* Firefox */
input[type=number] {
	-moz-appearance: textfield;
}
input {
	width: 100%;
	color: var(--text);
	background: var(--input);
	border: 0;
	border: 1px solid var(--line);
	border-radius: 12px;
	padding: 12px;
	height: 55px;
	font-size: 1.1em;
}
textarea {
	resize: vertical;
	width: 100%;
	color: var(--text);
	background: var(--input);
	border: 1px solid var(--line);
	border-radius: 12px;
	padding: 12px;
	max-height: 300px;
	font-size: 1.1em;
}
ul, ol {
	padding: 0;
	margin: 0;
	list-style: none;
}
ul li{
	margin: 10px 0;
}
a {
	cursor: pointer;
	text-decoration: none;
	color: var(--text);
}
small{
	font-weight: 400;
}
h1 {	
	font-size: 3.6em;
	font-weight: 800;
	line-height: 1.25;
}
.sincon h1{
	font-size: 2.8em;
	margin-top: 20px;
}
h2{
	font-size: 2.1em;
	font-weight: 800;
	line-height: 1.3;
}
h3, .colsbox .item .num, .carousel .item .num{
	font-size: 1.5em;
	font-weight: 700;
	line-height: 1.3;
}
h4{
	font-weight: 600;
}
h1,h2,h3,h4,p{
	word-break: keep-all;
}
p{
	font-weight: 300;
	line-height: 1.35;
}
p:last-child{
	margin-bottom: 0;
}
header {
	z-index: 9999;
	position: sticky;
	top: 0;
	display: flex;
	justify-content: space-between;
	width: 100%;
	height: 90px;
	color: var(--text);
	background: transparent;
}
body.home header{
	color: var(--white);
}
header.sty{
	background: var(--white);
	color: var(--text);
	box-shadow: var(--shadowline);
}
body.home header.sty, body.home header.sty nav a{
	color: var(--text);
}
body.home header.sty .site-branding svg #logotype{
	fill: var(--text);
}
header section {
	display: flex;
	gap: 40px;
	justify-content: space-between;
	align-items: center;
	padding: 0 30px;
}
.site-branding {
	display: flex;
	align-items: center;
	font-size: 1.7em;
	font-weight: bold;
	color: var(--white);
}
.site-branding svg {
	height: 44px;
	width: auto;
	fill: var(--gold);
}
.site-branding svg #logotype{
	fill: var(--text);
}
body.home .site-branding svg #logotype{
	fill: var(--white);
}
.site-branding #symbol{
	display: none;
}
header .fr {
	display: flex;
	gap: 16px;
}
header .bn {
	display: flex;
}
header .right{
	display: flex;
	align-items: center;
	gap: 20px;
}
header .right .golden{
	display: flex;
	align-items: center;
	gap: 10px;
}
header .bt{
	padding: 0 30px;
	font-size: 1.1em;
}
header .bt.ai{
	background: linear-gradient(330deg, #0c0c2d 0%, #3b3c70 100%);
}
header .bnbt{
	display: flex;
	align-items: center;	
	color: var(--white);
	background: linear-gradient(330deg, rgba(141, 112, 55, 1) 0%, rgb(212 184 127) 100%);
}
header #hbg {
	display: none;
	align-items: center;
}
#movetopwrp.active {
	transform: translateY(0);
}
#movetopwrp {
	position: fixed;
	right: 30px;
	bottom: 30px;
	transition: all 0.2s linear 0s;
	transform: translateY(0px);
	z-index: 998;
	display: flex;
	flex-direction: column;
	gap: 10px;
}
#movetopwrp .item#movetop{
	display: none;
}
#movetopwrp.active .item#movetop{
	display: flex;
}
#movetopwrp .item {
	width: 60px;
	height: 60px;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	background-color: var(--white);
	box-shadow: 0 3px 13px 0px rgb(0 0 0 / 10%);
	color: var(--textblue);
	border-radius: 50%;
	transition: all 0.2s linear 0s;	
}
#movetopwrp .item.kakao{
	background: var(--kakao);
	/* box-shadow: 0 0 0px 1px var(--kakao); */
}
#movetopwrp .item.kakao svg{
	width: 24px;
	height: 24px;
}
#movetopwrp .item.ai svg{
	width: auto;
	height: 24px;
}
#movetopwrp .item.top:hover {
	background: var(--main);
	color: var(--bg);
}

.mnb {
	z-index: 999;
	position: fixed;
	left: 0;
	bottom: 0;
	width: 100%;
	display: none;
	align-items: center;
	background: var(--bg);
	padding: 0 10px;
}
.mnb .item {
	height: 50px;
	width: 100%;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 2px;
	line-height: normal;
}
#mgnbwrp {
	position: fixed;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	z-index: 99999;
	display: flex;
	background: var(--blacktr);
	transition: opacity 0.2s ease, visibility 0.2s ease;
	opacity: 0;
	visibility: hidden;
	padding: 10px;
}
#mgnbwrp.active {
	opacity: 1;
	visibility: visible;
}
#mgnbwrp.active .mgnb{
	transform: translateX(0);
} 
#mgnbwrp .mgnb {
	position: relative;
	padding: 30px;
	background: var(--bg);
	width: 90vh;
	display: flex;
	flex-direction: column;
	justify-content: center;
	overflow-y: auto;
	transform: translateX(100%);
	transition: transform 0.4s ease;
	border-radius: 13px;
}

#mgnbwrp .mgnb ul li{
	margin: 0;
}
#mgnbwrp .exitmgn {
	width: 100%;
	display: flex;
	justify-content: flex-end;
	cursor: pointer;
}
#mgnbwrp .mgnb .contact {
	border-radius: 30px;
	font-weight: 700;
	margin-top: auto;
}
#mgnbwrp .mgnb .searchwrp {
	margin: 0 -10px 30px;
}
#mgnbwrp .mgnb nav ul li a{
	font-size: 1.4em;
	color: var(--text);
}
#page {
	position: relative;
	width: 100%;
}
header nav {
	position: absolute;
	scrollbar-width: auto;
	left: 50%;
	transform: translateX(-50%);
}
nav {
	display: flex;
	align-items: center;
}
nav .menu-gnb-container{
	width: 100%;
}
nav ul {
	width: 100%;
	display: flex;
	gap: 50px;
}
nav ul.sub-menu li::before{
	content: '';
	position: absolute;
	left: 0;
	top: 0;
	width: 15px;
	height: 16px;
	background: transparent;
	border-bottom: 1px solid var(--line);
	border-left: 1px solid var(--line);
	border-radius: 0 0 0 12px;
}
nav ul.sub-menu>li{
	position: relative;
	padding: 0 13px;
	border-radius: 0;
}
nav ul.sub-menu>li:hover{
	background: transparent;
}
nav ul.sub-menu>li a:hover{
	background: var(--grey);
	border-radius: 9px;
}
nav ul>li.menu-item-has-children {
	position: relative;
}
nav ul>li.menu-item-has-children::after {
	content: "";
	position: absolute;
	right: 20px;
	top: 18px;
	width: 16px;
	height: 16px;
	background-size: contain;
	background-repeat: no-repeat;
	background-image: url('data:image/svg+xml;utf8, <svg width="100%" height="100%" viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg"><path d="M6 9L12 15L18 9" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"/></svg>');
}
nav ul>li.menu-item-has-children.active::after{
	transform: rotate(180deg);
}
nav ul li a {
	z-index: 1;
	position: relative;
	font-weight: 800;
	font-size: 1.2em;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	color: var(--text);
	height: 40px;
	display: flex;
	align-items: center;
}
body.home nav ul li a{
	color: var(--white);
}
nav ul li:hover a{
	box-shadow: inset 0px -2px 0px var(--text);
}
body.home nav ul li:hover a{
	box-shadow: inset 0px -2px 0px var(--white);
}
body.home header.sty nav ul li:hover a{
	box-shadow: inset 0px -2px 0px var(--text);
}
nav ul li.current-menu-item a,
nav ul li.current-menu-ancestor a,
nav ul li.current_page_item a,
nav ul li.current_page_ancestor a,
nav ul li.current-menu-parent a,
nav ul li.current_page_parent a,
nav ul li.active a{
	color: var(--gold)!important;
	box-shadow: inset 0px -2px 0px var(--gold)!important;
}
nav ul li.active ul.sub-menu {
	display: block;
}
nav ul li ul.sub-menu::before{
	content: '';
	position: absolute;
	top: 0;
	width: 1px;
	height: calc(100% - 30px);
	background: var(--line);
}
nav ul li ul.sub-menu {
	overflow: hidden;
	position: relative;
	display: none;
	margin-top: -3px;
	padding-left: 3px;
}
nav ul li ul.sub-menu li a {
	font-weight: 400;
	font-size: .9em;
	padding: 8px 9px;
	width: 100%;
}
nav ul li ul.sub-menu li:last-child{
	border-bottom: 0;
}
#hisback {
	cursor: pointer;
	display: none;
	background: transparent;
	border: 0;
	height: 40px;
	align-items: center;
	justify-content: center;
	margin-left: -20px;
	padding: 0 10px;
	z-index: 1;
	color: var(--textblue);
}
.searchwrp input {
	width: 100%;
	padding: 0 12px 0 42px;
	font-size: 1.1em;
}
.searchwrp .searchbt {
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	position: absolute;
	left: 0;
	top: 0;
	width: 42px;
	height: 100%;
	color: var(--textgrey);
	background: transparent;
	border: 0;
}
main {
	position: relative;
	width: 100%;
	min-height: calc(100vh - 90px);
}
section {
	position: relative;
	padding: 0 30px;
	width: 100%;
	max-width: 1310px;
	margin: 0 auto;
}
section.sincon{
	max-width: 700px;
	padding-top: 100px;
	padding-bottom: 150px;	
}
section.sincon p{
	line-height: 1.4em;
	font-size: 1.1em;	
}
section.sincon iframe{
	width: 100%;
  aspect-ratio: 16 / 9;
  height: auto;
}
.otherposts{		
	background: var(--grey);
}
.otherposts section{
	position: relative;
	display: flex;
	justify-content: center;
	width: 100%;
	padding: 0;
	background: var(--grey);
}
.otherposts .line{
	display: flex;
	flex: 0 0 auto;
	width: 1px;
	background: var(--line);
}
.otherposts .item{
	z-index: 1;
	position: relative;
	display: flex;
	justify-content: center;
	align-items: center;
	height: 150px;
	padding: 0 60px;
	font-weight: 700;
	font-size: 1.2em;	
	color: #98948e;
	width: 100%;
}
.otherposts .item:hover{
	color: var(--text);
}
.otherposts .item .material-symbols-outlined{
	font-size: 30px;
}
.otherposts .item .otherpost_title{
	text-overflow: ellipsis;
	display: -webkit-box;
	-webkit-line-clamp: 1;
	-webkit-box-orient: vertical;
  overflow: hidden;
}
.profile_card{
	margin: 60px 0 0;
	padding: 40px 0 0;
	border-top: 1px solid var(--line);
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: space-between;
}
.profile_card .bt{
	max-width: none;
	width: auto;	
}
.profile_meta .avatar{
	border-radius: 50%;
	width: 46px;
	height: 46px;
	object-fit: cover;
}
.profile_meta{
	display: flex;
	align-items: center;
	gap: 10px;
}
.profile_meta .name_meta{
	display: flex;
	flex-direction: column;
	gap: 2px;
}
.profile_meta .name_meta .name{
	font-weight: 700;
}
.profile_meta .name_meta .com{
	font-size: .8em;
	font-weight: 300;
	color: var(--textgrey);
}
.part{
	display: flex;
	align-items: center;
	padding: 100px 0;
	overflow: hidden;
	border-bottom: 1px solid var(--line);
}
#contact.part{
	padding: 40px 0;
	background: var(--grey);
}
.part.nop{
	padding: 0;
	align-items: flex-end;
}
.part.grey{
	background: var(--grey);	
}
.part.dark{
	background: var(--darkfocus);
	color: var(--white);
}
.part_title h2{
	margin: 0;
}
.part_title p{
	font-size: 1.1em;
}
.part_focus{
	position: relative;
	padding: 90px 300px 90px 90px;		
	margin: 0 0 60px;
	border-radius: 16px;
	color: var(--white);
	background: var(--sub);
	background: radial-gradient(circle, rgb(59 60 112) 0%, rgb(12 12 45) 90%);
}
.part_focus .art{
	position: absolute;
	top: 0;
	left: 50%;
	transform: translateX(-50%);
	width: 76%;
	height: 100%;
	object-fit: cover;
	opacity: .2;
	border-radius: 16px;
}
.part_focus .peo{
	position: absolute;
	right: 20px;
	bottom: -20px;
	width: 286px;
	height: auto;
}
.part_focus p{
	position: relative;
	margin: 0;
	font-size: 1.4em;
	font-weight: 400;
	letter-spacing: -.4px;
}
.part_focus p gold{
	color: var(--gold);
	font-weight: 700;
	font-size: 1.15em;
}
.part_name{
	font-size: 1.8em;
	font-weight: 300;
}
.part_name span{
	font-weight: 800;
	letter-spacing: 5px;
}
.part_slogan{
	font-size: 3.8em;
	font-weight: 800;
	margin: 0 0 50px 0;
	line-height: 1;
	opacity: .15;
}
.part_slogan *:first-child{
	opacity: .5;
}
.part_title{
	position: relative;	
	padding: 0 0 30px;
	margin: 0 0 60px;
}
.part_title::after{
	content: '';
	position: absolute;
	transform: translateX(-50%);
	left: 50%;
	bottom: 0;
	width: 80px;
	height: 3px;
	background: var(--gold);
}

.cols{
	display: grid;
	grid-template-columns: repeat(2, 1fr);
}
.cols.flex{
	display: flex;
	align-items: center;
	gap: 60px;
}
.cols.flex .col:last-child{
	width: 100%;
}
.imgwrp {
	position: relative;
	display: flex;
}
.imgwrp::after{
	content: '';
	position: absolute;
	right: 0;
	top: 0;
	height: 100%;
	width: 100vw;
	background: #bbbaba;
	background: linear-gradient(58deg, rgba(187, 186, 186, 1) 43%, rgba(247, 247, 247, 1) 100%);
}
.imgwrp::before{
	display: none;
	content: '';
	position: absolute;
	left: 0;
	bottom: -1px;
	width: 100%;
	height: 50%;
	z-index: 2;
	background: #ffffff;
	background: linear-gradient(0deg, rgba(255, 255, 255, 1) 0%, rgba(255, 255, 255, 0.9) 20%, rgba(255, 255, 255, 0) 100%);
}
.imgwrp img{
	z-index: 1;
	max-width: 100%;
	height: auto;
	max-width: 350px;
	margin-right: -30px;
}

.slider_nav{
	position: absolute;
	transform: translate(-50%);
	left: 50%;
	bottom: 40px;	
	display: flex;
	gap: 10px;
}
.slider_nav .dot{
	width: 12px;
	height: 12px;
	border-radius: 32px;
	background: var(--white);
	cursor: pointer;
	overflow: hidden;
	opacity: 0.3;
}
.slider_nav .dot.active{
	opacity: 1;
}
.tags{
	margin: 30px 0 60px;
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}
.sincon .tags{
	margin: 40px 0 0;
}
.tags .tag{
	font-size: .9em;
	font-weight: 500;
	display: flex;
	align-items: center;
	padding: 0 14px;
	height: 37px;
	background: linear-gradient(330deg, #0c0c2d 0%, #3b3c70 100%);
	color: var(--white);
	border-radius: 8px;
}
.hat .tags .tag, .sincon .tags .tag{
	color: var(--text);
	background: var(--grey);			
	border: 1px solid var(--grey);
}
.list .hat:hover .tags .tag{
	border-color: #d7d5d3;
}
.hat .tags .tag::before, .sincon .tags .tag::before{
	content: '#';
}
.hat .tags {
	position: relative;
	margin: 30px 0 0;
	justify-content: flex-start;
}
.his dl{	
	display: flex;	
	margin-bottom: 10px;
	padding-left: 10px;
	padding-right: 10px;
	line-height: 1.7;
}
.his dl:last-child{
	padding: 0 10px;
	margin: 0;
}
.his dl dt{
	margin-right: 18px;
	width: 90px;
}
.his dl.bb{
	margin-bottom: 16px;
	padding-bottom: 16px;
	border-bottom: 1px dotted var(--line);
}
.his dl dd{
	font-weight: 400;
}
.colsbox.cols3{
	grid-template-columns: repeat(3, 1fr);
	gap: 1px;
	background: var(--line);
}
.colsbox.cols2{
	grid-template-columns: repeat(2, 1fr);
	gap: 1px;
	background: var(--line);
}
.colsbox.cols2 .item, .colsbox.cols3 .item{
	background: var(--white);
	border-radius: 0;
	box-shadow: none;
}
.colsbox.cols2 .item{
	display: flex;
	align-items: flex-start;
	gap: 10px;
}
.colsbox.colsbox_contact{
	gap: 1px;
	background: #4d4c73;
	border: 1px solid #4d4c73;
	border-radius: 16px;
	overflow: hidden;
	grid-template-columns: repeat(1, 1fr);
}
.colsbox.colsbox_contact .item{
	display: flex;
	gap: 10px;
	background: var(--sub);
	color: var(--white);
	padding: 26px 30px;
}
.colsbox.colsbox_contact .item:hover{
	background: #201f44;
}
.colsbox.colsbox_contact .item h3{
	margin: 0 0 10px;
} 
.colsbox.colsbox_contact .item p{
	margin: 0;
	opacity: .8;
}
.colsbox.colsbox_contact .item .material-symbols-rounded{
	font-size: 28px;	
}
.colsbox.colsbox_contact .item svg{
	width: 24px;
	height: 24px;
	fill: var(--white);
}
.colsbox{
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 20px;
}
.colsbox .item{
	color: var(--text);
	background: var(--white);
	padding: 42px;	
	border-radius: 10px;	
}
.colsbox .item .check{
	flex: 0 0 auto;
	width: 30px;
	height: auto;
	fill: var(--goldlt);
}
.colsbox .item .check .sym{
	fill: url(#checkGrad);
}
.colsbox .item h3{
	margin-top: 0;
}
.colsbox.nums .item h3, .carousel .item h3{
	margin: 0;
}
.colsbox.nums .item p, .carousel .item p{
	margin: 10px 0 0;
}
.colsbox .item .num, .carousel .item .num{
	font-style: italic;
	font-size: 2em;
	margin: 0 0 6px;
	background: linear-gradient(330deg, var(--gold) 0%, var(--grey) 100%);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
}
.contact_grid{
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 40px;
	margin: 0 0 50px;
}
.contact_form{
	display: flex;
	flex-direction: column;
	gap: 10px;
}
.contact_form .contact_form_title{
	display: flex;	
	align-items: center;
	gap: 10px;
	margin-bottom: 10px;
	color: var(--white);
}
.contact_form .contact_form_title h3{
	margin: 0;
}
.contact_form .item{
	overflow: hidden;
	position: relative;
	background: rgb(0 0 0 / 20%);
	border-radius: 12px;
	display: flex;
	align-items: center;
}
.contact_form .item.foc{
	outline: 2px solid var(--gold);
}
.contact_form .item .lb{
	flex: 0 0 auto;
	width: 70px;
	padding: 0 12px;
	display: flex;
	align-items: center;
	border-right: 1px solid #4d4c73;
	font-weight: 700;
}
.contact_form .gid{
	opacity: .6;
	word-break: keep-all;
	padding: 10px;
}
.contact_form .submitwrp{
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding-top: 6px;
}
.contact_form .submitwrp .bt{
	background: var(--white);
	color: var(--textblue);
}
.contact_form input, .contact_form textarea{
	border: 0;
	background: transparent;
	color: var(--white);
}
.contact_form input::placeholder, .contact_form textarea::placeholder{
	opacity: .6;
}
.contact_form textarea{
	resize: none;
}
.carouselwrp{
	position: relative;
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 3px;
}
.carousel{
	display: flex;
	gap: 20px;
	will-change: transform;
	cursor: grab;
}
.carousel:active{
	cursor: grabbing;
}
.carousel .item{
	white-space: normal;
	flex-shrink: 0;
	padding: 42px;	
	border-radius: 10px;
	background: var(--white);
	color: var(--text);
}
.carousel .item img{
	margin: 0 0 20px;
}
.carouselnav{
	display: flex;
	justify-content: center;
	gap: 16px;
	margin: 30px 0 0;	
}
.carouselnav .arw_prev span, .carouselnav .arw_next span{
	color: var(--white);
	font-size: 34px;
	font-variation-settings: 'wght' 500 !important;
}
.carouselnav .arw_prev, .carouselnav .arw_next{
	flex-shrink: 0;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 60px;
	height: 60px;	
	border-radius: 50%;
	background: rgb(0 0 0 / 30%);
	z-index: 1;
	transition: background 0.2s;    
}
.carouselnav .arw_prev_wrp, .carouselnav .arw_next_wrp{
	display: flex;
	align-items: center;
	justify-content: center;
	height: 100%;
	transition: opacity 0.2s;
}
.carouselnav .arw_prev_wrp.hidden, .carouselnav .arw_next_wrp.hidden{
	opacity: 0.3;
	pointer-events: none;
}
.scroll_down{
	color: var(--white);
	cursor: pointer;
	background: rgb(0 0 0 / 30%);
	border-radius: 50%;
	width: 60px;
	height: 60px;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 40px auto 0;
}
@keyframes bounce_down {
	0%, 100% { transform: translateY(-4px); }
	50%       { transform: translateY(4px); }
}
.scroll_down > * {
	animation: bounce_down 1.2s ease-in-out infinite;
	font-size: 34px;
	font-variation-settings: 'wght' 500 !important;
}
#home{
	position: relative;
	overflow: hidden;
	background: var(--darkfocus);
	color: var(--white);
	margin-top: -90px;
	height: 100vh;
	border-color: var(--sub);
}
#home .bt.ai{
	height: 65px;
	padding: 0 30px;
	background: transparent;
	max-width: 195px;
	position: relative;
	overflow: hidden;
	isolation: isolate;
	font-size: 1.15em;
}
#home .bt.ai::before{
	content: '';
	position: absolute;
	inset: -60%;
	background: conic-gradient(from 0deg, transparent, transparent 60%, rgba(244,230,207,0.85) 75%, transparent 90%);
	animation: ai_border_spin 3s linear infinite;
	z-index: -2;
}
#home .bt.ai::after{
	content: '';
	position: absolute;
	inset: 2px;
	background: linear-gradient(330deg, #0c0c2d 0%, #3b3c70 100%);
	border-radius: 30px;
	z-index: -1;
}
@keyframes ai_border_spin{
	to{ transform: rotate(360deg); }
}
#home h1 .gold{
	color: var(--gold);
}
#home h3{
	font-weight: 400;
}
#home img{
	pointer-events: none;
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	opacity: 0.2;
}
.faqs {
	display: grid;
	grid-gap: 14px;
	grid-template-columns: repeat(1, 1fr);
	font-size: 14px;
}
.faqs .item {
	background: var(--bg);
	outline: 1px solid var(--line);
	border-radius: 12px;
	overflow: hidden;
	word-break: keep-all;
}
.faqs .item .qustion {
	cursor: pointer;
	display: flex;
	justify-content: space-between;
	gap: 7px;
	font-weight: 600;
	font-size: 1.05em;
	padding: 20px;
}

.faqs .item .qustion svg {
	width: 20px;
	height: 20px;
}

.faqs .item .qustion svg.open,
.faqs .item.active .qustion svg.close {
	display: block;
}

.faqs .item .qustion svg.close,
.faqs .item.active .qustion svg.open {
	display: none;
}

.faqs .item .answer {
	padding: 20px;
	border-top: 1px solid var(--line);
	display: none;
	word-break: keep-all;
	color: var(--textgrey);
}

.faqs .item.active .answer {
	font-size: 1em;
	display: block;
}

.faqs .item.active .answer a {
	color: var(--color_gold);
	text-decoration: underline;
}

.bred {
	display: flex;
	align-items: center;
	gap: 1px;
	opacity: .5;
}
.bred .item{
	display: flex;
	font-weight: 500;
}
.bred .item:first-child > span{
	font-size: 22px;
}
.bred .material-symbols-outlined{
  font-variation-settings: 'wght' 200!important;
}
.symbol{
  margin: 0 0 20px;
}
.symbol svg{
	width: 56px;
	height: auto;
	fill: var(--goldlt);
}
.list {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 24px;
}
.list .hat{
	overflow: hidden;
	position: relative;
	padding: 40px;
	border: 1px solid var(--line);
	border-radius: 16px;
}
.list .hat:hover{
	background: var(--grey);
}
.list .hat h3{
	font-size: 1.3em;
	margin: 0 0 15px;
}
.list .excerpt {	
	word-wrap: break-word; /**긴 영문 url 대응 줄바꿈 **/
	word-break: keep-all;	
	overflow: hidden;
	text-overflow: ellipsis;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	line-height: 1.4;
}
.list .excerpt p{
	margin: 0;
}
.bt.lg {
	max-width: 230px;
	height: 60px;
	font-size: 1.15em;
	border-radius: 32px;
}
.bt.sml {
	height: 40px;
	max-width: 120px;
	border-radius: 32px;
	padding: 0 20px;
	font-size: .95em;
}
.bt {
	white-space: nowrap;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
	max-width: 150px;
	width: 100%;
	height: 50px;
	background: var(--sub);
	color: var(--white);
	font-size: 1.1em;
	font-weight: 700;
	border: 0;
	border-radius: 32px;
	padding: 0 30px;
}
.bt.more{
	width: auto;
	max-width: none;
	padding: 0 24px;
	height: 55px;
}
.morewrp{
	margin: 50px 0 0;
	display: flex;
	justify-content: center;
}
label {
	font-weight: 700;
}
.dropdown {
	cursor: pointer;
	position: relative;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 15px;
	background: var(--input);
	border: 1px solid var(--line);
	border-radius: 12px;
	height: 42px;
	padding: 0 12px;
	font-size: 14px;
}
.dropdown.active .dropitems {
	display: block;
}
.dropdown .dropitems.orileft {
	right: auto;
	left: 0;
}
.dropdown .dropitems.oribottom {
	top: auto;
	bottom: calc(100% + 10px);
	left: 0;
	right: auto;
}
.dropdown .dropitems {
	display: none;
	position: absolute;
	top: calc(100% + 8px);
	right: 0;
	min-width: 130px;
	background: var(--bg);
	box-shadow: rgba(0, 0, 0, 0.08) 0px 0px 1px 0px, rgba(0, 0, 0, 0.1) 0px 16px 30px 4px;
	border-radius: 12px;
	padding: 12px 0;
	z-index: 1;
	max-height: 300px;
	overflow-y: scroll;
	overflow: auto;
	scrollbar-width: thin;
	z-index: 100;
}
.dropdown .dropitems .item {
	display: flex;
	flex-direction: column;
	padding: 10px 20px;
	color: var(--text);
}
.dropdown .dropitems .item:hover {
	background: var(--light);
}
.empty {
	color: var(--textgrey);
	text-align: center;
	margin: 10px 0;
	opacity: .5;
}
.inputwrp .exmark{
	width: 16px;
	height: 16px;
}
.breadwrp {
	display: flex;
	align-items: center;
	gap: 8px;
	font-weight: 500;
	font-size: .7em;
	margin: 10px 0;
	color: var(--textgrey);
}
.modal {
	position: fixed;
	display: none;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	align-items: center;
	justify-content: center;
	background: var(--blacktr);
	z-index: 10000;
	padding: 20px;
}
.modal .modalconwrp {
	position: relative;
	max-width: 100%;
	width: 100%;
}
.modal.active, .modal.active .modalconwrp {
	display: flex;
}
.modal .modalcon {
	background: var(--bg);
	border-radius: 16px;
	width: 100%;
}
.modal .modalconin {
	overflow: hidden;
	position: relative;
	margin: 0 auto;
	width: 100%;
	padding: 20px;
}
.modal .modalconwrp .exit {
	cursor: pointer;
	position: absolute;
	top: -35px;
	right: 10px;
	color: var(--bg);
	z-index: 9;
	display: flex;
}
.modal .bts {
	position: relative;
	display: flex;
	justify-content: center;
	gap: 8px;
	margin-top: 30px;
}


.pgnwrp {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 22px;
	margin: 50px 0 70px;
}
#pagination, .numbar {
	display: flex;
	align-items: center;
	justify-content: right;
	gap: 8px;
}
#pagination .page-numbers.current {
	outline: 1px solid var(--sub);
	color: var(--textblue);
	background: transparent;
}
#pagination a:hover{
	outline: 1px solid var(--line);
	background: transparent;
}
#pagination a, #pagination .page-numbers {
	font-weight: 700;
	display: flex;
	align-items: center;
	justify-content: center;
	height: 40px;
	min-width: 40px;
	background: var(--grey);
	border-radius: 8px;
	padding: 0 6px;
}
.pgnwrp .counts {
	display: none;
	align-items: center;
	justify-content: center;
	gap: 9px;
	white-space: nowrap;
	font-size: .9em;
	font-weight: 300;
}
.pgnwrp .counts #pagego {
	height: 30px;
	padding: 6px 10px;
	font-weight: 400;
	font-size: .9em;
	border-radius: 8px;
}
.pgnwrp .counts input {
	text-align: center;
	height: 30px;
	font-size: 1em;
	padding: 4px;
	min-width: 33px;
	border-radius: 8px;
}
footer {
	overflow: hidden;
	position: relative;		
	padding: 100px 0;
	font-size: .9em;
	color: var(--textplace);
	background: var(--sub);
}
footer .bga{
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	opacity: .1;
}
footer .inr{
	padding: 0 14px;
}
footer h2{
	color: var(--white);
	margin: 0 0 40px;
}
footer h2 span{
	color: var(--gold);
}
footer .info{
	display: flex;
	gap: 6px 20px;
	margin: 0 0 20px;
	max-width: 60%;
	flex-wrap: wrap;
}
footer .info dl{
	display: flex;
	gap: 4px;
}
footer .info dl dt.com{
	font-weight: 700;
	color: var(--gold);
}
footer .copyright{
	font-size: .9em;
}
.tabwrp {
	border-radius: 12px;
}
.tab_head {
	position: relative;
	display: flex;
	align-items: center;
	width: 100%;
	overflow: hidden;
	font-weight: 700;
	font-size: 1.1em;
	border-radius: 12px;
	padding: 0 10px;
}
.tab_head::after{
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 1px;
	background: var(--line);
}
.tab_head a {
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	padding: 10px;
	background: var(--grey);	
	border: 1px solid var(--line);
	height: 50px;
}
.tab_head a:first-child{
	border-right: 0;
	border-radius: 16px 0 0 0;
	box-shadow: inset -2px -2px 10px -5px rgb(0 0 0 / 10%);	
}
.tab_head a:last-child{
	border-left: 0;
	border-radius: 0 16px 0 0;
	box-shadow: inset 2px -2px 10px -5px rgb(0 0 0 / 10%);
}
.tab_head a.active {
	z-index: 2;
	background: var(--bg);
	box-shadow: none;
	border: 1px solid var(--line)!important;
	border-bottom-color: var(--bg)!important;	
}
.tab_body {
	padding: 30px;
	background: var(--bg);
	border-radius: 0 0 10px 10px;
}
/**슬라이더**/

.sliderwrp {
	position: relative;
	width: 100%;
	margin-bottom: 30px;
}

.swiper {
	position: relative;
	width: 100%;
	height: 100%;
	max-width: 100%;
	border-radius: 8px;
}
.swiper .swiper-wrapper .swiper-slide .item {
	display: block;
	position: relative;
	width: 100%;
	height: 0;
	padding-top: 56.25%;
	border-radius: 8px;
	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%, rgba(0, 0, 0, 0.3085609243697479) 76%, rgba(0, 0, 0, 0.5886729691876751) 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(--bg);
	padding: 20px;
	line-height: 1.3;
	font-size: 14px;
	word-break: keep-all;
}
.swiper .swiper-wrapper .swiper-slide .item .meta .title {
	font-size: 1.4em;
	font-weight: bold;
	max-width: 60%;
}
.swiper .swiper-wrapper .swiper-slide .item .meta .summary {
	margin-top: 10px;
	max-width: 80%;
}
.sliderbtprev, .sliderbtnext {
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	outline: 1px solid rgba(0, 0, 0, 0.05);
	background: var(--bg);
	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;
}
/**모바일**/
@media screen and (max-width: 768px) {

	body {
		font-size: 15px;
	}
	h1{
		font-size: 9vw;
	}
	.sincon h1{
		font-size: 8vw;
	}
	h2{
		font-size: 7vw;
	}
	h3, .colsbox .item .num, .list .hat h3{
		font-size: 5vw;
	}
	.colsbox .item .num, .carousel .item .num{
		font-size: 10vw;
	}
	.site-branding svg {
		height: 32px;
	}	
	/* .site-branding #logo{
		display: none;
	}
	.site-branding #symbol{
		display: flex;
	} */
	header {		
		height: 70px;
	}
	header section {
    gap: 10px;
    padding: 0 20px;
	}
	header #hbg {
		display: flex;
	}
	header #hbg .material-symbols-outlined{
		font-size: 26px;
	}
	header .bnbt, header .ai{
		max-width: 100px;
    height: 45px;
	}
	/* header .right .golden{
		gap: 7px;
		position: absolute;
		left: 50%;
		transform: translateX(-50%);
	} */
	#home{
		margin-top: -70px;
	}
	.part{
		padding: 60px 0;
	}	
	.part_focus{
    padding: 30px 40px 330px 40px;
    margin: 0 0 30px;
	}
	.part_focus p{
    font-size: 5vw;
    margin: 0 -10px;
    line-height: 1.5;
	}
	.part_focus .peo{
		right: auto;
    bottom: -20px;
    width: 270px;
    height: auto;
    left: 50%;
    transform: translateX(-50%);
		z-index: 1;
	}
	.part_focus .art{
		width: 100%;
	}
	nav ul{
		flex-direction: column;
		gap: 20px;
	}	
	.his{
		margin: 30px 0 50px;
	}
	.mnb {
		display: flex;
	}
	#hisback.active {
		display: flex;
	}
	nav#gnb {
		display: none;
	}
	#site-navigation {
		display: none;
	}
	#page {
		grid-template-columns: 1fr;
	}
	header .fr {
		flex-direction: row;
		gap: 0;
	}
	#movetopwrp {
		right: 15px;
		bottom: 15px;
	}
	#movetopwrp .item{
		width: 50px;
		height: 50px;
	}
	.scroll_down{
		width: 50px;
		height: 50px;
	}
	.carouselnav .arw_prev, .carouselnav .arw_next{
		width: 50px;
		height: 50px;
	}
	#home h1 br{
		display: none;
	}
	.imgwrp{
		margin: 0 -20px;
	}
	.imgwrp::before{
		display: flex;
	}
	.part_slogan{
		font-size: 12vw;
		margin: 0 9px 15px 0;
	}
	section.sincon{
		padding-top: 14px;
		padding-bottom: 70px;
	}
	.colsbox{		    
		grid-template-columns: repeat(1, 1fr);
	}
	.cols{
		grid-template-columns: repeat(1, 1fr);
	}
	.colsbox.cols2{
		grid-template-columns: repeat(1, 1fr);
	}
	.colsbox .item{
		padding: 30px;
	}
	.carousel .item{
		padding: 30px;
	}
	.cols.flex{
		flex-direction: column;
		gap: 0;
	}
	.colsbox.cols2 .item{
		padding: 30px 10px;
	}
	footer .colsbox.cols2 .item{
		padding: 24px;
	}	
	.part_name{
		font-size: 5.5vw;	
		margin-right: 9px;
	}
	.part_name span{
		letter-spacing: 1px;
	}
	.tags{
    margin-bottom: 0;
	}	
	.sincon .tags{
		margin: 30px 0 0;
	}
	.imgwrp img{
    max-width: 48%;
    margin-right: 0;
		margin-left: 5px;
    max-height: 300px;
    object-fit: cover;
    object-position: top;
	}
	.imgwrp::after{
    background: linear-gradient(180deg, var(--grey) 0%, var(--white) 100%);
	}
	section {
		padding: 0 20px;
	}
	.list{
		grid-template-columns: repeat(1, 1fr);
	}
	.list .hat{
		padding: 30px;
	}
	.list .hat .tags{
		margin: 22px 0 0;
	}
	.morewrp{
		margin: 40px 0 0;
	}
	.otherposts section{
		flex-direction: column;
	}
	.otherposts .item{
		height: auto;
		padding: 30px;
		font-size: 1.1em;
	}
	.otherposts .line{
		width: 100%;
		height: 1px;
	}
	.tab {
		font-size: 15px;
	}
	.nextpaywrp button {
		max-width: 100%;
	}
	.pagetitle {
		margin: 20px 0;
		flex-direction: column;
		align-items: flex-start;
	}
	.faqs {
		font-size: 13px;
		gap: 12px;
	}
	.pgnwrp{
		margin: 30px 0 70px;
	}
	.profile_meta_ld{
    position: absolute;
    top: 50px;
    right: 0;
    z-index: 9;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    padding: 0 20px;
	}
	.profile_meta_ld .tags{
    gap: 6px;    
		justify-content: flex-end;
	}
	.profile_card{
		margin: 40px 0 0;
		align-items: unset;
    flex-direction: column;
		gap: 24px;
	}
	.profile_card .bt{
		height: 58px;
	}
	.his dl dt{
    width: 32px;
	}
	.hat .tags .tag, .sincon .tags .tag{
		height: 34px;
		padding: 0 12px;
	}
	.contact_grid{
    grid-template-columns: repeat(1, 1fr);
    margin: 0 0 60px;
    gap: 50px;
	}
	.contact_form .submitwrp{
		flex-direction: column;
		gap: 12px;
	}
	.contact_form .submitwrp .bt{
		max-width: 100%;
	}
	footer{
		padding: 40px 0;
	}
	footer .info{
    max-width: 100%;
    flex-direction: column;
    gap: 16px;
    margin: 0 0 30px;
	}
	footer h2 br{
		display: none;
	}
	footer .info dl{
		width: 100%;
	}
	footer .info dl dt{
		width: 100px;
		flex: 0 0 auto;
	}
	footer .info dl dt.com{
		font-size: 1.3em;
		font-weight: 700;
    color: var(--gold);
    width: auto;    
		margin-bottom: 10px;
	}
	.list .before {
		display: flex;
		align-items: flex-start;
		flex-direction: column;
	}
	.list .row .icon {
		position: absolute;
		right: 8px;
		bottom: 21px;
	}

}

@media print {
	header {
		display: none !important;
	}
}