@charset "UTF-8";

:root {
    --color-mv-bg: #FFFDF0;    

    --color-mint: #4DC4B0;
    --color-mint-dark: #2BAE94;
    --color-mint-bg: #c9ead6;
    --color-mint-pale: #EAF7F1;

    --color-orange: #EF822B;
    --color-orange-dark: #EF822B;
    --color-orange-pale: #FEEFD8;

    --color-yellow-bg: #FDF6E0;
    --color-yellow-pale: #FFFAE8;

    --color-red: #E84855;
    --color-amazon: #F5A23B;

    --color-text: #333333;
    --color-text-light: #666666;
    --color-white: #FFFFFF;

    --shadow-card: 0 4px 12px rgba(0, 0, 0, 0.06);

    --font-base: 'Noto Sans JP', sans-serif;
    --font-accent-meister: 'Zen Maru Gothic', sans-serif;
    --fw-medium: 600;
    --fw-bold: 800;

    --container-max: 1200px;
}


/* ---------------
 * Base
 * --------------- */
* {
    box-sizing: border-box;
}

html {
    font-size: 100%;
    scroll-behavior: smooth;
}

body {
    font-family: var(--font-base);
    font-size: 16px;
    font-weight: var(--fw-medium);
    line-height: 1.7;
    color: var(--color-text);
    background-color: var(--color-white);
    -webkit-font-smoothing: antialiased;
}

img {
    display: block;
    max-width: 100%;
    height: auto;
}

main {
    background-image:
        url("/kankou/meister/img/bg-white.svg"),
        linear-gradient(180deg, #C9EAD6 0%, #C9EAD6 20%, #8ECBB8 29.81%, #F3D698 50.48%, #FFF0D9 73.56%, #FFE4CA 100%);
    background-repeat: repeat-y, no-repeat;
    background-position: center 30vh, center top;
    background-size: 120vw auto, 100% 100%;
}

main figure img {
    cursor: zoom-in;
}

main figure img:hover {
    opacity: 0.8;
}

a {
    color: inherit;
    text-decoration: none;
    transition: opacity 0.3s ease;
}

a:hover {
    opacity: 0.7;
}

button {
    padding: 0;
    font-family: inherit;
    background: none;
    border: none;
    cursor: pointer;
}


/* ---------------
 * Utility
 * --------------- */
.visually-hidden {
    position: absolute;
    width: 1px;
    height: 1px;
    margin: -1px;
    padding: 0;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.is-hidden {
    display: none !important;
}

.is-no-scroll {
    overflow: hidden;
}

.is-modal-open {
    overflow: hidden;
}

.sp-only {
    display: none;
}


/* ---------------
 * Main visual
 * --------------- */
.mainvisual {
    min-height: clamp(420px, 30vw, 760px);
    background-image:
        url("/kankou/meister/img/wave-mint.svg"),
        linear-gradient(180deg, var(--color-mv-bg) 30%, var(--color-mv-bg) 100%, rgba(255, 253, 240, 0) 100%);
    background-position: center 4.5vh, center top;
    background-repeat: no-repeat, no-repeat;
    background-size: 100% auto, 100% 100%;
}

.mainvisual-inner {
    position: relative;
    display: grid;
    grid-template-columns: minmax(280px, clamp(548px, 38vw, 760px)) minmax(240px, clamp(460px, 32vw, 620px));
    justify-content: center;
    align-items: center;
    gap: clamp(16px, 3vw, 24px);
    max-width: min(1600px, calc(100% - 48px));
    margin: 0 auto;
    padding: clamp(24px, 2.4vw, 40px) 24px 0;
    justify-items: center;
}

.mainvisual-inner::before {
    content: "";
    position: absolute;
    top: 2vh;
    left: -1vw;
    width: 114px;
    height: 111px;
    aspect-ratio: 38/37;
    background: url("/kankou/meister/img/img-character1.png") no-repeat center / contain;
    pointer-events: none;
}

.mainvisual-catch {
    grid-column: 1 / -1;
    margin: 0;
    padding-bottom: 22px;
    font-size: 18px;
    font-family: var(--font-accent-meister);
    font-weight: var(--fw-bold);
    text-align: center;
    color: var(--color-text);
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='276' height='16' viewBox='0 0 276 16' fill='none'%3E%3Cpath d='M275 1H211.036L197.661 15V1H0' stroke='%23231815' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: center bottom;
    background-size: min(276px, 92vw) auto;
}

.mainvisual-title {
    width: 100%;
    max-width: clamp(548px, 38vw, 760px);
    grid-column: 1;
    margin: 0;
    line-height: 1.2;
}

.mainvisual-lead {
    position: relative;
    width: 100%;
    max-width: clamp(345px, 24vw, 480px);
    grid-column: 1;
    grid-row: 3;
    margin: 24px 0 0;
    font-size: clamp(18px, 1.25vw, 24px);
    font-weight: var(--fw-bold);
    line-height: 1.6;
    color: var(--color-text);
}

.mainvisual-lead::before {
    content: "";
    position: absolute;
    top: -80px;
    left: -80px;
    width: 99px;
    height: 97px;
    aspect-ratio: 99/97;
    background: url("/kankou/meister/img/img-character2.png") no-repeat center / contain;
    pointer-events: none;
}

.mainvisual-lead img {
    position: relative;
    z-index: 1;
}

.mainvisual-products {
    position: relative;
    width: 100%;
    max-width: clamp(460px, 32vw, 620px);
    grid-column: 2;
    grid-row: 2 / span 2;
    display: flex;
    justify-content: center;
    align-items: flex-end;
    gap: 16px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.mainvisual-products::after {
    content: "";
    position: absolute;
    right: -88px;
    bottom: -86px;
    width: 160px;
    height: 212px;
    background: url("/kankou/meister/img/img-key3.svg") no-repeat center / contain;
    pointer-events: none;
}

.mainvisual-products img {
    width: 100%;
    height: auto;
    z-index: 1;
}

@media (min-width: 768px) {
    .feature-inner,
    .ichimon-inner,
    .zuhan-inner,
    .summary-inner,
    .recommend-inner {
        width: min(calc(100% - 48px), var(--container-max));
    }
}


/* ---------------
 * Feature
 * --------------- */
.feature {
    padding: 64px 0 80px;
}

.feature-inner {
    max-width: var(--container-max);
    margin: 0 auto;
}

.feature-list {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 32px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.feature-item {
    position: relative;
    padding: clamp(24px, 3vw, 32px) clamp(14px, 1.8vw, 20px);
    text-align: center;
    background-color: var(--color-white);
    border-radius: 16px;
    box-shadow: var(--shadow-card);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: clamp(8px, 1vw, 12px);
    flex-shrink: 0;
}

.feature-item:first-child::after {
    content: "";
    position: absolute;
    left: -56px;
    bottom: 7px;
    width: 97px;
    height: 94px;
    aspect-ratio: 97/94;
    background: url("/kankou/meister/img/img-key1.svg") no-repeat center / contain;
}

.feature-item:last-child::before {
    content: "";
    position: absolute;
    right: -20px;
    top: -20px;
    width: 111px;
    height: 78px;
    background: url("/kankou/meister/img/img-seat.png") no-repeat center / contain;
}

.feature-text {
    text-align: center;
    font-family: var(--font-accent-meister);
    font-size: clamp(16px, 1.7vw, 21px);
    font-style: normal;
    font-weight: 700;
    line-height: 150%; /* 31.5px */
    color: var(--color-text);
}

.feature-em {
    display: inline-block;
    font-size: clamp(18px, 2vw, 24px);
    padding: 0 8px;
    font-weight: var(--fw-bold);
    background: var(--color-orange-pale);
}


/* ---------------
 * Ichimon (一問一答ページ)
 * --------------- */
.ichimon {
    position: relative;
    padding: 64px 0;
}

.ichimon-inner, .zuhan-inner {
    position: relative;
    max-width: var(--container-max);
    margin: 0 auto;
    padding: 64px 48px;
    background-color: var(--color-white);
    border-radius: 24px;
    box-shadow: var(--shadow-card);
}

.ichimon-inner::before {
    content: "";
    position: absolute;
    top: -64px;
    left: 50%;
    width: 88.591px;
    height: 88.933px;
    background-image: url("/kankou/meister/img/img-titlekey1.svg");
    background-size: 100%;
    transform: translateX(-50%);
}

.ichimon-title {
    display: block;
    width: fit-content;
    margin: 0 auto 32px;
    padding: 8px 32px;
    font-size: 28px;
    font-weight: var(--fw-bold);
    color: var(--color-white);
    background: url("/kankou/meister/img/img-titlewave.svg") no-repeat center center, var(--color-mint-dark);
    border-radius: 999px;
}

.ichimon-figure {
    margin: 0 auto 48px;
    max-width: 520px;
}

.ichimon-figure img {
    width: 100%;
}

.ichimon-points {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 32px;
    margin-bottom: 48px;
}

.ichimon-point-title {
    margin: 0 0 24px;
    padding-bottom: 8px;
    font-size: 22px;
    font-weight: var(--fw-bold);
    color: var(--color-mint-dark);
    text-align: center;
    border-bottom: 2px dotted var(--color-mint);
}

.ichimon-point-title::before {
    content: "";
    display: inline-block;
    width: 19px;
    height: 19px;
    margin-right: 8px;
    background: url("/kankou/meister/img/img-sec1-textdetail.svg") no-repeat center / contain;
    vertical-align: -2px;
}

.ichimon-point-list {
    margin: 0;
    padding: 0;
    list-style: none;
    counter-reset: none;
}

.ichimon-point-item {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 16px;
    padding: 12px 16px;
    background-color: var(--color-mint-pale);
    border-radius: 8px;
}

.ichimon-point-num {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    aspect-ratio: 1/1;
    padding-bottom: 2px;
    font-size: 24px;
    font-weight: var(--fw-bold);
    font-family: var(--font-accent-meister);
    color: var(--color-white);
    background-color: var(--color-mint-dark);
    border: 3px solid #FFF;
    box-shadow: 0 2px 2px 0 rgba(0, 0, 0, 0.12);
    border-radius: 50%;
}

.ichimon-point-text {
    margin: 0;
    font-size: 18px;
    line-height: 1.6;
}

.ichimon-point-text .em {
    font-weight: var(--fw-bold);
    color: var(--color-mint-dark);
    padding: 0 2px;
}

.ichimon-point-text .em > span {
    color: #7ABD3C;
}

.ichimon-samples {
    display: flex;
    gap: 48px;
    margin: 0;
    padding: 0;
    list-style: none;
    justify-items: center;
    justify-content: center;
}

.ichimon-sample-figure {
    margin: 0;
    text-align: center;
}

.ichimon-sample-figure img {
    width: 240px;
    height: auto;
    aspect-ratio: 3/4;
    margin-bottom: 8px;
}

.ichimon-sample-caption {
    font-size: 14px;
    font-weight: var(--fw-bold);
    color: var(--color-text);
}


/* ---------------
 * Zuhan (図版・資料/さくいんページ)
 * --------------- */
.zuhan {
    position: relative;
    padding: 64px 0;
}

.zuhan-inner::before {
    content: "";
    position: absolute;
    top: -64px;
    left: 50%;
    width: 90px;
    height: 87px;
    background-image: url("/kankou/meister/img/img-titlekey2.svg");
    background-size: 100%;
    transform: translateX(-50%);
}

.zuhan-title {
    display: block;
    width: fit-content;
    margin: 0 auto 16px;
    padding: 8px 32px;
    font-size: 22px;
    font-weight: var(--fw-bold);
    color: var(--color-white);
    background: url("/kankou/meister/img/img-titlewave.svg") no-repeat center center, var(--color-orange);
    border-radius: 999px;
}

.zuhan-subtitle {
    margin: 0 0 24px;
    padding-bottom: 8px;
    font-size: 22px;
    font-weight: var(--fw-bold);
    color: var(--color-orange-dark);
    text-align: center;
    border-bottom: 2px dotted var(--color-orange);
}

.zuhan-subtitle::before {
    content: "";
    display: inline-block;
    width: 19px;
    height: 19px;
    margin-right: 8px;
    background: url("/kankou/meister/img/img-sec2-textdetail.svg") no-repeat center / contain;
    vertical-align: -2px;
}

.zuhan-content {
    display: grid;
    grid-template-columns: 1fr 1fr;
    align-items: center;
    gap: 32px;
}

.zuhan-samples {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.zuhan-sample-figure {
    margin: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
}

.zuhan-sample-figure img {
    width: 100%;
    max-width: 240px;
    margin-bottom: 8px;
}

.zuhan-sample-caption {
    font-size: 13px;
    font-weight: var(--fw-bold);
    color: var(--color-text);
}

.zuhan-point-list {
    margin: 0;
    padding: 0;
    list-style: none;
}

.zuhan-point-item {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 16px;
    padding: 16px;
    background-color: var(--color-orange-pale);
    border-radius: 8px;
}

.zuhan-point-num {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    aspect-ratio: 1/1;
    font-size: 24px;
    font-weight: var(--fw-bold);
    font-family: var(--font-accent-meister);
    color: var(--color-white);
    background-color: var(--color-orange);
    border: 3px solid #FFF;
    box-shadow: 0 2px 2px 0 rgba(0, 0, 0, 0.12);
    border-radius: 50%;
}

.zuhan-point-text {
    margin: 0;
    font-size: 18px;
    line-height: 1.6;
}

.zuhan-point-text .em  {
    font-weight: var(--fw-bold);
    color: var(--color-orange-dark);
    padding: 0 2px;
}

.zuhan-point-text > span:not(.em) {
    color: #FF3624;
}



/* ---------------
 * Summary (学習サイクル)
 * --------------- */
.summary {
    --c-summary-card: #FFFFFF;
    --c-summary-bubble-mint: #F3F9F5;
    --c-summary-bubble-cream: #FFF4E2;

    position: relative;
    padding: 96px 24px 80px;
    overflow: hidden;
}

.summary-inner {
    position: relative;
    z-index: 2;
    max-width: var(--container-max);
    margin: 0 auto;
    padding: 64px 72px;
    background-color: var(--c-summary-card);
    border-radius: 32px;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.04);
}

.summary-inner::before,
.summary-inner::after {
    content: "";
    position: absolute;
    z-index: 1;
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    pointer-events: none;
}

.summary-inner::before {
    top: -64px;
    left: 50%;
    width: 88.591px;
    height: 88.933px;
    background-image: url("/kankou/meister/img/img-titlekey1.svg");
    background-size: 100%;
    transform: translateX(-50%);
}

.summary-inner::after {
    content: none;
}

.summary-content::before,
.summary-content::after {
    content: "";
    position: absolute;
    z-index: 1;
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    pointer-events: none;
}

.summary-content::before {
    width: clamp(88px, 15vw, 181px);
    height: auto;
    aspect-ratio: 151/146;
    top: clamp(-48px, -4vw, -20px);
    left: clamp(-56px, -5vw, -24px);
    background-image: url("/kankou/meister/img/img-key2.svg");
}

.summary-content::after {
    width: clamp(82px, 14vw, 170px);
    height: auto;
    aspect-ratio: 34/33;
    right: clamp(-56px, -5vw, -24px);
    bottom: clamp(-44px, -4vw, -18px);
    background-image: url("/kankou/meister/img/img-key1.svg");
}

.summary-content {
    position: relative;
    z-index: 2;
}

.summary-content > * {
    position: relative;
    z-index: 2;
}

.summary-content {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: clamp(10px, 1.8vw, 20px);
    width: min(100%, 1000px);
    margin: 0 auto;
}

.summary-content > img {
    width: clamp(170px, 22vw, 260px);
    height: auto;
    flex-shrink: 1;
}

.summary-lead-left,
.summary-lead-right {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    width: clamp(130px, 22vw, 210px);
    aspect-ratio: 1 / 1;
    height: auto;
    margin: 0;
    font-size: 20px;
    font-family: var(--font-accent-meister);
    font-weight: var(--fw-bold);
    line-height: 1.5;
    text-align: center;
    color: var(--color-text);
    border-radius: 50%;
}

.summary-lead-left {
    background-color: var(--c-summary-bubble-mint);
}

.summary-lead-right {
    background-color: var(--c-summary-bubble-cream);
}

.summary-lead-left::after {
    content: "";
    position: absolute;
    top: 50%;
    right: -14px;
    width: 20px;
    height: 24px;
    background-color: var(--c-summary-bubble-mint);
    clip-path: polygon(0 0, 100% 50%, 0 100%);
    transform: translateY(-50%);
}

.summary-lead-right::after {
    content: "";
    position: absolute;
    top: 50%;
    left: -14px;
    width: 20px;
    height: 24px;
    background-color: var(--c-summary-bubble-cream);
    clip-path: polygon(100% 0, 0 50%, 100% 100%);
    transform: translateY(-50%);
}



/* ---------------
 * Purchase
 * --------------- */
.purchase {
    padding: 64px 0;
    background-image:linear-gradient(#FFF0D9, #FFE4CA),
        url("/kankou/meister/img/img-titlewave2.svg");
    background-repeat: no-repeat;
    background-position: center bottom 68%;
    background-size: 180vw;
    background-blend-mode: multiply;
}

.purchase-inner {
    position: relative;
    z-index: 2;
    width: min(calc(100% - 48px), var(--container-max));
    max-width: var(--container-max);
    margin: 0 auto;
    padding: 64px 48px;
    background-color: var(--color-white);
    border-radius: 24px;
    box-shadow: var(--shadow-card);
    text-align: center;
}

.purchase-inner::before {
    content: "";
    position: absolute;
    top: -64px;
    left: 50%;
    width: 90px;
    height: 90px;
    background-image: url("/kankou/meister/img/img-titlecart.svg");
    background-size: 100%;
    transform: translateX(-50%);
}

.purchase-title {
    position: relative;
    margin: 0 0 32px;
    font-size: 28px;
    font-family: var(--font-accent-meister);
    font-weight: var(--fw-bold);
    color: var(--color-text);
}

.purchase-list {
    display: flex;
    flex-direction: column;
    gap: 32px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.purchase-btn {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    max-width: 500px;
    height: 64px;
    padding: 0 32px;
    font-size: 18px;
    font-weight: var(--fw-bold);
    color: var(--color-white);
    background-color: var(--color-amazon);
    border-radius: 999px;
    box-shadow: var(--shadow-card);
    transition: opacity 0.3s ease, transform 0.3s ease;
}

.purchase-btn::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 24px;
    width: 10px;
    height: 10px;
    border-top: 2px solid var(--color-white);
    border-right: 2px solid var(--color-white);
    transform: translateY(-50%) rotate(45deg);
}

.purchase-btn-amazon {
    background-color: var(--color-amazon);
    border-radius: 16px;
    box-shadow: 0 6px 0 0 #A07129;
    margin: auto;
}

.purchase-btn-rakuten {
    background-color: var(--color-red);
    border-radius: 16px;
    box-shadow: 0 6px 0 0 #BC4147;
    margin: auto;
}

.purchase-btn:hover {
    opacity: 1;
    transform: translateY(-2px);
}


/* ---------------
 * Recommend
 * --------------- */
.recommend {
    padding: 64px 0 80px;
    background-color: var(--color-yellow-bg);
    background: linear-gradient(180deg, #FFF0D9 0%, #FFDDC2 100%);
}

.recommend-inner {
    max-width: var(--container-max);
    margin: 0 auto;
    padding: 0 24px;
}

.recommend-title {
    position: relative;
    margin: 0 0 32px;
    font-size: 24px;
    font-weight: var(--fw-bold);
    text-align: center;
    color: var(--color-text);
}

.recommend-title::after {
    content: "";
    display: block;
    width: 56px;
    height: 2px;
    margin: 8px auto 0;
    background-color: var(--color-text);
}

.recommend-list {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.recommend-link {
    display: block;
    height: 100%;
    transition: transform 0.3s ease;
}

.recommend-link:hover {
    opacity: 1;
    transform: translateY(-4px);
}

.recommend-figure {
    margin: 0 0 12px;
    text-align: center;
}

.recommend-figure img {
    max-width: 140px;
    margin: 0 auto;
}

.recommend-item-title {
    margin: 0 0 8px;
    font-size: 15px;
    font-weight: var(--fw-bold);
    text-align: center;
    color: var(--color-text);
}

.recommend-item-text {
    margin: 0;
    font-size: 12px;
    line-height: 1.7;
    color: var(--color-text-light);
}


/* ---------------
 * Footer
 * --------------- */
.footer {
    display: flex;
    padding: 24px 0;
    background-color: var(--color-yellow-pale);
    justify-content: center;
}


/* ---------------
 * Page top button
 * --------------- */
.page-top {
    position: fixed;
    right: 24px;
    bottom: 24px;
    z-index: 50;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 64px;
    height: 64px;
    color: var(--color-white);
    background-color: var(--color-mint);
    border-radius: 50%;
    box-shadow: var(--shadow-card);
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.3s ease, visibility 0.3s ease, transform 0.3s ease;
}

.page-top::before {
    content: "";
    width: 12px;
    height: 12px;
    border-top: 2px solid var(--color-white);
    border-right: 2px solid var(--color-white);
    transform: translateY(2px) rotate(-45deg);
}

.page-top.is-visible {
    opacity: 1;
    visibility: visible;
}

.page-top:hover {
    opacity: 1;
    transform: translateY(-4px);
}


/* ---------------
 * modal
 * --------------- */
.image-modal {
    position: fixed;
    inset: 0;
    z-index: 200;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 24px;
    background: rgba(0, 0, 0, 0.72);
}

.image-modal.is-open {
    display: flex;
}

.image-modal__dialog {
    position: relative;
    max-height: calc(100vh - 48px);
}

.image-modal__img {
    width: 100%;
    max-height: calc(100vh - 140px);
    object-fit: contain;
    margin: 0 auto;
}

.image-modal__caption {
    margin: 10px 0 0;
    font-size: 14px;
    text-align: center;
    color: #FFFFFF;
}

.image-modal__close {
    position: absolute;
    top: -50px;
    right: -7px;
    width: 36px;
    height: 36px;
    font-size: 32px;
    line-height: 1;
    color: #FFFFFF;
    opacity: 0.9;
}

.image-modal__close:hover {
    opacity: 1;
}


/* ===============================================
 * Responsive - SP (max-width: 767px)
 * =============================================== */
@media (max-width: 767px) {

    .sp-only {
        display: block;
    }

    body {
        font-size: 16px;
    }

    main {
    background-image:
        url("/kankou/meister/img/bg-white.svg"),
        linear-gradient(180deg, #c0e7d2 0%, #c0e7d2 15%, #8ECBB8 29.81%, #F3D698 50.48%, #FFF0D9 73.56%, #FFE4CA 100%);
    }

    /* ---------------
     * Mainvisual SP
     * --------------- */
    .mainvisual {
        background-image:
            url("/kankou/meister/img/wave-mint.svg"),
            linear-gradient(180deg, var(--color-mv-bg) 30%, var(--color-mv-bg) 70%, rgba(255, 253, 240, 0) 100%);
        min-height: auto;
        padding: 32px 0 24px;
        background-position: right 26% bottom -100px, center top;
        background-size: clamp(1200px, 130vw, 1200px) auto;
    }

    .mainvisual-inner {
        grid-template-columns: 1fr;
        gap: 0;
        padding: 0 16px;
        text-align: center;
    }

    .mainvisual-inner::before {
        content: none;
    }

    .mainvisual-catch {
        font-size: 16px;
        margin-bottom: 16px;
        padding-bottom: 16px;
        background-size: min(220px, 88vw) auto;
    }

    .mainvisual-title {
        position: relative;
        grid-column: 1;
    }

    .mainvisual-title::before {
        content: "";
        position: absolute;
        top: -25%;
        right: -9vw;
        width: 71px;
        height: 70px;
        aspect-ratio: 71/70;
        background: url("/kankou/meister/img/img-character2.png") no-repeat center / contain;
        pointer-events: none;
    }

    .mainvisual-lead {
        grid-column: 1;
        grid-row: 4;
        font-size: 16px;
    }

    .mainvisual-lead::before {
        content: none;
    }

    .mainvisual-products {
        position: relative;
        grid-column: 1;
        grid-row: 3;
    }

    .mainvisual-products::after {
        content: "";
        top: 30vh;
        z-index: 0;
        transform: translateX(-50%);
    }

    .mainvisual-products::before {
        content: "";
        position: absolute;
        top: -25px;
        left: -7vw;
        width: 56px;
        height: 54px;
        background: url("/kankou/meister/img/img-character1.png") no-repeat center / contain;
        pointer-events: none;
    }

    /* ---------------
     * Feature SP
     * --------------- */
    .feature {
        padding: 40px 0;
    }

    .feature-inner {
        padding: 0 16px;
    }

    .feature-list {
        grid-template-columns: 1fr;
        gap: 32px;
    }

    .feature-item {
        padding: 16px 16px 32px;
        min-height: auto;
    }

    .feature-item:first-child::after {
        left: auto;
        right: -18px;
        top: -10px;
        bottom: auto;
        width: 78px;
        height: 76px;
    }

    .feature-item:last-child::before {
        right: auto;
        left: -14px;
        top: 18px;
        width: 88px;
        height: 62px;
        transform: translateY(-50%);
    }

    .feature-text {
        font-size: 16px;
    }


    /* ---------------
     * Ichimon SP
     * --------------- */
    .ichimon {
        padding: 48px 0;
    }

    .ichimon-inner {
        padding: 48px 16px 32px;
        margin: 0 16px;
        border-radius: 16px;
    }

    .ichimon-title {
        font-size: 16px;
        padding: 6px 20px;
        margin-bottom: 24px;
    }

    .ichimon-figure {
        margin-bottom: 32px;
    }

    .ichimon-points {
        grid-template-columns: 1fr;
        gap: 24px;
        margin-bottom: 32px;
    }

    .ichimon-point-title {
        font-size: 17px;
        margin-bottom: 16px;
    }

    .ichimon-point-item {
        padding: 8px 12px;
    }

    .ichimon-point-num {
        width: 28px;
        height: 28px;
        font-size: 16px;
    }

    .ichimon-point-text {
        font-size: 16px;
    }

    .ichimon-samples {
        gap: 16px;
    }


    /* ---------------
     * Zuhan SP
     * --------------- */
    .zuhan {
        padding: 48px 0;
    }

    .zuhan-inner {
        padding: 48px 16px 32px;
        margin: 0 16px;
        border-radius: 16px;
    }

    .zuhan-title {
        font-size: 16px;
        padding: 6px 20px;
    }

    .zuhan-subtitle {
        font-size: 17px;
    }

    .zuhan-content {
        grid-template-columns: 1fr;
        gap: 24px;
    }

    .zuhan-point-text {
        font-size: 16px;
    }


    /* ---------------
     * Summary SP
     * --------------- */
    .summary {
        padding: 72px 0 56px;
    }

    .summary-inner {
        padding: 48px 16px 32px;
        margin: 0 16px;
        border-radius: 16px;
    }

    .summary-content::before,
    .summary-content::after {
        width: 100px;
        height: 97px;
        aspect-ratio: 100/97;
    }

    .summary-content::before {
        top: -20px;
        left: -10px;
    }

    .summary-content::after {
        right: -10px;
        bottom: -18px;
    }

    .summary-content {
        flex-direction: column;
        align-items: center;
        gap: 16px;
        width: 100%;
    }

    .summary-content > img {
        width: min(240px, 72vw);
    }

    .summary-lead-left,
    .summary-lead-right {
        width: min(210px, 78vw);
        aspect-ratio: 1 / 1;
        height: auto;
        font-size: 16px;
        padding: 16px;
    }

    .summary-lead-left::after {
        top: auto;
        right: 50%;
        bottom: -12px;
        width: 24px;
        height: 14px;
        clip-path: polygon(0 0, 100% 0, 50% 100%);
        transform: translateX(50%);
    }

    .summary-lead-right::after {
        top: -12px;
        left: 50%;
        bottom: auto;
        width: 24px;
        height: 14px;
        clip-path: polygon(50% 0, 0 100%, 100% 100%);
        transform: translateX(-50%);
    }

    /* ---------------
     * Purchase SP
     * --------------- */
    .purchase {
        padding: 48px 0;
    }

    .purchase-inner {
        padding: 48px 16px 32px;
        margin: 0 16px;
        border-radius: 16px;
    }

    .purchase-inner::before {
        top: -48px;
        width: 72px;
        height: 72px;
    }

    .purchase-btn {
        height: 56px;
        font-size: 16px;
    }


    /* ---------------
     * Recommend SP
     * --------------- */
    .recommend {
        padding: 48px 0 56px;
    }

    .recommend-title {
        font-size: 20px;
    }

    .recommend-list {
        grid-template-columns: 1fr;
        gap: 24px;
    }

    .recommend-figure img {
        max-width: 120px;
    }

    .recommend-item-title,
    .recommend-item-text,
    .footer-copyright {
        font-size: 16px;
    }


    /* ---------------
     * Page top SP
     * --------------- */
    .page-top {
        right: 16px;
        bottom: 16px;
        width: 50px;
        height: 50px;
    }

}
