@keyframes splide-loading {
    0% {
        transform: rotate(0)
    }

    to {
        transform: rotate(1turn)
    }
}

.splide__track--draggable {
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    -ms-user-select: none;
    user-select: none
}

.splide__track--fade>.splide__list>.splide__slide {
    margin: 0 !important;
    opacity: 0;
    z-index: 0
}

.splide__track--fade>.splide__list>.splide__slide.is-active {
    opacity: 1;
    z-index: 1
}

.splide--rtl {
    direction: rtl
}

.splide__track--ttb>.splide__list {
    display: block
}

.splide__container {
    box-sizing: border-box;
    position: relative
}

.splide__list {
    backface-visibility: hidden;
    display: -ms-flexbox;
    display: flex;
    height: 100%;
    margin: 0 !important;
    padding: 0 !important
}

.splide.is-initialized:not(.is-active) .splide__list {
    display: block
}

.splide__pagination {
    -ms-flex-align: center;
    -ms-flex-pack: center;
    align-items: center;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    justify-content: center;
    margin: 0;
    pointer-events: none
}

.splide__pagination li {
    display: inline-block;
    line-height: 1;
    list-style-type: none;
    margin: 0;
    pointer-events: auto
}

.splide:not(.is-overflow) .splide__pagination {
    display: none
}

.splide__progress__bar {
    width: 0
}

.splide {
    position: relative;
    visibility: hidden
}

.splide.is-initialized,
.splide.is-rendered {
    visibility: visible
}

.splide__slide {
    -ms-flex-negative: 0;
    backface-visibility: hidden;
    box-sizing: border-box;
    flex-shrink: 0;
    list-style-type: none !important;
    margin: 0;
    position: relative
}

.splide__slide img {
    vertical-align: bottom
}

.splide__spinner {
    animation: splide-loading 1s linear infinite;
    border: 2px solid #999;
    border-left-color: transparent;
    border-radius: 50%;
    bottom: 0;
    contain: strict;
    display: inline-block;
    height: 20px;
    left: 0;
    margin: auto;
    position: absolute;
    right: 0;
    top: 0;
    width: 20px
}

.splide__sr {
    clip: rect(0 0 0 0);
    border: 0;
    height: 1px;
    margin: -1px;
    overflow: hidden;
    padding: 0;
    position: absolute;
    width: 1px
}

.splide__toggle.is-active .splide__toggle__play,
.splide__toggle__pause {
    display: none
}

.splide__toggle.is-active .splide__toggle__pause {
    display: inline
}

.splide__track {
    overflow: hidden;
    position: relative;
    z-index: 0
}

/*!
 * ress.css • v4.0.0
 * MIT License
 * github.com/filipelinhares/ress
 */
html {
    -webkit-text-size-adjust: 100%;
    box-sizing: border-box;
    tab-size: 4;
    word-break: normal
}

*,
:after,
:before {
    background-repeat: no-repeat;
    box-sizing: inherit
}

:after,
:before {
    text-decoration: inherit;
    vertical-align: inherit
}

* {
    margin: 0;
    padding: 0
}

hr {
    color: inherit;
    height: 0;
    overflow: visible
}

details,
main {
    display: block
}

summary {
    display: list-item
}

small {
    font-size: 80%
}

[hidden] {
    display: none
}

abbr[title] {
    border-bottom: none;
    text-decoration: underline;
    -webkit-text-decoration: underline dotted;
    text-decoration: underline dotted
}

a {
    background-color: transparent
}

code,
kbd,
pre,
samp {
    font-family: monospace, monospace
}

pre {
    font-size: 1em
}

b,
strong {
    font-weight: bolder
}

sub,
sup {
    font-size: 75%;
    line-height: 0;
    position: relative;
    vertical-align: initial
}

sub {
    bottom: -.25em
}

sup {
    top: -.5em
}

table {
    border-color: inherit;
    text-indent: 0
}

input {
    border-radius: 0
}

[disabled] {
    cursor: default
}

[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button {
    height: auto
}

[type=search] {
    -webkit-appearance: textfield;
    outline-offset: -2px
}

[type=search]::-webkit-search-decoration {
    -webkit-appearance: none
}

textarea {
    overflow: auto;
    resize: vertical
}

button,
input,
optgroup,
select,
textarea {
    font: inherit
}

optgroup {
    font-weight: 700
}

button {
    overflow: visible
}

button,
select {
    text-transform: none
}

[role=button],
[type=button],
[type=reset],
[type=submit],
button {
    color: inherit;
    cursor: pointer
}

[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner,
button::-moz-focus-inner {
    border-style: none;
    padding: 0
}

[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner,
button:-moz-focusring {
    outline: 1px dotted ButtonText
}

[type=reset],
[type=submit],
button,
html [type=button] {
    -webkit-appearance: button
}

button,
input,
select,
textarea {
    background-color: transparent;
    border-style: none
}

a:focus,
button:focus,
input:focus,
select:focus,
textarea:focus {
    outline-width: 0
}

select {
    -moz-appearance: none;
    -webkit-appearance: none
}

select::-ms-expand {
    display: none
}

select::-ms-value {
    color: currentColor
}

legend {
    border: 0;
    color: inherit;
    display: table;
    max-width: 100%;
    white-space: normal
}

::-webkit-file-upload-button {
    -webkit-appearance: button;
    color: inherit;
    font: inherit
}

img {
    border-style: none
}

progress {
    vertical-align: initial
}

[aria-busy=true] {
    cursor: progress
}

[aria-controls] {
    cursor: pointer
}

[aria-disabled=true] {
    cursor: default
}

html {
    display: flex;
    font-size: 10px
}

@media print {
    html {
        display: block
    }
}

body {
    -webkit-font-smoothing: antialiased;
    word-wrap: break-word;
    background-color: #fff;
    box-sizing: border-box;
    color: #14212b;
    display: flex;
    flex-direction: column;
    font-family: Noto Sans JP, sans-serif;
    font-size: 1.6rem;
    letter-spacing: .012em;
    line-height: 1.6;
    min-height: 100vh;
    overflow-wrap: break-word;
    position: relative;
    width: 100%
}

@media print {
    body {
        display: block
    }
}

@media only screen and (min-width:768px) {
    body {
        min-width: 1200px
    }
}

body.is-screen-lock {
    left: 0;
    position: fixed;
    top: 0;
    width: 100%
}

ul {
    list-style: none
}

* {
    box-sizing: border-box
}

:focus {
    outline: none
}

img {
    vertical-align: bottom;
    width: 100%
}

a {
    color: #14212b;
    text-decoration: none;
    transition: background .3s
}

a:hover {
    cursor: pointer
}

p {
    white-space: pre-line
}

#app {
    display: flex;
    flex: 1 1 auto;
    flex-direction: column
}

input[type=number],
input[type=number]::-webkit-inner-spin-button,
input[type=number]::-webkit-outer-spin-button {
    -webkit-appearance: textfield;
    appearance: textfield
}

@media print {
    * {
        page-break-after: avoid;
        page-break-before: avoid;
        page-break-inside: avoid
    }
}

@media only screen and (min-width:768px) {
    .only-sp {
        display: none
    }
}

.only-pc {
    display: none
}

@media only screen and (min-width:768px) {
    .only-pc {
        display: block
    }
}

.l-container {
    background-color: #fff
}

.l-container--gray {
    background-color: #fafafa
}

.l-container--professional-blue {
    background-color: #5081a5
}

.l-container__inner {
    margin-left: auto;
    margin-right: auto;
    max-width: 1200px;
    padding: 80px 24px;
    width: 100%
}

@media only screen and (min-width:768px) {
    .l-container__inner {
        padding: 120px 0
    }
}

.l-container__inner--anchor {
    padding-bottom: 32px;
    padding-top: 32px
}

@media only screen and (min-width:768px) {
    .l-container__inner--anchor {
        padding-bottom: 80px;
        padding-top: 64px
    }
}

.l-container__inner--full-width {
    max-width: 100%;
    padding: 0
}

.l-container__inner--full-width-sp {
    padding-left: 0;
    padding-right: 0
}

.l-container__inner--clamped {
    padding-bottom: 0;
    padding-top: 0
}

.l-container__inner--article {
    padding-top: 0
}

@media only screen and (min-width:768px) {
    .l-container__inner--article {
        padding-top: 120px
    }
}

.l-container__inner--article-column {
    border-top: 1px solid rgba(80, 129, 165, .15);
    padding-bottom: 0;
    padding-top: 16px
}

.l-container__inner--article-column+.l-container__inner--article-column {
    border-top-width: 0;
    padding-top: 64px
}

.l-container__inner--article-column:last-child {
    padding-bottom: 64px
}

@media only screen and (min-width:768px) {
    .l-container__inner--article-column {
        border-top-width: 0;
        padding-top: 0
    }

    .l-container__inner--article-column:first-child {
        padding-top: 40px
    }

    .l-container__inner--article-column:last-child {
        padding-bottom: 120px;
        padding-top: 104px
    }

    .l-container__inner--contact-area {
        padding-bottom: 144px;
        padding-top: 144px
    }
}

.l-container__inner--article-movie {
    border-top: 1px solid rgba(80, 129, 165, .15);
    padding-bottom: 0;
    padding-top: 16px
}

.l-container__inner--article-movie+.l-container__inner--article-movie {
    border-top-width: 0
}

.l-container__inner--article-movie:last-child {
    padding-bottom: 128px
}

@media only screen and (min-width:768px) {
    .l-container__inner--article-movie {
        border-top-width: 0;
        padding-top: 0
    }

    .l-container__inner--article-movie:first-child {
        padding-top: 1px;
        -webkit-transform: translateY(-1px);
        transform: translateY(-1px)
    }

    .l-container__inner--article-movie:last-child {
        padding-bottom: 80px
    }
}

.l-container__headline {
    margin-left: auto;
    margin-right: auto;
    max-width: 1200px;
    padding-left: 24px;
    padding-right: 24px
}

@media only screen and (min-width:768px) {
    .l-container__headline {
        padding-left: 0;
        padding-right: 0
    }
}

.l-container__member-intro {
    margin-left: auto;
    margin-right: auto;
    max-width: 1200px
}

@media only screen and (min-width:768px) {
    .l-container__member-intro {
        padding-bottom: 120px
    }
}

.l-container__inner-case-detail {
    margin-left: auto;
    margin-right: auto;
    margin-top: -56px;
    max-width: 1200px;
    padding-bottom: 80px;
    padding-left: 24px;
    padding-right: 24px;
    width: 100%
}

@media only screen and (min-width:768px) {
    .l-container__inner-case-detail {
        margin-top: -64px;
        padding-bottom: 120px;
        padding-left: 120px;
        padding-right: 120px
    }
}

.l-main {
    flex-grow: 1
}

.l-main.is-screen-lock {
    position: relative;
    top: 49px
}

@media only screen and (min-width:768px) {
    .l-section-article-single {
        background: #fafafa;
        padding: 32px 0 64px
    }
}

.l-section-article-single__hero {
    margin: 32px 0 8px;
    padding: 0 24px
}

@media only screen and (min-width:768px) {
    .l-section-article-single__hero {
        margin: 0 auto;
        max-width: 960px;
        padding: 0
    }
}

.l-section-article-single__inner {
    background: #fff;
    padding: 24px 24px 64px
}

@media only screen and (min-width:768px) {
    .l-section-article-single__inner {
        margin: 0 auto;
        max-width: 960px;
        padding: 48px 120px 80px
    }
}

.c-article-accordion+.c-article-accordion {
    margin-top: 16px
}

.c-article-accordion:first-child {
    margin-top: 32px
}

@media only screen and (min-width:768px) {
    .c-article-accordion:first-child {
        margin-top: 64px
    }
}

.c-article-detail__lead+.c-article-accordion,
.c-article-detail__text+.c-article-accordion {
    margin-top: 24px
}

@media only screen and (min-width:768px) {

    .c-article-detail__lead+.c-article-accordion,
    .c-article-detail__text+.c-article-accordion {
        margin-top: 32px
    }
}

.c-article-detail__text-link+.c-article-accordion {
    margin-top: 24px
}

@media only screen and (min-width:768px) {
    .c-article-detail__text-link+.c-article-accordion {
        margin-top: 40px
    }
}

.c-article-accordion__summary {
    align-items: center;
    background: #fafafa;
    cursor: pointer;
    display: flex;
    gap: 32px;
    justify-content: space-between;
    padding: 16px 24px
}

.c-article-accordion__summary::-webkit-details-marker {
    display: none
}

@media only screen and (min-width:768px) {
    .c-article-accordion__summary {
        padding: 16px 32px
    }
}

.c-article-accordion__summary>.c-icon-plus {
    stroke: #124a7b;
    display: block;
    flex-shrink: 0;
    height: 24px;
    width: 24px
}

@media only screen and (min-width:768px) {
    .c-article-accordion__summary>.c-icon-plus {
        height: 32px;
        width: 32px
    }
}

.c-article-accordion__summary--open>.c-icon-plus>.c-icon-plus__path:first-child {
    display: none
}

.c-article-accordion__title {
    font-size: 1.6rem;
    font-weight: 700
}

@media only screen and (min-width:768px) {
    .c-article-accordion__title {
        font-size: 2.4rem
    }
}

.c-article-accordion__contents {
    padding: 32px 0
}

.c-article-annotation {
    color: rgba(20, 33, 43, .5);
    font-size: 1.4rem;
    line-height: 160%;
    margin-top: 24px
}

@media only screen and (min-width:768px) {
    .c-article-annotation {
        font-size: 1.6rem;
        margin-top: 32px
    }
}

.c-article-author-information {
    background: #fafafa;
    margin-top: 48px;
    padding: 32px 24px
}

@media only screen and (min-width:768px) {
    .c-article-author-information {
        margin-top: 64px;
        padding: 64px 48px
    }
}

.c-article-author-information__header {
    display: flex;
    flex-direction: column;
    gap: 16px
}

@media only screen and (min-width:768px) {
    .c-article-author-information__header {
        align-items: center;
        flex-direction: row;
        gap: 32px
    }
}

.c-article-author-information__img {
    flex-shrink: 0;
    height: 120px;
    object-fit: cover;
    object-position: top center;
    width: 120px
}

@media only screen and (min-width:768px) {
    .c-article-author-information__img {
        height: 160px;
        width: 160px
    }
}

.c-article-author-information__information {
    display: flex;
    flex-direction: column;
    gap: 8px
}

.c-article-author-information__name {
    font-size: 2.4rem;
    font-weight: 700;
    line-height: 150%
}

@media only screen and (min-width:768px) {
    .c-article-author-information__name {
        font-size: 3.2rem;
        line-height: 180%
    }
}

.c-article-author-information__overview {
    color: rgba(20, 33, 43, .7);
    font-size: 1.4rem;
    line-height: 160%
}

.c-article-author-information__texts {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin-top: 32px;
    width: 100%
}

@media only screen and (min-width:768px) {
    .c-article-author-information__texts {
        margin-top: 48px
    }
}

.c-article-author-information__texts-title {
    font-size: 1.8rem;
    font-weight: 700;
    line-height: 180%
}

.c-article-author-information__texts-text {
    font-size: 1.4rem;
    line-height: 160%
}

@media only screen and (min-width:768px) {
    .c-article-author-information__texts-text {
        font-size: 1.6rem
    }
}

.c-article-author-information__list {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin-top: 32px
}

@media only screen and (min-width:768px) {
    .c-article-author-information__list {
        margin-top: 48px
    }
}

.c-article-author-information__list-title {
    font-size: 1.6rem;
    font-weight: 700;
    line-height: 160%
}

@media only screen and (min-width:768px) {
    .c-article-author-information__list-title {
        font-size: 1.8rem;
        line-height: 180%
    }
}

.c-article-author-information__list-list {
    display: flex;
    flex-direction: column
}

.c-article-author-information__list-item {
    display: flex;
    font-size: 1.4rem;
    gap: 8px;
    line-height: 160%
}

@media only screen and (min-width:768px) {
    .c-article-author-information__list-item {
        font-size: 1.6rem
    }
}

.c-article-author-information__list-item:before {
    content: "・"
}

.c-article-author-information__books {
    margin-top: 32px
}

@media only screen and (min-width:768px) {
    .c-article-author-information__books {
        margin-top: 48px
    }
}

.c-article-author-information__books-title {
    font-size: 1.8rem;
    font-weight: 700;
    line-height: 180%
}

.c-article-author-information__books-list {
    display: flex;
    gap: 16px;
    margin-top: 16px
}

@media only screen and (min-width:768px) {
    .c-article-author-information__books-list {
        gap: 64px
    }
}

.c-article-author-information__books-item {
    align-items: center;
    display: flex;
    flex: 1;
    flex-direction: column;
    gap: 16px;
    max-width: calc(33.33333% - 10.66667px)
}

@media only screen and (min-width:768px) {
    .c-article-author-information__books-item {
        max-width: calc(33.33333% - 42.66667px)
    }

    .c-article-author-information__books-picture {
        max-width: 80px
    }
}

.c-article-author-information__books-name {
    font-size: 1.4rem;
    line-height: 160%
}

@media only screen and (min-width:768px) {
    .c-article-author-information__books-name {
        font-size: 1.6rem
    }
}

.c-article-box {
    background: #fafafa;
    border: 1px solid rgba(80, 129, 165, .15);
    color: rgba(20, 33, 43, .7);
    font-size: 1.4rem;
    line-height: 160%;
    margin-top: 32px;
    padding: 16px
}

@media only screen and (min-width:768px) {
    .c-article-box {
        font-size: 1.8rem;
        line-height: 180%;
        padding: 24px 32px
    }
}

.c-article-box__title {
    font-weight: 700
}

.c-article-box__text {
    margin-top: 8px
}

.c-article-box__byline {
    color: rgba(20,33,43,.7);
    font-size: 1.4rem;
    line-height: 1.6;
    margin-top: 4px;
    text-align: right;
}

.c-article-column-links {
    display: flex;
    flex-direction: column;
    gap: 16px
}

@media only screen and (min-width:768px) {
    .c-article-column-links {
        gap: 24px
    }
}

.c-article-column-links__title {
    font-size: 2rem;
    font-weight: 700;
    line-height: 180%
}

@media only screen and (min-width:768px) {
    .c-article-column-links__title {
        font-size: 2.4rem
    }
}

.c-article-column-links__list {
    border-bottom: 1px solid rgba(80, 129, 165, .15);
    margin-left: -24px;
    width: 100vw
}

@media only screen and (min-width:768px) {
    .c-article-column-links__list {
        border-bottom-width: 0;
        display: flex;
        gap: 24px;
        justify-content: space-between;
        margin-left: 0;
        width: 100%
    }

    .c-article-column-links__item {
        flex: 1
    }
}

.c-article-column-links__link {
    align-items: center;
    border-top: 1px solid rgba(80, 129, 165, .15);
    display: flex;
    font-size: 1.6rem;
    gap: 16px;
    justify-content: space-between;
    line-height: 160%;
    padding: 24px
}

@media only screen and (min-width:768px) {
    .c-article-column-links__link {
        border: none;
        font-size: 1.8rem;
        line-height: 180%;
        outline: 1px solid rgba(80, 129, 165, .15);
        outline-offset: -1px;
        padding: 16px 24px
    }
}

.c-article-column-links__link:hover {
    color: #0062b2
}

@media only screen and (min-width:768px) {
    .c-article-column-links__link:hover {
        outline-offset: -2px;
        outline-width: 2px
    }
}

.c-article-column-links__link:hover>.c-icon-transition>.c-icon-transition__group>.c-icon-transition__path {
    stroke: #0062b2
}

.c-article-column-links__link>.c-icon-transition {
    height: 32px;
    width: 32px
}

@media only screen and (min-width:768px) {
    .c-article-column-links__link>.c-icon-transition {
        height: 40px;
        width: 40px
    }
}

.c-article-column-links__link>.c-icon-transition>.c-icon-transition__group>.c-icon-transition__path {
    stroke-width: 1px
}

.c-article-commentator-information-list {
    background: #fafafa;
    display: flex;
    flex-direction: column;
    margin-top: 48px;
    padding: 24px;
    row-gap: 16px
}

@media only screen and (min-width:768px) {
    .c-article-commentator-information-list {
        margin-top: 80px;
        padding: 48px;
        row-gap: 24px
    }
}

.c-article-commentator-information-list__heading {
    border-bottom: 1px solid rgba(80, 129, 165, .15);
    font-size: 1.4rem;
    font-weight: 700;
    line-height: 160%;
    padding-bottom: 8px
}

@media only screen and (min-width:768px) {
    .c-article-commentator-information-list__heading {
        font-size: 1.8rem;
        line-height: 180%
    }
}

.c-article-commentator-information {
    border-bottom: 1px solid rgba(80, 129, 165, .15);
    padding-bottom: 24px
}

@media only screen and (min-width:768px) {
    .c-article-commentator-information {
        padding-bottom: 32px
    }
}

.c-article-commentator-information__name {
    font-size: 2rem;
    font-weight: 700;
    line-height: 1.8
}

@media only screen and (min-width:768px) {
    .c-article-commentator-information__name {
        font-size: 3.2rem;
        line-height: 1.6
    }
}

.c-article-commentator-information__profile {
    color: rgba(20, 33, 43, .7);
    font-size: 1.4rem;
    line-height: 1.6;
    margin-top: 4px
}

.c-article-commentator-information__description {
    font-size: 1.4rem;
    line-height: 1.6;
    margin-top: 8px
}

@media only screen and (min-width:768px) {
    .c-article-commentator-information__description {
        font-size: 1.6rem;
        margin-top: 16px
    }
}

.c-article-detail {
    font-size: 1.6rem;
    line-height: 1.6
}

@media only screen and (min-width:768px) {
    .c-article-detail {
        font-size: 1.8rem
    }
}

.c-article-detail__lead {
    margin-top: 32px
}

@media only screen and (min-width:768px) {
    .c-article-detail__lead {
        margin-top: 40px
    }
}

.c-article-detail__text {
    font-size: 1.6rem;
    line-height: 160%;
    margin-top: 24px
}

@media only screen and (min-width:768px) {
    .c-article-detail__text {
        font-size: 2rem;
        line-height: 180%
    }
}

.c-article-detail__text+.c-article-detail__text {
    margin-top: 1.8em
}

.c-article-detail__text:first-child {
    margin-top: 32px
}

@media only screen and (min-width:768px) {
    .c-article-detail__text:first-child {
        margin-top: 40px
    }
}

.c-article-accordion__contents .c-article-detail__text:first-child,
.c-article-detail__heading-small+.c-article-detail__text {
    margin-top: 0
}

.c-article-detail__heading-extra-small+.c-article-detail__text,
.c-article-image+.c-article-detail__text {
    margin-top: 32px
}

.c-article-detail__bold {
    font-weight: 700
}

.c-article-detail__underline {
    -webkit-text-decoration: underline;
    text-decoration: underline;
    -webkit-text-decoration-thickness: 4px;
    text-decoration-thickness: 4px;   
    -webkit-text-decoration-color: rgba(187, 142, 0, .5);
    text-decoration-color: rgba(187, 142, 0, .5);
    -webkit-text-decoration-skip-ink: none;
    text-decoration-skip-ink: none;
    text-underline-offset: -.01em
}

.c-article-detail__color-red {
    color: red
}

.c-article-detail__heading {
    font-size: 1.8rem;
    font-weight: 700;
    line-height: 1.8;
    margin: 8px 0 24px;
    padding-left: 22px;
    padding-top: 40px;
    position: relative
}

@media only screen and (min-width:768px) {
    .c-article-detail__heading {
        font-size: 3.2rem;
        margin: 40px 0 32px;
        padding-left: 30px
    }
}

.c-article-detail__heading:before {
    background: #0062b2;
    content: "";
    display: block;
    height: calc(100% - 40px);
    left: 0;
    position: absolute;
    top: 40px;
    width: 6px
}

@media only screen and (min-width:768px) {
    .c-article-detail__heading:before {
        height: calc(69% - 27.6px);
        top: 50%;
        -webkit-transform: translateY(calc(-50% + 20px));
        transform: translateY(calc(-50% + 20px))
    }
}

.c-article-detail__heading-small {
    font-size: 1.6rem;
    font-weight: 700;
    line-height: 1.6;
    margin: 48px 0 0;
    padding-bottom: 32px;
    position: relative
}

@media only screen and (min-width:768px) {
    .c-article-detail__heading-small {
        font-size: 2.4rem;
        margin: 64px 0 24px
    }
}

.c-article-detail__heading+.c-article-detail__heading-small {
    margin-top: 24px
}

@media only screen and (min-width:768px) {
    .c-article-detail__heading+.c-article-detail__heading-small {
        margin-top: 32px
    }
}

.c-article-accordion__contents .c-article-detail__heading-small {
    margin-top: 32px
}

.c-article-accordion__contents .c-article-detail__heading-small:first-child {
    margin-top: 0
}

.c-article-detail__heading-small:after,
.c-article-detail__heading-small:before {
    background: rgba(80, 129, 165, .15);
    bottom: 15px;
    content: "";
    display: block;
    height: 2px;
    left: 0;
    position: absolute;
    width: 100%
}

.c-article-detail__heading-small:after {
    background: #0062b2;
    width: 20px
}

.c-article-detail__heading-small__mark {
    display: flex
}

.c-article-detail__heading-small__mark:before {
    margin-right: 5px
}

.c-article-detail__heading-small__mark--cross:before {
    content: "×"
}

.c-article-detail__heading-small__mark--circle:before {
    content: "○"
}

.c-article-detail__heading-extra-small {
    background: rgba(80, 129, 165, .05);
    color: #124a7b;
    font-size: 1.6rem;
    font-weight: 700;
    line-height: 160%;
    margin-top: 32px;
    padding: 8px 24px
}

@media only screen and (min-width:768px) {
    .c-article-detail__heading-extra-small {
        font-size: 2rem;
        line-height: 180%;
        padding: 8px 32px
    }
}

.c-article-detail__heading-extra-small:first-child,
.c-article-detail__heading-small+.c-article-detail__heading-extra-small {
    margin-top: 0
}

.c-article-detail__text-link {
    margin-top: 32px
}

.c-article-detail__text-link--last {
    margin-top: 48px
}

@media only screen and (min-width:768px) {
    .c-article-detail__text-link--last {
        margin-top: 80px
    }
}

.c-article-image+.c-article-detail__text-link {
    margin-top: 16px
}

@media only screen and (min-width:768px) {
    .c-article-image+.c-article-detail__text-link {
        margin-top: 32px
    }
}

.c-article-accordion+.c-article-detail__text-link {
    margin-top: 16px
}

@media only screen and (min-width:768px) {
    .c-article-accordion+.c-article-detail__text-link {
        margin-top: 24px
    }
}

.c-article-detail__text-link-link {
    color: #0062b2;
    display: inline-block;
    font-size: 1.6rem;
    text-decoration: underline
}

@media only screen and (min-width:768px) {
    .c-article-detail__text-link-link {
        font-size: 2rem
    }
}

.c-article-detail__note {
    color: rgba(20, 33, 43, .5);
    font-size: 1.4rem;
    line-height: 160%;
    margin-top: 16px
}

@media only screen and (min-width:768px) {
    .c-article-detail__note {
        font-size: 1.6rem;
        margin-top: 32px
    }
}

.c-article-list__row .c-article-detail__note {
    margin-top: 8px
}

.c-article-detail__caption {
    color: rgba(20, 33, 43, .7);
    font-size: 1.6rem;
    line-height: 160%;
    margin-top: 32px
}

.c-article-detail__contact {
    display: flex;
    flex-direction: column;
    font-size: 1.6rem;
    gap: 8px;
    line-height: 160%
}

@media only screen and (min-width:768px) {
    .c-article-detail__contact {
        font-size: 2rem;
        line-height: 180%
    }
}

.c-article-detail__contact-title {
    font-weight: 700
}

.c-article-detail__contact-data+.c-article-detail__contact-data {
    margin-top: 32px
}

.c-article-detail__column {
    display: flex
}

.c-article-detail__column-title {
    flex-shrink: 0;
    padding-right: 1em
}

.c-article-header__title {
    font-size: 2.4rem;
    line-height: 1.5;
    margin: 0
}

@media only screen and (min-width:768px) {
    .c-article-header__title {
        font-size: 4rem;
        line-height: 1.6
    }
}

.c-article-header__info {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin-top: 16px
}

@media only screen and (min-width:768px) {
    .c-article-header__info {
        align-items: baseline;
        flex-direction: row;
        gap: 16px
    }
}

.c-article-header__category {
    color: #5081a5;
    display: flex;
    font-size: 1.6rem;
    gap: 16px;
    line-height: 1.6
}

@media only screen and (min-width:768px) {
    .c-article-header__category {
        font-size: 1.8rem;
        line-height: 1
    }
}

.c-article-header__category-link {
    color: #5081a5
}

.c-article-header__date {
    align-items: center;
    color: rgba(20, 33, 43, .7);
    display: flex;
    font-size: 1.4rem;
    gap: 4px;
    line-height: 1.6
}

@media only screen and (min-width:768px) {
    .c-article-header__date {
        font-size: 1.6rem
    }
}

.c-article-header__eventType {
    border: 1px solid #124a7b;
    color: #124a7b;
    display: inline-block;
    font-size: 1.2rem;
    font-weight: 700;
    line-height: 160%;
    margin-top: 8px;
    padding: 4px 12px
}

@media only screen and (min-width:768px) {
    .c-article-header__eventType {
        font-size: 1.6rem;
        font-weight: 400;
        margin-top: 16px
    }
}

.c-article-header__image {
    aspect-ratio: 16/9;
    margin-top: 32px;
    object-fit: cover;
    width: 100%
}

.c-article-header__endEvent {
    background: #fafafa;
    display: flex;
    flex-direction: column;
    font-size: 1.6rem;
    gap: 8px;
    line-height: 160%;
    margin-top: 32px;
    padding: 24px
}

@media only screen and (min-width:768px) {
    .c-article-header__endEvent {
        padding: 32px 48px
    }
}

.c-article-header__endEvent__title {
    font-size: 1.8rem;
    font-weight: 700;
    line-height: 180%
}

.c-article-heading-list {
    font-size: 1.6rem;
    line-height: 160%;
    margin-top: 16px
}

@media only screen and (min-width:768px) {
    .c-article-heading-list {
        margin-top: 32px
    }
}

.c-article-heading-list+.c-article-heading-list {
    margin-top: 32px
}

@media only screen and (min-width:768px) {
    .c-article-heading-list {
        font-size: 2rem
    }
}

.c-article-heading-list__row {
    align-items: center;
    border-bottom: 1px solid rgba(80, 129, 165, .15);
    -webkit-column-gap: 8px;
    column-gap: 8px;
    display: flex;
    padding: 16px 0
}

.c-article-heading-list__title {
    flex: 0 0 80px;
    font-weight: 700
}

@media only screen and (min-width:768px) {
    .c-article-heading-list__title {
        flex: 0 0 200px
    }
}

.c-article-hero--movie {
    padding-top: 56.25%;
    position: relative;
    width: 100%
}

.c-article-hero--movie__iframe {
    bottom: 0;
    height: 100%;
    left: 0;
    position: absolute;
    right: 0;
    top: 0;
    width: 100%
}

.c-article-image {
    display: flex;
    flex-direction: column;
    gap: 16px;
    margin-top: 32px
}

@media only screen and (min-width:768px) {
    .c-article-image {
        gap: 8px
    }
}

.c-article-image--zoom-in {
    position: relative
}

.c-article-accordion__contents .c-article-image:first-child,
.c-article-detail__heading-small+.c-article-image {
    margin-top: 0
}

.c-article-image__img--tax {
    width: 270px
}

@media only screen and (min-width:768px) {
    .c-article-image__img--tax {
        width: auto
    }
}

.c-article-image__caption {
    color: rgba(20, 33, 43, .5);
    font-size: 1.4rem;
    line-height: 160%
}

.c-article-image>.c-icon-zoom-in {
    bottom: 8px;
    height: 24px;
    position: absolute;
    right: 8px;
    width: 24px
}

@media only screen and (min-width:768px) {
    .c-article-image>.c-icon-zoom-in {
        display: none
    }
}

.c-article-index-list {
    display: flex;
    flex-direction: column;
    gap: 16px
}

@media only screen and (min-width:768px) {
    .c-article-index-list {
        padding: 0 32px
    }
}

.c-article-index-list__link {
    color: #0062b2;
    font-size: 1.6rem;
    line-height: 160%
}

.c-article-index-list__link:hover {
    opacity: .6
}

.c-article-link {
    background: #0062b2;
    color: #fff;
    display: inline-block;
    font-size: 1.6rem;
    font-weight: 700;
    line-height: 100%;
    margin-top: 32px;
    padding: 14px 20px;
    position: relative;
    text-align: center
}

@media only screen and (min-width:768px) {
    .c-article-link {
        font-size: 1.8rem;
        line-height: 180%;
        min-width: 344px;
        padding: 20px 32px
    }
}

.c-article-link:hover:after {
    background-color: rgba(20, 33, 43, .25);
    bottom: 0;
    content: "";
    height: 5px;
    left: 0;
    position: absolute;
    width: 100%
}

.c-article-list {
    display: flex;
    flex-direction: column;
    gap: 8px
}

@media only screen and (min-width:768px) {
    .c-article-list {
        gap: 24px
    }
}

.c-article-detail__note+.c-article-list,
.c-article-detail__text+.c-article-list,
.c-article-image+.c-article-list {
    padding-top: 24px
}

.c-article-detail__heading-extra-small+.c-article-list {
    padding-top: 32px
}

.c-article-list__row {
    font-size: 1.6rem;
    line-height: 160%;
    padding-left: 24px;
    position: relative
}

@media only screen and (min-width:768px) {
    .c-article-list__row {
        font-size: 2rem;
        padding-left: 28px
    }
}

.c-article-list__row:before {
    content: "・";
    display: inline-block;
    left: 0;
    position: absolute;
    top: 0
}

.c-article-list--number {
    gap: 16px
}

.c-article-list--number__row {
    display: flex;
    gap: 8px;
    line-height: 160%;
    padding-left: 0
}

@media only screen and (min-width:768px) {
    .c-article-list--number__row {
        line-height: 180%
    }
}

.c-article-list--number__row:before {
    display: none
}

.c-article-list--number__container {
    margin-top: 8px
}

@media only screen and (min-width:768px) {
    .c-article-list--number__container {
        margin-top: 24px
    }
}

.c-article-list--definition {
    gap: 16px
}

.c-article-list--definition__row {
    display: flex;
    flex-direction: column;
    gap: 16px;
    line-height: 180%;
    padding-left: 0
}

.c-article-list--definition__row:before {
    display: none
}

.c-article-list--definition__note {
    color: rgba(20, 33, 43, .5);
    font-size: 1.4rem;
    line-height: 160%
}

@media only screen and (min-width:768px) {
    .c-article-list--definition__note {
        font-size: 1.6rem
    }
}

.c-article-source {
    color: rgba(20, 33, 43, .5);
    font-size: 1.4rem;
    line-height: 160%;
    margin-top: 48px
}

@media only screen and (min-width:768px) {
    .c-article-source {
        font-size: 1.6rem;
        margin-top: 64px
    }
}

.c-article-table+.c-article-source {
    margin-top: 24px
}

.c-article-source__header {
    display: flex;
    gap: 16px
}

.c-article-source__title {
    flex-shrink: 0
}

.c-article-source__info {
    display: flex;
    flex-direction: column;
    gap: 4px;
    margin-top: 4px
}

.c-article-source__link {
    color: rgba(20, 33, 43, .5)
}

.c-article-table {
    border-collapse: collapse;
    margin-top: 24px;
    width: 100%
}

.c-article-table__data,
.c-article-table__head-header,
.c-article-table__header {
    border: 1px solid #d5dce2;
    font-size: 1.6rem;
    padding: 24px 16px
}

@media only screen and (min-width:768px) {

    .c-article-table__data,
    .c-article-table__head-header,
    .c-article-table__header {
        font-size: 2rem
    }
}

.c-article-table__head-header {
    font-weight: 700;
    text-align: left
}

.c-article-table__header {
    font-weight: 400;
    text-align: left;
    vertical-align: middle;
    width: 82px
}

@media only screen and (min-width:768px) {
    .c-article-table__header {
        width: 160px
    }
}

.c-article-table__header--narrowest {
    white-space: nowrap;
    width: 0
}

@media only screen and (min-width:768px) {

    .c-article-table--large .c-article-table__data,
    .c-article-table--large .c-article-table__head-header,
    .c-article-table--large .c-article-table__header {
        padding-left: 32px;
        padding-right: 32px
    }
}

.c-article-table--kyosai-type .c-article-table__header {
    width: 98px
}

@media only screen and (min-width:768px) {
    .c-article-table--kyosai-type .c-article-table__header {
        width: 207px
    }
}

.c-article-table--bereaved-family .c-article-table__header {
    width: 82px
}

@media only screen and (min-width:768px) {
    .c-article-table--bereaved-family .c-article-table__header {
        width: 126px
    }
}

.c-article-table--bereaved-family .c-article-table__header+.c-article-table__data {
    width: 115px
}

@media only screen and (min-width:768px) {
    .c-article-table--bereaved-family .c-article-table__header+.c-article-table__data {
        width: 206px
    }
}

.c-article-table--souzoku-procedure .c-article-table__header {
    width: 32%
}

@media only screen and (min-width:768px) {
    .c-article-table--souzoku-procedure .c-article-table__header {
        width: 210px
    }
}

.c-article-table--souzoku-procedure .c-article-table__header+.c-article-table__data {
    width: 34%
}

@media only screen and (min-width:768px) {
    .c-article-table--souzoku-procedure .c-article-table__header+.c-article-table__data {
        width: 260px
    }
}

.c-article-table--souzoku-price {
    margin-top: 8px
}

.c-article-table--souzoku-price .c-article-table__header {
    font-weight: 700;
    vertical-align: top;
    width: 53%
}

@media only screen and (min-width:768px) {
    .c-article-table--souzoku-price .c-article-table__header {
        width: 250px
    }
}

.c-article-table--souzoku-price .c-article-table__data,
.c-article-table--souzoku-price .c-article-table__header {
    border-width: 0;
    padding: 8px 16px 8px 0
}

.c-article-table--souzoku-price .c-article-table__row:nth-child(3) .c-article-table__data,
.c-article-table--souzoku-price .c-article-table__row:nth-child(3) .c-article-table__header {
    border-top-width: 3px
}

.c-article-table--criterion {
    table-layout: fixed
}

.c-article-table--criterion .c-article-table__data,
.c-article-table--criterion .c-article-table__header {
    vertical-align: top;
    width: 33.3%;
    word-break: break-all
}

.c-article-table--family .c-article-table__head-header,
.c-article-table--property .c-article-table__head-header {
    font-size: 1.6rem;
    font-weight: 400;
    padding: 16px 8px;
    text-align: center
}

.c-article-table--family .c-article-table__data,
.c-article-table--family .c-article-table__header,
.c-article-table--property .c-article-table__data,
.c-article-table--property .c-article-table__header {
    font-size: 1.6rem;
    padding: 16px 8px;
    text-align: center
}

.c-article-table--family .c-article-table__header {
    width: 20%
}

.c-article-table--family .c-article-table__data:first-of-type {
    width: 25%
}

.c-article-table--property .c-article-table__header {
    width: 38%
}

.c-article-table .c-article-table__heading-color {
    background: #124a7b;
    color: #fff
}

.c-article-table .c-article-table__accent-color {
    background: #5081a5;
    color: #fff
}

.c-article-table .c-article-table__base-color-01 {
    background: #f2f7fa
}

.c-article-table .c-article-table__base-color-02 {
    background: #f6fbf5
}

.c-article-teacher-information+.c-article-teacher-information {
    margin-top: 32px
}

@media only screen and (min-width:768px) {
    .c-article-teacher-information+.c-article-teacher-information {
        margin-top: 64px
    }
}

.c-article-teacher-information__header {
    align-items: center;
    display: flex;
    gap: 16px
}

@media only screen and (min-width:768px) {
    .c-article-teacher-information__header {
        gap: 32px
    }
}

.c-article-teacher-information__img {
    flex-shrink: 0;
    height: 90px;
    object-fit: cover;
    width: 90px
}

@media only screen and (min-width:768px) {
    .c-article-teacher-information__img {
        height: 160px;
        width: 160px
    }
}

.c-article-teacher-information__information {
    display: flex;
    flex-direction: column;
    gap: 4px
}

.c-article-teacher-information__name {
    font-size: 1.6rem;
    font-weight: 700;
    line-height: 160%
}

@media only screen and (min-width:768px) {
    .c-article-teacher-information__name {
        font-size: 3.2rem;
        line-height: 180%
    }
}

.c-article-teacher-information__overview {
    color: rgba(20, 33, 43, .5);
    font-size: 1.4rem;
    line-height: 160%
}

.c-article-teacher-information__career,
.c-article-teacher-information__profile {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin-top: 24px;
    width: 100%
}

.c-article-teacher-information__career-title,
.c-article-teacher-information__profile-title {
    font-size: 1.6rem;
    font-weight: 700;
    line-height: 160%
}

@media only screen and (min-width:768px) {

    .c-article-teacher-information__career-title,
    .c-article-teacher-information__profile-title {
        font-size: 1.8rem;
        line-height: 180%
    }
}

.c-article-teacher-information__career-row,
.c-article-teacher-information__career-text,
.c-article-teacher-information__profile-row,
.c-article-teacher-information__profile-text {
    font-size: 1.4rem;
    line-height: 160%
}

@media only screen and (min-width:768px) {

    .c-article-teacher-information__career-row,
    .c-article-teacher-information__career-text,
    .c-article-teacher-information__profile-row,
    .c-article-teacher-information__profile-text {
        font-size: 1.6rem
    }
}

.c-article-teacher-information__career-list {
    display: flex;
    flex-direction: column;
    gap: 8px
}

.c-article-teacher-information__career-row {
    display: flex;
    gap: 8px
}

.c-article-teacher-information__career-year {
    display: inline-block;
    flex-shrink: 0;
    min-width: 4.2em
}

.c-article-time-list {
    display: flex;
    flex-direction: column;
    gap: 16px
}

@media only screen and (min-width:768px) {
    .c-article-time-list {
        padding: 0 32px
    }
}

.c-article-time-list__row {
    align-items: center;
    display: flex;
    gap: 16px
}

.c-article-time-list__title {
    color: rgba(20, 33, 43, .7);
    font-size: 1.8rem
}

.c-article-time-list__data {
    color: #14212b;
    font-size: 1.6rem
}

.c-articles-swiper {
    display: block
}

.c-articles-swiper__title {
    font-size: 2rem;
    font-weight: 700;
    letter-spacing: .24px;
    line-height: 180%
}

@media only screen and (min-width:768px) {
    .c-articles-swiper__title {
        font-size: 2.4rem;
        font-weight: 700;
        letter-spacing: .288px;
        line-height: 150%
    }
}

.c-articles-swiper__tabs {
    display: flex;
    margin-top: 16px;
    position: relative
}

@media only screen and (min-width:768px) {
    .c-articles-swiper__tabs {
        margin-top: 32px
    }
}

.c-articles-swiper__tabs--list {
    margin-top: 0
}

.c-articles-swiper__tabs--list>.c-articles-swiper__tab>.c-articles-swiper__tab__button {
    height: 76px
}

.c-articles-swiper__tabs--column-list {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    margin-top: 0
}

@media only screen and (min-width:768px) {
    .c-articles-swiper__tabs--column-list {
        display: flex;
        margin-top: 40px
    }
}

.c-articles-swiper__tab,
.c-articles-swiper__tab__button {
    width: 100%
}

.c-articles-swiper__body {
    display: none;
    margin-top: 32px
}

@media only screen and (min-width:768px) {
    .c-articles-swiper__body {
        margin-top: 40px
    }
}

.c-articles-swiper__body--show {
    display: block
}

@media only screen and (min-width:768px) {
    .c-articles-swiper__body--has-tab {
        margin-top: 40px
    }
}

.c-articles-swiper__articles-wrapper {
    margin-left: -24px;
    width: 100vw
}

@media only screen and (min-width:768px) {
    .c-articles-swiper__articles-wrapper {
        margin-left: 0;
        width: 100%
    }
}

.c-articles-swiper__articles {
    display: flex
}

.c-articles-swiper__pagination {
    margin-top: 26px
}

@media only screen and (min-width:768px) {
    .c-articles-swiper__pagination {
        margin-top: 40px
    }
}

.c-breadcrumbs {
    padding: 24px 0
}

.c-breadcrumbs__list {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 16px
}

@media only screen and (min-width:768px) {
    .c-breadcrumbs__list {
        flex-wrap: nowrap
    }
}

.c-breadcrumbs__item {
    align-items: center;
    display: flex;
    flex-shrink: 1;
    gap: 16px;
    min-width: 0;
    text-decoration: none
}

@media only screen and (min-width:768px) {
    .c-breadcrumbs__item {
        flex-shrink: 0
    }

    .c-breadcrumbs__item:last-child {
        flex-shrink: 1
    }
}

.c-breadcrumbs__item>.c-icon-arrow {
    flex-shrink: 0;
    height: 24px;
    -webkit-transform: rotate(180deg);
    transform: rotate(180deg);
    width: 24px
}

.c-breadcrumbs__item>.c-icon-arrow>.c-icon-arrow__group>.c-icon-arrow__path {
    stroke: rgba(20, 33, 43, .5)
}

.c-breadcrumbs__link,
.c-breadcrumbs__text {
    color: rgba(20, 33, 43, .5);
    font-size: 1.4rem;
    line-height: 100%;
    overflow: hidden;
    text-decoration: none;
    text-overflow: ellipsis;
    transition: .3s;
    white-space: nowrap
}

.c-breadcrumbs__link .c-breadcrumbs__text:hover {
    color: #0062b2
}

.c-button-group {
    padding-bottom: 40px;
    padding-top: 32px
}

@media only screen and (min-width:768px) {
    .c-button-group {
        padding-top: 40px
    }
}

.c-button-group__label {
    font-size: 2rem;
    font-weight: 700;
    letter-spacing: .24px;
    line-height: 180%
}

@media only screen and (min-width:768px) {
    .c-button-group__label {
        font-size: 2.4rem;
        letter-spacing: .288px;
        line-height: 150%
    }
}

.c-button-group__button-wrapper {
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(2, 1fr);
    justify-content: space-between;
    margin-top: 24px
}

@media only screen and (min-width:768px) {
    .c-button-group__button-wrapper {
        -webkit-column-gap: 24px;
        column-gap: 24px;
        display: flex;
        row-gap: 0
    }
}

.c-button-group__button-wrapper>.c-navigation-link {
    font-size: 1.6rem;
    font-weight: 400;
    letter-spacing: .192px;
    line-height: 160%;
    outline: 1px solid #14212b;
    outline-offset: -1px;
    padding: 6px 4px;
    text-align: center
}

.c-button-group__button-wrapper>.c-navigation-link:hover {
    outline-offset: -2px;
    outline-width: 2px
}

.c-button-group__button-wrapper>.c-navigation-link:nth-child(2) {
    grid-column: 1/2
}

@media only screen and (min-width:768px) {
    .c-button-group__button-wrapper>.c-navigation-link {
        flex: 1;
        font-size: 2rem;
        grid-row-start: none;
        letter-spacing: .24px;
        line-height: 180%;
        padding: 8px 24px
    }

    .c-button-group__button-wrapper>.c-navigation-link:nth-child(2) {
        grid-column: initial
    }
}

.c-case-card {
    background: #fff;
    display: flex;
    flex-direction: column;
    margin-top: -64px
}

@media only screen and (min-width:768px) {
    .c-case-card {
        flex-direction: row
    }
}

.c-case-card__image-container {
    flex-grow: 0
}

.c-case-card__image {
    flex-shrink: 0;
    height: auto;
    width: 100%
}

@media only screen and (min-width:768px) {
    .c-case-card__image {
        align-self: center;
        height: 270px;
        object-fit: cover;
        width: 480px
    }
}

.c-case-card__detail {
    display: flex;
    flex-direction: column;
    flex-grow: 1;
    gap: 40px;
    outline: 1px solid rgba(80, 129, 165, .15);
    outline-offset: -1px;
    padding: 24px
}

@media only screen and (min-width:768px) {
    .c-case-card__detail {
        padding: 40px 48px
    }
}

.c-case-card__detail__label {
    color: rgba(20, 33, 43, .5);
    font-size: 1.4rem;
    font-weight: 400;
    letter-spacing: .168px;
    line-height: 160%
}

@media only screen and (min-width:768px) {
    .c-case-card__detail__label {
        font-size: 1.6rem;
        letter-spacing: .192px;
        line-height: 150%
    }
}

.c-case-card__consulter {
    display: flex;
    flex-direction: column
}

@media only screen and (min-width:768px) {
    .c-case-card__consulter {
        gap: 12px
    }
}

.c-case-card__consulter>.c-case-card__info-wrapper {
    align-items: flex-end;
    -webkit-column-gap: 12px;
    column-gap: 12px;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap
}

.c-case-card__consulter__type {
    font-size: 1.8rem;
    font-weight: 700;
    letter-spacing: .216px;
    line-height: 180%
}

@media only screen and (min-width:768px) {
    .c-case-card__consulter__type {
        font-size: 2.4rem;
        letter-spacing: .288px;
        line-height: 150%
    }
}

.c-case-card__consulter__info {
    font-size: 1.4rem;
    font-weight: 400;
    letter-spacing: .168px;
    line-height: 160%
}

@media only screen and (min-width:768px) {
    .c-case-card__consulter__info {
        font-size: 1.6rem;
        letter-spacing: .192px
    }
}

.c-case-card__subject {
    display: flex;
    flex-direction: column
}

@media only screen and (min-width:768px) {
    .c-case-card__subject {
        gap: 12px
    }
}

.c-case-card__subject__ul {
    -webkit-column-gap: 20px;
    column-gap: 20px;
    display: flex;
    flex-wrap: wrap
}

.c-case-card__subject__item-a {
    color: #5081a5;
    font-size: 1.6rem;
    font-weight: 700;
    letter-spacing: .192px;
    line-height: 160%
}

.c-case-card__subject__item-a:hover {
    color: #0062b2
}

@media only screen and (min-width:768px) {
    .c-case-card__subject__item-a {
        font-size: 1.8rem;
        letter-spacing: .216px;
        line-height: 180%
    }
}

.c-case-event-panel {
    display: flex;
    flex-direction: column
}

.c-case-event-panel:hover>.c-case-event-panel__body>.c-case-event-panel__title {
    color: #0062b2
}

.c-case-event-panel:hover>.c-icon-transition>.c-icon-transition__group>.c-icon-transition__path {
    stroke: #0062b2
}

@media only screen and (min-width:768px) {
    .c-case-event-panel {
        flex-direction: row
    }
}

.c-case-event-panel__image {
    flex-shrink: 0;
    height: auto;
    width: 100%
}

@media only screen and (min-width:768px) {
    .c-case-event-panel__image {
        align-self: center;
        height: 216px;
        object-fit: cover;
        width: 384px
    }
}

.c-case-event-panel__header {
    display: flex;
    flex-direction: column;
    row-gap: 8px
}

@media only screen and (min-width:768px) {
    .c-case-event-panel__header {
        align-items: center;
        -webkit-column-gap: 32px;
        column-gap: 32px;
        flex-direction: row
    }
}

.c-case-event-panel__category-wrapper {
    -webkit-column-gap: 8px;
    column-gap: 8px;
    display: flex
}

.c-case-event-panel__tag {
    font-size: 1.2rem;
    padding: 4px 12px
}

@media only screen and (min-width:768px) {
    .c-case-event-panel__tag {
        font-size: 1.6rem
    }
}

.c-case-event-panel__tag--is-category {
    background-color: #5081a5;
    color: #fff;
    font-weight: 700
}

@media only screen and (min-width:768px) {
    .c-case-event-panel__tag--is-category {
        font-weight: 400
    }
}

.c-case-event-panel__tag--is-label {
    color: #124a7b;
    outline: 1px solid #124a7b;
    outline-offset: -1px
}

.c-case-event-panel__date {
    color: #124a7b;
    font-size: 1.4rem;
    letter-spacing: .168px;
    line-height: 160%
}

@media only screen and (min-width:768px) {
    .c-case-event-panel__date {
        font-size: 1.8rem;
        letter-spacing: .216px;
        line-height: 180%
    }
}

.c-case-event-panel__date--is-column {
    color: rgba(20, 33, 43, .5)
}

.c-case-event-panel__body {
    display: grid;
    margin-top: 12px;
    row-gap: 8px;
    width: 100%
}

@media only screen and (min-width:768px) {
    .c-case-event-panel__body {
        align-self: center;
        grid-auto-rows: -webkit-min-content;
        grid-auto-rows: min-content;
        margin-left: 40px;
        margin-top: 0
    }
}

.c-case-event-panel__title {
    -webkit-box-orient: vertical;
    display: -webkit-box;
    font-size: 1.6rem;
    font-weight: 700;
    letter-spacing: .192px;
    line-height: 160%;
    overflow: hidden
}

@media only screen and (min-width:768px) {
    .c-case-event-panel__title {
        -webkit-line-clamp: 2;
        font-size: 2.4rem
    }
}

.c-case-event-panel__description {
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
    display: -webkit-box;
    font-size: 1.4rem;
    letter-spacing: .168px;
    line-height: 160%;
    overflow: hidden
}

@media only screen and (min-width:768px) {
    .c-case-event-panel__description {
        font-size: 1.8rem
    }
}

.c-case-event-panel>.c-icon-transition {
    height: 32px;
    width: 32px
}

@media only screen and (min-width:768px) {
    .c-case-event-panel>.c-icon-transition {
        align-self: center;
        flex-shrink: 0;
        height: 40px;
        margin-left: 32px;
        width: 40px
    }
}

.c-case-fieldset {
    display: flex;
    flex-direction: column;
    gap: 48px
}

.c-case-fieldset:last-child {
    margin-bottom: 0
}

.c-case-fieldset__legend {
    align-items: center;
    color: #124a7b;
    display: flex;
    font-size: 1.8rem;
    font-weight: 700;
    gap: 32px;
    letter-spacing: .216px;
    line-height: 180%;
    white-space: nowrap
}

.c-case-fieldset__legend:after {
    background-color: rgba(80, 129, 165, .15);
    content: "";
    height: 1px;
    width: 100%
}

.c-case-fieldset__content {
    align-items: flex-start;
    display: flex;
    flex-direction: column;
    gap: 24px;
    margin-left: auto;
    margin-right: auto;
    max-width: 640px
}

.c-case-fieldset__title {
    font-size: 2.4rem;
    font-weight: 700;
    letter-spacing: .288px;
    line-height: 150%
}

@media only screen and (min-width:768px) {
    .c-case-fieldset__title {
        font-size: 3.2rem;
        letter-spacing: .384px;
        line-height: 180%
    }
}

.c-case-fieldset__paragraph {
    font-size: 1.6rem;
    font-weight: 400;
    letter-spacing: .192px;
    line-height: 160%
}

@media only screen and (min-width:768px) {
    .c-case-fieldset__paragraph {
        font-size: 2rem;
        letter-spacing: .24px;
        line-height: 180%
    }
}

.c-case-fieldset__wrapper {
    display: flex;
    flex-direction: column;
    gap: 96px;
    padding-bottom: 48px;
    padding-top: 48px
}

@media only screen and (min-width:768px) {
    .c-case-fieldset__wrapper {
        gap: 80px;
        padding-bottom: 80px;
        padding-top: 64px
    }
}

.c-case-fieldset__proposals {
    background-color: #fafafa;
    display: flex;
    flex-direction: column;
    gap: 16px;
    padding: 32px 24px;
    width: 100%
}

@media only screen and (min-width:768px) {
    .c-case-fieldset__proposals {
        padding: 32px
    }
}

.c-case-fieldset__proposals__item {
    align-items: center;
    display: flex;
    font-size: 1.6rem;
    font-weight: 400;
    gap: 12px;
    letter-spacing: .192px;
    line-height: 160%
}

@media only screen and (min-width:768px) {
    .c-case-fieldset__proposals__item {
        font-size: 2rem;
        letter-spacing: .24px;
        line-height: 180%
    }
}

.c-case-fieldset__proposals__item:before {
    background-color: #bb8e00;
    border-radius: 50%;
    content: "";
    flex-shrink: 0;
    height: 6px;
    width: 6px
}

.c-case-headline {
    display: flex;
    flex: 1 0 0;
    flex-direction: column;
    padding-bottom: 80px;
    padding-top: 32px;
    row-gap: 16px
}

@media only screen and (min-width:768px) {
    .c-case-headline {
        padding: 48px 120px 96px;
        row-gap: 16px
    }
}

.c-case-headline__number {
    background-color: #124a7b;
    color: #fff;
    font-size: 1.2rem;
    font-weight: 700;
    letter-spacing: .144px;
    line-height: 160%;
    padding: 4px 8px
}

@media only screen and (min-width:768px) {
    .c-case-headline__number {
        font-size: 1.8rem;
        letter-spacing: .216px;
        line-height: 100%;
        padding: 8px 16px
    }
}

.c-case-headline__headline {
    font-size: 2.4rem;
    font-weight: 700;
    letter-spacing: .288px;
    line-height: 150%
}

@media only screen and (min-width:768px) {
    .c-case-headline__headline {
        font-size: 4rem;
        letter-spacing: .48px;
        line-height: 160%
    }
}

.c-case-list {
    display: flex;
    flex-direction: column;
    padding-bottom: 80px;
    padding-top: 32px;
    row-gap: 48px
}

@media only screen and (min-width:768px) {
    .c-case-list {
        padding-bottom: 120px;
        padding-top: 48px
    }
}

.c-case-list__filter {
    display: flex;
    flex-direction: column;
    gap: 24px;
    margin-bottom: 32px
}

@media only screen and (min-width:768px) {
    .c-case-list__filter {
        gap: 40px;
        margin-bottom: 48px
    }
}

.c-case-navigation-bar {
    background-color: #14212b
}

.c-case-navigation-bar__list {
    display: flex;
    flex-direction: column;
    padding: 40px 24px;
    row-gap: 32px
}

@media only screen and (min-width:768px) {
    .c-case-navigation-bar__list {
        flex-direction: row;
        margin-left: auto;
        margin-right: auto;
        max-width: 1200px;
        padding: 40px 0
    }
}

.c-case-navigation-bar__list__item {
    font-size: 2rem;
    font-weight: 700;
    letter-spacing: .24px;
    line-height: 180%;
    position: relative
}

@media only screen and (min-width:768px) {
    .c-case-navigation-bar__list__item {
        padding-left: 60px;
        padding-right: 60px
    }

    .c-case-navigation-bar__list__item:first-child {
        padding-left: 0
    }

    .c-case-navigation-bar__list__item:after {
        background-color: #fff;
        bottom: 0;
        content: "";
        display: block;
        height: 24px;
        margin: auto 0;
        position: absolute;
        right: 0;
        top: 0;
        width: 1px
    }

    .c-case-navigation-bar__list__item:last-child {
        padding-right: 0
    }

    .c-case-navigation-bar__list__item:last-child:after {
        content: none
    }
}

.c-case-navigation-bar__list__item__link {
    align-items: center;
    color: #fff;
    display: flex
}

.c-case-navigation-bar__list__item__link>.c-icon-transition {
    margin-left: 8px
}

.c-case-navigation-bar__list__item__link>.c-icon-transition>.c-icon-transition__group>.c-icon-transition__path {
    stroke: #fff
}

.c-column-tab {
    align-items: center;
    color: rgba(20, 33, 43, .5);
    display: flex;
    font-size: 1.6rem;
    height: 58px;
    justify-content: center;
    position: relative;
    text-align: center
}

@media only screen and (min-width:768px) {
    .c-column-tab {
        font-size: 2rem;
        height: 60px
    }
}

.c-column-tab:before {
    background-color: rgba(80, 129, 165, .15);
    bottom: 0;
    content: "";
    height: 2px;
    left: 0;
    position: absolute;
    width: 100%
}

.c-column-tab:hover {
    color: #0062b2
}

.c-column-tab--checked {
    background-color: rgba(80, 129, 165, .05);
    color: #124a7b;
    font-weight: 700;
    pointer-events: none
}

.c-column-tab--checked:before {
    background-color: #124a7b
}

.c-contact-area {
    color: #fff;
    display: flex;
    flex-direction: column;
    gap: 48px
}

@media only screen and (min-width:768px) {
    .c-contact-area {
        flex-direction: row;
        justify-content: space-between
    }
}

.c-contact-area__header {
    display: flex;
    flex-direction: column;
    gap: 16px
}

@media only screen and (min-width:768px) {
    .c-contact-area__header {
        gap: 32px
    }
}

.c-contact-area__title {
    font-size: 3.2rem;
    font-weight: 700;
    line-height: 180%
}

@media only screen and (min-width:768px) {
    .c-contact-area__title {
        font-size: 5.6rem;
        line-height: 160%
    }
}

.c-contact-area__description {
    font-size: 1.6rem;
    line-height: 160%
}

@media only screen and (min-width:768px) {
    .c-contact-area__description {
        font-size: 2.4rem;
        line-height: 180%
    }
}

.c-contact-area__list {
    display: flex;
    flex-direction: column;
    gap: 48px
}

@media only screen and (min-width:768px) {
    .c-contact-area__list {
        gap: 64px
    }
}

.c-contact-area__item {
    display: flex;
    flex-direction: column;
    gap: 20px
}

.c-contact-area__item-title {
    font-size: 2rem;
    font-weight: 700;
    letter-spacing: .24px;
    line-height: 180%
}

@media only screen and (min-width:768px) {
    .c-contact-area__item-title {
        font-size: 2.4rem;
        letter-spacing: .288px;
        line-height: 100%
    }
}

.c-contact-area__item-description {
    font-size: 1.6rem;
    font-weight: 400;
    margin-left: 24px
}

@media only screen and (min-width:768px) {
    .c-contact-area__item-description {
        font-size: 1.8rem
    }
}

.c-contact-area__button {
    align-items: center;
    background: #fff;
    color: #0062b2;
    display: flex;
    font-size: 2.2rem;
    font-weight: 700;
    gap: 16px;
    justify-content: flex-start;
    line-height: 100%;
    padding: 20px 32px;
    text-decoration: none
}

@media only screen and (min-width:768px) {
    .c-contact-area__button {
        min-width: 484px
    }
}

.c-contact-area__button>.c-icon-mail,
.c-contact-area__button>.c-icon-tel {
    height: 32px;
    width: 32px
}

.c-contact-area__button>.c-icon-mail>.c-icon-mail__group>.c-icon-mail__path,
.c-contact-area__button>.c-icon-tel>.c-icon-tel__group>.c-icon-tel__path {
    stroke-width: 2px;
    stroke: #0062b2
}

@media only screen and (min-width:768px) {
    .c-contact-area__button--tel {
        background: transparent;
        border: 1px solid #fff;
        color: #fff;
        pointer-events: none
    }

    .c-contact-area__button--tel>.c-icon-tel>.c-icon-tel__group>.c-icon-tel__path {
        stroke: #fff
    }
}

.c-contact-area__button:hover {
    background-color: #124a7b
}

.c-contact-area__button:hover>.c-icon-mail>.c-icon-mail__group>.c-icon-mail__path {
    stroke: #fff
}

.c-contact-area__button:hover>.c-contact-area__button-text {
    color: #fff;
    -webkit-text-decoration-color: #fff;
    text-decoration-color: #fff;
    -webkit-text-decoration-line: underline;
    text-decoration-line: underline;
    text-decoration-thickness: 1px;
    text-underline-offset: 3px
}

.c-contact-area__button-text {
    align-items: center;
    display: flex;
    flex: 1;
    justify-content: center
}

.c-contact-area__button-inner {
    align-items: flex-start;
    display: inline-flex;
    flex-direction: column;
    gap: 8px;
    margin: 0 auto;
    padding: 0 8px
}

@media only screen and (min-width:768px) {
    .c-contact-area__button-inner {
        align-items: center;
        flex-direction: row;
        justify-content: center
    }
}

.c-contact-area__button-free {
    font-size: 1.4rem;
    line-height: 110%
}

.c-contact-area__button-number {
    font-family: Roboto Flex, sans-serif;
    font-size: 2.6rem;
    line-height: 100%
}

.c-contact-area__time {
    display: flex;
    font-size: 1.6rem;
    font-weight: 400;
    gap: 16px;
    line-height: 160%;
    margin-top: 8px
}

@media only screen and (min-width:768px) {
    .c-contact-area__time {
        font-size: 1.8rem
    }
}

.c-contact-area__time-br {
    display: inline
}

@media only screen and (min-width:768px) {
    .c-contact-area__time-br {
        display: none
    }
}

.c-corresponding-issue {
    color: rgba(20, 33, 43, .5);
    display: flex;
    flex-direction: column;
    font-size: 1.4rem;
    gap: 4px;
    letter-spacing: .216px;
    line-height: 160%;
    margin-top: 32px
}

@media only screen and (min-width:768px) {
    .c-corresponding-issue {
        flex-direction: row;
        font-size: 1.8rem;
        gap: 16px;
        margin-top: 64px
    }
}

.c-corresponding-issue__title {
    flex-shrink: 0;
    font-weight: 700
}

@media only screen and (min-width:768px) {
    .c-corresponding-issue__title-inner {
        border-right: 1px solid rgba(80, 129, 165, .15);
        display: inline-block;
        padding-right: 24px
    }
}

.c-corresponding-issue__body {
    display: flex-wrap
}

@media only screen and (min-width:768px) {
    .c-corresponding-issue__body {
        display: flex
    }

    .c-corresponding-issue__body--show-paragraph {
        display: block
    }
}

.c-corresponding-issue__text {
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
    display: -webkit-box;
    overflow: hidden
}

@media only screen and (min-width:768px) {
    .c-corresponding-issue__text {
        -webkit-line-clamp: 1
    }
}

.c-corresponding-issue__body--show-paragraph .c-corresponding-issue__text {
    display: block
}

@media only screen and (min-width:768px) {
    .c-corresponding-issue__body--show-paragraph .c-corresponding-issue__text {
        display: inline
    }
}

.c-corresponding-issue__toggle {
    cursor: pointer;
    display: block;
    flex-shrink: 0;
    text-align: right;
    text-decoration: underline
}

@media only screen and (min-width:768px) {
    .c-corresponding-issue__toggle {
        display: inline;
        margin-left: 1em
    }
}

.c-corresponding-issue__toggle:before {
    content: "全て表示"
}

.c-corresponding-issue__body--show-paragraph .c-corresponding-issue__toggle:before {
    content: "閉じる"
}

.c-detail-anchor-links {
    display: grid;
    grid-auto-rows: -webkit-min-content;
    grid-auto-rows: min-content;
    row-gap: 24px
}

@media only screen and (min-width:768px) {
    .c-detail-anchor-links {
        row-gap: 32px
    }
}

.c-detail-anchor-links__title {
    font-size: 1.8rem;
    font-weight: 700;
    letter-spacing: .216px;
    line-height: 180%
}

@media only screen and (min-width:768px) {
    .c-detail-anchor-links__title {
        font-size: 3.2rem;
        letter-spacing: .384px
    }
}

.c-detail-anchor-links__links {
    display: flex
}

.c-detail-anchor-links__links--wrap {
    display: grid;
    gap: 16px 20px;
    grid-template-columns: repeat(2, 1fr)
}

@media only screen and (min-width:768px) {
    .c-detail-anchor-links__links--wrap {
        display: flex;
        flex-wrap: nowrap
    }

    .c-detail-anchor-links__links {
        -webkit-column-gap: 64px;
        column-gap: 64px
    }
}

.c-detail-anchor-links__link-wrapper {
    flex: 1;
    padding: 0 16px
}

.c-detail-anchor-links__links--wrap .c-detail-anchor-links__link-wrapper {
    flex: auto;
    padding: 0
}

@media only screen and (min-width:768px) {
    .c-detail-anchor-links__link-wrapper {
        flex: auto;
        padding: 0
    }
}

.c-detail-anchor-links__link-wrapper+.c-detail-anchor-links__link-wrapper {
    border-left: 1px solid rgba(80, 129, 165, .15)
}

.c-detail-anchor-links__links--wrap .c-detail-anchor-links__link-wrapper+.c-detail-anchor-links__link-wrapper {
    border-left: none
}

@media only screen and (min-width:768px) {
    .c-detail-anchor-links__link-wrapper+.c-detail-anchor-links__link-wrapper {
        border-left: none
    }
}

.c-detail-anchor-links__link-wrapper:first-child {
    grid-column: 1/3;
    padding-left: 0
}

.c-detail-anchor-links__link-wrapper:last-child {
    padding-right: 0
}

.c-detail-anchor-links__link {
    align-items: center;
    display: flex;
    flex-direction: column;
    height: 83px;
    justify-content: flex-end;
    row-gap: 2px
}

.c-detail-anchor-links__link:hover>.c-detail-anchor-links__link-text {
    color: #0062b2
}

.c-detail-anchor-links__link:hover>.c-icon-arrow-down>.c-icon-arrow-down__group>.c-icon-arrow-down__path {
    stroke: #0062b2
}

.c-detail-anchor-links__links--wrap .c-detail-anchor-links__link {
    -webkit-column-gap: 4px;
    column-gap: 4px;
    flex-direction: row;
    height: auto;
    justify-content: flex-start
}

@media only screen and (min-width:768px) {

    .c-detail-anchor-links__link,
    .c-detail-anchor-links__links--wrap .c-detail-anchor-links__link {
        -webkit-column-gap: 16px;
        column-gap: 16px
    }

    .c-detail-anchor-links__link {
        flex-direction: row;
        height: auto;
        justify-content: flex-start
    }
}

.c-detail-anchor-links__link>.c-icon-arrow-down {
    height: 16px;
    width: 16px
}

@media only screen and (min-width:768px) {
    .c-detail-anchor-links__link>.c-icon-arrow-down {
        height: 24px;
        width: 24px
    }
}

.c-detail-anchor-links__link>.c-icon-arrow-down>.c-icon-arrow-down__group>.c-icon-arrow-down__path {
    vector-effect: non-scaling-stroke
}

.c-detail-anchor-links__link-text {
    align-items: center;
    color: #124a7b;
    display: flex;
    font-size: 1.4rem;
    height: 100%;
    letter-spacing: .168px;
    line-height: 160%;
    text-align: center
}

@media only screen and (min-width:768px) {
    .c-detail-anchor-links__link-text {
        font-size: 2rem;
        letter-spacing: .24px
    }
}

.c-details__content {
    overflow: hidden
}

.c-details__summary:hover>.c-details__summary-text {
    color: #0062b2
}

.c-dropdown {
    background: #fff;
    height: 300px;
    left: 0;
    position: fixed;
    top: 49px;
    -webkit-transform: translateX(100%);
    transform: translateX(100%);
    transition: -webkit-transform .4s ease;
    transition: transform .4s ease;
    transition: transform .4s ease, -webkit-transform .4s ease;
    width: 100%;
    z-index: 2
}

@media only screen and (min-width:768px) {
    .c-dropdown {
        display: none
    }
}

.c-dropdown.is-open {
    -webkit-transform: translateX(0);
    transform: translateX(0)
}

.c-dropdown__inner {
    height: 100%;
    overflow: auto
}

.c-dropdown__title {
    color: rgba(20, 33, 43, .7);
    font-size: 1.6rem;
    font-weight: 700;
    margin: 32px 24px 0
}

.c-dropdown__category {
    margin-top: 16px
}

.c-dropdown__category-item {
    border-top: 1px solid rgba(80, 129, 165, .15)
}

.c-dropdown__category-item:last-child {
    border-bottom: 1px solid rgba(80, 129, 165, .15)
}

.c-dropdown__category-link {
    align-items: center;
    color: #124a7b;
    display: flex;
    justify-content: space-between;
    padding: 24px 24px 24px 40px;
    text-decoration: none
}

.c-dropdown__category-link>.c-icon-transition>.c-icon-transition__group>.c-icon-transition__path {
    stroke: #124a7b;
    height: 24px;
    width: 24px
}

.c-dropdown__nav {
    margin: 16px 0
}

.c-dropdown__nav-link {
    color: #14212b;
    display: block;
    padding: 16px 24px;
    text-decoration: none
}

.c-event-list {
    align-items: flex-start;
    display: flex;
    flex-direction: column;
    gap: 48px;
    padding-bottom: 80px;
    padding-top: 48px
}

@media only screen and (min-width:768px) {
    .c-event-list {
        gap: 120px;
        padding-bottom: 120px;
        padding-top: 64px
    }
}

.c-event-list--clamped {
    padding-bottom: 0;
    padding-top: 0
}

@media only screen and (min-width:768px) {
    .c-event-list--clamped {
        padding-bottom: 0;
        padding-top: 0
    }
}

.c-event-list__category-panel {
    display: flex;
    flex-direction: column;
    gap: 16px
}

@media only screen and (min-width:768px) {
    .c-event-list__category-panel {
        gap: 24px
    }
}

.c-event-list__category-panel__title {
    font-size: 2rem;
    font-weight: 700;
    letter-spacing: .24px;
    line-height: 180%
}

@media only screen and (min-width:768px) {
    .c-event-list__category-panel__title {
        font-size: 3.2rem;
        letter-spacing: .384px;
        line-height: 180%
    }
}

.c-event-list__category-panel__items {
    display: flex;
    flex-direction: column;
    gap: 48px
}

.c-example-card {
    background-color: #fff;
    box-shadow: 8px 16px 40px 0 rgba(80, 129, 165, .1);
    display: flex;
    flex-direction: column;
    height: 100%;
    position: relative
}

.c-example-card:hover>.c-example-card__body>.c-example-card__info>.c-example-card__title,
.c-example-card:hover>.c-example-card__body>.c-example-card__link>.c-example-card__link-text {
    color: #0062b2
}

.c-example-card:hover>.c-example-card__body>.c-example-card__link>.c-icon-transition>.c-icon-transition__group>.c-icon-transition__path {
    stroke: #0062b2
}

.c-example-card__category {
    background-color: #5081a5;
    color: #fff;
    font-size: 1.4rem;
    font-weight: 700;
    left: 0;
    letter-spacing: .168px;
    line-height: 160%;
    padding: 8px 20px;
    position: absolute;
    top: 0
}

@media only screen and (min-width:768px) {
    .c-example-card__category {
        font-size: 2rem;
        letter-spacing: 3px;
        line-height: 160%;
        padding: 8px 40px
    }
}

.c-example-card__picture {
    display: block;
    height: auto;
    width: 100%
}

.c-example-card__body {
    display: flex;
    flex-direction: column;
    height: 100%;
    justify-content: space-between;
    padding: 16px 24px 24px
}

@media only screen and (min-width:768px) {
    .c-example-card__body {
        padding: 32px 40px 24px
    }
}

.c-example-card__info {
    display: flex;
    flex-direction: column;
    height: 100%;
    min-height: 146px;
    row-gap: 8px
}

.c-example-card__title {
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 4;
    display: -webkit-box;
    font-size: 2rem;
    font-weight: 700;
    letter-spacing: .24px;
    line-height: 180%;
    overflow: hidden
}

@media only screen and (min-width:768px) {
    .c-example-card__title {
        -webkit-line-clamp: 3;
        font-size: 2.4rem;
        letter-spacing: .288px;
        line-height: 150%
    }
}

.c-example-card__text {
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
    display: -webkit-box;
    font-size: 1.4rem;
    height: 66px;
    letter-spacing: .168px;
    line-height: 160%;
    overflow: hidden
}

@media only screen and (min-width:768px) {
    .c-example-card__text {
        -webkit-line-clamp: 2;
        font-size: 1.8rem;
        letter-spacing: .216px;
        line-height: 180%
    }
}

.c-example-card__link {
    margin-top: 16px
}

.c-example-card__link>.c-icon-transition {
    height: 32px;
    margin-left: 8px;
    width: 32px
}

@media only screen and (min-width:768px) {
    .c-example-card__link>.c-icon-transition {
        height: 40px;
        width: 40px
    }
}

.c-example-card__link>.c-icon-transition>.c-icon-transition__group>.c-icon-transition__path {
    stroke: #124a7b
}

.c-example-card__link-text {
    color: #124a7b;
    font-size: 1.6rem;
    letter-spacing: .192px;
    line-height: 160%;
    vertical-align: top
}

@media only screen and (min-width:768px) {
    .c-example-card__link-text {
        font-size: 1.8rem;
        letter-spacing: .216px;
        line-height: 180%
    }
}

.c-faq-list {
    margin-left: -24px;
    width: 100vw
}

@media only screen and (min-width:768px) {
    .c-faq-list {
        margin-left: 0;
        width: 100%
    }
}

.c-faq-list--article {
    margin-left: 0;
    width: 100%
}

.c-faq {
    position: relative
}

.c-faq:after {
    background-color: rgba(80, 129, 165, .15);
    bottom: 0;
    content: "";
    height: 1px;
    left: 0;
    position: absolute;
    width: 100%
}

.c-faq__mark {
    font-family: Roboto Flex, sans-serif;
    font-size: 2.4rem;
    font-weight: 700;
    letter-spacing: .288px;
    line-height: 180%
}

.c-faq__summary {
    color: #124a7b;
    -webkit-column-gap: 16px;
    column-gap: 16px;
    cursor: pointer;
    display: flex;
    padding: 24px;
    position: relative
}

.c-faq__summary::-webkit-details-marker {
    display: none
}

@media only screen and (min-width:768px) {
    .c-faq__summary {
        -webkit-column-gap: 32px;
        column-gap: 32px;
        padding: 24px 48px
    }
}

.c-faq__summary>.c-icon-plus {
    flex-shrink: 0;
    height: 32px;
    -webkit-transform: translateY(6px);
    transform: translateY(6px);
    width: 32px
}

.c-faq__summary--open>.c-icon-plus>.c-icon-plus__path:first-child {
    display: none
}

.c-faq__answer-mark {
    color: #bb8e00
}

.c-faq__text {
    flex: 1;
    font-size: 1.6rem;
    letter-spacing: .192px;
    line-height: 160%
}

@media only screen and (min-width:768px) {
    .c-faq__text {
        font-size: 2rem;
        letter-spacing: .24px;
        line-height: 180%
    }
}

.c-faq__text--center {
    align-items: center;
    display: flex
}

.c-faq__answer {
    background-color: #fafafa;
    -webkit-column-gap: 16px;
    column-gap: 16px;
    display: flex;
    padding: 24px
}

@media only screen and (min-width:768px) {
    .c-faq__answer {
        -webkit-column-gap: 32px;
        column-gap: 32px;
        padding: 24px 108px 24px 48px
    }
}

.c-faq__link {
    color: #0062b2;
    cursor: pointer;
    font-size: 1.6rem;
    letter-spacing: .24px;
    line-height: 180%;
    -webkit-text-decoration-color: #0062b2;
    text-decoration-color: #0062b2;
    -webkit-text-decoration-line: underline;
    text-decoration-line: underline;
    text-underline-offset: 4px
}

@media only screen and (min-width:768px) {
    .c-faq__link {
        font-size: 2rem
    }
}

.c-figure-caption-center {
    display: block;
    position: relative
}

.c-figure-caption-center__picture {
    display: block
}

.c-figure-caption-center__image {
    aspect-ratio: 1;
    height: 100%;
    object-fit: cover;
    width: 100%
}

@media only screen and (min-width:768px) {
    .c-figure-caption-center__image {
        aspect-ratio: 69/80
    }
}

.c-figure-caption-center__caption {
    background-color: hsla(0, 0%, 100%, .9);
    color: #124a7b;
    font-size: 1.2rem;
    font-weight: 700;
    left: 0;
    letter-spacing: .168px;
    line-height: 160%;
    padding: 4px 12px;
    position: absolute;
    top: 0;
    white-space: nowrap
}

@media only screen and (min-width:768px) {
    .c-figure-caption-center__caption {
        font-size: 1.8rem;
        letter-spacing: .216px;
        line-height: 180%;
        padding: 12px 20px
    }
}

.c-figure-map {
    background-color: #fff;
    display: grid;
    grid-template-rows: 46px auto;
    padding: 24px
}

@media only screen and (min-width:768px) {
    .c-figure-map {
        grid-template-rows: 82px auto;
        padding: 32px
    }
}

.c-figure-map__picture {
    grid-row: 2/3;
    height: 100%;
    width: 100%
}

.c-figure-map__caption {
    align-items: center;
    color: #124a7b;
    display: flex;
    font-size: 1.4rem;
    font-weight: 700;
    letter-spacing: .168px;
    line-height: 160%;
    position: relative
}

@media only screen and (min-width:768px) {
    .c-figure-map__caption {
        font-size: 2.4rem;
        letter-spacing: .288px;
        line-height: 150%
    }
}

.c-figure-map__caption__quantity {
    font-family: Roboto Flex, sans-serif;
    font-size: 2.4rem;
    letter-spacing: .288px;
    line-height: 150%;
    margin-left: 12px;
    position: relative;
    top: -2.6px
}

@media only screen and (min-width:768px) {
    .c-figure-map__caption__quantity {
        font-size: 4.8rem;
        letter-spacing: .576px;
        line-height: 160%
    }
}

.c-figure-map__caption__unit {
    font-size: 1.4rem;
    font-weight: 400;
    letter-spacing: .168px;
    line-height: 160%;
    margin-left: 4.55px;
    position: relative;
    top: -.8px
}

@media only screen and (min-width:768px) {
    .c-figure-map__caption__unit {
        font-size: 2rem;
        letter-spacing: .24px;
        line-height: 180%;
        top: 5px
    }
}

.c-follow-buttons {
    background: hsla(0, 0%, 100%, .9);
    border-top: 1px solid rgba(80, 129, 165, .15);
    bottom: 0;
    left: 0;
    opacity: 0;
    position: fixed;
    transition: opacity .3s ease;
    visibility: hidden;
    width: 100%;
    z-index: 50
}

@media only screen and (min-width:768px) {
    .c-follow-buttons {
        border-top-width: 0
    }
}

.c-follow-buttons--show {
    opacity: 1;
    position: -webkit-sticky;
    position: sticky;
    visibility: visible
}

.c-follow-buttons__inner {
    align-items: center;
    display: flex;
    justify-content: center
}

@media only screen and (min-width:768px) {
    .c-follow-buttons__inner {
        gap: 32px;
        height: 10vh;
        max-height: 104px;
        min-height: 70px
    }
}

.c-follow-buttons__link {
    align-items: center;
    display: flex;
    justify-content: center;
    padding: 20px 0;
    position: relative;
    width: 100%
}

@media only screen and (min-width:768px) {
    .c-follow-buttons__link {
        aspect-ratio: 584/72;
        max-width: 584px;
        min-width: 372px;
        padding: 0;
        width: 52.8vh
    }
}

.c-follow-buttons__link--mail {
    background-color: #0062b2
}

@media only screen and (min-width:768px) {
    .c-follow-buttons__link--mail:hover {
        background-color: #124a7b
    }

    .c-follow-buttons__link--mail:hover>.c-follow-buttons__mail--not-hover {
        display: none
    }

    .c-follow-buttons__link--mail:hover>.c-follow-buttons__mail--hover {
        display: block
    }
}

.c-follow-buttons__link--tel {
    background-color: #fff
}

@media only screen and (min-width:768px) {
    .c-follow-buttons__link--tel {
        border: 1px solid #0062b2;
        pointer-events: none
    }
}

.c-follow-buttons__image {
    height: 24px;
    width: auto
}

.c-follow-buttons__mail--hover {
    display: none
}

@media only screen and (min-width:768px) {
    .c-follow-buttons__mail {
        height: 3.5vh;
        max-height: 38px;
        min-height: 24.6px
    }

    .c-follow-buttons__tel {
        height: 4.5vh;
        max-height: 49px;
        min-height: 31.7px
    }
}

.c-footer__category {
    border-bottom: 1px solid rgba(80, 129, 165, .15)
}

@media only screen and (min-width:768px) {
    .c-footer__category {
        border-bottom-width: 0;
        display: flex;
        gap: 120px;
        margin: 40px auto 0;
        max-width: 1200px
    }
}

.c-footer__category-summary {
    align-items: center;
    border-top: 1px solid rgba(80, 129, 165, .15);
    color: #124a7b;
    display: flex;
    font-size: 1.6rem;
    gap: 16px;
    justify-content: space-between;
    padding: 24px
}

.c-footer__category-summary::-webkit-details-marker {
    display: none
}

@media only screen and (min-width:768px) {
    .c-footer__category-summary {
        display: none
    }
}

.c-footer__category-summary>.c-icon-plus {
    display: block;
    flex-shrink: 0;
    height: 32px;
    width: 32px
}

.c-footer__category-summary>.c-icon-plus>.c-icon-plus__path {
    stroke: #124a7b
}

.c-footer__category-summary--open>.c-icon-plus>.c-icon-plus__path:first-child {
    display: none
}

.c-footer__category-contents {
    background: #fafafa
}

@media only screen and (min-width:768px) {
    .c-footer__category-contents {
        background: none
    }
}

.c-footer__category-list {
    display: flex;
    flex-direction: column;
    gap: 32px;
    padding: 32px 24px
}

@media only screen and (min-width:768px) {
    .c-footer__category-list {
        gap: 12px;
        padding: 0
    }
}

.c-footer__category-item {
    color: rgba(20, 33, 43, .5);
    display: flex;
    gap: 16px
}

@media only screen and (min-width:768px) {
    .c-footer__category-item {
        justify-content: space-between
    }
}

.c-footer__category-link {
    color: rgba(20, 33, 43, .5);
    display: flex;
    flex: 1;
    flex-direction: column;
    font-size: 1.6rem;
    gap: 12px;
    line-height: 160%;
    text-decoration: none
}

.c-footer__category-link:hover {
    color: #0062b2
}

.c-footer__category-link--large {
    min-width: 8em;
    white-space: nowrap
}

@media only screen and (min-width:768px) {
    .c-footer__category-link--header {
        color: #124a7b
    }

    .c-footer__category-link--header:after {
        background-color: rgba(80, 129, 165, .15);
        content: "";
        display: block;
        height: 1px;
        width: 24px
    }
}

.c-footer__nav {
    display: flex;
    flex-direction: column;
    margin: 0 auto;
    max-width: 1200px;
    padding: 40px 24px 24px;
    row-gap: 16px
}

@media only screen and (min-width:768px) {
    .c-footer__nav {
        flex-direction: row;
        justify-content: space-between;
        padding: 56px 0 40px
    }
}

.c-footer__logo {
    align-items: flex-end;
    display: flex;
    gap: 8px
}

.c-footer__logo>.c-logo {
    height: 28px
}

@media only screen and (min-width:768px) {
    .c-footer__logo>.c-logo {
        height: 32px
    }
}

.c-footer__logo-title {
    color: #5081a5;
    font-size: 1.2rem;
    font-weight: 700;
    line-height: 135%
}

@media only screen and (min-width:768px) {
    .c-footer__logo-title {
        font-size: 1.3rem
    }
}

.c-footer__menu {
    align-items: flex-end;
    display: flex;
    flex-wrap: wrap;
    row-gap: 16px
}

.c-footer__menu-item {
    display: flex;
    font-size: 1.2rem;
    line-height: 160%
}

.c-footer__menu-item:after {
    align-items: flex-end;
    background-color: rgba(80, 129, 165, .15);
    content: "";
    display: inline-block;
    height: 22px;
    margin: 0 20px;
    width: 1px
}

.c-footer__menu-item:last-child:after {
    content: none
}

@media only screen and (min-width:768px) {
    .c-footer__menu-item {
        font-size: 1.4rem
    }
}

.c-footer__menu-link {
    color: rgba(20, 33, 43, .7);
    text-decoration: none
}

@media only screen and (min-width:768px) {
    .c-footer__menu-link {
        color: rgba(20, 33, 43, .5)
    }
}

.c-footer__menu-link:hover {
    color: #0062b2
}

.c-footer__info {
    border-top: 1px solid #eee
}

.c-footer__info-inner {
    align-items: center;
    display: flex;
    flex-direction: column;
    justify-content: center;
    margin: 0 auto;
    max-width: 1200px;
    width: 100%
}

@media only screen and (min-width:768px) {
    .c-footer__info-inner {
        flex-direction: row;
        justify-content: space-between
    }
}

.c-footer__info-copy {
    border-bottom: 1px solid #eee;
    color: rgba(20, 33, 43, .7);
    font-size: 1.2rem;
    line-height: 200%;
    padding: 16px 0;
    text-align: center;
    width: 100%
}

@media only screen and (min-width:768px) {
    .c-footer__info-copy {
        border-bottom-width: 0;
        width: auto
    }
}

.c-footer__info-link {
    display: block;
    padding: 16px 0
}

@media only screen and (min-width:768px) {
    .c-footer__info-link {
        padding: 0
    }
}

.c-footer__info-img {
    display: block;
    height: auto;
    width: 175px
}

@media only screen and (min-width:768px) {
    .c-footer__info-img {
        width: 378px
    }
}

.c-guidance-card {
    align-items: center;
    background-color: #fff;
    -webkit-column-gap: 20px;
    column-gap: 20px;
    display: flex;
    padding: 24px
}

@media only screen and (min-width:768px) {
    .c-guidance-card {
        -webkit-column-gap: 48px;
        column-gap: 48px;
        height: 100%
    }

    .c-guidance-card:hover {
        outline-offset: -2px;
        outline-width: 2px
    }
}

.c-guidance-card:hover>.c-guidance-card__body>.c-guidance-card__title {
    color: #0062b2
}

.c-guidance-card:hover>.c-guidance-card__body>.c-icon-transition>.c-icon-transition__group>.c-icon-transition__path {
    stroke: #0062b2
}

@media only screen and (min-width:768px) {
    .c-guidance-card {
        outline: 1px solid rgba(80, 129, 165, .15);
        outline-offset: -1px;
        padding: 32px 48px
    }
}

.c-guidance-card__image {
    align-self: center;
    flex-shrink: 0;
    height: 88px;
    width: 88px
}

@media only screen and (min-width:768px) {
    .c-guidance-card__image {
        height: 150px;
        width: 150px
    }
}

.c-guidance-card__body {
    display: grid;
    grid-template-columns: 1fr 32px;
    grid-template-rows: -webkit-min-content minmax(66px, auto);
    grid-template-rows: min-content minmax(66px, auto);
    row-gap: 4px;
    width: 100%
}

.c-guidance-card__body>.c-icon-transition {
    height: 32px;
    width: 32px
}

@media only screen and (min-width:768px) {
    .c-guidance-card__body>.c-icon-transition {
        align-self: center;
        height: 40px;
        width: 40px
    }

    .c-guidance-card__body {
        grid-template-columns: 1fr 40px;
        grid-template-rows: -webkit-min-content -webkit-max-content;
        grid-template-rows: min-content max-content;
        row-gap: 8px
    }
}

.c-guidance-card__title {
    font-size: 1.6rem;
    font-weight: 700;
    letter-spacing: .192px;
    line-height: 160%
}

@media only screen and (min-width:768px) {
    .c-guidance-card__title {
        font-size: 2rem;
        letter-spacing: .24px;
        line-height: 140%
    }
}

.c-guidance-card__description {
    font-size: 1.4rem;
    grid-column: 1/3;
    grid-row: 2/3;
    letter-spacing: .168px;
    line-height: 160%
}

@media only screen and (min-width:768px) {
    .c-guidance-card__description {
        font-size: 1.8rem;
        letter-spacing: .216px;
        line-height: 160%
    }
}

.c-guidance-cards__heading {
    font-size: 2rem;
    font-weight: 700;
    line-height: 180%
}

@media only screen and (min-width:768px) {
    .c-guidance-cards__heading {
        font-size: 2.4rem;
        line-height: 150%
    }
}

.c-guidance-cards__card {
    position: relative
}

.c-guidance-cards__card:before {
    top: 0
}

.c-guidance-cards__card:before,
.c-guidance-cards__card:last-child:after {
    background-color: rgba(80, 129, 165, .15);
    content: "";
    display: block;
    height: 1px;
    left: 0;
    position: absolute;
    width: 100%
}

.c-guidance-cards__card:last-child:after {
    bottom: 0
}

@media only screen and (min-width:768px) {

    .c-guidance-cards__card:before,
    .c-guidance-cards__card:last-child:after {
        content: none
    }
}

.c-guidance-cards--two-columns {
    display: grid;
    margin-left: -24px;
    width: 100vw
}

@media only screen and (min-width:768px) {
    .c-guidance-cards--two-columns {
        gap: 16px;
        grid-template-columns: 1fr 1fr;
        margin-left: 0;
        width: 100%
    }
}

.c-header {
    position: relative;
    z-index: 1
}

.c-header.is-open {
    left: 0;
    position: fixed;
    top: 0;
    width: 100vw;
    z-index: 90
}

.c-header__upper {
    border-bottom: 1px solid #e5ecf2
}

.c-header__inner {
    background: #fff;
    display: flex;
    justify-content: space-between;
    margin: 0 auto;
    max-width: 1920px;
    padding: 12px 24px
}

@media only screen and (min-width:768px) {
    .c-header__inner {
        align-items: flex-end;
        padding: 20px 40px
    }

    .c-header--top .c-header__inner {
        padding-top: 24px
    }
}

.c-header__main {
    display: flex;
    flex-direction: column;
    gap: 16px;
    margin-right: auto
}

@media only screen and (min-width:1440px) {
    .c-header__main {
        align-items: flex-end;
        flex-direction: row;
        gap: 40px
    }
}

.c-header--top .c-header__main {
    align-items: flex-end;
    flex-direction: row;
    justify-content: space-between;
    width: 100%
}

.c-header__logo-link {
    align-items: flex-end;
    display: flex;
    gap: 8px;
    text-decoration: none
}

@media only screen and (min-width:768px) {
    .c-header__logo-link {
        gap: 12px
    }
}

.c-header__logo-link:hover {
    opacity: 1
}

.c-header__logo-svg {
    display: inline-block;
    line-height: 0;
    object-fit: cover;
    width: 114px
}

@media only screen and (min-width:768px) {
    .c-header__logo-svg {
        width: 171px
    }
}

.c-header__logo-title {
    color: #5081a5;
    font-size: 1rem;
    font-weight: 700;
    letter-spacing: 0;
    line-height: 1.35
}

@media only screen and (min-width:768px) {
    .c-header__logo-title {
        font-size: 1.6rem;
        line-height: 160%
    }
}

.c-header__nav {
    display: none
}

@media only screen and (min-width:768px) {
    .c-header__nav {
        display: block;
        font-size: 1.6rem;
        letter-spacing: 0;
        line-height: 1
    }
}

@media only screen and (min-width:1440px) {
    .c-header__nav {
        line-height: 1.6
    }
}

.c-header--top .c-header__nav {
    line-height: 1.6
}

.c-header__nav-list {
    display: flex;
    gap: 24px
}

.c-header--top .c-header__nav-list {
    gap: 0
}

.c-header--top .c-header__nav-item {
    border-right: 1px solid rgba(80, 129, 165, .15);
    padding: 0 20px
}

.c-header--top .c-header__nav-item:last-child {
    border-right-width: 0;
    padding-right: 0
}

.c-header__nav-link {
    color: rgba(20, 33, 43, .5);
    text-decoration: none
}

.c-header__nav-link:hover {
    color: #0062b2
}

.c-header__nav-link--checked {
    color: #124a7b;
    pointer-events: none
}

.c-header__contact {
    display: none
}

@media only screen and (min-width:768px) {
    .c-header__contact {
        display: flex;
        flex-shrink: 0;
        gap: 16px
    }

    .c-header--top .c-header__contact {
        display: none
    }
}

.c-header__contact-tel {
    align-items: center;
    color: #124a7b;
    display: flex;
    gap: 10px
}

.c-header__contact-tel>.c-icon-tel {
    height: 22px;
    width: 22px
}

.c-header__contact-tel>.c-icon-tel>.c-icon-tel__group>.c-icon-tel__path {
    stroke-width: 1
}

.c-header__contact-inner {
    display: flex;
    flex-direction: column;
    gap: 2px
}

.c-header__contact-title {
    font-size: 1.2rem;
    line-height: 120%
}

.c-header__contact-number {
    font-size: 2.4rem;
    font-weight: 700;
    line-height: 120%
}

.c-header__contact-mail {
    align-items: center;
    background: #0062b2;
    color: #fff;
    display: flex;
    font-size: 1.8rem;
    font-weight: 700;
    gap: 8px;
    line-height: 180%;
    padding: 8px 16px;
    text-decoration: none
}

.c-header__contact-mail:hover {
    background-color: #124a7b;
    -webkit-text-decoration-color: #fff;
    text-decoration-color: #fff;
    -webkit-text-decoration-line: underline;
    text-decoration-line: underline;
    text-underline-offset: 3px
}

.c-header__contact-mail>.c-icon-mail {
    height: 20px;
    width: 20px
}

.c-header__contact-mail>.c-icon-mail>.c-icon-mail__group>.c-icon-mail__path {
    stroke-width: 3
}

.c-header__trigger {
    align-items: center;
    display: flex;
    height: 24px;
    justify-content: center;
    width: 24px
}

@media only screen and (min-width:768px) {
    .c-header__trigger {
        display: none
    }
}

.c-header__trigger .trigger-button {
    display: inline-block;
    height: 16px;
    position: relative;
    width: 24px
}

.c-header__trigger .trigger-button__line {
    background: #5081a5;
    display: inline-block;
    height: 2px;
    left: 0;
    position: absolute;
    -webkit-transform-origin: 50% 50% 0;
    transform-origin: initial;
    transition: all .4s;
    width: 100%
}

.c-header__trigger .trigger-button__line:first-child {
    top: 0
}

.c-header__trigger .trigger-button__line:nth-child(2) {
    top: 50%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%)
}

.c-header__trigger .trigger-button__line:last-child {
    bottom: 0;
    top: auto
}

.c-header__trigger.is-open .trigger-button__line:first-child {
    -webkit-transform: translateY(7px) rotate(-45deg);
    transform: translateY(7px) rotate(-45deg)
}

.c-header__trigger.is-open .trigger-button__line:nth-of-type(2) {
    opacity: 0
}

.c-header__trigger.is-open .trigger-button__line:last-child {
    -webkit-transform: translateY(-7px) rotate(45deg);
    transform: translateY(-7px) rotate(45deg)
}

.c-header__lower {
    box-shadow: 0 2px 2px 0 rgba(20, 33, 43, .1)
}

.c-header__category {
    display: none
}

@media only screen and (min-width:768px) {
    .c-header__category {
        display: flex;
        margin: 0 auto;
        max-width: 1920px
    }

    .c-header--top .c-header__category {
        display: none
    }
}

.c-header__category-item {
    flex: 1
}

.c-header__category-link {
    color: rgba(20, 33, 43, .7);
    display: block;
    font-size: 1.8rem;
    line-height: 130%;
    padding: 20px 48px 16px;
    text-align: center;
    text-decoration: none
}

.c-header__category-link.-active,
.c-header__category-link:hover {
    background: #5081a5;
    color: #fff;
    font-weight: 700
}

.c-header__category-link.-disabled {
    cursor: auto;
    pointer-events: none
}

.c-heading-background-image {
    -webkit-clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
    clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
    display: grid;
    grid-template-columns: 100%;
    grid-template-rows: auto;
    position: relative
}

.c-heading-background-image--has-guidance-cards {
    grid-template-columns: 100%;
    grid-template-rows: auto auto
}

@media only screen and (min-width:768px) {
    .c-heading-background-image--has-guidance-cards {
        row-gap: 80px
    }
}

.c-heading-background-image>.c-guidance-cards--two-columns {
    margin-left: 0
}

.c-heading-background-image__picture {
    display: block;
    height: 100vh;
    left: 0;
    position: fixed;
    top: 0;
    width: 100%
}

.c-heading-background-image__image {
    height: 100%;
    object-fit: cover;
    width: 100%
}

.c-heading-background-image__heading-large-image {
    color: #fff;
    grid-column: 1/2;
    grid-row: 1/2;
    justify-self: center;
    max-width: 1200px;
    padding: 160px 24px;
    position: relative;
    width: 100%
}

@media only screen and (min-width:768px) {
    .c-heading-background-image__heading-large-image {
        padding: 240px 0
    }
}

.c-heading-background-image__heading-large-image>.c-heading-large-image__subtitle {
    color: #fff
}

@media only screen and (min-width:768px) {
    .c-heading-background-image__heading-large-image--has-guidance-cards {
        padding-bottom: 0;
        padding-top: 200px
    }
}

.c-heading-background-image__guidance-cards {
    grid-row: 2/3;
    justify-self: center;
    max-width: 1200px
}

@media only screen and (min-width:768px) {
    .c-heading-background-image__guidance-cards {
        padding: 0 0 200px
    }
}

.c-heading-figure-column__image {
    margin-top: 48px
}

@media only screen and (min-width:768px) {
    .c-heading-figure-column__image {
        margin-top: 80px
    }
}

.c-heading-figure-column__essay {
    margin-top: 48px
}

@media only screen and (min-width:768px) {
    .c-heading-figure-column__essay {
        margin-top: 56px
    }
}

.c-heading-figure-column__title {
    font-size: 1.6rem;
    font-weight: 700;
    letter-spacing: .192px;
    line-height: 160%
}

@media only screen and (min-width:768px) {
    .c-heading-figure-column__title {
        font-size: 2.4rem;
        font-weight: 700;
        letter-spacing: .288px;
        line-height: 150%
    }
}

.c-heading-figure-column__text {
    font-size: 1.6rem;
    font-weight: 400;
    letter-spacing: .192px;
    line-height: 160%;
    margin-top: 16px
}

@media only screen and (min-width:768px) {
    .c-heading-figure-column__text {
        font-size: 1.8rem;
        font-weight: 400;
        letter-spacing: .216px;
        line-height: 180%;
        margin-top: 8px
    }
}

.c-heading-figure-column__link {
    margin-top: 32px
}

@media only screen and (min-width:768px) {
    .c-heading-figure-column__link {
        margin-top: 56px
    }
}

.c-heading-figure-youtube {
    margin: 0 auto;
    max-width: 1200px;
    padding: 80px 24px 0
}

@media only screen and (min-width:768px) {
    .c-heading-figure-youtube {
        padding: 120px 0
    }
}

.c-heading-figure-youtube__video-title {
    font-size: 1.6rem;
    font-weight: 700;
    letter-spacing: .192px;
    line-height: 160%;
    margin-top: 64px
}

@media only screen and (min-width:768px) {
    .c-heading-figure-youtube__video-title {
        font-size: 2.4rem;
        letter-spacing: .288px;
        line-height: 150%;
        margin-top: 80px
    }
}

.c-heading-figure-youtube__video {
    aspect-ratio: 16/9;
    display: block;
    margin-left: -24px;
    margin-top: 24px;
    width: 100vw
}

@media only screen and (min-width:768px) {
    .c-heading-figure-youtube__video {
        height: 80vh;
        margin-left: auto;
        margin-right: auto;
        margin-top: 32px;
        max-height: 675px;
        min-height: 460px;
        width: auto
    }
}

.c-heading-figure {
    display: grid
}

@media only screen and (min-width:768px) {
    .c-heading-figure {
        -webkit-column-gap: 120px;
        column-gap: 120px;
        grid-template-columns: minmax(auto, 768px) 312px;
        justify-content: space-between
    }

    .c-heading-figure--half {
        grid-template-columns: minmax(auto, 600px) 1fr
    }
}

.c-heading-figure--half .c-heading-figure__figure {
    justify-self: center
}

.c-heading-figure__title {
    font-size: 1.8rem;
    font-weight: 700;
    letter-spacing: .216px;
    line-height: 180%;
    margin-top: 48px
}

@media only screen and (min-width:768px) {
    .c-heading-figure__title {
        font-size: 2.4rem;
        letter-spacing: .288px;
        line-height: 150%;
        margin-top: 80px
    }
}

.c-heading-figure__text {
    margin-top: 16px
}

@media only screen and (min-width:768px) {
    .c-heading-figure__text {
        font-size: 1.8rem;
        margin-top: 24px
    }

    .c-heading-figure__text:first-of-type {
        margin-top: 8px
    }
}

.c-heading-figure__figure {
    align-items: center;
    -webkit-column-gap: 16px;
    column-gap: 16px;
    display: flex;
    justify-content: center;
    margin-top: 48px
}

@media only screen and (min-width:768px) {
    .c-heading-figure__figure {
        align-items: flex-start;
        align-self: center;
        flex-direction: column;
        grid-column: 2/3;
        grid-row: 1/4;
        margin-top: 0;
        row-gap: 16px
    }
}

.c-heading-figure__image {
    height: 160px;
    width: 160px
}

@media only screen and (min-width:768px) {
    .c-heading-figure__image {
        height: 312px;
        width: 312px
    }
}

.c-heading-figure__caption {
    color: rgba(20, 33, 43, .5);
    font-size: 1.2rem;
    line-height: 160%
}

@media only screen and (min-width:768px) {
    .c-heading-figure__caption {
        color: rgba(20, 33, 43, .7);
        font-size: 1.6rem;
        line-height: 160%
    }
}

.c-heading-icon-column {
    display: grid;
    grid-auto-rows: auto;
    grid-template-columns: 100%;
    margin: 0 auto;
    max-width: 1200px;
    padding: 80px 24px 0;
    row-gap: 48px
}

@media only screen and (min-width:768px) {
    .c-heading-icon-column {
        grid-template-columns: 600px 480px;
        grid-template-rows: auto auto;
        justify-content: space-between;
        padding: 120px 0;
        row-gap: 80px
    }
}

.c-heading-icon-column__picture {
    display: block;
    height: 160px;
    justify-self: center;
    width: 160px
}

@media only screen and (min-width:768px) {
    .c-heading-icon-column__picture {
        align-self: center;
        height: 280px;
        width: 280px
    }

    .c-heading-icon-column__guidance-cards {
        grid-column: 1/3
    }
}

.c-heading-images__images {
    display: flex;
    margin-top: 32px
}

@media only screen and (min-width:768px) {
    .c-heading-images__images {
        margin-top: 80px
    }
}

.c-heading-images__images--two-columns {
    flex-direction: column;
    margin-top: 48px;
    row-gap: 24px
}

@media only screen and (min-width:768px) {
    .c-heading-images__images--two-columns {
        -webkit-column-gap: 48px;
        column-gap: 48px;
        flex-direction: row;
        margin-top: 80px
    }
}

.c-heading-images__images--four-columns {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    margin-top: 48px
}

@media only screen and (min-width:768px) {
    .c-heading-images__images--four-columns {
        -webkit-column-gap: 32px;
        column-gap: 32px;
        grid-template-columns: repeat(4, 1fr);
        margin-top: 80px
    }
}

.c-heading-images__picture {
    height: auto;
    width: 100%
}

@media only screen and (min-width:768px) {
    .c-heading-images__picture {
        height: 100%;
        width: auto
    }
}

.c-heading-images__caption {
    color: rgba(20, 33, 43, .5);
    font-size: 1.4rem;
    letter-spacing: .168px;
    line-height: 160%;
    margin-top: 16px
}

@media only screen and (min-width:768px) {
    .c-heading-images__caption {
        font-size: 1.6rem;
        letter-spacing: .192px;
        line-height: 160%
    }
}

.c-heading-large-image-column__body {
    margin-top: 48px
}

@media only screen and (min-width:768px) {
    .c-heading-large-image-column__body {
        margin-top: 80px
    }
}

.c-guidance-cards__heading+.c-heading-large-image-column__body {
    margin-top: 16px
}

@media only screen and (min-width:768px) {
    .c-guidance-cards__heading+.c-heading-large-image-column__body {
        margin-top: 32px
    }
}

.c-heading-large-image-column__body>.c-case-event-panel+.c-case-event-panel {
    margin-top: 48px
}

.c-heading-large-image-column__button {
    margin-top: 32px
}

@media only screen and (min-width:768px) {
    .c-heading-large-image-column__button {
        margin-top: 48px
    }
}

.c-heading-large-image-column__button--sp-seperated {
    margin-top: 48px
}

@media only screen and (min-width:768px) {
    .l-container__inner--article-column .c-heading-large-image-column__button {
        margin-top: 64px
    }
}

.l-container__inner--article-movie .c-heading-large-image-column__button {
    margin-top: 64px
}

@media only screen and (min-width:768px) {
    .l-container__inner--article-movie .c-heading-large-image-column__button {
        margin-top: 80px
    }
}

.c-heading-large-image-example-card {
    overflow-x: hidden;
    padding: 80px 24px
}

@media only screen and (min-width:768px) {
    .c-heading-large-image-example-card {
        margin: 0 auto;
        max-width: 1920px;
        min-height: 854px;
        overflow: hidden;
        padding: 120px 40px;
        position: relative
    }

    .c-heading-large-image-example-card__heading-large-image {
        margin: 0 auto;
        width: 1200px
    }

    .c-heading-large-image-example-card__carousel {
        position: relative
    }

    .c-heading-large-image-example-card__carousel>.c-swiper-pagination {
        justify-content: flex-start;
        padding-left: 202px
    }

    .c-heading-large-image-example-card__carousel:after {
        background: linear-gradient(90deg, #fafafa, #fafafa 50%, hsla(0, 0%, 98%, 0));
        content: "";
        height: 100%;
        left: 0;
        position: absolute;
        top: 0;
        width: 60px
    }
}

.c-heading-large-image-example-card__carousel>.splide__track {
    overflow: unset
}

.c-heading-large-image-example-card__carousel-wrapper {
    margin-top: 64px
}

@media only screen and (min-width:768px) {
    .c-heading-large-image-example-card__carousel-wrapper {
        left: calc(50% + 50px);
        margin-top: 0;
        overflow: hidden;
        position: absolute;
        top: 120px;
        width: calc(50% - 50px)
    }
}

.c-heading-large-image-example-card__cards {
    display: flex;
    margin-top: 64px
}

.c-heading-large-image-example-card__pagination {
    margin-top: 32px
}

@media only screen and (min-width:768px) {
    .c-heading-large-image-example-card__pagination {
        margin-top: 40px
    }
}

.c-heading-large-image {
    position: relative
}

.c-heading-large-image__anchor {
    position: absolute;
    top: -40px
}

.c-heading-large-image__subtitle {
    color: #124a7b;
    font-size: 1.4rem;
    font-weight: 700
}

@media only screen and (min-width:768px) {
    .c-heading-large-image__subtitle {
        font-size: 2.4rem
    }
}

.c-heading-large-image__inner {
    display: flex;
    flex-direction: column;
    gap: 48px;
    margin-top: 8px
}

@media only screen and (min-width:768px) {
    .c-heading-large-image__inner {
        flex-direction: row;
        gap: 120px;
        justify-content: space-between;
        margin-top: 24px
    }
}

.c-heading-large-image__title {
    font-size: 3.2rem;
    font-weight: 700;
    line-height: 1.6
}

@media only screen and (min-width:768px) {
    .c-heading-large-image__title {
        font-size: 5.6rem
    }
}

.c-heading-large-image__text {
    line-height: 1.6;
    margin-top: 16px
}

.c-heading-large-image__text--note {
    font-size: 1.4rem;
    line-height: 160%;
    margin-top: 16px;
}

@media only screen and (min-width:768px) {
    .c-heading-large-image__text {
        font-size: 1.8rem;
        line-height: 1.8;
        margin-top: 24px
    }

    .c-heading-large-image__text--large {
        font-size: 2.4rem
    }

    .c-heading-large-image__text--note {
        font-size: 1.6rem;
    }
}

.c-heading-large-image__link {
    margin-top: 32px
}

@media only screen and (min-width:768px) {
    .c-heading-large-image__link {
        margin-top: 40px
    }
}

.c-heading-large-image__image {
    height: 184px;
    object-fit: cover;
    width: 100%
}

@media only screen and (min-width:768px) {
    .c-heading-large-image__image {
        flex-shrink: 0;
        height: 312px;
        width: 312px
    }
}

.c-heading-large-tall-image-column__body {
    margin-top: 48px
}

@media only screen and (min-width:768px) {
    .c-heading-large-tall-image-column__body {
        margin-top: 80px
    }
}

.c-heading-large-tall-image {
    display: flex;
    flex-direction: column;
    row-gap: 48px
}

@media only screen and (min-width:768px) {
    .c-heading-large-tall-image {
        align-items: center;
        -webkit-column-gap: 120px;
        column-gap: 120px;
        flex-direction: row;
        justify-content: space-between;
        row-gap: 0;
        width: 100%
    }

    .c-heading-large-tall-image__main {
        max-width: 600px
    }
}

.c-heading-large-tall-image__image {
    height: auto;
    width: 100%
}

@media only screen and (min-width:768px) {
    .c-heading-large-tall-image__image {
        width: 480px
    }
}

.c-headline {
    display: flex;
    flex-direction: column;
    padding-bottom: 24px;
    padding-top: 24px;
    row-gap: 16px
}

@media only screen and (min-width:768px) {
    .c-headline {
        padding: 64px 0 48px;
        row-gap: 16px
    }
}

.c-headline--padding-lg {
    padding-bottom: 32px;
    padding-top: 32px
}

@media only screen and (min-width:768px) {
    .c-headline--padding-lg {
        padding-bottom: 64px;
        padding-top: 64px
    }
}

.c-headline__headline {
    font-size: 2.4rem;
    font-weight: 700;
    letter-spacing: .288px;
    line-height: 150%
}

@media only screen and (min-width:768px) {
    .c-headline__headline {
        font-size: 4rem;
        letter-spacing: .48px;
        line-height: 160%
    }
}

.c-headline__description {
    font-size: 1.6rem;
    letter-spacing: .192px;
    line-height: 160%
}

@media only screen and (min-width:768px) {
    .c-headline__description {
        font-size: 2rem;
        letter-spacing: .24px;
        line-height: 180%
    }
}

.c-iframe-google-map {
    display: block;
    height: 560px;
    width: 100%
}

@media only screen and (min-width:768px) {
    .c-iframe-google-map {
        height: 560px
    }
}

.c-information-panel {
    display: flex;
    flex-direction: column
}

.c-information-panel:hover>.c-information-panel__header>.c-information-panel__title {
    color: #0062b2
}

.c-information-panel__picture {
    aspect-ratio: 287/190
}

@media only screen and (min-width:768px) {
    .c-information-panel__picture {
        aspect-ratio: 16/9
    }
}

.c-information-panel__picture--video {
    position: relative
}

.c-information-panel__picture--video:after,
.c-information-panel__picture--video:before {
    border-color: transparent transparent transparent #fff;
    border-style: solid;
    border-width: 10px 0 10px 17px;
    content: "";
    display: inline-block;
    height: 0;
    left: 50%;
    margin-left: 3px;
    position: absolute;
    top: 50%;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    width: 0;
    z-index: 1
}

@media only screen and (min-width:768px) {

    .c-information-panel__picture--video:after,
    .c-information-panel__picture--video:before {
        border-width: 14px 0 14px 24px;
        margin-left: 4px
    }
}

.c-information-panel__picture--video:after {
    border-color: #fff;
    border-radius: 64px;
    border-width: 1px;
    height: 48px;
    margin-left: 0;
    width: 48px
}

@media only screen and (min-width:768px) {
    .c-information-panel__picture--video:after {
        height: 80px;
        width: 80px
    }
}

.c-information-panel__image {
    height: 100%;
    object-fit: cover;
    width: 100%
}

.c-information-panel__header {
    display: flex;
    flex-direction: column;
    margin-top: 12px;
    row-gap: 8px
}

@media only screen and (min-width:768px) {
    .c-information-panel__header {
        margin-top: 16px
    }
}

.c-information-panel__date {
    color: rgba(20, 33, 43, .7);
    font-size: 1.2rem;
    letter-spacing: .012em;
    line-height: 100%
}

@media only screen and (min-width:768px) {
    .c-information-panel__date {
        font-size: 1.4rem
    }
}

.c-information-panel__title {
    font-size: 1.6rem;
    font-weight: 700;
    letter-spacing: .01em;
    line-height: 140%
}

@media only screen and (min-width:768px) {
    .c-information-panel__title {
        font-size: 1.8rem;
        letter-spacing: .012em;
        line-height: 180%
    }
}

.c-information-panel__category {
    display: flex;
    flex-direction: row;
    gap: 8px;
    margin-top: 12px
}

@media only screen and (min-width:768px) {
    .c-information-panel__category {
        gap: 16px;
        margin-top: 8px
    }
}

.c-information-panel__category__item {
    color: #5081a5;
    font-size: 1.4rem;
    letter-spacing: .012em;
    line-height: 160%
}

@media only screen and (min-width:768px) {
    .c-information-panel__category__item {
        font-size: 1.6rem
    }
}

.c-itemization-panel {
    display: flex;
    flex-direction: column;
    outline: 1px solid #eee;
    outline-offset: -1px;
    padding: 24px;
    width: 100%
}

@media only screen and (min-width:768px) {
    .c-itemization-panel {
        padding: 40px 64px
    }
}

.c-itemization-panel__title {
    color: #124a7b;
    font-size: 1.6rem;
    font-weight: 700;
    letter-spacing: .192px;
    line-height: 160%
}

@media only screen and (min-width:768px) {
    .c-itemization-panel__title {
        font-size: 2.4rem;
        letter-spacing: .288px;
        line-height: 150%
    }
}

.c-itemization-panel__item {
    -webkit-column-gap: 12px;
    column-gap: 12px;
    display: flex;
    font-size: 1.4rem;
    letter-spacing: .168px;
    line-height: 160%;
    margin-top: 8px
}

@media only screen and (min-width:768px) {
    .c-itemization-panel__item {
        font-size: 2rem;
        font-weight: 400;
        letter-spacing: .24px;
        line-height: 180%
    }
}

.c-itemization-panel__item:before {
    align-self: center;
    background-color: #bb8e00;
    border-radius: 6px;
    content: "";
    display: block;
    height: 6px;
    width: 6px
}

.c-itemization-panel__item:first-of-type {
    margin-top: 10px
}

@media only screen and (min-width:768px) {
    .c-itemization-panel__item:first-of-type {
        margin-top: 24px
    }
}

.c-itemization-panels {
    display: flex;
    flex-direction: column;
    row-gap: 32px
}

@media only screen and (min-width:768px) {
    .c-itemization-panels {
        -webkit-column-gap: 48px;
        column-gap: 48px;
        flex-direction: row;
        justify-content: space-between
    }
}

.c-itemization-panels>.c-icon-x {
    align-self: center;
    flex-shrink: 0;
    height: 40px;
    width: 40px
}

@media only screen and (min-width:768px) {
    .c-itemization-panels>.c-icon-x {
        height: 73.854px;
        width: 73.854px
    }
}

.c-link-with-icon {
    align-items: center;
    display: flex;
    padding: 20px 32px
}

.c-link-with-icon:hover>.c-link-with-icon__text {
    -webkit-text-decoration-color: #fff;
    text-decoration-color: #fff;
    -webkit-text-decoration-line: underline;
    text-decoration-line: underline;
    text-decoration-thickness: 1px;
    text-underline-offset: 3px
}

.c-link-with-icon--only-sp {
    pointer-events: auto
}

@media only screen and (min-width:768px) {
    .c-link-with-icon--only-sp {
        pointer-events: none
    }
}

.c-main-visual {
    position: relative
}

@media only screen and (min-width:768px) {
    .c-main-visual {
        height: calc(100vh - 149px);
        max-height: 600px;
        min-height: 413px
    }

    .c-main-visual--top {
        height: calc(100vh - 81px);
        max-height: 736px
    }

    .c-main-visual--top>.c-main-visual__body {
        padding-bottom: 78px
    }
}

.c-main-visual__media {
    display: block;
    height: 375px;
    position: absolute;
    width: 100%
}

.c-main-visual__media:after {
    background-color: rgba(0, 0, 0, .4);
    content: "";
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%
}

@media only screen and (min-width:768px) {
    .c-main-visual__media {
        height: 100%
    }
}

.c-main-visual__image,
.c-main-visual__video {
    display: block;
    height: 100%;
    object-fit: cover;
    width: 100%
}

.c-main-visual__video {
    left: 0;
    position: absolute;
    top: 0
}

.c-main-visual__body {
    position: relative
}

@media only screen and (min-width:768px) {
    .c-main-visual__body {
        align-items: flex-end;
        display: flex;
        height: 100%;
        justify-content: space-between;
        margin-left: auto;
        margin-right: auto;
        max-width: 1200px;
        padding: 0 0 64px
    }
}

.c-main-visual__contents {
    align-content: flex-end;
    color: #fff;
    display: grid;
    grid-auto-rows: -webkit-min-content;
    grid-auto-rows: min-content;
    height: 375px;
    padding: 0 24px 24px
}

@media only screen and (min-width:768px) {
    .c-main-visual__contents {
        max-width: 800px;
        padding: 0;
        row-gap: 24px
    }
}

.c-main-visual__contents--no-link {
    padding-bottom: 32px
}

@media only screen and (min-width:768px) {
    .c-main-visual__contents--no-link {
        max-width: none;
        padding-bottom: 0
    }
}

.c-main-visual__tag {
    background-color: hsla(0, 0%, 100%, .1);
    font-size: 1.4rem;
    letter-spacing: .168px;
    line-height: 160%;
    outline: 1px solid #fff;
    outline-offset: -1px;
    padding: 6px 16px;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content
}

@media only screen and (min-width:768px) {
    .c-main-visual__tag {
        font-size: 2.4rem;
        letter-spacing: 2.4px;
        line-height: 130%
    }
}

.c-main-visual__tag+.c-main-visual__title {
    margin-top: 16px
}

@media only screen and (min-width:768px) {
    .c-main-visual__tag+.c-main-visual__title {
        margin-top: 24px
    }
}

@media only screen and (min-width:768px)and (min-width:768px) {
    .c-main-visual__tag+.c-main-visual__title {
        margin-top: 0
    }
}

.c-main-visual__title {
    font-size: 3.2rem;
    font-style: normal;
    font-weight: 700;
    letter-spacing: .384px;
    line-height: 140%
}

@media only screen and (min-width:768px) {
    .c-main-visual__title {
        font-size: 6.2rem;
        font-style: normal;
        font-weight: 700;
        letter-spacing: .7px;
        line-height: 140%
    }
}

.c-main-visual__description {
    font-size: 1.6rem;
    font-weight: 400;
    letter-spacing: .192px;
    line-height: 160%;
    margin-top: 8px
}

@media only screen and (min-width:768px) {
    .c-main-visual__description {
        font-size: 2.4rem;
        font-weight: 700;
        letter-spacing: .288px;
        line-height: 180%;
        margin-top: 0
    }
}

.c-main-visual__links {
    display: grid;
    flex-shrink: 0;
    grid-auto-rows: -webkit-max-content;
    grid-auto-rows: max-content
}

@media only screen and (min-width:768px) {
    .c-main-visual__links {
        row-gap: 16px;
        width: 390px
    }
}

.c-main-visual__mail-link {
    background-color: #0062b2;
    color: #fff;
    position: relative
}

.c-main-visual__mail-link:hover {
    background-color: #124a7b
}

.c-main-visual__mail-link>.c-icon-mail {
    height: 24px;
    width: 24px
}

@media only screen and (min-width:768px) {
    .c-main-visual__mail-link>.c-icon-mail {
        height: 32px;
        width: 32px
    }
}

.c-main-visual__mail-link__text {
    align-items: center;
    display: flex;
    font-size: 1.8rem;
    font-weight: 700;
    justify-content: center;
    letter-spacing: .216px;
    line-height: 100%;
    width: 100%
}

@media only screen and (min-width:768px) {
    .c-main-visual__mail-link__text {
        font-size: 2.2rem;
        letter-spacing: .264px
    }
}

.c-main-visual__tel-link {
    background-color: #fff;
    color: #124a7b;
    font-family: Roboto Flex, sans-serif;
    font-size: 2.2rem;
    font-style: normal;
    font-weight: 700;
    letter-spacing: .264px;
    line-height: 100%;
    position: relative
}

.c-main-visual__tel-link:before {
    background-color: rgba(80, 129, 165, .15);
    bottom: -1px;
    content: "";
    height: 1px;
    left: 0;
    position: absolute;
    width: 100%
}

@media only screen and (min-width:768px) {
    .c-main-visual__tel-link:before {
        content: none
    }
}

.c-main-visual__tel-link>.c-link-with-icon__text {
    align-items: center;
    display: flex;
    gap: 8px;
    justify-content: center
}

.c-main-visual__tel-link>.c-icon-tel {
    stroke: #124a7b;
    height: 24px;
    width: 24px
}

@media only screen and (min-width:768px) {
    .c-main-visual__tel-link>.c-icon-tel {
        height: 32px;
        width: 32px
    }
}

.c-main-visual__tel-link__text {
    align-items: center;
    -webkit-column-gap: 8px;
    column-gap: 8px;
    display: flex;
    font-family: Roboto Flex, sans-serif;
    font-size: 2.2rem;
    font-weight: 700;
    justify-content: center;
    letter-spacing: .264px;
    line-height: 100%;
    width: 100%
}

@media only screen and (min-width:768px) {
    .c-main-visual__tel-link__text {
        font-size: 2.6rem;
        letter-spacing: .312px
    }
}

.c-main-visual__tel-link__small {
    font-family: Noto Sans JP, sans-serif;
    font-size: 1.2rem;
    font-weight: 700;
    letter-spacing: .144px;
    line-height: 110%
}

@media only screen and (min-width:768px) {
    .c-main-visual__tel-link__small {
        font-size: 1.4rem;
        letter-spacing: .168px
    }
}

.c-member-intro-panel {
    background-color: #fff;
    margin-bottom: 32px;
    margin-left: auto;
    margin-right: auto;
    padding-bottom: 32px;
    padding-top: 32px
}

.c-member-intro-panel:last-child {
    margin-bottom: 0
}

@media only screen and (min-width:768px) {
    .c-member-intro-panel {
        padding-bottom: 64px;
        padding-top: 64px
    }
}

.c-member-intro-panel__inner {
    display: flex;
    flex-direction: column;
    max-width: 1080px;
    padding-left: 24px;
    padding-right: 24px;
    row-gap: 32px
}

@media only screen and (min-width:768px) {
    .c-member-intro-panel__inner {
        margin-left: auto;
        margin-right: auto;
        padding-left: 40px;
        padding-right: 40px;
        row-gap: 48px
    }
}

.c-member-intro-panel__header {
    display: flex;
    flex-direction: column
}

@media only screen and (min-width:768px) {
    .c-member-intro-panel__header {
        -webkit-column-gap: 80px;
        column-gap: 80px;
        flex-direction: row
    }
}

.c-member-intro-panel__picture {
    align-self: center
}

.c-member-intro-panel__image {
    align-self: center;
    flex-shrink: 0;
    height: 327px;
    width: 327px
}

@media only screen and (min-width:768px) {
    .c-member-intro-panel__image {
        height: 420px;
        width: 420px
    }
}

.c-member-intro-panel__short {
    display: flex;
    flex-direction: column;
    flex-grow: 1;
    padding-top: 24px
}

@media only screen and (min-width:768px) {
    .c-member-intro-panel__short {
        padding-top: 32px
    }
}

.c-member-intro-panel__position {
    color: rgba(20, 33, 43, .5);
    font-size: 1.6rem;
    font-weight: 700;
    letter-spacing: .192px;
    line-height: 160%
}

@media only screen and (min-width:768px) {
    .c-member-intro-panel__position {
        font-size: 1.8rem;
        letter-spacing: .216px;
        line-height: 180%
    }
}

.c-member-intro-panel__name {
    font-size: 2.4rem;
    font-weight: 700;
    letter-spacing: .288px;
    line-height: 150%
}

@media only screen and (min-width:768px) {
    .c-member-intro-panel__name {
        font-size: 4rem;
        letter-spacing: .48px;
        line-height: 160%
    }
}

.c-member-intro-panel__divider {
    background-color: rgba(80, 129, 165, .15);
    height: 1px;
    margin-bottom: 16px;
    margin-top: 16px
}

@media only screen and (min-width:768px) {
    .c-member-intro-panel__divider {
        margin-bottom: 24px;
        margin-top: 24px
    }
}

.c-member-intro-panel__achievements {
    color: rgba(20, 33, 43, .7);
    font-size: 1.4rem;
    letter-spacing: .168px;
    line-height: 160%
}

@media only screen and (min-width:768px) {
    .c-member-intro-panel__achievements {
        font-size: 1.6rem;
        letter-spacing: .192px
    }
}

.c-member-intro-panel__achievements__item {
    align-items: center;
    display: flex;
    margin-bottom: 8px
}

.c-member-intro-panel__achievements__item:last-child {
    margin-bottom: none
}

.c-member-intro-panel__achievements__item:before {
    background-color: #bb8e00;
    content: " ";
    height: 6px;
    margin-right: 12px;
    width: 6px
}

.c-member-intro-panel__body {
    display: flex;
    flex-direction: column;
    row-gap: 16px
}

@media only screen and (min-width:768px) {
    .c-member-intro-panel__body {
        row-gap: 32px
    }
}

.c-member-intro-panel__body--show-paragraph .c-member-intro-panel__toggle-paragraph__expand {
    display: none
}

.c-member-intro-panel__body--show-paragraph .c-member-intro-panel__toggle-paragraph__hide {
    display: flex
}

.c-member-intro-panel__title {
    font-size: 2rem;
    font-weight: 700;
    letter-spacing: .24px;
    line-height: 180%
}

@media only screen and (min-width:768px) {
    .c-member-intro-panel__title {
        font-size: 3.2rem;
        letter-spacing: .384px
    }
}

.c-member-intro-panel__paragraph {
    font-size: 1.6rem;
    height: 0;
    letter-spacing: .192px;
    line-height: 160%;
    overflow: hidden;
    transition: height .3s ease
}

@media only screen and (min-width:768px) {
    .c-member-intro-panel__paragraph {
        font-size: 1.8rem;
        height: -webkit-fit-content;
        height: -moz-fit-content;
        height: fit-content;
        letter-spacing: .216px;
        line-height: 180%
    }
}

.c-member-intro-panel__toggle-paragraph {
    color: #124a7b;
    cursor: pointer;
    font-size: 1.6rem;
    font-weight: 700;
    letter-spacing: .192px;
    margin-top: 8px
}

.c-member-intro-panel__toggle-paragraph .c-icon-plus__path {
    stroke: #124a7b
}

.c-member-intro-panel__toggle-paragraph__expand {
    -webkit-column-gap: 8px;
    column-gap: 8px;
    display: flex
}

.c-member-intro-panel__toggle-paragraph__hide {
    -webkit-column-gap: 8px;
    column-gap: 8px;
    display: none
}

@media only screen and (min-width:768px) {

    .c-member-intro-panel__toggle-paragraph__expand,
    .c-member-intro-panel__toggle-paragraph__hide {
        display: none
    }
}

.c-modal-sp-image {
    margin: 0 auto
}

.c-modal-sp-image::-webkit-backdrop {
    background-color: rgba(0, 0, 0, .5)
}

.c-modal-sp-image::backdrop {
    background-color: rgba(0, 0, 0, .5)
}

.c-modal-sp-image[open] {
    align-items: center;
    display: flex;
    justify-content: center
}

.c-modal-sp-image:modal {
    background-color: unset;
    border: none;
    height: 100%;
    max-height: 100%;
    width: 100%
}

.c-modal-sp-image__close {
    height: 45px;
    position: absolute;
    right: 0;
    top: 16px;
    width: 45px
}

.c-modal-sp-image__close>.c-icon-plus {
    height: 30px;
    width: 30px
}

.c-modal-sp-image__close>.c-icon-plus>.c-icon-plus__path {
    stroke: #fff;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
    -webkit-transform-origin: center;
    transform-origin: center
}

.c-modal-sp-image__inner {
    height: -webkit-fit-content;
    height: -moz-fit-content;
    height: fit-content;
    max-height: calc(100% - 122px);
    overflow-y: scroll;
    width: 100%
}

.c-modal-sp-image__background {
    height: 100svh;
    left: 0;
    position: fixed;
    top: 0;
    width: 100%;
    z-index: -1
}

.c-navigation-link {
    background-color: #fff;
    color: #14212b;
    display: inline-block;
    font-size: 1.6rem;
    padding: 14px 20px
}

.c-navigation-link--filled {
    background-color: #14212b;
    color: #fff
}

.c-navigation-link--disabled {
    pointer-events: none
}

@media only screen and (min-width:768px) {
    .c-navigation-link {
        font-size: 2.4rem;
        font-weight: 400;
        padding: 18px 40px
    }
}

.c-navigation-link:hover {
    -webkit-text-decoration-line: underline;
    text-decoration-line: underline;
    text-decoration-thickness: 1px;
    text-underline-offset: 3px
}

.c-result-comparison {
    color: #fff;
    display: flex;
    flex-direction: column;
    gap: 16px
}

@media only screen and (min-width:768px) {
    .c-result-comparison {
        flex-direction: row;
        gap: 24px
    }
}

.c-result-comparison__arrow {
    align-self: center;
    border-color: rgba(20, 33, 43, .5) transparent transparent;
    border-style: solid;
    border-width: 16px 13px 0;
    height: 0;
    width: 0
}

@media only screen and (min-width:768px) {
    .c-result-comparison__arrow {
        border-color: transparent transparent transparent rgba(20, 33, 43, .5);
        border-width: 20px 0 20px 24px
    }
}

.c-result-comparison__before {
    outline: 2px solid rgba(20, 33, 43, .5);
    outline-offset: -2px;
    position: relative
}

.c-result-comparison__before-text {
    background-color: #14212b;
    font-size: 1.2rem;
    font-weight: 700;
    letter-spacing: .144px;
    line-height: 160%;
    padding: 8px 24px;
    position: absolute;
    text-align: center
}

@media only screen and (min-width:768px) {
    .c-result-comparison__before-text {
        font-size: 1.8rem;
        letter-spacing: .216px;
        line-height: 180%
    }
}

.c-result-comparison__after {
    outline: 2px solid #bb8e00;
    outline-offset: -2px;
    position: relative
}

.c-result-comparison__after-text {
    background-color: #bb8e00;
    font-size: 1.2rem;
    font-weight: 700;
    letter-spacing: .144px;
    line-height: 160%;
    padding: 8px 24px;
    position: absolute;
    text-align: center
}

@media only screen and (min-width:768px) {
    .c-result-comparison__after-text {
        font-size: 1.8rem;
        letter-spacing: .216px;
        line-height: 180%
    }
}

.c-small-heading-tall-image {
    display: flex;
    flex-direction: column;
    row-gap: 48px
}

@media only screen and (min-width:768px) {
    .c-small-heading-tall-image {
        -webkit-column-gap: 115px;
        column-gap: 115px;
        flex-direction: row;
        justify-content: space-between
    }
}

.c-small-heading-tall-image__subtitle {
    color: #124a7b;
    font-size: 1.4rem;
    font-weight: 700;
    letter-spacing: .168px;
    line-height: 160%
}

@media only screen and (min-width:768px) {
    .c-small-heading-tall-image__subtitle {
        font-size: 2.4rem;
        letter-spacing: .288px;
        line-height: 180%
    }
}

.c-small-heading-tall-image__title {
    font-size: 2.4rem;
    font-weight: 700;
    letter-spacing: .288px;
    line-height: 150%;
    margin-top: 8px
}

@media only screen and (min-width:768px) {
    .c-small-heading-tall-image__title {
        font-size: 3.2rem;
        letter-spacing: .384px;
        line-height: 180%;
        margin-top: 24px
    }
}

.c-small-heading-tall-image__text {
    font-size: 1.6rem;
    letter-spacing: .192px;
    line-height: 160%;
    margin-top: 16px
}

@media only screen and (min-width:768px) {
    .c-small-heading-tall-image__text {
        font-size: 2rem;
        letter-spacing: .24px;
        line-height: 180%;
        margin-top: 24px
    }
}

.c-small-heading-tall-image__picture {
    align-self: center;
    aspect-ratio: 64/31;
    width: 100%
}

@media only screen and (min-width:768px) {
    .c-small-heading-tall-image__picture {
        aspect-ratio: 664/265;
        height: 265px;
        width: unset
    }
}

.c-small-heading-tall-image__image {
    height: 100%;
    object-fit: cover;
    width: 100%
}

.c-solution-process--has-image {
    position: relative
}

.c-solution-process--has-image>.c-solution-process__body {
    padding-bottom: 120px;
    padding-top: 120px;
    position: relative;
    z-index: 3
}

.c-solution-process--has-image>.c-solution-process__body>.c-solution-process__header>.c-heading-large-image__inner>.c-heading-large-image__info>.c-heading-large-image__text,
.c-solution-process--has-image>.c-solution-process__body>.c-solution-process__header>.c-heading-large-image__inner>.c-heading-large-image__info>.c-heading-large-image__title,
.c-solution-process--has-image>.c-solution-process__body>.c-solution-process__header>.c-heading-large-image__subtitle {
    color: #fff
}

.c-solution-process--has-image>.c-solution-process__body>.c-solution-process__contents>.c-swiper-pagination>.splide__arrow>.c-icon-arrow>.c-icon-arrow__group>.c-icon-arrow__path {
    stroke: #fff
}

.c-solution-process--has-image>.c-solution-process__body>.c-solution-process__contents>.c-swiper-pagination>.c-swiper-pagination__pages>[role=presentation]>.c-swiper-pagination__page__button:not(.is-active):before {
    background-color: #fff
}

.c-solution-process__image-wrapper {
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%
}

.c-solution-process__image {
    height: 100%;
    object-fit: cover;
    width: 100%
}

.c-solution-process__body {
    display: flex;
    flex-direction: column;
    margin: 0 auto;
    max-width: 1200px;
    padding: 64px 24px
}

@media only screen and (min-width:768px) {
    .c-solution-process__body {
        flex-direction: row;
        justify-content: space-between;
        padding: 120px 0
    }

    .c-solution-process__header {
        align-self: center;
        max-width: 600px
    }
}

.c-solution-process__contents {
    margin-top: 48px
}

@media only screen and (min-width:768px) {
    .c-solution-process__contents {
        margin-top: 0
    }
}

.c-solution-process__contents__items-wrapper {
    height: 290px;
    margin-left: -24px;
    position: relative;
    width: 100vw
}

@media only screen and (min-width:768px) {
    .c-solution-process__contents__items-wrapper {
        -webkit-clip-path: none;
        clip-path: none;
        height: 100%;
        margin-left: 0;
        width: 100%
    }
}

.c-solution-process__contents__items {
    display: flex;
    list-style-type: none
}

@media only screen and (min-width:768px) {
    .c-solution-process__contents__items {
        flex-direction: column;
        width: -webkit-fit-content;
        width: -moz-fit-content;
        width: fit-content
    }
}

.c-solution-process__contents__item {
    background-color: #fafafa;
    border-bottom: 3px solid #fafafa;
    border-top: 3px solid #fafafa;
    display: grid;
    flex-shrink: 0;
    gap: 8px;
    grid-auto-rows: -webkit-min-content;
    grid-auto-rows: min-content;
    height: 290px;
    padding: 64px 40px 0 32px;
    position: relative;
    width: 248px
}

@media only screen and (min-width:768px) {
    .c-solution-process__contents__item {
        border: 0;
        -webkit-column-gap: 24px;
        column-gap: 24px;
        grid-template-columns: auto 344px;
        grid-template-rows: auto auto;
        height: -webkit-fit-content;
        height: -moz-fit-content;
        height: fit-content;
        padding: 40px;
        row-gap: 0;
        width: -webkit-fit-content;
        width: -moz-fit-content;
        width: fit-content
    }
}

.c-solution-process__contents__item:before {
    background-color: #fff;
    content: "";
    height: 100%;
    position: absolute;
    right: 0;
    top: 0;
    width: 24px
}

@media only screen and (min-width:768px) {
    .c-solution-process__contents__item:before {
        content: none
    }
}

.c-solution-process__contents__item:after {
    border-color: transparent transparent transparent #fafafa;
    border-style: solid;
    border-width: 145px 0 145px 24px;
    content: "";
    height: 0;
    position: absolute;
    right: 0;
    top: 0;
    width: 0
}

@media only screen and (min-width:768px) {
    .c-solution-process__contents__item:after {
        border-color: #fafafa transparent transparent;
        border-width: 24px 40px 0;
        left: 50%;
        top: 100%;
        -webkit-transform: translateX(-50%);
        transform: translateX(-50%);
        z-index: 1
    }
}

.c-solution-process__contents__item:nth-child(2n) {
    background-color: #fff
}

.c-solution-process__contents__item:nth-child(2n):before {
    background-color: #fafafa
}

.c-solution-process__contents__item:nth-child(2n):after {
    border-color: transparent transparent transparent #fff
}

@media only screen and (min-width:768px) {
    .c-solution-process__contents__item:nth-child(2n):after {
        border-color: #fff transparent transparent
    }
}

.c-solution-process__contents__item:last-child {
    padding-right: 16px
}

@media only screen and (min-width:768px) {
    .c-solution-process__contents__item:last-child {
        padding-right: 40px
    }
}

.c-solution-process__contents__item:last-child:after,
.c-solution-process__contents__item:last-child:before {
    content: none
}

.c-solution-process__contents__item__number {
    color: #bb8e00;
    font-family: Roboto Flex, sans-serif;
    font-size: 2.8rem;
    font-weight: 300;
    letter-spacing: .336px;
    line-height: 100%
}

@media only screen and (min-width:768px) {
    .c-solution-process__contents__item__number {
        align-self: center;
        font-size: 4rem;
        font-style: normal;
        font-weight: 200;
        grid-column: 1/2;
        grid-row: 1/3;
        letter-spacing: .48px;
        line-height: 140%
    }
}

.c-solution-process__contents__item__title {
    font-size: 1.6rem;
    font-weight: 700;
    letter-spacing: .192px;
    line-height: 160%;
    padding-top: 8px
}

@media only screen and (min-width:768px) {
    .c-solution-process__contents__item__title {
        font-size: 1.8rem;
        letter-spacing: .216px;
        line-height: 140%
    }
}

.c-solution-process__contents__item__description {
    color: rgba(20, 33, 43, .7);
    font-size: 1.4rem;
    letter-spacing: .168px;
    line-height: 160%;
    padding-top: 8px
}

@media only screen and (min-width:768px) {
    .c-solution-process__contents__item__description {
        font-size: 1.6rem;
        font-weight: 400;
        letter-spacing: .192px;
        line-height: 140%
    }

    .c-solution-process__contents>.c-swiper-pagination {
        display: none
    }
}

.c-solution-process__contents__pagination {
    margin-top: 32px
}

.c-suggestion-panel__body {
    margin-top: 48px;
    position: relative
}

@media only screen and (min-width:768px) {
    .c-suggestion-panel__body {
        margin-top: 64px
    }
}

.c-suggestion-panel__body:after {
    background-color: rgba(80, 129, 165, .15);
    bottom: 0;
    content: "";
    display: block;
    height: 1px;
    left: 0;
    position: absolute;
    width: 100%
}

.c-suggestion-panel__title {
    align-items: center;
    color: #124a7b;
    -webkit-column-gap: 32px;
    column-gap: 32px;
    display: flex;
    font-size: 2rem;
    letter-spacing: .24px;
    line-height: 180%;
    white-space: nowrap
}

.c-suggestion-panel__title:after {
    background-color: rgba(80, 129, 165, .15);
    content: "";
    display: block;
    height: 1px;
    width: 100%
}

@media only screen and (min-width:768px) {
    .c-suggestion-panel__title {
        font-size: 2rem
    }
}

.c-suggestion-panel__items {
    display: flex;
    flex-direction: column;
    margin-top: 24px;
    padding-bottom: 32px
}

@media only screen and (min-width:768px) {
    .c-suggestion-panel__items {
        -webkit-column-gap: 32px;
        column-gap: 32px;
        flex-direction: row;
        margin-top: 32px;
        padding: 0 24px 40px
    }
}

.c-suggestion-panel__primary-items {
    display: flex;
    flex-direction: column;
    row-gap: 24px;
    width: 100%
}

@media only screen and (min-width:768px) {
    .c-suggestion-panel__primary-items {
        row-gap: 32px;
        width: calc(50% - 16px)
    }
}

.c-suggestion-panel__primary-items+.c-suggestion-panel__primary-items {
    margin-top: 24px
}

@media only screen and (min-width:768px) {
    .c-suggestion-panel__primary-items+.c-suggestion-panel__primary-items {
        margin-top: 0
    }
}

.c-suggestion-panel__primary-item__title-wrapper {
    align-items: center;
    -webkit-column-gap: 8px;
    column-gap: 8px;
    display: flex
}

.c-suggestion-panel__primary-item>.c-icon-check {
    height: 32px;
    width: 32px
}

.c-suggestion-panel__primary-item__title {
    font-size: 1.6rem;
    font-weight: 700;
    letter-spacing: .192px;
    line-height: 160%
}

@media only screen and (min-width:768px) {
    .c-suggestion-panel__primary-item__title {
        font-size: 2rem;
        letter-spacing: .24px;
        line-height: 180%
    }
}

.c-suggestion-panel__secondary-items {
    display: grid;
    grid-auto-rows: -webkit-min-content;
    grid-auto-rows: min-content;
    margin-top: 8px;
    padding-left: 12px;
    row-gap: 8px
}

.c-suggestion-panel__secondary-item__title {
    align-items: center;
    display: flex;
    font-size: 1.6rem;
    letter-spacing: .192px;
    line-height: 160%
}

.c-suggestion-panel__secondary-item__title:before {
    background-color: rgba(20, 33, 43, .5);
    border-radius: 4px;
    content: "";
    height: 4px;
    margin-right: 12px;
    width: 4px
}

@media only screen and (min-width:768px) {
    .c-suggestion-panel__secondary-item__title {
        font-size: 1.8rem
    }
}

.c-suggestion-panel__secondary-item__description {
    color: rgba(20, 33, 43, .7);
    font-size: 1.4rem;
    letter-spacing: .168px;
    line-height: 160%;
    margin-top: 8px;
    padding-left: 16px
}

@media only screen and (min-width:768px) {
    .c-suggestion-panel__secondary-item__description {
        font-size: 1.6rem;
        padding-right: 64px
    }
}

.c-suggestion-panel__link {
    margin-top: 48px
}

.c-swiper-pagination {
    -webkit-column-gap: 26px;
    column-gap: 26px;
    display: flex;
    justify-content: center;
    position: relative;
    touch-action: manipulation
}

.c-swiper-pagination__pages {
    display: flex;
    row-gap: 12px
}

.c-swiper-pagination__pages>[role=presentation] {
    display: inline-flex;
    list-style-type: none
}

.c-swiper-pagination__page__button {
    align-items: center;
    display: flex;
    height: 16px;
    justify-content: center;
    position: relative;
    width: 20px
}

.c-swiper-pagination__page__button:before {
    background-color: rgba(20, 33, 43, .5);
    border-radius: 50%;
    content: "";
    height: 8px;
    width: 8px
}

.c-swiper-pagination__page__button.is-active {
    width: 24px
}

.c-swiper-pagination__page__button.is-active:before {
    background-color: #bb8e00;
    height: 12px;
    width: 12px
}

.c-swiper-pagination__backward,
.c-swiper-pagination__forward {
    align-self: center;
    height: 40px;
    width: 40px
}

.c-swiper-pagination__backward:hover>.c-icon-arrow>.c-icon-arrow__group>.c-icon-arrow__path,
.c-swiper-pagination__forward:hover>.c-icon-arrow>.c-icon-arrow__group>.c-icon-arrow__path {
    stroke: #0062b2
}

.c-swiper-pagination__forward>.c-icon-arrow {
    -webkit-transform: rotate(180deg);
    transform: rotate(180deg)
}

.c-three-cards-visual {
    position: relative
}

.c-three-cards-visual__background-wrapper {
    display: block;
    height: 100%;
    width: 100%
}

.c-three-cards-visual__background {
    height: 100%;
    left: 0;
    object-fit: cover;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: 1
}

.c-three-cards-visual__body {
    display: grid;
    grid-auto-rows: -webkit-max-content;
    grid-auto-rows: max-content;
    padding: 80px 24px;
    position: relative;
    row-gap: 32px;
    z-index: 2
}

@media only screen and (min-width:768px) {
    .c-three-cards-visual__body {
        margin-left: auto;
        margin-right: auto;
        max-width: 1200px;
        padding: 120px 0;
        row-gap: 64px
    }
}

.c-three-cards-visual__header {
    color: #fff;
    display: grid;
    grid-auto-rows: -webkit-min-content;
    grid-auto-rows: min-content;
    row-gap: 8px
}

@media only screen and (min-width:768px) {
    .c-three-cards-visual__header {
        row-gap: 24px
    }
}

.c-three-cards-visual__header__description {
    font-size: 1.4rem;
    font-weight: 700;
    letter-spacing: .168px;
    line-height: 160%
}

@media only screen and (min-width:768px) {
    .c-three-cards-visual__header__description {
        font-size: 2.4rem
    }
}

.c-three-cards-visual__header__title {
    font-size: 3.2rem;
    font-weight: 700;
    letter-spacing: .384px;
    line-height: 1.6
}

@media only screen and (min-width:768px) {
    .c-three-cards-visual__header__title {
        font-size: 5.6rem
    }
}

.c-three-cards-visual__main {
    display: flex;
    flex-direction: column;
    gap: 16px
}

@media only screen and (min-width:768px) {
    .c-three-cards-visual__main {
        flex-direction: row;
        gap: 24px
    }

    .c-three-cards-visual__main--no-image {
        gap: 40px
    }
}

.c-three-cards-visual__main--no-image>.c-three-cards-visual__main__card {
    padding: 40px 32px
}

@media only screen and (min-width:768px) {
    .c-three-cards-visual__main--no-image>.c-three-cards-visual__main__card {
        padding: 40px
    }
}

.c-three-cards-visual__main--no-image>.c-three-cards-visual__main__card .c-three-cards-visual__main__card__title {
    font-weight: 700;
    margin-top: 0
}

.c-three-cards-visual__main--no-image>.c-three-cards-visual__main__card .c-three-cards-visual__main__card__description {
    color: rgba(20, 33, 43, .7)
}

.c-three-cards-visual__main__card {
    background-color: #fff;
    display: grid;
    flex: 1;
    grid-auto-rows: -webkit-min-content;
    grid-auto-rows: min-content;
    padding: 32px
}

@media only screen and (min-width:768px) {
    .c-three-cards-visual__main__card {
        padding: 32px 40px
    }
}

.c-three-cards-visual__main__card__image-wrapper {
    justify-self: center
}

.c-three-cards-visual__main__card__image {
    height: 80px;
    width: 80px
}

@media only screen and (min-width:768px) {
    .c-three-cards-visual__main__card__image {
        height: 88px;
        width: 88px
    }
}

.c-three-cards-visual__main__card__title {
    color: #bb8e00;
    font-size: 1.8rem;
    font-weight: 400;
    letter-spacing: .216px;
    line-height: 180%;
    margin-top: 24px
}

@media only screen and (min-width:768px) {
    .c-three-cards-visual__main__card__title {
        font-size: 2.4rem;
        letter-spacing: .288px
    }
}

.c-three-cards-visual__main__card__description {
    font-size: 1.6rem;
    letter-spacing: .192px;
    line-height: 160%;
    margin-top: 8px
}

@media only screen and (min-width:768px) {
    .c-three-cards-visual__main__card__description {
        font-size: 1.8rem
    }
}

.c-three-cards-visual__footer {
    color: #fff;
    font-size: 1.4rem;
    letter-spacing: .168px;
    line-height: 160%
}

@media only screen and (min-width:768px) {
    .c-three-cards-visual__footer {
        font-size: 2rem
    }
}

#border,
.c-top-categories__category:after,
.c-top-categories__category:first-child:before {
    background-color: rgba(80, 129, 165, .15);
    height: 1px;
    width: 100%
}

.c-top-categories {
    padding-top: 47px
}

@media only screen and (min-width:768px) {
    .c-top-categories {
        margin: 0 auto;
        padding: 64px 0 80px;
        width: 1200px
    }
}

.c-top-categories__title {
    color: #124a7b;
    font-size: 1.4rem;
    font-weight: 700;
    letter-spacing: .168px;
    line-height: 160%;
    padding-left: 24px
}

@media only screen and (min-width:768px) {
    .c-top-categories__title {
        font-size: 3.2rem;
        font-weight: 700;
        letter-spacing: .384px;
        line-height: 180%;
        padding-left: 0
    }
}

.c-top-categories__categories {
    -webkit-column-gap: 80px;
    column-gap: 80px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    margin-top: 16px
}

@media only screen and (min-width:768px) {
    .c-top-categories__categories {
        flex-direction: row;
        margin-top: 40px
    }
}

.c-top-categories__category {
    flex: 1;
    position: relative
}

.c-top-categories__category:first-child:before {
    content: "";
    left: 0;
    position: absolute;
    top: 0
}

@media only screen and (min-width:768px) {
    .c-top-categories__category:first-child:before {
        content: none
    }
}

.c-top-categories__category:after {
    bottom: 0;
    content: "";
    left: 0;
    position: absolute
}

@media only screen and (min-width:768px) {
    .c-top-categories__category:after {
        content: none
    }
}

.c-top-category {
    align-items: center;
    -webkit-column-gap: 20px;
    column-gap: 20px;
    display: flex;
    flex-direction: row;
    padding: 24px
}

@media only screen and (min-width:768px) {
    .c-top-category {
        flex-direction: column;
        padding: 0;
        row-gap: 8px
    }
}

.c-top-category:hover>.c-top-category__body>.c-top-category__title {
    color: #0062b2
}

.c-top-category:hover>.c-top-category__body>.c-icon-transition>.c-icon-transition__group>.c-icon-transition__path {
    stroke: #0062b2
}

.c-top-category__picture {
    display: block;
    flex-shrink: 0;
    height: 80px;
    width: 80px
}

@media only screen and (min-width:768px) {
    .c-top-category__picture {
        height: 152px;
        width: 152px
    }
}

.c-top-category__body {
    display: grid;
    grid-template-columns: auto 1fr;
    grid-template-rows: auto 66px
}

@media only screen and (min-width:768px) {
    .c-top-category__body {
        -webkit-column-gap: 6px;
        column-gap: 6px;
        grid-template-rows: auto auto;
        row-gap: 12px
    }
}

.c-top-category__body>.c-icon-transition {
    height: 32px;
    justify-self: flex-end;
    width: 32px
}

@media only screen and (min-width:768px) {
    .c-top-category__body>.c-icon-transition {
        height: 40px;
        justify-self: flex-start;
        width: 40px
    }
}

.c-top-category__title {
    font-size: 1.6rem;
    font-weight: 700;
    letter-spacing: .192px;
    line-height: 160%
}

@media only screen and (min-width:768px) {
    .c-top-category__title {
        font-size: 2.4rem;
        font-weight: 700;
        line-height: 150%
    }
}

.c-top-category__description {
    font-size: 1.4rem;
    grid-column: 1/3;
    letter-spacing: .168px;
    line-height: 160%
}

@media only screen and (min-width:768px) {
    .c-top-category__description {
        color: rgba(20, 33, 43, .7);
        font-size: 1.8rem;
        letter-spacing: .216px;
        line-height: 180%
    }
}

.c-useful-information-column__contents {
    margin-top: 64px
}

@media only screen and (min-width:768px) {
    .c-useful-information-column__contents {
        margin-top: 80px
    }
}

.c-useful-information-column__title {
    font-size: 2rem;
    font-weight: 700;
    letter-spacing: .24px;
    line-height: 180%
}

@media only screen and (min-width:768px) {
    .c-useful-information-column__title {
        font-size: 2.4rem;
        letter-spacing: .288px;
        line-height: 150%
    }
}

.c-useful-information-column__guidance-cards {
    margin-top: 16px
}

@media only screen and (min-width:768px) {
    .c-useful-information-column__guidance-cards {
        margin-top: 32px
    }
}

.c-useful-information-column__link {
    margin-top: 32px
}

@media only screen and (min-width:768px) {
    .c-useful-information-column__link {
        margin-top: 48px
    }
}

.c-useful-information-column__topics {
    margin-top: 64px
}

@media only screen and (min-width:768px) {
    .c-useful-information-column__topics {
        margin-top: 160px
    }
}

.c-useful-information-column__topics-list {
    -ms-overflow-style: none;
    margin-top: 24px;
    max-height: 368px;
    overflow-y: scroll;
    scrollbar-width: none
}

.c-useful-information-column__topics-list::-webkit-scrollbar {
    display: none
}

@media only screen and (min-width:768px) {
    .c-useful-information-column__topics-list {
        margin-top: 32px;
        max-height: 360px
    }
}

.c-useful-information-column__topic {
    -webkit-column-gap: 16px;
    column-gap: 16px;
    display: flex;
    padding: 24px 0
}

@media only screen and (min-width:768px) {
    .c-useful-information-column__topic {
        -webkit-column-gap: 64px;
        column-gap: 64px;
        padding: 32px 0
    }

    .c-useful-information-column__topic:hover>.c-useful-information-column__topic-title {
        color: #0062b2
    }
}

.c-useful-information-column__topic-wrapper {
    position: relative;
    width: calc(100% - 20px)
}

@media only screen and (min-width:768px) {
    .c-useful-information-column__topic-wrapper {
        max-width: 1148px
    }
}

.c-useful-information-column__topic-wrapper:first-child:before {
    background-color: rgba(80, 129, 165, .15);
    content: "";
    height: 1px;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%
}

.c-useful-information-column__topic-wrapper:after {
    background-color: rgba(80, 129, 165, .15);
    bottom: 0;
    content: "";
    height: 1px;
    left: 0;
    position: absolute;
    width: 100%
}

.c-useful-information-column__topic-date {
    color: rgba(20, 33, 43, .5);
    font-family: Roboto Flex, sans-serif;
    font-size: 1.2rem;
    letter-spacing: .144px;
    line-height: 160%
}

@media only screen and (min-width:768px) {
    .c-useful-information-column__topic-date {
        color: rgba(20, 33, 43, .5);
        font-size: 1.4rem;
        letter-spacing: .168px;
        line-height: 160%
    }
}

.c-useful-information-column__topic-title {
    font-size: 1.4rem;
    letter-spacing: .168px;
    line-height: 160%
}

@media only screen and (min-width:768px) {
    .c-useful-information-column__topic-title {
        font-size: 1.6rem;
        letter-spacing: .192px;
        line-height: 160%
    }
}

.c-useful-information-column__topics-scroll {
    position: relative;
    width: calc(100% + 20px)
}

@media only screen and (min-width:768px) {
    .c-useful-information-column__topics-scroll {
        width: 100%
    }
}

.c-useful-information-column__topics-scroll-track {
    background-color: rgba(80, 129, 165, .15);
    height: 100%;
    pointer-events: none;
    position: absolute;
    right: 0;
    top: 0;
    width: 3px
}

@media only screen and (min-width:768px) {
    .c-useful-information-column__topics-scroll-track {
        pointer-events: auto;
        width: 4px
    }
}

.c-useful-information-column__topics-scroll-thumb {
    background-color: #0062b2;
    position: absolute;
    right: 0;
    width: 3px
}

@media only screen and (min-width:768px) {
    .c-useful-information-column__topics-scroll-thumb {
        width: 4px
    }
}

.js-scroll-thumb {
    pointer-events: none
}

.s-251218{
    letter-spacing: 1.288px;
}
