/*=======================================
　base
=======================================*/
* {
    margin: 0px;
    padding: 0px;
    box-sizing: border-box;
}

body {
    color: #212121;
    font-weight: 500;
    font-size: 16px;
}

img, picture {
    display: block;
    max-width: 100%;
    height: auto;
    vertical-align: top;
    /* image-rendering: -webkit-optimize-contrast; */
}

ul, li {
    list-style: none;
}

a {
    opacity: 1;
    text-decoration: none;
    transition: all 0.3s ease 0s;
    color: #212121;
}

@media (hover: hover) {
    a:hover {
        opacity: 0.8;
    }
}

#contents, body #contents {
    font-family: "Noto Sans JP", YakuHanJP, 游ゴシック体, YuGothic, "游ゴシック Medium", "Yu Gothic Medium", 游ゴシック, "Yu Gothic", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic ProN", メイリオ, Meiryo, Meiryo, "MS PGothic", Osaka, sans-serif;
    -webkit-font-smoothing: antialiased;
    font-feature-settings: "palt";
    text-size-adjust: 100%;
}

html.g-ww #cnwrapper {
    max-width: 100%;
}

.clearfix::after {
    content: "";
    display: block;
    clear: both;
}

.pc {
    display: inline-block;
}

.sp {
    display: none;
}

@media screen and (max-width: 768px) {
    .pc {
        display: none;
    }

    .sp {
        display: inline-block;
    }
}

#contents img {
    /* image-rendering: -webkit-optimize-contrast; */
}

#main {
    width: 100%;
}

/*=======================================
　common
=======================================*/
.inner {
    width: 90%;
    margin: 0 auto;
}
.w990 {
    max-width: calc(990 / 1900 * 100vw);
}
#main .wow {
    animation-delay: 0.4s;
}

/*=======================================
　ボタン
=======================================*/
.tenjijyo_btn {
    max-width: calc(990 / 1900 * 100vw);
    margin: 0 auto;
}
.tenjijyo_btn img {
    width: 100%;
}
.tenjijyo_btn .tenjijyo_btn_txt {
    display: none;
}

/*=======================================
　float_btn
=======================================*/
.float_btn {
    height: calc(116 / 1900 * 100vw);
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100%;
    z-index: 21;
}
.float_btn a {
    background: #168fb5;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    height: 100%;
}
.float_btn a span {
    font-family: 'Noto Serif JP', serif;
    font-size: calc(38 / 1900 * 100vw);
    letter-spacing : 0.14em;
    color: #fff;
    position: relative;
}
.float_btn a span::after {
    content: "";
    width: calc(24 / 1900 * 100vw);
    height: calc(32 / 1900 * 100vw);
    aspect-ratio: 1;
    display: inline-block;
    background: url("../img/arrow01.svg") no-repeat center / 100%;
    border-radius: 50vw;
    position: absolute;
    top: 50%;
    right: calc(-77 / 1900 * 100vw);
    transform: translateY(-50%);
}
.float_btn a:hover {
    text-decoration: none;
}

/*=======================================
　mv
=======================================*/
.mv {
    margin-bottom: calc(150 / 1900 * 100vw);
}

/*=======================================
　intro
=======================================*/
.intro {
    margin-bottom: calc(256 / 1900 * 100vw);
}
.intro p {
    font-size: calc(23 / 1900 * 100vw);
    line-height: 2.33;
    letter-spacing: 0.08em;
    text-align: center;
}

/*=======================================
　cmn_section
=======================================*/
.cmn_section_wrap {
    display: flex;
    flex-direction: column;
    row-gap: calc(411 / 1900 * 100vw);
    margin-bottom: calc(255 / 1900 * 100vw);
}
.cmn_section_wrap .cmn_section .cmn_section_block01 {
    position: relative;
    margin-bottom: calc(172 / 1900 * 100vw);
}
.cmn_section_wrap .cmn_section .cmn_section_block01 .img {
    width: 89%;
    position: relative;
}
.cmn_section_wrap .cmn_section .cmn_section_block01 .copy {
    position: absolute;
    top: 0;
    background: #fff;
    padding: 0 15.89% 13.03%;
    padding: 0 calc(55 / 1900 * 100vw) calc(70 / 1900 * 100vw);
    width: 18.22%;
    top: -12.5%;
}
.cmn_section_wrap .cmn_section .cmn_section_block02 {
    margin-bottom: calc(200 / 1900 * 100vw);
}
.cmn_section_wrap .cmn_section .cmn_section_block02 .inner {
    max-width: calc(1360 / 1900 * 100vw);
    display: flex;
    column-gap: 7.35%;
    align-items: center;
    justify-content: space-between;
}
.cmn_section_wrap .cmn_section .cmn_section_block02 .img {
    margin-left: calc(50% - 50vw);
    width: 75.15%;
}
.cmn_section_wrap .cmn_section .cmn_section_block02 .txt {
    flex: 1;
    font-family: 'Noto Serif JP', serif;
    font-size: calc(32 / 1900 * 100vw);
    line-height: 2;
    letter-spacing: 0.13em;
    color: #424242;
}
.cmn_section_wrap .cmn_section .cmn_section_block03 .txt {
    font-size: calc(28 / 1900 * 100vw);
    line-height: 2;
    letter-spacing: 0.05em;
    text-align: center;
    margin-bottom: calc(50 / 1900 * 100vw);
}
.cmn_section_wrap .cmn_section:nth-child(2) .cmn_section_block01 .copy {
    width: 23.42%;
}
.cmn_section_wrap .cmn_section:nth-child(odd) .cmn_section_block01 .img {
    margin-left: auto;
}
.cmn_section_wrap .cmn_section:nth-child(odd) .cmn_section_block01 .copy {
    left: 16.54%;
}
.cmn_section_wrap .cmn_section:nth-child(odd) .cmn_section_block02 .inner .img {
    margin-left: calc(50% - 50vw);
}
.cmn_section_wrap .cmn_section:nth-child(even) .cmn_section_block01 .copy {
    right: 16.54%;
}
.cmn_section_wrap .cmn_section:nth-child(even) .cmn_section_block02 .inner {
    flex-direction: row-reverse;
}
.cmn_section_wrap .cmn_section:nth-child(even) .cmn_section_block02 .inner .img {
    margin-right: calc(50% - 50vw);
}

/*=======================================
　expert_designer_sec
=======================================*/
.expert_designer_sec {
    padding: calc(80 / 1900 * 100vw) 0;
    background: #e1d19a;
    margin-bottom: calc(220 / 1900 * 100vw);
}
.expert_designer_sec .inner {
    max-width: calc(1116 / 1900 * 100vw);
}
.expert_designer_sec .inner h2 {
    font-family: 'Noto Serif JP', serif;
    font-weight: 500;
    text-align: center;
    font-size: calc(49 / 1900 * 100vw);
    line-height: 1.7;
    letter-spacing: 0.04em;
    color: #424242;
    margin-bottom: calc(20 / 1900 * 100vw);
}
.expert_designer_sec .inner .txt {
    font-size: calc(21 / 1900 * 100vw);
    font-weight: 500;
    line-height: 1.952;
    text-align: center;
    margin-bottom: calc(40 / 1900 * 100vw);
    letter-spacing: 0.15em;
}
.expert_designer_sec .inner .bnr_expert_designer a {
    display: block;
}

/* モーダル用スタイル */
.modal_expert_designer {
    width: calc(1100 / 1900 * 100vw);
    margin: 0!important;
    overflow: visible!important;
    background: none;
    padding: 0!important;
}
.modal_expert_designer .modal_expert_designer_inn {
    box-shadow: inset 0 0 0 calc(23 / 1900 * 100vw) #e1d19a;
    padding: calc(100 / 1900 * 100vw) 0 calc(55 / 1900 * 100vw);
    background: #fff;
}
.modal_expert_designer .modal_frame {
    width: 78.37%;
    margin: 0 auto;
}
.modal_expert_designer .modal_ttl {
    font-family: 'Noto Serif JP', serif;
    text-align: center;
    font-size: calc(49 / 1900 * 100vw);
    font-weight: 500;
    line-height: 1.697;
    letter-spacing: 0.09em;
    color: #424242;
    margin-bottom: calc(25 / 1900 * 100vw);
}
.modal_expert_designer .modal_body .flex_area {
    display: flex;
    align-items: center;
    column-gap: calc(25 / 1900 * 100vw);
    margin-bottom: calc(25 / 1900 * 100vw);
}
.modal_expert_designer .modal_body .img {
    width: 26.84%;
    flex-shrink: 0;
}
.fancybox-container .modal_expert_designer .modal_body .txt p {
    flex: 1;
    font-size: calc(18 / 1900 * 100vw);
    line-height: 2.136!important;
    letter-spacing: 0.05em;
    color: #424242;
    text-align: justify;
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 500;
}
.modal_expert_designer .modal_btn_wrap {
    margin-left: auto;
    width: fit-content;
}
.modal_expert_designer .modal_btn {
    transition: opacity 0.3s ease;
    width: calc(214 / 1900 * 100vw);
    height: calc(40 / 1900 * 100vw);
    display: inline-block;
    background: #168fb5;
    display: flex;
    align-items: center;
    justify-content: center;
}
.modal_expert_designer .modal_btn span {
    font-family: 'Noto Sans JP', sans-serif;
    color: #fff;
    font-size: calc(15 / 1900 * 100vw);
    letter-spacing: 0.02em;
    line-height: 1;
    width: fit-content;
    padding-right: calc(25 / 1900 * 100vw);
    position: relative;
}
.modal_expert_designer .modal_btn span::after {
    content: "";
    width: calc(12 / 1900 * 100vw);
    height: calc(18 / 1900 * 100vw);
    display: inline-block;
    background: url("../img/arrow01.svg") no-repeat center / 100%;
    position: absolute;
    right: 0;
    top: 45%;
    transform: translateY(-50%);
}
.modal_expert_designer .modal_btn:hover {
    opacity: 0.8;
    border: none;
}

/* Fancybox 閉じるボタン カスタマイズ */
/* 親要素のclippingを解除してボタンをモーダル外に表示 */
.fancybox-stage {
    overflow: visible !important;
}
.fancybox-slide--inline {
    overflow: visible !important;
}
.fancybox-slide--inline .fancybox-content {
    overflow: visible !important;
}
.fancybox-close-small {
    position: absolute !important;
    top: calc(-58 / 1900 * 100vw) !important;
    right: calc(0 / 1900 * 100vw) !important;
    width: calc(42 / 1900 * 100vw) !important;
    height: calc(42 / 1900 * 100vw) !important;
    padding: 0 !important;
    background: url('../img/modal_close.svg') no-repeat center center / contain !important;
    color: transparent !important;
    opacity: 1 !important;
}
.fancybox-close-small svg {
    display: none !important;
}

/*=======================================
　sumai_sec
=======================================*/
.sumai_sec {
    margin-bottom: calc(118 / 1900 * 100vw);
}
.sumai_sec .inner h2 {
    display: flex;
    flex-direction: column;
    align-items: center;
    color: #424242;
    margin-bottom: calc(140 / 1900 * 100vw);
    text-align: center;
}
.sumai_sec .inner h2 small {
    font-size: calc(42 / 1900 * 100vw);
    line-height: 1.666;
    letter-spacing: 0.02em;
    font-family: 'Noto Serif JP', serif;
    font-weight: 500;
}
.sumai_sec .inner h2 span {
    font-size: calc(60 / 1900 * 100vw);
    line-height: 1.541;
    font-family: 'Noto Serif JP', serif;
    font-weight: 500;
}
.sumai_sec .inner .sumai_block_wrap {
    display: flex;
    flex-direction: column;
    row-gap: calc(122 / 1900 * 100vw);
}
.sumai_sec .inner .sumai_block_wrap .sumai_block h3 {
    display: flex;
    align-items: center;
    column-gap: calc(16 / 1900 * 100vw);
    margin-bottom: calc(40 / 1900 * 100vw);
}
.sumai_sec .inner .sumai_block_wrap .sumai_block h3 .sumai_ttl_label {
    font-weight: 700;
    font-size: calc(22 / 1900 * 100vw);
    letter-spacing: 0.09em;
    color: #FFFFFF;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    background: #21366e;
    height: calc(44 / 1900 * 100vw);
    padding: 0 calc(15 / 1900 * 100vw);
    white-space: nowrap;
}
.sumai_sec .inner .sumai_block_wrap .sumai_block h3 .sumai_ttl_txt {
    font-family: 'Noto Serif JP', serif;
    font-size: calc(39 / 1900 * 100vw);
    letter-spacing: -0.05em;
    line-height: 1.748;
    font-weight: 500;
}
.sumai_sec .inner .sumai_block_wrap .sumai_block .flex_area {
    display: flex;
    justify-content: space-between;
    margin-bottom: calc(32 / 1900 * 100vw);
}
.sumai_sec .inner .sumai_block_wrap .sumai_block .flex_area .txt {
    width: 50.69%;
    font-size: calc(18 / 1900 * 100vw);
    letter-spacing: 0.02em;
    line-height: 2.136;
    font-weight: 500;
}
.sumai_sec .inner .sumai_block_wrap .sumai_block .flex_area .img {
    width: 43.74%;
}
.sumai_sec .inner .sumai_block_wrap .sumai_block .bnr_area {
    margin-bottom: calc(40 / 1900 * 100vw);
}
.sumai_sec .inner .sumai_block_wrap .sumai_block .point {
    display: flex;
    align-items: center;
    column-gap: calc(3 / 1900 * 100vw);
}
.sumai_sec .inner .sumai_block_wrap .sumai_block .point .icon {
    width: 14.34%;
}
.sumai_sec .inner .sumai_block_wrap .sumai_block .point .icon span {
    display: none;
}
.sumai_sec .inner .sumai_block_wrap .sumai_block .point .txt {
    width: 84.84%;
    font-size: calc(18 / 1900 * 100vw);
    line-height: 2.136;
    letter-spacing: 0.02em;
    border-top: calc(1.3 / 1900 * 100vw) solid #899699;
    border-bottom: calc(1.3 / 1900 * 100vw) solid #899699;
    padding: calc(30 / 1900 * 100vw) 1em;
}

/*=======================================
　bnr_detail
=======================================*/
.bnr_detail {
    margin-bottom: calc(150 / 1900 * 100vw);
}

/*=======================================
　gpsMap_area
=======================================*/
#gpsMap_area {
    margin-bottom: calc(145 / 1900 * 100vw);
}

/*=======================================
　bnr_catalog
=======================================*/
.bnr_catalog {
    margin-bottom: calc(145 / 1900 * 100vw);
}

/*=======================================
　最下部tenjijyo_btn
=======================================*/
#main > .tenjijyo_btn {
    margin-bottom: calc(145 / 1900 * 100vw);
}