@charset "utf-8";

/*===========================================================
下層カバー
===========================================================*/

.in-cover {
    padding: 4% 15px 0;
    max-width: 1920px;
    width: 100%;
    height: 250px;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
}

.in-cover:before {
    content: "";
    display: block;
    position: absolute;
    max-width: 1920px;
    width: 100%;
    height: 100%;
    top: 0;
    right: 0;
    bottom: 0;
    right: 0;
    background: rgba(0, 0, 0, 0.5);
}

.in-cover-title-box {
    margin: 0 auto;
    text-align: center;
}

.in-cover-title {
    font-size: clamp(26px, calc(1.625rem + ((1vw - 3.75px) * 3.4951)), 80px);
    font-weight: 700;
    letter-spacing: 0;
    font-family: var(--font-family02);
    color: var(--primary);
}

.in-cover-sub-title {
    font-size: clamp(20px, calc(1.25rem + ((1vw - 3.2px) * 1.25)), 40px);
    font-weight: 700;
    letter-spacing: 0.05em;
    color: var(--white);
}

/*===========================================================
パンくず
===========================================================*/

.bread-wrapper {
    max-width: 1920px;
    width: 100%;
    padding: 15px;
}

.bread-box {
    max-width: 1220px;
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    margin: auto;
    font-size: 12px;
    letter-spacing: 0.05em;
}

.bread-link {
    display: block;
    color: var(--base-font-color);
    text-decoration: underline;
}

.bread-link:hover {
    color: var(--base-font-color);
    text-decoration: none;
}

/*===========================================================
inner
===========================================================*/

.in-wrapper {
    max-width: 1920px;
    width: 100%;
    margin: 0 auto;
    padding: 60px 15px;
    position: relative;
}

.inner01 {
    max-width: 1220px;
    width: 100%;
    margin: 0 auto;
    position: relative;
}

.inner02 {
    max-width: 1320px;
    width: 100%;
    margin: 0 auto;
    position: relative;
}

.inner03 {
    max-width: 1420px;
    width: 100%;
    margin: 0 auto;
    position: relative;
}

.inner04 {
    max-width: 1520px;
    width: 100%;
    margin: 0 auto;
    position: relative;
}

.inner05 {
    max-width: 1620px;
    width: 100%;
    margin: 0 auto;
    position: relative;
}

/*===========================================================
br調整
===========================================================*/

.br-none br {
    display: none;
}

/*===========================================================
共通
===========================================================*/

.common-first-text-area {
    margin: 40px 0 0;
}

.common-first-text-box {
    margin: 20px 0 0;
}

.common-first-text-box:first-child {
    margin: 0;
}

.common-first-illust-box01 {
    max-width: 712px;
    width: 37.1%;
    position: absolute;
    right: 0;
    top: 20%;
    z-index: -1;
}

.common-second-main-title-box .title01 {
    margin: 20px 0 0;
}

.common-second-block {
	margin: 60px 0 0;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-direction: column;
}

.common-second-block:first-child {
	margin: 0;
}

.common-secound-illust-box01 {
    max-width: 408px;
    width: 42.5%;
    position: absolute;
    top: 5%;
    right: 0;
}

.common-secound-illust-box02 {
    max-width: 525px;
    width: 27.3%;
    position: absolute;
    top: 40%;
    left: 0;
}

.common-secound-illust-box03 {
    max-width: 610px;
    width: 31.8%;
    position: absolute;
    right: 0;
    bottom: 0;
    z-index: -1;
}

.common-third-illust-box01 {
    max-width: 638px;
    width: 33.2%;
    position: absolute;
    right: 0;
    bottom: 2%;
}

/*===========================================================
バナー
===========================================================*/

.common-banner-area {
    display: grid;
    grid-template-columns: repeat(1, 1fr);
    gap: 40px;
}

.common-banner-link {
    padding: 8px 8px 8px 8px;
    width: 100%;
    height: 250px;
    position: relative;
    display: block;
}

.common-banner-link::before {
    content: "";
    display: block;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.4);
    position: absolute;
    top: 0;
    bottom: 0;
    right: 0;
    left: 0;
    margin: auto;
    transition: all .3s;
}

.common-banner-link:hover::before {
	background: rgba(0, 0, 0, 0.1);
}

.common-banner-img-box {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    bottom: 0;
    right: 0;
    left: 0;
    margin: auto;
    z-index: -1;
}

.common-banner-img-box img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.common-banner-title-area {
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 2px solid #937400;
    text-align: center;
}

.banner-title {
    font-size: clamp(20px, calc(1.25rem + ((1vw - 3.75px) * 1.2945)), 40px);
    font-weight: 700;
    letter-spacing: 0;
    font-family: var(--font-family02);
    color: var(--base-font-color);
}

.common-banner-link:hover .banner-title {
    color: var(--base-font-color);
}

/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
@media screen and (min-width:414px) {


/*===========================================================

===========================================================*/



} /* min-width: 414px ここまで */


/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
@media screen and (min-width:544px) {


/*===========================================================
br調整
===========================================================*/

.sm-br-block br {
    display: block;
}

.sm-br-none br {
    display: none;
}

} /* min-width: 544px ここまで */


/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
@media screen and (min-width: 768px) {


/*===========================================================
br調整
===========================================================*/

.md-br-block br {
    display: block;
}

.md-br-none br {
    display: none;
}

/*===========================================================
下層カバー
===========================================================*/

.in-cover {
    max-width: 1920px;
    width: 100%;
    height: 400px;
    justify-content: flex-start;
}

/*===========================================================
inner
===========================================================*/

.in-wrapper {
    padding: 80px 15px;
}

/*===========================================================
共通
===========================================================*/

.common-first-text-area {
    margin: 60px 0 0;
}

.common-first-text-box {
    margin: 30px 0 0;
}

.common-second-block {
	margin: 80px 0 0;
	justify-content: space-between;
	flex-direction: row;
}

.common-second-block:nth-of-type(even) {
	flex-direction: row-reverse;
}

/*===========================================================
バナー
===========================================================*/

.common-banner-area {
    grid-template-columns: repeat(2, 1fr);
}

} /* min-width: 768px ここまで */


/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
@media screen and (min-width: 1024px) {


/*===========================================================
br調整
===========================================================*/

.lg-br-block br {
    display: block;
}

.lg-br-none br {
    display: none;
}

/*===========================================================
パンくず
===========================================================*/

.bread-box {
    font-size: 14px;
}

/*===========================================================
inner
===========================================================*/

.in-wrapper {
    padding: 150px 15px;
}

.in-first-wrapper {
    padding: 120px 15px;
}

/*===========================================================
共通
===========================================================*/

.common-first-text-area {
    margin: 80px 0 0;
}

.common-first-text-area {
    margin: 80px 0 0;
}

.common-second-block {
	margin: 120px 0 0;
}

/*===========================================================
バナー
===========================================================*/

.common-banner-area {
    gap: 40px 60px;
}

} /* min-width: 1024px ここまで */


/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
@media screen and (min-width:1200px) {


/*===========================================================

===========================================================*/



} /* min-width: 1200px ここまで */


/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
@media screen and (min-width:1440px) {


/*===========================================================

===========================================================*/



} /* min-width: 1440px ここまで */


/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
@media screen and (min-width:1620px) {




} /* min-width: 1520px ここまで */

/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */ 