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

:root {
    --gold: #c9a84c;
    --gold-light: #e8d5a3;
    --gold-dim: rgba(201,168,76,0.12);
    --green-deep: #1e3d20;
    --green-mid: #2d5a30;
    --green-light: #4a7a4e;
    --green-pale: #e8f0e8;
    --green-border: rgba(45,90,48,0.15);
    --bg: #f7f4ed;
    --bg2: #f0ece2;
    --bg3: #ebe6da;
    --card: #ffffff;
    --card2: #faf8f3;
    --text: #1a2e1c;
    --text2: #4a6b4e;
    --text3: #8a9e8c;
    --text4: #2d4a30;
    --border: rgba(45,90,48,0.12);
    --serif: 'Noto Serif JP',serif;
    --sans: 'Noto Sans JP',sans-serif;
}

body {
    background: var(--bg);
    color: var(--text);
    font-family: var(--sans);
    line-height: 1.75;
    -webkit-font-smoothing: antialiased;
    overflow-x: hidden;
}

/* ── IMAGES ── */
.img-full {
    display: block;
    width: 100%;
    max-width: 100%;
    height: auto;
}

.section-divider {
    margin-top: 4rem;
    overflow: hidden;
}

/* ── 手描きディバイダー ── */
.divider {
    display: block;
    padding-top: 1rem;
    padding-bottom: 1rem;
    width: min(512px, 88%);

    /* デスクトップ512px、スマホは画面の88%に縮む */
    height: auto;

    /* 縦横比を維持して追従 */
    margin: 0 auto;
}

.location-photo {
    margin-bottom: 44px;
}

.strategy-figure {
    text-align: center;
    margin-bottom: 2rem;
}

.strategy-figure img {
    display: inline-block;
    max-width: min(80%, 560px);
    height: auto;
}

.strategy-links {
    display: grid;
    grid-template-columns: repeat(3,minmax(0,1fr));
    gap: 14px;
}

.strategy-link {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    min-width: 0;
    padding: 0;
    background: var(--card);
    border: 1px solid var(--green-border);
    text-align: center;
    color: var(--green-mid);
    transition: all .25s;
    overflow: hidden;
}

.strategy-link__thumb {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 180px;
    padding: 12px;
    box-sizing: border-box;
    background: var(--bg2);
    border-bottom: 1px solid var(--green-border);
    overflow: hidden;
}

.strategy-link__thumb img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: contain;
    object-position: center;
    box-shadow: 2px 4px 14px rgba(30,61,32,0.18);
}

.strategy-link__thumb--placeholder {
    background: linear-gradient(160deg, var(--bg2) 0%, var(--bg3) 100%);
}

.strategy-link__label {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 72px;
    padding: 16px 14px;
    font-family: var(--serif);
    font-size: 14px;
    letter-spacing: .08em;
    line-height: 1.6;
}

.strategy-link:hover {
    border-color: var(--green-mid);
    color: var(--green-deep);
    box-shadow: 0 4px 16px rgba(30,61,32,0.1);
    transform: translateY(-2px);
}

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

/* ── LAYOUT ── */
.sec {
    padding: 100px 24px;
    border-top: 1px solid var(--border);
}

.sec-sm {
    padding: 68px 24px;
    border-top: 1px solid var(--border);
}

.w {
    max-width: 920px;
    margin: 0 auto;
}

.w-sm {
    max-width: 680px;
    margin: 0 auto;
}

.w-xs {
    max-width: 800px;
    margin: 0 auto;
}

/* ── TYPE ── */
.serif {
    font-family: var(--serif);
    font-weight: 400;
}

.cap {
    font-size: 12px;
    letter-spacing: .2em;
    text-transform: uppercase;
    color: var(--green-mid);
    display: block;
    text-align: center;
    margin-bottom: 20px;
}

.h1 {
    font-family: var(--serif);
    font-weight: 400;
    font-size: clamp(34px,5.5vw,60px);
    line-height: 1.4;
    letter-spacing: .04em;
}

.h2 {
    font-family: var(--serif);
    font-weight: 400;
    font-size: clamp(26px,3.8vw,40px);
    line-height: 1.4;
    letter-spacing: .04em;
    text-align: center;
}

.h3 {
    font-family: var(--serif);
    font-weight: 400;
    font-size: clamp(19px,2.6vw,26px);
    line-height: 1.5;
}

.lead {
    font-size: 17px;
    color: var(--text2);
    line-height: 1.95;
    text-align: center;
}

.body {
    font-size: 15px;
    color: var(--text2);
    line-height: 1.9;
}

.sm {
    font-size: 13px;
    color: var(--text3);
    letter-spacing: .06em;
}

.gold {
    color: var(--gold);
}

.green {
    color: var(--green-mid);
}

/* ── GOLD LINE ── */
.gl {
    width: 52px;
    height: 1px;
    background: linear-gradient(90deg,transparent,var(--gold),transparent);
    margin: 36px auto;
}

/* ── CARD ── */
.card {
    background: var(--card);
    border: 1px solid var(--green-border);
    position: relative;
    box-shadow: 0 2px 16px rgba(30,61,32,0.06);
}

.card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 2px;
    background: linear-gradient(90deg,transparent,var(--gold),transparent);
}

/* ── BADGE ── */
.bf {
    background: rgba(45,90,48,0.08);
    color: var(--green-mid);
    border: 1px solid rgba(45,90,48,0.25);
    font-size: 11px;
    letter-spacing: .15em;
    padding: 3px 12px;
    display: inline-block;
}

.bp {
    background: var(--gold-dim);
    color: #8a6820;
    border: 1px solid rgba(201,168,76,0.4);
    font-size: 11px;
    letter-spacing: .15em;
    padding: 3px 12px;
    display: inline-block;
}

/* ── BUTTONS ── */
.btn {
    display: inline-block;
    font-family: var(--serif);
    letter-spacing: .12em;
    padding: 16px 36px;
    cursor: pointer;
    transition: all .25s;
    text-align: center;
    border: none;
    font-size: 14px;
}

.btn-g {
    background: var(--green-deep);
    color: #f5f2eb;
    font-weight: 500;
}

.btn-g:hover {
    background: var(--green-mid);
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(30,61,32,0.25);
}

.btn-gold {
    background: var(--gold);
    color: #1a2e1c;
    font-weight: 500;
}

.btn-gold:hover {
    background: var(--gold-light);
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(201,168,76,0.35);
}

.btn-o {
    background: transparent;
    color: var(--green-deep);
    border: 1.5px solid var(--green-mid);
}

.btn-o:hover {
    background: var(--green-pale);
}

.btn-sm {
    font-size: 13px;
    padding: 11px 24px;
    letter-spacing: .1em;
}

/* ── NAV ── */
nav {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 100;
    padding: 16px 28px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    background: var(--green-deep);
    box-shadow: 0 2px 12px rgba(0,0,0,0.2);
}

.nav-logo {
    font-family: var(--serif);
    font-size: 17px;
    color: var(--gold);
    letter-spacing: .12em;
}

.nav-links {
    display: flex;
    gap: 24px;
    align-items: center;
}

/* モバイル専用UIはデスクトップでは非表示 */
.nav-quick {
    display: none;
}

/* ブランドマークはモバイルのみ表示（デスクトップはテキストロゴ） */
.nav-logo-mark {
    display: none;
}

.nav-sep {
    color: #fff;
}

.nav-link {
    font-size: 12px;
    letter-spacing: .12em;
    color: rgba(245,242,235,0.65);
    transition: color .2s;
}

.nav-link:hover {
    color: var(--gold);
}

.nav-link[aria-current="page"] {
    color: var(--gold);

    /* 文字色をゴールドに */
    border-bottom: 2px solid var(--gold);

    /* 短い下線 */
    padding-bottom: 4px;

    /* 下線と文字の間隔 */
}

/* ── HERO ── */
#hero {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    overflow: hidden;
    padding: 100px 24px;

    /* background: linear-gradient(160deg, #e8f0e4 0%, #f5f2eb 45%, #eae5d8 100%); */
    border-top: none;
}

.hero-forest-bg {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    pointer-events: none;

    /* 追加：高さを一定程度で止める設定 */
    /* max-height: 160px;  ここに上限としたい高さを指定（例：600px や 80vh など） */
    /* height: 160px;既存の高さ設定（例：アスペクト比やビューポート指定など） */
    width: 100%;
    height: 100vh;

    /* または aspect-ratio: 16/9; など */
    background-color: transparent;
    z-index: 1;

    /* 中のテキストなどが隠れないようにする */
}

/* 2. 背景画像専用のレイヤー（擬似要素）の設定 */
.hero-forest-bg::before {
    content: "";

    /* ★必須：擬似要素を表示させるためのおまじない */
    position: absolute;

    /* 親要素（.hero-section）を基準に絶対配置 */
    bottom: 0;

    /* 下端にピッタリくっつける */
    left: 0;
    width: 100%;

    /* ★ここで背景レイヤーの高さを制御します */
    height: 160px;

    /* 背景画像の設定をここに記述 */
    background-image: url('../images/Ginza-BuildingView-Divider-160.png');
    background-position: center bottom;
    background-repeat: no-repeat;
    z-index: -1;

    /* テキストなどのコンテンツより後ろ（背面）に配置 */
}

.yatsugatake-divider {
    bottom: 0;
    left: 0;
    right: 0;
    pointer-events: none;
    background-image: url('../images/Mountain-Skyline-Divider-green-160-g.png');
    height: 160px;
    background-position: center bottom;
    background-repeat: no-repeat;
}

.hero-light {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    pointer-events: none;
    overflow: hidden;
}

.hero-ray {
    position: absolute;
    top: -10%;
    width: 2px;
    background: linear-gradient(180deg,rgba(201,168,76,0.12),rgba(180,220,120,0.08),transparent);
    animation: sway 10s ease-in-out infinite;
    transform-origin: top center;
}

@keyframes sway{
    0%,
    100% {
        transform: rotate(-3deg);
    }

    50% {
        transform: rotate(3deg);
    }
}

.hero-content {
    position: relative;
    z-index: 1;
    text-align: center;
    max-width: 760px;
    width: 100%;
    min-width: 0;
}

.hero-content img {
    display: block;
    max-width: 100%;
    max-height: 180px;
    height: auto;
    width: auto;
    margin: 0 auto;
}

.hero-forest-bg img {
    display: block;
    width: 100%;
    height: auto;
}

.hero-date-box {
    display: inline-flex;
    align-items: center;
    gap: 20px;
    padding: 12px 28px;
    margin-bottom: 1rem;
    background: rgba(255,255,255,0.7);
    border: 1px solid rgba(45,90,48,0.2);
    backdrop-filter: blur(4px);
}

.hero-date-text {
    font-size: 14px;
    color: var(--green-mid);
    letter-spacing: .1em;
    font-family: var(--serif);
}

.hero-date-sep {
    width: 1px;
    height: 18px;
    background: rgba(45,90,48,0.2);
}

.hero-btns {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
    justify-content: center;
    margin-top: 44px;
}

.scroll-hint {
    margin-top: 2rem;
    margin-bottom: 2rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
}

.scroll-line {
    width: 1px;
    height: 56px;
    background: linear-gradient(180deg,transparent,var(--green-mid));
    animation: pulse 2s ease-in-out infinite;
}

@keyframes pulse{
    0%,
    100% {
        opacity: .3;
    }

    50% {
        opacity: .9;
    }
}

/* ── HERO v2 ── */
.hero__lead {
    font-family: var(--serif);
    font-size: clamp(16px,2.4vw,20px);
    color: var(--text2);
    letter-spacing: .12em;
    line-height: 1.8;
    margin-bottom: 24px;
    margin-top: 1rem;
}

.hero__title {
    font-family: var(--serif);
    font-weight: 400;
    font-size: clamp(2rem,5vw,3rem);
    line-height: 1.35;
    letter-spacing: .06em;
    color: var(--green-deep);
    margin-bottom: 20px;
}

.hero__brand {
    font-family: var(--serif);
    font-size: clamp(18px,2.8vw,28px);
    color: var(--gold);
    letter-spacing: .15em;
    margin-bottom: 44px;
}

/* ── ABOUT (What is Open Lab?) ── */
.section--about {
    background: var(--bg);
}

.about__intro {
    margin-top: 36px;
    text-align: center;
}

.about__intro p {
    margin-bottom: 24px;
}

.about__intro p:last-child {
    margin-bottom: 0;
}

/* ── DIVERSITY ── */
.section--diversity {
    background: var(--bg2);
}

.diversity-cards {
    display: grid;
    grid-template-columns: repeat(2,1fr);
    gap: 14px;
}

.diversity-card {
    background: var(--card);
    border: 1px solid var(--green-border);
    padding: 28px 26px;
    position: relative;
    transition: all .25s;
}

.diversity-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 2px;
    background: linear-gradient(90deg,var(--green-mid),var(--gold),transparent);
}

.diversity-card:hover {
    border-color: var(--green-mid);
    box-shadow: 0 4px 16px rgba(30,61,32,0.1);
    transform: translateY(-2px);
}

.diversity-card__title {
    font-family: var(--serif);
    font-size: clamp(16px,2vw,19px);
    color: var(--green-mid);
    margin-bottom: 10px;
    letter-spacing: .06em;
}

.diversity-card__description {
    font-size: 15px;
    color: var(--text2);
    line-height: 1.9;
}

.section-conclusion {
    font-style: normal;
}

/* ── LOCATIONS ── */
.section--locations {
    background: var(--bg3);
}

.location-cards {
    display: grid;
    grid-template-columns: repeat(3,1fr);
    gap: 14px;
    margin-top: 44px;
}

.location-cards--duo {
    grid-template-columns: repeat(2,1fr);
}

.location-card {
    background: var(--card);
    border: 1px solid var(--green-border);
    padding: 32px 26px;
    text-align: center;
    position: relative;
    transition: all .25s;
}

.location-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 2px;
    background: linear-gradient(90deg,var(--green-mid),var(--gold),transparent);
}

.location-card:hover {
    border-color: var(--green-mid);
    box-shadow: 0 4px 16px rgba(30,61,32,0.1);
    transform: translateY(-2px);
}

.location-card__name {
    font-family: var(--serif);
    font-size: clamp(18px,2.4vw,22px);
    color: var(--text);
    letter-spacing: .1em;
    margin-bottom: 12px;
}

.location-card__description {
    font-size: 15px;
    color: var(--text2);
    line-height: 1.8;
}

.locations__host {
    margin-top: 52px;
    text-align: center;
    padding: 32px;
    background: var(--card);
    border: 1px solid var(--green-border);
}

.locations__host-label {
    font-family: var(--serif);
    font-size: 14px;
    letter-spacing: .2em;
    color: var(--green-mid);
    text-transform: uppercase;
    margin-bottom: 12px;
}

.locations__host-link {
    display: inline-block;
    margin-top: 14px;
    font-family: var(--serif);
    font-size: 13px;
    letter-spacing: .1em;
    color: var(--green-mid);
    border-bottom: 1px solid var(--green-border);
    padding-bottom: 2px;
    transition: color .2s;
}

.locations__host-link:hover {
    color: var(--green-deep);
}

/* ── PREP ── */
#prep {
    background: var(--bg2);
}

.prep-grid {
    display: grid;
    grid-template-columns: repeat(3,1fr);
    gap: 4px;
    margin: 40px 0;
}

.prep-item {
    padding: 24px 22px;
    background: var(--card);
    border: 1px solid var(--green-border);
    display: flex;
    gap: 16px;
    align-items: flex-start;
}

.prep-n {
    font-family: var(--serif);
    font-size: 22px;
    color: var(--gold);
    min-width: 30px;
    line-height: 1;
}

.prep-types {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
    margin-top: 28px;
}

.prep-type {
    padding: 24px;
    border: 1px solid var(--green-border);
    background: var(--card);
    position: relative;
}

.prep-type::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 2px;
    background: linear-gradient(90deg,transparent,var(--gold),transparent);
}

.prep-type-tag {
    font-size: 11px;
    letter-spacing: .15em;
    color: var(--green-mid);
    margin-bottom: 10px;
    display: block;
    text-transform: uppercase;
}

/* ── SESSION ── */
#session {
    background: var(--bg3);
}

.tl-item {
    display: flex;
    gap: 20px;
    margin-bottom: 4px;
}

.tl-time {
    min-width: 72px;
    padding: 20px 0;
    text-align: right;
    font-family: var(--serif);
    font-size: 14px;
    color: var(--gold);
    letter-spacing: .05em;
    line-height: 1;
    flex-shrink: 0;
}

.tl-body {
    flex: 1;
    padding: 22px 26px;
    background: var(--card);
    border: 1px solid var(--green-border);
    position: relative;
}

.tl-body.highlight {
    border-left: 3px solid var(--green-mid);
}

.tl-body.highlight::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 2px;
    background: linear-gradient(90deg,var(--green-mid),var(--gold),transparent);
}

.tl-title {
    font-family: var(--serif);
    font-size: 18px;
    margin-bottom: 6px;
    color: var(--text);
}

.tl-sub {
    font-size: 14px;
    color: var(--text2);
}

/* ── SCHEDULE ── */
#schedule {
    background: var(--bg);
}

.sch-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 16px;
    padding: 20px 26px;
    border: 1px solid var(--green-border);
    background: var(--card);
    margin-bottom: 6px;
    flex-wrap: wrap;
    transition: all .25s;
}

.sch-item:hover {
    border-color: var(--green-mid);
    box-shadow: 0 2px 12px rgba(30,61,32,0.08);
}

.sch-l {
    display: flex;
    align-items: center;
    gap: 16px;
    flex-wrap: wrap;
}

.sch-r {
    text-align: right;
}

/* ── FORM ── */
#form {
    background: var(--bg2);
    border-top: 2px solid var(--green-mid);
}

.field {
    margin-bottom: 20px;
}

.field-label {
    display: block;
    font-size: 13px;
    font-weight: 500;
    color: var(--text4);
    letter-spacing: .08em;
    margin-bottom: 8px;
}

.field-label .req {
    color: var(--gold);
    margin-left: 4px;
}

.field-hint {
    font-size: 12px;
    color: var(--text3);
    margin-top: 5px;
}

.inp {
    background: #fff;
    border: 1.5px solid rgba(45,90,48,0.2);
    color: var(--text);
    font-family: var(--sans);
    font-size: 15px;
    padding: 13px 16px;
    width: 100%;
    transition: border-color .2s,box-shadow .2s;
}

.inp:focus {
    outline: none;
    border-color: var(--green-mid);
    box-shadow: 0 0 0 3px rgba(45,90,48,0.08);
}

.inp::placeholder {
    color: transparent;
}

/* プレースホルダー非表示 */
select.inp {
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%234a7a4e' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 14px center;
    padding-right: 40px;
}

.type-sel {
    display: grid;
    grid-template-columns: repeat(auto-fit,minmax(150px,1fr));
    gap: 8px;
    margin-bottom: 24px;
}

.type-btn {
    padding: 14px 12px;
    text-align: left;
    cursor: pointer;
    border: 1.5px solid rgba(45,90,48,0.2);
    background: #fff;
    color: var(--text2);
    font-family: var(--sans);
    font-size: 13px;
    line-height: 1.6;
    transition: all .2s;
}

.type-btn.active {
    border-color: var(--green-mid);
    background: var(--green-pale);
    color: var(--green-deep);
    font-weight: 500;
}

.form-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit,minmax(220px,1fr));
    gap: 16px;
}

.cb-wrap {
    display: flex;
    gap: 12px;
    align-items: flex-start;
    padding: 16px;
    border: 1.5px solid rgba(45,90,48,0.15);
    background: #fff;
    margin-bottom: 20px;
    cursor: pointer;
}

.cb-wrap input[type=checkbox] {
    margin-top: 3px;
    accent-color: var(--green-mid);
    width: 16px;
    height: 16px;
    flex-shrink: 0;
}

.cb-label {
    font-size: 14px;
    color: var(--text2);
    line-height: 1.65;
}

.cb-label strong {
    color: var(--text);
    font-weight: 500;
}

.success-box {
    background: var(--card);
    border: 2px solid var(--green-mid);
    padding: 60px 32px;
    text-align: center;
    display: none;
}

/* ── DIVIDER ── */
.layer-div {
    padding: 56px 24px;
    background: var(--green-deep);
    text-align: center;
    position: relative;
    overflow: hidden;
}

.layer-div-fg {
    position: relative;
    z-index: 1;
}

/* ── SECOND LAYER ── */
#problem {
    background: var(--bg);
}

.prob-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit,minmax(240px,1fr));
    gap: 10px;
    margin: 40px 0;
}

.prob-item {
    background: var(--card);
    border: 1px solid var(--green-border);
    padding: 22px;
    display: flex;
    gap: 14px;
    align-items: flex-start;
    border-left: 3px solid var(--gold);
}

.prob-n {
    font-family: var(--serif);
    font-size: 22px;
    color: var(--gold);
    min-width: 30px;
}

#reversal {
    background: var(--bg2);
}

.evidence {
    background: var(--card);
    border: 1px solid var(--green-border);
    border-left: 3px solid var(--green-mid);
    padding: 36px;
    margin: 28px 0;
}

.fork {
    background: var(--green-pale);
    border: 1px solid rgba(45,90,48,0.2);
    padding: 28px 32px;
    text-align: center;
    margin-top: 24px;
}

.fork-inner {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 28px;
    margin-top: 16px;
    flex-wrap: wrap;
}

#strategy {
    background: var(--bg3);
}

.d-grid {
    display: grid;
    grid-template-columns: repeat(3,1fr);
    gap: 10px;
}

.d-card {
    background: var(--card);
    border: 1px solid var(--green-border);
    padding: 24px;
    position: relative;
    transition: all .25s;
}

.d-card:hover {
    border-color: var(--green-mid);
    box-shadow: 0 4px 16px rgba(30,61,32,0.1);
    transform: translateY(-2px);
}

.d-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 2px;
    background: linear-gradient(90deg,var(--green-mid),var(--gold),transparent);
}

.d-tag {
    background: var(--green-deep);
    color: #f5f2eb;
    font-size: 10px;
    letter-spacing: .1em;
    padding: 3px 8px;
    display: inline-block;
    margin-bottom: 8px;
}

#cases {
    background: var(--bg);
}

.case-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit,minmax(270px,1fr));
    gap: 14px;
    margin-top: 44px;
}

.case-card {
    background: var(--card);
    border: 1px solid var(--green-border);
    padding: 30px;
    position: relative;
}

.case-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 2px;
    background: linear-gradient(90deg,var(--green-mid),var(--gold),transparent);
}

.case-industry {
    font-size: 11px;
    letter-spacing: .2em;
    text-transform: uppercase;
    color: var(--green-mid);
    margin-bottom: 14px;
    display: block;
}

.case-issue {
    font-size: 11px;
    color: var(--text3);
    letter-spacing: .08em;
    margin-bottom: 5px;
    text-transform: uppercase;
    margin-top: 14px;
}

.case-result {
    border-top: 1px solid var(--green-border);
    margin-top: 18px;
    padding-top: 16px;
}

.case-result-label {
    font-size: 11px;
    letter-spacing: .15em;
    color: var(--green-mid);
    text-transform: uppercase;
    margin-bottom: 6px;
    display: block;
}

#services {
    background: var(--bg2);
}

.svc-group {
    margin-bottom: 52px;
}

.svc-group:last-child {
    margin-bottom: 0;
}

.svc-group-title {
    font-size: 12px;
    letter-spacing: .2em;
    text-transform: uppercase;
    color: var(--green-mid);
    margin-bottom: 16px;
    padding-bottom: 12px;
    border-bottom: 1px solid rgba(45,90,48,0.2);
}

.svc-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit,minmax(270px,1fr));
    gap: 12px;
}

.svc-card {
    background: var(--card);
    border: 1px solid var(--green-border);
    padding: 30px;
    position: relative;
}

.svc-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 2px;
    background: linear-gradient(90deg,var(--green-mid),var(--gold),transparent);
}

.price {
    font-family: var(--serif);
    font-size: 26px;
    color: var(--green-deep);
    margin: 14px 0 4px;
}

.price-note {
    font-size: 12px;
    color: var(--text3);
    letter-spacing: .08em;
}

.compare {
    background: var(--green-pale);
    border: 1px solid rgba(45,90,48,0.15);
    padding: 14px 16px;
    margin-top: 14px;
    font-size: 13px;
    color: var(--text2);
    line-height: 1.75;
}

#profile {
    background: var(--bg3);
}

.prof-photo {
    width: 160px;
    height: 160px;
    border: 2px solid var(--green-border);
    overflow: hidden;
    flex-shrink: 0;
    box-shadow: 0 4px 20px rgba(30,61,32,0.12);
}

.cr-item {
    display: flex;
    gap: 8px;
    align-items: center;
    padding: 4px 0;
}

.dia {
    color: var(--green-mid);
    font-size: 10px;
}

#book {
    background: var(--bg);
}

.book-card {
    background: var(--card);
    border: 1px solid var(--green-border);
    padding: 44px;
    display: flex;
    gap: 36px;
    align-items: center;
    flex-wrap: wrap;
    position: relative;
    box-shadow: 0 2px 16px rgba(30,61,32,0.06);
}

.book-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 2px;
    background: linear-gradient(90deg,var(--green-mid),var(--gold),transparent);
}

/* ── FOREST SILHOUETTE ── */
.forest-top {
    width: 100%;
    overflow: hidden;
    height: 80px;
    position: relative;
}

.forest-top svg {
    display: block;
    width: 100%;
    height: 100%;
}

.mountain-divider {
    width: 100%;
    overflow: hidden;
    height: 52px;
    position: relative;
}

.mountain-divider svg {
    display: block;
    width: 100%;
    height: 100%;
}

.leaf-row {
    width: 100%;
    overflow: hidden;
    height: 56px;
    position: relative;
}

.leaf-row svg {
    display: block;
    width: 100%;
    height: 100%;
}

/* ── FOOTER ── */
footer {
    background: var(--green-deep);
    padding: 60px 24px;
}

.ft {
    max-width: 680px;
    margin: 0 auto;
    text-align: center;
}

.ft-links {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 24px;
    margin: 28px 0;
    position: static;
    padding: 0;
    background: none;
    box-shadow: none;
    z-index: auto;
}

.ft-link {
    font-size: 13px;
    letter-spacing: .1em;
    color: rgba(245,242,235,0.55);
    transition: color .2s;
}

.ft-link:hover {
    color: var(--gold);
}

/* ── SERVICE OVERVIEW ── */
#service-overview {
    background: var(--bg2);
}

.style-cards {
    display: grid;
    grid-template-columns: repeat(3,1fr);
    gap: 14px;
    margin: 44px 0;
}

.style-card {
    background: var(--card);
    border: 1px solid var(--green-border);
    padding: 28px 24px;
    position: relative;
    transition: all .25s;
    display: flex;
    flex-direction: column;
    text-decoration: none;
}

.style-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 2px;
    background: linear-gradient(90deg,var(--green-mid),var(--gold),transparent);
}

.style-card:hover {
    border-color: var(--green-mid);
    box-shadow: 0 4px 16px rgba(30,61,32,0.1);
    transform: translateY(-2px);
}

.style-card--featured {
    border-color: var(--green-mid);
    background: var(--green-pale);
}

.style-card--featured::before {
    background: linear-gradient(90deg,var(--gold),var(--green-mid),var(--gold));
}

.style-card__number {
    font-size: 11px;
    letter-spacing: .2em;
    text-transform: uppercase;
    color: var(--green-mid);
    margin-bottom: 8px;
}

.style-card__title {
    font-family: var(--serif);
    font-size: clamp(18px,2.4vw,22px);
    color: var(--text);
    margin-bottom: 10px;
}

.style-card__description {
    font-size: 14px;
    color: var(--text2);
    line-height: 1.8;
    flex: 1;
}

.style-card__price {
    font-family: var(--serif);
    font-size: 15px;
    color: var(--green-deep);
    margin-top: 14px;
    padding-top: 12px;
    border-top: 1px solid var(--border);
}

.style-card__link {
    font-size: 13px;
    color: var(--green-mid);
    margin-top: 10px;
    letter-spacing: .08em;
}

.theme-overview {
    margin-top: 56px;
    padding: 36px;
    background: var(--card);
    border: 1px solid var(--green-border);
}

.theme-overview__title {
    font-family: var(--serif);
    font-size: clamp(18px,2.4vw,22px);
    text-align: center;
    margin-bottom: 8px;
    color: var(--text);
}

.theme-overview__lead {
    font-size: 14px;
    color: var(--text2);
    text-align: center;
    margin-bottom: 24px;
}

.theme-list {
    display: grid;
    grid-template-columns: repeat(3,1fr);
    gap: 14px;
}

.theme-item {
    padding: 20px;
    border: 1px solid var(--green-border);
    background: var(--bg);
}

.theme-item__title {
    font-family: var(--serif);
    font-size: 16px;
    color: var(--green-mid);
    margin-bottom: 6px;
}

.theme-item__description {
    font-size: 13px;
    color: var(--text2);
    line-height: 1.7;
}

.theme-overview__note {
    font-size: 13px;
    color: var(--text3);
    text-align: center;
    margin-top: 16px;
}

/* ── STYLE SECTIONS ── */
#style-1 {
    background: var(--bg3);
}

#style-2 {
    background: var(--bg);
}

#style-3 {
    background: var(--bg2);
}

.style-section--featured {
    background: linear-gradient(180deg,var(--green-pale) 0%,#f0efe8 100%);
}

.theme-block {
    margin-top: 48px;
    padding-top: 32px;
    border-top: 1px solid var(--border);
}

.theme-block:first-of-type {
    border-top: none;
    padding-top: 0;
}

.theme-block__title {
    font-family: var(--serif);
    font-size: 18px;
    color: var(--green-mid);
    letter-spacing: .1em;
    margin-bottom: 20px;
    padding-left: 14px;
    border-left: 3px solid var(--gold);
}

.service-card {
    background: var(--card);
    border: 1px solid var(--green-border);
    padding: 28px;
    margin-bottom: 12px;
    position: relative;
}

.service-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 2px;
    background: linear-gradient(90deg,var(--green-mid),var(--gold),transparent);
}

.service-card__title {
    font-family: var(--serif);
    font-size: clamp(17px,2.2vw,20px);
    color: var(--text);
    margin-bottom: 10px;
}

.service-card__description {
    font-size: 15px;
    color: var(--text2);
    line-height: 1.9;
    margin-bottom: 16px;
}

.service-card__details {
    display: flex;
    flex-wrap: wrap;
    gap: 4px 24px;
    margin-bottom: 16px;
}

.service-card__details dt {
    font-size: 12px;
    color: var(--text3);
    letter-spacing: .1em;
    min-width: 36px;
}

.service-card__details dd {
    font-size: 14px;
    color: var(--text);
    margin-right: 8px;
}

.service-card__cta {
    display: inline-block;
    font-family: var(--serif);
    font-size: 13px;
    letter-spacing: .1em;
    color: var(--green-mid);
    border: 1.5px solid var(--green-mid);
    padding: 10px 24px;
    transition: all .25s;
}

.service-card__cta:hover {
    background: var(--green-pale);
    transform: translateY(-1px);
}

/* ── STYLE 4: TWO-POLE STRUCTURE ── */
.style4-block {
    margin-top: 48px;
    padding: 36px;
    background: var(--card);
    border: 1px solid var(--green-border);
    position: relative;
}

.style4-block::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: linear-gradient(90deg,var(--green-mid),var(--gold),transparent);
}

.style4-block--membership::before {
    background: linear-gradient(90deg,var(--gold),var(--green-mid),var(--gold));
}

.style4-block__header {
    margin-bottom: 28px;
    padding-bottom: 20px;
    border-bottom: 1px solid var(--border);
}

.style4-block__title {
    font-family: var(--serif);
    font-size: clamp(20px,2.8vw,28px);
    color: var(--text);
    letter-spacing: .06em;
    margin-bottom: 6px;
}

.style4-block__subtitle {
    font-size: 15px;
    color: var(--green-mid);
    letter-spacing: .06em;
}

.style4-block__content {
}

.style4-block__description {
    font-size: 15px;
    color: var(--text2);
    line-height: 1.9;
    margin-bottom: 16px;
}

.style4-block__target {
    font-size: 13px;
    color: var(--text3);
    letter-spacing: .06em;
    margin: 20px 0;
    padding: 12px 16px;
    background: var(--bg);
    border: 1px solid var(--border);
}

.style4-block__notes {
    margin: 20px 0;
}

.style4-block__notes p {
    margin-bottom: 4px;
}

.style4-block__cta {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 28px;
}

.plan-card {
    display: inline-flex;
    align-items: baseline;
    gap: 16px;
    padding: 16px 24px;
    margin-bottom: 20px;
    background: linear-gradient(135deg,var(--green-pale),#f5f2eb);
    border: 1px solid rgba(45,90,48,0.2);
}

.plan-card__name {
    font-family: var(--serif);
    font-size: 16px;
    color: var(--text);
    letter-spacing: .06em;
}

.plan-card__price {
    font-family: var(--serif);
    font-size: 22px;
    color: var(--green-deep);
}

.style4-features {
    margin-top: 48px;
}

.style4-features__title {
    font-family: var(--serif);
    font-size: clamp(18px,2.4vw,22px);
    text-align: center;
    color: var(--text);
    margin-bottom: 24px;
}

.style4-feature-list {
    display: grid;
    grid-template-columns: repeat(3,1fr);
    gap: 14px;
}

.style4-feature {
    background: var(--card);
    border: 1px solid var(--green-border);
    padding: 24px;
}

.style4-feature__title {
    font-family: var(--serif);
    font-size: 16px;
    color: var(--green-mid);
    margin-bottom: 10px;
}

.style4-feature__description {
    font-size: 14px;
    color: var(--text2);
    line-height: 1.8;
}

/* ── MONTHLY LAB ── */
.section--monthly-lab {
    background: var(--bg2);
}

.monthly-lab__schedule {
    margin-top: 8px;
}

.monthly-lab__schedule-title {
    font-family: var(--serif);
    font-size: clamp(18px,2.4vw,22px);
    text-align: center;
    color: var(--text);
    margin-bottom: 24px;
}

.schedule-timeline {
    display: grid;
    gap: 6px;
}

.schedule-slot {
    display: flex;
    gap: 20px;
    background: var(--card);
    border: 1px solid var(--green-border);
    padding: 22px 26px;
    position: relative;
}

.schedule-slot:nth-child(2),
.schedule-slot:nth-child(3) {
    border-left: 3px solid var(--green-mid);
}

.schedule-slot:nth-child(2)::before,
.schedule-slot:nth-child(3)::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 2px;
    background: linear-gradient(90deg,var(--green-mid),var(--gold),transparent);
}

.schedule-slot__time {
    min-width: 120px;
    font-family: var(--serif);
    font-size: 14px;
    color: var(--gold);
    letter-spacing: .05em;
    flex-shrink: 0;
    padding-top: 2px;
}

.schedule-slot__content {
    flex: 1;
}

.schedule-slot__title {
    font-family: var(--serif);
    font-size: 17px;
    color: var(--text);
    margin-bottom: 6px;
}

.schedule-slot__description {
    font-size: 14px;
    color: var(--text2);
    line-height: 1.8;
}

.monthly-lab__info {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
    margin-top: 44px;
}

.monthly-lab__info-block {
    background: var(--card);
    border: 1px solid var(--green-border);
    padding: 24px;
}

.monthly-lab__info-title {
    font-family: var(--serif);
    font-size: 16px;
    color: var(--green-mid);
    margin-bottom: 10px;
    letter-spacing: .1em;
}

.monthly-lab__cta {
    text-align: center;
    margin-top: 44px;
    margin-bottom: 44px;
}

.monthly-lab__schedule-note {
    font-size: .85rem;
    color: var(--muted, #888);
    margin: .25rem 0 1.25rem;
}

/* ── MEMBER BADGE ── */
.bm {
    background: rgba(30,61,32,0.12);
    color: var(--green-deep);
    border: 1px solid rgba(30,61,32,0.35);
    font-size: 11px;
    letter-spacing: .15em;
    padding: 3px 12px;
    display: inline-block;
    font-weight: 500;
}

.sch-item--member {
    border-left: 3px solid var(--green-deep);
}

/* ── STYLE 4: PHASES ── */
.phase-section__title {
    font-family: var(--serif);
    font-size: clamp(18px,2.4vw,22px);
    text-align: center;
    color: var(--text);
    margin: 44px 0 24px;
}

.phase-cards {
    display: grid;
    gap: 10px;
    margin-bottom: 48px;
}

.phase-card {
    background: var(--card);
    border: 1px solid var(--green-border);
    padding: 28px 30px;
    position: relative;
    border-left: 3px solid var(--green-mid);
}

.phase-card:nth-child(1) {
    border-left-color: #b8d4b8;
}

.phase-card:nth-child(2) {
    border-left-color: #8aba8a;
}

.phase-card:nth-child(3) {
    border-left-color: #5ea05e;
}

.phase-card:nth-child(4) {
    border-left-color: #3d803d;
}

.phase-card:nth-child(5) {
    border-left-color: var(--green-deep);
}

.phase-card__name {
    font-family: var(--serif);
    font-size: clamp(17px,2.2vw,20px);
    color: var(--text);
    margin-bottom: 4px;
}

.phase-card__price {
    font-family: var(--serif);
    font-size: 22px;
    color: var(--green-deep);
    margin-bottom: 10px;
}

.phase-card__description {
    font-size: 15px;
    color: var(--text2);
    line-height: 1.8;
    margin-bottom: 8px;
}

.phase-card__target {
    font-size: 12px;
    color: var(--text3);
    letter-spacing: .06em;
}

.phase-features {
    margin-top: 48px;
}

.phase-features__title {
    font-family: var(--serif);
    font-size: clamp(18px,2.4vw,22px);
    text-align: center;
    color: var(--text);
    margin-bottom: 24px;
}

.phase-feature-list {
    display: grid;
    grid-template-columns: repeat(3,1fr);
    gap: 14px;
}

.phase-feature {
    background: var(--card);
    border: 1px solid var(--green-border);
    padding: 24px;
}

.phase-feature__title {
    font-family: var(--serif);
    font-size: 16px;
    color: var(--green-mid);
    margin-bottom: 10px;
}

.phase-feature__description {
    font-size: 14px;
    color: var(--text2);
    line-height: 1.8;
}

.phase-cta {
    margin-top: 48px;
    text-align: center;
    padding: 36px;
    background: var(--card);
    border: 1px solid var(--green-border);
}

.phase-cta__description {
    font-size: 15px;
    color: var(--text2);
    line-height: 1.9;
    margin-bottom: 24px;
}

.phase-cta__button {
    display: inline-block;
    font-family: var(--serif);
    letter-spacing: .12em;
    padding: 16px 36px;
    background: var(--green-deep);
    color: #f5f2eb;
    font-weight: 500;
    font-size: 14px;
    transition: all .25s;
}

.phase-cta__button:hover {
    background: var(--green-mid);
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(30,61,32,0.25);
}

@media (max-width:1023px){
    .style-cards {
        grid-template-columns: repeat(2,1fr);
    }

    .theme-list {
        grid-template-columns: repeat(2,1fr);
    }

    .phase-feature-list {
        grid-template-columns: 1fr;
    }

    .diversity-cards {
        grid-template-columns: repeat(2,1fr);
    }

    .style4-feature-list {
        grid-template-columns: 1fr;
    }

    .monthly-lab__info {
        grid-template-columns: 1fr;
    }
}

@media (max-width:640px){
    .sec {
        padding: 72px 20px;
    }

    .sec-sm {
        padding: 52px 20px;
    }

    .hero-btns {
        flex-direction: column;
        align-items: stretch;
    }

    .btn {
        width: 100%;
    }

    .prep-grid {
        grid-template-columns: 1fr;
    }

    .prep-types,
    .fork-inner {
        flex-direction: column;
    }

    .tl-item {
        flex-direction: column;
        gap: 0;
    }

    .tl-time {
        text-align: left;
        padding: 14px 0 4px;
    }
}

/* ── タブレット以下（≤1023px）：ロゴマーク＋ハンバーガーナビを適用 ── */
@media (max-width:1023px){
    /* ── モバイルナビ：主要CTA＋ハンバーガー ── */
    /* モバイルはロゴをブランドマーク（gold）に差し替え。テキストを隠してマークを表示 */
    nav {
        padding: 12px 16px;
    }

    .nav-logo {
        display: none;
    }

    .nav-logo-mark {
        display: block;
        height: 32px;
        width: auto;
    }

    .nav-quick {
        display: flex;
        gap: 8px;
        align-items: center;
    }

    .nav-quick-btn {
        font-size: 12px;
        letter-spacing: .08em;
        color: var(--gold);
        border: 1px solid var(--gold);
        border-radius: 4px;
        padding: 6px 10px;
        white-space: nowrap;
    }

    .nav-quick-btn--primary {
        background: var(--gold);
        color: var(--green-deep);
    }

    .nav-toggle {
        width: 40px;
        height: 40px;
        background: none;
        border: none;
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: center;
        gap: 5px;
        cursor: pointer;
        padding: 0;
    }

    .nav-toggle span {
        width: 20px;
        height: 2px;
        background: rgba(245,242,235,0.85);
        transition: transform .25s, opacity .25s;
    }

    .nav-toggle[aria-expanded="true"] span:nth-child(1) {
        transform: translateY(7px) rotate(45deg);
    }

    .nav-toggle[aria-expanded="true"] span:nth-child(2) {
        opacity: 0;
    }

    .nav-toggle[aria-expanded="true"] span:nth-child(3) {
        transform: translateY(-7px) rotate(-45deg);
    }

    /* ドロワー：固定ヘッダー直下に縦並びで展開 */
    .nav-links {
        display: none;
        position: absolute;
        top: 100%;
        left: 0;
        right: 0;
        flex-direction: column;
        align-items: stretch;
        gap: 0;
        background: var(--green-deep);
        box-shadow: 0 8px 16px rgba(0,0,0,0.25);
        padding: 8px 0 16px;
    }

    .nav-links.is-open {
        display: flex;
    }

    .nav-links .nav-link {
        padding: 14px 28px;
        font-size: 14px;
    }

    .nav-links .nav-link[aria-current="page"] {
        border-bottom: none;

        /* ドロワー内では下線でなく色のみで現在地表示 */
        padding-bottom: 14px;
    }

    .nav-sep {
        display: none;
    }
}

@media (max-width:640px){
    .book-card {
        flex-direction: column;
    }

    .sch-item {
        flex-direction: column;
        align-items: flex-start;
    }

    .sch-r {
        text-align: left;
    }

    .style-cards {
        grid-template-columns: 1fr;
    }

    .theme-list {
        grid-template-columns: 1fr;
    }

    .theme-overview {
        padding: 24px 20px;
    }

    .service-card__details {
        flex-direction: column;
        gap: 4px;
    }

    .phase-feature-list {
        grid-template-columns: 1fr;
    }

    .phase-cta {
        padding: 28px 20px;
    }

    .d-grid {
        grid-template-columns: 1fr;
    }

    .strategy-links {
        grid-template-columns: 1fr;
    }

    .diversity-cards {
        grid-template-columns: 1fr;
    }

    .location-cards {
        grid-template-columns: 1fr;
    }

    .location-cards--duo {
        grid-template-columns: 1fr;
    }

    .locations__host {
        padding: 24px 20px;
    }

    .style4-block {
        padding: 24px 20px;
    }

    .style4-block__cta {
        flex-direction: column;
    }

    .style4-block__cta .btn {
        width: 100%;
        text-align: center;
    }

    .style4-feature-list {
        grid-template-columns: 1fr;
    }

    .schedule-slot {
        flex-direction: column;
        gap: 4px;
    }

    .schedule-slot__time {
        min-width: auto;
    }

    .monthly-lab__info {
        grid-template-columns: 1fr;
    }

    .plan-card {
        flex-direction: column;
        gap: 4px;
    }
}

/* ════════════════════════════════════════════════════
   CONCIERGE /concierge/ 追加ユーティリティ
   ════════════════════════════════════════════════════ */
/* 相談バンド（ヒーロー直下の細い帯） */
.sec--band {
    background: var(--bg2);
    border-top: 1px solid var(--gold);
    padding: 18px 24px;
}

.consult-band__inner {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 12px 24px;
    text-align: center;
}

/* #overview 3つの関わり方（クリッカブルなミニカード） */
.overview-grid {
    display: grid;
    grid-template-columns: repeat(3,1fr);
    gap: 14px;
    margin-top: 8px;
}

.overview-card {
    display: block;
    background: var(--card);
    border: 1px solid var(--green-border);
    padding: 24px;
    transition: all .25s;
}

.overview-card:hover {
    border-color: var(--green-mid);
    box-shadow: 0 4px 16px rgba(30,61,32,0.1);
    transform: translateY(-2px);
}

.overview-card__title {
    font-family: var(--serif);
    font-size: 16px;
    color: var(--green-mid);
    margin-bottom: 10px;
}

.overview-card__desc {
    font-size: 14px;
    color: var(--text2);
    line-height: 1.8;
}

.overview-card__more {
    display: inline-block;
    margin-top: 12px;
    font-size: 12px;
    letter-spacing: .1em;
    color: var(--gold);
}

.overview__closing {
    text-align: center;
    margin-top: 24px;
}

/* #diagnose 現在地を知る（2カードを横並び） */
.diagnose-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
    margin-top: 24px;
}

/* 図A / 図B 共通（インラインSVG図解） */
.concierge-figure {
    margin: 28px auto;
    max-width: 520px;
}

.concierge-figure--wide {
    max-width: 720px;
}

.concierge-figure svg {
    width: 100%;
    height: auto;
    display: block;
    background: var(--card);
    border: 1px solid var(--green-border);
    border-radius: 10px;
    padding: 16px;
}

.concierge-figure figcaption {
    font-size: 12px;
    color: var(--text2);
    text-align: center;
    margin-top: 10px;
    line-height: 1.7;
}

.fig-case__label {
    font-family: var(--serif);
    font-size: 14px;
    color: var(--text);
    text-align: center;
    margin: 22px 0 2px;
}

.fig-case__sub {
    font-size: 11.5px;
    color: var(--text2);
    text-align: center;
    margin-bottom: 8px;
    line-height: 1.7;
}

/* #get-started 意図ベース2群CTA */
.gs-group {
    margin-top: 32px;
}

.gs-group__title {
    font-family: var(--serif);
    font-size: 16px;
    color: var(--green-mid);
    text-align: center;
    margin-bottom: 16px;
}

.gs-ctas {
    display: flex;
    flex-direction: column;
    gap: 12px;
    max-width: 480px;
    margin: 0 auto;
}

.gs-ctas .btn {
    width: 100%;
}

.gs-note {
    font-size: 13px;
    color: var(--text3);
    letter-spacing: .06em;
    text-align: center;
    margin-top: 12px;
}

@media (max-width:1023px){
    .overview-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width:640px){
    .diagnose-grid {
        grid-template-columns: 1fr;
    }
}
