/*==============================================================
	RESET
==============================================================*/

html {
	scroll-behavior: smooth;
}



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

/*==============================================================
	Shortcut
==============================================================*/

.mb20{margin-bottom: 20px;}
.mb40{margin-bottom: 40px;}
.mb60{margin-bottom: 60px;}
.mb80{margin-bottom: 80px;}
.mb100{margin-bottom: 100px;}
@media screen and (max-width: 767px) {
	.mb20{margin-bottom: 4vw;}
	.mb40{margin-bottom: 8vw;}
	.mb60{margin-bottom: 12vw;}
	.mb80{margin-bottom: 16vw;}
	.mb100{margin-bottom: 20vw;}
}


span.span-bl{display: inline;}
@media screen and (max-width: 767px) {span.span-bl{display: block;}}
span.span-bl-no{display: block;}
@media screen and (max-width: 767px) {span.span-bl-no{display: inline;}}


@media screen and (min-width: 768px) {
	.sp_hide{display: block; }
	.sp_show{display: none; }
}
@media screen and (max-width: 767px) {
	.sp_hide{display: none;}
	.sp_show{display: block; }
}




.flx{
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	justify-content: space-between;
	/* align-items: center;   */
	align-items: start;
}

.nobold {
	font-weight: normal;
}
.circletxt{
	position: relative;
	display: inline-block;
	border-radius: 50%;
}

.circletxt span{
	box-sizing: border-box;
	position: absolute;
	display: inline-block;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
	text-align:center;
}

.brpc {display: inline; }
.brsp{display: none; }

@media screen and (max-width: 767px) {
	.brpc {display: none; }
	.brsp {display: inline; }
}
.txtimg {
	text-indent:100%;
	white-space:nowrap;
	overflow:hidden;
}


/*==============================================================
	ANIMATION
==============================================================*/
@keyframes fadeIn{
    0% {
      opacity: 0;
    }

    100% {
      opacity: 1;
    }
}
@keyframes fadeOut{
    0% {
      opacity: 1;
    }

    100% {
      opacity: 0;
    }
}
/*==============================================================
	SETTING
==============================================================*/
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, address, big, code, del, em, img, ins, kbd, q, samp, small, strong, sub, sup, var, b, u, i, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, figure, figcaption, footer, header, nav, output, ruby, section, summary, time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	font-size: 100%;
	vertical-align: baseline;
	font-style: normal;
}

a{
	text-decoration: none;
	color: #000000;
}
ol, ul {
	list-style: none
}
table {
	border-collapse: collapse;
	border-spacing: 0;
}

img{
	vertical-align: top;
}

/* TEXT */
body {
	font-family: 'Zen Kaku Gothic New', 'Yu Gothic', "游ゴシック", 'YuGothic', "游ゴシック体", Hiragino Kaku Gothic ProN, 'Meiryo', sans-serif;
	font-weight: 400;
	font-style: normal;
	/* regular400
		midiam500
		bold700
		'Zen Kaku Gothic New' */
	/* regular400
		semibold600
		bold700
		'Zen Old Mincho' */
	/* regular400
	'Questrial' */
}
.font-sansselif {
	font-family: 'Zen Kaku Gothic New', 'Yu Gothic', "游ゴシック", 'YuGothic', "游ゴシック体", Hiragino Kaku Gothic ProN, 'Meiryo', sans-serif;
}
.font-futura {
	font-family: 'Futura','Century Gothic','Zen Kaku Gothic New', 'Yu Gothic', "游ゴシック", 'YuGothic', "游ゴシック体", Hiragino Kaku Gothic ProN, 'Meiryo', sans-serif;
}
.font-selif {
	font-family: 'A-OTF A1明朝 Std','Zen Old Mincho','游明朝','Yu Mincho',YuMincho,'Hiragino Mincho Pro',serif;
}

.italic{
	font-weight: bold;
	/* display: inline-block; */
	font-style: italic;
}

body{
	font-size: 16px;
	letter-spacing: 1px;
	line-height: 1.5;
	color: #000;
	overflow: auto;
}

::-moz-selection {
	color: #fff;
	background-color: #4673ff;
}
::selection {
	color: #fff;
	background-color: #4673ff;
}

h1{
	font-size: 48px;
}

h2{
	font-size: 36px;
}
h3{
	font-size: 24px;
}
h4{
	font-size: 18px;
}
p{
	font-size: 16px;
	line-height: 1.5;
}
small{
	font-size: 10px;
}
em{font-weight: normal;}


.italic{
	font-weight: bold;
	font-style: italic;
}


.fs-18{
	font-size: 18px;
}
.fs-14{
	font-size: 14px;
}
.fs-12{
	font-size: 12px;
}

@media screen and (max-width: 767px) {
	body{
		font-size: 4vw;
		letter-spacing: 0.2vw;
	}
	
	h1{
		font-size: 12vw;
	}
	
	h2{
		font-size: 6.4vw;
	}
	h3{
		font-size: 5.4vw;
	}
	h4{
		font-size: 4.2vw;
	}
	p{
		font-size: 3.6vw;
	}
	small{
		font-size: 2.5vw;
	}
	.fs-18{
		font-size: 4.2vw;
	}
	.fs-14{
		font-size: 3.4vw;
	}
	.fs-12{
		font-size: 2.8vw;
	}

}



/* HOVER */
a{
	transition: opacity 0.2s linear;
}
a:hover{
	opacity: 0.9;
}


/*==============================================================
	LAYOUT
==============================================================*/

html {
	height: 100%;
	background-color: #fff;
	height: 100dvh;
}

body {
	height: 100%;
	margin: 0;
	padding: 0;
	position: relative;
	/* min-width: 1024px; */
	min-width: 1024px;
	height: 100dvh;
}



#content{
	width: 100%;
    height: auto;
	position: relative;
}


main {
	height: 100%;
	width: 100%;
    height: auto;
	position: relative;
	overflow: hidden;
}


section{
	width: 100%;
	box-sizing: border-box;
	padding: 0;
}
section div.sc_bg{
	width: 100%;
	box-sizing: border-box;
}

section div.sc_inner{
	position: relative;
	width: 100%;
	box-sizing: border-box;
	max-width: 1000px;
	margin: 0 auto;
}

section._anchorfix {
	padding-top: 175px;
	margin-top: -175px;
}

@media screen and (min-width: 768px) and (max-width: 1024px) {

}

@media screen and (max-width: 767px) {
	html {
	}
	body {
		min-width: unset;
	}

	#base{
		display: block;
	}
	
	main {
	}


	section{
		min-width: unset;
		padding: 0;
	}
	
	section div.sc_inner{
		max-width: unset;
	}
	
	section._anchorfix {
		padding-top: 22vw;
		margin-top: -22vw;
	}
}

/*==============================================================
	LOADING
==============================================================*/
#splash {
	position: fixed;
	z-index: 9999;
	width: 100%;
	height: 100%;
	background:#fff;
	text-align:center;
	display: flex;
	justify-content: center;
	align-items: center;
}

.loading {
	top: 50%;
	left: 50%;
	z-index: 999;
	/* width: 100%; */
	color: #000;
	transition: .33s linear;
	transition-property: opacity transform;
	opacity: 1;
	transform: scale(1);
}

.loading img{
	width: 100%;
	height: 100%;
}

#splash.loaded .loading{
	opacity: 0;
	transform: scale(0.95);
}
/* #splash.loaded {
	opacity: 0;
	visibility: hidden;
} */

/* #progress-box {
width: 100%;
height: 0;
position: relative;
z-index: 10000;
background: transparent;
}
#progress-bar {
	width: 0;
	height: 3px;
	background: #000000;
	position: fixed;
	left: 0;
	top: 0;
	z-index: 6;
	transition: .3s;
} */



/* ====================
	CSLIDER By Slick
==================== */


.cslider_body{
	width: 100%;
	box-sizing: border-box;
	overflow: hidden;
	text-align: left;
	max-height: 240px;
}


.cslider{
	/* min-height: 160px; */
	position: relative;
	margin-left: -60px;
	padding-left: 40px;
	padding-right: 40px;
}


.cslider .slick-slide{
	width: auto;
	/* height: 160px; */
	margin: 0 20px;
	position: relative; 
	overflow: hidden;
}
.cslider .slick-slide div{
	display: block;
}

.cslider .slick-slide a{
	display: block;
	/* height: 160px; */
	width: 100%;
	aspect-ratio: 1 / 0.56;
}


.cslider .slick-slide img{
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.cslider .slick-slide .img_over{
	position: absolute;
	display: block;
	width: 100%;
	height: 100%;
	background:linear-gradient(to top, rgba(0,0,0,0.5), rgba(0,0,0,0));
	mix-blend-mode: multiply;
	z-index: 2;
}

.cslider .slick-arrow {
	width: 60px;
	height: 102%;
	cursor: pointer;
	position: absolute;
	left: 0;
	z-index: 3;
	background: url(../img/common/cs_arrow.svg) no-repeat;
	background-size: 80%;
	background-position: center;
	background-color: #e7eae6;
}

.cslider .slick-arrow.slick-next{
	left: auto;
	right: 0;
}


.cslider .slick-slide .cap {
	position: absolute;
	left: 0;
	bottom: 0;
	z-index: 3;
	padding: 12px;
	color: #fff;
	box-sizing: border-box;
	width: 100%;
	overflow: hidden;
}
.cslider .slick-slide .cap span{
	display: block;
	font-size: 15px;
	font-style: italic;
	font-weight: bold;
}
.cslider .slick-slide .cap h4{
	font-size: 16px;
	font-weight: normal;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	box-sizing: border-box;
	width: 100%;
	overflow: hidden;
}

@media screen and (max-width: 767px) {
	.cslider_body{
		width: 100%;
		box-sizing: border-box;
		overflow: hidden;
		max-height: unset;
	}
	
	.cslider{
		min-height: unset;
		overflow: hidden;
		position: relative;
		margin-left: 0;
		padding-left: 0;
		padding-right: 0;
	}
	
	
	.cslider .slick-slide {
		width: auto;
		height: unset;
		margin: 0 2vw;
	}

	.cslider .slick-slide a{
		height: unset;
	}

	.cslider .slick-slide img {
		width: auto;
		height: 28vw;
		aspect-ratio: 1 / 0.57;
		position: relative;
	}
	.cslider .slick-slide .img_over{
	}
	
	.cslider .slick-slide .cap {
		position: absolute;
		left: 0;
		bottom: 0;
		z-index: 2;
		width: 100% ;
		padding: 2vw;
		color: #fff;
	}

	.cslider .slick-slide .cap span{
		font-size: 2.4vw;
		line-height: 1;
	}
	.cslider .slick-slide .cap h4{
		font-size: 2.4vw;
	}
	
	.cslider .slick-arrow {
		width: 9vw;
		height: 9vw;
		cursor: pointer;
		position: absolute;
		top: 36vw;
		left: 1vw;
		z-index: 3;
		background: url(../img/common/circlearrowprev_white.png) no-repeat;
		background-size: 9vw;
		text-indent:100%;
		white-space:nowrap;
		overflow:hidden;
	}
	
	.cslider .slick-arrow {
		width: 9vw;
		height: 9vw;
		top:  10vw;
		left: 1vw;
		background: url(../img/common/cs_arrow-white.svg) no-repeat;
		background-size: 80%;
		background-position: center;
		transform: rotate(180deg);
	}
	.cslider .slick-arrow.slick-next{
		left: auto;
		right: 1vw;
		transform: rotate(0deg);
	}
}


/* ====================
	SLICK CSS
==================== */

.slick-slider
{
    position: relative;

    display: block;
    box-sizing: border-box;

    -webkit-user-select: none;
       -moz-user-select: none;
        -ms-user-select: none;
            user-select: none;

    -webkit-touch-callout: none;
    -khtml-user-select: none;
    -ms-touch-action: pan-y;
        touch-action: pan-y;
    -webkit-tap-highlight-color: transparent;
}

.slick-list
{
    position: relative;

    display: block;
    overflow: hidden;

    margin: 0;
    padding: 0;
}
.slick-list:focus
{
    outline: none;
}
.slick-list.dragging
{
    cursor: pointer;
    cursor: hand;
}

.slick-slider .slick-track,
.slick-slider .slick-list
{
    -webkit-transform: translate3d(0, 0, 0);
       -moz-transform: translate3d(0, 0, 0);
        -ms-transform: translate3d(0, 0, 0);
         -o-transform: translate3d(0, 0, 0);
            transform: translate3d(0, 0, 0);
}

.slick-track
{
    position: relative;
    top: 0;
    left: 0;

    display: block;
    margin-left: auto;
    margin-right: auto;
}
.slick-track:before,
.slick-track:after
{
    display: table;

    content: '';
}
.slick-track:after
{
    clear: both;
}
.slick-loading .slick-track
{
    visibility: hidden;
}

.slick-slide
{
    display: none;
    float: left;

    height: 100%;
    min-height: 1px;
}
[dir='rtl'] .slick-slide
{
    float: right;
}
.slick-slide img
{
    display: block;
}
.slick-slide.slick-loading img
{
    display: none;
}
.slick-slide.dragging img
{
    pointer-events: none;
}
.slick-initialized .slick-slide
{
    display: block;
}
.slick-loading .slick-slide
{
    visibility: hidden;
}
.slick-vertical .slick-slide
{
    display: block;

    height: auto;

    border: 1px solid transparent;
}
.slick-arrow.slick-hidden {
    display: none;
}
/* ====================
	SLICK THEME
==================== */
/* Slider */
.slick-loading .slick-list
{
    background: #fff url('./ajax-loader.gif') center center no-repeat;
}

/* Icons */
@font-face
{
    font-family: 'slick';
    font-weight: normal;
    font-style: normal;

    src: url('./fonts/slick.eot');
    src: url('./fonts/slick.eot?#iefix') format('embedded-opentype'), url('./fonts/slick.woff') format('woff'), url('./fonts/slick.ttf') format('truetype'), url('./fonts/slick.svg#slick') format('svg');
}
/* Arrows */
.slick-prev,
.slick-next
{
    font-size: 0;
    line-height: 0;

    position: absolute;
    top: 50%;

    display: block;

    width: 20px;
    height: 20px;
    padding: 0;
    -webkit-transform: translate(0, -50%);
    -ms-transform: translate(0, -50%);
    transform: translate(0, -50%);

    cursor: pointer;

    color: transparent;
    border: none;
    outline: none;
    background: transparent;
}
/* .slick-prev:hover,
.slick-prev:focus,
.slick-next:hover,
.slick-next:focus
{
    color: transparent;
    outline: none;
    background: transparent;
}
.slick-prev:hover:before,
.slick-prev:focus:before,
.slick-next:hover:before,
.slick-next:focus:before
{
    opacity: 1;
}
.slick-prev.slick-disabled:before,
.slick-next.slick-disabled:before
{
    opacity: .25;
}

.slick-prev:before,
.slick-next:before
{
    font-family: 'slick';
    font-size: 20px;
    line-height: 1;

    opacity: .75;
    color: white;

    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
} */

.slick-prev
{
    left: -25px;
}
[dir='rtl'] .slick-prev
{
    right: -25px;
    left: auto;
}
.slick-prev:before
{
    content: '竊�';
}
[dir='rtl'] .slick-prev:before
{
    content: '竊�';
}

.slick-next
{
    right: -25px;
}
[dir='rtl'] .slick-next
{
    right: auto;
    left: -25px;
}
.slick-next:before
{
    content: '竊�';
}
[dir='rtl'] .slick-next:before
{
    content: '竊�';
}

/* Dots */
.slick-dotted.slick-slider
{
    margin-bottom: 30px;
}

.slick-dots
{
    position: absolute;
    bottom: -25px;

    display: block;

    width: 100%;
    padding: 0;
    margin: 0;

    list-style: none;

    text-align: center;
}
.slick-dots li
{
    position: relative;

    display: inline-block;

    width: 20px;
    height: 20px;
    margin: 0 5px;
    padding: 0;

    cursor: pointer;
}
.slick-dots li button
{
    font-size: 0;
    line-height: 0;

    display: block;

    width: 20px;
    height: 20px;
    padding: 5px;

    cursor: pointer;

    color: transparent;
    border: 0;
    outline: none;
    background: transparent;
}
.slick-dots li button:hover,
.slick-dots li button:focus
{
    outline: none;
}
.slick-dots li button:hover:before,
.slick-dots li button:focus:before
{
    opacity: 1;
}
.slick-dots li button:before
{
    font-family: 'slick';
    font-size: 6px;
    line-height: 20px;

    position: absolute;
    top: 0;
    left: 0;

    width: 20px;
    height: 20px;

    content: '窶｢';
    text-align: center;

    opacity: .25;
    color: black;

    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}
.slick-dots li.slick-active button:before
{
    opacity: .75;
    color: black;
}
/* ========================================
	miscellaneous 
======================================== */

a.-pdf{
	box-sizing: border-box;
	display: inline-block;
	height: 26px;
	padding-top: 3px;
	padding-right: 30px;
	background-image: url(../img/common/icon-pdf.svg);
	background-repeat: no-repeat;
	background-position: right top;
	background-size: 22px 26px;
}
@media screen and (max-width: 767px) {
	a.-pdf{
		height: 6.8vw;
		padding-top: 0.8vw;
		padding-right: 7vw;
		background-size: 5.2vw 6.8vw;
	}
}

/* SERRCHBOX */

.searchbox {
    display: flex;
    width: 100%;
	box-sizing: border-box;
}

.searchbox input[type="text"] {
    width: 87%;
	box-sizing: border-box;
    flex-grow: 1;
    padding: 11px 0 11px 10px;
    border: 1px solid #fff;
    border-radius: 30px 0 0 30px;
}
.searchbox input[type="text"]::placeholder{
	color: #aaa;
}


.searchbox button {
	width: 13%;
	box-sizing: border-box;
    cursor: pointer;
    padding: 12px 12px 12px 30px;
    border-radius: 0 30px 30px 0;
    border: 1px solid #fff;
	border-left: none;
    background-color: #3b6c40;
	background-image: url(../img/common/icon-search.svg);
	background-repeat: no-repeat;
	background-size: 20px;
	background-position: left 7px center;
    color: #fff;
    font-size: 16px;
}

.searchbox input:focus {
    outline: 0;
    /* border: 1px solid #3b6c40; */
}

.searchbox button:hover {
    /* color: #4ab6f6; */
}

@media screen and (max-width: 767px) {
	.searchbox {
		display: flex;
		width: 100%;
	}
	.searchbox input[type="text"] {
		box-sizing: border-box;
		width: 80%;
		padding: 3.6vw 0 4.2vw 4.2vw;
		border-radius: 8vw 0 0 8vw;
		font-size: 3.2vw;
	}
	.searchbox button {
		box-sizing: border-box;
		width: 20%;
		padding: 3.6vw 0 4.2vw 4.2vw;
		/* padding: .8rem 1.3rem .8rem 3rem; */
		border-radius: 0 8vw 8vw 0;
		background-size: 6vw;
		background-position: left 3vw center;
		font-size: 3.2vw;
	}
	
}

/*==============================================================
	ELEMENT
==============================================================*/
/* button */

.buttonbase {
	box-sizing: border-box;
	border: 1px solid #4673ff;
	background-color: #fff;
	border-radius: 22.5px;
	display: inline-block;
	height: 45px;
	width: 180px;
}
.buttonbase a{
	box-sizing: border-box;
	width: 100%;
	height: 100%;
	color: #4673ff;
	display: flex;
	flex-direction: row;
	justify-content: space-between;
	align-items: center;
	background: url(../img/common/arrow-blue.svg) no-repeat;
	background-position: center right 20px;
	background-size: 19px;
	padding: 15px 0 18px 0;
	padding-left: 30px;
	white-space: nowrap;
	font-size: 14px;
	font-weight: 500;
	cursor: pointer;
}

@media screen and (max-width: 767px) {
	.buttonbase {
		border-radius: 5.625vw;
		height: 11.25vw;
		width: 45vw;
	}
	.buttonbase a{
		background-position: center right 5vw;
		background-size: 5vw;
		padding: 3.75vw 0 4.5vw 0;
		padding-left: 7.5vw;
		font-size: 3.5vw;
	}
}

.buttonbase._linkbtn {
	border: 1px solid #808080;
	background-color: #fff;
	border-radius: 30px;
	height: 60px;
	width: 100%;
	background-image: url(../img/about/link-01.png);
	background-repeat: no-repeat;
	background-position: center left 30px;
	background-size: 75%;
	margin-bottom: 20px;
}
.buttonbase._linkbtn a{
	color: #000;
	background: url(../img/common/arrow-black.svg) no-repeat;
	background-position: center right 20px;
	background-size: 19px;
	padding: 15px 0 18px 30px;
	text-indent:1000%;
	white-space:nowrap;
	overflow:hidden;
}

