@charset "UTF-8";
*,
:before,
:after  {
    box-sizing: border-box;
    border-style: solid;
    border-width: 0;
    min-width: 0
}
html  {
    line-height: 1.15;
    -webkit-text-size-adjust: 100%;
    -webkit-tap-highlight-color: transparent
}
body  {
    margin: 0
}
main  {
    display: block
}
p,
table,
blockquote,
address,
pre,
iframe,
form,
figure,
dl  {
    margin: 0
}
h1,
h2,
h3,
h4,
h5,
h6  {
    font-size: inherit;
    font-weight: inherit;
    margin: 0
}
ul,
ol  {
    margin: 0;
    padding: 0;
    list-style: none
}
dt  {
    font-weight: 700
}
dd  {
    margin-left: 0
}
hr  {
    box-sizing: content-box;
    height: 0;
    overflow: visible;
    border-top-width: 1px;
    margin: 0;
    clear: both;
    color: inherit
}
pre  {
    font-family: monospace, monospace;
    font-size: inherit
}
address  {
    font-style: inherit
}
a  {
    background-color: transparent;
    text-decoration: none;
    color: inherit
}
abbr[title]  {
    -webkit-text-decoration: underline dotted;
    text-decoration: underline dotted
}
b,
strong  {
    font-weight: bolder
}
code,
kbd,
samp  {
    font-family: monospace, monospace;
    font-size: inherit
}
small  {
    font-size: 80%
}
sub,
sup  {
    font-size: 75%;
    line-height: 0;
    position: relative;
    vertical-align: baseline
}
sub  {
    bottom: -.25em
}
sup  {
    top: -.5em
}
svg,
img,
embed,
object,
iframe  {
    vertical-align: bottom
}
button,
input,
optgroup,
select,
textarea  {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    vertical-align: middle;
    color: inherit;
    font: inherit;
    background: transparent;
    padding: 0;
    margin: 0;
    border-radius: 0;
    text-align: inherit;
    text-transform: inherit
}
button,
[type=button],
[type=reset],
[type=submit]  {
    cursor: pointer
}
button:disabled,
[type=button]:disabled,
[type=reset]:disabled,
[type=submit]:disabled  {
    cursor: default
}
:-moz-focusring  {
    outline: auto
}
select:disabled  {
    opacity: inherit
}
option  {
    padding: 0
}
fieldset  {
    margin: 0;
    padding: 0;
    min-width: 0
}
legend  {
    padding: 0
}
progress  {
    vertical-align: baseline
}
textarea  {
    overflow: auto
}
[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button  {
    height: auto
}
[type=search]  {
    outline-offset: -2px
}
[type=search]::-webkit-search-decoration  {
    -webkit-appearance: none
}
::-webkit-file-upload-button  {
    -webkit-appearance: button;
    font: inherit
}
[type=number]  {
    -moz-appearance: textfield
}
label[for]  {
    cursor: pointer
}
details  {
    display: block
}
summary  {
    display: list-item
}
[contenteditable]:focus  {
    outline: auto
}
table  {
    border-color: inherit;
    border-collapse: collapse
}
caption  {
    text-align: left
}
td,
th  {
    vertical-align: top;
    padding: 0
}
th  {
    text-align: left;
    font-weight: 700
}
:root  {
    --color-text-base: #424242;
    --color-white: #ffffff;
    --color-base: #EBEBED;
    --gradient-primary: linear-gradient(98.08deg, #198B9D 2.55%, #53D9BC 99.89%);
    --gradient-secondary: linear-gradient(88.76deg, #A76BBD .34%, #5C6DDF 99.2%);
    --gradient-tertiary: linear-gradient(90deg, #E5641A 0%, #DA892C 100%);
    --section-color-white: #ffffff;
    --section-color-dark: #424242;
    --font-family-jost: "Jost", sans-serif;
    --font-family-goldman: "Goldman", sans-serif
}
html  {
    scroll-behavior: smooth;
    font-size: 16px
}
body  {
    font-family: Noto Sans JP, sans-serif;
    color: #424242;
    background-color: #ebebed;
    font-size: 16px;
    font-weight: 400;
    line-height: 1.5;
    letter-spacing: .05em;
    overflow-wrap: anywhere;
    word-break: normal;
    line-break: strict
}
a  {
    display: block;
    transition: opacity .3s
}
img  {
    max-width: 100%;
    height: auto;
    object-fit: cover
}
table  {
    border-collapse: collapse;
    border: none
}
td,
th  {
    border: none
}
small  {
    font-size: 100%
}
strong  {
    font-weight: 700
}
.inner  {
    box-sizing: initial;
    padding-inline: 20px;
    max-inline-size: 1200px;
    margin-inline: auto
}
.inner-narrow  {
    max-inline-size: 1000px
}
.card  {
    background: var(--color-white);
    border-radius: var(--border-radius-lg);
    padding: var(--space-lg);
    box-shadow: var(--shadow-base)
}
.card-header  {
    margin-bottom: var(--space-md)
}
.card-title  {
    font-size: var(--font-size-heading);
    font-weight: var(--font-weight-bold);
    background: linear-gradient(90deg, var(--color-primary) 0%, var(--color-primary-light) 100%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    margin-bottom: var(--space-sm)
}
.card-body  {
    font-size: var(--font-size-small);
    line-height: var(--line-height-relaxed);
    letter-spacing: var(--letter-spacing-base);
    color: var(--color-text-base);
    text-align: center;
    margin-bottom: var(--space-lg)
}
.card-footer  {
    display: flex;
    gap: var(--space-lg);
    justify-content: center
}
.badge  {
    position: relative;
    display: inline-block;
    font-size: .875rem;
    padding: .4375rem 1.0625rem;
    font-family: var(--font-family-jost);
    font-weight: 600;
    letter-spacing: .1em;
    background: transparent;
    text-transform: uppercase;
    -webkit-clip-path: polygon(0% 0%, 100% 0, 100% 70%, 90% 100%, 0% 100%);
    clip-path: polygon(0% 0%, 100% 0, 100% 70%, 90% 100%, 0% 100%);
    background: var(--gradient-primary)
}
.badge:before  {
    content: "";
    position: absolute;
    inset: .0625rem;
    background: #fff;
    -webkit-clip-path: polygon(0% 0%, 100% 0, 100% 70%, 90% 100%, 0% 100%);
    clip-path: polygon(0% 0%, 100% 0, 100% 70%, 90% 100%, 0% 100%);
    z-index: -2
}
.badge-primary-white  {
    background: var(--gradient-primary)
}
.badge-primary-white:before  {
    background: #fff
}
.badge-primary-gray  {
    background: var(--gradient-primary)
}
.badge-primary-gray:before  {
    background: #fff
}
.badge-white-primary  {
    background: #fff
}
.badge-white-primary:before  {
    background: var(--gradient-primary)
}
.badge-white  {
    background: #fff
}
.badge-secondary:before  {
    background: linear-gradient(45deg, var(--color-accent-purple) 0%, var(--color-accent-purple-dark) 100%)
}
.section  {
    padding-block: 3.75rem
}
.section-background-gradient  {
    background: linear-gradient(98.08deg, #198b9d 2.55%, #53d9bc 99.89%)
}
.section-background-white  {
    background: #fff
}
.section-title  {
    font-size: 1.5rem;
    font-weight: 700;
    line-height: 1.5;
    padding-bottom: 1.875rem;
    position: relative;
    background: var(--gradient-primary);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    margin-top: 1.25rem
}
.section-title:after  {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: .0625rem;
    background: var(--gradient-primary)
}
.section-title-white  {
    color: var(--section-color-white);
    background: none
}
.section-title-black  {
    color: var(--section-color-dark);
    background: none
}
.section-title-white:after  {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: .0625rem;
    background: var(--section-color-white)
}
.section-description  {
    font-size: .875rem;
    font-weight: 500;
    line-height: 2;
    letter-spacing: .1em;
    margin-top: 1.25rem;
    background: var(--gradient-primary);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent
}
.section-description-white  {
    background: none;
    color: var(--section-color-white)
}
.section-description-dark  {
    background: none;
    color: var(--section-color-dark)
}
.section-content  {
    margin-top: 2.5rem
}
.check-icon  {
    position: relative;
    width: 1.5625rem;
    aspect-ratio: 1;
    flex-shrink: 0;
    border-radius: 50%;
    background: var(--gradient-primary);
    margin-top: .125rem
}
.check-icon:before  {
    content: "";
    position: absolute;
    inset: 0;
    background-color: #fff;
    border-radius: 50%;
    scale: .9;
    transform-origin: center
}
.check-icon:after  {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    translate: -50% -75%;
    rotate: -45deg;
    width: .75rem;
    height: .375rem;
    border-left: 1px solid;
    border-bottom: 1px solid;
    border-image: var(--gradient-primary) 1
}
.button  {
    display: inline-grid;
    grid-template-columns: 1fr auto 1fr;
    -moz-column-gap: .5em;
    column-gap: .5em;
    align-items: center;
    font-size: 1rem;
    font-weight: 500;
    letter-spacing: .1em;
    text-decoration: none;
    cursor: pointer;
    border: none;
    border-radius: 0;
    color: #fff;
    padding-block: 1em;
    padding-inline: 1em;
    background: var(--gradient-primary);
    transition: opacity .3s ease;
    width: 100%
}
.button:before  {
    content: ""
}
.button:after  {
    content: "";
    justify-self: end;
    width: 1.03125em;
    height: .3125em;
    background: url(../../assets/images/arrow-forward.png) no-repeat center/contain
}
.button--primary  {
    background: var(--gradient-primary)
}
.button--secondary  {
    background: var(--gradient-secondary)
}
.button--tertiary  {
    background: var(--gradient-tertiary)
}
.u-font-jost  {
    font-family: Jost, sans-serif
}
.u-font-goldman  {
    font-family: Goldman, sans-serif
}
.header  {
    padding-block: .9375rem
}
.header-logo  {
    width: 8.25rem;
    margin-inline: auto
}
.hero-section  {
    position: relative
}
.hero-background  {
    position: relative;
    height: 428px;
    margin: 0 var(--inner-padding-sp)
}
.hero-course-name  {
    font-family: Goldman, sans-serif;
    font-size: .75rem;
    color: #a5a3a1;
    font-weight: 400;
    line-height: 1.2;
    letter-spacing: -.02em;
    writing-mode: sideways-lr;
    flex-shrink: 0
}
.hero-visual-wrapper  {
    position: relative;
    display: flex;
    align-items: flex-start;
    gap: .4375rem
}
.visual-item  {
    position: absolute;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat
}
.visual-center  {
    top: 0;
    left: 60px;
    width: 194px;
    height: 372px;
    background-image: url(../../assets/images/hero-visual-center.jpg);
    z-index: 3
}
.visual-right  {
    top: 60px;
    right: 0;
    width: 44px;
    height: 312px;
    background-image: url(../../assets/images/hero-visual-right.jpg);
    z-index: 2
}
.visual-left  {
    top: 0;
    left: 0;
    width: 44px;
    height: 304px;
    background-image: url(../../assets/images/hero-visual-left.jpg);
    z-index: 1
}
.course-name  {
    position: absolute;
    top: 57px;
    left: 20px;
    width: 14px;
    height: 159px;
    font-family: Goldman, sans-serif;
    font-size: 12px;
    line-height: 1.2;
    letter-spacing: -.027em;
    color: var(--color-text-base);
    writing-mode: vertical-lr;
    -webkit-text-orientation: mixed;
    text-orientation: mixed;
    display: flex;
    align-items: center;
    justify-content: center
}
.hero-content  {
    position: relative;
    margin-top: -6.25rem
}
.hero-title-wrapper  {
    margin-inline: auto;
    width: -moz-fit-content;
    width: fit-content
}
.hero-title  {
    display: inline;
    -webkit-box-decoration-break: clone;
    box-decoration-break: clone;
    font-size: 1.5rem;
    font-weight: 700;
    line-height: 1.75;
    letter-spacing: .1em;
    background-color: #fff;
    padding-inline: .625rem 0;
    text-wrap: nowrap
}
.title-accent  {
    position: relative
}
.title-accent:before  {
    content: "";
    position: absolute;
    bottom: 4px;
    left: 0;
    width: 268px;
    height: 35px;
    background-color: var(--color-white);
    z-index: -1
}
.title-main  {
    position: relative
}
.hero-subtitle  {
    font-size: .75rem;
    line-height: 2;
    letter-spacing: .1em;
    margin-top: 1.6875rem
}
.hero-awards  {
    display: flex;
    justify-content: center;
    align-items: flex-end;
    gap: .625rem;
    margin-top: 1.25rem
}
.award-item  {
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding-inline: 1.125rem;
    padding-block: .625rem;
    z-index: 1;
    height: 3.625rem;
    width: 6.5rem;
    aspect-ratio: 104/58
}
.award-item:before  {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 50%;
    height: 100%;
    background-image: url(../../assets/images/award-left.svg);
    background-repeat: no-repeat;
    background-position: left center;
    background-size: contain;
    z-index: -1
}
.award-item:after  {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    width: 50%;
    height: 100%;
    background-image: url(../../assets/images/award-right.svg);
    background-repeat: no-repeat;
    background-position: right center;
    background-size: contain;
    z-index: -1
}
.award-number  {
    font-size: 1.25rem;
    font-weight: 700;
    line-height: 1.2;
    letter-spacing: -.02em;
    color: transparent;
    text-align: center;
    background: var(--gradient-primary);
    -webkit-background-clip: text;
    background-clip: text;
    z-index: 2
}
.award-number>span  {
    font-size: .625rem;
    color: var(--color-black)
}
.award-label  {
    font-size: .6875rem;
    line-height: 1.27;
    letter-spacing: 0;
    font-weight: 700;
    color: var(--color-black);
    text-align: center;
    position: relative;
    z-index: 2;
    white-space: nowrap
}
.hero-cta  {
    background-color: var(--color-white);
    padding-block: 1.375rem;
    margin-top: 1.875rem;
    border-image: linear-gradient(var(--color-white) 0 0) fill 0 //0 100lvi
}
.cta-title {
    font-size:.875rem;
    line-height:2;
    letter-spacing:.1em;
    text-align:center
}
.cta-title>span {
    font-size:1rem;
    letter-spacing:-.02em;
    margin-right:.3125rem
}
.course-brand {
    font-family:Goldman,sans-serif;
    font-size:16px;
    font-weight:400;
    line-height:1.75;
    letter-spacing:-.02em;
    color:var(--color-black)
}
.course-type {
    font-size:14px;
    font-weight:500;
    line-height:2;
    letter-spacing:.1em;
    color:var(--color-black)
}
.cta-button {
    max-width:18.75rem;
    margin-inline:auto;
    margin-top:.3125rem
}
.cta-button .button {
    font-size:1rem
}
.hero-container {
    display:block
}
.hero-sticky-banner {
    position:fixed;
    bottom:0;
    left:0;
    right:0;
    box-shadow:0 -4px 20px #0000001a;
    z-index:1000;
    transform:translateY(100%);
    transition:transform .3s ease;
    opacity:0;
    visibility:hidden
}
.hero-sticky-banner.is-visible {
    transform:translateY(0);
    opacity:1;
    visibility:visible
}
.hero-sticky-banner .hero-cta {
    margin-top:0
}
.curriculum-button {
    margin:0 0 3.75rem;
    text-align:center
}
.arrow:before {
    content:"";
    position:absolute;
    top:0;
    left:0;
    width:100%;
    height:1px;
    background-color:#fff
}
.arrow:after {
    content:"";
    position:absolute;
    top:-.125rem;
    right:0;
    width:.375rem;
    height:.25rem;
    border-right:1px solid #ffffff;
    border-bottom:1px solid #ffffff;
    transform:rotate(-45deg)
}
.course-subtitle {
    font-size:1.5rem;
    line-height:1.5;
    font-weight:700;
    color:#fff;
    margin-block:3.75rem 1.875rem
}
.sub-divider {
    width:100%;
    height:1px;
    background-color:#fff;
    margin:0 0 2.5rem
}
.course-cards {
    display:grid;
    grid-template-columns:repeat(auto-fill,minmax(min(360px,100%),1fr));
    gap:2.5rem
}
.course-cards:nth-of-type(1) .course-card {
    min-height:20.75rem
}
/* .course-cards:nth-of-type(2) .course-card {
    min-height:21.875rem
} */
.course-cards:nth-of-type(3) .course-card {
    min-height:25.625rem
}
.course-card {
    display:grid;
    grid-template-rows:auto auto 1fr;
    gap:1.25rem;
    background-color:#fff;
    padding-block:2.1875rem;
    padding-inline:1.875rem;
    -webkit-clip-path:polygon(0 0,100% 0,100% calc(100% - 2.5rem),calc(100% - 2.5rem) 100%,0 100%);
    clip-path:polygon(0 0,100% 0,100% calc(100% - 2.5rem),calc(100% - 2.5rem) 100%,0 100%)
}
.course-card:nth-child(1) .course-card-image {
    width:4.9375rem
}
.course-card:nth-child(2) .course-card-image {
    width:4.9375rem
}
.course-card:nth-child(3) .course-card-image {
    width:5.875rem
}
.course-card-image {
    justify-self:center
}
.course-card-title {
    justify-self:center;
    font-size:1.5rem;
    font-weight:700;
    line-height:1.4583333333;
    letter-spacing:0;
    background:var(--gradient-secondary);
    -webkit-background-clip:text;
    background-clip:text;
    color:transparent
}
.course-card-description {
    position:relative;
    font-size:.875rem;
    line-height:2;
    font-weight:400;
    letter-spacing:0;
    list-style:none;
    padding-left:1em
}
.course-card-description.course-card-description-period:before {
    position:absolute;
    content:"・";
    font-size:1em;
    left:0
}
.course-card-description+.course-card-description {
    margin-top:.625rem
}
.course-button {
    max-width:17.5rem;
    margin-inline:auto;
    margin-top:3.75rem
}
.community-section {
    background-color:#ebebed;
    padding-inline:0;
    border-image:linear-gradient(#ebebed 0 0) fill 0//0 100lvi
}
.community-cards {
    display:grid;
    grid-template-columns:repeat(auto-fill,minmax(min(342px,100%),1fr));
    gap:2.5rem 1.75rem
}
.community-card {
    display:grid;
    grid-template-rows:auto 1fr;
    gap:1.875rem
}
.community-card-image img {
    width:100%
}
.community-card:hover .community-card-image img {
    scale:none
}
.community-card-content {
    padding:0
}
.community-card-title {
    line-height:1.5;
    letter-spacing:-.02em
}
.support-cards {
    display:grid;
    grid-template-columns:repeat(auto-fill,minmax(min(342px,100%),1fr));
    gap:1.875rem
}
.support-card {
    display:grid;
    grid-template-rows:auto auto 1fr;
    gap:1.375rem;
    background-color:#fff;
    padding-block:1.875rem;
    padding-inline:1.625rem;
    -webkit-clip-path:polygon(0 0,100% 0,100% calc(100% - 2.5rem),calc(100% - 2.5rem) 100%,0 100%);
    clip-path:polygon(0 0,100% 0,100% calc(100% - 2.5rem),calc(100% - 2.5rem) 100%,0 100%)
}
.support-card-title {
    position:relative;
    font-size:1.25rem;
    font-weight:700;
    letter-spacing:.05em;
    background:var(--gradient-primary);
    -webkit-background-clip:text;
    background-clip:text;
    color:transparent;
    padding-bottom:.6875rem
}
.support-card-title:after {
    content:"";
    position:absolute;
    bottom:0;
    left:0;
    width:100%;
    height:.0625rem;
    background:var(--gradient-primary)
}
.support-card-image {
    width:100%
}
.support-card-description {
    font-size:.875rem;
    font-weight:400;
    letter-spacing:0;
    line-height:1.7142857143
}
.merit-item {
    display:flex;
    flex-direction:column;
    gap:1.25rem
}
.merit-item+.merit-item {
    margin-top:3.75rem
}
.merit-item-text-group {
    order:2
}
.merit-item-badge {
    position:relative;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    width:4.5rem;
    height:1.5625rem;
    background:var(--gradient-primary);
    -webkit-clip-path:polygon(0% 0%,100% 0,100% 70%,90% 100%,0% 100%);
    clip-path:polygon(0% 0%,100% 0,100% 70%,90% 100%,0% 100%);
    padding-block:.21875rem;
    margin-bottom:1.25rem
}
.merit-item-badge:before {
    content:"";
    position:absolute;
    inset:.0625rem;
    background:#fff;
    -webkit-clip-path:polygon(0% 0%,100% 0,100% 70%,90% 100%,0% 100%);
    clip-path:polygon(0% 0%,100% 0,100% 70%,90% 100%,0% 100%);
    z-index:-2
}
.merit-item-number {
    font-family:Futura PT,sans-serif;
    font-size:.875rem;
    font-weight:500;
    line-height:1.28;
    letter-spacing:.1em;
    color:#44403d
}
.merit-item-title {
    position:relative;
    font-size:1.25rem;
    line-height:1.5;
    font-weight:700;
    letter-spacing:.05em;
    padding-bottom:1.25rem
}
.merit-item-title:before {
    content:"";
    position:absolute;
    bottom:0;
    left:0;
    width:100%;
    height:.0625rem;
    background:var(--gradient-primary)
}
.merit-item-text {
    font-size:1rem;
    font-weight:400;
    line-height:2;
    letter-spacing:0;
    margin-top:1.25rem
}
.merit-item-image-group {
    order:1
}
.merit-item-collage {
    margin-top:1.25rem;
    display:flex;
    flex-direction:column;
    gap:.625rem
}
.merit-item-sub-image {
    width:100%;
    height:auto
}
.merit-item-caption {
    margin-top:.625rem;
    font-size:.75rem;
    font-weight:400;
    line-height:1.83;
    letter-spacing:.1em
}
.case-item {
    display:flex;
    flex-direction:column;
    gap:1.25rem
}
.case-item-image-group {
    order:1
}
.case-item-text-group {
    order:2
}
.case-item-section+.case-item-section {
    margin-top:2.5rem
}
.case-item-section-title {
    position:relative;
    font-size:1.25rem;
    line-height:1.45;
    font-weight:700;
    letter-spacing:.05em;
    padding-bottom:.9375rem;
    background:var(--gradient-primary);
    -webkit-background-clip:text;
    background-clip:text;
    color:transparent
}
.case-item-section-title:after {
    content:"";
    position:absolute;
    bottom:0;
    left:0;
    width:100%;
    height:.0625rem;
    background:var(--gradient-primary)
}
.case-item-text {
    font-size:1rem;
    font-weight:400;
    line-height:2;
    letter-spacing:0;
    margin-top:1.25rem;
    color:var(--color-text-base)
}
.value-items {
    display:grid;
    grid-template-columns:1fr;
    gap:2.5rem 0
}
.value-item {
    display:block
}
.value-item-header {
    display:contents
}
.value-item-title {
    font-size:1.5rem;
    font-weight:700;
    line-height:1.5;
    letter-spacing:0
}
.value-item-question {
    display:contents
}
.value-item-question-text {
    line-height:1.75;
    letter-spacing:.1em;
    margin-top:.9375rem
}
.value-item-chart {
    margin-top:1.875rem;
    max-width:21.875rem;
    margin-inline:auto
}
.value-item-chart-image {
    max-width:100%;
    height:auto
}
.value-item-testimonials {
    display:contents
}
.value-item-testimonial {
    display:flex;
    gap:.75rem;
    align-items:center;
    padding-block:1.25rem;
    padding-inline:.9375rem;
    border:1px solid currentColor;
    margin-top:1.875rem
}
.value-item-testimonial+.value-item-testimonial {
    margin-top:1.25rem
}
.value-item-testimonial-avatar {
    flex-shrink:0;
    width:3.4375rem;
    aspect-ratio:1
}
.value-item-testimonial-content {
    flex:1
}
.value-item-testimonial-text {
    font-size:.875rem;
    font-weight:400;
    line-height:1.57;
    letter-spacing:0
}
.contact-section {
    background:var(--gradient-primary);
    padding-block:3.75rem
}
.contact-content {
    background-color:#fff;
    padding-block:2.5rem;
    padding-inline:1.25rem;
    margin-top:0
}
.contact-title {
    position:relative;
    font-size:1.25rem;
    font-weight:700;
    line-height:1.2;
    letter-spacing:0;
    background:var(--gradient-primary);
    -webkit-background-clip:text;
    background-clip:text;
    color:transparent;
    padding-bottom:1.25rem;
    text-align:center
}
.contact-title:after {
    content:"";
    position:absolute;
    bottom:0;
    left:0;
    width:100%;
    height:.0625rem;
    background:var(--gradient-primary)
}
.contact-description {
    font-size:.875rem;
    font-weight:500;
    line-height:1.71;
    letter-spacing:.1em;
    padding-top:1.25rem
}
.contact-buttons {
    display:flex;
    flex-direction:column;
    gap:1.25rem;
    align-items:center;
    margin-top:1.25rem
}
.contact-button {
    width:100%;
    max-width:22.5rem;
    flex:1
}
.contact-buttons .button {
    font-size:.875rem
}
.trial-section {
    background-color:#ebebed;
    padding-block:3.75rem 8rem
}
.trial-banners {
    display:flex;
    flex-direction:column;
    gap:1.875rem
}
.trial-banner {
    display:block;
    text-decoration:none;
    transition:opacity var(--transition-default)
}
.trial-banner:hover {
    opacity:.8
}
.trial-cta {
    display:flex;
    justify-content:center;
    margin-top:1.875rem
}
.trial-cta-content {
    background-color:#fff;
    padding-block:1.6875rem;
    padding-inline:1.25rem;
    text-align:center;
    width:100%
}
.trial-cta-text {
    font-size:.875rem;
    font-weight:500;
    line-height:1.57;
    letter-spacing:.1em;
    color:#44403d
}
.trial-cta-button {
    margin-inline:auto;
    margin-top:1.25rem
}
.trial-cta-button .button {
    font-size:.8125rem;
    letter-spacing:0
}
.price-cards {
    display:grid;
    grid-template-columns:repeat(auto-fill,minmax(min(342px,100%),1fr));
    gap:1.875rem;
    margin-top:2.5rem
}
.price-card {
    display:inline-grid;
    background-color:#fff;
    padding-block:1.75rem;
    padding-inline:1.25rem;
    place-items:center
}
.price-card-tag {
    display:inline-grid;
    place-content:center;
    font-size:.875rem;
    font-weight:700;
    padding-block:.5rem;
    padding-inline:1.125rem;
    color:transparent;
    background:var(--gradient-secondary);
    -webkit-background-clip:text;
    background-clip:text;
    border:1px solid;
    border-image:linear-gradient(88.76deg,#a76bbd .34%,#5c6ddf 99.2%) 1
}
.price-card-price {
    display:flex;
    align-items:baseline;
    gap:.625rem;
    margin-top:.625rem
}
.price-card-amount {
    font-size:2.5rem;
    font-weight:700;
    letter-spacing:0;
    color:transparent;
    background:var(--gradient-secondary);
    -webkit-background-clip:text;
    background-clip:text
}
.price-card-details {
    display:flex;
    gap:.625rem;
    align-items:center
}
.price-card-label,.price-card-unit {
    font-size:.875rem;
    font-weight:500;
    letter-spacing:.05em
}
.price-card-monthly {
    font-family:Noto Sans JP,sans-serif;
    font-size:.875rem;
    font-weight:500;
    letter-spacing:0;
    margin-top:.4375rem
}
.price-support {
    font-size:.875rem;
    font-weight:400;
    letter-spacing:0;
    line-height:2;
    background-color:#fff;
    padding-block:1.875rem;
    padding-inline:1.25rem;
    margin-top:1.25rem
}
.price-support-content {
    max-width:62.5rem
}
.price-support-title {
    font-size:1.25rem;
    font-weight:700;
    letter-spacing:0;
    line-height:1.45;
    color:transparent;
    background:var(--gradient-primary);
    -webkit-background-clip:text;
    background-clip:text;
    text-align:center
}
.price-support-description {
    font-family:Noto Sans JP,sans-serif;
    font-size:.875rem;
    font-weight:400;
    line-height:2;
    padding-top:.9375rem
}
.price-notes {
    margin-top:1.25rem
}
.price-notes-text {
    font-family:Noto Sans JP,sans-serif;
    font-size:.875rem;
    font-weight:400;
    line-height:2;
    color:#fff
}
.price-notes-text a{
    display: inline-block;
    text-decoration: underline;
}
.present-images {
    max-width:52.5rem;
    margin-inline:auto
}
.present-title {
    font-size:1.5rem;
    font-weight:700;
    line-height:1.5;
    padding-bottom:1.875rem;
    position:relative;
    color:transparent;
    background:var(--gradient-primary);
    -webkit-background-clip:text;
    background-clip:text
}
.present-title:after {
    content:"";
    position:absolute;
    bottom:0;
    left:0;
    width:100%;
    height:.0625rem;
    background:var(--gradient-primary)
}
.present-items {
    display:flex;
    flex-direction:column;
    gap:.625rem;
    padding-block:1.875rem;
    max-width:42.5rem;
    border:1px solid #BBBBBB;
    border-radius:.3125rem;
    margin-top:1.875rem;
    margin-inline:auto
}
.present-item {
    display:flex;
    align-items:center;
    gap:.625rem;
    width:-moz-fit-content;
    width:fit-content;
    margin-inline:auto
}
.present-text {
    font-size:.875rem;
    font-weight:700;
    line-height:1.45;
    letter-spacing:.05em
}
.present-text {
    font-family:Noto Sans JP,sans-serif;
    font-size:.875rem;
    font-weight:700;
    line-height:1.45;
    letter-spacing:.05em;
    background:linear-gradient(45deg,#a76bbd,#5c6ddf);
    -webkit-background-clip:text;
    background-clip:text;
    color:transparent;
    flex:1
}
.guide-section {
    padding-block:2.5rem
}
.guide-content {
    position:relative;
    background-color:var(--color-white);
    border:1px solid #000;
    padding:var(--space-lg);
    margin:0 var(--inner-padding-sp);
    text-align:center
}
.guide-badge {
    order:1;
    align-self:flex-start;
    flex-shrink:0
}
.guide-title {
    font-size:1.25rem;
    line-height:1.6;
    padding-bottom:0;
    order:2
}
.guide-title:after {
    content:none
}
.guide-container {
    display:flex;
    flex-direction:column;
    align-items:center;
    border:1px solid #000000;
    background-color:var(--color-white);
    padding-block:2.5rem;
    padding-inline:1.25rem
}
.guide-container .section-label {
    margin-inline:0 auto
}
.guide-wrapper {
    display:contents;
    flex:1
}
.guide-image {
    order:3;
    max-width:12rem;
    margin-top:1.25rem
}
.guide-contents {
    order:4;
    text-align:left;
    margin-top:1.25rem;
    color:#1d2350
}
.guide-contents-title {
    font-size:.875rem;
    font-weight:400;
    line-height:2;
    letter-spacing:.1em
}
.guide-contents-items {
    display:flex;
    flex-direction:column;
    gap:.625rem;
    margin-top:.4375rem
}
.guide-contents-item {
    display:flex;
    align-items:flex-start;
    gap:.625rem
}
.guide-contents-item .check-icon {
    width:1.3125rem
}
.item-text {
    font-size:14px;
    font-weight:400;
    line-height:1.43;
    letter-spacing:.1em;
    color:#1d2350;
    flex:1
}
.guide-cta {
    order:5;
    margin-top:1.875rem;
    width:17.5rem
}
.future-section {
    padding-block:0
}
.future-container {
    background-color:var(--color-white);
    padding-block:4.375rem;
    border-image:linear-gradient(var(--color-white) 0 0) fill 0//0 100lvi
}
.future-header {
    text-align:left;
    margin-bottom:var(--space-xl)
}
.future-badge {
    display:inline-block;
    padding:var(--space-xs) var(--space-sm);
    background-color:var(--color-white);
    border:1px solid;
    border-image:linear-gradient(45deg,var(--color-primary) 0%,var(--color-primary-light) 100%) 1;
    border-radius:var(--border-radius-base);
    margin-bottom:var(--space-lg)
}
.badge-text {
    font-family:Futura PT,sans-serif;
    font-size:14px;
    font-weight:500;
    line-height:1.28;
    letter-spacing:.1em;
    color:var(--color-black)
}
.future-cards {
    display:grid;
    grid-template-columns:repeat(auto-fill,minmax(min(342px,100%),1fr));
    gap:2.5rem 1.59375rem
}
.feature-card {
    display:grid;
    grid-template-rows:auto 1fr;
    gap:1.875rem
}
.feature-card-image img {
    width:100%;
    height:auto;
    display:block;
    object-fit:cover
}
.feature-card-title {
    font-size:1.25rem;
    font-weight:700;
    letter-spacing:.05em;
    background:var(--gradient-primary);
    -webkit-background-clip:text;
    background-clip:text;
    color:transparent
}
.feature-card-description {
    font-size:1rem;
    font-weight:400;
    line-height:2;
    letter-spacing:-.02em;
    margin-top:1.25rem
}
@media screen and (min-width: 768px) {
    html {
        font-size:1.3333333333vw
    }
    .inner {
        padding-inline:20px
    }
    .section {
        padding-block:5rem 6.25rem
    }
    .section-title {
        font-size:2.25rem;
        line-height:1.7777777778
    }
    .check-icon {
        width:1.96875rem
    }
    .check-icon:after {
        translate:-50% -75%;
        width:1rem;
        height:.5rem
    }
    .button {
        font-size:1rem
    }
    .u-hidden-pc {
        display:none
    }
    .header {
        padding-block:1.875rem 0
    }
    .header-logo {
        width:15rem;
        margin-inline:0 auto
    }
    .hero-course-name {
        font-size:1rem;
        position:absolute;
        bottom:0;
        right:-2.5rem;
        writing-mode:vertical-lr
    }
    .hero-visual-wrapper {
        max-width:37.5rem
    }
    .hero-title-wrapper {
        width:100%
    }
    .hero-title {
        font-size:2.5rem
    }
    .hero-subtitle {
        font-size:.875rem;
        line-height:2.57
    }
    .hero-awards {
        gap:1.125rem;
        margin-top:2.0625rem
    }
    .award-item {
        justify-content:center;
        width:11rem;
        height:6.0625rem;
        aspect-ratio:176/97
    }
    .award-number {
        font-size:2rem
    }
    .award-number>span {
        font-size:1rem
    }
    .award-label {
        font-size:.9375rem
    }
    .hero-cta {
        border-image:none;
        padding-block:1.875rem;
        margin-top:4.875rem
    }
    .cta-title {
        font-size:1rem
    }
    .cta-title>span {
        font-size:1.25rem
    }
    .cta-button {
        max-width:21.25rem
    }
    .cta-button .button {
        font-size:1.125rem
    }
    .hero-container {
        display:flex;
        gap:1.25rem;
        flex-direction:row-reverse;
        align-items:flex-end;
        justify-content:space-between
    }
    .hero-sticky-banner {
        display:none
    }
    .course-subtitle {
        font-size:1.75rem;
        margin-block:3.75rem 2.5rem
    }
    .course-cards:nth-of-type(1) .course-card {
        min-height:25.625rem
    }
    /* .course-cards:nth-of-type(2) .course-card {
        min-height:23.75rem
    } */
    .course-button {
        max-width:20rem;
        margin-top:3.125rem
    }
    .community-section {
        padding-inline:3.75rem;
        border-image:none;
        padding-bottom:6.25rem
    }
    .support-card-title {
        font-size:1.5rem;
        letter-spacing:.05em
    }
    .merit-item {
        flex-direction:row;
        align-items:flex-start;
        justify-content:space-between
    }
    .merit-item+.merit-item {
        margin-top:6.25rem
    }
    .merit-item-reverse {
        flex-direction:row-reverse
    }
    .merit-item-text-group {
        flex:1;
        max-width:32.5rem
    }
    .merit-item-badge {
        margin-bottom:2.1875rem
    }
    .merit-item-title {
        font-size:1.75rem
    }
    .merit-item-text {
        line-height:1.75;
        letter-spacing:.1em
    }
    .merit-item-image-group {
        flex:1;
        max-width:36.25rem;
        margin-top:1.5625rem
    }
    .merit-item-collage {
        margin-top:1.875rem
    }
    .merit-item-caption {
        margin-top:1.25rem;
        font-size:.875rem
    }
    .case-item {
        flex-direction:row;
        align-items:flex-start;
        justify-content:space-between
    }
    .case-item-image-group,.case-item-text-group {
        flex:1;
        max-width:35.625rem
    }
    .case-item-section+.case-item-section {
        margin-top:3.75rem
    }
    .case-item-section-title {
        font-size:1.25rem
    }
    .case-item-text {
        line-height:2
    }
    .value-items {
        display:grid;
        grid-template-columns:repeat(2,minmax(min(300px,100%),1fr));
        gap:0 3.125rem
    }
    .value-item {
        display:grid;
        grid-template-rows:subgrid;
        grid-row:span 5
    }
    .value-item-title {
        inline-size:-moz-fit-content;
        inline-size:fit-content;
        margin-inline:auto;
        font-size:1.75rem
    }
    .value-item-question-text {
        inline-size:-moz-fit-content;
        inline-size:fit-content;
        margin-inline:auto;
        margin-top:1.25rem
    }
    .value-item-testimonial {
        gap:1.75rem;
        padding-block:1.25rem;
        padding-inline:1.25rem
    }
    .value-item-testimonial+.value-item-testimonial {
        margin-top:1.875rem
    }
    .value-item-testimonial-avatar {
        width:4.375rem
    }
    .value-item-testimonial-text {
        font-size:1rem;
        line-height:1.8
    }
    .contact-section {
        padding-block:5rem
    }
    .contact-content {
        padding-block:3.75rem;
        padding-inline:8.125rem
    }
    .contact-title {
        font-size:1.75rem;
        margin-bottom:1.5rem
    }
    .contact-description {
        line-height:2;
        margin-bottom:3.125rem;
        text-align:center
    }
    .contact-buttons {
        flex-direction:row;
        justify-content:center;
        gap:1.25rem
    }
    .contact-buttons .button {
        font-size:1rem
    }
    .trial-section {
        padding-block:5rem
    }
    .trial-banners {
        gap:1.875rem;
        flex-direction:row;
        align-items:flex-start
    }
    .trial-banner {
        flex:452.91
    }
    .trial-banner:nth-of-type(1) {
        flex:592.56
    }
    .trial-banner:nth-of-type(2) {
        flex:452.91
    }
    .trial-cta {
        margin-top:3.3125rem
    }
    .trial-cta-content {
        max-width:50rem;
        padding-block:2.5rem
    }
    .trial-cta-text {
        font-size:1rem;
        line-height:1.75
    }
    .trial-cta-button {
        max-width:29.5rem;
        margin-top:1.875rem
    }
    .trial-cta-button .button {
        font-size:1.125rem
    }
    .price-cards {
        gap:1.875rem;
        margin-top:3.75rem
    }
    .price-support {
        padding-block:1.875rem;
        padding-inline:5.8125rem
    }
    .price-support-title {
        text-align:left
    }
    .price-support-description {
        padding-top:.625rem
    }
    .present-section-title {
        margin-top:0;
        text-align:center
    }
    .present-section-title:after {
        content:none
    }
    .present-section-description {
        text-align:center
    }
    .present-items {
        margin-top:2.8125rem
    }
    .present-text {
        font-size:1.125rem
    }
    .guide-section {
        padding-block:5rem 0
    }
    .guide-title {
        font-size:1.25rem;
        line-height:1.4;
        margin-top:0
    }
    .guide-container {
        flex-direction:row;
        align-items:flex-start;
        padding-inline:3.75rem
    }
    .guide-wrapper {
        order:3;
        display:block;
        margin-left:6.75rem
    }
    .guide-image {
        margin-top:0;
        max-width:15.75rem;
        margin-left:2.5rem
    }
    .guide-contents-item {
        align-items:center
    }
    .guide-contents-item .check-icon:after {
        translate:-50% -75%;
        width:.625rem;
        height:.3125rem
    }
    .guide-cta {
        max-width:20.5rem
    }
    .future-container {
        padding-inline:3.75rem
    }
}
@media (min-width: 1200px) {
    html {
        font-size:16px
    }
}
@media screen and (max-width: 767px) {
    .u-hidden-sp {
        display:none
    }
}
@media (max-width: 375px) {
    html {
        font-size:4.2666666667vw
    }
}
@media (any-hover: hover) {
    a:hover,.button:hover {
        opacity:.7
    }
}

/* footer */

/* フッター全体のスタイル */
.footer {
    background-color: #fff;
    padding: 80px 0;
    color: #404040;
    font-family: "ｍｓ ゴシック", "ms gothic", "ヒラギノ角ゴ pro w3", "hiragino kaku gothic pro", osaka, sans-serif;
  }
  
  .footer-inner {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px;
  }
  
  .footer-content {
    display: flex;
    justify-content: center;
  }
  
  .footer-content-inner {
    text-align: center;
  }
  
  /* SNSシェアボタンのスタイル */
  .sns-list {
    display: flex;
    justify-content: center;
    gap: 20px;
    margin-bottom: 50px;
    list-style: none;
    padding: 0;
  }
  
  .sns-list li a,
  .sns-list li button {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    color: #404040;
    text-decoration: none;
    font-size: 10px;
    transition: opacity 0.3s;
  }
  
  .sns-list li a:hover,
  .sns-list li button:hover {
    opacity: 0.7;
  }
  
  .sns-list svg {
    width: 25px;
    height: 25px;
  }
  
  /* ポリシーリンクのスタイル */
  .policy-list {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: 20px;
    margin-bottom: 60px;
    list-style: none;
    padding: 0;
  }
  
  .policy-item a {
    color: #404040;
    text-decoration: underline;
    font-size: 12px;
    transition: opacity 0.3s;
  }
  
  .policy-item a:hover {
    opacity: 0.7;
    text-decoration: none;
  }
  
  /* コピーライトのスタイル */
  .footer-copyright {
    font-size: 10px;
    color: #999;
  }
  
  /* レスポンシブ対応 */
  @media screen and (max-width: 768px) {
    .footer {
        padding: 80px 20px 180px;
    }
    .policy-list {
      flex-direction: column;
      align-items: center;
      gap: 10px;
    }
    
    .sns-list {
      gap: 15px;
    }
  }