@import"https://fonts.googleapis.com/css2?family=Hanken+Grotesk:wght@700&family=IBM+Plex+Sans+JP:wght@100;200;300;400;500;600;700&family=Syncopate:wght@700&display=swap";

*,
*::before,
*::after {
    margin: 0;
    padding: 0;
    box-sizing: border-box
}

:where([hidden]:not([hidden=until-found])) {
    display: none !important
}

:where(html) {
    -webkit-text-size-adjust: none;
    color-scheme: dark light;
    -moz-tab-size: 2;
    -o-tab-size: 2;
    tab-size: 2;
    scrollbar-gutter: stable
}

:where(html:has(dialog:modal[open])) {
    overflow: clip
}

@media(prefers-reduced-motion: no-preference) {
    :where(html:focus-within) {
        scroll-behavior: smooth
    }
}

:where(body) {
    line-height: 1.5;
    font-family: system-ui, sans-serif;
    -webkit-font-smoothing: antialiased
}

:where(button) {
    all: unset
}

:where(input, button, textarea, select) {
    font: inherit;
    color: inherit
}

:where(textarea) {
    resize: vertical;
    resize: block
}

:where(button, label, select, summary, [role=button], [role=option]) {
    cursor: pointer
}

:where(:disabled) {
    cursor: not-allowed
}

:where(label:has(>input:disabled), label:has(+input:disabled)) {
    cursor: not-allowed
}

:where(a) {
    color: inherit;
    text-underline-offset: .2ex
}

:where(ul, ol) {
    list-style: none
}

:where(img, svg, video, canvas, audio, iframe, embed, object) {
    display: block
}

:where(img, picture, svg, video) {
    max-inline-size: 100%;
    block-size: auto
}

:where(p, h1, h2, h3, h4, h5, h6) {
    overflow-wrap: break-word
}

:where(h1, h2, h3) {
    line-height: calc(1em + .5rem);
    text-wrap: balance
}

:where(hr) {
    border: none;
    border-block-start: 1px solid;
    color: inherit;
    block-size: 0;
    overflow: visible
}

:where(dialog) {
    border: none;
    background: none;
    inset: unset;
    max-width: unset;
    max-height: unset
}

:where(dialog:not([open])) {
    display: none !important
}

:where(:focus-visible) {
    outline: 3px solid CanvasText;
    box-shadow: 0 0 0 5px Canvas;
    outline-offset: 1px
}

:where(:focus-visible, :target) {
    scroll-margin-block: 8vh
}

:where(.visually-hidden:not(:focus-within, :active)) {
    clip-path: inset(50%) !important;
    height: 1px !important;
    width: 1px !important;
    overflow: hidden !important;
    position: absolute !important;
    white-space: nowrap !important;
    border: 0 !important
}

html {
    font-size: 62.5%
}

main {
    position: relative;
    width: 100%;
    padding-top: 0 !important;
    color: #181818;
    font-family: "IBM Plex Sans JP", sans-serif;
    font-weight: 400;
    font-style: normal;
    font-size: 1.6rem;
    font-feature-settings: "palt";
    -webkit-font-smoothing: antialiased;
    letter-spacing: -0.05em;
    line-break: strict;
    line-height: 1.7;
    text-align: justify
}

main.fixed {
    position: fixed
}

@media screen and (max-width: 768px) {
    main {
        padding: 0 !important
    }
}

img {
    max-width: 100%;
    height: auto;
    vertical-align: middle;
    font-style: italic;
    background-repeat: no-repeat;
    background-size: cover;
    shape-margin: .75rem
}

h1,
h2,
h3,
h4,
h5,
h6 {
    margin: 0;
    padding: 0;
    font-size: inherit;
    font-weight: unset
}

p {
    margin: 0
}

ol,
ul {
    padding-left: 0 !important
}

dt {
    font-weight: unset !important
}

dd {
    margin: 0
}

table {
    border-collapse: collapse
}

label {
    margin-bottom: 0 !important
}

.en_font {
    font-family: "Hanken Grotesk", sans-serif;
    font-weight: 700;
    font-style: normal;
    line-height: 1
}

.bold {
    font-weight: 700
}

.mid {
    font-weight: 600
}

.italic {
    font-style: italic
}

.pop {
    font-family: "Syncopate", sans-serif;
    font-weight: 700;
    font-style: normal
}

.sup {
    font-size: 1rem;
    vertical-align: super
}

::-moz-selection {
    color: #fff;
    background-color: #00bfd1
}

::selection {
    color: #fff;
    background-color: #00bfd1
}

@media screen and (max-width: 768px) {
    .pc {
        display: none
    }
}

.tb {
    display: none
}

@media screen and (max-width: 1024px) {
    .tb {
        display: block
    }
}

.sp {
    display: none
}

@media screen and (max-width: 768px) {
    .sp {
        display: block
    }
}

.contents {
    width: 100%
}

@media screen and (max-width: 768px) {
    .contents {
        padding-top: 0;
        overflow: hidden
    }
}

.contents a {
    color: inherit;
    text-decoration: none
}

.contents a:hover {
    opacity: 1 !important;
    text-decoration: none !important
}

.contents img {
    max-inline-size: none
}

.contents ul::before {
    content: none
}

.top-page-wrapper {
    background-color: #f2f9fc
}

.keyvisual {
    overflow: hidden
}

@media screen and (max-width: 1072px) {
    .keyvisual {
        overflow-x: scroll
    }
}

@media screen and (max-width: 768px) {
    .keyvisual {
        overflow: hidden
    }
}

.keyvisual .kv-wrapper {
    position: relative;
    aspect-ratio: 1/.551;
    width: min(1600px, 100%);
    margin-inline: auto;
    background-image: url(../img/fv.webp);
    background-position: 0 0;
    background-repeat: no-repeat;
    background-size: cover
}

@media screen and (max-width: 1300px) {
    .keyvisual .kv-wrapper {
        width: auto;
        height: 794px
    }
}

@media screen and (max-width: 768px) {
    .keyvisual .kv-wrapper {
        aspect-ratio: 1/1.053;
        width: 100%;
        height: auto;
        background-position: 50%
    }
}

.keyvisual .title-container {
    position: absolute;
    top: 40px;
    left: 40px;
    width: -moz-fit-content;
    width: fit-content;
    padding: 30px 20px;
    background-color: #00bfd1;
    color: #fff;
    z-index: 10
}

@media screen and (max-width: 768px) {
    .keyvisual .title-container {
        position: relative;
        top: auto;
        left: auto;
        width: 100%;
        padding: 20px 0
    }
}

.keyvisual .title-container .title-img {
    margin-inline: auto
}

.keyvisual .page-link-btn {
    display: flex;
    justify-content: center;
    align-items: center;
    position: absolute;
    padding: 10px 10px 8px;
    color: #535353;
    background-color: #fff;
    border-radius: 4px;
    transform: translateY(10px);
    opacity: 0;
    transition: all .4s
}

@media screen and (max-width: 768px) {
    .keyvisual .page-link-btn {
        padding: 2px 5px
    }
}

.keyvisual .page-link-btn.btn01 {
    top: 8%;
    left: 64.3%
}

@media screen and (max-width: 768px) {
    .keyvisual .page-link-btn.btn01 {
        left: 74%
    }
}

.keyvisual .page-link-btn.btn01.active {
    transition: all .4s ease-in-out
}

.keyvisual .page-link-btn.btn02 {
    top: 23%;
    left: 45%
}

@media screen and (max-width: 768px) {
    .keyvisual .page-link-btn.btn02 {
        left: 39%
    }
}

.keyvisual .page-link-btn.btn02.active {
    transition: all .4s .2s ease-in-out
}

.keyvisual .page-link-btn.btn03 {
    top: 32%;
    left: 27%
}

@media screen and (max-width: 768px) {
    .keyvisual .page-link-btn.btn03 {
        top: 35%;
        left: 7%
    }
}

.keyvisual .page-link-btn.btn03.active {
    transition: all .4s .4s ease-in-out
}

.keyvisual .page-link-btn.btn04 {
    top: 55%;
    left: 49.3%
}

.keyvisual .page-link-btn.btn04.active {
    transition: all .4s .6s ease-in-out
}

.keyvisual .page-link-btn.btn05 {
    top: 70%;
    left: 54%
}

.keyvisual .page-link-btn.btn05.active {
    transition: all .4s .8s ease-in-out
}

.keyvisual .page-link-btn.btn06 {
    top: 73%;
    left: 30%
}

@media screen and (max-width: 768px) {
    .keyvisual .page-link-btn.btn06 {
        top: 72%;
        left: 21%
    }
}

.keyvisual .page-link-btn.btn06.active {
    transition: all .4s 1s ease-in-out
}

.keyvisual .page-link-btn.active {
    transform: translateY(0);
    opacity: 1
}

.keyvisual .page-link-btn.top-fukidashi::after {
    top: -8px;
    clip-path: polygon(50% 0%, 0% 100%, 100% 100%)
}

.keyvisual .page-link-btn.bottom-fukidashi::after {
    bottom: -8px;
    clip-path: polygon(49% 100%, 0 0, 100% 0)
}

.keyvisual .page-link-btn:-moz-any-link:hover {
    transform: scale(1.05) translateY(-5px);
    -moz-transition: all .4s;
    transition: all .4s
}

.keyvisual .page-link-btn:any-link:hover {
    transform: scale(1.05) translateY(-5px);
    transition: all .4s
}

.keyvisual .page-link-btn::after {
    content: "";
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    width: 12px;
    height: 9px;
    background-color: #fff
}

.keyvisual .page-link-btn .btn-text {
    padding: 0 1em;
    font-size: 2rem
}

@media screen and (max-width: 768px) {
    .keyvisual .page-link-btn .btn-text {
        padding: 0 .5em;
        font-size: 1.3rem
    }
}

.keyvisual .page-link-btn .btn-icon {
    width: 34px
}

@media screen and (max-width: 768px) {
    .keyvisual .page-link-btn .btn-icon {
        width: 18px
    }
}

.intro-area .area-wrapper {
    position: relative;
    width: min(1600px, 100%);
    margin-inline: auto;
    padding-top: 100px;
    padding-bottom: 150px
}

@media screen and (max-width: 768px) {
    .intro-area .area-wrapper {
        padding-top: 230px;
        padding-bottom: 250px
    }
}

.intro-area .intro-img {
    position: absolute;
    transform: translateY(20px);
    opacity: 0;
    z-index: 20
}

.intro-area .intro-img.active {
    transform: translateY(0);
    transition: all .4s .5s ease-in-out;
    opacity: 1
}

.intro-area .intro-img.img01 {
    top: 5%;
    width: clamp(180px, 20.8333333333vw, 300px)
}

@media screen and (max-width: 768px) {
    .intro-area .intro-img.img01 {
        top: 7%;
        left: 5%
    }
}

.intro-area .intro-img.img02 {
    top: 31%;
    left: 13%;
    width: clamp(120px, 12.5vw, 180px)
}

@media screen and (max-width: 768px) {
    .intro-area .intro-img.img02 {
        top: 0%;
        left: 0
    }
}

.intro-area .intro-img.img03 {
    top: 60%;
    left: 3%;
    width: clamp(120px, 20.8333333333vw, 300px)
}

@media screen and (max-width: 768px) {
    .intro-area .intro-img.img03 {
        top: auto;
        right: 2%;
        bottom: 12%;
        left: auto
    }
}

.intro-area .intro-img.img04 {
    top: -8%;
    right: 10%;
    width: clamp(150px, 20.8333333333vw, 300px)
}

@media screen and (max-width: 768px) {
    .intro-area .intro-img.img04 {
        top: 2%;
        right: 0
    }
}

.intro-area .intro-img.img05 {
    top: 32%;
    right: 2%;
    width: clamp(180px, 20.8333333333vw, 300px)
}

@media screen and (max-width: 768px) {
    .intro-area .intro-img.img05 {
        top: auto;
        right: 15%;
        bottom: 0%
    }
}

.intro-area .intro-img.img06 {
    top: 52%;
    right: 18%;
    width: clamp(80px, 8.3333333333vw, 120px)
}

@media screen and (max-width: 768px) {
    .intro-area .intro-img.img06 {
        top: auto;
        right: auto;
        bottom: 10%;
        left: 0
    }
}

.intro-area .text-container {
    text-align: center
}

.intro-area .text-container .top-text {
    color: #00bfd1;
    font-size: clamp(3.2rem, 2.5vw, 3.6rem);
    letter-spacing: 2.28px;
    line-height: 1.26;
    transform: translateY(30px);
    opacity: 0;
    letter-spacing: .1px
}

.intro-area .text-container .top-text.active {
    transform: translateY(0);
    transition: all .4s ease-in-out;
    opacity: 1
}

.intro-area .text-container .text-box {
    letter-spacing: .96px;
    line-height: 1.75
}

.intro-area .text-container .text-box .text {
    margin-top: 2em;
    transform: translateY(30px);
    opacity: 0
}

.intro-area .text-container .text-box .text.active {
    transform: translateY(0);
    transition: all .4s ease-in-out;
    opacity: 1
}

.text-slider-wrapper {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    gap: 20px;
    position: relative;
    padding: 5px 0;
    overflow: hidden
}

.text-slider-wrapper .text-slider-inner {
    flex: 1 0 auto;
    display: flex;
    justify-content: flex-start;
    align-items: center;
    gap: 20px;
    animation: scroll-left 60s infinite linear both
}

.text-slider-wrapper .text-slide {
    color: rgba(213, 219, 222, .3);
    font-size: clamp(6.4rem, 9.4444444444vw, 13.6rem);
    line-height: 1
}

@keyframes scroll-left {
    from {
        transform: translateX(0)
    }

    to {
        transform: translateX(-100%)
    }
}

.point-area {
    width: min(1200px, 90%);
    margin-top: 50px;
    margin-inline: auto;
    margin-bottom: -60px
}

@media screen and (max-width: 768px) {
    .point-area {
        margin-top: 100px
    }
}

.point-area .area-title {
    text-align: center
}

.point-area .area-title .top-text {
    color: #00bfd1;
    font-size: clamp(4.6rem, 4.5138888889vw, 6.5rem);
    line-height: 1
}

.point-area .area-title .bottom-text {
    font-size: clamp(1.8rem, 1.3888888889vw, 2rem)
}

.point-area .point-list {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 15px;
    position: relative;
    margin-top: 40px;
    z-index: 20
}

@media screen and (max-width: 768px) {
    .point-area .point-list {
        grid-template-columns: 1fr;
        margin-top: 20px
    }
}

.point-area .point-list .point-list-item {
    display: grid;
    grid-template-rows: subgrid;
    grid-row: span 3;
    padding: 40px 12%;
    background-color: #fff;
    border-radius: 4px;
    transform: translateY(20px);
    opacity: 0
}

@media screen and (max-width: 768px) {
    .point-area .point-list .point-list-item {
        padding: 30px 5%
    }
}

.point-area .point-list .point-list-item.active {
    transform: translateY(0);
    opacity: 1
}

.point-area .point-list .point-list-item.active:nth-of-type(1) {
    transition: all .4s
}

.point-area .point-list .point-list-item.active:nth-of-type(2) {
    transition: all .4s .3s
}

.point-area .point-list .point-list-item.active:nth-of-type(3) {
    transition: all .4s .6s
}

.point-area .point-list .num {
    color: rgba(213, 219, 222, .3);
    font-size: clamp(2.8rem, 4.5138888889vw, 6.5rem);
    line-height: .8;
    text-align: center
}

.point-area .point-list .item-topic {
    color: #00bfd1;
    font-size: clamp(1.8rem, 1.3888888889vw, 2rem);
    line-height: 1.5;
    text-align: center
}

.point-area .point-list .item-text {
    margin-top: .5em;
    font-size: 1.5rem
}

.keyword-area {
    position: relative;
    padding-top: 150px;
    padding-bottom: 150px;
    background-image: url(../img/fv.webp);
    background-position: 50%;
    background-repeat: no-repeat;
    background-size: cover
}

@media screen and (max-width: 768px) {
    .keyword-area {
        padding-top: 100px;
        padding-bottom: 100px
    }
}

.keyword-area::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 191, 209, .9)
}

.keyword-area .area-wrapper {
    position: relative;
    width: min(1300px, 90%);
    margin-inline: auto
}

.keyword-area .area-topic {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 1em;
    color: #fff;
    font-size: clamp(1.8rem, 1.3888888889vw, 2rem);
    text-align: center
}

.keyword-area .area-topic::before {
    content: "";
    display: inline-block;
    aspect-ratio: 1/1;
    width: 20px;
    background-image: url(../img/icon-search-w.svg);
    background-position: 50%;
    background-repeat: no-repeat;
    background-size: contain
}

.keyword-area .area-inner {
    display: flex;
    flex-wrap: wrap;
    grid-template-columns: repeat(3, 1fr);
    gap: 15px;
    margin-top: 40px;
    justify-content: center
}

@media screen and (max-width: 1250px) {
    .keyword-area .area-inner {
        grid-template-columns: repeat(2, 1fr)
    }
}

@media screen and (max-width: 768px) {
    .keyword-area .area-inner {
        grid-template-columns: 1fr;
        margin-top: 20px
    }
}

.keyword-area .keyword-link-btn {
    display: grid;
    grid-template-columns: 100px 1fr 30px;
    justify-content: flex-start;
    align-items: center;
    gap: 15px;
    padding: 20px;
    padding-right: 40px;
    background-color: #fff;
    border-radius: 999rem;
    transition: all .4s;
    width: 400px
}

@media screen and (max-width: 768px) {
    .keyword-area .keyword-link-btn {
        padding: 10px;
        padding-right: 30px;
        width: 100%
    }
}

.keyword-area .keyword-link-btn:-moz-any-link:hover {
    transform: scale(0.95);
    -moz-transition: all .4s;
    transition: all .4s
}

.keyword-area .keyword-link-btn:any-link:hover {
    transform: scale(0.95);
    transition: all .4s
}

.keyword-area .keyword-link-btn .btn-img {
    width: 100px
}

.keyword-area .keyword-link-btn .text-box {
    color: #00bfd1
}

.keyword-area .keyword-link-btn .text-box .top-text {
    display: block;
    font-size: clamp(2rem, 1.6666666667vw, 2.4rem);
    line-height: 1.2;
    text-align: left
}

.keyword-area .keyword-link-btn .text-box .top-text.long-text {
    word-break: keep-all;
    overflow-wrap: break-word
}

.keyword-area .keyword-link-btn .text-box .bottom-text {
    font-size: 1.2rem;
    letter-spacing: -0.24px
}

.main-page-wrapper {
    display: grid;
    grid-template-columns: 490px calc(100vw - 490px);
    justify-content: center;
    align-items: flex-start
}

@media screen and (max-width: 768px) {
    .main-page-wrapper {
        display: block
    }
}

.main-page-wrapper .aside-block {
    position: sticky;
    top: 0;
    left: 0;
    height: 100vh;
    background-color: #00bfd1;
    color: #fff
}

@media screen and (max-width: 768px) {
    .main-page-wrapper .aside-block {
        position: relative;
        top: auto;
        left: auto;
        height: auto
    }
}

.main-page-wrapper .aside-block .aside-top-img {
    width: 100%
}

.main-page-wrapper .aside-block .block-wrapper {
    height: calc(100vh - 230px);
    background-color: #00bfd1;
    overflow-y: scroll
}

@media screen and (max-width: 768px) {
    .main-page-wrapper .aside-block .block-wrapper {
        height: auto;
        padding-bottom: 50px;
        overflow: hidden
    }
}

.main-page-wrapper .aside-block .text-container {
    width: 80%;
    margin: 40px auto 0;
    padding-bottom: 60px
}

@media screen and (max-width: 768px) {
    .main-page-wrapper .aside-block .text-container {
        width: 100%;
        padding: 0px 20px 10px
    }
}

.main-page-wrapper .aside-block .text-container .block-title .top-text {
    font-size: clamp(3.2rem, 2.9166666667vw, 4.2rem)
}

.main-page-wrapper .aside-block .text-container .block-title .bottom-text {
    font-size: 1.3rem;
    letter-spacing: .25px
}

.main-page-wrapper .aside-block .text-container .top-topic {
    margin-top: 1.75em;
    font-size: 1.8rem;
    letter-spacing: .1px
}

.main-page-wrapper .aside-block .text-container .top-text {
    margin-top: 1em;
    font-size: 1.4rem;
    font-weight: 500
}

.main-page-wrapper .aside-block .text-container .block-list {
    margin-top: 20px
}

.main-page-wrapper .aside-block .text-container .block-list-topic {
    margin-top: 1em;
    padding: 2px 1.25em 0;
    background-color: #fff;
    border-radius: 999rem;
    color: #00bfd1;
    font-size: 1.4rem;
    font-weight: 700 !important;
    letter-spacing: .1px
}

.main-page-wrapper .aside-block .text-container .block-list-detail {
    margin-top: .5em;
    font-size: 1.3rem;
    font-weight: 500;
    letter-spacing: .1px
}

.main-page-wrapper .article-block .block-top-topic {
    width: min(760px, 90%);
    margin-top: 50px;
    margin-inline: auto;
    color: #00bfd1;
    font-size: clamp(1.8rem, 1.6666666667vw, 2.4rem)
}

@media screen and (max-width: 768px) {
    .main-page-wrapper .article-block .block-top-topic {
        text-align: center;
        margin-top: 0px;
        margin-inline: 0px;
        padding-top: 50px;
        width: 100%
    }
}

.main-page-wrapper .article-block .block-inner {
    width: 100%
}

.main-page-wrapper .article-block .block-inner:nth-of-type(even) {
    background-color: #f2f9fc
}

.main-page-wrapper .article-block .block-inner:first-of-type .article-area {
    margin-top: 50px;
    padding-top: 0;
    padding-bottom: 80px
}

@media screen and (max-width: 768px) {
    .main-page-wrapper .article-block .block-inner:first-of-type .article-area {
        padding-bottom: 60px;
        margin-top: 0px;
        padding-top: 50px
    }
}

.main-page-wrapper .article-block .block-inner:not(:first-of-type) .article-area {
    border-top: 1px solid #00bfd1
}

.main-page-wrapper .article-area {
    width: min(800px, 90%);
    margin-inline: auto;
    padding: 80px 0 95px
}

@media screen and (max-width: 768px) {
    .main-page-wrapper .article-area {
        padding: 60px 0 40px
    }
}

.main-page-wrapper .article-area .area-title {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    gap: 15px
}

.main-page-wrapper .article-area .area-title .title-icon {
    width: clamp(60px, 6.25vw, 90px)
}

.main-page-wrapper .article-area .area-title .top-text {
    color: #00bfd1;
    font-size: clamp(4.2rem, 4.5138888889vw, 6.5rem);
    line-height: 1
}

.main-page-wrapper .article-area .area-title .bottom-text {
    font-size: clamp(1.4rem, 1.25vw, 1.8rem);
    letter-spacing: 1.08px
}

.main-page-wrapper .article-area .card-list {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(360px, calc(50% - 40px)));
    justify-content: flex-start;
    align-items: start;
    gap: 40px;
    margin-top: 40px
}

@media screen and (max-width: 768px) {
    .main-page-wrapper .article-area .card-list {
        grid-template-columns: 1fr
    }
}

.main-page-wrapper .article-area .card-list-item {
    letter-spacing: .1px
}

.main-page-wrapper .article-area .item-link:-moz-any-link:hover .card-img,
.main-page-wrapper .article-area .item-link:-moz-any-link:hover .link-icon {
    transform: scale(1.07);
    -moz-transition: all .4s;
    transition: all .4s
}

.main-page-wrapper .article-area .item-link:any-link:hover .card-img,
.main-page-wrapper .article-area .item-link:any-link:hover .link-icon {
    transform: scale(1.07);
    transition: all .4s
}

@media screen and (max-width: 768px) {
    .main-page-wrapper .article-area .item-link {
        display: grid;
        grid-template-columns: 160px 1fr;
        gap: 0 10px
    }
}

.main-page-wrapper .article-area .item-link .img-box {
    aspect-ratio: 16/9;
    overflow: hidden;
    border-radius: 4px
}

@media screen and (max-width: 768px) {
    .main-page-wrapper .article-area .item-link .img-box {
        grid-row: 1/4
    }
}

.main-page-wrapper .article-area .item-link .card-img {
    transition: all .4s
}

@media screen and (max-width: 768px) {
    .main-page-wrapper .article-area .item-link .card-img {
        max-inline-size: 100%
    }
}

.main-page-wrapper .article-area .item-link .top-container {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1em;
    margin-top: 10px
}

@media screen and (max-width: 768px) {
    .main-page-wrapper .article-area .item-link .top-container {
        grid-row: 1/2;
        flex-direction: column-reverse;
        align-items: flex-start;
        gap: 5px;
        margin-top: 0
    }
}

.main-page-wrapper .article-area .item-link .univ-place {
    color: #7f7f7f;
    font-size: clamp(1rem, .9027777778vw, 1.2rem);
    line-height: 1.5;
    font-weight: 500
}

.main-page-wrapper .article-area .item-link .category-wrp {
    display: flex;
    gap: 1rem
}

.main-page-wrapper .article-area .item-link .category {
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 2px .75em 0px;
    border: 1px solid #181818;
    border-radius: 999rem;
    font-size: clamp(1rem, .9722222222vw, 1.4rem)
}

.main-page-wrapper .article-area .item-link .univ-name {
    margin-top: 8px;
    font-size: clamp(1.3rem, 1.6666666667vw, 2.4rem)
}

@media screen and (max-width: 768px) {
    .main-page-wrapper .article-area .item-link .univ-name {
        margin-top: 0
    }
}

.main-page-wrapper .article-area .item-link .bottom-container {
    margin-top: 6px;
    font-size: clamp(1rem, .9722222222vw, 1.4rem)
}

@media screen and (max-width: 768px) {
    .main-page-wrapper .article-area .item-link .bottom-container {
        margin-top: 0
    }
}

.main-page-wrapper .article-area .item-link .tag-list {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
    align-items: center;
    gap: 5px;
    margin-top: 15px
}

@media screen and (max-width: 768px) {
    .main-page-wrapper .article-area .item-link .tag-list {
        grid-column: 1/3
    }
}

.main-page-wrapper .article-area .item-link .tag-list-item {
    padding: 0 .5em;
    background-color: #ffe97b;
    font-size: clamp(1rem, .8333333333vw, 1.2rem)
}

.main-page-wrapper .article-area .item-link .tag-list-item::before {
    content: "#"
}

.main-page-wrapper .article-area .item-link .link-icon {
    margin-top: 10px;
    margin-right: 0;
    margin-left: auto;
    transition: all .4s
}

@media screen and (max-width: 768px) {
    .main-page-wrapper .article-area .item-link .link-icon {
        display: none
    }
}

.other-page-link-area {
    width: min(1300px, 90%);
    margin: 0px auto 80px
}

.other-page-link-area .area-topic {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    gap: 1em;
    font-size: clamp(1.8rem, 1.3888888889vw, 2rem)
}

.other-page-link-area .area-topic::before {
    content: "";
    display: inline-block;
    aspect-ratio: 1/1;
    width: 20px;
    background-image: url(../img/icon-serch-b.svg)
}

.other-page-link-area .other-page-link-container {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-evenly;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 15px;
    margin-top: 30px;
    width: 100%
}

@media(max-width: 1000px) {
    .other-page-link-area .other-page-link-container {
        justify-content: center
    }
}

@media screen and (max-width: 768px) {
    .other-page-link-area .other-page-link-container {
        grid-template-columns: repeat(2, 1fr)
    }
}

.other-page-link-area .other-page-link-container .other-page-link-btn {
    padding: 10px 1em 8px;
    border: 1px solid #00bfd1;
    border-radius: 999rem;
    color: #00bfd1;
    font-size: clamp(1.6rem, 1.3888888889vw, 2rem);
    line-height: 1;
    text-align: center;
    width: 248px;
    justify-content: center
}

@media(max-width: 1500px) {
    .other-page-link-area .other-page-link-container .other-page-link-btn {
        width: 16vw
    }
}

@media(max-width: 1000px) {
    .other-page-link-area .other-page-link-container .other-page-link-btn {
        width: 24vw
    }
}

@media screen and (max-width: 768px) {
    .other-page-link-area .other-page-link-container .other-page-link-btn {
        padding: 13px 1em 11px;
        width: 100%
    }
}

.other-page-link-area .other-page-link-container .other-page-link-btn.current {
    background-color: #00bfd1;
    color: #fff
}

.back-link-btn {
    position: sticky;
    display: block;
    width: -moz-fit-content;
    width: fit-content;
    margin-right: 2%;
    margin-bottom: 20px;
    margin-left: auto;
    right: 2%;
    bottom: -10px;
    transition: all .4s;
    z-index: 999;
    transform: translateY(-120px)
}

.back-link-btn:-moz-any-link:hover {
    transform: translateY(-120px) scale(1.05);
    -moz-transition: all .4s;
    transition: all .4s
}

.back-link-btn:any-link:hover {
    transform: translateY(-120px) scale(1.05);
    transition: all .4s
}

@media screen and (max-width: 768px) {
    .back-link-btn {
        bottom: 20px;
        margin-top: 0px;
        margin-bottom: 0px;
        transform: translateY(-40px)
    }

    .back-link-btn:-moz-any-link:hover {
        transform: translateY(-40px) scale(1.05);
        -moz-transition: all .4s;
        transition: all .4s
    }

    .back-link-btn:any-link:hover {
        transform: translateY(-40px) scale(1.05);
        transition: all .4s
    }
}

.card-list:has(>:only-child) {
    gap: 0 !important
}

@media screen and (max-width: 768px) {
    .article-area:has(.card-list>:only-child) {
        padding-bottom: 80px !important
    }
}
.g-header *,
.g-footer *,
#float-menu * {
-webkit-box-sizing: content-box;
box-sizing: content-box;
}