@charset "UTF-8";

/*!
 * Bootstrap Reboot v4.1.1 (https://getbootstrap.com/)
 * Copyright 2011-2018 The Bootstrap Authors
 * Copyright 2011-2018 Twitter, Inc.
 * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
 * Forked from Normalize.css, licensed MIT (https://github.com/necolas/normalize.css/blob/master/LICENSE.md)
 */
*, *::before, *::after {
    box-sizing: border-box;
}

html {
    font-family: sans-serif;
    line-height: 1.15;
    -webkit-text-size-adjust: 100%;
        -ms-text-size-adjust: 100%;
    -ms-overflow-style: scrollbar;
    -webkit-tap-highlight-color: transparent;
}

@-ms-viewport {
    width: device-width;
}

article, aside, figcaption, figure, footer, header, hgroup, main, nav, section {
    display: block;
}

body {
    margin: 0;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif, 'Apple Color Emoji', 'Segoe UI Emoji', 'Segoe UI Symbol';
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.5;
    color: #212529;
    text-align: left;
    background-color: #fff;
}

[tabindex='-1']:focus {
    outline: 0 !important;
}

hr {
    box-sizing: content-box;
    height: 0;
    overflow: visible;
}

h1, h2, h3, h4, h5, h6 {
    margin-top: 0;
    margin-bottom: .5rem;
}

p {
    margin-top: 0;
    margin-bottom: 1rem;
}

abbr[title], abbr[data-original-title] {
            text-decoration: underline;
    -webkit-text-decoration: underline dotted;
            text-decoration: underline dotted;
    cursor: help;
    border-bottom: 0;
}

address {
    margin-bottom: 1rem;
    font-style: normal;
    line-height: inherit;
}

ol, ul, dl {
    margin-top: 0;
    margin-bottom: 1rem;
}

ol ol, ul ul, ol ul, ul ol {
    margin-bottom: 0;
}

dt {
    font-weight: 700;
}

dd {
    margin-bottom: .5rem;
    margin-left: 0;
}

blockquote {
    margin: 0 0 1rem;
}

dfn {
    font-style: italic;
}

b, strong {
    font-weight: bolder;
}

small {
    font-size: 80%;
}

sub, sup {
    position: relative;
    font-size: 75%;
    line-height: 0;
    vertical-align: baseline;
}

sub {
    bottom: -.25em;
}

sup {
    top: -.5em;
}

a {
    color: #007bff;
    text-decoration: none;
    background-color: transparent;
    -webkit-text-decoration-skip: objects;
}

a:not([href]):not([tabindex]) {
    color: inherit;
    text-decoration: none;
}

a:not([href]):not([tabindex]):hover, a:not([href]):not([tabindex]):focus {
    color: inherit;
    text-decoration: none;
}

a:not([href]):not([tabindex]):focus {
    outline: 0;
}

pre, code, kbd, samp {
    font-family: SFMono-Regular, Menlo, Monaco, Consolas, 'Liberation Mono', 'Courier New', monospace;
    font-size: 1em;
}

pre {
    margin-top: 0;
    margin-bottom: 1rem;
    overflow: auto;
    -ms-overflow-style: scrollbar;
}

figure {
    margin: 0 0 1rem;
}

img {
    vertical-align: middle;
    border-style: none;
}

svg:not(:root) {
    overflow: hidden;
}

table {
    border-collapse: collapse;
}

caption {
    padding-top: .75rem;
    padding-bottom: .75rem;
    color: #6c757d;
    text-align: left;
    caption-side: bottom;
}

th {
    text-align: inherit;
}

label {
    display: inline-block;
    margin-bottom: .5rem;
}

button {
    border-radius: 0;
}

button:focus {
    outline: 1px dotted;
    outline: 5px auto -webkit-focus-ring-color;
}

input, button, select, optgroup, textarea {
    margin: 0;
    font-family: inherit;
    font-size: inherit;
    line-height: inherit;
}

button, input {
    overflow: visible;
}

button, select {
    text-transform: none;
}

button, html [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 {
    padding: 0;
    border-style: none;
}

input[type='radio'], input[type='checkbox'] {
    box-sizing: border-box;
    padding: 0;
}

input[type='date'], input[type='time'], input[type='datetime-local'], input[type='month'] {
    -webkit-appearance: listbox;
}

textarea {
    overflow: auto;
    resize: vertical;
}

fieldset {
    min-width: 0;
    padding: 0;
    margin: 0;
    border: 0;
}

legend {
    display: block;
    width: 100%;
    max-width: 100%;
    padding: 0;
    margin-bottom: .5rem;
    font-size: 1.5rem;
    line-height: inherit;
    color: inherit;
    white-space: normal;
}

progress {
    vertical-align: baseline;
}

[type='number']::-webkit-inner-spin-button, [type='number']::-webkit-outer-spin-button {
    height: auto;
}

[type='search'] {
    outline-offset: -2px;
    -webkit-appearance: none;
}

[type='search']::-webkit-search-cancel-button, [type='search']::-webkit-search-decoration {
    -webkit-appearance: none;
}

::-webkit-file-upload-button {
    font: inherit;
    -webkit-appearance: button;
}

output {
    display: inline-block;
}

summary {
    display: list-item;
    cursor: pointer;
}

template {
    display: none;
}

[hidden] {
    display: none !important;
}
/*
base
============================== */
:root {
    font-size: 62.5%;
}

body {
    font-family: 'Noto Sans Japanese', 'ヒラギノ角ゴ ProN', 'Hiragino Kaku Gothic ProN', YuGothic, '游ゴシック', 'Yu Gothic Medium', 'メイリオ', Meiryo, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
    font-feature-settings: 'palt';
    font-size: 1.5rem;
    height: 100%;
    line-height: 2;
    overflow-x: hidden;
}

body._fixed {
    position: fixed;
    width: 100%;
}

img {
    height: auto;
    vertical-align: bottom;
    max-width: 100%;
}

a, a img, a::before, a::after, button, button img, button::before, button::after {
    transition: opacity .3s, background-color .3s;
}

a {
    border-bottom: 1px solid #1e398c;
    color: #1e398c;
}

p {
    margin-bottom: 1rem;
}

input, textarea {
    font-family: 'Noto Sans Japanese', 'ヒラギノ角ゴ ProN', 'Hiragino Kaku Gothic ProN', YuGothic, '游ゴシック', 'Yu Gothic Medium', 'メイリオ', Meiryo, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
    line-height: 2;
}

select {
    -webkit-appearance: none;
       -moz-appearance: none;
            appearance: none;
    background-image: url(/common/images/icon_arrow_04.svg);
    background-repeat: no-repeat;
    background-size: 14px auto;
    background-position: right 16px center;
    background-color: #fff;
    border: 1px solid #ccc;
    border-radius: 6px;
    padding: 5px 40px 5px 20px;
    position: relative;
}

::-ms-expand {
    display: none;
}

input:not([type=checkbox]), input:not([type=radio]) {
    background-color: #fff;
    border: 1px solid #ccc;
    border-radius: 6px;
    padding: 10px 20px;
}

textarea {
    background-color: #fff;
    border: 1px solid #ccc;
    border-radius: 6px;
    padding: 8px 20px;
}

button:not(:disabled) {
    cursor: pointer;
}

.str_header .headerNavSub > ul, .str_header .headerNav > ul, .str_header .headerNav > ul > li .areaNavChild .navSubItem > ul, .str_header .headerNav > ul > li .navChild, .str_header .headerLinkList, .str_header .headerLinkList02, .flowContainer .flow01 .flowList, .flowContainer .flow01 .flowList > li > .list, .str_footer .footerLinkList, .mod_linkPnlList, .mod_linkAnchor > ul, .sitemap .firstLayer, .sitemap .firstLayer ul, .mod_listPath > ol, .mod_listPnl > .list, .mod_listBtn, .mod_listFacility, .mod_listNews02, .mod_listRank > .list, .mod_listCase, .mod_list_step, .mod_listOrder, .mod_listBurette, .mod_listCheck, .mod_listPanel, .mod_listPanel > li._large .content .mod_listBurette, .mod_listVoice, .mod_listOrder02, .mod_listRecruitarea, .mod_boxStep .detail .list, .mod_boxStep._type03 .detail .list > li .content .work .txtList, .mod_jsTab > .tabList ul, .mod_listQa, .mod_jsSlide .slick-dots, .mod_jsBanner .slick-dots, .mod_carousel .slick-dots {
    list-style-type: none;
    margin: 0;
    padding: 0;
}

.str_header > .inner, .str_contents > .inner, .str_main > .inner, [class*='str_container'] > .inner, .contentsHead > .inner, .str_footer > .inner {
    margin: 0 auto;
    padding: 0 15px;
    max-width: 1310px;
}

.str_header > .inner > :last-child, .str_contents > .inner > :last-child, .str_main > .inner > :last-child, [class*='str_container'] > .inner > :last-child, .contentsHead > .inner > :last-child, .str_footer > .inner > :last-child {
    margin-bottom: 0;
}

/* structure header
============================== */
.str_header {
    background-color: #fff;
    border-bottom: 2px solid #a3c3e2;
}

.qol_top .str_header {
    background-color: transparent;
    border-bottom: none;
}

.str_header a {
    border-bottom: none;
}

.str_header .headerLyt {
    -webkit-align-items: flex-start;
            align-items: flex-start;
    display: -webkit-flex;
    display:         flex;
    -webkit-flex-wrap: wrap;
            flex-wrap: wrap;
    -webkit-align-items: center;
            align-items: center;
}

.str_header .headerLyt > .areaNav {
    position: static;
    top: 71px;
    left: 0;
    width: 100%;
}

.str_header .headerLyt > .areaNav::after {
    background-image: linear-gradient(rgba(0, 0, 0, .1), transparent);
    content: '';
    display: block;
    height: 12px;
}

.str_header .headerLyt > .areaNav > .inner {
    background-color: rgba(255, 255, 255, .8);
    padding: 20px 15px;
}

.str_header .headerLyt > .areaNav > .inner > :last-cild {
    margin-bottom: 0;
}

.str_header .headerLyt > #areaNav {
    overflow: hidden;
}

.str_header .headerLyt > #areaNav:not(.jsInit) {
    transition: height .5s ease;
}

.str_header .headerLyt > #areaNav[aria-hidden] {
    position: absolute;
    z-index: 100;
}

.str_header .headerLyt > #areaNav[aria-hidden=false] {
    border-top: 1px solid #dad7d4;
    overflow-y: auto;
    max-height: calc(100% - 71px);
}

.str_header .headerLogo {
    -webkit-flex-shrink: 0;
            flex-shrink: 0;
    padding-top: 15px;
    margin-bottom: 12px;
    position: relative;
    width: 58px;
    z-index: 2;
}

.str_header .siteHdg {
    font-size: 1.8rem;
    color: #1e398c;
    font-weight: bold;
    -webkit-flex-grow: 1;
            flex-grow: 1;
    padding-left: 12px;
}

.str_header .headerNavSub {
    background-color: #fff;
    border-radius: 6px 6px 0 0;
    overflow: hidden;
}

.str_header .headerNavSub > ul {
    background-image: linear-gradient(90deg, rgba(0, 155, 228, .3) 10%, rgba(255, 233, 0, .3) 50%, rgba(229, 0, 32, .3) 90%);
    padding: 5px;
}

.str_header .headerNavSub > ul > li + li {
    margin-top: 5px;
}

.str_header .headerNavSub > ul > li > a {
    background-color: #fff;
    border-radius: 50px;
    color: #333;
    display: block;
    font-size: 1.2rem;
    padding: 4px 30px 4px 40px;
    position: relative;
}

.str_header .headerNavSub > ul > li > a::after {
    background: url(/common/images/icon_arrow_01_02.svg) no-repeat center/contain;
    content: '';
    display: block;
    height: 13px;
    position: absolute;
    top: 50%;
    right: 8px;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    width: 13px;
}

.str_header .headerNavSub > ul > li > a[class*='_navIcon']::before {
    content: '';
    display: block;
    position: absolute;
    top: 50%;
    left: 5px;
    -webkit-transform: translateY(-50%) scale(.5);
            transform: translateY(-50%) scale(.5);
    -webkit-transform-origin: left center;
            transform-origin: left center;
}

.str_header .headerNavSub > ul > li > a._navIcon01::before {
    background-image: url(/common/images/sprite.png);
    background-position: 0 0;
    width: 48px;
    height: 48px;
}

.str_header .headerNavSub > ul > li > a._navIcon02::before {
    background-image: url(/common/images/sprite.png);
    background-position: -50px 0;
    width: 48px;
    height: 48px;
}

.str_header .headerNavSub > ul > li > a._navIcon03::before {
    background-image: url(/common/images/sprite.png);
    background-position: 0 -50px;
    width: 48px;
    height: 48px;
}

.str_header .headerNavSub > ul > li > a._navIcon04::before {
    background-image: url(/common/images/sprite.png);
    background-position: -50px -50px;
    width: 48px;
    height: 48px;
}

.str_header .headerNavSub > ul > li > a._navIcon05::before {
    background-image: url(/common/images/sprite.png);
    background-position: -100px 0;
    width: 48px;
    height: 48px;
}

.str_header .headerNavSub > ul > li > a._navIcon06::before {
    background-image: url(/common/images/sprite.png);
    background-position: -100px -50px;
    width: 48px;
    height: 48px;
}

.str_header .headerNavSub > ul > li > a > b {
    font-size: 1.3rem;
}

.str_header .headerSearch {
    background-color: #fff;
    padding: 15px 5px;
    position: relative;
}

.str_header .headerSearch > .searchTxt {
    background-color: #fff;
    border: 1px solid #dad7d4;
    border-radius: 50px;
    padding: 2px 5px;
    width: 100%;
    font-size: 1.2rem;
}

.str_header .headerSearch > .searchBtn {
    content: '';
    display: block;
    background-color: #1e398c;
    background-image: url(/common/images/icon_search_01.png);
    background-size: 12px;
    background-repeat: no-repeat;
    background-position: 4px;
    border-radius: 50%;
    padding: 0;
    height: 20px;
    position: absolute;
    top: 50%;
    right: 10px;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    width: 20px;
    color: transparent;
    border: none;
    cursor: pointer;
}

.str_header .headerSearch > .searchBtn::before {
    background-color: #1e398c;
    border-radius: 50%;
    content: '';
    display: block;
    height: 20px;
    position: absolute;
    top: 50%;
    right: 10px;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    width: 20px;
}

.str_header .headerSearch > .searchBtn img {
    display: inline-block;
    margin: 0 5px 3px;
    position: relative;
    width: 10px;
    z-index: 1;
}

.str_header .headerNavBtn {
    -webkit-align-self: center;
            align-self: center;
    background-color: transparent;
    border: none;
    color: #1e398c;
    display: inline-block;
    font-size: 1rem;
    padding: 24px 4px 0;
    position: relative;
    width: 40px;
}

.str_header .headerNavBtn::before, .str_header .headerNavBtn::after {
    border-top: 2px solid #1e398c;
    content: '';
    display: block;
    position: absolute;
    left: 4px;
    width: 32px;
    transition: -webkit-transform .3s;
    transition:         transform .3s;
    transition:         transform .3s, -webkit-transform .3s;
}

.str_header .headerNavBtn::before {
    border-bottom: 2px solid #1e398c;
    height: 11px;
    top: 0;
}

.str_header .headerNavBtn::after {
    top: 18px;
}

.str_header .headerNavBtn[data-state=open]::before {
    border-bottom-color: transparent;
    height: 0;
    top: 12px;
    -webkit-transform: rotate(45deg);
            transform: rotate(45deg);
}

.str_header .headerNavBtn[data-state=open]::after {
    top: 12px;
    -webkit-transform: rotate(-45deg);
            transform: rotate(-45deg);
}

.str_header .headerNavBtn > .btnTxt {
    display: block;
    text-align: center;
}

.str_header .headerNav {
    background: #fff;
    border-radius: 0 0 6px 6px;
    overflow: hidden;
}

.str_header .headerNav > ul {
    margin-top: -5px;
    padding: 5px;
}

.str_header .headerNav > ul > li {
    background-color: #fff;
    border: 2px solid #dbdbdb;
    border-radius: 6px;
}

.str_header .headerNav > ul > li a, .str_header .headerNav > ul > li button, .str_header .headerNav > ul > li .navHook {
    color: #333;
    display: block;
    font-weight: bold;
    position: relative;
}

.str_header .headerNav > ul > li button {
    background-color: transparent;
    border: none;
    text-align: left;
    width: 100%;
}

.str_header .headerNav > ul > li > a, .str_header .headerNav > ul > li > button, .str_header .headerNav > ul > li > .navHook {
    padding: 10px 40px 10px 12px;
    transition: color .3s;
}

.str_header .headerNav > ul > li > a::before, .str_header .headerNav > ul > li > a::after {
    content: '';
    display: block;
    position: absolute;
    top: 50%;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
}

.str_header .headerNav > ul > li > a::before {
    background-color: #1e398c;
    border-radius: 50%;
    height: 20px;
    right: 12px;
    width: 20px;
}

.str_header .headerNav > ul > li > a::after {
    border: 3px solid transparent;
    border-right-width: 0;
    border-left: 5px solid #fff;
    right: 19px;
}

.str_header .headerNav > ul > li > button {
    position: relative;
}

.str_header .headerNav > ul > li > button > .mark {
    background-color: #1e398c;
    border-radius: 50%;
    display: block;
    height: 20px;
    overflow: hidden;
    padding-left: 20px;
    position: absolute;
    top: 50%;
    right: 12px;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    transition: -webkit-transform .3s;
    transition:         transform .3s;
    transition:         transform .3s, -webkit-transform .3s;
    width: 20px;
    white-space: nowrap;
}

.str_header .headerNav > ul > li > button > .mark::before, .str_header .headerNav > ul > li > button > .mark::after {
    border-top: 2px solid #fff;
    content: '';
    display: block;
    height: 0;
    position: absolute;
    top: 50%;
    left: 7px;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    width: 6px;
}

.str_header .headerNav > ul > li > button > .mark::after {
    -webkit-transform: translateY(-50%) rotate(-90deg);
            transform: translateY(-50%) rotate(-90deg);
    transition: -webkit-transform .3s;
    transition:         transform .3s;
    transition:         transform .3s, -webkit-transform .3s;
}

.str_header .headerNav > ul > li > button[data-state=open] {
    color: #1e398c;
}

.str_header .headerNav > ul > li > button[data-state=open] > .mark::after {
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
}

.str_header .headerNav > ul > li + li {
    margin-top: 5px;
}

.str_header .headerNav > ul > li .areaNavChild {
    font-size: 1.2rem;
    overflow: hidden;
    transition: height .3s;
}

.str_header .headerNav > ul > li .areaNavChild > .inner {
    padding: 0 12px;
}

.str_header .headerNav > ul > li .areaNavChild .navItemLyt > .itemHigh {
    border-top: 1px solid #cfcfcf;
}

.str_header .headerNav > ul > li .areaNavChild .navItemLyt > .itemHigh > a {
    padding: 10px 14px 10px 0;
}

.str_header .headerNav > ul > li .areaNavChild .navItemLyt > .itemHigh > a::after {
    border-top: 1px solid #333;
    border-right: 1px solid #333;
    content: '';
    display: block;
    height: 7px;
    margin-top: -4px;
    position: absolute;
    top: 50%;
    right: 2px;
    -webkit-transform: rotate(45deg);
            transform: rotate(45deg);
    width: 7px;
}

.str_header .headerNav > ul > li .areaNavChild .navItemLyt > .itemHigh > a > .img {
    display: none;
}

.str_header .headerNav > ul > li .areaNavChild .navSubItem {
    background-image: linear-gradient(90deg, rgba(0, 155, 228, .3) 10%, rgba(255, 233, 0, .3) 50%, rgba(229, 0, 32, .3) 90%);
    display: none;
}

.str_header .headerNav > ul > li .areaNavChild .navSubItem > ul {
    display: -webkit-flex;
    display:         flex;
    padding-right: 8px;
    padding-bottom: 8px;
}

.str_header .headerNav > ul > li .areaNavChild .navSubItem > ul > li {
    margin-top: 8px;
    margin-left: 8px;
    width: 50%;
}

.str_header .headerNav > ul > li .areaNavChild .navSubItem > ul > li > a {
    background-color: #fff;
    border: 2px solid #fff;
    border-radius: 50px;
    display: block;
    font-size: 1.2rem;
    font-weight: normal;
    line-height: 1.4;
    padding: 8px 35px 8px 68px;
    position: relative;
    transition: border-color .3s;
}

.str_header .headerNav > ul > li .areaNavChild .navSubItem > ul > li > a[class*='_navIcon']::before {
    border-radius: 50%;
    content: '';
    display: block;
    height: 48px;
    position: absolute;
    top: 50%;
    left: 4px;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    width: 48px;
}

.str_header .headerNav > ul > li .areaNavChild .navSubItem > ul > li > a::before {
    border-radius: 50%;
    content: '';
    display: block;
    height: 48px;
    position: absolute;
    top: 50%;
    left: 6px;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    width: 48px;
}

.str_header .headerNav > ul > li .areaNavChild .navSubItem > ul > li > a::after {
    background: url(/common/images/icon_arrow_01_02.svg) no-repeat center/contain;
    content: '';
    display: block;
    height: 14px;
    position: absolute;
    top: 50%;
    right: 8px;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    width: 14px;
}

.str_header .headerNav > ul > li .areaNavChild .navSubItem > ul > li > a._navIcon01::before {
    background-image: url(/common/images/sprite.png);
    background-position: 0 0;
    width: 48px;
    height: 48px;
}

.str_header .headerNav > ul > li .areaNavChild .navSubItem > ul > li > a._navIcon02::before {
    background-image: url(/common/images/sprite.png);
    background-position: -50px 0;
    width: 48px;
    height: 48px;
}

.str_header .headerNav > ul > li .areaNavChild .navSubItem > ul > li > a._navIcon03::before {
    background-image: url(/common/images/sprite.png);
    background-position: 0 -50px;
    width: 48px;
    height: 48px;
}

.str_header .headerNav > ul > li .areaNavChild .navSubItem > ul > li > a._navIcon04::before {
    background-image: url(/common/images/sprite.png);
    background-position: -50px -50px;
    width: 48px;
    height: 48px;
}

.str_header .headerNav > ul > li .areaNavChild .navSubItem > ul > li > a._navIcon05::before {
    background-image: url(/common/images/sprite.png);
    background-position: -100px 0;
    width: 48px;
    height: 48px;
}

.str_header .headerNav > ul > li .areaNavChild .navSubItem > ul > li > a._navIcon06::before {
    background-image: url(/common/images/sprite.png);
    background-position: -100px -50px;
    width: 48px;
    height: 48px;
}

.str_header .headerNav > ul > li .areaNavChild .navSubItem > ul > li > a > b {
    display: block;
    font-size: 1.6rem;
    font-weight: bold;
}

.str_header .headerNav > ul > li .navChild > li {
    border-top: 1px solid #cfcfcf;
}

.str_header .headerNav > ul > li .navChild > li > a {
    padding: 10px 20px 10px 10px;
}

.str_header .headerNav > ul > li .navChild > li > a::after {
    border-top: 1px solid #333;
    border-right: 1px solid #333;
    content: '';
    display: block;
    height: 7px;
    margin-top: -4px;
    position: absolute;
    top: 50%;
    right: 2px;
    -webkit-transform: rotate(45deg);
            transform: rotate(45deg);
    width: 7px;
}

.str_header .headerBtn {
    margin-top: 20px;
}

.str_header .headerBtn > :last-cild {
    margin-bottom: 0;
}

.str_header .headerLinkList > li + li {
    margin-top: 5px;
}

.str_header .headerLinkList > li > a {
    background-color: #5084d9;
    border-radius: 50px;
    color: #fff;
    display: block;
    font-size: 1.3rem;
    font-weight: bold;
    padding: 4px 30px 4px 17px;
    position: relative;
}

.str_header .headerLinkList > li > a::after {
    background-image: url(/common/images/icon_arrow_01.svg);
    background-repeat: no-repeat;
    background-size: contain;
    content: '';
    height: 13px;
    position: absolute;
    top: 50%;
    right: 10px;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    width: 13px;
}

.str_header .headerLinkList > li > a._type02 {
    background-color: #1e398c;
}

.str_header .headerLinkList02 {
    display: -webkit-flex;
    display:         flex;
    -webkit-justify-content: center;
            justify-content: center;
    margin: 20px 0 0 -20px;
    -webkit-flex-wrap: wrap;
            flex-wrap: wrap;
}

.str_header .headerLinkList02 > li {
    margin-left: 20px;
}

.str_header .headerLinkList02 > li > a {
    border-bottom: 1px solid #1e398c;
    display: block;
    font-size: 1.2rem;
    font-weight: bold;
}

.str_header .navCloseBtn {
    background-color: #9e9e9e;
    border: none;
    color: #fff;
    display: block;
    padding: 15px;
    text-align: center;
    width: 100%;
}

.str_header .navCloseBtn::before {
    background-image: url(/common/images/sprite.png);
    background-position: -135px -124px;
    width: 12px;
    height: 11px;
    content: '';
    display: inline-block;
    margin-right: 8px;
}

/* structure contents
============================== */
.str_main {
    border-top: 2px solid #96c4e4;
}

.qol_top .str_main {
    border: none;
}

.str_contents > .inner {
    padding: 15px;
}

.str_main > .inner {
    padding: 15px;
}

[class*='str_container'] > .inner {
    padding: 28px 15px 40px;
}

[class*='str_container'] > .inner._narrow {
    padding: 10px 15px;
}

[class*='str_container'] > .inner > [class*='mod_hdgL'] {
    margin-top: 0;
}

[class*='str_container']._borderRainbow {
    position: relative;
}

[class*='str_container']._borderRainbow::after {
    content: '';
    display: block;
    position: absolute;
    bottom: 0;
    background-image: linear-gradient(90deg, #87cfeb 10%, #fff47f 50%, #f27f8f 90%);
    width: 100%;
    height: 110px;
    opacity: .7;
    z-index: -1;
}

.str_container02 {
    background-color: #ebf2fa;
}

.str_container03 {
    background-color: #fef6ec;
}

.str_container04 {
    background-color: #f0f0f0;
}

/* top */

.str_containerVideo::after {
    background: url(/common/images/bg_top_01.svg) center bottom no-repeat;
    background-size: auto 100%;
    content: '';
    display: block;
    padding-top: 21.8%;
    width: 100%;
    height: auto;
}

.str_containerVideo video, .str_containerVideo .thumbnail {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    z-index: -1;
}

.str_containerVideo video {
    opacity: .8;
}

.str_containerTop {
    background-image: linear-gradient(90deg, #bde5f8 5%, #fff8bd 50%, #f8bdc5 96%);
    margin-top: -3px;
    position: relative;
}

.str_containerTop::after {
    background-image: linear-gradient(transparent 0%, #fff 90%);
    content: '';
    display: block;
    height: 145px;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
}

.str_containerTop::before {
    background-color: #fff;
    content: '';
    display: block;
    position: absolute;
    top: 145px;
    bottom: 0;
    width: 100%;
}

.str_containerTop > .inner {
    position: relative;
    z-index: 1;
}

.str_containerTop .topSearch > .head {
    color: #1e398c;
    margin-bottom: 7px;
}

.str_containerTop .topSearch > .head .hdg {
    font-size: 2.2rem;
    margin-bottom: 0;
    padding-left: 38px;
    position: relative;
}

.str_containerTop .topSearch > .head .hdg::before {
    background-image: url(/common/images/sprite.png);
    background-position: 0 -100px;
    width: 39px;
    height: 38px;
    content: '';
    display: block;
    position: absolute;
    top: 3px;
    left: -8px;
    -webkit-transform: scale(.9);
            transform: scale(.9);
}

.str_containerTop .topSearch > .head .hdg em {
    font-style: normal;
    font-weight: bold;
}

.str_containerTop .topSearch > .head .subTxt {
    margin-top: -10px;
    font-size: 1.2rem;
    text-align: right;
}

.str_containerTop .topSearch > .head .subTxt b {
    font-size: 1.8rem;
}

.str_containerTop + .str_container {
    background-color: #fff;
}

.contentsHead {
    position: relative;
    padding-top: 105px;
}

.contentsHead::before {
    content: '';
    display: block;
    position: absolute;
    top: 0;
    width: 100%;
    height: 105px;
    z-index: -1;
}

.contentsHead .content {
    border-radius: 10px;
    background-color: #fff;
    margin: -40px 0 0;
    padding-top: 45px;
}

.contentsHead .content > *:last-child {
    margin-bottom: 0;
}

.contentsHead._service::before, .contentsHead._know::before, .contentsHead._efforts::before, .contentsHead._company::before {
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
}

.contentsHead._recruit::before {
    background-image: url(/recruit/images/recruit_mv_ball.png), url(/recruit/images/recruit_mv.jpg);
    background-repeat: no-repeat;
    background-position: center top, center;
    background-size: contain, cover;
}

.contentsHead._recruit .content {
    background-image: url(/recruit/images/bg_recruit_01.png);
    background-repeat: no-repeat;
    background-position: 23px 26px;
    background-size: 202px auto;
}

.contentsHead._service::before {
    background-image: url(/service/images/service_mv.jpg);
}

.contentsHead._know::before {
    background-image: url(/know/images/know_mv.jpg);
}

.contentsHead._efforts::before {
    background-image: url(/efforts/images/efforts_mv.jpg);
}

.contentsHead._company::before {
    background-image: url(/company/images/company_mv.jpg);
}

.contentsHead._education_system::before {
    background-image: url(/education_system/images/education_system_mv.jpg);
}

.contentsHead .mod_hdgL2 {
    margin: 0 0 3px 0;
}

.contentsHead .hdg {
    margin-left: 36px;
    font-size: 2.7rem;
    font-weight: bold;
    line-height: 1.5;
    color: #303030;
    margin-bottom: 3px;
}

.contentsHead .hdg em {
    display: inline-block;
    margin-left: 5px;
    margin-right: 5px;
    padding: 0 11px 2px;
    font-size: 2.5rem;
    border-radius: 5px;
}

.contentsHead .hdg em.em_01 {
    background-color: #ffe3e7;
}

.contentsHead .hdg em.em_02 {
    background-color: #e5f8ff;
}

.contentsHead .hdg em.em_03 {
    background-color: #fff6c6;
}

.contentsHead .lead {
    margin-left: 19px;
    margin-right: 19px;
    font-size: 1.8rem;
    color: #00afe6;
    line-height: 1.37143;
    margin-bottom: 31px;
}

.contentsHead .txt {
    margin-left: 19px;
    margin-right: 19px;
    line-height: 1.5;
    margin-bottom: 5px;
}

.sub_container {
    background-color: #fff6ec;
    position: relative;
    padding: 14px 16px;
    margin-bottom: 40px;
    border-radius: 5px;
}

.sub_container::before {
    content: '';
    display: inline-block;
    position: absolute;
    left: 0;
    right: 0;
    top: -14px;
    margin: auto;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 0 14px 14px 14px;
    border-color: transparent transparent #fff6ec transparent;
}

.sectionContainer {
    background-color: #fff6ec;
    border-radius: 10px;
    padding: 17px 16px 12px;
}

[class^='sectionContainer_'] {
    border-radius: 10px;
    padding: 17px 16px 20px;
    margin-bottom: 20px;
}

[class^='sectionContainer_'] .mod_hdgL4 {
    margin-bottom: 12px;
}

[class^='sectionContainer_'] > [class^='mod_']:last-child {
    margin-bottom: 0;
}

.sectionContainer_02 {
    background-color: #eaf0fa;
}

.sectionContainer_03 {
    background-color: #f0f0f0;
    padding: 4px 16px 20px;
}

.sectionContainer_04 {
    background-color: #fff6ec;
}

.flowContainer {
    border-radius: 10px;
    border: 2px solid #dedede;
    margin-bottom: 40px;
}

.flowContainer > .content {
    position: relative;
    padding: 0 10px 30px;
    margin-bottom: 30px;
    background-color: #e5eaf4;
}

.flowContainer > .content *:last-child {
    margin-bottom: 0;
}

.flowContainer > .content::after {
    content: '';
    display: inline-block;
    position: absolute;
    right: 0;
    bottom: -24px;
    left: 0;
    z-index: 1;
    width: 0;
    height: 0;
    margin: auto;
    border-color: #e5eaf4 transparent transparent transparent;
    border-style: solid;
    border-width: 24px 23px 0 23px;
}

.flowContainer > .content:nth-of-type(2) {
    background-color: #ccd6ea;
}

.flowContainer > .content:nth-of-type(2)::after {
    border-color: #ccd6ea transparent transparent transparent;
}

.flowContainer > .content:nth-of-type(3) {
    background-color: #b2c1df;
}

.flowContainer > .content:nth-of-type(3)::after {
    border-color: #b2c1df transparent transparent transparent;
}

.flowContainer > .content:nth-of-type(4) {
    background-color: #99add4;
}

.flowContainer > .content:nth-of-type(4)::after {
    border-color: #99add4 transparent transparent transparent;
}

.flowContainer > .content:nth-of-type(5) {
    background-color: #7f99c9;
}

.flowContainer > .content:nth-of-type(5)::after {
    border-color: #7f99c9 transparent transparent transparent;
}

.flowContainer > .content:nth-of-type(6) {
    background-color: #6685bf;
}

.flowContainer > .content:nth-of-type(6)::after {
    border-color: #6685bf transparent transparent transparent;
}

.flowContainer > .content:last-of-type {
    margin-bottom: 0;
    border-radius: 0 0 9px 9px;
}

.flowContainer > .content:last-of-type::after {
    display: none;
}

.flowContainer > .content .mod_hdg04 {
    background-color: #fff;
    padding: 0 10px 20px;
    margin: 20px -10px 40px;
}

.flowContainer .flow01 > .hdg, .flowContainer .flow01 > .col > .hdg {
    text-align: left;
    margin-bottom: 0;
}

.flowContainer .flow01 > .hdg > span, .flowContainer .flow01 > .col > .hdg > span {
    display: inline-block;
    min-width: 180px;
    border-radius: 10px;
    background-color: #1e398c;
    padding: 5px 15px;
    text-align: center;
    color: #fff;
    font-style: italic;
    font-size: 1.8rem;
}

.flowContainer .flow01 .flowList {
    overflow: hidden;
    -webkit-flex-wrap: wrap;
            flex-wrap: wrap;
    position: relative;
    padding-top: 20px;
    padding-bottom: 40px;
    margin-bottom: 26px;
}

.flowContainer .flow01 .flowList::before {
    content: '';
    display: inline-block;
    position: absolute;
    top: 0;
    left: 12px;
    height: calc(100% - 70px);
    width: 6px;
    background-color: #1e398c;
    margin: auto;
}

.flowContainer .flow01 .flowList::after {
    content: '';
    display: inline-block;
    position: absolute;
    bottom: 12px;
    left: 12px;
    height: 55px;
    width: 6px;
    margin: auto;
    border-right: 5px dotted #5c7cba;
}

.flowContainer .flow01 .flowList > li {
    position: relative;
    padding: 10px 10px 0;
    border-radius: 10px;
    margin-left: 40px;
    margin-bottom: 30px;
    border: 2px solid #1e398c;
    background-color: #fff;
}

.flowContainer .flow01 .flowList > li::before {
    content: '';
    display: inline-block;
    position: absolute;
    left: -25px;
    top: 13px;
    height: 2px;
    width: 25px;
    background-image: linear-gradient(to right, transparent, transparent 2px, #1e398c 2px, #1e398c 8px);
    background-repeat: repeat-x;
    background-size: 8px 2px;
}

.flowContainer .flow01 .flowList > li::after {
    content: '';
    display: inline-block;
    position: absolute;
    left: -36px;
    top: 6px;
    background-color: #fff;
    border: 2px solid #1e398c;
    border-radius: 50%;
    width: 18px;
    height: 18px;
}

.flowContainer .flow01 .flowList > li > .hdg {
    margin-bottom: 14px;
    font-size: 1.4rem;
    background-color: #ff577c;
    border-radius: 24px;
    text-align: center;
    color: #fff;
    font-weight: normal;
}

.flowContainer .flow01 .flowList > li > .title {
    font-weight: bold;
    margin-bottom: 15px;
}

.flowContainer .flow01 .flowList > li > .title > .sub {
    display: block;
    font-size: 1.2rem;
}

.flowContainer .flow01 .flowList > li > .list {
    display: -webkit-flex;
    display:         flex;
    -webkit-flex-wrap: wrap;
            flex-wrap: wrap;
}

.flowContainer .flow01 .flowList > li > .list > li {
    margin-right: 10px;
    margin-bottom: 10px;
    padding: 3px 11px 2px;
    color: #1e398c;
    font-weight: bold;
    border-radius: 5px;
    background-color: #e5eaf5;
}

.flowContainer .flow01._branch .col {
    padding: 26px 10px;
    margin-bottom: 20px;
    border-radius: 10px;
    background-color: #fff;
}

.flowContainer .flow01._branch .col > .hdg {
    text-align: center;
}

.flowContainer .flow01._branch .col._withSub > .hdg {
    position: relative;
    margin-bottom: 50px;
}

.flowContainer .flow01._branch .col._withSub > .hdg::before {
    content: '';
    display: inline-block;
    position: absolute;
    left: 0;
    right: 0;
    top: 100%;
    margin: auto;
    height: 100%;
    width: 6px;
    border-right: 5px dotted #5c7cba;
}

.flowContainer .flow01._branch .col .hdg02 {
    text-align: center;
    margin-bottom: 0;
}

.flowContainer .flow01._branch .col .hdg02 span {
    display: inline-block;
    min-width: 180px;
    border-radius: 10px;
    background-color: #cfe9ff;
    padding: 5px 15px;
    text-align: center;
    color: #1e398c;
    border: 2px solid #1e398c;
    font-style: italic;
    font-size: 1.8rem;
}

.flowContainer .flow01._branch .flowList {
    margin-bottom: 0;
    padding-bottom: 14px;
}

.flowContainer .flow01._branch .flowList::before {
    height: calc(100% - 3px);
    left: 0;
    right: 0;
}

.flowContainer .flow01._branch .flowList::after {
    bottom: 0;
    background-image: url(/common/images/sprite.png);
    background-position: -70px -166px;
    width: 22px;
    height: 12px;
    border: none;
    left: 0;
    right: 0;
}

.flowContainer .flow01._branch .flowList > li {
    margin-left: 0;
    margin-bottom: 20px;
}

.flowContainer .flow01._branch .flowList > li:nth-child(even) {
    margin-top: 0;
}

.flowContainer .flow01._branch .flowList > li::before, .flowContainer .flow01._branch .flowList > li::after {
    display: none;
}

.flowContainer .flow01._branch .flowList > li .hdg._type02 {
    background-color: #1e398c;
    padding: 5px;
}

.flowContainer .flow02 .itemWrap {
    position: relative;
    margin-bottom: 20px;
    padding-left: 40px;
}

.flowContainer .flow02 .itemWrap::after {
    content: '';
    display: inline-block;
    position: absolute;
    top: 0;
    left: 12px;
    height: calc(100% + 20px);
    width: 6px;
    background-color: #1e398c;
}

.flowContainer .flow02 .itemWrap:first-child::before {
    content: '';
    display: inline-block;
    position: absolute;
    top: -20px;
    left: 12px;
    height: 20px;
    width: 6px;
    border-right: 5px dotted #5c7cba;
}

.flowContainer .flow02 .itemWrap:last-child::before {
    content: '';
    display: inline-block;
    position: absolute;
    bottom: -20px;
    left: 12px;
    height: 20px;
    width: 6px;
    border-right: 5px dotted #5c7cba;
}

.flowContainer .flow02 .itemWrap:last-child::after {
    height: 100%;
}

.flowContainer .flow02 .itemWrap:first-child:last-child::before {
    content: '';
    display: inline-block;
    position: absolute;
    top: -20px;
    left: 12px;
    height: calc(100% + 40px);
    width: 6px;
    border-right: 5px dotted #5c7cba;
}

.flowContainer .flow02 .itemWrap > .item {
    position: relative;
    padding: 19px 19px 17px;
    border-radius: 10px;
    border: 2px solid #1e398c;
    background-color: #fff;
}

.flowContainer .flow02 .itemWrap > .item:last-child {
    margin-bottom: 0;
}

.flowContainer .flow02 .itemWrap > .item::before {
    content: '';
    display: inline-block;
    position: absolute;
    left: -27px;
    top: 0;
    height: 2px;
    width: 27px;
    bottom: 0;
    margin: auto;
    background-image: linear-gradient(to right, transparent, transparent 2px, #1e398c 2px, #1e398c 8px);
    background-repeat: repeat-x;
    background-size: 8px 2px;
}

.flowContainer .flow02 .itemWrap > .item::after {
    content: '';
    display: inline-block;
    position: absolute;
    left: -36px;
    top: 0;
    bottom: 0;
    margin: auto;
    background-color: #fff;
    border: 2px solid #1e398c;
    border-radius: 50%;
    width: 18px;
    height: 18px;
    z-index: 2;
}

.flowContainer .flow02 .itemWrap > .item .img img {
    width: 100%;
    border-radius: 10px;
    margin-bottom: 20px;
}

.flowContainer .flow02 .itemWrap > .item .content .tag {
    display: inline-block;
    border-radius: 21px;
    background-color: #9fc737;
    line-height: 1;
    margin-bottom: 0;
    padding: 5px 16px 6px;
    font-size: 1.2rem;
    color: #fff;
}

.flowContainer .flow02 .itemWrap > .item .content .tag._type02 {
    background-color: #00b3cb;
}

.flowContainer .flow02 .itemWrap > .item .content .title {
    font-size: 2rem;
    font-weight: bold;
    color: #1e398c;
    margin-bottom: 0;
}

.flowContainer .flow02 .itemWrap > .item .content .txt {
    font-weight: bold;
    font-size: 1.4rem;
}

.flowContainer > .content:last-child .itemWrap:last-child::before {
    height: calc(50% + 20px);
    top: -20px;
}

.flowContainer > .content:last-child .itemWrap:last-child::after {
    height: 50%;
}

/* structure footer
============================== */
.str_footer {
    background-color: #727272;
    color: #fff;
    text-align: center;
}

.str_footer::before {
    background-image: linear-gradient(90deg, #87cfeb 10%, #fff47f 50%, #f27f8f 90%);
    content: '';
    display: block;
    height: 20px;
}

.str_footer > .inner {
    padding: 18px 15px;
}

.str_footer a {
    color: #fff;
}

.str_footer .footerLinkList {
    display: -webkit-flex;
    display:         flex;
    -webkit-flex-wrap: wrap;
            flex-wrap: wrap;
    -webkit-justify-content: center;
            justify-content: center;
    margin: 0 0 5px -40px;
    padding: 0;
}

.str_footer .footerLinkList > li {
    margin-left: 40px;
}

.str_footer .footerLinkList > li > a {
    border-bottom: none;
}

.str_footer .footerCopyright {
    margin-bottom: 0;
}

/* hdg
============================== */
.mod_hdgL1 {
    font-size: 2.8rem;
    margin: 10px 0;
    padding: 10px 0;
    line-height: 1.5;
}

.mod_hdgL1[class*='_icon'] {
    padding-left: 50px;
    position: relative;
}

.mod_hdgL1[class*='_icon']::before {
    content: '';
    display: block;
    position: absolute;
    top: 15px;
    left: 0;
}

.mod_hdgL1._iconSearch::before {
    background-image: url(/common/images/sprite.png);
    background-position: 0 -100px;
    width: 39px;
    height: 38px;
}

.mod_hdgL2 {
    border-bottom: 2px solid #a3c3e2;
    color: #1e398c;
    font-size: 2.4rem;
    margin: 50px 0 15px;
    overflow: hidden;
    line-height: 1.5;
    padding: 50px 0 10px;
    position: relative;
    text-align: center;
}

.mod_hdgL2::before {
    background-image: url(/common/images/hdg_icon_01.svg);
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center;
    content: '';
    display: block;
    height: 40px;
    position: absolute;
    top: 0;
    left: 50%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
    width: 46px;
}

.mod_hdgL2 .areaBadge {
    color: #212529;
    display: block;
    font-weight: normal;
}

.mod_hdgL2 .areaBadge .mod_txtBadge {
    margin: -5px 5px 0;
    vertical-align: middle;
}

.mod_hdgL2 .sub {
    display: inline-block;
    font-size: 1.8rem;
    margin-left: 8px;
}

.mod_hdgL2 .company {
    display: block;
    margin-top: 9px;
    font-size: 1.8rem;
    color: #212529;
}

.mod_hdgL2_02 {
    font-size: 2.4rem;
    line-height: 1.375;
    margin-bottom: 24px;
    text-align: center;
}

.mod_hdgL2_02::before {
    background-image: url(/common/images/hdg_icon_01.svg);
    background-size: contain;
    background-repeat: no-repeat;
    content: '';
    display: block;
    height: 40px;
    margin: 0 auto 15px;
    width: 45px;
}

.mod_hdgL2_02 > .lead {
    font-size: 1.7rem;
    font-weight: normal;
    color: #3aade3;
    display: block;
    margin-bottom: 10px;
}

.mod_hdgL2_02 > .lead._type02 {
    color: #e0bf26;
}

.mod_hdgL2_02 > .lead._type03 {
    color: #f54d66;
}

.mod_hdgL3 {
    border-bottom: 1px solid #d2d2d2;
    font-size: 2.2rem;
    margin-bottom: 20px;
    padding-bottom: 5px;
    line-height: 1.42857;
}

.mod_hdgL4 {
    font-size: 2rem;
    border-bottom: solid 2px #1e398c;
    color: #1e398c;
    padding-bottom: 7px;
    margin-bottom: 2px;
}

.mod_hdg02 {
    margin-top: 15px;
    border-bottom: 1px solid #d2d2d2;
    padding-bottom: 15px;
    display: -webkit-flex;
    display:         flex;
    -webkit-align-items: center;
            align-items: center;
    font-size: 2rem;
    font-weight: bold;
}

.mod_hdg02 .icon {
    margin-right: 20px;
    -webkit-flex-shrink: 0;
            flex-shrink: 0;
}

.mod_hdg02 em {
    font-style: normal;
}

.mod_hdg02 .em_01 {
    color: #009ce8;
}

.mod_hdg02 .em_02 {
    color: #00b479;
}

.mod_hdg02 .em_03 {
    color: #ec52a5;
}

.mod_hdg03 {
    border-bottom: 1px solid #d2d2d2;
    font-size: 1.8rem;
    margin-bottom: 10px;
    padding-bottom: 5px;
    line-height: 1.42857;
    color: #1e398c;
}

.mod_hdgL4 + .mod_hdg03 {
    margin-top: 20px;
}

.mod_hdg04 {
    position: relative;
    padding: 0 10px 45px;
}

.mod_hdg04::after {
    content: '';
    display: inline-block;
    position: absolute;
    right: 0;
    bottom: -24px;
    left: 0;
    z-index: 1;
    width: 0;
    height: 0;
    margin: auto;
    border-color: #fff transparent transparent transparent;
    border-style: solid;
    border-width: 24px 23px 0 23px;
}

.mod_hdg04 .hdg {
    margin-bottom: 13px;
    text-align: center;
    color: #1e398c;
    font-size: 2.8rem;
}

.mod_hdg04 .hdg .category {
    display: inline-block;
    position: relative;
    margin-left: 7px;
    margin-right: 8px;
    top: -4px;
    font-size: 1.6rem;
}

.mod_hdg04 .hdg .category b {
    display: inline-block;
    border: 2px solid #1e398c;
    padding: 4px 5px 6px;
    line-height: 1;
}

.mod_hdg04 .hdg .category b + b {
    margin-left: -2px;
}

.mod_hdg04 .hdg .category b:first-child {
    border-radius: 5px 0 0 5px;
}

.mod_hdg04 .hdg .category b:last-child {
    border-radius: 0 5px 5px 0;
}

.mod_hdg04 .hdg .year {
    display: inline-block;
    margin-right: 8px;
    color: #9fc737;
    font-size: 2.2rem;
}

.mod_hdg04 .hdg .year._type02 {
    color: #00b3cb;
}

.mod_hdg04 .hdg .year .num {
    font-size: 2.8rem;
}

.mod_hdg04 .lead {
    background-color: #1e398c;
    color: #fff;
    display: block;
    max-width: 626px;
    margin: auto;
    text-align: center;
    padding: 2px 5px 3px;
    border-radius: 17px;
    font-weight: bold;
    font-size: 1.6rem;
}

.mod_hdg04 .note {
    font-size: 10px;
    text-align: center;
    color: #1e398c;
}

.mod_txt {
    margin-bottom: 20px;
}

.mod_txt p {
    margin-bottom: 0;
    line-height: 1.75;
}

.mod_txt._topinfo {
    margin-bottom: 30px;
    padding: 20px;
    border-radius: 10px;
    font-size: 1.5rem;
    color: #003690;
    background-color: #fff;
}

.mod_txt._topinfo .hdg {
    font-size: 1.6rem;
}

.strongTxt {
    color: #d24255;
}

.emTxt {
    font-size: 2.2rem;
}

.mod_txtSub {
    font-size: 1.6rem;
    text-align: center;
}

.mod_txtBadge {
    background-color: #f99aa8;
    border-radius: 50px;
    display: inline-block;
    font-size: 1.2rem;
    font-weight: bold;
    padding: 3px 20px;
    text-align: center;
    min-width: 132px;
}

.mod_txtBadge._type02, .mod_listNews > div > dt > .badge._type02 {
    background-color: #fbe877;
    -webkit-flex-shrink: 0;
            flex-shrink: 0;
}

.mod_txtBadge._type03, .mod_listNews > div > dt > .badge._type03 {
    background-color: #beecdc;
    -webkit-flex-shrink: 0;
            flex-shrink: 0;
}

.mod_txtBadge._type04, .mod_listNews > div > dt > .badge._type04 {
    background-color: #b5e1f5;
    -webkit-flex-shrink: 0;
            flex-shrink: 0;
}

.mod_txtRelease {
    color: #303030;
    font-size: 1.2rem;
    text-align: right;
}

.mod_txtLead {
    font-size: 1.5rem;
    font-weight: bold;
}

.mod_txtLead > [class^='em_'] {
    display: inline-block;
    font-style: normal;
    border-radius: 5px;
    line-height: 1.5;
    padding: 3px 8px;
    margin-left: 7px;
    margin-right: 7px;
}

.mod_txtLead .em_01 {
    background-color: #e5f8ff;
    color: #009ce8;
}

.mod_txtLead .em_02 {
    background-color: #d9f5eb;
    color: #00b479;
}

.mod_txtLead .em_03 {
    background-color: #ffeff2;
    color: #ec52a5;
}

.mod_txtNote {
    display: table;
}

.mod_txtNote .mark {
    display: table-cell;
    padding-right: 5px;
}

.mod_txtNote .txt {
    display: table-cell;
}

.mod_listBurette + .mod_txtNote {
    margin-top: -20px;
}

em {
    font-style: normal;
    font-weight: bold;
}

em.em_01 {
    color: #f54d66;
}

em.em_02 {
    color: #00afe6;
}

em.em_03 {
    color: #e0bf26;
}

img + .linkIcon {
    display: none;
}

.iconPdf {
    margin-left: 6px;
    margin-bottom: 7px;
}

.iconBlank {
    margin-left: 5px;
    margin-bottom: 4px;
}

[class^='mod_btn'] .iconBlank {
    margin-bottom: 10px;
}

.mod_link {
    border-bottom: none;
    color: #1e398c;
    display: inline-block;
    font-size: 1.5rem;
    font-weight: bold;
    padding-left: 30px;
    position: relative;
}

.mod_link::before, .mod_link::after {
    content: '';
    display: block;
}

.mod_link::before {
    background-image: url(/common/images/icon_arrow_03.svg);
    background-repeat: no-repeat;
    background-size: contain;
    height: 20px;
    position: absolute;
    top: 6px;
    left: 0;
    -webkit-transform: none;
            transform: none;
    width: 20px;
}

.mod_link._left::before {
    -webkit-transform: rotate(180deg);
            transform: rotate(180deg);
}

.mod_link::after {
    border-bottom: 1px solid #1e398c;
    right: 0;
    bottom: 0;
    left: 34px;
}

table .mod_link {
    line-height: 2;
}

.mod_link[href^='#anc_']::before {
    -webkit-transform: rotate(90deg);
            transform: rotate(90deg);
}

.mod_linkPnl {
    border-bottom: none;
    display: block;
}

.mod_linkPnl::after {
    display: none;
    opacity: 0;
}

.mod_linkPnl > .img {
    margin-bottom: 10px;
    overflow: hidden;
}

.mod_linkPnl > .img img {
    border-radius: 20px;
    display: block;
    width: 100%;
}

.mod_linkPnl > .txt {
    color: #1e398c;
    display: inline-block;
    font-size: 1.5rem;
    font-weight: bold;
    padding-left: 32px;
    position: relative;
}

.mod_linkPnl > .txt::before, .mod_linkPnl > .txt::after {
    content: '';
    display: block;
}

.mod_linkPnl > .txt::before {
    content: url(/common/images/icon_arrow_03.svg);
    margin-top: -12px;
    position: absolute;
    top: 50%;
    left: 0;
}

.mod_linkPnl > .txt::after {
    border-bottom: 1px solid #1e398c;
    content: '';
    display: block;
    position: absolute;
    left: 36px;
    bottom: 0;
    right: 0;
}

.mod_linkPnl > .txt em {
    font-style: normal;
    font-size: 1.7rem;
}

.mod_linkPnl > .txt em.em_01 {
    color: #f54d66;
}

.mod_linkPnl > .txt em.em_02 {
    color: #00afe6;
}

.mod_linkPnl > .txt em.em_03 {
    color: #e0bf26;
}

.mod_linkPnl + .discription {
    margin-top: 10px;
    line-height: 1.5;
    font-size: 1.4rem;
}

.mod_linkPnl._no_border > .txt::after {
    border: none;
}

.mod_linkPnl02 {
    background-color: #fff;
    border: 1px solid #ccc;
    border-radius: 5px;
    display: block;
    padding: 13px 16px 25px;
}

.mod_linkPnl02 > .img img {
    border-radius: 10px;
    width: 100%;
}

.mod_linkPnl02 > .txt {
    color: #000;
    margin-bottom: 15px;
}

.mod_linkPnl02 > .txt > .hdg {
    font-size: 2rem;
    font-weight: bold;
    position: relative;
    padding-left: 45px;
    margin-bottom: 0;
}

.mod_linkPnl02 > .txt > .hdg em {
    font-style: normal;
}

.mod_linkPnl02 > .txt > .hdg::before {
    background-image: url(/common/images/hdg_icon_01.svg);
    background-size: contain;
    background-repeat: no-repeat;
    content: '';
    display: block;
    height: 29px;
    position: absolute;
    top: 6px;
    left: 0;
    width: 32px;
}

.mod_linkPnl02 > .txt > :last-child {
    margin-bottom: 0;
}

.mod_linkPnl02 > .btn {
    display: inline-block;
    font-size: 1.5rem;
    font-weight: bold;
    margin-top: 15px;
    padding-left: 30px;
    position: relative;
}

.mod_linkPnl02 > .btn::before {
    background-image: url(/common/images/icon_arrow_03.svg);
    background-size: contain;
    background-repeat: no-repeat;
    content: '';
    display: block;
    height: 20px;
    position: absolute;
    top: 5px;
    left: 0;
    width: 20px;
}

.mod_linkPnl02 > .btn::after {
    border-bottom: 1px solid #1e398c;
    content: '';
    display: block;
    position: absolute;
    right: 0;
    bottom: 0;
    left: 30px;
}

.mod_linkPnlList {
    margin-bottom: 32px;
}

.mod_linkPnlList > li + li {
    margin-top: 10px;
}

.mod_linkPnlList > li > a, .mod_linkPnlList > li > .nolink {
    border: 1px solid #ddd;
    border-radius: 5px;
    display: -webkit-flex;
    display:         flex;
    padding: 16px;
}

.mod_linkPnlList > li > a > .ico, .mod_linkPnlList > li > .nolink > .ico {
    -webkit-flex-shrink: 0;
            flex-shrink: 0;
    margin-right: 14px;
}

.mod_linkPnlList > li > a > .txt, .mod_linkPnlList > li > .nolink > .txt {
    -webkit-flex-grow: 1;
            flex-grow: 1;
}

.mod_linkPnlList > li > a > .txt > .sub, .mod_linkPnlList > li > .nolink > .txt > .sub {
    color: #666;
    display: block;
    font-size: 1.2rem;
}

.mod_linkPnlList > li > a .linkIcon, .mod_linkPnlList > li > .nolink .linkIcon {
    -webkit-align-self: center;
            align-self: center;
}

.mod_linkPnlList > li > a > .txt > .main {
    border-bottom: 1px solid #1e398c;
    color: #1e398c;
}

.mod_linkAnchor {
    background-image: linear-gradient(90deg, #87cfeb 10%, #fff47f 50%, #f27f8f 90%);
    margin-top: 40px;
    margin-bottom: 20px;
    padding: 20px;
}

.mod_linkAnchor > ul {
    display: -webkit-flex;
    display:         flex;
    -webkit-flex-wrap: wrap;
            flex-wrap: wrap;
    -webkit-align-items: center;
            align-items: center;
    max-width: 1200px;
    margin: auto;
}

.mod_linkAnchor > ul > li {
    width: 100%;
    margin-bottom: 10px;
}

.mod_linkAnchor > ul > li:last-child {
    margin-bottom: 0;
}

.mod_linkAnchor > ul > li a {
    display: block;
    position: relative;
    border-radius: 10px;
    border-bottom: none;
    padding: 10px 50px 10px 30px;
    width: 100%;
    text-align: center;
    background-color: #fff;
    color: #303030;
}

.mod_linkAnchor > ul > li a::before {
    content: '';
    display: inline-block;
    content: url(/common/images/icon_arrow_03.svg);
    position: absolute;
    top: 0;
    right: 21px;
    width: 23px;
    height: 23px;
    bottom: 0;
    margin: auto;
    -webkit-transform: rotate(90deg);
            transform: rotate(90deg);
}

.mod_linkAnchor > ul > li a em {
    font-size: 2rem;
}

.mod_linkAnchor > ul > li a:not([href^='#'])::before {
    -webkit-transform: rotate(0);
            transform: rotate(0);
}

/* sitemap */
.sitemap .firstLayer li {
    position: relative;
    padding-left: 13px;
}

.sitemap .firstLayer li::before {
    content: '';
    display: inline-block;
    position: absolute;
    left: 0;
}

.sitemap .firstLayer > li::before {
    background-color: #333;
    border-radius: 50%;
    width: 4px;
    height: 4px;
    top: 13px;
}

.sitemap .firstLayer > li > .secondLayer > li::before {
    width: 3px;
    height: 3px;
    background-color: #003394;
    border-radius: 50%;
    top: 15px;
}

.sitemap .firstLayer > li > .secondLayer > li > .thirdLayer > li {
    padding-left: 30px;
}

.sitemap .firstLayer > li > .secondLayer > li > .thirdLayer > li::before {
    width: 10px;
    height: 5px;
    border-left: 1px solid #7d8cba;
    border-bottom: 1px solid #7d8cba;
    top: 13px;
}

.sitemap .firstLayer > li > .secondLayer > li > .thirdLayer > li::after {
    content: '';
    display: inline-block;
    position: absolute;
    left: 20px;
    width: 3px;
    height: 3px;
    background-color: #7d8cba;
    border-radius: 50%;
    top: 15px;
}

.sitemap .firstLayer > li > .secondLayer > li > .thirdLayer > li .fourthLayer {
    margin-left: -10px;
}

.sitemap .firstLayer > li > .secondLayer > li > .thirdLayer > li .fourthLayer > li::before {
    width: 10px;
    height: 5px;
    border-left: 1px solid #7d8cba;
    border-bottom: 1px solid #7d8cba;
    top: 12px;
}

.mod_btn, .mod_btn04 {
    background-color: #1e398c;
    border: none;
    border-radius: 10px;
    color: #fff;
    display: block;
    font-size: 2rem;
    font-weight: bold;
    text-align: center;
    margin: 0 16px;
    padding: 5px 16px;
    width: calc(100% - 32px);
}

.mod_btn._btnSmall, ._btnSmall.mod_btn04 {
    padding: 0 34px;
    line-height: 1.2;
}

.mod_btn02 {
    background-color: #ffee0d;
    border: none;
    border-radius: 10px;
    color: #1e398c;
    display: inline-block;
    font-weight: bold;
    padding: 5px 24px;
}

.mod_btn03 {
    padding: 8px 15px 11px;
    background-color: #ebf2fa;
    border: 2px solid #a3c3e2;
    border-radius: 4px;
    font-size: 1.6rem;
    color: #003690;
}

.mod_btn04 {
    background-color: #ebf2fa;
    border: 2px solid #a3c3e2;
    color: #1e398c;
}

.mod_listPath {
    font-size: 1.1rem;
}

.mod_listPath > ol {
    overflow: hidden;
}

.mod_listPath > ol > li {
    float: left;
}

.mod_listPath > ol > li:not(:last-child) {
    padding-right: 16px;
    position: relative;
}

.mod_listPath > ol > li:not(:last-child)::before, .mod_listPath > ol > li:not(:last-child)::after {
    border-top: 1px solid #666;
    content: '';
    display: block;
    height: 0;
    margin-top: -2px;
    position: absolute;
    top: 50%;
    right: 3px;
    -webkit-transform: rotate(25deg);
            transform: rotate(25deg);
    width: 8px;
}

.mod_listPath > ol > li:not(:last-child)::after {
    margin-top: 1px;
    -webkit-transform: rotate(-25deg);
            transform: rotate(-25deg);
}

.mod_listPath > ol > li a {
    border-bottom: none;
    color: #578dcb;
}

.mod_listPath > ol > li a::after {
    display: none;
}

.mod_listPath > ol > li > b {
    font-weight: normal;
}

.mod_listPnl {
    margin-bottom: 15px;
}

.mod_listPnl > .hdg {
    color: #1e398c;
    font-size: 1.7rem;
    text-align: center;
}

.mod_listPnl > .list {
    background-color: #fff;
    border-radius: 5px;
    box-shadow: 1px 1px 0 #a3c3e2 inset, -1px -1px 0 #a3c3e2 inset, -1px 1px 0 #a3c3e2 inset, 1px -1px 0 #a3c3e2 inset;
    display: -webkit-flex;
    display:         flex;
    -webkit-flex-wrap: wrap;
            flex-wrap: wrap;
    font-size: 1.5rem;
    overflow: hidden;
}

.mod_listPnl > .list > li {
    float: left;
    border-right: 1px solid #a3c3e2;
    border-bottom: 1px solid #a3c3e2;
    width: 50%;
}

.mod_listPnl > .list > li > a {
    border-bottom: none;
    color: #1e398c;
    display: block;
    height: 100%;
    padding: 6px;
    text-align: center;
}

.mod_listBtn {
    margin-top: -15px;
    margin-bottom: 20px;
}

.mod_listBtn > li {
    margin-top: 15px;
}

.mod_listBtn._center {
    -webkit-justify-content: center;
            justify-content: center;
}

.mod_listBtn._right {
    -webkit-justify-content: flex-end;
            justify-content: flex-end;
}

.mod_listFacility {
    display: -webkit-flex;
    display:         flex;
    -webkit-flex-wrap: wrap;
            flex-wrap: wrap;
    font-size: 1.1rem;
    margin: -15px 0 0 -10px;
}

.mod_listFacility > li {
    margin: 15px 0 0 10px;
    padding: 9px 0 9px 60px;
    position: relative;
    width: 152px;
}

.mod_listFacility > li::before, .mod_listFacility > li::after {
    content: '';
    display: block;
    position: absolute;
}

.mod_listFacility > li::before {
    background-color: #fff;
    border-radius: 3px;
    height: 40px;
    top: 0;
    left: 0;
    width: 50px;
}

.mod_listFacility > li::after {
    top: 20px;
    left: 25px;
    -webkit-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
}

.mod_listFacility > li[aria-hidden=true]::before {
    background-color: rgba(255, 255, 255, .6);
}

.mod_listFacility > li[data-item]::after {
    background-image: url(/common/images/sprite.png);
}

.mod_listFacility > li[data-item='01']::after {
    background-position: -150px 0;
    height: 25px;
    width: 24px;
}

.mod_listFacility > li[data-item='01'][aria-hidden=true]::after {
    background-position: -150px -27px;
}

.mod_listFacility > li[data-item='02']::after {
    background-position: -81px -100px;
    height: 22px;
    width: 30px;
}

.mod_listFacility > li[data-item='02'][aria-hidden=true]::after {
    background-position: -113px -100px;
}

.mod_listFacility > li[data-item='03']::after {
    background-position: -54px -140px;
    height: 20px;
    width: 28px;
}

.mod_listFacility > li[data-item='03'][aria-hidden=true]::after {
    background-position: -84px -140px;
}

.mod_listFacility > li[data-item='04']::after {
    background-position: -114px -140px;
    height: 20px;
    width: 28px;
}

.mod_listFacility > li[data-item='04'][aria-hidden=true]::after {
    background-position: -144px -140px;
}

.mod_listFacility > li[data-item='05']::after {
    background-position: -176px -83px;
    height: 28px;
    width: 17px;
}

.mod_listFacility > li[data-item='05'][aria-hidden=true]::after {
    background-position: -176px -113px;
}

.mod_listFacility > li[data-item='06']::after {
    background-position: 0 -140px;
    height: 24px;
    width: 25px;
}

.mod_listFacility > li[data-item='06'][aria-hidden=true]::after {
    background-position: -27px -140px;
}

.mod_listFacility > li[data-item='07']::after {
    background-position: -176px -29px;
    height: 25px;
    width: 21px;
}

.mod_listFacility > li[data-item='07'][aria-hidden=true]::after {
    background-position: -176px -56px;
}

.mod_listFacility > li[data-item='08']::after {
    background-position: -199px -47px;
    height: 27px;
    width: 15px;
}

.mod_listFacility > li[data-item='08'][aria-hidden=true]::after {
    background-position: -199px -105px;
}

.mod_listFacility > li[data-item='09']::after {
    background-position: -150px -108px;
    height: 27px;
    width: 21px;
}

.mod_listFacility > li[data-item='09'][aria-hidden=true]::after {
    background-position: -176px 0;
}

.mod_listFacility > li[data-item='10']::after {
    background-position: 0 -166px;
    height: 16px;
    width: 33px;
}

.mod_listFacility > li[data-item='10'][aria-hidden=true]::after {
    background-position: -35px -166px;
}

.mod_listFacility > li[data-item='11']::after {
    background-position: -150px -54px;
    height: 25px;
    width: 23px;
}

.mod_listFacility > li[data-item='11'][aria-hidden=true]::after {
    background-position: -150px -81px;
}

.mod_listDl {
    margin-top: -10px;
}

.mod_listDl > div {
    margin-top: 10px;
}

.mod_listDl[data-col='2'] {
    display: -webkit-flex;
    display:         flex;
    -webkit-flex-wrap: wrap;
            flex-wrap: wrap;
    margin-left: -15px;
}

.mod_listDl[data-col='2'] > div {
    margin-left: 15px;
    width: calc((100% - 30px) / 2);
}

.mod_listDl._typeContact {
    text-align: center;
}

.mod_listDl._typeContact dd {
    font-weight: bold;
    font-size: 1.2rem;
}

.mod_listNews {
    border-top: 2px solid #1e398c;
    border-bottom: 2px solid #1e398c;
    padding: 15px 0;
    margin-bottom: 32px;
}

.mod_listNews > div + div {
    border-top: 1px dashed #ddd;
    margin-top: 10px;
    padding-top: 10px;
}

.mod_listNews > div > dt {
    font-weight: normal;
    -webkit-flex-shrink: 0;
            flex-shrink: 0;
}

.mod_listNews > div > dt > .badge {
    background-color: #f99aa8;
    border-radius: 50px;
    display: inline-block;
    margin-left: 10px;
    padding: 0 8px;
    line-height: 1.8;
}

.mod_listNews._simple {
    border: none;
    padding: 0;
}

.mod_listNews._simple > div + div {
    border: none;
    padding-top: 0;
}

.mod_listNews .new {
    margin-left: 6px;
    margin-bottom: 5px;
}

.mod_listNews02 {
    border-top: 2px solid #1e398c;
    border-bottom: 2px solid #1e398c;
    padding: 15px 0;
    margin-bottom: 32px;
}

.mod_listNews02 > li {
    display: -webkit-flex;
    display:         flex;
    padding: 16px;
    border-bottom: none;
}

.mod_listNews02 > li + li {
    border-top: 1px dashed #ddd;
    margin-top: 10px;
    padding-top: 26px;
}

.mod_listNews02 > li > a .linkIcon {
    -webkit-align-self: center;
            align-self: center;
}

.mod_listNews02 > li > .ico {
    -webkit-flex-shrink: 0;
            flex-shrink: 0;
    margin-right: 14px;
}

.mod_listNews02 > li > .txt {
    -webkit-flex-grow: 1;
            flex-grow: 1;
}

.mod_listNews02 > li > .txt > .sub {
    color: #666;
    display: block;
    font-size: 1.2rem;
}

.mod_listNews02 > li > .txt > .main > a {
    border-bottom: 1px solid #1e398c;
    color: #1e398c;
}

.mod_listNews02 .new {
    margin-left: 6px;
    margin-bottom: 5px;
}

.mod_listDl02 > div > dt, .mod_listDl02 > div > dd {
    display: block;
}

.mod_listDl02 > div > dt {
    font-weight: bold;
}

.mod_listDl02 > div > dd {
    font-size: 1.7rem;
}

.mod_listDl02 > div .subTxt {
    font-size: 1.4rem;
    margin-left: 30px;
}

.mod_listRank {
    margin-bottom: 32px;
}

.mod_listRank > .list {
    width: 100%;
    line-height: 1.375;
    font-weight: bold;
}

.mod_listRank > .list > li {
    display: -webkit-flex;
    display:         flex;
    border-bottom: 1px solid #969ea4;
    font-size: 1.5rem;
    padding: 7px 5px 7px 10px;
}

.mod_listRank > .list > li:last-child {
    border-bottom: none;
}

.mod_listRank > .list > li .rank {
    color: #1e398c;
    -webkit-flex: 0 0 68px;
            flex: 0 0 68px;
}

.mod_listRank > .list > li:first-child {
    padding: 4px 5px 5px 10px;
    font-size: 2rem;
}

.mod_listRank > .list > li.attention {
    background-color: #fff6ec;
    background-image: url(/common/images/icon_rank_01.png);
    background-repeat: no-repeat;
    background-position: right 6px center;
}

.mod_listRank > .list > li em {
    font-style: normal;
}

.mod_listRank .note {
    color: #303030;
    font-size: 1.4rem;
}

.mod_listCase > li {
    display: -webkit-flex;
    display:         flex;
    -webkit-align-items: center;
            align-items: center;
    border-radius: 10px;
    border: 1px solid #bfbfbf;
    background-color: #1e398c;
    margin-bottom: 10px;
}

.mod_listCase > li .clause {
    text-align: center;
    font-size: 1.5rem;
    font-weight: bold;
    border-radius: 9px 0 0 9px;
    color: #fff;
    height: 100%;
    -webkit-flex: 0 0 64px;
            flex: 0 0 64px;
}

.mod_listCase > li > dl {
    display: -webkit-flex;
    display:         flex;
    -webkit-flex-basis: 100%;
            flex-basis: 100%;
    -webkit-align-items: center;
            align-items: center;
    background-color: #fff;
    border-radius: 0 9px 9px 0;
    margin-bottom: 0;
    padding: 16px 0 12px 13px;
}

.mod_listCase > li > dl dt {
    display: -webkit-flex;
    display:         flex;
    -webkit-justify-content: center;
            justify-content: center;
    -webkit-align-items: center;
            align-items: center;
    background-color: #ff577c;
    color: #fff;
    font-size: 1.6rem;
    height: 33px;
    width: 33px;
    border-radius: 50%;
    padding-bottom: 2px;
    margin-right: 8px;
    -webkit-flex-shrink: 0;
            flex-shrink: 0;
}

.mod_listCase > li > dl dt._small {
    font-size: 1.3rem;
    padding-bottom: 0;
}

.mod_listCase > li > dl dd {
    margin-bottom: 0;
    line-height: 1.375;
}

.mod_listCase > li > dl dd:first-letter {
    color: #ff577c;
}

.mod_listCase02 .item {
    display: -webkit-flex;
    display:         flex;
    -webkit-align-items: center;
            align-items: center;
    border-radius: 10px;
    border: 1px solid #bfbfbf;
    background-color: #1e398c;
    margin-bottom: 10px;
}

.mod_listCase02 .item:last-child {
    margin-bottom: 0;
}

.mod_listCase02 .item dt {
    text-align: center;
    font-size: 1.7rem;
    font-weight: bold;
    border-radius: 9px 0 0 9px;
    line-height: 1.1;
    color: #fff;
    height: 100%;
    -webkit-flex: 0 0 70px;
            flex: 0 0 70px;
}

.mod_listCase02 .item dt .translation {
    display: block;
    font-size: 1rem;
}

.mod_listCase02 .item dd {
    -webkit-flex-basis: 100%;
            flex-basis: 100%;
    -webkit-align-items: center;
            align-items: center;
    background-color: #fff;
    border-radius: 0 9px 9px 0;
    margin-bottom: 0;
    padding: 12px 0 12px 17px;
}

.mod_listCase02 .item dd strong {
    color: #ff577c;
}

.mod_list_step {
    position: relative;
    display: -webkit-flex;
    display:         flex;
    margin-bottom: 30px;
    -webkit-justify-content: center;
            justify-content: center;
}

.mod_list_step > li {
    padding-top: 15px;
    margin-right: 64px;
    text-align: center;
    color: #aeaeae;
    font-size: 1.8rem;
    font-weight: bold;
    line-height: 1;
}

.mod_list_step > li::after {
    content: '';
    display: inline-block;
    position: absolute;
    top: 31px;
    margin-left: 12px;
    height: 3px;
    width: 37px;
    background-color: #d5d5d5;
}

.mod_list_step > li:last-child {
    margin-right: 0;
}

.mod_list_step > li:last-child::after {
    display: none;
}

.mod_list_step > li .num {
    display: block;
    font-size: 2rem;
    color: #fff;
    border-radius: 50%;
    margin: auto;
    padding-top: 6px;
    padding-right: 3px;
    background-color: #d5d5d5;
    -webkit-align-items: center;
            align-items: center;
    margin-bottom: 16px;
    font-style: italic;
    height: 32px;
    width: 32px;
}

.mod_list_step > li.current {
    padding-top: 0;
    color: #1e398c;
    font-size: 2.4rem;
}

.mod_list_step > li.current::after {
    margin-left: 20px;
}

.mod_list_step > li.current .num {
    width: 64px;
    height: 64px;
    background-color: transparent;
    background-image: url(/common/images/bg_step_02.png);
    margin-bottom: 3px;
    padding-top: 21px;
}

.mod_listOrder > li {
    display: -webkit-flex;
    display:         flex;
    -webkit-align-items: center;
            align-items: center;
    border-radius: 10px;
    background-color: #fff;
    padding: 10px;
    margin-bottom: 10px;
    color: #1e398c;
    line-height: 1.5;
    font-weight: bold;
    font-size: 1.6rem;
}

.mod_listOrder > li:last-child {
    margin-bottom: 0;
}

.mod_listOrder > li .num {
    display: -webkit-flex;
    display:         flex;
    position: relative;
    -webkit-flex: 0 0 32px;
            flex: 0 0 32px;
    margin-right: 12px;
    height: 32px;
    color: #fff;
    font-size: 1.2rem;
    background-color: #1e398c;
    border-radius: 3px;
    -webkit-justify-content: center;
            justify-content: center;
    -webkit-align-items: center;
            align-items: center;
}

.mod_listOrder > li .num::after {
    position: absolute;
    content: '';
    display: inline-block;
    top: 0;
    bottom: 0;
    right: -5px;
    margin: auto;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 4px 0 4px 5px;
    border-color: transparent transparent transparent #1e398c;
}

.mod_listBurette {
    margin-bottom: 20px;
}

.mod_listBurette > li {
    position: relative;
    padding-left: 14px;
}

.mod_listBurette > li::before {
    content: '';
    display: inline-block;
    position: absolute;
    top: 12px;
    left: 0;
    width: 5px;
    height: 5px;
    background-color: #a1dbf6;
    border-radius: 100%;
}

.mod_listCheck > li {
    position: relative;
    -webkit-flex-shrink: 0;
            flex-shrink: 0;
    border-radius: 10px;
    padding: 1px 10px 3px 46px;
    border: 2px solid #1e398c;
    margin-right: 20px;
    margin-bottom: 10px;
    background-color: #fff;
    font-weight: bold;
}

.mod_listCheck > li:last-child {
    margin-bottom: 0;
}

.mod_listCheck > li::before {
    background-image: url(/common/images/sprite.png);
    background-position: -94px -166px;
    width: 16px;
    height: 12px;
    content: '';
    display: block;
    margin-top: -6px;
    position: absolute;
    left: 16px;
    top: 50%;
}

.mod_listPanel {
    margin: -12px 0 4px 0;
}

.mod_listPanel > li {
    width: 100%;
    border-radius: 10px;
    border: 1px solid #bfbfbf;
    background-color: #fff;
    padding: 15px 16px 13px;
    margin-top: 13px;
    font-size: 1.6rem;
    font-weight: bold;
    color: #1e398c;
}

.mod_listPanel > li .title {
    display: -webkit-flex;
    display:         flex;
    -webkit-align-items: center;
            align-items: center;
}

.mod_listPanel > li .title .icon {
    margin-right: 12px;
}

.mod_listPanel > li._middle .title, .mod_listPanel > li._large .title {
    font-size: 2rem;
}

.mod_listPanel > li._middle .title .sub, .mod_listPanel > li._large .title .sub {
    font-size: 1.6rem;
}

.mod_listPanel > li._large {
    width: 100%;
}

.mod_listPanel > li._large .content {
    margin-top: 14px;
    border-top: 1px solid #bfbfbf;
    padding: 13px 10px 0;
}

.mod_listPanel > li._large .content .mod_listBurette > li {
    font-size: 1.6rem;
    color: #303030;
    font-weight: normal;
}

.mod_listVoice > li {
    display: -webkit-flex;
    display:         flex;
    -webkit-align-items: center;
            align-items: center;
    border-radius: 10px;
    border: 1px solid #bfbfbf;
    background-color: #fff;
    padding: 15px 16px 13px;
    margin-bottom: 13px;
    font-size: 1.6rem;
}

.mod_listVoice > li .icon {
    -webkit-flex-shrink: 0;
            flex-shrink: 0;
    margin-right: 20px;
}

.mod_listVoice > li .content {
    margin-top: -9px;
}

.mod_listVoice > li .tag {
    padding: 0 15px 2px;
    margin-bottom: 2px;
    border-radius: 20px;
    font-size: 1.2rem;
    background-color: #1e398c;
    line-height: 1;
    color: #fff;
}

.mod_listVoice > li .txt {
    margin-bottom: 0;
}

.mod_listOrder02 {
    margin-bottom: 20px;
}

.mod_listOrder02 > li {
    display: table;
    margin-bottom: 5px;
    line-height: 1.4;
}

.mod_listOrder02 > li .num {
    display: table-cell;
}

.mod_listOrder02 > li .txt {
    display: table-cell;
}

.mod_listRecruitarea {
    margin: 1.6rem 0;
}

.mod_listRecruitarea > dt, .mod_listRecruitarea > dd {
    padding: .4rem;
}

.mod_listRecruitarea > dt {
    border-top: 1px solid #999;
    border-bottom: 1px solid #999;
    font-weight: normal;
}

.mod_listRecruitarea > dd {
    border-bottom: 1px solid #999;
}

/* lay
============================== */
.mod_grid {
    margin-bottom: 30px;
}

.mod_grid._keepNarrow {
    display: -webkit-flex;
    display:         flex;
    -webkit-flex-wrap: wrap;
            flex-wrap: wrap;
    -webkit-justify-content: space-between;
            justify-content: space-between;
}

.mod_grid[data-col] {
    -webkit-justify-content: flex-start;
            justify-content: flex-start;
}

.mod_grid > .col > :last-child {
    margin-bottom: 0;
}

.mod_grid > .col + .col {
    margin-top: 30px;
}

.top_grid {
    -webkit-align-items: flex-end;
            align-items: flex-end;
    display: -webkit-flex;
    display:         flex;
    -webkit-flex-direction: column-reverse;
            flex-direction: column-reverse;
    -webkit-flex-wrap: wrap;
            flex-wrap: wrap;
    margin-top: -20px;
    margin-bottom: 36px;
}

.top_grid > .col {
    margin-top: 22px;
    width: 100%;
}

.mod_grid._keepNarrow {
    margin-left: -48px;
    margin-top: -48px;
}

.mod_grid._keepNarrow[data-col='2'] > .col {
    margin: 48px 0 0 48px;
    width: calc((100% - 96px) / 2);
}

.mod_grid._keepNarrow {
    margin-left: -48px;
    margin-top: -48px;
}

.mod_grid._keepNarrow[data-col='3'] > .col {
    margin: 48px 0 0 48px;
    width: calc((99.99% - 144px) / 3);
}

.mod_lytImg._keepNarrow {
    display: -webkit-flex;
    display:         flex;
    margin-left: -15px;
}

.mod_lytImg._keepNarrow > .img {
    -webkit-flex-shrink: 0;
            flex-shrink: 0;
    margin-left: 15px;
}

.mod_lytImg._keepNarrow > .txt {
    -webkit-flex-grow: 1;
            flex-grow: 1;
    margin-left: 15px;
}

.mod_box {
    background-color: #f1f6fb;
    border-radius: 6px;
    margin: 27px 0 48px;
    padding: 14px;
}

.mod_box > .hdg {
    border: 1px solid #1e398c;
    border-radius: 6px;
    background-color: #fff;
    color: #1e398c;
    display: table;
    font-size: 1.5rem;
    margin: -35px 0 20px;
    padding: 5px 20px;
    position: relative;
}

.mod_box > .hdg::after {
    background-image: url(/common/images/sprite.png);
    background-position: -124px -166px;
    width: 10px;
    height: 8px;
    content: '';
    display: block;
    position: absolute;
    bottom: -8px;
    left: 18px;
    z-index: 1;
}

.mod_box > .hdg._icon01 {
    padding-left: 45px;
}

.mod_box > .hdg._icon01::before {
    background-image: url(/common/images/sprite.png);
    background-position: -94px -166px;
    width: 16px;
    height: 12px;
    content: '';
    display: block;
    margin-top: -6px;
    position: absolute;
    left: 16px;
    top: 50%;
}

.mod_box > .hdg._type02 {
    border-color: #a3c3e2;
    border-radius: 50px;
    font-size: 1.5rem;
    letter-spacing: .05em;
    line-height: 1.2;
    margin: -35px auto 25px;
    padding: 3px 20px 3px 70px;
}

.mod_box > .hdg._type02::before {
    background-image: url(/common/images/sprite.png);
    background-position: -41px -100px;
    width: 38px;
    height: 38px;
    content: '';
    display: block;
    position: absolute;
    top: 50%;
    left: 4px;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
}

.mod_box > .hdg._type02::after {
    background-image: url(/common/images/sprite.png);
    background-position: -199px -158px;
    width: 20px;
    height: 16px;
    bottom: -15px;
    left: 50%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
}

.mod_box > .hdg._type02 em {
    font-size: 3.4rem;
    font-style: normal;
    font-weight: bold;
}

.mod_box > .hdg._type02 em + b {
    margin-top: .85em;
}

.mod_box > .hdg._type02 b {
    font-size: 1.6rem;
}

.mod_box > :last-child {
    margin-bottom: 0;
}

.mod_box > .mod_hdgL2:first-child {
    margin-top: 0;
}

.mod_box02 {
    background-image: linear-gradient(90deg, #87cfeb 10%, #fff47f 50%, #f27f8f 90%);
    margin-bottom: 35px;
    border-radius: 5px;
    padding: 2px;
}

.mod_box02 > .inner {
    background-color: #fff;
    background-image: url(/common/images/bg_box_01.png);
    background-repeat: no-repeat;
    background-position: left bottom;
    background-size: 100% auto;
    border-radius: 3px;
    padding: 15px 17px 40px;
}

.mod_box02 .img {
    margin-bottom: 21px;
}

.mod_box02 .img img {
    border-radius: 10px;
}

.mod_box02 .title {
    color: #003394;
    font-weight: bold;
    font-size: 2rem;
    margin-bottom: 10px;
    padding-bottom: 9px;
    line-height: 1.5;
    display: -webkit-flex;
    display:         flex;
    border-bottom: dashed 1px #003394;
}

.mod_box02 .title .icon {
    -webkit-flex-shrink: 0;
            flex-shrink: 0;
    margin-right: 15px;
}

.mod_box02 .txt {
    margin-bottom: 0;
    line-height: 1.5;
}

.mod_box03 {
    border-radius: 10px;
    background-color: #fff;
    padding: 10px 15px;
    margin-bottom: 30px;
}

.mod_box03 > *:last-child {
    margin-bottom: 0;
}

.mod_box04 {
    border-radius: 10px;
    background-color: #eaf0fa;
    padding: 30px 20px;
    margin-bottom: 30px;
}

.mod_box04 > *:last-child {
    margin-bottom: 0;
}

.mod_box05 {
    border-radius: 10px;
    background-color: #fff6ec;
    padding: 20px;
    margin-bottom: 30px;
}

.mod_box05 > *:last-child {
    margin-bottom: 0;
}

.mod_box06 {
    border-radius: 10px;
    background-color: #fff6ec;
    padding: 20px;
    margin-bottom: 30px;
}

.mod_box06 .inner {
    border-radius: 10px;
    background-color: #fff;
    padding: 20px;
    margin-bottom: 20px;
}

.mod_box06 .inner > *:last-child {
    margin-bottom: 0;
}

.mod_box06 .inner .title {
    font-weight: bold;
}

.mod_box06 .mod_hdgL4 {
    margin-bottom: 17px;
}

.mod_box06 > *:last-child {
    margin-bottom: 0;
}

.mod_boxContact {
    border: 1px dashed #a3c3e2;
    border-radius: 6px;
    margin-bottom: 20px;
    padding: 30px 20px 8px;
}

.mod_boxContact > .hdg {
    color: #1e398c;
    font-size: 1.4rem;
    font-weight: bold;
    margin: -15px 0 14px;
    text-align: center;
}

.mod_boxContact > .hdg::before, .mod_boxContact > .hdg::after {
    background-image: url(/common/images/hdg_icon_01.svg);
    background-repeat: no-repeat;
    background-size: contain;
    content: '';
    display: inline-block;
    height: 23px;
    margin-right: 13px;
    vertical-align: middle;
    width: 26px;
}

.mod_boxContact > .hdg::after {
    margin-right: 0;
    margin-left: 13px;
    -webkit-transform: rotateY(180deg);
            transform: rotateY(180deg);
}

.mod_boxContact > :last-child {
    margin-bottom: 0;
}

.mod_boxSearch {
    background-color: #f4f4f4;
    border-radius: 10px;
    margin-bottom: 20px;
    padding: 20px;
}

.mod_boxSearch label {
    display: block;
    font-weight: bold;
    margin-bottom: 11px;
}

.mod_boxSearch input, .mod_boxSearch select {
    background-color: #fff;
    border: 1px solid #ddd;
    border-radius: 5px;
    margin-bottom: 10px;
    width: 100%;
    margin-top: 13px;
}

.mod_boxSearch select {
    padding: 10px 40px 10px 20px;
}

.mod_boxSearch .boxSearchBtn {
    background-color: #1e398c;
    border: none;
    border-radius: 10px;
    color: #fff;
    display: block;
    font-weight: bold;
    padding: 3px;
    width: 100%;
    font-size: 2.1rem;
    cursor: pointer;
}

.mod_boxSearch .itemRadio label {
    position: relative;
    cursor: pointer;
}

.mod_boxSearch .itemRadio label span {
    display: block;
    padding: 9px 24px 8px 55px;
    background-color: #fff;
    border: solid 1px #ccc;
    border-radius: 5px;
}

.mod_boxSearch .itemRadio label span::before {
    content: '';
    display: block;
    position: absolute;
    top: 50%;
    left: 20px;
    width: 18px;
    height: 18px;
    margin-top: -9px;
    border: solid 1px #ccc;
    border-radius: 100%;
}

.mod_boxSearch .itemRadio label .txt {
    font-weight: normal;
}

.mod_boxSearch .itemRadio label input {
    position: absolute;
    top: 0;
    left: 0;
    opacity: 0;
}

.mod_boxSearch .itemRadio label input:checked + .txt::after {
    content: '';
    display: block;
    position: absolute;
    top: 50%;
    left: 25px;
    width: 8px;
    height: 8px;
    margin-top: -4px;
    background: #3748b3;
    border-radius: 100%;
}

.mod_boxSearch .itemRadio label input:focus + .txt {
    border: dotted 1px #666;
}

.mod_boxSearch02.topSearch {
    margin: 0 15px;
}

.mod_boxSearch02.topSearch > .contents > .colMain {
    -webkit-flex: 1 1 auto;
            flex: 1 1 auto;
    margin-bottom: 0;
}

.mod_boxSearch02.topSearch > .contents > .colSub {
    -webkit-flex-shrink: 0;
            flex-shrink: 0;
    margin: 20px 0 30px;
}

.mod_boxSearch02.topSearch .formList > div + div {
    margin-top: 12px;
}

.mod_boxSearch02.topSearch .formList > div > dd input:not([type=checkbox]), .mod_boxSearch02.topSearch .formList > div > dd input:not([type=radio]), .mod_boxSearch02.topSearch .formList > div > dd select {
    font-size: 1.6rem;
    padding: 8px 20px;
    width: 100%;
}

.mod_boxSearch02.topSearch .btnSubmit {
    background-color: #1e398c;
    border: none;
    border-radius: 10px;
    color: #fff;
    display: block;
    font-size: 2rem;
    text-align: center;
    letter-spacing: .1em;
    padding: 3px 40px;
    width: 100%;
    cursor: pointer;
}

.mod_boxNews {
    background-color: #fff;
    border-radius: 20px;
    padding: 10px 16px;
}

#google_map {
    height: 60vh;
    margin-bottom: 5px;
    width: 100%;
}

.mod_boxForm > .formList {
    padding: 0 16px;
}

.mod_boxForm > .formList input:not([type=checkbox]), .mod_boxForm > .formList input:not([type=radio]) {
    width: 100%;
}

.mod_boxForm > .formList select {
    width: 100%;
}

.mod_boxPnl {
    display: -webkit-flex;
    display:         flex;
    -webkit-flex-direction: column;
            flex-direction: column;
}

.mod_boxPnl > .hdg {
    border: 1px solid #1e398c;
    border-radius: 6px;
    background-color: #fff;
    margin: -35px auto 0;
    color: #1e398c;
    font-size: 1.5rem;
    font-weight: bold;
    -webkit-order: 2;
            order: 2;
    position: relative;
    text-align: center;
    padding: 8px;
    width: 80%;
}

.mod_boxPnl > .hdg::after {
    background-image: url(/common/images/sprite.png);
    background-position: -124px -166px;
    width: 10px;
    height: 8px;
    content: '';
    display: block;
    position: absolute;
    top: -8px;
    left: 50%;
    -webkit-transform: rotate(180deg) translateX(50%);
            transform: rotate(180deg) translateX(50%);
}

.mod_boxPnl > .img {
    display: block;
    -webkit-order: 1;
            order: 1;
    overflow: hidden;
    text-align: center;
}

.mod_boxPnl > .img > img {
    width: 100%;
    border-radius: 50%;
}

.mod_boxPnl > .contents {
    -webkit-order: 3;
            order: 3;
    width: 80%;
    margin: auto;
}

.mod_boxPnl > .contents > strong {
    display: inline-block;
    font-size: 1.6rem;
    line-height: 1.33333;
    margin-bottom: 12px;
}

.mod_boxAdobe, .mod_boxDownload {
    border: dashed 1px #a3c3e2;
    border-radius: 3px;
    padding: 12px 16px 9px;
    line-height: 1.6;
}

.mod_boxAdobe .img, .mod_boxDownload .img {
    margin-bottom: 10px;
}

.mod_boxDownload {
    margin-top: 60px;
}

.mod_boxStep {
    border: 1px solid #dedede;
    border-radius: 10px;
    margin-bottom: 20px;
}

.mod_boxStep .disciption {
    position: relative;
    background-color: #eaf0fa;
    border-radius: 9px;
    padding: 8px 16px 18px;
    margin-bottom: 30px;
}

.mod_boxStep .disciption:after {
    content: '';
    display: inline-block;
    position: absolute;
    left: 0;
    right: 0;
    margin: auto;
    bottom: -16px;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 16px 16px 0 16px;
    border-color: #eaf0fa transparent transparent transparent;
}

.mod_boxStep .disciption > .guide > .hdg {
    font-size: 2rem;
    border-bottom: 1px solid #1e398c;
    color: #1e398c;
    padding-bottom: 3px;
    margin-bottom: 6px;
}

.mod_boxStep .disciption > .guide > .txt {
    font-size: 1.5rem;
    color: #303030;
    margin-bottom: 0;
}

.mod_boxStep .disciption > .guide > .img {
    margin-top: 12px;
    text-align: center;
}

.mod_boxStep .disciption > .guide > .img a {
    border: none;
}

.mod_boxStep .disciption > .inner {
    background-color: #fff;
    border-radius: 10px;
    padding: 20px;
    margin-top: 30px;
    line-height: 1.46667;
}

.mod_boxStep .disciption > .inner > .hdg {
    display: -webkit-flex;
    display:         flex;
    font-size: 1.5rem;
    color: #1e398c;
    border-bottom: 1px solid #d2d2d2;
    padding-bottom: 12px;
    margin-bottom: 10px;
}

.mod_boxStep .disciption > .inner > .hdg .icon {
    margin-right: 14px;
    -webkit-flex-shrink: 0;
            flex-shrink: 0;
}

.mod_boxStep .disciption > .inner .content > .txt {
    font-size: 1.5rem;
    color: #303030;
}

.mod_boxStep .detail {
    padding: 0 16px 13px;
}

.mod_boxStep .detail > .hdg {
    color: #1e398c;
    font-size: 2rem;
    border-bottom: 1px solid #1e398c;
    margin-bottom: 12px;
    padding-bottom: 5px;
}

.mod_boxStep .detail .list > li {
    position: relative;
    display: -webkit-flex;
    display:         flex;
    margin-bottom: 7px;
}

.mod_boxStep .detail .list > li::before {
    content: '';
    display: block;
    position: absolute;
    left: 26px;
    top: 14px;
    height: calc(100% - 20px);
    width: 4px;
    background-color: #1e398c;
    z-index: 1;
}

.mod_boxStep .detail .list > li::after {
    background-image: url(/common/images/sprite.png);
    background-position: -199px -24px;
    width: 20px;
    height: 21px;
    content: '';
    display: block;
    position: absolute;
    bottom: -5px;
    left: 18px;
}

.mod_boxStep .detail .list > li > .num {
    background-image: url(/common/images/bg_step_01_sp.png);
    background-repeat: no-repeat;
    width: 55px;
    height: 55px;
    padding-top: 14px;
    margin-right: 15px;
    margin-top: 8px;
    -webkit-flex-shrink: 0;
            flex-shrink: 0;
    font-size: 1rem;
    font-style: italic;
    text-align: center;
    line-height: 1;
    z-index: 2;
    color: #fff;
}

.mod_boxStep .detail .list > li > .num._inline {
    padding-top: 18px;
}

.mod_boxStep .detail .list > li > .num._inline b {
    display: inline;
}

.mod_boxStep .detail .list > li > .num b {
    display: block;
    font-size: 1.6rem;
    margin-right: 2px;
}

.mod_boxStep .detail .list > li .txt {
    margin-bottom: 3px;
    line-height: 1.46667;
    font-weight: bold;
}

.mod_boxStep .detail .list > li .content {
    -webkit-flex-basis: 100%;
            flex-basis: 100%;
    border-bottom: 1px solid #959595;
    padding-bottom: 15px;
}

.mod_boxStep .detail .list > li .content > .box {
    width: 100%;
    border-radius: 10px;
    background-color: #eee;
    margin-top: 12px;
    padding: 20px;
    line-height: 1.5;
}

.mod_boxStep .detail .list > li .content > .box > p {
    margin-bottom: 0;
}

.mod_boxStep .detail .list > li .content > .box *:last-child {
    margin-bottom: 0;
}

.mod_boxStep .detail .list > li .content._layout {
    display: -webkit-flex;
    display:         flex;
    -webkit-flex-wrap: wrap;
            flex-wrap: wrap;
}

.mod_boxStep .detail .list > li .content._layout .txtArea {
    -webkit-order: 2;
            order: 2;
    -webkit-flex: 1 1 100%;
            flex: 1 1 100%;
    margin-top: 0;
}

.mod_boxStep .detail .list > li .content._layout .img {
    text-align: center;
    -webkit-order: 1;
            order: 1;
    -webkit-flex: 1 2 100%;
            flex: 1 2 100%;
    margin-bottom: 20px;
}

.mod_boxStep .detail .list > li:last-child::before, .mod_boxStep .detail .list > li:last-child::after {
    display: none;
}

.mod_boxStep .detail .list > li:last-child .content {
    border-bottom: none;
    padding-bottom: 0;
}

.mod_boxStep .detail:first-child {
    padding-top: 8px;
}

.mod_boxStep._type02 {
    border: none;
    background-color: #eaf0fa;
}

.mod_boxStep._type02 .detail .list > li .content .title {
    display: inline-block;
    width: 100%;
    font-weight: bold;
    font-size: 1.6rem;
    text-align: center;
    color: #fff;
    padding: 2px 10px 4px;
    margin-bottom: 15px;
    border-radius: 30px;
    background-color: #1e398c;
    background-color: #1e398c;
}

.mod_boxStep._type02 .detail .list > li .content .title._type02 {
    background-color: #019be5;
}

.mod_boxStep._type02 .detail .list > li .content .title._type03 {
    background-color: #ff577c;
}

.mod_boxStep._type02 .detail .list > li .content > .box {
    background-color: #fff;
}

.mod_boxStep._type02 .detail .list > li .content .img img {
    border-radius: 10px;
}

.mod_boxStep._type03 {
    border: none;
}

.mod_boxStep._type03 .detail {
    padding: 0;
}

.mod_boxStep._type03 .detail .list > li .num {
    padding-top: 18px;
}

.mod_boxStep._type03 .detail .list > li .num b {
    display: inline-block;
}

.mod_boxStep._type03 .detail .list > li > .txt {
    font-size: 1.8rem;
    color: #1e398c;
}

.mod_boxStep._type03 .detail .list > li .content .title {
    color: #1e398c;
    font-weight: bold;
    font-size: 1.8rem;
}

.mod_boxStep._type03 .detail .list > li .content > .box {
    padding: 20px;
}

.mod_boxStep._type03 .detail .list > li .content > .box *:last-child {
    margin-bottom: 0;
}

.mod_boxStep._type03 .detail .list > li .content .openTime {
    display: -webkit-flex;
    display:         flex;
    -webkit-align-items: center;
            align-items: center;
    -webkit-justify-content: space-around;
            justify-content: space-around;
    -webkit-align-self: stretch;
            align-self: stretch;
    font-weight: bold;
    background-color: #fff;
    border-radius: 6px;
    color: #1e398c;
    margin-bottom: 20px;
}

.mod_boxStep._type03 .detail .list > li .content .openTime > p {
    padding: 15px;
    margin-bottom: 0;
    width: 100%;
    text-align: center;
}

.mod_boxStep._type03 .detail .list > li .content .openTime > p + p {
    position: relative;
}

.mod_boxStep._type03 .detail .list > li .content .openTime > p + p::before {
    content: '';
    display: inline-block;
    position: absolute;
    top: 0;
    left: -40px;
    bottom: 0;
    margin: auto;
    height: 30px;
    width: 30px;
    border-right: 2px solid #eee;
    border-bottom: 2px solid #eee;
    -webkit-transform: rotate(-45deg) skew(-20deg, -20deg);
            transform: rotate(-45deg) skew(-20deg, -20deg);
}

.mod_boxStep._type03 .detail .list > li .content .work {
    -webkit-flex-basis: 347px;
            flex-basis: 347px;
    margin-bottom: 20px;
}

.mod_boxStep._type03 .detail .list > li .content .work .title {
    font-weight: bold;
    font-size: 1.6rem;
    text-align: center;
    color: #fff;
    padding: 2px 10px 4px;
    border-radius: 30px;
    background-color: #1e398c;
    background-color: #1e398c;
}

.mod_boxStep._type03 .detail .list > li .content .work .title._type02 {
    background-color: #019be5;
}

.mod_boxStep._type03 .detail .list > li .content .work .title._type03 {
    background-color: #ff577c;
}

.mod_boxStep._type03 .detail .list > li .content .work .txtList > li {
    position: relative;
    padding-left: 12px;
    margin-bottom: 5px;
}

.mod_boxStep._type03 .detail .list > li .content .work .txtList > li::before {
    content: '';
    display: inline-block;
    position: absolute;
    top: 10px;
    left: 0;
    width: 4px;
    height: 4px;
    background-color: #333;
    border-radius: 100%;
}

.mod_boxStep._type03 .detail .list > li .content .work .txt {
    text-align: center;
    font-weight: normal;
}

.mod_boxStep._type03 .detail .list > li .content .work .txt + .title {
    margin-top: 20px;
}

.mod_boxStep._type03 .detail .list > li .content .img {
    display: inline-block;
    -webkit-flex-shrink: 0;
            flex-shrink: 0;
}

.mod_boxStep._type03 .detail .list > li .content .img img {
    border-radius: 20px;
}

.mod_boxStep .mod_listCheck {
    margin-top: 10px;
}

.mod_boxCase {
    border: 2px solid #1e398c;
    background-color: #fff;
    border-radius: 10px;
    padding: 16px 16px 15px;
}

.mod_boxCase .hdg {
    display: -webkit-flex;
    display:         flex;
    -webkit-align-items: center;
            align-items: center;
    margin-bottom: 16px;
    line-height: 1;
}

.mod_boxCase .hdg .num {
    display: -webkit-flex;
    display:         flex;
    position: relative;
    -webkit-flex: 0 0 32px;
            flex: 0 0 32px;
    margin-right: 12px;
    height: 32px;
    color: #fff;
    font-size: 1.2rem;
    background-color: #1e398c;
    border-radius: 3px;
    -webkit-justify-content: center;
            justify-content: center;
    -webkit-align-items: center;
            align-items: center;
}

.mod_boxCase .hdg .num::after {
    position: absolute;
    content: '';
    display: inline-block;
    top: 0;
    bottom: 0;
    right: -5px;
    margin: auto;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 4px 0 4px 5px;
    border-color: transparent transparent transparent #1e398c;
}

.mod_boxCase .hdg .sub {
    display: block;
    color: #666;
    font-size: 1.1rem;
    line-height: 1.2;
}

.mod_boxCase .hdg .ttl {
    color: #1e398c;
    font-weight: bold;
    font-size: 1.5rem;
    line-height: 1.2;
}

.mod_boxContact02 {
    border: 2px solid #dedede;
    border-radius: 5px;
    background-color: #fff;
    padding: 2px 13px 8px;
    margin-bottom: 15px;
}

.mod_boxContact02 .hdg {
    font-size: 2.3rem;
    color: #ff577c;
    border-bottom: 1px solid #bfbfbf;
    margin-bottom: 5px;
    padding-bottom: 4px;
    font-weight: bold;
    text-align: center;
}

.mod_boxContact02 .hdg::before {
    background-image: url(/common/images/sprite.png);
    background-position: -199px -134px;
    width: 15px;
    height: 22px;
    content: '';
    display: inline-block;
    margin-right: 10px;
    margin-bottom: -2px;
}

.mod_boxContact02 .content {
    padding-top: 7px;
}

.mod_boxContact02 .content + .content {
    border-top: 1px solid #969ea4;
    margin-top: 13px;
}

.mod_boxContact02 .tel {
    display: -webkit-flex;
    display:         flex;
    -webkit-flex-wrap: wrap;
            flex-wrap: wrap;
    margin-bottom: 5px;
}

.mod_boxContact02 .tel dt {
    font-size: 1.5rem;
    margin-right: 20px;
}

.mod_boxContact02 .tel dd {
    margin-bottom: 0;
}

.mod_boxContact02 .tel dd::before {
    background-image: url(/common/images/sprite.png);
    background-position: -81px -124px;
    width: 25px;
    height: 13px;
    content: '';
    display: inline-block;
    margin-right: 10px;
}

.mod_boxContact02 .tel dd .telLink {
    display: inline-block;
    background-color: #1e398c;
    border-radius: 15px;
    color: #fff;
    font-weight: bold;
    font-size: 1.6rem;
    line-height: 1.1;
    padding: 5px 20px 4px;
    text-align: center;
    min-width: 110px;
}

.mod_boxContact02 .tel dd .telLink a {
    color: inherit;
}

.mod_boxContact02 .txt {
    font-size: 1.5rem;
    margin-bottom: 0;
    line-height: 1.46667;
}

.mod_boxPrivacy {
    height: 457px;
    padding: 20px 15px;
    margin-bottom: 20px;
    overflow-y: auto;
    border: 2px solid #ddd;
    border-radius: 5px;
    line-height: 1.5;
}

.mod_boxPrivacy .hdg {
    margin-bottom: 15px;
    text-align: center;
    font-size: 1.6rem;
    font-weight: bold;
}

.mod_boxPrivacy .hdg02 {
    font-weight: normal;
}

.mod_boxMessage {
    margin-bottom: 24px;
    text-align: center;
}

.mod_boxMessage img {
    width: auto;
    max-width: 100%;
    margin-bottom: 20px;
    border-radius: 10px;
}

.mod_boxMessage .lead {
    line-height: 1.25;
    font-size: 2rem;
    font-weight: bold;
}

.mod_boxMessage .name {
    text-align: right;
    font-size: 2rem;
}

.mod_boxMessage .name .sub {
    display: inline-block;
    margin-right: 19px;
    font-size: 1.6rem;
}

.mod_tbl {
    margin-bottom: 20px;
}

.mod_tbl > table {
    display: block;
    width: 100%;
    border-collapse: collapse;
    line-height: 1.5;
}

.mod_tbl > table p {
    margin-bottom: 0;
}

.mod_tbl > table tbody {
    border-bottom: 1px solid #ddd;
}

.mod_tbl > table tbody tr th, .mod_tbl > table tbody tr td {
    display: block;
    padding: 16px;
}

.mod_tbl > table tbody tr th > :last-child, .mod_tbl > table tbody tr td > :last-child {
    margin-bottom: 0;
}

.mod_tbl > table tbody tr th {
    background-color: #fef6ec;
    border-top: 1px solid #ddd;
    vertical-align: top;
    white-space: nowrap;
    font-weight: normal;
}

.mod_tbl > table tbody tr th .withTag {
    display: -webkit-flex;
    display:         flex;
    -webkit-align-items: flex-start;
            align-items: flex-start;
    -webkit-justify-content: space-between;
            justify-content: space-between;
    white-space: normal;
}

.mod_tbl > table tbody tr th .withTag .tag {
    -webkit-flex-shrink: 0;
            flex-shrink: 0;
    padding: 1px 7px 2px;
    margin-top: 5px;
    margin-left: 10px;
    background-color: #d24255;
    border-radius: 4px;
    color: #fff;
}

.mod_tbl + .mod_listBtn {
    margin-top: 0;
}

.mod_tbl02 {
    width: 100%;
    margin-top: 20px;
    margin-bottom: 60px;
    overflow-x: auto;
}

.mod_tbl02._scroll th, .mod_tbl02._scroll td {
    white-space: nowrap;
}

.mod_tbl02 table {
    width: 100%;
    border-collapse: collapse;
}

.mod_tbl02 table th, .mod_tbl02 table td {
    padding: 13px 20px 12px;
    border: 1px solid #ddd;
    font-size: 1.6rem;
}

.mod_tbl02 table th *:last-child, .mod_tbl02 table td *:last-child {
    margin-bottom: 0;
}

.mod_tbl02 table th {
    font-weight: normal;
}

.mod_tbl02 table thead th {
    padding: 13px 10px 12px;
    background-color: #fef6ec;
    text-align: center;
    font-size: 1.5rem;
}

.mod_tbl02 table tbody th {
    background-color: #fef6ec;
    text-align: left;
}

.mod_tbl02 table thead + tbody th {
    background-color: #f4f4f4;
}

.mod_tbl02 table .tblMark {
    display: block;
    margin: 0 auto;
}

p:not([class]) + .mod_tbl02 {
    margin-top: 20px;
}

.mod_tbl02 .location::before {
    background-image: url(/common/images/sprite.png);
    background-position: -176px -143px;
    width: 16px;
    height: 20px;
    content: '';
    display: inline-block;
    margin: 0 7px -2px 41px;
}

.mod_tbl03 {
    margin-bottom: 20px;
    overflow-x: auto;
}

.mod_tbl03 > table {
    width: 100%;
    border: 1px solid #c7b47c;
}

.mod_tbl03 > table thead th {
    padding: 7px 6px 6px;
    background-color: #c7b47c;
    text-align: center;
    font-size: 2rem;
    color: #fff;
}

.mod_tbl03 > table tbody td {
    padding: 8px 3px 9px;
    border: 1px solid #c7b47c;
    text-align: center;
    white-space: nowrap;
    font-size: 1.5rem;
    color: #303030;
}

.mod_tbl04 {
    margin-bottom: 20px;
}

.mod_tbl04 > table {
    width: 100%;
    border: 1px solid #a7a7a7;
    border-bottom: none;
}

.mod_tbl04 > table thead th {
    padding: 7px 6px 6px;
    background-color: #a7a7a7;
    text-align: center;
    font-size: 2rem;
    color: #fff;
}

.mod_tbl04 > table tbody th {
    font-size: 1.8rem;
    font-weight: bold;
}

.mod_tbl04 > table tbody th, .mod_tbl04 > table tbody td {
    display: block;
    padding: 7px 16px 8px;
    border-right: 1px solid #a7a7a7;
    color: #303030;
}

.mod_tbl04 > table tbody th {
    background-image: linear-gradient(to right, transparent 10px, #a7a7a7 11px, #a7a7a7 50%, transparent 50%, transparent 100%), linear-gradient(to left, transparent 10px, #a7a7a7 11px, #a7a7a7 50%, transparent 50%, transparent 100%);
    background-repeat: no-repeat;
    background-position: left bottom;
    background-size: 100% 1px;
    font-size: 1.8rem;
}

.mod_tbl04 > table tbody td {
    border-bottom: 1px solid #a7a7a7;
    font-size: 1.5rem;
}

.mod_hdgL4 + [class*='mod_tbl'] {
    margin-top: 40px;
}

.mod_tbl05 {
    margin-bottom: 20px;
}

.mod_tbl05 > table {
    width: 100%;
    border: 0 none;
    border-bottom: none;
}

.mod_tbl05 > table tbody th {
    font-size: 1.6rem;
    font-weight: bold;
}

.mod_tbl05 > table tbody th, .mod_tbl05 > table tbody td {
    display: block;
    padding: 7px 6px 8px;
    border-right: 0 none;
    color: #303030;
}

.mod_tbl05 > table tbody th {
    background-repeat: no-repeat;
    background-position: left bottom;
    background-size: 100% 1px;
    font-size: 1.6rem;
    vertical-align: top;
}

.mod_tbl05 > table tbody td {
    border-bottom: 0 none;
    font-size: 1.5rem;
}

.mod_tbl05 > table tbody tr:last-of-type th, .mod_tbl05 > table tbody tr:last-of-type td {
    border-bottom: 0 none;
}

img.corner {
    border-radius: 0 !important;
}

.mod_img {
    margin-bottom: 90px;
}

.mod_img img {
    border-radius: 20px;
    width: 100%;
}

.mod_img .caption {
    font-size: 1.2rem;
}

.mod_grid .mod_img {
    margin-bottom: 0;
}

.mod_img._border img {
    border: 1px solid #cdcdcd;
}

.mod_img._youtube {
    position: relative;
    width: 100%;
    padding-top: 56.25%;
}

.mod_img._youtube iframe {
    border: none;
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    right: 0;
}

.mod_img._fix {
    text-align: center;
}

.mod_img._fix img {
    width: auto;
}

.mod_img_layout {
    margin-bottom: 30px;
}

.mod_img_layout .content p {
    margin-bottom: 0;
}

.mod_img_layout .img {
    -webkit-flex-shrink: 0;
            flex-shrink: 0;
    margin-top: 10px;
    margin-left: 0;
    text-align: center;
}

.mod_img_layout .img .caption {
    display: block;
    font-size: 1.2rem;
}

.mod_img_layout .note {
    display: block;
    font-size: 1.2rem;
}

.mod_img_layout._reverse .content {
    -webkit-order: 2;
            order: 2;
}

.mod_img_layout._reverse .img {
    -webkit-order: 1;
            order: 1;
    margin: 10px 0 0 0;
}

.accessMap {
    border: none;
    width: 100%;
    min-height: 400px;
}

.mod_formGrp > .item {
    display: -webkit-flex;
    display:         flex;
    -webkit-align-items: center;
            align-items: center;
    margin-right: -10px;
}

.mod_formGrp > .item + .mod_btn03 {
    margin-top: 15px;
}

.mod_formGrp > .item._birthday label {
    width: 33.33333%;
}

.mod_formGrp label + label {
    margin-left: 10px;
}

.mod_formGrp input._error, .mod_formGrp select._error, .mod_formGrp textarea._error {
    background-color: #ffe5e9;
}

.mod_formGrp input {
    margin: 0 10px 5px 10px;
}

.mod_formGrp input._name, .mod_formGrp input._address, .mod_formGrp input._mail {
    width: 100%;
}

.mod_formGrp input._address, .mod_formGrp input._mail, .mod_formGrp input._other {
    width: 100%;
    margin-left: 0;
}

.mod_formGrp input._poscode {
    width: 35%;
}

.mod_formGrp input._phonenum {
    width: 28%;
}

.mod_formGrp input._year, .mod_formGrp input._month, .mod_formGrp input._day {
    width: calc(100% - 1em - 10px);
}

.mod_formGrp input._phonenum, .mod_formGrp input._year, .mod_formGrp input._month, .mod_formGrp input._day {
    padding: 10px;
    margin-bottom: 5px;
}

.mod_formGrp input._phonenum:first-child, .mod_formGrp input._year:first-child, .mod_formGrp input._month:first-child, .mod_formGrp input._day:first-child {
    margin-left: 0;
}

.mod_formGrp select {
    width: 100%;
    padding: 8px 20px;
    line-height: 2;
    font-size: 1.6rem;
}

.mod_formGrp textarea {
    width: 100%;
    max-width: 100%;
    min-height: 160px;
}

.mod_formGrp .errTxt {
    margin-bottom: 0;
    font-size: 1.4rem;
    color: #d24255;
}

.mod_formGrp .note {
    display: block;
}

.mod_formGrp + .mod_formGrp {
    margin-top: 20px;
}

.mod_formGrp .itemRadio label {
    position: relative;
    cursor: pointer;
}

.mod_formGrp .itemRadio label:first-child {
    margin-left: 0;
}

.mod_formGrp .itemRadio label span {
    display: block;
    padding: 9px 24px 8px 55px;
    background-color: #fff;
    border: solid 1px #ccc;
    border-radius: 5px;
}

.mod_formGrp .itemRadio label span::before {
    content: '';
    display: block;
    position: absolute;
    top: 50%;
    left: 20px;
    width: 18px;
    height: 18px;
    margin-top: -9px;
    background-color: #fff;
    border: solid 1px #ccc;
    border-radius: 100%;
}

.mod_formGrp .itemRadio label .txt {
    font-weight: normal;
}

.mod_formGrp .itemRadio label input[type='radio'] {
    position: absolute;
    top: 0;
    left: 0;
    opacity: 0;
}

.mod_formGrp .itemRadio label input[type='radio']:checked + .txt::after {
    content: '';
    display: block;
    position: absolute;
    top: 50%;
    left: 25px;
    width: 8px;
    height: 8px;
    margin-top: -4px;
    background: #3748b3;
    border-radius: 100%;
}

.mod_formGrp .itemRadio label input[type='radio']:focus + .txt {
    border: dotted 1px #666;
}

.mod_formGrp .itemRadio label input[type='radio']._error + .txt {
    background-color: #ffe5e9;
}

.mod_cmpPrivacy {
    -webkit-align-items: center;
            align-items: center;
    display: -webkit-flex;
    display:         flex;
    margin: 0 auto -36px;
    max-width: 760px;
}

.mod_cmpPrivacy > .img {
    -webkit-flex-shrink: 0;
            flex-shrink: 0;
}

.mod_cmpPrivacy > .txt {
    font-size: 1.4rem;
    -webkit-flex-grow: 1;
            flex-grow: 1;
    line-height: 1.71429;
    margin-left: 30px;
}

.mod_cmpPrivacy > .txt > :last-child {
    margin-bottom: 0;
}

.mod_jsTab > .tabList ul {
    margin-bottom: 26px;
    display: -webkit-flex;
    display:         flex;
    -webkit-justify-content: space-between;
            justify-content: space-between;
}

.mod_jsTab > .tabList ul > li {
    -webkit-flex: 1 1 50%;
            flex: 1 1 50%;
    margin-right: 10px;
}

.mod_jsTab > .tabList ul > li:last-child {
    margin-right: 0;
}

.mod_jsTab > .tabList ul > li a {
    background-color: #fff;
    border: 2px solid #ccc;
    color: #909090;
    border-radius: 20px;
    display: block;
    font-size: 1.6rem;
    padding: 0 12px;
    text-align: center;
    transition: background-color .3s, border-color .3s, color .3s;
}

.mod_jsTab > .tabList ul > li a[aria-selected=true] {
    background-color: #1e398c;
    border-color: #1e398c;
    color: #fff;
}

.mod_jsTab > .tabContents {
    overflow: hidden;
    transition: height .3s;
}

.mod_jsTab > .tabContents > .tabItem[aria-hidden=true] {
    display: none;
}

.js_tab > .tabContents {
    overflow: hidden;
    transition: height .3s;
}

.js_tab > .tabContents > .tabItem[aria-hidden=true] {
    display: none;
}

.mod_listQa > li {
    margin-bottom: 40px;
}

.mod_listQa > li > a {
    display: block;
    border: solid 2px #ccc;
    border-radius: 10px;
    background-color: #fff;
    text-align: center;
    color: #ccc;
    width: 100%;
    padding: 7px 5px 11px;
    margin: auto;
}

.mod_listQa > li > a[aria-selected='true'] {
    border-color: #1e398c;
    background-color: #1e398c;
    color: #fff;
    position: relative;
}

.mod_listQa > li > a[aria-selected='true']::before, .mod_listQa > li > a[aria-selected='true']::after {
    content: '';
    display: inline-block;
    position: absolute;
    left: 0;
    right: 0;
    width: 6px;
    height: 6px;
    margin: auto;
    border-radius: 50%;
    background-color: #1e398c;
}

.mod_listQa > li > a[aria-selected='true']::before {
    bottom: -10px;
}

.mod_listQa > li > a[aria-selected='true']::after {
    bottom: -20px;
}

.mod_boxQa {
    margin-bottom: 40px;
}

.mod_boxQa .question {
    position: relative;
    border: 2px solid #1e398c;
    border-radius: 10px;
    background-color: #fff;
    margin: 0 15px 6px;
}

.mod_boxQa .question::before, .mod_boxQa .question::after {
    position: absolute;
}

.mod_boxQa .question::before {
    content: '';
    display: inline-block;
    left: 17px;
    bottom: -9px;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 9px 6px 0 6px;
    border-color: #1e398c transparent transparent transparent;
}

.mod_boxQa .question::after {
    content: '';
    display: inline-block;
    left: 19px;
    bottom: -6px;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 7px 4px 0 4px;
    border-color: #fff transparent transparent transparent;
}

.mod_boxQa .question .btn {
    border: none;
    display: block;
    width: 100%;
    text-align: left;
    padding: 3px 50px 5px 12px;
    background-color: transparent;
    color: #1e398c;
    font-weight: bold;
}

.mod_boxQa .question .btn .state {
    display: inline-block;
    position: absolute;
    top: 0;
    bottom: 0;
    margin: auto;
    right: 10px;
    height: 20px;
    width: 20px;
    border: 2px solid #1e398c;
    border-radius: 50%;
    text-indent: 100%;
    white-space: nowrap;
    overflow: hidden;
}

.mod_boxQa .question .btn .state::before, .mod_boxQa .question .btn .state::after {
    content: '';
    display: inline-block;
    position: absolute;
    top: 0;
    bottom: 0;
    margin: auto;
    right: 4px;
    height: 2px;
    width: 8px;
    background-color: #1e398c;
}

.mod_boxQa .question .btn .state::after {
    -webkit-transform: rotate(90deg);
            transform: rotate(90deg);
}

.noJs .mod_boxQa .question .btn .state {
    display: none;
}

.mod_boxQa .question .btn[data-state='open'] .state::after {
    -webkit-transform: rotate(0);
            transform: rotate(0);
}

.mod_boxQa .answer {
    border-radius: 10px;
    background-color: #f0f6fb;
    padding: 50px 20px 10px;
    margin-top: -42px;
}

.mod_boxQa .answer .title {
    color: #1e398c;
    font-weight: bold;
    margin-bottom: 14px;
}

.mod_boxQa .answer .content {
    line-height: 1.6;
    font-size: 1.5rem;
}

.mod_boxQa .answer[aria-hidden='true'] {
    display: none;
}

.areaMap #areaMapImg {
    display: none;
}

.js_selectContnts select {
    border: solid 1px #1e398c;
    width: 100%;
    margin-bottom: 23px;
    border-radius: 3px;
    font-size: 1.6rem;
    padding: 7px 34px 9px 14px;
}

.js_selectContnts [aria-hidden='true'] {
    display: none;
}

.js_tgl .js_tglTarget[aria-hidden='true'] {
    display: none;
}

/* Slider */
.slick-slider {
    position: relative;
    display: block;
    box-sizing: border-box;
    -webkit-touch-callout: none;
    -webkit-user-select: none;
       -moz-user-select: none;
        -ms-user-select: none;
            user-select: none;
    touch-action: pan-y;
    -webkit-tap-highlight-color: transparent;
}

.slick-list {
    position: relative;
    overflow: hidden;
    display: block;
    margin: 0;
    padding: 0;
}

.slick-slider .slick-track, .slick-slider .slick-list {
    -webkit-transform: translate3d(0, 0, 0);
            transform: translate3d(0, 0, 0);
}

.slick-track {
    position: relative;
    left: 0;
    top: 0;
    display: block;
    margin-left: auto;
    margin-right: auto;
}

.slick-track:before, .slick-track:after {
    content: '';
    display: table;
}

.slick-track:after {
    clear: both;
}

.slick-loading .slick-track {
    visibility: hidden;
}

.slick-slide {
    float: left;
    height: 100%;
    min-height: 1px;
    display: none;
}

[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;
}

.mod_jsSlide, .mod_jsBanner {
    display: -webkit-flex;
    display:         flex;
    -webkit-flex-wrap: wrap;
            flex-wrap: wrap;
    -webkit-justify-content: center;
            justify-content: center;
    margin-bottom: 12px;
}

.mod_jsSlide._narrow, .mod_jsBanner._narrow {
    margin: 0 auto 18px;
    max-width: 470px;
}

.mod_jsSlide._narrow .slick-list, .mod_jsBanner._narrow .slick-list {
    width: calc(100% - 70px);
    max-width: 400px;
}

.mod_jsSlide .slick-list, .mod_jsBanner .slick-list {
    border-radius: 8px;
    line-height: 1;
    overflow: hidden;
}

.mod_jsSlide .slideItem img, .mod_jsBanner .slideItem img {
    display: block;
}

.mod_jsSlide .slick-arrow, .mod_jsBanner .slick-arrow {
    background-color: transparent;
    border: none;
    display: block;
    -webkit-flex-shrink: 0;
            flex-shrink: 0;
    overflow: hidden;
    padding: 0 0 0 35px;
    position: relative;
    white-space: nowrap;
    width: 35px;
}

.mod_jsSlide .slick-arrow::before, .mod_jsSlide .slick-arrow::after, .mod_jsBanner .slick-arrow::before, .mod_jsBanner .slick-arrow::after {
    background-color: #d6d6d6;
    border-radius: 5px;
    content: '';
    display: block;
    height: 2px;
    position: absolute;
    -webkit-transform: rotate(45deg);
            transform: rotate(45deg);
    width: 20px;
}

.mod_jsSlide .slick-arrow::after, .mod_jsBanner .slick-arrow::after {
    -webkit-transform: rotate(-45deg);
            transform: rotate(-45deg);
}

.mod_jsSlide .slick-prev::before, .mod_jsBanner .slick-prev::before {
    top: 50%;
    left: 5px;
}

.mod_jsSlide .slick-prev::after, .mod_jsBanner .slick-prev::after {
    top: calc(50% - 13px);
    left: 5px;
}

.mod_jsSlide .slick-next::before, .mod_jsBanner .slick-next::before {
    top: calc(50% - 13px);
    right: 5px;
}

.mod_jsSlide .slick-next::after, .mod_jsBanner .slick-next::after {
    top: 50%;
    right: 5px;
}

.mod_jsSlide .slick-dots, .mod_jsBanner .slick-dots {
    display: -webkit-flex;
    display:         flex;
    -webkit-justify-content: center;
            justify-content: center;
    margin-top: 0;
    margin-left: -12px;
}

.mod_jsSlide .slick-dots > li, .mod_jsBanner .slick-dots > li {
    margin-top: 12px;
    margin-left: 12px;
}

.mod_jsSlide .slick-dots > li > button, .mod_jsBanner .slick-dots > li > button {
    background-color: #d6d6d6;
    border: none;
    border-radius: 50%;
    color: transparent;
    display: block;
    height: 8px;
    overflow: hidden;
    padding: 0;
    position: relative;
    transition: background-color .3s, -webkit-transform .3s;
    transition: background-color .3s, transform .3s;
    transition: background-color .3s, transform .3s, -webkit-transform .3s;
    width: 8px;
}

.mod_jsSlide .slick-dots > li.slick-active > button, .mod_jsBanner .slick-dots > li.slick-active > button {
    -webkit-animation: slideActive 1s both;
            animation: slideActive 1s both;
    background-color: #ffe900;
}

@-webkit-keyframes slideActive {
    0% {
        -webkit-transform: scale(1) translateY(0);
                transform: scale(1) translateY(0);
    }
    50% {
        -webkit-transform: scale(1.625) translateY(-5px);
                transform: scale(1.625) translateY(-5px);
    }
    100% {
        -webkit-transform: scale(1.625) translateY(0);
                transform: scale(1.625) translateY(0);
    }
}

@keyframes slideActive {
    0% {
        -webkit-transform: scale(1) translateY(0);
                transform: scale(1) translateY(0);
    }
    50% {
        -webkit-transform: scale(1.625) translateY(-5px);
                transform: scale(1.625) translateY(-5px);
    }
    100% {
        -webkit-transform: scale(1.625) translateY(0);
                transform: scale(1.625) translateY(0);
    }
}

.mod_jsBanner {
    margin: 0 auto 28px;
    max-width: 310px;
}

.mod_jsBanner .slick-list {
    border-radius: 0;
    width: calc(100% - 70px);
    max-width: 240px;
}

.mod_carousel {
    padding: 50px 0;
    position: relative;
}

.mod_carousel::before {
    border: 5px solid #ffee0d;
    border-radius: 50%;
    content: '';
    display: block;
    height: calc(100vw - 30px);
    position: absolute;
    top: 50px;
    left: 50%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
    width: calc(100vw - 30px);
}

.mod_carousel .slideItem {
    background-color: rgba(0, 0, 0, .5);
    border-radius: 50%;
    color: #fff;
    display: -webkit-flex;
    display:         flex;
    line-height: 1.66667;
    height: calc(100vw - 40px);
    overflow: hidden;
    padding: 10vw 15vw 13vw;
    width: calc(100vw - 40px);
}

.mod_carousel .slideItem > .hdg {
    font-size: 2rem;
    line-height: 1.8;
    text-align: center;
    position: relative;
    z-index: 1;
}

.mod_carousel .slideItem > .hdg em {
    font-style: normal;
    font-weight: bold;
}

.mod_carousel .slideItem > .contents {
    font-size: 1.5rem;
    overflow-y: auto;
    position: relative;
    z-index: 1;
}

.mod_carousel .slideItem > .contents::-webkit-scrollbar {
    width: 8px;
}

.mod_carousel .slideItem > .contents::-webkit-scrollbar-thumb {
    background-color: rgba(0, 0, 0, .3);
    border-radius: 4px;
}

.mod_carousel .slideItem > .contents > :last-child {
    margin-bottom: 0;
}

.mod_carousel .slideItem > .contents > .btnArea {
    margin-top: 15px;
    text-align: center;
}

.mod_carousel .slideItem > .carouselBg {
    display: none;
}

.mod_carousel .slick-list {
    margin-top: 5px;
}

.mod_carousel .slick-slide {
    width: calc(100vw - 40px);
}

.mod_carousel .slick-slide .slideItem {
    display: -webkit-flex !important;
    display:         flex !important;
    -webkit-flex-direction: column;
            flex-direction: column;
    -webkit-justify-content: center;
            justify-content: center;
    transition: -webkit-transform .3s;
    transition:         transform .3s;
    transition:         transform .3s, -webkit-transform .3s;
    -webkit-transform: scale(.5);
            transform: scale(.5);
}

.mod_carousel .slick-slide .slideItem > .hdg {
    font-size: 3.2rem;
    transition: font-size .3s;
}

.mod_carousel .slick-slide .slideItem > .contents {
    height: 0;
    opacity: 0;
    overflow: hidden;
    transition: height .3s, opacity .3s;
}

.mod_carousel .item-next .slideItem, .mod_carousel .slick-center .slideItem {
    -webkit-justify-content: flex-start;
            justify-content: flex-start;
    -webkit-transform: scale(1);
            transform: scale(1);
}

.mod_carousel .item-next .slideItem > .hdg, .mod_carousel .slick-center .slideItem > .hdg {
    font-size: 2rem;
}

.mod_carousel .item-next .slideItem > .contents, .mod_carousel .slick-center .slideItem > .contents {
    height: 100%;
    opacity: 1;
    overflow-y: auto;
}

.mod_carousel .item-next .slideItem > .carouselBg, .mod_carousel .slick-center .slideItem > .carouselBg {
    opacity: 0;
}

.mod_carousel .slick-arrow {
    background-color: transparent;
    border: none;
    color: transparent;
    overflow: hidden;
    height: 40px;
    position: absolute;
    top: 54vw;
    white-space: nowrap;
    width: 40px;
    z-index: 2;
}

.mod_carousel .slick-arrow::before {
    border-top: 1px solid #ffee0d;
    border-right: 1px solid #ffee0d;
    content: '';
    display: block;
    height: 18px;
    position: absolute;
    top: 11px;
    -webkit-transform: rotate(45deg);
            transform: rotate(45deg);
    width: 18px;
}

.mod_carousel .slick-prev {
    left: 20px;
}

.mod_carousel .slick-prev::before {
    left: 20px;
    -webkit-transform: rotate(-135deg);
            transform: rotate(-135deg);
}

.mod_carousel .slick-next {
    right: 20px;
}

.mod_carousel .slick-next::before {
    right: 20px;
}

.mod_carousel .slick-dots {
    display: -webkit-flex;
    display:         flex;
    -webkit-justify-content: center;
            justify-content: center;
    margin-top: 30px;
    margin-left: -27px;
}

.mod_carousel .slick-dots > li {
    margin-left: 27px;
}

.mod_carousel .slick-dots > li > button {
    border: 3px solid #747474;
    border-radius: 50%;
    background-color: #747474;
    color: transparent;
    display: block;
    height: 16px;
    overflow: hidden;
    padding: 0;
    transition: background-color .3s, border-color .3s;
    white-space: nowrap;
    width: 16px;
}

@-webkit-keyframes carouselActive {
    0% {
        -webkit-transform: translateY(0);
                transform: translateY(0);
    }
    50% {
        box-shadow: 0 0 3px #1e398c;
        -webkit-transform: translateY(-8px);
                transform: translateY(-8px);
    }
    100% {
        -webkit-transform: translateY(0);
                transform: translateY(0);
    }
}

@keyframes carouselActive {
    0% {
        -webkit-transform: translateY(0);
                transform: translateY(0);
    }
    50% {
        box-shadow: 0 0 3px #1e398c;
        -webkit-transform: translateY(-8px);
                transform: translateY(-8px);
    }
    100% {
        -webkit-transform: translateY(0);
                transform: translateY(0);
    }
}

.mod_carousel .slick-dots > li.slick-active > button {
    -webkit-animation: carouselActive 1s both;
            animation: carouselActive 1s both;
    border-color: #1e398c;
    background-color: #ffee0d;
}

.mod_carousel > [class*='itemBg'] {
    background-size: cover;
    background-position: center;
    height: 100%;
    opacity: 0;
    position: absolute;
    top: 0;
    left: 0;
    transition: opacity .3s;
    width: 100%;
    z-index: -1;
}

.mod_carousel > [class*='itemBg']._show {
    opacity: 1;
}

/* text
============================== */
.txtLeft {
    text-align: left !important;
}

.txtCenter {
    text-align: center !important;
}

.txtRight {
    text-align: right !important;
}

.mt-00 {
    margin-top: 0;
}

.mb-00 {
    margin-bottom: 0;
}

.mt-05 {
    margin-top: 3px;
}

.mb-05 {
    margin-bottom: 3px;
}

.mt-10 {
    margin-top: 6px;
}

.mb-10 {
    margin-bottom: 6px;
}

.mt-15 {
    margin-top: 9px;
}

.mb-15 {
    margin-bottom: 9px;
}

.mt-20 {
    margin-top: 12px;
}

.mb-20 {
    margin-bottom: 12px;
}

.mt-25 {
    margin-top: 15px;
}

.mb-25 {
    margin-bottom: 15px;
}

.mt-30 {
    margin-top: 18px;
}

.mb-30 {
    margin-bottom: 18px;
}

.mt-35 {
    margin-top: 21px;
}

.mb-35 {
    margin-bottom: 21px;
}

.mt-40 {
    margin-top: 24px;
}

.mb-40 {
    margin-bottom: 24px;
}

.mt-45 {
    margin-top: 27px;
}

.mb-45 {
    margin-bottom: 27px;
}

.mt-50 {
    margin-top: 30px;
}

.mb-50 {
    margin-bottom: 30px;
}

.mt-55 {
    margin-top: 33px;
}

.mb-55 {
    margin-bottom: 33px;
}

.mt-60 {
    margin-top: 36px;
}

.mb-60 {
    margin-bottom: 36px;
}

.mt-65 {
    margin-top: 39px;
}

.mb-65 {
    margin-bottom: 39px;
}

.mt-70 {
    margin-top: 42px;
}

.mb-70 {
    margin-bottom: 42px;
}

.mt-75 {
    margin-top: 45px;
}

.mb-75 {
    margin-bottom: 45px;
}

.mt-80 {
    margin-top: 48px;
}

.mb-80 {
    margin-bottom: 48px;
}

.mt-85 {
    margin-top: 51px;
}

.mb-85 {
    margin-bottom: 51px;
}

.mt-90 {
    margin-top: 54px;
}

.mb-90 {
    margin-bottom: 54px;
}

.mt-95 {
    margin-top: 57px;
}

.mb-95 {
    margin-bottom: 57px;
}

.mt-100 {
    margin-top: 60px;
}

.mb-100 {
    margin-bottom: 60px;
}

.w_5 {
    width: 5% !important;
}

.w_6 {
    width: 6% !important;
}

.w_7 {
    width: 7% !important;
}

.w_8 {
    width: 8% !important;
}

.w_9 {
    width: 9% !important;
}

.w_10 {
    width: 10% !important;
}

.w_11 {
    width: 11% !important;
}

.w_12 {
    width: 12% !important;
}

.w_13 {
    width: 13% !important;
}

.w_14 {
    width: 14% !important;
}

.w_15 {
    width: 15% !important;
}

.w_16 {
    width: 16% !important;
}

.w_17 {
    width: 17% !important;
}

.w_18 {
    width: 18% !important;
}

.w_19 {
    width: 19% !important;
}

.w_20 {
    width: 20% !important;
}

.w_21 {
    width: 21% !important;
}

.w_22 {
    width: 22% !important;
}

.w_23 {
    width: 23% !important;
}

.w_24 {
    width: 24% !important;
}

.w_25 {
    width: 25% !important;
}

.w_26 {
    width: 26% !important;
}

.w_27 {
    width: 27% !important;
}

.w_28 {
    width: 28% !important;
}

.w_29 {
    width: 29% !important;
}

.w_30 {
    width: 30% !important;
}

.w_31 {
    width: 31% !important;
}

.w_32 {
    width: 32% !important;
}

.w_33 {
    width: 33% !important;
}

.w_34 {
    width: 34% !important;
}

.w_35 {
    width: 35% !important;
}

.w_36 {
    width: 36% !important;
}

.w_37 {
    width: 37% !important;
}

.w_38 {
    width: 38% !important;
}

.w_39 {
    width: 39% !important;
}

.w_40 {
    width: 40% !important;
}

.w_41 {
    width: 41% !important;
}

.w_42 {
    width: 42% !important;
}

.w_43 {
    width: 43% !important;
}

.w_44 {
    width: 44% !important;
}

.w_45 {
    width: 45% !important;
}

.w_46 {
    width: 46% !important;
}

.w_47 {
    width: 47% !important;
}

.w_48 {
    width: 48% !important;
}

.w_49 {
    width: 49% !important;
}

.w_50 {
    width: 50% !important;
}

.w_51 {
    width: 51% !important;
}

.w_52 {
    width: 52% !important;
}

.w_53 {
    width: 53% !important;
}

.w_54 {
    width: 54% !important;
}

.w_55 {
    width: 55% !important;
}

.w_56 {
    width: 56% !important;
}

.w_57 {
    width: 57% !important;
}

.w_58 {
    width: 58% !important;
}

.w_59 {
    width: 59% !important;
}

.w_60 {
    width: 60% !important;
}

.w_61 {
    width: 61% !important;
}

.w_62 {
    width: 62% !important;
}

.w_63 {
    width: 63% !important;
}

.w_64 {
    width: 64% !important;
}

.w_65 {
    width: 65% !important;
}

.w_66 {
    width: 66% !important;
}

.w_67 {
    width: 67% !important;
}

.w_68 {
    width: 68% !important;
}

.w_69 {
    width: 69% !important;
}

.w_70 {
    width: 70% !important;
}

.w_71 {
    width: 71% !important;
}

.w_72 {
    width: 72% !important;
}

.w_73 {
    width: 73% !important;
}

.w_74 {
    width: 74% !important;
}

.w_75 {
    width: 75% !important;
}

.w_76 {
    width: 76% !important;
}

.w_77 {
    width: 77% !important;
}

.w_78 {
    width: 78% !important;
}

.w_79 {
    width: 79% !important;
}

.w_80 {
    width: 80% !important;
}

.w_81 {
    width: 81% !important;
}

.w_82 {
    width: 82% !important;
}

.w_83 {
    width: 83% !important;
}

.w_84 {
    width: 84% !important;
}

.w_85 {
    width: 85% !important;
}

.w_86 {
    width: 86% !important;
}

.w_87 {
    width: 87% !important;
}

.w_88 {
    width: 88% !important;
}

.w_89 {
    width: 89% !important;
}

.w_90 {
    width: 90% !important;
}

.w_91 {
    width: 91% !important;
}

.w_92 {
    width: 92% !important;
}

.w_93 {
    width: 93% !important;
}

.w_94 {
    width: 94% !important;
}

.w_95 {
    width: 95% !important;
}

.w_96 {
    width: 96% !important;
}

.w_97 {
    width: 97% !important;
}

.w_98 {
    width: 98% !important;
}

.w_99 {
    width: 99% !important;
}

.w_100 {
    width: 100% !important;
}

@media screen and (min-width: 771px) {
    body {
        font-size: 1.6rem;
        line-height: 1.75;
    }
    input:not([type=checkbox]), input:not([type=radio]) {
        padding: 7px 20px;
    }
    .str_header > .inner {
        width: 1310px;
        max-width: 100%;
    }
    .str_header {
        border-bottom-width: 3px;
    }
    .str_header .headerLyt {
        -webkit-flex-wrap: nowrap;
                flex-wrap: nowrap;
        position: relative;
        width: 100%;
        -webkit-align-items: flex-start;
                align-items: flex-start;
        -webkit-justify-content: space-between;
                justify-content: space-between;
    }
    .str_header .headerLyt > .areaNav {
        display: -webkit-flex;
        display:         flex;
        width: auto;
    }
    .str_header .headerLyt > .areaNav::after {
        display: none;
    }
    .str_header .headerLyt > .areaNav > .inner {
        background-color: transparent;
    }
    .str_header .headerLyt > .areaNav > .inner {
        -webkit-align-items: flex-start;
                align-items: flex-start;
        display: -webkit-flex;
        display:         flex;
        -webkit-justify-content: flex-end;
                justify-content: flex-end;
        -webkit-flex-wrap: wrap;
                flex-wrap: wrap;
        padding: 10px 0 0 0;
    }
    .str_header .headerLyt > #areaNav {
        overflow: unset;
    }
    .str_header .headerLyt > #areaNav[aria-hidden] {
        position: static;
    }
    .str_header .headerLyt > #areaNav[aria-hidden=false] {
        overflow-y: unset;
    }
    .str_header .headerLogo {
        padding-top: 0;
        margin-bottom: 40px;
        width: 140px;
    }
    .str_header .headerLogo > a {
        background-color: #1e398c;
        border-radius: 0 0 5px 5px;
        display: inline-block;
        padding: 24px 0 32px;
        text-align: center;
        width: 100%;
    }
    .str_header .headerNavSub {
        display: none;
    }
    .str_header .headerSearch {
        background-color: transparent;
        -webkit-order: 2;
                order: 2;
        padding: 0;
        width: 180px;
        font-size: 1.6rem;
    }
    .str_header .headerSearch > .searchBtn {
        background-size: 15px;
        background-position: 6px;
        right: 5px;
        height: 28px;
        width: 28px;
    }
    .str_header .headerSearch > .searchBtn::before {
        right: 5px;
        height: 28px;
        width: 28px;
    }
    .str_header .headerNavBtn {
        display: none;
    }
    .str_header .headerNav {
        background-color: transparent;
        border-radius: 0;
        -webkit-order: 3;
                order: 3;
        margin-top: 22px;
        overflow: unset;
        width: 100%;
    }
    .str_header .headerNav > ul {
        background-color: transparent;
        display: -webkit-flex;
        display:         flex;
        -webkit-justify-content: flex-end;
                justify-content: flex-end;
        -webkit-flex-wrap: wrap;
                flex-wrap: wrap;
        padding: 0;
        margin-right: -6px;
    }
    .noJs .str_header .headerNav > ul {
        display: block;
    }
    .str_header .headerNav > ul > li {
        background-color: transparent;
        border: none;
    }
    .str_header .headerNav > ul > li a, .str_header .headerNav > ul > li button, .str_header .headerNav > ul > li .navHook {
        font-size: 1.2rem;
    }
    .str_header .headerNav > ul > li > a, .str_header .headerNav > ul > li > button, .str_header .headerNav > ul > li > .navHook {
        padding: 8px 6px 50px 8px;
        white-space: nowrap;
    }
    .str_header .headerNav > ul > li > a::before, .str_header .headerNav > ul > li > a::after {
        display: none;
    }
    .str_header .headerNav > ul > li > button > .mark {
        background-image: url(/common/images/icon_arrow_02.svg);
        background-color: transparent;
        border-radius: 0;
        height: 7px;
        padding-left: 10px;
        top: auto;
        top: 41px;
        left: 50%;
        -webkit-transform: translateX(-50%);
                transform: translateX(-50%);
        width: 10px;
    }
    .str_header .headerNav > ul > li > button > .mark::before, .str_header .headerNav > ul > li > button > .mark::after {
        display: none;
    }
    .str_header .headerNav > ul > li > button[data-state=open]::before, .str_header .headerNav > ul > li > button[data-state=open]::after {
        content: '';
        display: block;
        height: 0;
        position: absolute;
        left: 50%;
        bottom: 52px;
        -webkit-transform: translate(-50%, 52px);
                transform: translate(-50%, 52px);
        width: 0;
        z-index: 101;
    }
    .str_header .headerNav > ul > li > button[data-state=open]::before {
        border: 11px solid transparent;
        border-top-width: 0;
        border-bottom: 17px solid rgba(0, 0, 0, .15);
        margin-top: 40px;
    }
    .str_header .headerNav > ul > li > button[data-state=open]::after {
        border: 10px solid transparent;
        border-top-width: 0;
        border-bottom: 16px solid #fff;
    }
    .str_header .headerNav > ul > li > button[data-state=open] > .arrow::after {
        border: 10px solid transparent;
        border-bottom: 16px solid rgba(204, 204, 204, .9);
        content: '';
        margin-left: -10px;
        position: absolute;
        bottom: -50px;
        left: 50%;
        z-index: 101;
    }
    .str_header .headerNav > ul > li > button[data-state=open] > .mark {
        -webkit-transform: rotate(-180deg) translateX(50%);
                transform: rotate(-180deg) translateX(50%);
    }
    .str_header .headerNav > ul > li + li {
        margin-top: 0;
    }
    .str_header .headerNav > ul > li + li > a, .str_header .headerNav > ul > li + li > button {
        background-image: linear-gradient(#333, #333);
        background-size: 2px 12px;
        background-position: left 15px;
        background-repeat: no-repeat;
    }
    .str_header .headerNav > ul > li .areaNavChild {
        background-color: rgba(255, 255, 255, .95);
        border-radius: 6px;
        box-shadow: 0 0 15px rgba(0, 0, 0, .25);
        width: 100%;
        max-width: 1280px;
    }
    .str_header .headerNav > ul > li .areaNavChild[aria-hidden] {
        position: absolute;
        right: 0;
        left: 0;
        width: 100%;
        max-width: 1280px;
        z-index: 100;
    }
    .str_header .headerNav > ul > li .areaNavChild > .inner {
        padding: 0 20px;
    }
    .str_header .headerNav > ul > li .areaNavChild .navItemLyt {
        -webkit-align-items: flex-start;
                align-items: flex-start;
        display: -webkit-flex;
        display:         flex;
        -webkit-justify-content: space-between;
                justify-content: space-between;
        padding: 15px 0;
    }
    .str_header .headerNav > ul > li .areaNavChild .navItemLyt > .itemHigh {
        border-top: none;
        -webkit-flex-shrink: 0;
                flex-shrink: 0;
    }
    .str_header .headerNav > ul > li .areaNavChild .navItemLyt > .itemHigh > a::after {
        display: none;
    }
    .str_header .headerNav > ul > li .areaNavChild .navItemLyt > .itemHigh > a > .img {
        border-radius: 10px;
        display: block;
        overflow: hidden;
    }
    .str_header .headerNav > ul > li .areaNavChild .navItemLyt > .itemHigh > a > .txt {
        color: #1e398c;
        display: inline-block;
        font-size: 1.8rem;
        margin-top: 15px;
        padding-bottom: 3px;
        padding-left: 36px;
        position: relative;
    }
    .str_header .headerNav > ul > li .areaNavChild .navItemLyt > .itemHigh > a > .txt::before {
        content: url(/common/images/icon_arrow_03.svg);
        margin-top: -12px;
        position: absolute;
        top: 50%;
        left: 0;
    }
    .str_header .headerNav > ul > li .areaNavChild .navItemLyt > .itemHigh > a > .txt::after {
        border-bottom: 1px solid #1e398c;
        content: '';
        display: block;
        position: absolute;
        left: 36px;
        bottom: 0;
        right: 0;
    }
    .str_header .headerNav > ul > li .areaNavChild .navSubItem {
        display: block;
    }
    .str_header .headerNav > ul > li .areaNavChild .navSubItem > ul > li > a:hover, .str_header .headerNav > ul > li .areaNavChild .navSubItem > ul > li > a:focus {
        border-color: #019be5;
        opacity: 1;
    }
    .str_header .headerNav > ul > li .navChild {
        display: -webkit-flex;
        display:         flex;
        -webkit-flex-wrap: wrap;
                flex-wrap: wrap;
        margin: -9px 0 0 21px;
        width: 100%;
    }
    .str_header .headerNav > ul > li .navChild > li {
        border: 2px solid #dbdbdb;
        border-radius: 6px;
        margin: 9px 0 0 9px;
        width: calc((100% - 18px) / 2);
    }
    .str_header .headerNav > ul > li .navChild > li {
        width: calc((99.999% - 27px) / 3);
    }
    .str_header .headerNav > ul > li .navChild > li > a::after {
        border-width: 2px;
        right: 12px;
    }
    .str_header .headerBtn {
        -webkit-align-items: flex-start;
                align-items: flex-start;
        display: -webkit-flex;
        display:         flex;
        -webkit-flex-wrap: wrap;
                flex-wrap: wrap;
        margin-top: 0;
        margin-bottom: 20px;
    }
    .str_header .headerLinkList {
        display: -webkit-flex;
        display:         flex;
    }
    .str_header .headerLinkList > li + li {
        margin-top: 0;
        margin-left: 10px;
    }
    .str_header .headerLinkList > li > a {
        font-size: 1rem;
        padding: 4px 30px 4px 17px;
        text-align: center;
    }
    .str_header .headerLinkList02 {
        margin: 5px 10px;
    }
    .str_header .headerLinkList02 > li + li {
        margin-left: 20px;
    }
    .str_header .headerLinkList02 > li > a {
        border-bottom: 1px solid #1e398c;
        color: #1e398c;
        font-size: 1rem;
        font-weight: bold;
        padding: 0;
    }
    .str_header .navCloseBtn {
        display: none;
    }
    .str_main {
        border-top: 3px solid #96c4e4;
    }
    [class*='str_container'] > .inner {
        padding: 44px 15px 75px;
    }
    .str_container02 > .inner {
        padding: 44px 15px 50px;
    }
    .str_container03 > .inner {
        padding: 44px 15px 50px;
    }
    .str_container04 > .inner {
        padding: 44px 15px 50px;
    }
    .str_containerVideo {
        padding-top: 8%;
    }
    .str_containerTop::after {
        top: auto;
        bottom: 0;
    }
    .str_containerTop::before {
        display: none;
    }
    .str_containerTop .topSearch > .head .hdg {
        margin-right: 10px;
        font-size: 2.6rem;
        padding-left: 55px;
    }
    .contentsHead {
        padding-top: 250px;
        margin-bottom: 15px;
    }
    .contentsHead::before {
        height: 283px;
    }
    .contentsHead .content {
        border-radius: 20px;
        padding-top: 80px;
    }
    .contentsHead._recruit .content {
        background-position: 46px 51px;
        background-size: 226px auto;
    }
    .contentsHead .mod_hdgL2 {
        margin-left: 61px;
        margin-right: 61px;
        margin-bottom: 28px;
    }
    .contentsHead .hdg {
        margin-left: 61px;
        margin-bottom: 28px;
        font-size: 3rem;
    }
    .contentsHead .lead {
        font-size: 2rem;
        margin-left: 58px;
        margin-right: 58px;
    }
    .contentsHead .txt {
        margin-left: 58px;
        margin-right: 58px;
    }
    .sub_container {
        border-radius: 10px;
        padding: 38px 30px 60px;
    }
    .sub_container > [class^='mod_']:last-child {
        margin-bottom: 0;
    }
    .sectionContainer {
        padding: 28px 30px 24px;
    }
    [class^='sectionContainer_'] {
        padding: 20px 30px 24px;
    }
    [class^='sectionContainer_'] .mod_hdgL4 {
        margin-bottom: 30px;
    }
    .mod_grid [class^='sectionContainer_'] {
        display: -webkit-flex;
        display:         flex;
        -webkit-flex-direction: column;
                flex-direction: column;
        -webkit-flex-grow: 1;
                flex-grow: 1;
    }
    .flowContainer {
        margin-bottom: 80px;
    }
    .flowContainer > .content {
        padding: 0 52px 60px;
        margin-bottom: 60px;
    }
    .flowContainer > .content .mod_hdg04 {
        padding-bottom: 45px;
        margin: 34px -52px 75px;
    }
    .flowContainer .flow01 > .hdg, .flowContainer .flow01 > .col > .hdg {
        text-align: center;
    }
    .flowContainer .flow01 .flowList {
        padding-top: 40px;
    }
    .flowContainer .flow01 .flowList::before {
        left: 0;
        right: 0;
        height: calc(100% - 55px);
    }
    .flowContainer .flow01 .flowList::after {
        left: 0;
        bottom: 0;
        right: 0;
    }
    .flowContainer .flow01 .flowList > li {
        float: left;
        clear: both;
        width: 40%;
        padding: 12px 17px 2px;
        margin-left: 0;
    }
    .flowContainer .flow01 .flowList > li::before {
        left: auto;
        right: -25%;
        width: 25%;
    }
    .flowContainer .flow01 .flowList > li::after {
        left: auto;
        right: calc(-25% - 13px);
    }
    .flowContainer .flow01 .flowList > li:nth-child(even) {
        margin-top: 47px;
        float: right;
        clear: none;
    }
    .flowContainer .flow01 .flowList > li:nth-child(even)::before {
        left: -25%;
    }
    .flowContainer .flow01 .flowList > li:nth-child(even)::after {
        left: calc(-25% - 12px);
    }
    .flowContainer .flow01._branch {
        display: -webkit-flex;
        display:         flex;
    }
    .flowContainer .flow01._branch .col {
        margin-bottom: 0;
        margin-right: 40px;
        padding: 26px 48px;
        display: -webkit-flex;
        display:         flex;
        -webkit-flex-direction: column;
                flex-direction: column;
        -webkit-flex-basis: calc(50% - 20px);
                flex-basis: calc(50% - 20px);
    }
    .flowContainer .flow01._branch .col:last-child {
        margin-right: 0;
    }
    .flowContainer .flow01._branch .col._withSub {
        -webkit-justify-content: space-between;
                justify-content: space-between;
    }
    .flowContainer .flow01._branch .col._withSub > .hdg {
        display: -webkit-flex;
        display:         flex;
        -webkit-justify-content: center;
                justify-content: center;
        -webkit-align-items: flex-start;
                align-items: flex-start;
        -webkit-flex: 1 1 auto;
                flex: 1 1 auto;
    }
    .flowContainer .flow01._branch .col._withSub > .hdg::before {
        top: 45px;
    }
    .flowContainer .flow01._branch .col .hdg02 {
        margin-right: 0;
    }
    .flowContainer .flow01._branch .flowList {
        display: block;
    }
    .flowContainer .flow01._branch .flowList > li {
        width: 100%;
        float: none;
    }
    .flowContainer .flow02 .itemWrap {
        margin-bottom: 40px;
        padding-left: 60px;
    }
    .flowContainer .flow02 .itemWrap::after {
        left: 8px;
        height: calc(100% + 42px);
    }
    .flowContainer .flow02 .itemWrap:first-child::before {
        top: -42px;
        left: 8px;
        height: 42px;
    }
    .flowContainer .flow02 .itemWrap:last-child::before {
        bottom: -42px;
        left: 8px;
        height: 42px;
    }
    .flowContainer .flow02 .itemWrap:first-child:last-child::before {
        top: -42px;
        left: 8px;
        height: calc(100% + 84px);
    }
    .flowContainer .flow02 .itemWrap > .item {
        display: -webkit-flex;
        display:         flex;
    }
    .flowContainer .flow02 .itemWrap > .item::before {
        left: -47px;
        width: 47px;
    }
    .flowContainer .flow02 .itemWrap > .item::after {
        left: -60px;
    }
    .flowContainer .flow02 .itemWrap > .item .img {
        -webkit-order: 1;
                order: 1;
        -webkit-flex-shrink: 0;
                flex-shrink: 0;
        margin-right: 40px;
    }
    .flowContainer .flow02 .itemWrap > .item .img img {
        width: auto;
        border-radius: 20px;
        margin-bottom: 0;
    }
    .flowContainer .flow02 .itemWrap > .item .content {
        -webkit-order: 2;
                order: 2;
    }
    .flowContainer .flow02 .itemWrap > .item .content .tag {
        margin-bottom: 10px;
    }
    .flowContainer .flow02 .itemWrap > .item .content .title {
        margin-bottom: 6px;
        font-size: 2.3rem;
    }
    .flowContainer .flow02 .itemWrap > .item .content .txt {
        font-size: 1.6rem;
    }
    .flowContainer > .content:last-child .itemWrap:last-child::before {
        height: calc(50% + 42px);
        top: -42px;
    }
    .mod_hdgL2 {
        font-size: 2.6rem;
        margin-bottom: 45px;
        padding: 0 0 20px 58px;
        text-align: left;
    }
    .mod_hdgL2::before {
        left: 0;
        -webkit-transform: none;
                transform: none;
    }
    .mod_hdgL2 .areaBadge {
        display: inline-block;
        margin-left: 25px;
    }
    .mod_hdgL2 .sub {
        font-size: 2rem;
    }
    .mod_hdgL2_02 {
        font-size: 3.2rem;
        padding-left: 75px;
        position: relative;
        text-align: left;
        margin-bottom: 30px;
    }
    .mod_hdgL2_02::before {
        height: 53px;
        margin: 0;
        position: absolute;
        top: 50%;
        margin-top: -26px;
        left: 0;
        width: 57px;
    }
    .mod_hdgL2_02 > .lead {
        font-size: 2rem;
        margin-bottom: 6px;
    }
    .mod_hdgL3 {
        border-bottom-width: 2px;
        margin-bottom: 35px;
    }
    .mod_hdg02 {
        font-size: 2.2rem;
        border-bottom: none;
        padding-bottom: 5px;
    }
    .mod_hdg03 {
        font-size: 2rem;
        border-bottom-width: 2px;
        margin-bottom: 15px;
        padding-bottom: 15px;
    }
    .mod_txt {
        margin-bottom: 37px;
    }
    .mod_txt p {
        line-height: 1.75;
    }
    .mod_txtSub {
        text-align: left;
    }
    .mod_txtBadge {
        padding: 2px 20px;
        font-size: 1.3rem;
    }
    .mod_txtLead {
        font-size: 2rem;
    }
    .mod_txtLead > [class^='em_'] {
        padding: 4px 12px 5px;
        margin-left: 10px;
        margin-right: 10px;
    }
    .mod_listBurette + .mod_txtNote {
        margin-top: -30px;
    }
    .iconPdf {
        margin-left: 12px;
    }
    .iconBlank {
        margin-left: 12px;
        margin-bottom: 4px;
    }
    [class^='mod_btn'] .iconBlank {
        margin-bottom: 7px;
    }
    .mod_link {
        font-size: 1.8rem;
        padding-left: 34px;
    }
    .mod_link::before {
        height: 23px;
        top: 8px;
        width: 23px;
    }
    .mod_linkPnl > .img {
        margin-bottom: 16px;
    }
    .mod_linkPnl + .discription {
        font-size: 1.5rem;
    }
    .mod_linkPnl02 {
        padding: 21px 22px 15px;
        border: none;
        border-radius: 10px;
        display: -webkit-flex;
        display:         flex;
    }
    .mod_linkPnl02 > .img {
        -webkit-flex: 1 0 auto;
                flex: 1 0 auto;
        text-align: right;
    }
    .mod_linkPnl02 > .txt {
        margin-left: 30px;
    }
    .mod_linkPnl02 > .btn {
        -webkit-align-self: center;
                align-self: center;
        background-image: url(/common/images/icon_arrow_03.svg);
        background-size: contain;
        background-repeat: no-repeat;
        display: block;
        height: 24px;
        margin-left: 20px;
        overflow: hidden;
        padding-left: 20px;
        width: 24px;
        white-space: nowrap;
        text-indent: 100%;
    }
    .mod_linkPnl02 > .btn::before, .mod_linkPnl02 > .btn::after {
        display: none;
    }
    .mod_linkPnl02 > :first-child {
        margin-left: 0;
    }
    .mod_linkPnlList {
        display: -webkit-flex;
        display:         flex;
        -webkit-flex-wrap: wrap;
                flex-wrap: wrap;
        -webkit-align-items: center;
                align-items: center;
        margin: -12px 0 45px -12px;
    }
    .mod_linkPnlList > li {
        margin: 12px 0 0 12px;
        width: calc(50% - 12px);
    }
    .mod_linkPnlList > li > a, .mod_linkPnlList > li > .nolink {
        border-radius: 10px;
        border-width: 2px;
        padding: 24px 16px 20px;
    }
    .mod_linkPnlList > li > a > .txt, .mod_linkPnlList > li > .nolink > .txt {
        font-size: 1.6rem;
    }
    .mod_linkAnchor {
        margin-bottom: 40px;
    }
    .mod_linkAnchor > ul > li {
        width: calc(33.333333% - 40px / 3);
        margin-right: 20px;
        margin-bottom: 0;
    }
    .mod_linkAnchor > ul > li:last-child {
        margin-right: 0;
    }
    .mod_linkAnchor > ul > li a {
        padding: 10px 30px;
    }
    .sitemap .firstLayer > li > .secondLayer > li > .thirdLayer > li::before {
        top: 12px;
    }
    .mod_btn, .mod_btn04 {
        display: inline-block;
        margin: 0;
        padding: 10px 34px;
        width: auto;
        min-width: 268px;
    }
    .mod_btn02 {
        font-size: 2rem;
        padding: 10px 30px;
    }
    .mod_btn03 {
        padding: 10px 15px 12px;
        border-radius: 10px;
    }
    .mod_btn03:hover, .mod_btn03:focus {
        opacity: .8;
    }
    .mod_listPath {
        font-size: 1.4rem;
        margin-bottom: 23px;
    }
    .mod_listPath > ol > li:not(:last-child) {
        padding-right: 36px;
        margin-right: 10px;
    }
    .mod_listPath > ol > li:not(:last-child)::before, .mod_listPath > ol > li:not(:last-child)::after {
        margin-top: -3px;
        right: 6px;
        width: 11px;
    }
    .mod_listPath > ol > li:not(:last-child)::after {
        margin-top: 2px;
    }
    .mod_listPnl {
        max-width: 250px;
    }
    .mod_listBtn {
        display: -webkit-flex;
        display:         flex;
        margin: -15px 0 40px -40px;
    }
    .mod_listBtn > li {
        margin-left: 40px;
    }
    .mod_listBtn > li > a {
        margin: 0;
    }
    .mod_listFacility {
        font-size: 1.3rem;
        margin-left: -20px;
    }
    .mod_listFacility > li {
        margin-left: 20px;
        padding: 7px 0 7px 60px;
        width: 180px;
    }
    .mod_listDl {
        margin-top: -3px;
    }
    .mod_listDl > div {
        margin-top: 3px;
        display: -webkit-flex;
        display:         flex;
    }
    .mod_listDl > div > dt {
        margin-right: 9px;
    }
    .mod_listDl._typeContact dd {
        font-size: 1.8rem;
    }
    .mod_listNews {
        border-width: 3px;
        margin-bottom: 45px;
    }
    .mod_listNews > div {
        display: -webkit-flex;
        display:         flex;
    }
    .mod_listNews > div > dt {
        font-size: 1.6rem;
    }
    .mod_listNews > div > dt > .badge {
        font-size: 1.4rem;
        padding: 3px 12px;
        margin-left: 20px;
    }
    .mod_listNews > div > dd {
        padding-left: 23px;
        font-size: 1.6rem;
    }
    .mod_listNews02 {
        border-width: 3px;
        margin-bottom: 45px;
    }
    .mod_listNews02 > li {
        border-radius: 10px;
        border-width: 2px;
        padding: 24px 16px 20px;
        margin: 12px 0 0 12px;
    }
    .mod_listNews02 > li > .txt {
        font-size: 1.6rem;
    }
    .mod_listRank {
        margin-bottom: 45px;
    }
    .mod_listCase > li .clause {
        font-size: 1.8rem;
        -webkit-flex: 0 0 80px;
                flex: 0 0 80px;
    }
    .mod_listCase > li > dl {
        padding: 10px 0 12px 20px;
    }
    .mod_listCase > li > dl dt {
        font-size: 1.8rem;
    }
    .mod_listCase > li > dl dt._small {
        font-size: 1.4rem;
    }
    .mod_listCase > li > dl dd {
        font-size: 1.8rem;
    }
    .mod_listCase02 .item dt {
        font-size: 1.8rem;
        -webkit-flex: 0 0 85px;
                flex: 0 0 85px;
    }
    .mod_listCase02 .item dd {
        font-size: 1.6rem;
        padding: 11px 0 12px 14px;
    }
    .mod_list_step {
        margin-bottom: 55px;
    }
    .mod_list_step > li {
        margin-right: 162px;
    }
    .mod_list_step > li::after {
        top: 30px;
        width: 142px;
    }
    .mod_listOrder > li {
        font-size: 1.8rem;
    }
    .mod_listOrder > li .num {
        -webkit-flex-basis: 40px;
                flex-basis: 40px;
        height: 40px;
        margin-right: 24px;
        font-size: 1.8rem;
    }
    .mod_listOrder > li .num::after {
        right: -6px;
        border-width: 5px 0 5px 6px;
    }
    .mod_listBurette {
        margin-bottom: 37px;
    }
    .mod_listBurette > li::before {
        top: 13px;
    }
    .mod_listCheck {
        display: -webkit-flex;
        display:         flex;
        -webkit-flex-wrap: wrap;
                flex-wrap: wrap;
        -webkit-align-items: flex-start;
                align-items: flex-start;
    }
    .mod_listCheck > li {
        margin-bottom: 0;
    }
    .mod_listCheck > li:last-child {
        margin-bottom: 10px;
    }
    .mod_listPanel {
        display: -webkit-flex;
        display:         flex;
        -webkit-flex-wrap: wrap;
                flex-wrap: wrap;
        margin-left: -13px;
    }
    .mod_listPanel > li {
        width: calc(25% - 13px);
        margin-left: 13px;
    }
    .mod_listPanel > li._large .content .mod_listBurette {
        padding: 13px 60px 0;
        display: -webkit-flex;
        display:         flex;
        -webkit-flex-wrap: wrap;
                flex-wrap: wrap;
    }
    .mod_listPanel > li._large .content .mod_listBurette > li {
        width: 412px;
    }
    .mod_listPanel > li._middle {
        width: calc(50% - 13px);
    }
    .mod_listVoice > li .content {
        margin-top: -7px;
    }
    .mod_listOrder02 {
        margin-bottom: 37px;
    }
    .mod_listRecruitarea {
        margin: 1.6rem 0;
    }
    .mod_grid {
        margin-bottom: 80px;
    }
    .mod_grid._keepMiddle {
        display: -webkit-flex;
        display:         flex;
        -webkit-flex-wrap: wrap;
                flex-wrap: wrap;
        -webkit-justify-content: space-between;
                justify-content: space-between;
    }
    .mod_grid > .col {
        display: block;
    }
    .mod_grid > .col > .itemText._type02 {
        padding: 25px 10%;
    }
    .mod_grid + .mod_grid {
        margin-top: -68px;
    }
    .mod_grid._alignCenter {
        -webkit-align-items: center;
                align-items: center;
    }
    .mod_grid._appeal {
        margin-bottom: 40px;
    }
    .mod_grid._reverse .col:first-child {
        -webkit-order: 2;
                order: 2;
    }
    .mod_grid._reverse .col:last-child {
        -webkit-order: 1;
                order: 1;
    }
    .mod_grid._liquid > .col:first-child {
        -webkit-flex: 1 1 auto;
                flex: 1 1 auto;
        width: auto;
    }
    .mod_grid._liquid > .col:last-child {
        width: auto;
    }
    .top_grid > .col {
        -webkit-flex: 1 0 auto;
                flex: 1 0 auto;
    }
    .mod_grid._keepMiddle {
        margin-left: -48px;
        margin-top: -48px;
    }
    .mod_grid._keepMiddle[data-col='2'] > .col {
        margin: 48px 0 0 48px;
        width: calc((100% - 96px) / 2);
    }
    .mod_grid._keepMiddle {
        margin-left: -48px;
        margin-top: -48px;
    }
    .mod_grid._keepMiddle[data-col='3'] > .col {
        margin: 48px 0 0 48px;
        width: calc((99.99% - 144px) / 3);
    }
    .mod_lytImg {
        display: -webkit-flex;
        display:         flex;
        margin-left: -15px;
    }
    .mod_lytImg > .img {
        -webkit-flex-shrink: 0;
                flex-shrink: 0;
        margin-left: 15px;
    }
    .mod_lytImg > .img > :last-child {
        margin-bottom: 0;
    }
    .mod_lytImg > .txt {
        -webkit-flex-grow: 1;
                flex-grow: 1;
        margin-left: 15px;
    }
    .mod_lytImg > .txt > :last-child {
        margin-bottom: 0;
    }
    .mod_lytImg._reverse .col:first-child {
        -webkit-order: 2;
                order: 2;
    }
    .mod_lytImg._reverse .col:last-child {
        -webkit-order: 1;
                order: 1;
    }
    .mod_box {
        padding: 30px;
        margin-bottom: 85px;
    }
    .mod_box > .hdg {
        border-radius: 12px;
        border-width: 2px;
        font-size: 1.6rem;
        margin: -55px 0 30px;
        padding: 4px 20px;
    }
    .mod_box > .hdg::after {
        background-image: url(/common/images/sprite.png);
        background-position: -112px -166px;
        width: 10px;
        height: 12px;
        bottom: -9px;
    }
    .mod_box > .hdg._type02 {
        -webkit-align-items: center;
                align-items: center;
        border-radius: 50%;
        display: -webkit-flex;
        display:         flex;
        -webkit-flex-wrap: wrap;
                flex-wrap: wrap;
        height: 154px;
        -webkit-justify-content: center;
                justify-content: center;
        margin-top: -50px;
        padding: 20px;
        width: 154px;
    }
    .mod_box > .hdg._type02::before {
        display: none;
    }
    .mod_box > .hdg._type02 span:not([class]) {
        display: block;
        margin-top: -40px;
        width: 100%;
    }
    .mod_box02 {
        border-radius: 10px;
    }
    .mod_box02 > .inner {
        display: -webkit-flex;
        display:         flex;
        -webkit-align-items: center;
                align-items: center;
        padding: 30px 28px 30px;
        border-radius: 8px;
    }
    .mod_box02 > .inner > .img, .mod_box02 > .inner > .content {
        width: calc((100% - 48px) / 2);
    }
    .mod_box02 > .inner > .content {
        margin-left: 48px;
    }
    .mod_box02 .img {
        margin-bottom: 0;
    }
    .mod_box02 .title {
        display: -webkit-flex;
        display:         flex;
        -webkit-align-items: center;
                align-items: center;
    }
    .mod_box03 {
        border-radius: 20px;
        padding: 20px 30px;
    }
    .mod_box04 {
        margin-bottom: 60px;
        border-radius: 20px;
        padding: 40px 52px;
    }
    .mod_box05 {
        margin-bottom: 60px;
        border-radius: 20px;
        padding: 30px 32px 34px;
    }
    .mod_box06 {
        margin-bottom: 60px;
        padding: 20px 32px 24px;
    }
    .mod_box06 .inner {
        padding: 20px 32px 24px;
    }
    .mod_boxContact {
        padding: 35px 20px 18px;
        margin-bottom: 30px;
    }
    .mod_boxContact > .hdg {
        font-size: 1.6rem;
        margin: -15px 0 19px;
    }
    .mod_boxSearch {
        -webkit-align-items: center;
                align-items: center;
        display: -webkit-flex;
        display:         flex;
        -webkit-justify-content: center;
                justify-content: center;
        padding: 40px;
        text-align: center;
    }
    .mod_boxSearch .itemTxt._wide {
        -webkit-flex: 0 1 850px;
                flex: 0 1 850px;
    }
    .mod_boxSearch label {
        -webkit-align-items: center;
                align-items: center;
        display: -webkit-flex;
        display:         flex;
        margin-bottom: 0;
        font-size: 1.6rem;
        white-space: nowrap;
    }
    .mod_boxSearch label .text {
        -webkit-flex-shrink: 0;
                flex-shrink: 0;
    }
    .mod_boxSearch input, .mod_boxSearch select {
        -webkit-flex-grow: 1;
                flex-grow: 1;
        margin: 0 20px;
    }
    .mod_boxSearch .itemBtn {
        -webkit-flex-shrink: 0;
                flex-shrink: 0;
    }
    .mod_boxSearch .boxSearchBtn {
        padding: 6px 38px;
        width: auto;
    }
    .mod_boxSearch .itemRadio {
        display: -webkit-flex;
        display:         flex;
        -webkit-align-items: center;
                align-items: center;
        margin-right: 40px;
    }
    .mod_boxSearch .itemRadio label {
        margin-left: 10px;
    }
    .mod_boxSearch .itemRadio label:first-child {
        margin-left: 20px;
    }
    .mod_boxSearch02 > .contents {
        display: -webkit-flex;
        display:         flex;
    }
    .mod_boxSearch02.topSearch {
        margin: 0;
    }
    .mod_boxSearch02.topSearch > .head {
        -webkit-align-items: flex-end;
                align-items: flex-end;
        display: -webkit-flex;
        display:         flex;
        margin-bottom: 40px;
    }
    .mod_boxSearch02.topSearch > .head .hdg {
        margin-right: 14px;
    }
    .mod_boxSearch02.topSearch > .head .subTxt {
        margin-bottom: 3px;
    }
    .mod_boxSearch02.topSearch > .contents {
        -webkit-align-items: flex-end;
                align-items: flex-end;
        -webkit-flex-wrap: wrap;
                flex-wrap: wrap;
        -webkit-flex: 0 0 auto;
                flex: 0 0 auto;
    }
    .mod_boxSearch02.topSearch > .contents > .colSub {
        margin: 0 0 0 23px;
    }
    .mod_boxSearch02.topSearch .formList > div {
        -webkit-align-items: center;
                align-items: center;
    }
    .mod_boxSearch02.topSearch .formList > div + div {
        margin-top: 0;
    }
    .mod_boxSearch02.topSearch .formList > div > dt {
        padding-right: 18px;
    }
    .mod_boxSearch02.topSearch .formList > div > dd {
        -webkit-flex: 1 1 auto;
                flex: 1 1 auto;
        margin-bottom: 0;
    }
    .mod_boxSearch02.topSearch .formList > div + div > dt, .mod_boxSearch02.topSearch .formList > div + div > dd {
        padding-top: 12px;
    }
    .mod_boxSearch02.topSearch .btnSubmit {
        display: inline-block;
        font-size: 2.4rem;
        line-height: 1.8;
        width: auto;
    }
    .mod_boxNews {
        display: -webkit-flex;
        display:         flex;
        padding: 28px 60px 30px 55px;
    }
    .mod_boxNews > .areaStretch, .mod_boxNews > .areaFixed {
        margin-left: 30px;
    }
    .mod_boxNews > .areaStretch {
        -webkit-flex-grow: 1;
                flex-grow: 1;
    }
    .mod_boxNews > .areaFixed {
        -webkit-flex-shrink: 0;
                flex-shrink: 0;
    }
    .mod_boxNews > :first-child {
        margin-left: 0;
    }
    #google_map {
        height: 615px;
    }
    .mod_boxAdobe, .mod_boxDownload {
        display: -webkit-flex;
        display:         flex;
        border-radius: 6px;
        padding: 26px 29px;
    }
    .mod_boxAdobe .img, .mod_boxDownload .img {
        -webkit-flex-shrink: 0;
                flex-shrink: 0;
        margin-bottom: 0;
        margin-right: 31px;
    }
    .mod_boxStep .disciption {
        display: -webkit-flex;
        display:         flex;
        padding: 34px 30px 42px;
        margin-bottom: 50px;
    }
    .mod_boxStep .disciption:after {
        border-width: 32px 32px 0 32px;
        bottom: -32px;
    }
    .mod_boxStep .disciption > .guide, .mod_boxStep .disciption > .inner {
        width: calc((100% - 48px) / 2);
    }
    .mod_boxStep .disciption > .guide > .hdg {
        margin-top: 5px;
        margin-bottom: 17px;
        padding-bottom: 6px;
    }
    .mod_boxStep .disciption > .guide > .txt {
        line-height: 1.5;
        font-size: 1.6rem;
    }
    .mod_boxStep .disciption > .guide > .img a:first-child {
        margin-right: 10px;
    }
    .mod_boxStep .disciption > .guide > .img {
        text-align: left;
        margin-top: 34px;
    }
    .mod_boxStep .disciption > .inner {
        padding: 30px 38px 22px;
        margin-top: 0;
        margin-left: 48px;
    }
    .mod_boxStep .disciption > .inner > .hdg {
        font-size: 1.6rem;
        padding-bottom: 15px;
        margin-bottom: 18px;
    }
    .mod_boxStep .disciption > .inner .content {
        display: -webkit-flex;
        display:         flex;
    }
    .mod_boxStep .disciption > .inner .content > .txt {
        margin-right: 36px;
        font-size: 1.6rem;
    }
    .mod_boxStep .disciption > .inner .content > .img {
        -webkit-flex-shrink: 0;
                flex-shrink: 0;
    }
    .mod_boxStep .detail {
        padding: 0 56px 13px;
    }
    .mod_boxStep .detail > .hdg {
        margin-bottom: 24px;
    }
    .mod_boxStep .detail .list > li {
        margin-bottom: 22px;
    }
    .mod_boxStep .detail .list > li::before {
        left: 42px;
        top: 20px;
    }
    .mod_boxStep .detail .list > li::after {
        background-image: url(/common/images/sprite.png);
        background-position: -199px 0;
        width: 21px;
        height: 22px;
        left: 33px;
        bottom: -11px;
    }
    .mod_boxStep .detail .list > li > .num._inline {
        padding-top: 26px;
    }
    .mod_boxStep .detail .list > li > .num {
        background-image: url(/common/images/bg_step_01.png);
        width: 80px;
        height: 80px;
        font-size: 1.2rem;
        padding-top: 20px;
        margin: 0 35px 0 4px;
    }
    .mod_boxStep .detail .list > li > .num b {
        font-size: 2.4rem;
    }
    .mod_boxStep .detail .list > li .txt {
        font-size: 1.6rem;
    }
    .mod_boxStep .detail .list > li .content {
        padding-bottom: 30px;
        margin-top: 25px;
    }
    .mod_boxStep .detail .list > li .content > .box {
        padding: 30px 34px;
        margin-top: 35px;
    }
    .mod_boxStep .detail .list > li .content._layout {
        -webkit-flex-wrap: nowrap;
                flex-wrap: nowrap;
    }
    .mod_boxStep .detail .list > li .content._layout .img {
        margin-bottom: 0;
        margin-right: 40px;
    }
    .mod_boxStep .detail:first-child {
        padding-top: 34px;
    }
    .mod_boxStep._type02 .detail .list > li .content .title {
        width: auto;
        min-width: 346px;
    }
    .mod_boxStep._type03 .detail .list > li .num {
        padding-top: 26px;
    }
    .mod_boxStep._type03 .detail .list > li .content > .box {
        display: -webkit-flex;
        display:         flex;
        -webkit-align-items: flex-start;
                align-items: flex-start;
    }
    .mod_boxStep._type03 .detail .list > li .content > .box > .col {
        display: -webkit-flex;
        display:         flex;
        -webkit-flex-basis: 423px;
                flex-basis: 423px;
    }
    .mod_boxStep._type03 .detail .list > li .content > .box > .col + .col {
        margin-left: 62px;
    }
    .mod_boxStep._type03 .detail .list > li .content .openTime {
        -webkit-flex-direction: column;
                flex-direction: column;
        margin-bottom: 0;
        margin-right: 20px;
    }
    .mod_boxStep._type03 .detail .list > li .content .openTime > p + p::before {
        top: -35px;
        left: 11px;
        bottom: auto;
        -webkit-transform: rotate(45deg) skew(-20deg, -20deg);
                transform: rotate(45deg) skew(-20deg, -20deg);
    }
    .mod_boxStep._type03 .detail .list > li .content .work {
        margin-bottom: 0;
        margin-right: 10px;
    }
    .mod_boxStep._type03 .detail .list > li .content .work .txtList > li::before {
        top: 11px;
    }
    .mod_boxStep._type03 .detail .list > li .content .img {
        margin-left: 10px;
    }
    .mod_boxStep .mod_listCheck {
        margin-top: -5px;
    }
    .mod_boxCase {
        padding: 20px;
    }
    .mod_boxCase .hdg .num {
        -webkit-flex-basis: 40px;
                flex-basis: 40px;
        height: 40px;
        font-size: 1.8rem;
    }
    .mod_boxCase .hdg .num::after {
        right: -6px;
        border-width: 5px 0 5px 6px;
    }
    .mod_boxCase .hdg .sub {
        font-size: 1.4rem;
    }
    .mod_boxCase .hdg .ttl {
        font-size: 2rem;
    }
    .mod_boxContact02 {
        padding: 5px 30px 16px;
        border-radius: 10px;
    }
    .mod_boxContact02 .hdg {
        border-width: 2px;
    }
    .mod_boxContact02 .content {
        padding-top: 10px;
    }
    .mod_boxContact02 .tel {
        margin-bottom: 8px;
    }
    .mod_boxContact02 .tel dd .telLink a {
        display: none !important;
    }
    .mod_boxPrivacy {
        height: 294px;
    }
    .mod_boxMessage {
        max-width: 620px;
        margin: 0 auto 34px;
    }
    .mod_boxMessage img {
        margin-bottom: 37px;
    }
    .mod_boxMessage .lead {
        font-size: 2.4rem;
    }
    .mod_boxMessage .name {
        font-size: 2.4rem;
    }
    .mod_boxMessage .name .sub {
        font-size: 1.8rem;
    }
    .mod_tbl > table {
        display: table;
    }
    .mod_tbl > table tbody {
        display: table-row-group;
        border-bottom: none;
    }
    .mod_tbl > table tbody tr th, .mod_tbl > table tbody tr td {
        display: table-cell;
        overflow: hidden;
        border-top: 1px solid #ddd;
        border-bottom: 1px solid #ddd;
        font-size: 1.6rem;
    }
    .mod_tbl03 {
        margin-bottom: 40px;
    }
    .mod_tbl03 > table tbody td {
        padding: 8px 8px 9px;
    }
    .mod_tbl04 {
        margin-bottom: 40px;
    }
    .mod_tbl04 > table {
        border-bottom: 1px solid #a7a7a7;
    }
    .mod_tbl04 > table tbody th, .mod_tbl04 > table tbody td {
        display: table-cell;
        border-bottom: 1px solid #a7a7a7;
    }
    .mod_tbl04 > table tbody th {
        padding: 7px 36px 8px;
        background-image: linear-gradient(to bottom, transparent 10px, #a7a7a7 11px, #a7a7a7 50%, transparent 50%, transparent 100%), linear-gradient(to top, transparent 10px, #a7a7a7 11px, #a7a7a7 50%, transparent 50%, transparent 100%);
        background-position: right top;
        background-size: 1px 100%;
        border-right: none;
    }
    .mod_tbl04 > table tbody td {
        padding: 7px 28px 8px;
    }
    .mod_tbl05 {
        margin-bottom: 40px;
    }
    .mod_tbl05 > table {
        border-bottom: 0 none;
    }
    .mod_tbl05 > table tbody th, .mod_tbl05 > table tbody td {
        display: table-cell;
        border-bottom: 1px solid #a7a7a7;
    }
    .mod_tbl05 > table tbody th {
        padding: 7px 6px 8px;
        background-position: right top;
        background-size: 1px 100%;
        border-right: none;
    }
    .mod_tbl05 > table tbody td {
        padding: 7px 28px 8px;
    }
    .mod_img {
        margin-bottom: 50px;
    }
    .mod_img .caption {
        font-size: 1.4rem;
    }
    .mod_img_layout {
        display: -webkit-flex;
        display:         flex;
    }
    .mod_img_layout .img {
        margin-top: 0;
        margin-left: 50px;
    }
    .mod_img_layout .img .caption {
        font-size: 1.4rem;
    }
    .mod_img_layout._reverse .img {
        margin-top: 0;
        margin-right: 50px;
    }
    .mod_formGrp > .item + .mod_btn03 {
        margin-top: 0;
        margin-left: 20px;
    }
    .mod_formGrp > .item._birthday label {
        width: auto;
    }
    .mod_formGrp input._name {
        width: 240px;
    }
    .mod_formGrp input._poscode {
        width: 115px;
    }
    .mod_formGrp input._address {
        width: 520px;
    }
    .mod_formGrp input._phonenum {
        width: 150px;
    }
    .mod_formGrp input._year, .mod_formGrp input._month, .mod_formGrp input._day {
        width: 150px;
    }
    .mod_formGrp input._phonenum, .mod_formGrp input._year, .mod_formGrp input._month, .mod_formGrp input._day {
        padding: 10px 20px;
    }
    .mod_formGrp input._mail {
        width: 360px;
    }
    .mod_formGrp input._other {
        max-width: 790px;
    }
    .mod_formGrp select {
        width: 320px;
        margin-bottom: 5px;
    }
    .mod_formGrp .errTxt {
        font-size: 1.5rem;
    }
    .mod_formGrp + .mod_formGrp {
        margin-top: 10px;
    }
    .mod_formGrp._float {
        float: left;
    }
    .mod_formGrp._float .item {
        margin-bottom: 0;
    }
    .mod_formGrp._float + .mod_formGrp {
        margin-top: 0;
        margin-left: 20px;
    }
    .mod_formGrp._flex {
        display: -webkit-flex;
        display:         flex;
        -webkit-align-items: center;
                align-items: center;
        -webkit-flex-wrap: wrap;
                flex-wrap: wrap;
    }
    .mod_formGrp._flex .errTxt {
        width: 100%;
    }
    .mod_formGrp .itemRadio {
        display: -webkit-flex;
        display:         flex;
        -webkit-align-items: center;
                align-items: center;
        margin-right: 40px;
    }
    .mod_formGrp .itemRadio label {
        margin-left: 10px;
    }
    .mod_jsTab > .tabList {
        display: -webkit-flex;
        display:         flex;
        margin-bottom: 10px;
    }
    .mod_jsTab > .tabList > .hdg {
        display: inline-block;
        margin-right: 40px;
        vertical-align: middle;
    }
    .mod_jsTab > .tabList ul {
        display: block;
        overflow: hidden;
        margin-top: 7px;
    }
    .mod_jsTab > .tabList ul > li {
        float: left;
        display: block;
        width: 160px;
    }
    .mod_jsTab > .tabList ul > li a {
        text-align: center;
    }
    .mod_listQa {
        display: -webkit-flex;
        display:         flex;
        -webkit-justify-content: center;
                justify-content: center;
    }
    .mod_listQa > li {
        -webkit-flex-basis: 346px;
                flex-basis: 346px;
        margin-right: 20px;
        min-width: 235px;
    }
    .mod_listQa > li:last-child {
        margin-right: 0;
    }
    .mod_boxQa .question {
        margin: 0 30px 6px;
    }
    .mod_boxQa .answer {
        padding: 50px 45px 15px;
    }
    .areaMap {
        position: relative;
        padding-top: 50px;
    }
    .areaMap > .hdg._type02 {
        margin-top: 0;
        position: absolute;
        left: 50%;
        top: 150px;
        margin-left: -120px;
    }
    .areaMap #areaMapImg {
        display: block;
        text-align: center;
        margin-bottom: 180px;
    }
    .areaMap .mod_listPnl {
        position: absolute;
    }
    html.noJs .areaMap .mod_listPnl {
        position: static;
    }
    .areaMap .mod_listPnl._position01 {
        top: 36px;
        right: 42px;
    }
    .areaMap .mod_listPnl._position02 {
        top: 282px;
        right: 42px;
    }
    .areaMap .mod_listPnl._position03 {
        top: 539px;
        right: 42px;
    }
    .areaMap .mod_listPnl._position04 {
        left: 50%;
        bottom: 16px;
        -webkit-transform: translate(-50%);
                transform: translate(-50%);
    }
    .areaMap .mod_listPnl._position05 {
        top: 36px;
        left: 27px;
    }
    .areaMap .mod_listPnl._position06 {
        top: 282px;
        left: 27px;
    }
    .areaMap .mod_listPnl._position07 {
        top: 539px;
        left: 27px;
    }
    .js_selectContnts select {
        border-width: 2px;
        width: 324px;
        margin-bottom: 44px;
        background-position: right 20px center;
    }
    .mod_jsSlide._narrow, .mod_jsBanner._narrow {
        max-width: 520px;
        margin-bottom: 37px;
    }
    .mod_jsSlide .slick-arrow, .mod_jsBanner .slick-arrow {
        padding-left: 60px;
        width: 60px;
    }
    .mod_jsSlide .slick-arrow::before, .mod_jsSlide .slick-arrow::after, .mod_jsBanner .slick-arrow::before, .mod_jsBanner .slick-arrow::after {
        height: 3px;
        width: 30px;
    }
    .mod_jsSlide .slick-prev::after, .mod_jsBanner .slick-prev::after {
        top: calc(50% - 19px);
    }
    .mod_jsSlide .slick-next::before, .mod_jsBanner .slick-next::before {
        top: calc(50% - 19px);
    }
    .mod_jsBanner {
        margin: -10px auto 30px;
        padding-right: 20px;
        max-width: none;
    }
    .mod_jsBanner .slick-list {
        max-width: none;
    }
    .mod_jsBanner .slideItem {
        margin-left: 20px;
        margin-top: 10px;
    }
    .mod_carousel {
        padding: 125px 0 140px;
        margin-top: 25px;
    }
    .mod_carousel::before {
        border-width: 10px;
        height: 582px;
        top: 125px;
        width: 582px;
    }
    .mod_carousel .slideItem {
        padding: 100px;
        height: 562px;
        line-height: 2.11111;
        width: 562px;
    }
    .mod_carousel .slideItem > .contents {
        font-size: 1.8rem;
    }
    .mod_carousel .slideItem > .contents > .btnArea {
        margin-top: 25px;
    }
    .mod_carousel .slideItem > .carouselBg {
        background-size: cover;
        background-position: center;
        border-radius: 50%;
        display: block;
        height: 100%;
        position: absolute;
        top: 0;
        left: 0;
        transition: opacity .3s;
        width: 100%;
    }
    .mod_carousel .slideItem > .carouselBg::before {
        background-color: rgba(0, 0, 0, .4);
        border-radius: 50%;
        content: '';
        height: 100%;
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
    }
    .mod_carousel .slick-list {
        margin-top: 10px;
    }
    .mod_carousel .slick-slide {
        width: 562px;
    }
    .mod_carousel .slick-slide .slideItem > .hdg {
        font-size: 3.6rem;
    }
    .mod_carousel .item-next .slideItem > .hdg, .mod_carousel .slick-center .slideItem > .hdg {
        font-size: 3.6rem;
    }
    .mod_carousel .slick-arrow {
        height: 60px;
        top: 400px;
        width: 60px;
    }
    .mod_carousel .slick-arrow::before {
        border-width: 2px;
        height: 37px;
        width: 37px;
    }
    .mod_carousel .slick-prev {
        left: 50%;
        -webkit-transform: translateX(-280px);
                transform: translateX(-280px);
    }
    .mod_carousel .slick-next {
        right: 50%;
        -webkit-transform: translateX(280px);
                transform: translateX(280px);
    }
    .mt-00 {
        margin-top: 0;
    }
    .mb-00 {
        margin-bottom: 0;
    }
    .mt-05 {
        margin-top: 5px;
    }
    .mb-05 {
        margin-bottom: 5px;
    }
    .mt-10 {
        margin-top: 10px;
    }
    .mb-10 {
        margin-bottom: 10px;
    }
    .mt-15 {
        margin-top: 15px;
    }
    .mb-15 {
        margin-bottom: 15px;
    }
    .mt-20 {
        margin-top: 20px;
    }
    .mb-20 {
        margin-bottom: 20px;
    }
    .mt-25 {
        margin-top: 25px;
    }
    .mb-25 {
        margin-bottom: 25px;
    }
    .mt-30 {
        margin-top: 30px;
    }
    .mb-30 {
        margin-bottom: 30px;
    }
    .mt-35 {
        margin-top: 35px;
    }
    .mb-35 {
        margin-bottom: 35px;
    }
    .mt-40 {
        margin-top: 40px;
    }
    .mb-40 {
        margin-bottom: 40px;
    }
    .mt-45 {
        margin-top: 45px;
    }
    .mb-45 {
        margin-bottom: 45px;
    }
    .mt-50 {
        margin-top: 50px;
    }
    .mb-50 {
        margin-bottom: 50px;
    }
    .mt-55 {
        margin-top: 55px;
    }
    .mb-55 {
        margin-bottom: 55px;
    }
    .mt-60 {
        margin-top: 60px;
    }
    .mb-60 {
        margin-bottom: 60px;
    }
    .mt-65 {
        margin-top: 65px;
    }
    .mb-65 {
        margin-bottom: 65px;
    }
    .mt-70 {
        margin-top: 70px;
    }
    .mb-70 {
        margin-bottom: 70px;
    }
    .mt-75 {
        margin-top: 75px;
    }
    .mb-75 {
        margin-bottom: 75px;
    }
    .mt-80 {
        margin-top: 80px;
    }
    .mb-80 {
        margin-bottom: 80px;
    }
    .mt-85 {
        margin-top: 85px;
    }
    .mb-85 {
        margin-bottom: 85px;
    }
    .mt-90 {
        margin-top: 90px;
    }
    .mb-90 {
        margin-bottom: 90px;
    }
    .mt-95 {
        margin-top: 95px;
    }
    .mb-95 {
        margin-bottom: 95px;
    }
    .mt-100 {
        margin-top: 100px;
    }
    .mb-100 {
        margin-bottom: 100px;
    }
    .wideHide {
        display: none !important;
    }
}

@media screen and (min-width: 1021px) {
    a:hover, button:hover {
        opacity: .8;
        text-decoration: none;
    }
    .str_header .headerLogo {
        width: 17vw;
    }
    .str_header .headerSearch {
        width: 204px;
    }
    .str_header .headerSearch > .searchTxt {
        padding: 4px 6px 4px 8px;
    }
    .str_header .headerSearch > .searchBtn img {
        width: 15px;
        margin: 0 1px 1px;
    }
    .str_header .headerNav > ul > li a, .str_header .headerNav > ul > li button, .str_header .headerNav > ul > li .navHook {
        font-size: 1.3rem;
    }
    .str_header .headerNav > ul > li > a, .str_header .headerNav > ul > li > button, .str_header .headerNav > ul > li > .navHook {
        padding: 8px 16px 50px 18px;
    }
    .str_header .headerNav > ul > li .areaNavChild .navItemLyt > .itemHigh > a {
        padding: 0;
    }
    .str_header .headerNav > ul > li .navChild > li > a {
        display: -webkit-flex;
        display:         flex;
        height: 100%;
        padding: 10px 32px 10px 16px;
    }
    .str_header .headerNav > ul > li .navChild > li > a:hover, .str_header .headerNav > ul > li .navChild > li > a:focus {
        background-color: #e4e4e4;
        opacity: 1;
    }
    .str_header .headerLinkList > li > a::after {
        right: 15px;
    }
    .str_containerTop .topSearch > .head .hdg::before {
        top: 8px;
        left: 0;
    }
    .str_containerTop .topSearch > .head .subTxt {
        font-size: 1.4rem;
    }
    .str_containerTop .topSearch > .head .subTxt b {
        font-size: 2rem;
    }
    .str_containerTop .topSearch label {
        font-size: 1.8rem;
        white-space: nowrap;
    }
    .str_footer::before {
        height: 40px;
    }
    .mod_hdgL2 .company {
        display: inline-block;
        float: right;
    }
    .mod_linkPnl > .img img {
        width: auto;
    }
    .mod_linkPnl > .txt {
        font-size: 1.8rem;
        padding-left: 36px;
    }
    .mod_linkPnl > .txt em {
        font-size: 2.1rem;
    }
    .mod_linkPnl02 > .img img {
        width: auto;
    }
    .mod_linkPnl02 > .txt > .hdg {
        font-size: 2.2rem;
    }
    .mod_grid {
        display: -webkit-flex;
        display:         flex;
        -webkit-flex-wrap: wrap;
                flex-wrap: wrap;
        -webkit-justify-content: space-between;
                justify-content: space-between;
        margin-bottom: 80px;
    }
    .mod_grid {
        margin-left: -48px;
        margin-top: -48px;
    }
    .mod_grid[data-col='2'] > .col {
        margin: 48px 0 0 48px;
        width: calc((100% - 96px) / 2);
    }
    .mod_grid {
        margin-left: -48px;
        margin-top: -48px;
    }
    .mod_grid[data-col='3'] > .col {
        margin: 48px 0 0 48px;
        width: calc((99.99% - 144px) / 3);
    }
    .mod_boxPnl > .hdg {
        border-width: 2px;
        padding: 4px;
        width: 260px;
        margin: -35px auto 10px;
    }
    .mod_boxPnl > .hdg::after {
        background-image: url(/common/images/sprite.png);
        background-position: -112px -166px;
        width: 10px;
        height: 12px;
        top: -9px;
    }
    .mod_boxPnl > .contents {
        width: 260px;
        line-height: 1.5;
    }
    .areaMap #areaMapImg {
        margin-bottom: 87px;
    }
    .areaMap .mod_listPnl._position04 {
        right: 340px;
        bottom: 16px;
        left: auto;
        -webkit-transform: translate(0);
                transform: translate(0);
    }
    .areaMap .mod_listPnl._position05 {
        top: 36px;
        left: 16%;
    }
}

@media screen and (min-width: 771px) and (min-width: 1021px) {
    .str_header .headerNav > ul {
        margin-right: -16px;
    }
    .str_header .headerNav > ul > li + li > a, .str_header .headerNav > ul > li + li > button {
        background-size: 2px 14px;
    }
}

@media screen and (min-width: 1250px) {
    .mod_linkPnl02 > .img {
        margin-left: 30px;
        -webkit-flex: 1 0 216px;
                flex: 1 0 216px;
        text-align: left;
    }
    .top_grid {
        -webkit-flex-direction: row-reverse;
                flex-direction: row-reverse;
        margin-bottom: 0;
        margin-left: -2.59%;
        margin-bottom: 45px;
        -webkit-justify-content: space-between;
                justify-content: space-between;
    }
    .top_grid > .col {
        margin-left: 2.59%;
        width: auto;
        -webkit-justify-content: flex-start;
                justify-content: flex-start;
        -webkit-flex: 1 1 auto;
                flex: 1 1 auto;
    }
    .top_grid > .col:first-child {
        max-width: 534px;
        -webkit-flex: 0 1 534px;
                flex: 0 1 534px;
    }
    .mod_boxSearch02.topSearch .formList > div {
        display: -webkit-flex;
        display:         flex;
        -webkit-justify-content: flex-end;
                justify-content: flex-end;
    }
    .mod_boxSearch02.topSearch .formList > div > dt {
        text-align: right;
    }
    .mod_boxSearch02.topSearch .formList > div > dd {
        -webkit-flex: 0 1 350px;
                flex: 0 1 350px;
    }
}

@media screen and (min-width: 1320px) {
    .str_header .headerLogo {
        width: 231px;
    }
    .str_header .headerSearch > .searchTxt {
        font-size: 1.6rem;
    }
    .str_header .headerNav > ul > li a, .str_header .headerNav > ul > li button, .str_header .headerNav > ul > li .navHook {
        font-size: 1.6rem;
    }
    .str_header .headerNav > ul > li > a, .str_header .headerNav > ul > li > button, .str_header .headerNav > ul > li > .navHook {
        padding: 8px 30px 50px 32px;
    }
    .str_header .headerBtn {
        margin-bottom: 0;
    }
    .str_header .headerLinkList > li > a {
        font-size: 1.4rem;
        padding: 5px 45px 5px 29px;
        min-width: 180px;
        text-align: center;
    }
    .str_header .headerLinkList02 {
        margin: 5px 30px;
    }
    .str_header .headerLinkList02 > li > a {
        font-size: 1.4rem;
    }
}

@media screen and (min-width: 771px) and (min-width: 1320px) {
    .str_header .headerNav > ul {
        margin-right: -30px;
    }
    .str_header .headerNav > ul > li + li > a, .str_header .headerNav > ul > li + li > button {
        background-size: 2px 18px;
    }
}

@media screen and (max-width: 770px) {
    .mod_tbl04 col {
        width: 100% !important;
    }
    .mod_tbl05 col {
        width: 100% !important;
    }
}

@media only screen and (max-width: 770px) {
    .narrowHide {
        display: none !important;
    }
}
