/* ===========================================================
   Aifit — chat / trust / ambassador / notes / membership
   =========================================================== */

/* ---------- trust strip ---------- */
.trust { background: var(--lav); padding: clamp(2.4rem, 5vh, 3.6rem) 0 1.4rem; }
.trust-inner { display: grid; grid-template-columns: 0.9fr 1.6fr; gap: clamp(1.5rem, 4vw, 3.5rem); align-items: center; }
.trust-lead { font-family: var(--mincho); font-size: clamp(1.05rem, 1.8vw, 1.4rem); color: var(--ink); line-height: 1.7; }
.trust-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1rem; }
.tstat { display: flex; flex-direction: column; align-items: center; text-align: center; padding: 0.6rem 0.3rem; position: relative; }
.tstat:not(:last-child)::after { content: ""; position: absolute; right: 0; top: 18%; bottom: 18%; width: 1px; background: var(--line); }
.tstat-num { font-family: var(--mincho); font-weight: 700; font-size: clamp(1.9rem, 3.6vw, 2.9rem); color: var(--purple); line-height: 1; letter-spacing: .01em; }
.tstat-num i { font-style: normal; font-size: 0.46em; margin-left: 0.12em; color: var(--purple-deep); }
.tstat-label { font-size: 0.72rem; color: var(--muted); margin-top: 0.5rem; }
.trust-note { font-size: 0.66rem; color: var(--muted); text-align: right; margin-top: 0.6rem; }
.trust-note a { color: var(--purple); text-decoration: underline; }
.watch-ribbon { display: flex; align-items: center; gap: 1.2rem; justify-content: center; margin-top: 1.6rem; padding: 0.95rem 1.4rem; background: #fff; border: 1px solid var(--line); border-radius: 16px; box-shadow: 0 10px 28px -18px rgba(87,72,120,.55); text-decoration: none; transition: box-shadow .25s ease, transform .25s ease, border-color .25s ease; }
.watch-ribbon:hover { border-color: var(--purple); box-shadow: 0 16px 36px -16px rgba(87,72,120,.6); transform: translateY(-2px); }
.watch-ribbon-chev { flex: none; color: var(--purple); transition: transform .25s ease; }
.watch-ribbon:hover .watch-ribbon-chev { transform: translateX(4px); }
.watch-ribbon img { flex: none; width: 66px; height: auto; display: block; }
.watch-ribbon-tx { display: flex; flex-direction: column; gap: 0.2rem; max-width: 40rem; }
.watch-ribbon-kicker { font-style: normal; display: block; font-size: 0.82rem; font-weight: 700; letter-spacing: .05em; color: var(--gold-deep); margin-top: 0.3rem; }
.watch-ribbon-tx strong { font-family: var(--mincho); font-weight: 600; color: var(--purple-deep); font-size: clamp(1.6rem, 3.8vw, 2.8rem); line-height: 1.45; letter-spacing: .03em; display: block; margin-bottom: 0.5rem; }
.watch-ribbon-eyebrow { font-style: normal; display: block; font-size: 0.74rem; font-weight: 700; letter-spacing: .04em; color: var(--purple); margin-top: 0.55rem; }
.watch-ribbon-tx > span { font-size: 0.82rem; color: var(--muted); line-height: 1.65; }
@media (max-width: 680px) { .watch-ribbon { flex-direction: column; text-align: center; } .watch-ribbon-chev { display: none; } }
.br-sp { display: none; }

/* ---------- chat section ---------- */
.chat { background: linear-gradient(180deg, var(--lav) 0%, var(--lav-2) 100%); padding: clamp(3.5rem, 8vh, 6rem) 0; }
.chat-head { text-align: center; max-width: 46rem; margin: 0 auto clamp(2rem, 4vh, 3rem); }
.chat-title { font-size: clamp(1.7rem, 3.4vw, 2.6rem); margin: 1rem 0 1.1rem; }
.chat-title em { font-style: normal; color: var(--purple); position: relative; }
.chat-title em::after { content: ""; position: absolute; left: 0; right: 0; bottom: 0.08em; height: 0.26em; background: var(--lav-3); z-index: -1; }
.chat-lead { color: var(--text); font-size: 0.98rem; }
.chat-lead strong { color: var(--purple-deep); font-weight: 700; }

/* worries */
.worries { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(1rem, 1.8vw, 1.4rem); margin-bottom: clamp(2rem, 4vh, 3rem); }
.worry { background: #fff; border-radius: 16px; padding: 1.5rem 1.4rem; box-shadow: var(--shadow-sm); }
.worry-ic { width: 2.8rem; height: 2.8rem; border-radius: 50%; background: var(--lav-2); color: var(--purple); display: inline-flex; align-items: center; justify-content: center; margin-bottom: 0.8rem; }
.worry-ic .ic { width: 1.5rem; height: 1.5rem; }
.worry-title { font-size: 1.08rem; color: var(--ink); margin-bottom: 0.4rem; }
.worry-desc { font-size: 0.84rem; color: var(--text); line-height: 1.75; }

/* modes + phone */
.chat-main { display: grid; grid-template-columns: 1.6fr 1fr; gap: clamp(1.5rem, 3vw, 2.6rem); align-items: stretch; }
.chat-modes { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; align-content: start; }
.cmode { background: #fff; border-radius: 16px; padding: clamp(1.3rem, 2vw, 1.7rem); box-shadow: var(--shadow-sm); border-top: 3px solid var(--node); display: flex; flex-direction: column; transition: transform .3s, box-shadow .3s; }
.cmode:hover { transform: translateY(-4px); box-shadow: var(--shadow); }
.cmode-top { display: flex; align-items: center; justify-content: space-between; margin-bottom: 0.7rem; }
.cmode-ic { width: 2.6rem; height: 2.6rem; border-radius: 50%; background: color-mix(in srgb, var(--node) 12%, #fff); color: var(--node); display: inline-flex; align-items: center; justify-content: center; }
.cmode-ic .ic { width: 1.4rem; height: 1.4rem; }
.cmode-en { font-size: 0.58rem; font-weight: 700; letter-spacing: .18em; color: var(--muted); }
.cmode-name { font-size: clamp(1.1rem, 1.7vw, 1.32rem); color: var(--ink); margin-bottom: 0.5rem; }
.cmode-desc { font-size: 0.82rem; color: var(--text); line-height: 1.8; flex: 1; }
.cmode-cta { display: inline-flex; align-items: center; gap: 0.4em; margin-top: 1rem; font-weight: 700; font-size: 0.88rem; color: var(--node); }
.cmode-cta .ic { width: 1em; height: 1em; transition: transform .25s; }
.cmode:hover .cmode-cta .ic { transform: translateX(4px); }
.chat-badges { grid-column: 1 / -1; display: flex; flex-wrap: wrap; gap: 0.6rem; margin-top: 0.3rem; }
.cbadge { display: inline-flex; align-items: center; gap: 0.4em; font-size: 0.78rem; font-weight: 600; color: var(--purple-deep); background: #fff; border: 1px solid var(--line); border-radius: 999px; padding: 0.42em 0.95em; }
.cbadge .ic { width: 0.9em; height: 0.9em; color: var(--purple); }

/* phone (chat) */
.chat-aside { display: flex; flex-direction: column; align-items: center; gap: 1.2rem; }
.cphone { position: relative; width: min(100%, 270px); aspect-ratio: 270/540; background: linear-gradient(160deg, #2F2E37, #4a4856); border-radius: 30px; padding: 11px; box-shadow: 0 30px 60px -26px rgba(47,41,66,.7); }
.cphone-notch { position: absolute; left: 50%; top: 14px; transform: translateX(-50%); width: 34%; height: 9px; border-radius: 99px; background: #1f1e25; z-index: 3; }
.cphone-screen { width: 100%; height: 100%; border-radius: 20px; background: linear-gradient(180deg, #F6F2FB, #ECE4F5); display: flex; flex-direction: column; overflow: hidden; }
.cphone-bar { display: flex; align-items: center; gap: 0.4em; padding: 1.3em 1em 0.7em; font-size: 0.8rem; font-weight: 700; color: var(--purple-deep); border-bottom: 1px solid var(--line-soft); }
.cphone-bar .ic { width: 1.2em; height: 1.2em; color: var(--purple); }
.cphone-body { flex: 1; padding: 0.9em; display: flex; flex-direction: column; gap: 0.55em; }
.cb { max-width: 86%; font-size: 0.68rem; line-height: 1.6; padding: 0.6em 0.8em; border-radius: 13px; }
.cb--a { align-self: flex-start; background: #fff; color: var(--ink); border: 1px solid var(--line-soft); border-bottom-left-radius: 4px; }
.cb--u { align-self: flex-end; background: var(--purple); color: #fff; border-bottom-right-radius: 4px; }
.cphone-input { display: flex; align-items: center; justify-content: space-between; margin: 0.6em; padding: 0.55em 0.6em 0.55em 0.9em; background: #fff; border: 1px solid var(--line); border-radius: 99px; font-size: 0.66rem; color: var(--muted); }
.cphone-input i { width: 1.7em; height: 1.7em; border-radius: 50%; background: var(--purple); color: #fff; display: inline-flex; align-items: center; justify-content: center; }
.cphone-input i .ic { width: 0.9em; height: 0.9em; }
.cphone-cta { width: 100%; justify-content: center; }

/* sample questions */
.chat-q { margin-top: clamp(2rem, 4vh, 3rem); text-align: center; }
.chat-q-cap { font-family: var(--mincho); font-size: 1.05rem; color: var(--ink); margin-bottom: 1rem; }
.chat-q-list { display: flex; flex-wrap: wrap; gap: 0.6rem; justify-content: center; }
.qchip { display: inline-flex; align-items: center; gap: 0.45em; font-size: 0.82rem; font-weight: 600; color: var(--purple-deep); background: #fff; border: 1px solid var(--line); border-radius: 999px; padding: 0.6em 1.1em; transition: transform .25s, box-shadow .25s, border-color .25s, color .25s; }
.qchip .ic { width: 0.95em; height: 0.95em; color: var(--purple); transition: transform .25s; }
.qchip:hover { transform: translateY(-2px); border-color: var(--purple); box-shadow: var(--shadow-sm); }
.qchip:hover .ic { transform: translateX(3px); }

/* ---------- consultation modes (mirrors real /chat/ start screen) ---------- */
.consult { background: linear-gradient(165deg, #2b2536 0%, #1c1726 100%); border-radius: 26px; padding: clamp(1.7rem, 4vw, 3.2rem); margin-top: clamp(1.6rem, 3.5vh, 2.6rem); box-shadow: 0 50px 90px -46px rgba(33,26,52,.75), inset 0 0 0 1px rgba(255,255,255,.05); }
.consult-head { text-align: center; margin-bottom: clamp(1.5rem, 3.5vh, 2.4rem); }
.consult-head .eyebrow { color: var(--gold); display: inline-flex; justify-content: center; }
.consult-head .eyebrow::before { background: var(--gold); }
.consult-title { color: #fff; font-size: clamp(1.5rem, 3vw, 2.15rem); margin: 0.6rem 0 0.7rem; }
.consult-sub { color: rgba(255,255,255,.66); font-size: 0.85rem; letter-spacing: .02em; }
.consult-grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(1rem, 2vw, 1.5rem); align-items: stretch; }

.cmode { position: relative; border-radius: 20px; padding: clamp(1.5rem, 2.5vw, 2.2rem); display: flex; flex-direction: column; overflow: hidden; transition: transform .3s, box-shadow .3s; }
.cmode:hover { transform: translateY(-5px); }
.cmode-tag { align-self: flex-start; font-size: 0.58rem; font-weight: 800; letter-spacing: .22em; padding: 0.45em 1.1em; border-radius: 999px; margin-bottom: 1.1rem; }
.cmode-name { color: #fff; font-size: clamp(1.25rem, 2.1vw, 1.6rem); margin-bottom: 0.4rem; }
.cmode-tagline { font-size: 0.85rem; font-weight: 700; margin-bottom: 0.7rem; }
.cmode-desc { font-size: 0.82rem; line-height: 1.85; color: rgba(255,255,255,.76); flex: 1; }
.cmode-person { display: flex; flex-direction: column; gap: 1px; margin-top: 0.9rem; padding-top: 0.9rem; border-top: 1px solid rgba(255,255,255,.12); font-size: 0.74rem; color: rgba(255,255,255,.6); }
.cmode-person b { color: #fff; font-size: 0.96rem; font-family: var(--mincho); }
.cmode-cta { margin-top: 1.3rem; display: inline-flex; align-items: center; justify-content: center; gap: 0.5em; font-weight: 800; font-size: 0.95rem; padding: 0.95em 1.4em; border-radius: 999px; transition: filter .2s, transform .2s; }
.cmode-cta .ic { width: 1em; height: 1em; transition: transform .25s; }
.cmode:hover .cmode-cta .ic { transform: translateX(4px); }
.cmode-cta:hover { filter: brightness(1.06); }

/* Aifit — gold / standard */
.cmode--gold { background: linear-gradient(158deg, #342d41, #241f31); box-shadow: inset 0 0 0 1px rgba(194,165,94,.4); }
.cmode--gold .cmode-tag { background: rgba(194,165,94,.16); color: var(--gold); }
.cmode-ic { width: 3.1rem; height: 3.1rem; border-radius: 50%; background: linear-gradient(140deg, #EFE2BC, var(--gold) 60%, var(--gold-deep)); color: #3a2f12; display: inline-flex; align-items: center; justify-content: center; margin-bottom: 1.1rem; box-shadow: 0 10px 24px -10px rgba(194,165,94,.6); }
.cmode-ic .ic { width: 1.55rem; height: 1.55rem; }
.cmode--gold .cmode-tagline { color: var(--gold); }
.cmode--gold .cmode-cta { background: linear-gradient(135deg, #EFE2BC, var(--gold) 55%, var(--gold-deep)); color: #3a2f12; }

/* Takehara — boxing ring / red-orange */
.cmode--boxing { background: radial-gradient(125% 95% at 70% -5%, #62200f 0%, #401411 46%, #20101a 100%); box-shadow: inset 0 0 0 1px rgba(229,108,48,.45); }
.cmode--boxing .cmode-tag { background: rgba(229,108,48,.22); color: #ffb583; }
.cmode--boxing::before, .cmode--boxing::after { content: ""; position: absolute; top: 0; bottom: 0; width: 6px; background: linear-gradient(180deg, #ef3b25, #9e2417); opacity: .9; }
.cmode--boxing::before { left: 0; }
.cmode--boxing::after { right: 0; }
.cmode-ring { position: relative; display: flex; flex-direction: column; align-items: center; gap: 0.85rem; padding: 0.9rem 0 1.1rem; margin-bottom: 0.7rem; }
.cmode-rope { width: 100%; height: 4px; background: #e8542a; box-shadow: 0 7px 0 #c0392b, 0 -7px 0 #f3a13c, 0 0 14px rgba(229,108,48,.45); }
.cmode-avatar { width: 5.4rem; height: 5.4rem; border-radius: 50%; overflow: hidden; border: 3px solid var(--gold); box-shadow: 0 0 0 4px rgba(229,108,48,.3), 0 12px 26px -8px rgba(0,0,0,.6); }
.cmode-avatar image-slot::part(empty) { background: linear-gradient(150deg, #5a2218, #3a1410); color: rgba(255,255,255,.5); font-size: 0.58rem; }
.cmode-telop { font-family: var(--mincho); font-weight: 800; font-size: clamp(1rem, 1.9vw, 1.3rem); text-align: center; color: #ffd84a; text-shadow: 0 2px 0 #b3340f, 0 0 18px rgba(229,108,48,.65); line-height: 1.45; letter-spacing: .02em; }
.cmode--boxing .cmode-tagline { color: #ff9c5c; }
.cmode--boxing .cmode-cta { background: linear-gradient(135deg, #f7a93c, #e2502a 58%, #c0392b); color: #fff; box-shadow: 0 14px 28px -12px rgba(226,80,42,.6); }

.consult-badges { display: flex; flex-wrap: wrap; justify-content: center; gap: 0.6rem; margin-top: clamp(1.5rem, 3.5vh, 2.2rem); }
.consult-badges .cbadge { background: rgba(255,255,255,.07); border: 1px solid rgba(255,255,255,.16); color: rgba(255,255,255,.85); }
.consult-badges .cbadge .ic { color: var(--gold); }

/* quick entry — 2-minute ending note */
.consult-quick { display: flex; align-items: center; gap: 1.1rem; margin-top: clamp(1rem, 2.5vh, 1.6rem); padding: 1.2rem 1.5rem; background: #fff; border: 1px solid var(--gold); border-radius: 18px; box-shadow: 0 18px 40px -24px rgba(159,130,56,.4); transition: transform .25s, box-shadow .25s; }
.consult-quick:hover { transform: translateY(-3px); box-shadow: 0 24px 48px -24px rgba(159,130,56,.5); }
.cq-note { flex: none; width: 2.6rem; height: 2.6rem; border-radius: 50%; background: linear-gradient(140deg, #EFE2BC, var(--gold) 60%, var(--gold-deep)); color: #fff; display: inline-flex; align-items: center; justify-content: center; }
.cq-note .ic { width: 1.3em; height: 1.3em; }
.cq-tx { display: flex; flex-direction: column; gap: 2px; flex: 1; }
.cq-tx b { font-family: var(--mincho); font-size: 1.05rem; color: var(--ink); }
.cq-tx em { font-style: normal; font-size: 0.8rem; color: var(--text); line-height: 1.7; }
.cq-go { flex: none; display: inline-flex; align-items: center; gap: 0.4em; font-weight: 800; font-size: 0.88rem; color: var(--gold-deep); white-space: nowrap; }
.cq-go .ic { width: 1em; height: 1em; transition: transform .25s; }
.consult-quick:hover .cq-go .ic { transform: translateX(4px); }

/* ---------- ambassador ---------- */
.amb { background: var(--dark); color: #fff; padding: clamp(3rem, 6.5vh, 5rem) 0; }
.amb-grid { display: grid; grid-template-columns: 0.92fr 1.08fr; gap: clamp(1.8rem, 4vw, 3.5rem); align-items: center; }
.amb-photo { position: relative; border-radius: 18px; overflow: hidden; aspect-ratio: 4/3.4; box-shadow: 0 30px 60px -28px rgba(0,0,0,.7); }
.amb-photo image-slot::part(empty) { background: linear-gradient(150deg, #4a4856, #34333c); color: rgba(255,255,255,.55); }
.amb-catch { position: absolute; left: 1rem; bottom: 1rem; z-index: 2; display: inline-flex; align-items: center; gap: 0.5em; font-family: var(--mincho); font-weight: 700; font-size: 0.92rem; color: #fff; background: linear-gradient(135deg, #C2533A, #8E2F1F); padding: 0.55em 1.1em; border-radius: 10px; box-shadow: 0 12px 24px -10px rgba(0,0,0,.6); }
.amb-catch .ic { width: 1.2em; height: 1.2em; }
.amb .eyebrow { color: var(--gold); }
.amb .eyebrow::before { background: var(--gold); }
.amb-name { color: #fff; font-size: clamp(1.8rem, 3.4vw, 2.6rem); display: flex; align-items: baseline; gap: 0.7em; flex-wrap: wrap; margin: 1rem 0 1rem; }
.amb-name small { font-size: 0.42em; font-family: var(--gothic); font-weight: 600; color: var(--gold); letter-spacing: .04em; }
.amb-text { color: rgba(255,255,255,.78); font-size: 0.96rem; max-width: 34rem; margin-bottom: 1.7rem; }
.amb-cta { display: flex; flex-wrap: wrap; gap: 0.8rem; }
.amb-cta .btn--ghost { background: transparent; color: #fff; border-color: rgba(255,255,255,.4); }
.amb-cta .btn--ghost:hover { background: rgba(255,255,255,.1); border-color: #fff; }

/* ---------- ending notes ---------- */
.notes { background: var(--lav-2); padding: clamp(3.5rem, 7vh, 5.5rem) 0; }
.notes-head { text-align: center; max-width: 40rem; margin: 0 auto clamp(2rem, 4vh, 3rem); }
.notes-title { font-size: clamp(1.6rem, 3vw, 2.3rem); margin: 1rem 0 0.9rem; }
.notes-lead { color: var(--text); font-size: 0.95rem; }
.notes-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(1rem, 2vw, 1.5rem); }
.ncard { background: #fff; border-radius: 18px; padding: clamp(1.5rem, 2.4vw, 2rem); box-shadow: var(--shadow-sm); display: flex; flex-direction: column; border-top: 3px solid var(--purple); transition: transform .3s, box-shadow .3s; }
.ncard:hover { transform: translateY(-5px); box-shadow: var(--shadow); }
.ncard-badge { align-self: flex-start; font-size: 0.68rem; font-weight: 700; letter-spacing: .08em; color: var(--purple-deep); background: var(--lav-2); border-radius: 999px; padding: 0.4em 0.9em; margin-bottom: 0.9rem; }
.ncard-title { font-size: clamp(1.1rem, 1.7vw, 1.34rem); color: var(--ink); margin-bottom: 0.6rem; }
.ncard-desc { font-size: 0.85rem; color: var(--text); line-height: 1.8; flex: 1; }
.ncard-cta { display: inline-flex; align-items: center; gap: 0.4em; margin-top: 1.1rem; font-weight: 700; font-size: 0.88rem; color: var(--purple-deep); }
.ncard-cta .ic { width: 1em; height: 1em; transition: transform .25s; }
.ncard:hover .ncard-cta .ic { transform: translateX(4px); }

/* ---------- membership ---------- */
.member { background: linear-gradient(160deg, var(--purple) 0%, var(--purple-deep) 100%); color: #fff; padding: clamp(3.5rem, 7vh, 5.5rem) 0; }
.member-grid { display: grid; grid-template-columns: 0.95fr 1.4fr; gap: clamp(1.8rem, 4vw, 3.2rem); align-items: center; }
.member .eyebrow { color: #fff; opacity: .9; }
.member .eyebrow::before { background: #fff; }
.member-title { color: #fff; font-size: clamp(1.7rem, 3.2vw, 2.5rem); margin: 1rem 0 0.8rem; }
.member-name { font-family: var(--mincho); font-size: 1.1rem; color: #F0E7CF; letter-spacing: .04em; margin-bottom: 0.8rem; }
.member-desc { color: rgba(255,255,255,.82); font-size: 0.92rem; margin-bottom: 1.2rem; }
.member-tags { display: flex; flex-wrap: wrap; gap: 0.5rem; }
.member-tags span { font-size: 0.78rem; font-weight: 700; color: #fff; border: 1px solid rgba(255,255,255,.45); border-radius: 999px; padding: 0.42em 1em; }
.member-benefits { display: flex; flex-direction: column; gap: 0.9rem; }

/* ---------- membership 必読ポイント（強調カード） ---------- */
.mpoint { position: relative; background: linear-gradient(150deg, #FBEFCB 0%, var(--gold) 60%, var(--gold-deep) 100%); color: var(--purple-ink); border-radius: 16px; box-shadow: 0 22px 46px -22px rgba(159,130,56,.85); border: 2px solid #fff3d4; overflow: hidden; }
.mpoint-figure { position: relative; aspect-ratio: 16 / 10; }
.mpoint-figure img { width: 100%; height: 100%; object-fit: cover; object-position: center 34%; display: block; }
.mpoint-figure::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(47,41,66,.74) 0%, rgba(47,41,66,.2) 24%, rgba(47,41,66,0) 44%, rgba(47,41,66,.3) 60%, rgba(47,41,66,.82) 100%); }
.mpoint-alert { position: absolute; z-index: 2; top: clamp(2.7rem, 8vw, 3.6rem); left: clamp(1rem, 3vw, 1.6rem); right: clamp(1rem, 3vw, 1.6rem); display: flex; flex-direction: column; gap: .06em; }
.mpoint-alert span { font-family: var(--mincho); font-weight: 700; color: #fff; font-size: clamp(1.55rem, 4.6vw, 2.5rem); line-height: 1.22; letter-spacing: .01em; text-shadow: 0 2px 16px rgba(0,0,0,.72); }
.mpoint-alert em { font-style: normal; color: #FCE8A8; }
.mpoint-badge { position: absolute; top: .9rem; left: .9rem; z-index: 2; display: inline-block; background: var(--purple-deep); color: #fff; font-family: var(--mincho); font-weight: 700; font-size: .82rem; letter-spacing: .14em; padding: .4em 1.1em; border-radius: 999px; box-shadow: 0 8px 16px -8px rgba(0,0,0,.55); }
.mpoint-title { position: absolute; z-index: 2; left: clamp(1rem, 3vw, 1.6rem); right: clamp(1rem, 3vw, 1.6rem); bottom: .85rem; font-family: var(--mincho); font-weight: 700; font-size: clamp(1.45rem, 3.6vw, 2.1rem); line-height: 1.3; color: #fff; text-shadow: 0 2px 14px rgba(0,0,0,.55); margin: 0; }
.mpoint-title em { font-style: normal; color: #FCE8A8; box-shadow: inset 0 -.3em 0 rgba(194,165,94,.5); padding: 0 .05em; }
.mpoint-body { padding: clamp(1.2rem, 3vw, 1.7rem); }
.mpoint-desc { font-size: clamp(.92rem, 1.9vw, 1.02rem); line-height: 1.85; font-weight: 600; color: #4a3f24; }
.mpoint-desc b { color: #7a1f1f; font-weight: 800; }
.mpoint-desc u { text-decoration: none; font-weight: 800; color: var(--purple-ink); box-shadow: inset 0 -.5em 0 rgba(255,255,255,.55); }
.mpoint-cta { display: inline-flex; align-items: center; gap: .4em; margin-top: 1rem; background: var(--purple-deep); color: #fff; font-weight: 700; font-size: .9rem; padding: .75em 1.4em; border-radius: 999px; box-shadow: 0 12px 24px -12px rgba(47,41,66,.7); transition: transform .2s, box-shadow .2s; }
.mpoint-cta .ic { width: 1.05em; height: 1.05em; }
.mpoint-cta:hover { transform: translateY(-2px); box-shadow: 0 18px 30px -12px rgba(47,41,66,.8); }
.mben { display: flex; gap: 1.1rem; align-items: flex-start; background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.16); border-radius: 14px; padding: 1.2rem 1.4rem; backdrop-filter: blur(4px); }
.mben-no { font-family: var(--mincho); font-weight: 700; font-size: 1.5rem; color: #F0E7CF; line-height: 1; flex: none; opacity: .85; }

/* ---------- membership VS banner (pop) ---------- */
.vsbanner { margin-top: clamp(2rem, 5vw, 3.4rem); background: #fff; border-radius: 24px; padding: clamp(1.5rem, 3.4vw, 2.6rem); color: var(--ink); box-shadow: 0 34px 70px -34px rgba(0,0,0,.5); position: relative; overflow: hidden; }
.vsbanner::before { content: ""; position: absolute; top: -40px; right: -40px; width: 160px; height: 160px; border-radius: 50%; background: var(--gold-tint); opacity: .5; }
.vsb-head { text-align: center; position: relative; margin-bottom: clamp(1.2rem, 3vw, 1.8rem); }
.vsb-pop { display: inline-block; background: var(--gold-tint); color: var(--gold-deep); font-weight: 700; font-size: .78rem; letter-spacing: .04em; padding: .38em 1.1em; border-radius: 999px; }
.vsb-head h3 { font-family: var(--mincho); font-size: clamp(1.5rem, 3.4vw, 2.2rem); color: var(--purple-deep); margin-top: .7rem; }
.vsb-sub { font-size: clamp(.86rem, 1.6vw, .96rem); color: var(--text); max-width: 40rem; margin: .7rem auto 0; line-height: 1.85; }
.vsb-sub b { color: var(--purple-deep); font-weight: 700; }

.vsb-compare { display: grid; grid-template-columns: 1fr auto 1fr; gap: clamp(.8rem, 2vw, 1.6rem); align-items: stretch; position: relative; }
.vsb-card { border-radius: 18px; padding: clamp(1.1rem, 2.4vw, 1.7rem); display: flex; flex-direction: column; gap: .55rem; position: relative; }
.vsb-card--old { background: #F2F1F4; border: 1px solid #E5E3EA; color: #7B7886; }
.vsb-card--new { background: linear-gradient(160deg, #FBF4DD, #F2E4BB); border: 2px solid var(--gold); color: var(--purple-ink); box-shadow: 0 18px 38px -20px rgba(159,130,56,.6); }
.vsb-tag { font-size: .74rem; font-weight: 700; letter-spacing: .05em; }
.vsb-card--old .vsb-tag { color: #9A97A4; }
.vsb-tag--new { color: var(--gold-deep); }
.vsb-lead { font-family: var(--mincho); font-size: clamp(1.1rem, 2.4vw, 1.35rem); line-height: 1.4; color: #8C8996; margin-top: .1rem; }
.vsb-zero { display: flex; align-items: baseline; gap: .45rem; flex-wrap: wrap; margin-top: .1rem; }
.vsb-zero b { font-size: .82rem; font-weight: 700; color: var(--purple-deep); }
.vsb-zero strong { font-family: var(--mincho); font-weight: 700; font-size: clamp(2.8rem, 8vw, 3.8rem); line-height: .85; color: var(--gold-deep); }
.vsb-zero small { font-size: 1.2rem; font-weight: 700; }
.vsb-punch { font-family: var(--mincho); font-size: clamp(1.05rem, 2.2vw, 1.25rem); font-weight: 700; color: var(--purple-deep); }
.vsb-punch em { font-style: normal; color: var(--gold-deep); box-shadow: inset 0 -.5em 0 rgba(194,165,94,.28); padding: 0 .1em; }
.vsb-pts { list-style: none; margin: .2rem 0 0; padding: 0; display: flex; flex-direction: column; gap: .32rem; }
.vsb-pts li { font-size: .85rem; font-weight: 600; padding-left: 1.5em; position: relative; }
.vsb-card--old .vsb-pts li::before { content: "×"; position: absolute; left: 0; color: #BCB9C5; font-weight: 800; }
.vsb-pts--new li::before { content: "✓"; position: absolute; left: 0; color: var(--gold-deep); font-weight: 800; }
.vsb-arrow { align-self: center; flex: none; font-family: var(--mincho); font-weight: 800; font-size: 1rem; letter-spacing: .02em; color: #fff; background: var(--purple); width: 2.7rem; height: 2.7rem; border-radius: 50%; display: flex; align-items: center; justify-content: center; box-shadow: 0 10px 20px -8px rgba(87,72,120,.7); }
.vsb-stamp { position: absolute; top: -.85rem; right: -.5rem; transform: rotate(8deg); background: var(--purple); color: #fff; font-family: var(--mincho); font-weight: 700; font-size: .92rem; padding: .45em .95em; border-radius: 999px; border: 2px solid #fff; box-shadow: 0 10px 20px -8px rgba(0,0,0,.4); }
@media (max-width: 680px) {
  .vsb-compare { grid-template-columns: 1fr; }
  .vsb-arrow { transform: rotate(90deg); margin: -.1rem auto; }
}

/* 乗り換えキャンペーン帯 */
.vsb-campaign { margin-bottom: clamp(1.3rem, 3vw, 2rem); border-radius: 16px; padding: clamp(1.1rem, 2.6vw, 1.5rem) clamp(1.2rem, 3vw, 1.9rem); background: linear-gradient(120deg, var(--purple) 0%, var(--purple-deep) 62%, #46395f 100%); color: #fff; display: flex; align-items: center; gap: .8rem 1.3rem; flex-wrap: wrap; position: relative; overflow: hidden; box-shadow: 0 20px 42px -22px rgba(87,72,120,.75); }
.vsb-campaign::before { content: ""; position: absolute; top: -60px; right: -30px; width: 180px; height: 180px; border-radius: 50%; background: radial-gradient(circle, rgba(194,165,94,.5), transparent 70%); }
.vsb-campaign-badge { position: relative; flex: none; background: linear-gradient(135deg, #EFE2BC, var(--gold) 55%, var(--gold-deep)); color: var(--purple-ink); font-family: var(--mincho); font-weight: 700; font-size: clamp(.86rem, 1.8vw, .98rem); letter-spacing: .03em; padding: .5em 1.1em; border-radius: 999px; white-space: nowrap; box-shadow: 0 8px 18px -8px rgba(0,0,0,.45), inset 0 1px 0 rgba(255,255,255,.45); }
.vsb-campaign-text { position: relative; font-family: var(--mincho); font-size: clamp(1.15rem, 2.8vw, 1.55rem); font-weight: 700; line-height: 1.4; }
.vsb-campaign-text em { font-style: normal; color: #FCE8A8; box-shadow: inset 0 -.45em 0 rgba(194,165,94,.4); padding: 0 .08em; }
.vsb-campaign-note { position: relative; flex-basis: 100%; font-size: .73rem; font-weight: 500; color: rgba(255,255,255,.72); }
.mben-title { color: #fff; font-size: 1.12rem; margin-bottom: 0.3rem; }
.mben-desc { color: rgba(255,255,255,.78); font-size: 0.84rem; line-height: 1.7; }

/* ---------- overrides: connect now 2-col, voices restyle ---------- */
.connect-grid { grid-template-columns: 1.15fr 1fr !important; }
.ccard-ic--ai { background: linear-gradient(135deg, #EFE2BC, var(--gold) 60%, var(--gold-deep)) !important; color: #fff !important; }

.vcard { flex-direction: column !important; align-items: stretch !important; gap: 0.8rem !important; }
.vcard-top { display: flex; align-items: center; gap: 0.8rem; }
.vcard--real { border: 1px solid var(--gold); box-shadow: 0 18px 40px -22px rgba(159,130,56,.4); }
.vcard-avatar { width: 3.2rem; height: 3.2rem; }
.vcard-who small { display: block; font-size: 0.64rem; color: var(--purple); font-weight: 700; margin-top: 2px; }

/* ---------- responsive ---------- */
@media (max-width: 1080px) {
  .trust-inner { grid-template-columns: 1fr; gap: 1.2rem; text-align: center; }
  .trust-lead br.br-sp { display: none; }
  .chat-main { grid-template-columns: 1fr; }
  .chat-aside { order: -1; }
  .cphone { width: 240px; }
  .amb-grid { grid-template-columns: 1fr; }
  .amb-photo { max-width: 30rem; aspect-ratio: 16/10; }
  .member-grid { grid-template-columns: 1fr; }
  .connect-grid { grid-template-columns: 1fr !important; max-width: 620px; margin: 0 auto; }
}
@media (max-width: 760px) {
  .worries { grid-template-columns: 1fr; }
  .chat-modes { grid-template-columns: 1fr; }
  .consult-grid { grid-template-columns: 1fr; }
  .consult-quick { flex-direction: column; text-align: center; }
  .cq-tx { align-items: center; }
  .notes-grid { grid-template-columns: 1fr; }
  .trust-stats { grid-template-columns: repeat(2, 1fr); gap: 1.2rem 0.5rem; }
  .tstat:nth-child(2)::after { display: none; }
  .br-sp { display: inline; }
}
