@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100;300;400;500;700;900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Roboto:ital,wght@0,500;0,700;1,400&display=swap');
/*------------------------------------------------------------
	デフォルトスタイル
------------------------------------------------------------*/
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, font, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td {
	margin: 0;
	padding: 0;
	background: transparent;
	border: 0;
	outline: 0;
	font-size: 1em;
}
html {
	font-size: 62.5%;
}
body, table, input, textarea, select, option {
    font-family: 'Noto Sans JP', sans-serif;
}
article, aside, canvas, details, figcaption, figure, footer, header, hgroup, menu, nav, section, summary {
	display: block;
}
ol, ul {
	list-style: none;
}
blockquote, q {
	quotes: none;
}
:focus {
	outline: 0;
}
ins {
	text-decoration: none;
}
del {
	text-decoration: line-through;
}
img {
	vertical-align: top;
	max-width: 100%;
    height: auto;
}
a,
a:link {
	color: #333;
	text-decoration: none;
}
a:visited {
	color: #333;
}
a:hover {
	color: #333;
}
a:active {
	color: #333;
}
/*------------------------------------------------------------
	汎用スタイル
------------------------------------------------------------*/
/* clearfix */	
.clearfix:after {content: "";display: block;clear: both;}
/* flex */	
.flex,.flexA,.flexB,.flexC {display: flex;flex-wrap: wrap;}
.flexA {justify-content: space-around;}
.flexB {justify-content: space-between;}
.flexC {justify-content: center;}

/*------------------------------------------------------------
	レイアウト
------------------------------------------------------------*/
body {
	min-width: 1120px;
	color: #333;
	font-size: 1.6rem;
    font-weight: 500;
	line-height: 1.5;
	text-size-adjust: none;
	-webkit-text-size-adjust: none;
	background-color: #FFF;
}
#container {
	text-align: left;
    position: relative;
}
a[href^="tel:"] {
	cursor: default;
	pointer-events: none;
}
/*------------------------------------------------------------
	ヘッダー
------------------------------------------------------------*/
#gHeader .hBox {
    padding: 26px 30px 22px 50px;
    align-items: center;
}
#gHeader .hBox h1 {
    margin: 4px 0 0 20px;
    font-weight: 400;
}
#gNavi li {
    margin-left: 25px;
    display: inline-block;
}
#gNavi li a {
    letter-spacing: 0.05em;
}
#gNavi li a:hover {
    opacity: 0.7;
}
#gHeader .loginList {
    display: flex;
    flex-flow: wrap;
    justify-content: flex-end;
    background-color: #E4005A;
}
#gHeader .loginList li a {
    padding: 12px 28px 11px;
    display: block;
    color: #FFF;
    font-weight: 400;
}
#gHeader .loginList li a:hover {
    opacity: 0.7;
}
#gHeader .loginList li.col01 a {
    background-color: #910782;
}
#gHeader .loginList li.col02 a {
    background-color: #262626;
}
#gHeader .loginList li span {
    margin-right: 4px;
    vertical-align: middle;
}
@media (max-width: 1200px) and (min-width: 1120px) {
    #gHeader .hBox h1 {
        margin-left: 10px;
    }
    #gNavi li {
        margin-left: 15px;
    }
}
/*------------------------------------------------------------
	フッター
------------------------------------------------------------*/
#gFooter {
    padding: 75px 20px 70px;
    background-color: #404040;
}
#gFooter .pageTop {
    position: fixed;
    bottom: 30px;
    right: 30px;
}
#gFooter .pageTop a {
    display: block;
    border-radius: 50%;
}
#gFooter .pageTop a:hover {
    opacity: 0.7;
}
#gFooter .fBox {
    margin: 0 auto;
    width: 1100px;
}
#gFooter .fNavi {
    margin-bottom: 50px;
    text-align: center;
}
#gFooter .fNavi li {
    margin: 0 30px;
    display: inline-block;
}
#gFooter .fNavi li a {
    color: #FFF;
}
#gFooter .fNavi li a:hover {
    opacity: 0.7;
}
#gFooter address {
    color: #FFF;
    font-size: 1.2rem;
    font-weight: 300;
    font-style: normal;
    text-align: center;
}
/*------------------------------------------------------------
	content
------------------------------------------------------------*/
.content {
    margin: 0 auto;
    width: 1100px;
}
/*------------------------------------------------------------
	comSub
------------------------------------------------------------*/
.comSub {
    margin: 0 20px;
}
/*------------------------------------------------------------
	h2
------------------------------------------------------------*/
h2 {
    margin-bottom: 40px;
    padding: 7px 10px;
    display: flex;
    align-items: center;
    font-size: 2.4rem;
    font-weight: 700;
    border-radius: 50px;
    border: 3px solid #a1ce72; 
    background-color: #F2FFE3;
}
h2 span {
    margin-right: 15px;
    padding-top: 4px;
    width: 60px;
    height: 60px;
    color: #FFF;
    font-size: 3.6rem;
    text-align: center;
    display: inline-block;
    vertical-align: top;
    font-weight: 700;
    font-family: 'Roboto', sans-serif;
    border-radius: 50%;
    background: url("../img/shared/h2_bg01.png") no-repeat center / cover;
    box-sizing: border-box;
    line-height: 1.5;
}
/*------------------------------------------------------------
	comLink
------------------------------------------------------------*/
.comLink {
    margin-bottom: 50px;
}
.comLink a {
    margin: 0 auto;
    padding: 27px;
    width: 500px;
    display: block;
    color: #FFF;
    font-size: 2.4rem;
    text-align: center;
    background-color: #FD5266;
    box-sizing: border-box;
}
.comLink a:hover {
    opacity: 0.7;
}

.hLogoBox  h1 {
    font-size: 1em;
}

#gNavi a {
    font-weight: 800;
    line-height: 1.5;
}

.ec-layoutRole__main {
    margin: 24px;
    min-height: 550px;
}

.ec-blockBtn--cancel {
	color: #fff !important;
}