/* Geo design system — 2026-05-12 v6 (white minimal modern)
 * v5 の和テイストが過剰だったので刷新。
 * シンプル、白基調、モダン、ジュエリーブランドらしい上品さ。
 * ゴールドはホバー時のごく僅かなアクセントのみ。
 * TROZO（想定：黒基調）に対して Geo は「白・ライト・モダン」で対比を取る。
 */

:root {
    --bg: #ffffff;
    --bg-soft: #fafaf8;
    --bg-elev: #ffffff;
    --bg-card: #ffffff;
    --bg-deep: #f5f4f1;

    --line: #e5e3de;
    --line-soft: #f0eeea;
    --line-strong: #d0cdc6;

    --text: #1a1a1a;
    --text-mute: #6b6862;
    --text-soft: #a8a59f;

    --accent: #a8884a;
    --accent-soft: #c8a96a;
    --accent-deep: #6e5828;

    --serif: 'Cormorant Garamond', 'Hiragino Mincho ProN', 'Yu Mincho', serif;
    --serif-jp: 'Noto Serif JP', 'Hiragino Mincho ProN', 'Yu Mincho', serif;
    --sans: 'Noto Sans JP', -apple-system, 'Hiragino Sans', 'Yu Gothic UI', sans-serif;

    --container: 1180px;
    --container-narrow: 760px;
    --radius: 4px;
    --radius-sm: 2px;
    --shadow-card: 0 2px 12px rgba(0, 0, 0, 0.04);
    --shadow-card-hover: 0 6px 24px rgba(0, 0, 0, 0.08);
}

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

body {
    background: var(--bg);
    color: var(--text);
    font-family: var(--sans);
    font-weight: 400;
    line-height: 1.8;
    font-size: 15px;
    -webkit-font-smoothing: antialiased;
    overflow-x: hidden;
}

a { color: var(--text); text-decoration: none; transition: color .2s, border-color .2s; }
a:hover { color: var(--accent); }

h1, h2, h3, h4 {
    font-family: var(--serif-jp);
    font-weight: 500;
    letter-spacing: .04em;
    line-height: 1.5;
    margin: 0 0 .8em;
    color: var(--text);
}

h1 { font-size: clamp(1.8rem, 4vw, 2.4rem); font-weight: 500; }
h2 { font-size: clamp(1.2rem, 2.4vw, 1.5rem); font-weight: 500; }
h3 { font-size: 1.05rem; font-weight: 500; }

p { margin: 0 0 1.2em; }

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

/* === Site Header === */
.site-header {
    border-bottom: 1px solid var(--line-soft);
    position: sticky; top: 0; z-index: 100;
    background: rgba(255, 255, 255, 0.92);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
}
.site-header__inner {
    max-width: var(--container);
    margin: 0 auto;
    padding: 1.1rem 1.6rem;
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.brand { color: var(--text); }
.brand__name {
    font-family: var(--serif-jp);
    font-size: 1.15rem;
    font-weight: 500;
    letter-spacing: .24em;
}
.site-nav {
    display: flex; gap: 2.2rem;
    font-family: var(--sans);
    font-size: .78rem;
    font-weight: 400;
    letter-spacing: .2em;
}
.site-nav a {
    color: var(--text-mute);
    padding: .25rem 0;
}
.site-nav a:hover { color: var(--text); }

/* === Site Main === */
.site-main { min-height: 60vh; }

/* === Site Footer === */
.site-footer {
    border-top: 1px solid var(--line-soft);
    margin-top: 0;
    padding: 4rem 1.4rem 3.5rem;
    color: var(--text-mute);
    font-size: .82rem;
    background: var(--bg);
}
.site-footer__inner {
    max-width: var(--container);
    margin: 0 auto;
    text-align: center;
}
.site-footer__brand {
    font-family: var(--serif-jp);
    font-size: 1rem;
    font-weight: 500;
    color: var(--text);
    letter-spacing: .18em;
    margin-bottom: 1.5rem;
}
.site-footer__channels {
    list-style: none; padding: 0;
    display: flex; flex-wrap: wrap; justify-content: center; gap: .4rem 2rem;
    margin-bottom: 2rem;
    font-size: .82rem;
}
.site-footer__channels li { margin: 0; }
.site-footer__channels a {
    display: inline-block;
    padding: .5rem .2rem;
    color: var(--text-mute);
}
.site-footer__channels a:hover { color: var(--text); }
.site-footer__copy { color: var(--text-soft); font-size: .78rem; letter-spacing: .1em; }

/* === Eyebrow（小さなセクションラベル） === */
.eyebrow {
    font-size: .7rem;
    letter-spacing: .35em;
    color: var(--accent);
    text-transform: uppercase;
    margin: 0 0 1.2rem;
    font-weight: 500;
}

/* === Buttons === */
.btn {
    display: inline-block;
    padding: .85rem 1.8rem;
    font-size: .82rem;
    letter-spacing: .15em;
    line-height: 1.5;
    border-radius: 999px;
    border: 1px solid transparent;
    transition: all .2s ease;
    cursor: pointer;
    font-family: var(--sans);
    /* 日本語ボタン文字の不自然な改行を防ぐ（「石名のアクセサリーを見る」等が2行になる時、単語の途中で切れない） */
    word-break: keep-all;
    overflow-wrap: anywhere;
}
.btn--primary {
    background: var(--text);
    color: #fff;
    border-color: var(--text);
}
.btn--primary:hover {
    background: transparent;
    color: var(--text);
}
.btn--ghost {
    background: transparent;
    color: var(--text);
    border-color: var(--line-strong);
}
.btn--ghost:hover {
    background: var(--bg-soft);
    border-color: var(--text);
    color: var(--text);
}

/* === Link with arrow === */
.link-arrow {
    display: inline-flex; align-items: center; gap: .55rem;
    font-size: .85rem;
    letter-spacing: .12em;
    color: var(--text);
    border-bottom: 1px solid var(--line-strong);
    padding-bottom: .3rem;
    transition: gap .2s, color .2s;
}
.link-arrow:hover { gap: .9rem; color: var(--accent-deep); }
.link-arrow span { font-family: var(--serif); }

/* === Home Hero === */
.home-hero {
    min-height: clamp(520px, 78vh, 720px);
    display: grid;
    place-items: center;
    text-align: center;
    padding: 5rem 1.6rem 4rem;
    background:
        radial-gradient(ellipse 800px 400px at 50% 90%, var(--bg-deep) 0%, transparent 65%),
        var(--bg);
}
.home-hero__inner { max-width: 620px; }
.home-hero__logo {
    width: 72px; height: 72px;
    border-radius: 50%;
    margin: 0 auto 2rem;
    object-fit: cover;
    border: 1px solid var(--line);
}
.home-hero__title {
    font-family: var(--serif-jp);
    font-size: clamp(2.4rem, 6vw, 3.6rem);
    font-weight: 500;
    letter-spacing: .28em;
    margin: 0 0 .8em;
    line-height: 1.15;
}
.home-hero__tagline {
    color: var(--text-mute);
    font-size: .95rem;
    letter-spacing: .1em;
    line-height: 2.0;
    margin: 0 0 2.4rem;
}
.home-hero__cta {
    display: flex; justify-content: center; gap: .8rem;
    flex-wrap: wrap;
}
.sp-only { display: none; }

/* === Home Values（ジオの考え方 3 列） === */
.home-values {
    padding: 6rem 1.6rem 5rem;
    border-top: 1px solid var(--line-soft);
}
.home-values__inner {
    max-width: var(--container);
    margin: 0 auto;
}
.home-values__header {
    text-align: center;
    margin-bottom: 3.5rem;
}
.home-values__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 2rem;
}
.value-card {
    padding: 2.4rem 2rem;
    border: 1px solid var(--line-soft);
    border-radius: var(--radius);
    background: var(--bg);
    transition: border-color .25s, transform .25s, box-shadow .25s;
}
.value-card:hover {
    border-color: var(--line-strong);
    transform: translateY(-2px);
    box-shadow: var(--shadow-card);
}
.value-card__num {
    font-family: var(--serif);
    font-style: italic;
    font-size: 1.05rem;
    color: var(--accent);
    letter-spacing: .2em;
    margin: 0 0 1.2rem;
}
.value-card__title {
    font-family: var(--serif-jp);
    font-size: 1.18rem;
    font-weight: 500;
    letter-spacing: .1em;
    line-height: 1.5;
    margin: 0 0 1rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid var(--line-soft);
}
.value-card__body {
    color: var(--text-mute);
    font-size: .9rem;
    line-height: 2.0;
    letter-spacing: .04em;
    margin: 0;
}

/* === Philosophy / Story === */
.home-story {
    padding: 6rem 1.6rem;
    background: var(--bg-soft);
    border-top: 1px solid var(--line-soft);
    border-bottom: 1px solid var(--line-soft);
}
.home-story__inner {
    max-width: 720px;
    margin: 0 auto;
    text-align: center;
}
.home-story__title {
    font-family: var(--serif-jp);
    font-size: clamp(1.6rem, 3.4vw, 2.2rem);
    font-weight: 500;
    letter-spacing: .12em;
    line-height: 1.7;
    margin: 0 0 2rem;
}
.home-story__body {
    color: var(--text-mute);
    font-size: .94rem;
    line-height: 2.05;
    letter-spacing: .06em;
    margin: 0 0 1.6em;
}
.home-story__body:last-child { margin-bottom: 0; }

/* === Stones Index Hero === */
.stones-index__hero {
    max-width: 760px;
    margin: 0 auto;
    padding: 4rem 1.4rem 2rem;
    text-align: center;
}
.stones-index__kicker {
    font-size: .72rem;
    letter-spacing: .35em;
    color: var(--accent);
    margin-bottom: 1.5rem;
}
.stones-index__title {
    font-size: clamp(2rem, 5vw, 3rem);
    letter-spacing: .15em;
    margin-bottom: .6em;
}
.stones-index__lead {
    color: var(--text-mute);
    font-size: .95rem;
    line-height: 1.95;
    margin: 0;
}
@media (max-width: 600px) {
    .stones-index__hero { padding: 3rem 1.2rem 1.5rem; }
    .stones-index__lead { font-size: .88rem; }
    .stones-index__kicker::before, .stones-index__kicker::after { display: none; }
}

/* === Home Stones === */
.home-stones {
    max-width: var(--container);
    margin: 0 auto;
    padding: 5rem 1.4rem;
}
.home-stones__header { text-align: center; margin-bottom: 3rem; }
.home-stones__grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 2.5rem 1.8rem;
}
.stone-tile { display: block; color: var(--text); transition: transform .3s ease; }
.stone-tile:hover { transform: translateY(-4px); }
.stone-tile__img {
    aspect-ratio: 1 / 1;
    background: var(--bg-card);
    border-radius: var(--radius);
    overflow: hidden;
    margin-bottom: 1rem;
    box-shadow: var(--shadow-card);
}
.stone-tile__img img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s ease; }
.stone-tile:hover .stone-tile__img img { transform: scale(1.05); }
.stone-tile__body { padding: 0 .2rem; }
.stone-tile__name {
    font-family: var(--serif);
    font-size: 1.3rem;
    color: var(--text);
    margin: 0 0 .2em;
    letter-spacing: .04em;
}
.stone-tile:hover .stone-tile__name { color: var(--accent); }
.stone-tile__wamei { color: var(--text-mute); font-size: .82rem; letter-spacing: .15em; margin: 0 0 .8em; }
.stone-tile__tagline { color: var(--text-mute); font-size: .82rem; line-height: 1.7; margin: 0; }

/* === Home Channels === */
.home-channels {
    max-width: 760px;
    margin: 0 auto;
    padding: 5rem 1.4rem 6rem;
    text-align: center;
}
.home-channels__list {
    list-style: none; padding: 0; margin: 2rem 0 0;
    display: flex; flex-wrap: wrap; justify-content: center;
    gap: 1rem 2rem;
    font-size: .88rem;
}
.home-channels__list a {
    display: inline-block;
    color: var(--text-mute);
    padding: .55rem .2rem;
    border-bottom: 1px solid transparent;
}
.home-channels__list a:hover {
    color: var(--text);
    border-bottom-color: var(--line-strong);
}

@media (max-width: 880px) {
    .home-values__grid { grid-template-columns: 1fr; gap: 1.2rem; max-width: 540px; margin: 0 auto; }
    .value-card { padding: 2rem 1.8rem; }
}

@media (max-width: 600px) {
    .sp-only { display: inline; }
    .home-hero { min-height: 64vh; padding: 4rem 1.4rem 3rem; }
    .home-hero__logo { width: 64px; height: 64px; margin-bottom: 1.4rem; }
    .home-hero__title { font-size: clamp(2rem, 10vw, 2.8rem); letter-spacing: .2em; }
    .home-hero__tagline { font-size: .88rem; letter-spacing: .06em; margin-bottom: 2rem; }
    .home-hero__cta {
        flex-direction: column;
        align-items: stretch;
        gap: .55rem;
        max-width: 280px;
        margin: 0 auto;
    }
    .home-hero__cta .btn { display: block; text-align: center; }
    .btn { padding: .85rem 1.4rem; font-size: .82rem; letter-spacing: .12em; }

    .home-values { padding: 4rem 1.2rem 3.5rem; }
    .home-values__header { margin-bottom: 2.5rem; }
    .value-card { padding: 1.8rem 1.6rem; }
    .value-card__title { font-size: 1.05rem; }
    .value-card__body { font-size: .85rem; line-height: 1.95; }

    .home-story { padding: 4rem 1.4rem; }
    .home-story__title { letter-spacing: .08em; line-height: 1.7; }
    .home-story__body { font-size: .88rem; letter-spacing: .03em; line-height: 1.95; }

    .home-channels { padding: 3.5rem 1.2rem 4rem; }
    .home-channels__list { gap: .8rem 1.4rem; font-size: .82rem; }
    .site-footer { padding: 3rem 1.2rem 3rem; }
    .site-footer__channels { gap: .9rem 1.4rem; font-size: .8rem; }
}


/* ======================================
   STONE LP — editorial design
   ====================================== */

.stone-page { color: var(--text); }

/* === Breadcrumb === */
.breadcrumb {
    max-width: var(--container);
    margin: 0 auto;
    padding: .9rem 1.4rem .2rem;
    font-size: .78rem;
    color: var(--text-mute);
    letter-spacing: .05em;
}
.breadcrumb ol {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
    align-items: center;
}
.breadcrumb li { display: inline-flex; align-items: center; }
.breadcrumb a { color: var(--text-mute); }
.breadcrumb a:hover { color: var(--accent); }
.breadcrumb span[aria-hidden] { color: var(--text-soft); opacity: .6; }
.breadcrumb [aria-current] { color: var(--text); }
@media (max-width: 600px) {
    .breadcrumb { padding: .8rem 1.2rem .1rem; font-size: .73rem; }
}

/* === HERO === */
.stone-hero {
    position: relative;
    min-height: clamp(560px, 78vh, 760px);
    display: grid;
    place-items: center;
    text-align: center;
    overflow: hidden;
    background: var(--bg-deep);
}
.stone-hero--with-image {
    background:
        var(--hero-img) center / cover no-repeat;
}
.stone-hero__overlay {
    position: absolute; inset: 0;
    background:
        radial-gradient(ellipse at center, rgba(8,8,10,.45) 0%, rgba(8,8,10,.78) 65%, rgba(8,8,10,.95) 100%),
        linear-gradient(to bottom, rgba(8,8,10,.55) 0%, rgba(8,8,10,.3) 40%, rgba(8,8,10,.85) 100%);
    z-index: 1;
}
.stone-hero__inner {
    position: relative; z-index: 2;
    padding: 4rem 1.4rem;
    max-width: 900px;
}
.stone-hero__kicker {
    font-size: .72rem;
    letter-spacing: .35em;
    color: var(--accent);
    margin-bottom: 2rem;
    text-transform: uppercase;
}
.stone-hero__kicker::before,
.stone-hero__kicker::after {
    content: '—';
    margin: 0 .8em;
    opacity: .6;
}
.stone-hero__title {
    font-size: clamp(2.8rem, 8vw, 4.8rem);
    letter-spacing: .12em;
    margin: 0 0 .35em;
    line-height: 1.15;
}
.stone-hero__wamei {
    font-family: var(--serif);
    color: var(--text);
    font-size: clamp(1.1rem, 2.2vw, 1.3rem);
    letter-spacing: .25em;
    margin-bottom: 2rem;
    opacity: .85;
}
.stone-hero__tagline {
    color: var(--text-mute);
    font-size: .95rem;
    line-height: 1.85;
    max-width: 540px;
    margin: 0 auto;
}
.stone-hero__scroll {
    position: absolute;
    bottom: 2.4rem; left: 50%;
    transform: translateX(-50%);
    z-index: 2;
}
.stone-hero__scroll span {
    display: block;
    width: 1px; height: 56px;
    background: linear-gradient(to bottom, transparent, var(--accent) 50%, transparent);
    animation: scrollPulse 2.2s ease-in-out infinite;
}
@keyframes scrollPulse {
    0%, 100% { opacity: .3; transform: translateY(-6px); }
    50% { opacity: 1; transform: translateY(6px); }
}

/* === Section title === */
.section-title {
    text-align: center;
    font-family: var(--serif-jp);
    font-weight: 500;
    font-size: clamp(1.1rem, 2vw, 1.3rem);
    letter-spacing: .14em;
    margin-bottom: 1.6em;
}
.section-title--left { text-align: left; }
/* 装飾要素は使わない方針なので何も描画しない */
.section-title__ornament { display: none; }

.section-subtitle {
    text-align: center;
    color: var(--text-mute);
    font-size: .85rem;
    letter-spacing: .06em;
    margin-bottom: 2.5rem;
}

/* === INTRO === */
.stone-intro {
    max-width: 760px;
    margin: 0 auto;
    padding: 5rem 1.4rem 1rem;
    text-align: center;
}
.stone-intro__lead {
    font-size: 1.08rem;
    line-height: 2.05;
    color: var(--text);
    margin: 0;
}

/* === STONE WORDS === */
.stone-words {
    max-width: 900px;
    margin: 0 auto;
    padding: 4rem 1.4rem;
}
.stone-words__list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: .7rem .9rem;
}
.stone-words__list li {
    border: 1px solid var(--accent-soft);
    color: var(--accent);
    padding: .55rem 1.5rem;
    border-radius: 999px;
    font-size: .9rem;
    letter-spacing: .1em;
    transition: background .2s, color .2s;
}
.stone-words__list li:hover {
    background: var(--accent);
    color: var(--bg);
}

/* === PROSE SPLIT (2-col description + image) === */
.stone-prose-split {
    max-width: var(--container);
    margin: 0 auto;
    padding: 5rem 1.4rem;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 4rem;
    align-items: start;
}
.stone-prose-split__text {
    max-width: 540px;
}
.stone-prose-split__text p {
    font-size: 1rem;
    line-height: 2.1;
    color: var(--text);
}
.stone-prose-split__media {
    position: relative;
    aspect-ratio: 4 / 5;
    background: var(--bg-card);
    border-radius: var(--radius);
    overflow: hidden;
    box-shadow: var(--shadow-card);
    position: sticky;
    top: 6rem;
}
.stone-prose-split__media img {
    width: 100%; height: 100%; object-fit: cover;
}

/* === DIVERSITY GALLERY === */
.stone-gallery {
    background: var(--bg-deep);
    padding: 6rem 1.4rem;
    margin: 4rem 0;
}
.stone-gallery__header {
    max-width: var(--container);
    margin: 0 auto 3rem;
    text-align: center;
}
.stone-gallery__grid {
    max-width: var(--container);
    margin: 0 auto;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1.5rem;
}
.gallery-card {
    margin: 0;
    aspect-ratio: 1 / 1;
    overflow: hidden;
    border-radius: var(--radius);
    background: var(--bg-card);
    transition: transform .3s ease;
}
.gallery-card:hover { transform: translateY(-4px); }
.gallery-card a, .gallery-card img {
    display: block;
    width: 100%; height: 100%;
}
.gallery-card img {
    object-fit: cover;
    transition: transform .5s ease;
}
.gallery-card:hover img { transform: scale(1.05); }

/* === MINERAL DATA === */
.stone-data {
    max-width: 760px;
    margin: 0 auto;
    padding: 5rem 1.4rem;
}
.stone-data__card {
    background: var(--bg-card);
    border: 1px solid var(--line);
    border-radius: var(--radius);
    padding: 2rem 2.2rem;
}
.stone-data__card dl { margin: 0; }
.stone-data__row {
    display: grid;
    grid-template-columns: 150px 1fr;
    gap: 1.2rem;
    padding: .85rem 0;
    border-bottom: 1px solid var(--line);
}
.stone-data__row:last-child { border-bottom: none; }
.stone-data__row dt {
    color: var(--text-mute);
    font-size: .82rem;
    letter-spacing: .12em;
    padding-top: 2px;
}
.stone-data__row dd {
    margin: 0;
    color: var(--text);
    font-size: .92rem;
    line-height: 1.8;
}

/* === NARRATIVE (2-col text+image, alternating) === */
.stone-narrative {
    max-width: var(--container);
    margin: 0 auto;
    padding: 5rem 1.4rem;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 4rem;
    align-items: center;
}
.stone-narrative--reverse {
    grid-template-columns: 1fr 1fr;
}
.stone-narrative--reverse .stone-narrative__media {
    order: -1;
}
.stone-narrative__text { max-width: 540px; }
.stone-narrative__lead {
    font-family: var(--serif);
    font-size: 1.2rem;
    color: var(--accent);
    line-height: 1.7;
    letter-spacing: .03em;
    margin: 0 0 1.5em;
}
.stone-narrative__text p {
    font-size: 1rem;
    line-height: 2.05;
    color: var(--text);
}
.stone-narrative__media {
    aspect-ratio: 4 / 5;
    background: var(--bg-card);
    border-radius: var(--radius);
    overflow: hidden;
    box-shadow: var(--shadow-card);
}
.stone-narrative__media img {
    width: 100%; height: 100%; object-fit: cover;
}

/* === FAQ === */
.stone-faq {
    max-width: 820px;
    margin: 0 auto;
    padding: 5rem 1.4rem;
}
.stone-faq__list { display: flex; flex-direction: column; gap: .8rem; }
.faq-item {
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: var(--bg-card);
    overflow: hidden;
    transition: border-color .2s;
}
.faq-item[open] { border-color: var(--accent-soft); }
.faq-item summary {
    list-style: none;
    cursor: pointer;
    padding: 1.3rem 1.6rem;
    display: flex;
    align-items: flex-start;
    gap: 1rem;
    user-select: none;
    transition: background .2s;
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary:hover { background: rgba(200,169,106,.05); }
.faq-item__q-label {
    font-family: var(--serif);
    font-size: 1.3rem;
    color: var(--accent);
    line-height: 1;
    flex-shrink: 0;
}
.faq-item__q {
    flex: 1;
    font-size: 1rem;
    line-height: 1.65;
    color: var(--text);
    padding-top: 4px;
}
.faq-item__a {
    padding: 0 1.6rem 1.5rem 1.6rem;
    display: flex;
    gap: 1rem;
    align-items: flex-start;
    border-top: 1px solid var(--line-soft);
    margin-top: 0;
}
.faq-item[open] .faq-item__a { animation: faqOpen .25s ease; }
@keyframes faqOpen { from { opacity: 0; transform: translateY(-4px);} to { opacity: 1; transform: translateY(0);} }
.faq-item__a-label {
    font-family: var(--serif);
    font-size: 1.3rem;
    color: var(--text-mute);
    line-height: 1;
    padding-top: 1.6rem;
    flex-shrink: 0;
}
.faq-item__a p {
    flex: 1;
    margin: 1.4rem 0 0;
    color: var(--text-mute);
    font-size: .93rem;
    line-height: 1.95;
}

/* === PRODUCTS === */
.stone-products {
    max-width: var(--container);
    margin: 0 auto;
    padding: 5rem 1.4rem;
}
.stone-products__header { text-align: center; margin-bottom: 3rem; }
.products-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(230px, 1fr));
    gap: 2.5rem 1.6rem;
}
.product-card {
    display: block;
    color: var(--text);
}
.product-card__img {
    aspect-ratio: 1 / 1;
    background: var(--bg-card);
    border-radius: var(--radius);
    overflow: hidden;
    margin-bottom: 1rem;
    box-shadow: 0 1px 8px rgba(45, 38, 32, 0.12);
}
.product-card__img img {
    width: 100%; height: 100%; object-fit: cover;
    transition: transform .5s ease;
}
.product-card:hover .product-card__img img { transform: scale(1.06); }
.product-card__title {
    font-family: var(--sans);
    font-size: .85rem;
    line-height: 1.6;
    margin: 0 0 .4em;
    color: var(--text);
    font-weight: 400;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.product-card__price {
    font-family: var(--serif);
    font-size: 1rem;
    color: var(--accent);
    margin: 0;
    letter-spacing: .02em;
}
.stone-products__empty {
    text-align: center;
    color: var(--text-mute);
    padding: 3rem 0;
}

/* === BUTTON === */
.btn {
    display: inline-block;
    padding: .95rem 2.4rem;
    border: 1px solid var(--accent);
    color: var(--accent);
    font-size: .85rem;
    letter-spacing: .25em;
    transition: background .25s, color .25s, transform .2s;
    background: transparent;
    cursor: pointer;
}
.btn:hover {
    background: var(--accent);
    color: var(--bg);
    transform: translateY(-2px);
}
.btn--lg {
    padding: 1.2rem 3rem;
    font-size: .9rem;
}

/* === STONE CTA === */
.stone-cta {
    position: relative;
    min-height: 460px;
    display: grid;
    place-items: center;
    text-align: center;
    overflow: hidden;
    margin-top: 4rem;
    background: var(--cta-img) center / cover no-repeat fixed;
}
@media (hover: none) {
    .stone-cta { background-attachment: scroll; }
}
.stone-cta__overlay {
    position: absolute; inset: 0;
    background:
        radial-gradient(ellipse at center, rgba(8,8,10,.65) 0%, rgba(8,8,10,.92) 75%);
    z-index: 1;
}
.stone-cta__inner {
    position: relative; z-index: 2;
    padding: 5rem 1.4rem;
    max-width: 760px;
}
.stone-cta__kicker {
    font-size: .72rem;
    letter-spacing: .4em;
    color: var(--accent);
    margin-bottom: 1.6rem;
}
.stone-cta__title {
    font-size: clamp(1.8rem, 4vw, 2.6rem);
    margin-bottom: .8em;
    letter-spacing: .1em;
}
.stone-cta__lead {
    color: var(--text-mute);
    font-size: .95rem;
    line-height: 1.95;
    margin: 0 auto 2.4rem;
    max-width: 540px;
}

/* === fade-in (IntersectionObserver + fallback) === */
.fade-in {
    opacity: 0;
    transform: translateY(20px);
    transition: opacity .8s ease, transform .8s ease;
}
.fade-in.is-visible {
    opacity: 1;
    transform: translateY(0);
}
/* JS無効・観察者未対応・iOSの低電力モード等でのフォールバック */
.no-js .fade-in,
.fade-in--immediate {
    opacity: 1 !important;
    transform: none !important;
}

/* ===========================
   Mobile (tablet ≤ 880px)
   =========================== */
@media (max-width: 880px) {
    /* Sections: vertical padding 圧縮 */
    .stone-intro { padding: 3.5rem 1.4rem 1rem; }
    .stone-words,
    .stone-data,
    .stone-faq,
    .stone-products { padding: 3.5rem 1.4rem; }
    .stone-prose-split,
    .stone-narrative { padding: 3.5rem 1.4rem; }

    /* 2-col → 1-col */
    .stone-prose-split,
    .stone-narrative {
        grid-template-columns: 1fr;
        gap: 2rem;
    }
    .stone-prose-split__media,
    .stone-narrative__media {
        position: static;
        aspect-ratio: 4 / 3;
        max-height: 460px;
    }
    .stone-narrative--reverse .stone-narrative__media { order: 0; }

    /* Gallery */
    .stone-gallery {
        padding: 4rem 1.4rem;
        margin: 2.5rem 0;
    }
    .stone-gallery__grid { grid-template-columns: repeat(2, 1fr); gap: 1.2rem; }

    /* Mineral data */
    .stone-data__card { padding: 1.6rem 1.6rem; }
    .stone-data__row { grid-template-columns: 110px 1fr; gap: .8rem; padding: .75rem 0; }

    /* CTA */
    .stone-cta { min-height: 420px; background-attachment: scroll; }
}

/* ===========================
   Mobile (phone ≤ 600px)
   =========================== */
@media (max-width: 600px) {
    body { line-height: 1.78; }

    /* Header / Nav — stack brand + wrap nav (6 links + 検索 アイコンが 375px 幅で横並びだとあふれる) */
    .site-header__inner {
        flex-direction: column;
        gap: .55rem;
        padding: .7rem .95rem .65rem;
    }
    .brand__name { font-size: 1.15rem; letter-spacing: .18em; }
    .site-nav {
        flex-wrap: wrap;
        justify-content: center;
        gap: .55rem 1rem;
        font-size: .76rem;
        letter-spacing: .12em;
    }
    .site-nav a { padding: .3rem .1rem; }

    /* Hero */
    .stone-hero { min-height: 64vh; }
    .stone-hero__inner { padding: 3rem 1.2rem; }
    .stone-hero__kicker {
        font-size: .68rem;
        letter-spacing: .25em;
        margin-bottom: 1.4rem;
    }
    .stone-hero__kicker::before, .stone-hero__kicker::after { display: none; }
    .stone-hero__title {
        font-size: clamp(2.4rem, 12vw, 3.2rem);
        letter-spacing: .08em;
        margin-bottom: .3em;
    }
    .stone-hero__wamei {
        font-size: 1rem;
        letter-spacing: .18em;
        margin-bottom: 1.5rem;
    }
    .stone-hero__tagline { font-size: .88rem; line-height: 1.85; padding: 0 .3rem; }
    .stone-hero__scroll { bottom: 1.6rem; }
    .stone-hero__scroll span { height: 42px; }

    /* Intro */
    .stone-intro { padding: 3rem 1.2rem 1rem; }
    .stone-intro__lead { font-size: .98rem; line-height: 1.95; }

    /* Section title */
    .section-title { font-size: clamp(1.3rem, 5vw, 1.6rem); gap: .5rem; margin-bottom: 1.3em; }
    .section-subtitle { font-size: .8rem; margin-bottom: 2rem; letter-spacing: .1em; }

    /* Stone words */
    .stone-words { padding: 3rem 1.2rem; }
    .stone-words__list { gap: .5rem .55rem; }
    .stone-words__list li {
        font-size: .8rem;
        padding: .42rem 1.05rem;
        letter-spacing: .08em;
    }

    /* Sections padding */
    .stone-data,
    .stone-faq,
    .stone-products,
    .stone-prose-split,
    .stone-narrative { padding: 3rem 1.2rem; }
    .stone-prose-split,
    .stone-narrative { gap: 1.8rem; }
    .stone-prose-split__media,
    .stone-narrative__media { aspect-ratio: 4 / 3.5; max-height: 380px; }

    /* Body text */
    .stone-prose-split__text p,
    .stone-narrative__text p { font-size: .95rem; line-height: 1.95; }
    .stone-narrative__lead { font-size: 1.05rem; margin-bottom: 1.2em; }

    /* Mineral data: stack vertically on phones */
    .stone-data { padding: 3rem 1.2rem; }
    .stone-data__card { padding: 1.3rem 1.3rem; }
    .stone-data__row {
        grid-template-columns: 1fr;
        gap: .2rem;
        padding: .9rem 0;
    }
    .stone-data__row dt {
        font-size: .73rem;
        letter-spacing: .15em;
        padding-top: 0;
    }
    .stone-data__row dd { font-size: .92rem; line-height: 1.85; }

    /* Gallery */
    .stone-gallery { padding: 3.5rem 1.2rem; margin: 2rem 0; }
    .stone-gallery__grid { grid-template-columns: repeat(2, 1fr); gap: 1rem; }

    /* Products */
    .stone-products { padding: 3rem 1.2rem 4rem; }
    .products-grid { grid-template-columns: repeat(2, 1fr); gap: 1.8rem .9rem; }
    .product-card__img { margin-bottom: .7rem; }
    .product-card__title { font-size: .76rem; line-height: 1.55; }
    .product-card__price { font-size: .9rem; }

    /* FAQ */
    .stone-faq { padding: 3rem 1.2rem; }
    .stone-faq__list { gap: .65rem; }
    .faq-item summary { padding: 1.05rem 1.1rem; gap: .7rem; }
    .faq-item__q { font-size: .92rem; line-height: 1.62; padding-top: 2px; }
    .faq-item__a { padding: 0 1.1rem 1.15rem; gap: .7rem; }
    .faq-item__a p { font-size: .88rem; line-height: 1.85; margin-top: 1rem; }
    .faq-item__q-label, .faq-item__a-label { font-size: 1.15rem; }
    .faq-item__a-label { padding-top: 1.1rem; }

    /* CTA */
    .stone-cta { min-height: 380px; }
    .stone-cta__inner { padding: 4rem 1.2rem; }
    .stone-cta__kicker { letter-spacing: .3em; font-size: .68rem; margin-bottom: 1.3rem; }
    .stone-cta__title { font-size: clamp(1.5rem, 6vw, 2rem); letter-spacing: .06em; }
    .stone-cta__lead { font-size: .88rem; line-height: 1.85; margin-bottom: 2rem; }
    .btn--lg { padding: 1.05rem 2rem; font-size: .82rem; letter-spacing: .2em; }

    /* Footer */
    .site-footer { padding: 3rem 1.2rem 3.5rem; margin-top: 0; }
    .site-footer__brand { font-size: 1rem; }
    .site-footer__channels { gap: .85rem 1.1rem; font-size: .82rem; margin-bottom: 1.6rem; }
}

/* ===========================
   Phone (narrow ≤ 380px)
   =========================== */
@media (max-width: 380px) {
    .stone-hero__title { font-size: 2.1rem; letter-spacing: .06em; }
    .stone-hero__wamei { font-size: .92rem; }
    .stone-hero__tagline { font-size: .82rem; }
    .products-grid { gap: 1.5rem .7rem; }
    .stone-gallery__grid { gap: .8rem; }
    .stone-words__list li { padding: .38rem .95rem; font-size: .76rem; }
}

/* ======================================
   CHARM LP (願い別お守り)
   ====================================== */

.charm-page {
    max-width: var(--container-narrow);
    margin: 0 auto;
    padding: 0 1.6rem;
}

/* Breadcrumb */
.breadcrumb {
    padding: 1.5rem 0 .5rem;
    font-size: .78rem;
    color: var(--text-mute);
}
.breadcrumb ol {
    list-style: none; padding: 0; margin: 0;
    display: flex; flex-wrap: wrap; gap: .5rem;
}
.breadcrumb a { color: var(--text-mute); }
.breadcrumb a:hover { color: var(--text); }
.breadcrumb span[aria-hidden] { color: var(--text-soft); }

/* Hero */
.charm-hero {
    text-align: center;
    padding: 3rem 0 2rem;
}
.charm-hero__title {
    font-family: var(--serif-jp);
    font-size: clamp(1.8rem, 4.5vw, 2.6rem);
    font-weight: 500;
    letter-spacing: .14em;
    line-height: 1.7;
    margin: 0 0 1.6rem;
}
.charm-hero__lead {
    color: var(--text-mute);
    font-size: .98rem;
    line-height: 2.0;
    letter-spacing: .06em;
    max-width: 600px;
    margin: 0 auto;
}

/* Intro */
.charm-intro {
    padding: 2.5rem 0 4rem;
    max-width: 640px;
    margin: 0 auto;
}
.charm-intro p {
    font-size: .96rem;
    line-height: 2.0;
    letter-spacing: .04em;
    margin: 0 0 1.4em;
}
.charm-intro p:last-child { margin-bottom: 0; }

/* Stones list — editorial 風の左右交互 2 カラム */
.charm-stones {
    padding: 4rem 0 5rem;
    border-top: 1px solid var(--line-soft);
}
.charm-stones__list {
    display: flex;
    flex-direction: column;
    gap: 5rem;
    margin-top: 2rem;
}
.stone-block {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 3rem;
    align-items: center;
}
.stone-block--reverse .stone-block__media { order: 2; }
.stone-block--reverse .stone-block__body { order: 1; }
.stone-block__media {
    aspect-ratio: 4 / 5;
    overflow: hidden;
    border-radius: var(--radius);
    background: var(--bg-deep);
}
.stone-block__media a, .stone-block__media-placeholder {
    display: block;
    width: 100%; height: 100%;
}
.stone-block__media img {
    width: 100%; height: 100%;
    object-fit: cover;
    transition: transform .8s ease;
}
.stone-block__media a:hover img { transform: scale(1.04); }
.stone-block__media-placeholder {
    background: linear-gradient(135deg, var(--bg-deep), var(--bg-soft));
}
.stone-block__body { padding: .5rem 0; }
.stone-block__num {
    font-family: var(--serif);
    font-style: italic;
    font-size: 1.2rem;
    color: var(--accent);
    letter-spacing: .2em;
    margin: 0 0 1rem;
}
.stone-block__name {
    font-family: var(--serif-jp);
    font-size: clamp(1.6rem, 3vw, 2rem);
    font-weight: 500;
    letter-spacing: .1em;
    line-height: 1.4;
    margin: 0 0 .4em;
}
.stone-block__wamei {
    color: var(--text-mute);
    font-size: .88rem;
    letter-spacing: .1em;
    margin: 0 0 1.4rem;
    padding-bottom: 1.4rem;
    border-bottom: 1px solid var(--line-soft);
}
.stone-block__words {
    list-style: none; padding: 0;
    display: flex; flex-wrap: wrap;
    gap: .5rem;
    margin: 0 0 1.6rem;
}
.stone-block__words li {
    font-size: .78rem;
    padding: .35rem 1rem;
    border: 1px solid var(--line);
    border-radius: 999px;
    color: var(--text-mute);
    letter-spacing: .04em;
    background: var(--bg-soft);
}
.stone-block__lore {
    color: var(--text);
    font-size: .92rem;
    line-height: 2.05;
    letter-spacing: .04em;
    margin: 0 0 1.6rem;
}
.stone-block .link-arrow { margin-top: .3rem; }

/* Tips */
.charm-tips {
    padding: 4rem 0;
    border-top: 1px solid var(--line-soft);
}
.charm-tips__list {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
    margin-top: 1rem;
}
.tip-card {
    padding: 2rem 1.6rem;
    border: 1px solid var(--line-soft);
    border-radius: var(--radius);
    background: var(--bg-soft);
}
.tip-card__num {
    font-family: var(--serif);
    font-style: italic;
    font-size: 1rem;
    color: var(--accent);
    letter-spacing: .15em;
    margin: 0 0 1rem;
}
.tip-card__title {
    font-family: var(--serif-jp);
    font-size: 1rem;
    font-weight: 500;
    letter-spacing: .06em;
    line-height: 1.6;
    margin: 0 0 .8rem;
    padding-bottom: .8rem;
    border-bottom: 1px solid var(--line-soft);
}
.tip-card__body {
    color: var(--text-mute);
    font-size: .85rem;
    line-height: 1.95;
    letter-spacing: .03em;
    margin: 0;
}

/* FAQ */
.charm-faq {
    padding: 4rem 0;
    border-top: 1px solid var(--line-soft);
}
.charm-faq__list {
    max-width: 640px;
    margin: 0 auto;
}
.faq-item {
    border-bottom: 1px solid var(--line-soft);
    padding: 0;
}
.faq-item summary {
    cursor: pointer;
    list-style: none;
    padding: 1.3rem 0;
    display: flex; gap: 1rem; align-items: flex-start;
    transition: color .2s;
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary:hover { color: var(--accent-deep); }
.faq-item__q-label, .faq-item__a-label {
    font-family: var(--serif);
    font-style: italic;
    font-size: 1rem;
    color: var(--accent);
    flex-shrink: 0;
    line-height: 1.7;
}
.faq-item__q {
    font-size: .95rem;
    font-weight: 500;
    line-height: 1.7;
    letter-spacing: .03em;
}
.faq-item__a {
    display: flex; gap: 1rem; align-items: flex-start;
    padding: 0 0 1.4rem 0;
    color: var(--text-mute);
}
.faq-item__a p {
    font-size: .9rem;
    line-height: 1.95;
    letter-spacing: .03em;
    margin: 0;
}
.faq-item[open] .faq-item__q-label { color: var(--accent-deep); }

/* CTA */
.charm-cta {
    padding: 5rem 1rem 6rem;
    text-align: center;
    border-top: 1px solid var(--line-soft);
    margin-top: 2rem;
}
.charm-cta__title {
    font-family: var(--serif-jp);
    font-size: clamp(1.4rem, 3vw, 1.8rem);
    font-weight: 500;
    letter-spacing: .14em;
    margin: 0 0 1rem;
}
.charm-cta__lead {
    color: var(--text-mute);
    font-size: .9rem;
    line-height: 1.95;
    letter-spacing: .04em;
    max-width: 480px;
    margin: 0 auto 2rem;
}

@media (max-width: 600px) {
    .charm-hero { padding: 2rem 0 1.5rem; }
    .charm-hero__title { letter-spacing: .1em; line-height: 1.7; }
    .charm-hero__lead { font-size: .9rem; letter-spacing: .03em; line-height: 1.95; }
    .charm-intro { padding: 1.5rem 0 3rem; }
    .charm-intro p { font-size: .9rem; line-height: 1.95; }
    .charm-stones, .charm-tips, .charm-faq { padding: 3rem 0; }
    .charm-stones__list { gap: 3rem; }
    .stone-block { grid-template-columns: 1fr; gap: 1.5rem; }
    .stone-block--reverse .stone-block__media { order: 0; }
    .stone-block--reverse .stone-block__body { order: 0; }
    .stone-block__media { aspect-ratio: 1 / 1; }
    .stone-block__name { font-size: 1.4rem; }
    .stone-block__num { font-size: 1rem; margin-bottom: .6rem; }
    .stone-block__wamei { padding-bottom: 1.1rem; margin-bottom: 1.2rem; font-size: .82rem; }
    .stone-block__words { gap: .4rem; margin-bottom: 1.2rem; }
    .stone-block__words li { font-size: .72rem; padding: .3rem .85rem; }
    .stone-block__lore { font-size: .88rem; line-height: 1.95; margin-bottom: 1.2rem; }
    .charm-tips__list { grid-template-columns: 1fr; gap: 1rem; }
    .tip-card { padding: 1.6rem 1.4rem; }
    .charm-cta { padding: 3.5rem 1rem 4rem; }
}

/* ======================================
   CHARMS INDEX
   ====================================== */
.charms-index {
    max-width: var(--container);
    margin: 0 auto;
    padding: 0 1.6rem;
}
.charms-index__hero {
    text-align: center;
    padding: 3rem 0 3rem;
    max-width: 720px;
    margin: 0 auto;
}
.charms-index__title {
    font-family: var(--serif-jp);
    font-size: clamp(2rem, 5vw, 2.8rem);
    font-weight: 500;
    letter-spacing: .2em;
    margin: 0 0 1.4rem;
    line-height: 1.3;
}
.charms-index__lead {
    color: var(--text-mute);
    font-size: .98rem;
    line-height: 2.0;
    letter-spacing: .06em;
    margin: 0;
}

.charms-index__grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 2rem 1.6rem;
    padding: 2rem 0 5rem;
}
.charm-card {
    display: flex;
    flex-direction: column;
    color: var(--text);
    background: var(--bg);
    transition: transform .3s ease;
}
.charm-card:hover { transform: translateY(-4px); }
.charm-card__media {
    aspect-ratio: 1 / 1;
    overflow: hidden;
    background: var(--bg-deep);
    border-radius: var(--radius);
    margin-bottom: 1rem;
}
.charm-card__media img {
    width: 100%; height: 100%;
    object-fit: cover;
    transition: transform .8s ease;
}
.charm-card:hover .charm-card__media img { transform: scale(1.05); }
.charm-card__media-placeholder {
    width: 100%; height: 100%;
    background: linear-gradient(135deg, var(--bg-deep), var(--bg-soft));
}
.charm-card__body { padding: .2rem .3rem 0; }
.charm-card__kicker {
    font-size: .65rem;
    letter-spacing: .3em;
    color: var(--accent);
    text-transform: uppercase;
    margin: 0 0 .6rem;
}
.charm-card__title {
    font-family: var(--serif-jp);
    font-size: 1.1rem;
    font-weight: 500;
    letter-spacing: .08em;
    margin: 0 0 .8rem;
    line-height: 1.5;
}
.charm-card__summary {
    color: var(--text-mute);
    font-size: .82rem;
    line-height: 1.85;
    letter-spacing: .03em;
    margin: 0 0 1rem;
    /* 3行クランプ */
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.charm-card__link {
    display: inline-flex; align-items: center; gap: .5rem;
    font-size: .82rem;
    letter-spacing: .1em;
    color: var(--text);
    border-bottom: 1px solid var(--line-strong);
    padding-bottom: .25rem;
    transition: gap .2s, color .2s;
}
.charm-card:hover .charm-card__link { gap: .85rem; color: var(--accent-deep); }
.charm-card__link span { font-family: var(--serif); }

.charms-index__cta {
    padding: 5rem 1rem 6rem;
    text-align: center;
    border-top: 1px solid var(--line-soft);
    margin-top: 1rem;
}
.charms-index__cta-title {
    font-family: var(--serif-jp);
    font-size: clamp(1.4rem, 3vw, 1.8rem);
    font-weight: 500;
    letter-spacing: .14em;
    margin: 0 0 1rem;
}
.charms-index__cta-lead {
    color: var(--text-mute);
    font-size: .9rem;
    line-height: 1.95;
    letter-spacing: .04em;
    max-width: 480px;
    margin: 0 auto 2rem;
}

@media (max-width: 880px) {
    .charms-index__grid { grid-template-columns: repeat(2, 1fr); gap: 2rem 1.2rem; }
}
@media (max-width: 600px) {
    .charms-index__hero { padding: 2rem 0 2rem; }
    .charms-index__title { letter-spacing: .16em; }
    .charms-index__lead { font-size: .9rem; line-height: 1.95; }
    .charms-index__grid { padding: 1rem 0 4rem; gap: 1.8rem 1rem; }
    .charm-card__media { margin-bottom: .8rem; }
    .charm-card__title { font-size: 1rem; }
    .charm-card__summary { font-size: .78rem; line-height: 1.8; }
    .charms-index__cta { padding: 3.5rem 1rem 4rem; }
}
@media (max-width: 380px) {
    /* 8 cardsを2colにすると各140px以下で詰まり過ぎ。1colにしてtap面を拡大 */
    .charms-index__grid { grid-template-columns: 1fr; gap: 1.6rem; }
    .charm-card__title { font-size: 1.05rem; }
}

/* ======================================
   HOME → CHARMS / WORDS 二択導線
   ====================================== */
.home-explore {
    padding: 6rem 1.6rem;
    background: var(--bg-soft);
    border-top: 1px solid var(--line-soft);
    border-bottom: 1px solid var(--line-soft);
}
.home-explore__inner {
    max-width: var(--container);
    margin: 0 auto;
    text-align: center;
}
.home-explore__title {
    font-family: var(--serif-jp);
    font-size: clamp(1.6rem, 3.2vw, 2rem);
    font-weight: 500;
    letter-spacing: .14em;
    line-height: 1.6;
    margin: 0 0 1rem;
}
.home-explore__lead {
    color: var(--text-mute);
    font-size: .92rem;
    line-height: 2.0;
    letter-spacing: .05em;
    margin: 0 0 2.8rem;
}
.home-explore__grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.5rem;
    text-align: left;
}
.home-explore__grid--three {
    grid-template-columns: repeat(3, 1fr);
}
.home-explore__grid--six {
    grid-template-columns: repeat(3, 1fr);
    max-width: var(--container);
    margin: 0 auto;
}
@media (max-width: 880px) {
    .home-explore__grid--three { grid-template-columns: 1fr; }
    .home-explore__grid--six { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
    .home-explore__grid--six { grid-template-columns: 1fr; }
}
.explore-card {
    display: block;
    padding: 2.4rem 2rem;
    border: 1px solid var(--line-soft);
    border-radius: var(--radius);
    background: var(--bg);
    color: var(--text);
    transition: all .25s ease;
}
.explore-card:hover {
    border-color: var(--line-strong);
    transform: translateY(-3px);
    box-shadow: var(--shadow-card-hover);
}
.explore-card__kicker {
    font-size: .65rem;
    letter-spacing: .3em;
    color: var(--accent);
    text-transform: uppercase;
    margin: 0 0 1rem;
}
.explore-card__title {
    font-family: var(--serif-jp);
    font-size: 1.4rem;
    font-weight: 500;
    letter-spacing: .12em;
    margin: 0 0 1rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid var(--line-soft);
}
.explore-card__lead {
    color: var(--text-mute);
    font-size: .88rem;
    line-height: 1.95;
    letter-spacing: .03em;
    margin: 0 0 1.4rem;
}
.explore-card__link {
    display: inline-flex; align-items: center; gap: .45rem;
    font-size: .82rem;
    letter-spacing: .1em;
    color: var(--text);
    border-bottom: 1px solid var(--line-strong);
    padding-bottom: .25rem;
    transition: gap .2s, color .2s;
}
.explore-card:hover .explore-card__link { gap: .75rem; color: var(--accent-deep); }
.explore-card__link span { font-family: var(--serif); }

@media (max-width: 600px) {
    .home-explore { padding: 4rem 1.4rem; }
    .home-explore__title { letter-spacing: .1em; }
    .home-explore__lead { font-size: .88rem; margin-bottom: 2rem; }
    .home-explore__grid { grid-template-columns: 1fr; gap: 1rem; }
    .explore-card { padding: 2rem 1.6rem; }
    .explore-card__title { font-size: 1.2rem; }
}

/* ======================================
   WORDS INDEX
   ====================================== */
.words-index {
    max-width: var(--container);
    margin: 0 auto;
    padding: 0 1.6rem;
}
.words-index__hero {
    text-align: center;
    padding: 3rem 0 3rem;
    max-width: 720px;
    margin: 0 auto;
}
.words-index__title {
    font-family: var(--serif-jp);
    font-size: clamp(2rem, 5vw, 2.8rem);
    font-weight: 500;
    letter-spacing: .2em;
    margin: 0 0 1.4rem;
    line-height: 1.3;
}
.words-index__lead {
    color: var(--text-mute);
    font-size: .98rem;
    line-height: 2.0;
    letter-spacing: .06em;
    margin: 0;
}
.words-index__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
    padding: 2rem 0 5rem;
}
.word-card {
    display: flex;
    flex-direction: column;
    color: var(--text);
    border: 1px solid var(--line-soft);
    border-radius: var(--radius);
    overflow: hidden;
    background: var(--bg);
    transition: all .25s ease;
}
.word-card:hover {
    border-color: var(--line-strong);
    transform: translateY(-3px);
    box-shadow: var(--shadow-card-hover);
}
.word-card__media {
    aspect-ratio: 4 / 3;
    overflow: hidden;
    background: var(--bg-deep);
}
.word-card__media img {
    width: 100%; height: 100%;
    object-fit: cover;
    transition: transform .6s ease;
}
.word-card:hover .word-card__media img { transform: scale(1.05); }
.word-card__media-placeholder {
    width: 100%; height: 100%;
    background: linear-gradient(135deg, var(--bg-deep), var(--bg-soft));
}
.word-card__body { padding: 1.6rem 1.6rem 1.8rem; }
.word-card__kicker {
    font-size: .62rem;
    letter-spacing: .3em;
    color: var(--accent);
    text-transform: uppercase;
    margin: 0 0 .9rem;
}
.word-card__name {
    font-family: var(--serif-jp);
    font-size: 1.6rem;
    font-weight: 500;
    letter-spacing: .1em;
    margin: 0 0 1rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid var(--line-soft);
}
.word-card__summary {
    color: var(--text-mute);
    font-size: .85rem;
    line-height: 1.9;
    letter-spacing: .03em;
    margin: 0 0 1.2rem;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.word-card__stones {
    display: flex; flex-wrap: wrap; gap: .35rem;
    margin: 0 0 1.4rem;
}
.word-card__stones span {
    font-size: .72rem;
    color: var(--text-soft);
    padding: .25rem .7rem;
    background: var(--bg-soft);
    border-radius: 999px;
    letter-spacing: .03em;
}
.word-card__link {
    display: inline-flex; align-items: center; gap: .4rem;
    font-size: .8rem;
    letter-spacing: .1em;
    color: var(--text);
    border-bottom: 1px solid var(--line-strong);
    padding-bottom: .2rem;
}
.word-card:hover .word-card__link { color: var(--accent-deep); gap: .7rem; }
.word-card__link span { font-family: var(--serif); }

.words-index__cta {
    padding: 5rem 1rem 6rem;
    text-align: center;
    border-top: 1px solid var(--line-soft);
    margin-top: 1rem;
}
.words-index__cta-title {
    font-family: var(--serif-jp);
    font-size: clamp(1.4rem, 3vw, 1.8rem);
    font-weight: 500;
    letter-spacing: .14em;
    margin: 0 0 1rem;
}
.words-index__cta-lead {
    color: var(--text-mute);
    font-size: .9rem;
    line-height: 1.95;
    letter-spacing: .04em;
    max-width: 480px;
    margin: 0 auto 2rem;
}

/* ======================================
   WORD SHOW
   ====================================== */
.word-page {
    max-width: var(--container-narrow);
    margin: 0 auto;
    padding: 0 1.6rem;
}
.word-hero {
    text-align: center;
    padding: 3rem 0 2rem;
}
.word-hero__title {
    font-family: var(--serif-jp);
    font-size: clamp(2rem, 5vw, 2.8rem);
    font-weight: 500;
    letter-spacing: .14em;
    margin: 0 0 1.6rem;
    line-height: 1.5;
}
.word-hero__lead {
    color: var(--text-mute);
    font-size: .98rem;
    line-height: 2.0;
    letter-spacing: .06em;
    max-width: 600px;
    margin: 0 auto;
}
.word-intro {
    padding: 2.5rem 0 4rem;
    max-width: 640px;
    margin: 0 auto;
}
.word-intro p {
    font-size: .96rem;
    line-height: 2.0;
    letter-spacing: .04em;
    margin: 0 0 1.4em;
}
.word-intro p:last-child { margin-bottom: 0; }

.word-stones {
    padding: 4rem 0 5rem;
    border-top: 1px solid var(--line-soft);
}
.word-stones__list {
    display: flex;
    flex-direction: column;
    gap: 5rem;
    margin-top: 2rem;
}

.word-related {
    padding: 4rem 0;
    border-top: 1px solid var(--line-soft);
}
.word-related__list {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.2rem;
    margin-top: 2rem;
}
.related-card {
    display: block;
    color: var(--text);
    padding: 1.6rem 1.4rem;
    border: 1px solid var(--line-soft);
    border-radius: var(--radius);
    transition: all .25s ease;
}
.related-card:hover {
    border-color: var(--line-strong);
    transform: translateY(-2px);
}
.related-card__kicker {
    font-size: .6rem;
    letter-spacing: .3em;
    color: var(--accent);
    text-transform: uppercase;
    margin: 0 0 .6rem;
}
.related-card__name {
    font-family: var(--serif-jp);
    font-size: 1.05rem;
    font-weight: 500;
    letter-spacing: .08em;
    margin: 0 0 .8rem;
    padding-bottom: .8rem;
    border-bottom: 1px solid var(--line-soft);
}
.related-card__link {
    display: inline-flex; align-items: center; gap: .35rem;
    font-size: .78rem;
    letter-spacing: .1em;
    color: var(--text-mute);
}
.related-card__link span { font-family: var(--serif); }
.related-card:hover .related-card__link { color: var(--text); gap: .55rem; }

.word-faq {
    padding: 4rem 0;
    border-top: 1px solid var(--line-soft);
}
.word-faq__list {
    max-width: 640px;
    margin: 0 auto;
}

@media (max-width: 880px) {
    .words-index__grid { grid-template-columns: repeat(2, 1fr); gap: 1.2rem; }
    .word-related__list { grid-template-columns: 1fr; gap: 1rem; }
}
@media (max-width: 600px) {
    .words-index__hero { padding: 2rem 0 2rem; }
    .words-index__title { letter-spacing: .16em; }
    .words-index__lead { font-size: .9rem; line-height: 1.95; }
    .words-index__grid { padding: 1rem 0 4rem; gap: 1rem; grid-template-columns: 1fr; }
    .word-card { padding: 1.6rem 1.4rem; }
    .word-card__name { font-size: 1.4rem; }
    .word-card__summary { font-size: .82rem; }
    .words-index__cta { padding: 3.5rem 1rem 4rem; }

    .word-hero { padding: 2rem 0 1.5rem; }
    .word-hero__title { letter-spacing: .1em; line-height: 1.6; }
    .word-hero__lead { font-size: .9rem; line-height: 1.95; }
    .word-intro { padding: 1.5rem 0 3rem; }
    .word-intro p { font-size: .9rem; line-height: 1.95; }
    .word-stones, .word-related, .word-faq { padding: 3rem 0; }
    .word-stones__list { gap: 3rem; }
}

/* 石言葉 pill 内のリンク（charm show） */
.stone-block__words li a {
    color: var(--text-mute);
    border-bottom: 1px solid transparent;
    transition: color .2s, border-color .2s;
}
.stone-block__words li a:hover {
    color: var(--accent-deep);
    border-bottom-color: var(--accent-soft);
}

/* ======================================
   GUIDE INDEX
   ====================================== */
.guides-index {
    max-width: var(--container-narrow);
    margin: 0 auto;
    padding: 0 1.6rem;
}
.guides-index__hero {
    text-align: center;
    padding: 3rem 0 3rem;
    max-width: 720px;
    margin: 0 auto;
}
.guides-index__title {
    font-family: var(--serif-jp);
    font-size: clamp(2rem, 5vw, 2.8rem);
    font-weight: 500;
    letter-spacing: .2em;
    margin: 0 0 1.4rem;
    line-height: 1.3;
}
.guides-index__lead {
    color: var(--text-mute);
    font-size: .98rem;
    line-height: 2.0;
    letter-spacing: .06em;
    margin: 0;
}
.guides-index__grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1.5rem;
    padding: 2rem 0 5rem;
}
.guide-card {
    display: block;
    color: var(--text);
    padding: 2.4rem 2rem;
    border: 1px solid var(--line-soft);
    border-radius: var(--radius);
    background: var(--bg);
    transition: all .25s ease;
}
.guide-card:hover {
    border-color: var(--line-strong);
    transform: translateY(-3px);
    box-shadow: var(--shadow-card-hover);
}
.guide-card__kicker {
    font-size: .65rem;
    letter-spacing: .3em;
    color: var(--accent);
    text-transform: uppercase;
    margin: 0 0 1rem;
}
.guide-card__title {
    font-family: var(--serif-jp);
    font-size: 1.3rem;
    font-weight: 500;
    letter-spacing: .12em;
    margin: 0 0 1rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid var(--line-soft);
}
.guide-card__summary {
    color: var(--text-mute);
    font-size: .88rem;
    line-height: 1.95;
    letter-spacing: .03em;
    margin: 0 0 1.4rem;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.guide-card__link {
    display: inline-flex; align-items: center; gap: .45rem;
    font-size: .82rem;
    letter-spacing: .1em;
    color: var(--text);
    border-bottom: 1px solid var(--line-strong);
    padding-bottom: .25rem;
}
.guide-card:hover .guide-card__link { gap: .75rem; color: var(--accent-deep); }
.guide-card__link span { font-family: var(--serif); }

/* ======================================
   GUIDE SHOW
   ====================================== */
.guide-page {
    max-width: var(--container-narrow);
    margin: 0 auto;
    padding: 0 1.6rem;
}
.guide-hero {
    text-align: center;
    padding: 3rem 0 2rem;
    border-bottom: 1px solid var(--line-soft);
    margin-bottom: 3rem;
}
.guide-hero__title {
    font-family: var(--serif-jp);
    font-size: clamp(1.8rem, 4.4vw, 2.4rem);
    font-weight: 500;
    letter-spacing: .14em;
    margin: 0 0 1.4rem;
    line-height: 1.5;
}
.guide-hero__lead {
    color: var(--text-mute);
    font-size: .96rem;
    line-height: 2.0;
    letter-spacing: .06em;
    max-width: 600px;
    margin: 0 auto;
}
.guide-body {
    padding: 0 0 4rem;
    max-width: 700px;
    margin: 0 auto;
}
.guide-section {
    display: grid;
    grid-template-columns: 4rem 1fr;
    gap: 1rem;
    padding: 2.5rem 0;
    border-bottom: 1px solid var(--line-soft);
}
.guide-section:first-of-type { padding-top: 1rem; }
.guide-section:last-of-type { border-bottom: none; }
.guide-section__num {
    font-family: var(--serif);
    font-style: italic;
    font-size: 1.2rem;
    color: var(--accent);
    letter-spacing: .15em;
    padding-top: .35rem;
}
.guide-section__title {
    font-family: var(--serif-jp);
    font-size: 1.2rem;
    font-weight: 500;
    letter-spacing: .08em;
    line-height: 1.6;
    margin: 0 0 1.2rem;
}
.guide-section__content p {
    font-size: .94rem;
    line-height: 2.0;
    letter-spacing: .04em;
    margin: 0 0 1.1em;
    color: var(--text);
}
.guide-section__content p:last-child { margin-bottom: 0; }

.guide-faq {
    padding: 4rem 0;
    border-top: 1px solid var(--line-soft);
}
.guide-faq__list { max-width: 640px; margin: 0 auto; }

@media (max-width: 600px) {
    .guides-index__grid { grid-template-columns: 1fr; gap: 1rem; padding: 1rem 0 4rem; }
    .guide-card { padding: 1.8rem 1.6rem; }
    .guide-card__title { font-size: 1.15rem; }

    .guide-hero { padding: 2rem 0 1.5rem; margin-bottom: 2rem; }
    .guide-hero__title { letter-spacing: .1em; line-height: 1.6; }
    .guide-hero__lead { font-size: .9rem; line-height: 1.95; }
    .guide-section { grid-template-columns: 1fr; gap: .4rem; padding: 2rem 0; }
    .guide-section__num { font-size: 1rem; padding-top: 0; }
    .guide-section__title { font-size: 1.05rem; }
    .guide-section__content p { font-size: .88rem; line-height: 1.95; }
    .guide-faq { padding: 3rem 0; }
}

/* === Section CTA Button === */
.section-cta-wrap {
    display: flex; flex-wrap: wrap; gap: .8rem;
    margin-top: 1.8rem;
}
.section-cta {
    display: inline-flex; align-items: center; gap: .6rem;
    min-height: 44px;
    padding: .75rem 1.5rem;
    border: 1px solid var(--line-strong);
    border-radius: 999px;
    font-size: .85rem;
    font-family: var(--sans);
    letter-spacing: .08em;
    color: var(--text);
    background: var(--bg);
    transition: all .22s ease;
}
.section-cta:hover {
    background: var(--text);
    color: #fff;
    border-color: var(--text);
    gap: .9rem;
}
.section-cta span { font-family: var(--serif); font-size: 1rem; }

@media (max-width: 600px) {
    .section-cta { padding: .65rem 1.2rem; font-size: .8rem; }
}

/* ======================================
   DIAGNOSE (form + result)
   ====================================== */
.diagnose, .diagnose-result {
    max-width: var(--container-narrow);
    margin: 0 auto;
    padding: 0 1.6rem;
}

/* Form hero */
.diagnose__hero {
    text-align: center;
    padding: 3rem 0 2rem;
}
.diagnose__title {
    font-family: var(--serif-jp);
    font-size: clamp(2rem, 5vw, 2.8rem);
    font-weight: 500;
    letter-spacing: .2em;
    margin: 0 0 1.4rem;
}
.diagnose__lead {
    color: var(--text-mute);
    font-size: .96rem;
    line-height: 2.0;
    letter-spacing: .05em;
    max-width: 580px;
    margin: 0 auto;
}
.diagnose__note {
    display: block;
    margin-top: .8rem;
    font-size: .78rem;
    color: var(--text-soft);
    letter-spacing: .02em;
}

/* Form */
.diagnose__form {
    max-width: 560px;
    margin: 2rem auto 5rem;
    padding: 2.4rem 2rem 2.6rem;
    border: 1px solid var(--line-soft);
    border-radius: var(--radius);
    background: var(--bg);
}
.form-row {
    margin-bottom: 2rem;
    border: none;
    padding: 0;
}
.form-row:last-of-type { margin-bottom: 0; }
.form-label {
    display: block;
    font-family: var(--serif-jp);
    font-size: 1rem;
    font-weight: 500;
    letter-spacing: .08em;
    margin: 0 0 1rem;
    color: var(--text);
}
.form-input {
    width: 100%;
    padding: .75rem 1rem;
    border: 1px solid var(--line);
    border-radius: var(--radius-sm);
    font-family: var(--sans);
    /* 16px 固定: 16px 未満だと iOS Safari がフォーカス時に自動ズームする */
    font-size: 16px;
    color: var(--text);
    background: var(--bg);
    transition: border-color .2s;
}
.form-input:focus {
    outline: none;
    border-color: var(--text);
}
.form-options {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: .6rem;
}
.option {
    display: flex; align-items: center;
    min-height: 44px;
    padding: .8rem .9rem;
    border: 1px solid var(--line);
    border-radius: var(--radius-sm);
    cursor: pointer;
    transition: all .15s ease;
    font-size: .9rem;
    background: var(--bg);
}
.option input[type="radio"] {
    margin-right: .6rem;
    accent-color: var(--text);
}
.option:hover { border-color: var(--text-mute); }
.option:has(input:checked) {
    background: var(--text);
    color: #fff;
    border-color: var(--text);
}
.form-submit {
    margin-top: 2.5rem;
    text-align: center;
}
.form-submit .btn { font-size: .9rem; padding: 1rem 2.4rem; }

/* Result hero */
.diagnose-result__hero {
    text-align: center;
    padding: 3rem 0 2rem;
}
.diagnose-result__title {
    font-family: var(--serif-jp);
    font-size: clamp(1.8rem, 4.5vw, 2.4rem);
    font-weight: 500;
    letter-spacing: .14em;
    line-height: 1.5;
    margin: 0 0 1rem;
}
.diagnose-result__lead {
    color: var(--text-mute);
    font-size: .92rem;
    line-height: 1.95;
    letter-spacing: .04em;
    max-width: 600px;
    margin: 0 auto;
}

/* Primary stone (大型) */
.primary-stone {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 3rem;
    align-items: center;
    padding: 3rem 0 4rem;
    border-bottom: 1px solid var(--line-soft);
}
.primary-stone__media {
    aspect-ratio: 4 / 5;
    overflow: hidden;
    border-radius: var(--radius);
    background: var(--bg-deep);
}
.primary-stone__media img {
    width: 100%; height: 100%; object-fit: cover;
}
.primary-stone__placeholder {
    width: 100%; height: 100%;
    background: linear-gradient(135deg, var(--bg-deep), var(--bg-soft));
}
.primary-stone__kicker {
    font-size: .68rem;
    letter-spacing: .3em;
    color: var(--accent);
    text-transform: uppercase;
    margin: 0 0 1rem;
}
.primary-stone__name {
    font-family: var(--serif-jp);
    font-size: clamp(2rem, 4.5vw, 2.8rem);
    font-weight: 500;
    letter-spacing: .12em;
    margin: 0 0 .4em;
    line-height: 1.3;
}
.primary-stone__wamei {
    color: var(--text-mute);
    font-size: .88rem;
    letter-spacing: .1em;
    margin: 0 0 1.4rem;
    padding-bottom: 1.4rem;
    border-bottom: 1px solid var(--line-soft);
}
.primary-stone__short {
    color: var(--text);
    font-size: .94rem;
    line-height: 2.0;
    letter-spacing: .04em;
    margin: 0 0 1.6rem;
}

/* Diagnose reasons */
.diagnose-reasons {
    padding: 4rem 0;
    border-bottom: 1px solid var(--line-soft);
}
.diagnose-reasons__list {
    list-style: none;
    padding: 0;
    margin: 1.5rem auto 0;
    max-width: 600px;
}
.diagnose-reasons__list li {
    position: relative;
    padding: .6rem 0 .6rem 1.6rem;
    font-size: .9rem;
    line-height: 1.9;
    color: var(--text);
    letter-spacing: .03em;
}
.diagnose-reasons__list li::before {
    content: '◇';
    position: absolute;
    left: 0;
    color: var(--accent);
    font-size: .7rem;
    top: 1.1rem;
}

/* Secondary stones */
.secondary-stones { padding: 4rem 0; border-bottom: 1px solid var(--line-soft); }
.secondary-stones__list {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 2.4rem;
    margin-top: 2rem;
}
.secondary-stone {
    display: flex;
    flex-direction: column;
    gap: 1.4rem;
}
.secondary-stone__media {
    aspect-ratio: 4 / 5;
    overflow: hidden;
    border-radius: var(--radius);
    background: var(--bg-deep);
}
.secondary-stone__media img {
    width: 100%; height: 100%; object-fit: cover;
    transition: transform .6s;
}
.secondary-stone__media:hover img { transform: scale(1.04); }
.secondary-stone__placeholder {
    width: 100%; height: 100%;
    background: linear-gradient(135deg, var(--bg-deep), var(--bg-soft));
}
.secondary-stone__name {
    font-family: var(--serif-jp);
    font-size: 1.3rem;
    font-weight: 500;
    letter-spacing: .1em;
    margin: 0 0 .3em;
}
.secondary-stone__wamei {
    color: var(--text-mute);
    font-size: .82rem;
    letter-spacing: .08em;
    margin: 0 0 1rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid var(--line-soft);
}
.secondary-stone__short {
    color: var(--text-mute);
    font-size: .86rem;
    line-height: 1.95;
    letter-spacing: .03em;
    margin: 0 0 1rem;
}

/* Related links */
.diagnose-related {
    padding: 4rem 0;
    border-bottom: 1px solid var(--line-soft);
}
.diagnose-related__cols {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 2.4rem;
    margin-top: 2rem;
    max-width: 720px;
    margin-left: auto;
    margin-right: auto;
}
.diagnose-related__col ul {
    list-style: none;
    padding: 0;
    margin: 0;
}
.diagnose-related__col li {
    border-bottom: 1px solid var(--line-soft);
}
.diagnose-related__col li:last-child { border-bottom: none; }
.diagnose-related__col li a {
    display: block;
    padding: .75rem 0;
    font-size: .9rem;
    color: var(--text);
    letter-spacing: .04em;
}
.diagnose-related__col li a:hover { color: var(--accent-deep); }

/* Re-diagnose */
.diagnose-redo {
    padding: 5rem 0 6rem;
    text-align: center;
}
.diagnose-redo__title {
    font-family: var(--serif-jp);
    font-size: clamp(1.4rem, 3vw, 1.8rem);
    font-weight: 500;
    letter-spacing: .14em;
    margin: 0 0 1rem;
}
.diagnose-redo__lead {
    color: var(--text-mute);
    font-size: .9rem;
    line-height: 1.95;
    letter-spacing: .04em;
    max-width: 500px;
    margin: 0 auto 2rem;
}

@media (max-width: 600px) {
    .diagnose__hero { padding: 2rem 0 1.5rem; }
    .diagnose__form { padding: 1.8rem 1.4rem 2rem; margin: 1.5rem auto 3.5rem; }
    .form-options { grid-template-columns: 1fr; gap: .5rem; }
    .form-submit .btn { padding: .85rem 1.8rem; font-size: .85rem; }

    .primary-stone { grid-template-columns: 1fr; gap: 2rem; padding: 2.5rem 0 3rem; }
    .secondary-stones__list { grid-template-columns: 1fr; gap: 2.4rem; }
    .diagnose-related__cols { grid-template-columns: 1fr; gap: 2rem; }
    .diagnose-reasons, .secondary-stones, .diagnose-related { padding: 3rem 0; }
    .diagnose-redo { padding: 3.5rem 0 4rem; }
}

/* Home → Diagnose banner */
.home-explore__diagnose { margin-top: 1.5rem; }
.diagnose-banner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1.6rem;
    padding: 2.2rem 2rem;
    border: 1px solid var(--line-soft);
    border-radius: var(--radius);
    background: var(--text);
    color: #fff;
    transition: all .25s ease;
}
.diagnose-banner:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(0,0,0,.14);
    color: #fff;
}
.diagnose-banner .eyebrow { color: var(--accent-soft); margin: 0 0 .6rem; }
.diagnose-banner__title {
    font-family: var(--serif-jp);
    font-size: 1.2rem;
    font-weight: 500;
    letter-spacing: .1em;
    margin: 0 0 .5rem;
    color: #fff;
}
.diagnose-banner__lead {
    color: rgba(255,255,255,.78);
    font-size: .88rem;
    line-height: 1.7;
    letter-spacing: .03em;
    margin: 0;
}
.diagnose-banner__cta {
    flex-shrink: 0;
    display: inline-flex; align-items: center; gap: .6rem;
    font-size: .88rem;
    letter-spacing: .12em;
    padding: .8rem 1.6rem;
    border: 1px solid rgba(255,255,255,.4);
    border-radius: 999px;
    transition: all .2s ease;
}
.diagnose-banner:hover .diagnose-banner__cta {
    background: #fff;
    color: var(--text);
    gap: .9rem;
}
.diagnose-banner__cta span { font-family: var(--serif); }
@media (max-width: 600px) {
    .diagnose-banner { flex-direction: column; align-items: flex-start; padding: 1.8rem 1.5rem; gap: 1.2rem; }
    .diagnose-banner__cta { padding: .7rem 1.4rem; font-size: .82rem; }
}

/* ======================================
   CALENDAR (月相と今日の石)
   ====================================== */
.calendar {
    max-width: var(--container-narrow);
    margin: 0 auto;
    padding: 0 1.6rem;
}

/* Hero */
.calendar__hero { padding: 2rem 0 3rem; }
.calendar__hero .eyebrow {
    text-align: center;
    font-size: .85rem;
    letter-spacing: .5em;
    margin: 0 0 2rem;
}
.calendar__hero-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 3rem;
    align-items: center;
}

/* Moon card */
.moon-card {
    text-align: center;
    padding: 2.4rem 1.6rem;
}
.moon-card__visual {
    width: 180px; height: 180px;
    margin: 0 auto 1.6rem;
    display: flex; align-items: center; justify-content: center;
}
.moon-card__visual svg {
    width: 100%; height: 100%;
    filter: drop-shadow(0 6px 18px rgba(0,0,0,.18));
    border-radius: 50%;
}
.moon-card__phase {
    font-family: var(--serif-jp);
    font-size: 1.5rem;
    font-weight: 500;
    letter-spacing: .14em;
    margin: 0 0 .3em;
}
.moon-card__age {
    color: var(--text-soft);
    font-size: .78rem;
    letter-spacing: .15em;
    margin: 0 0 1.4rem;
}
.moon-card__lore {
    color: var(--text-mute);
    font-size: .88rem;
    line-height: 1.95;
    letter-spacing: .04em;
    margin: 0;
    max-width: 320px;
    margin-left: auto;
    margin-right: auto;
}

/* Today's stone */
.today-stone {
    text-align: center;
    padding: 2.4rem 1.6rem;
    background: var(--bg-soft);
    border-radius: var(--radius);
    border: 1px solid var(--line-soft);
}
.today-stone__name {
    font-family: var(--serif-jp);
    font-size: clamp(1.8rem, 4vw, 2.4rem);
    font-weight: 500;
    letter-spacing: .14em;
    margin: 0 0 .3em;
    line-height: 1.3;
}
.today-stone__wamei {
    color: var(--text-mute);
    font-size: .85rem;
    letter-spacing: .1em;
    margin: 0 0 1.4rem;
}
.today-stone__media {
    aspect-ratio: 1 / 1;
    max-width: 280px;
    margin: 0 auto 1.4rem;
    border-radius: var(--radius);
    overflow: hidden;
    background: var(--bg-deep);
}
.today-stone__media img {
    width: 100%; height: 100%; object-fit: cover;
}
.today-stone__placeholder {
    width: 100%; height: 100%;
    background: linear-gradient(135deg, var(--bg-deep), var(--bg-soft));
}
.today-stone__short {
    color: var(--text);
    font-size: .92rem;
    line-height: 1.95;
    letter-spacing: .04em;
    margin: 0 0 1.6rem;
    max-width: 380px;
    margin-left: auto;
    margin-right: auto;
}

/* Reason */
.calendar-reason {
    padding: 3rem 0;
    border-top: 1px solid var(--line-soft);
    text-align: center;
}
.calendar-reason__body {
    color: var(--text);
    font-size: .96rem;
    line-height: 2.0;
    letter-spacing: .04em;
    max-width: 600px;
    margin: 0 auto 2.5rem;
}
.calendar-related {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 2.4rem;
    max-width: 600px;
    margin: 2rem auto 0;
    text-align: left;
}
.calendar-related__col ul {
    list-style: none; padding: 0; margin: .5rem 0 0;
}
.calendar-related__col li {
    border-bottom: 1px solid var(--line-soft);
}
.calendar-related__col li:last-child { border-bottom: none; }
.calendar-related__col a {
    display: block;
    padding: .75rem 0;
    font-size: .9rem;
    color: var(--text);
    letter-spacing: .03em;
}
.calendar-related__col a:hover { color: var(--accent-deep); }

/* Forecast */
.calendar-forecast {
    padding: 3.5rem 0;
    border-top: 1px solid var(--line-soft);
}
.forecast-grid {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: .8rem;
    margin-top: 1.5rem;
}
.forecast-card {
    text-align: center;
    padding: 1.2rem .6rem;
    border: 1px solid var(--line-soft);
    border-radius: var(--radius);
    background: var(--bg);
}
.forecast-card--today {
    border-color: var(--text);
    background: var(--bg-soft);
}
.forecast-card__date {
    font-size: .72rem;
    color: var(--text-mute);
    letter-spacing: .05em;
    margin: 0 0 .8rem;
}
.forecast-card__moon {
    width: 44px; height: 44px;
    margin: 0 auto .8rem;
    display: flex; align-items: center; justify-content: center;
}
.forecast-card__moon svg {
    width: 100%; height: 100%;
    filter: drop-shadow(0 2px 4px rgba(0,0,0,.10));
    border-radius: 50%;
}
.forecast-card__phase {
    font-family: var(--serif-jp);
    font-size: .78rem;
    font-weight: 500;
    letter-spacing: .04em;
    margin: 0 0 .35rem;
}
.forecast-card__stone {
    font-size: .68rem;
    color: var(--text-mute);
    letter-spacing: .03em;
    margin: 0;
}

/* About */
.calendar-about {
    padding: 4rem 0 6rem;
    border-top: 1px solid var(--line-soft);
    max-width: 640px;
    margin: 0 auto;
    text-align: center;
}
.calendar-about p {
    color: var(--text-mute);
    font-size: .92rem;
    line-height: 2.0;
    letter-spacing: .04em;
}
.calendar-about__small {
    font-size: .78rem !important;
    color: var(--text-soft) !important;
    margin-top: 1.4rem;
}

@media (max-width: 880px) {
    .calendar__hero-grid { grid-template-columns: 1fr; gap: 2rem; }
    .forecast-grid { grid-template-columns: repeat(4, 1fr); gap: .6rem; }
    .forecast-grid > .forecast-card:nth-child(n+5) { grid-column: span 1; }
}
@media (max-width: 600px) {
    .calendar { padding: 0 1.2rem; }
    .calendar__hero { padding: 1.5rem 0 2rem; }
    .moon-card__visual { width: 140px; height: 140px; }
    .moon-card__phase { font-size: 1.25rem; }
    .today-stone { padding: 1.8rem 1.4rem; }
    .today-stone__media { max-width: 240px; }
    .calendar-reason { padding: 2.5rem 0; }
    .calendar-related { grid-template-columns: 1fr; gap: 1.6rem; }
    .calendar-forecast { padding: 2.5rem 0; }
    /* 7枚を 4+3 で配置（3-3-1 で1枚だけ孤立するのを避ける） */
    .forecast-grid { grid-template-columns: repeat(4, 1fr); gap: .45rem; }
    .forecast-card { padding: 1rem .35rem; }
    .forecast-card__moon { width: 36px; height: 36px; margin-bottom: .55rem; }
    .forecast-card__date { font-size: .68rem; margin-bottom: .55rem; }
    .forecast-card__phase { font-size: .7rem; }
    .forecast-card__stone { font-size: .62rem; }
    .calendar-about { padding: 3rem 0 4rem; }
}
@media (max-width: 380px) {
    /* 320-380px では 7枚を 1段に詰めるのは限界、4+3 を維持しつつフォントを更に詰める */
    .forecast-card__date,
    .forecast-card__phase { letter-spacing: 0; }
    .forecast-card__stone { letter-spacing: 0; }
}

/* Home → Calendar banner (淡色版、診断バナーの下) */
.home-explore__calendar { margin-top: 1rem; }
.calendar-banner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1.6rem;
    padding: 2rem 2rem;
    border: 1px solid var(--line-soft);
    border-radius: var(--radius);
    background: var(--bg);
    color: var(--text);
    transition: all .25s ease;
}
.calendar-banner:hover {
    border-color: var(--line-strong);
    transform: translateY(-2px);
    box-shadow: var(--shadow-card);
    color: var(--text);
}
.calendar-banner .eyebrow { color: var(--accent); margin: 0 0 .6rem; }
.calendar-banner__title {
    font-family: var(--serif-jp);
    font-size: 1.15rem;
    font-weight: 500;
    letter-spacing: .1em;
    margin: 0 0 .5rem;
}
.calendar-banner__lead {
    color: var(--text-mute);
    font-size: .86rem;
    line-height: 1.7;
    letter-spacing: .03em;
    margin: 0;
}
.calendar-banner__cta {
    flex-shrink: 0;
    display: inline-flex; align-items: center; gap: .55rem;
    font-size: .85rem;
    letter-spacing: .1em;
    padding: .7rem 1.4rem;
    border: 1px solid var(--line-strong);
    border-radius: 999px;
    transition: all .2s ease;
}
.calendar-banner:hover .calendar-banner__cta {
    background: var(--text);
    color: #fff;
    border-color: var(--text);
    gap: .85rem;
}
.calendar-banner__cta span { font-family: var(--serif); }
@media (max-width: 600px) {
    .calendar-banner { flex-direction: column; align-items: flex-start; padding: 1.6rem 1.4rem; gap: 1rem; }
}

/* ======================================
   SEARCH
   ====================================== */
.search-page {
    max-width: var(--container-narrow);
    margin: 0 auto;
    padding: 0 1.6rem;
}
.search-hero {
    text-align: center;
    padding: 3rem 0 2.5rem;
}
.search-hero__title {
    font-family: var(--serif-jp);
    font-size: clamp(2rem, 5vw, 2.6rem);
    font-weight: 500;
    letter-spacing: .18em;
    margin: 0 0 1rem;
}
.search-hero__lead {
    color: var(--text-mute);
    font-size: .95rem;
    line-height: 1.95;
    letter-spacing: .04em;
    max-width: 580px;
    margin: 0 auto 2.4rem;
}
.search-form {
    max-width: 560px;
    margin: 0 auto;
    display: flex;
    align-items: stretch;
    border: 1px solid var(--line-strong);
    border-radius: 999px;
    overflow: hidden;
    transition: border-color .2s;
}
.search-form:focus-within { border-color: var(--text); }
.search-form__input {
    flex: 1;
    min-width: 0;
    border: none;
    padding: .9rem 1.4rem;
    font-family: var(--sans);
    /* 16px 固定: iOS Safari の自動ズーム回避 */
    font-size: 16px;
    color: var(--text);
    background: var(--bg);
    outline: none;
}
.search-form__submit {
    border: none;
    background: var(--text);
    color: #fff;
    padding: 0 1.4rem;
    cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    transition: background .2s;
}
.search-form__submit:hover { background: var(--accent-deep); }

.search-suggestions {
    max-width: 560px;
    margin: 1.6rem auto 3rem;
    text-align: center;
}
.search-suggestions__label {
    font-size: .82rem;
    color: var(--text-mute);
    letter-spacing: .06em;
    margin: 0 0 1rem;
}
.search-suggestions ul {
    list-style: none; padding: 0; margin: 0;
    display: flex; flex-wrap: wrap; justify-content: center;
    gap: .5rem;
}
.search-suggestions li a {
    display: inline-block;
    padding: .4rem 1rem;
    border: 1px solid var(--line);
    border-radius: 999px;
    font-size: .82rem;
    letter-spacing: .04em;
    color: var(--text-mute);
    background: var(--bg);
    transition: all .2s;
}
.search-suggestions li a:hover {
    color: var(--text);
    border-color: var(--text-mute);
    background: var(--bg-soft);
}

.search-summary {
    text-align: center;
    color: var(--text-mute);
    font-size: .9rem;
    letter-spacing: .04em;
    margin: 0 0 2.5rem;
}
.search-group {
    padding: 2rem 0;
    border-top: 1px solid var(--line-soft);
}
.search-group__title {
    display: flex; align-items: baseline; justify-content: space-between;
    font-family: var(--serif-jp);
    font-size: 1.15rem;
    font-weight: 500;
    letter-spacing: .1em;
    margin: 0 0 1.4rem;
}
.search-group__count {
    font-family: var(--sans);
    font-size: .72rem;
    color: var(--text-soft);
    letter-spacing: .1em;
    font-weight: 400;
}
.search-results {
    list-style: none; padding: 0; margin: 0;
    display: flex; flex-direction: column;
    gap: 1rem;
}
.search-result__link {
    display: block;
    padding: 1.4rem 1.6rem;
    border: 1px solid var(--line-soft);
    border-radius: var(--radius);
    background: var(--bg);
    color: var(--text);
    transition: all .2s;
}
.search-result__link:hover {
    border-color: var(--line-strong);
    transform: translateY(-1px);
    box-shadow: var(--shadow-card);
}
.search-result__label {
    display: inline-block;
    font-size: .68rem;
    letter-spacing: .25em;
    color: var(--accent);
    text-transform: uppercase;
    margin: 0 0 .55rem;
}
.search-result__title {
    font-family: var(--serif-jp);
    font-size: 1.08rem;
    font-weight: 500;
    letter-spacing: .06em;
    margin: 0 0 .5rem;
}
.search-result__snippet {
    color: var(--text-mute);
    font-size: .86rem;
    line-height: 1.8;
    letter-spacing: .02em;
    margin: 0;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/* === Header search icon === */
.header-search {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px; height: 36px;
    margin-left: .8rem;
    color: var(--text-mute);
    border-radius: 50%;
    transition: all .2s;
}
.header-search:hover { color: var(--text); background: var(--bg-soft); }
.header-search svg { display: block; }

@media (max-width: 600px) {
    .search-hero { padding: 2rem 0 2rem; }
    .search-form__input { padding: .8rem 1.2rem; }
    .search-suggestions { margin: 1.2rem auto 2.4rem; }
    .search-group { padding: 1.6rem 0; }
    .search-result__link { padding: 1.2rem 1.4rem; }
    .header-search { width: 40px; height: 40px; margin-left: .1rem; }
}


/* ======================================
   STONE SPOTLIGHT (例: ダイヤモンド)
   TROZO の鉱物百科構成と被らないよう、贈り物・色別物語・石言葉×場面の編集軸で構成
   ====================================== */
.stone-spotlight {
    max-width: var(--container);
    margin: 0 auto;
    padding: 0 1.6rem;
}

/* Hero: 左右 2 カラム */
.spot-hero {
    display: grid;
    grid-template-columns: 1fr 1fr;
    align-items: center;
    gap: 4rem;
    padding: 3rem 0 5rem;
}
.spot-hero__title {
    font-family: var(--serif-jp);
    font-size: clamp(2.4rem, 5vw, 3.4rem);
    font-weight: 500;
    letter-spacing: .18em;
    line-height: 1.3;
    margin: 0 0 .8rem;
}
.spot-hero__subtitle {
    font-family: var(--serif-jp);
    font-size: clamp(1.2rem, 2.4vw, 1.4rem);
    font-weight: 400;
    letter-spacing: .15em;
    color: var(--accent-deep);
    margin: 0 0 2rem;
    line-height: 1.6;
}
.spot-hero__lead {
    color: var(--text-mute);
    font-size: .96rem;
    line-height: 2.0;
    letter-spacing: .04em;
    margin: 0 0 2.4rem;
}
.spot-hero__name {
    display: inline-flex; align-items: baseline; gap: .4rem;
    padding: .8rem 1.4rem;
    border-top: 1px solid var(--line);
    border-bottom: 1px solid var(--line);
    font-family: var(--serif-jp);
}
.spot-hero__name > span:first-child {
    font-size: 1.15rem;
    font-weight: 500;
    letter-spacing: .12em;
}
.spot-hero__wamei {
    color: var(--text-mute);
    font-size: .82rem;
    letter-spacing: .1em;
}
.spot-hero__media {
    aspect-ratio: 4 / 5;
    overflow: hidden;
    border-radius: var(--radius);
    background: var(--bg-deep);
}
.spot-hero__media img {
    width: 100%; height: 100%; object-fit: cover;
    transition: transform .8s;
}
.spot-hero__media:hover img { transform: scale(1.04); }

/* Editorial intro */
.spot-editorial {
    max-width: 680px;
    margin: 0 auto;
    padding: 0 0 5rem;
    border-bottom: 1px solid var(--line-soft);
}
.spot-editorial p {
    font-size: .98rem;
    line-height: 2.05;
    letter-spacing: .05em;
    margin: 0 0 1.5em;
    color: var(--text);
}
.spot-editorial p:first-child::first-letter {
    font-family: var(--serif);
    font-size: 3rem;
    line-height: 1;
    float: left;
    margin: .15em .25em 0 0;
    color: var(--accent);
    font-style: italic;
}
.spot-editorial p:last-child { margin-bottom: 0; }

/* 3 colors */
.spot-colors { padding: 5rem 0; border-bottom: 1px solid var(--line-soft); }
.spot-colors__header { text-align: center; margin-bottom: 3rem; }
.spot-colors__title {
    font-family: var(--serif-jp);
    font-size: clamp(1.5rem, 3vw, 1.9rem);
    font-weight: 500;
    letter-spacing: .14em;
    margin: 0;
}
.spot-colors__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.8rem;
}
.color-card { display: flex; flex-direction: column; }
.color-card__media {
    aspect-ratio: 1 / 1;
    overflow: hidden;
    border-radius: var(--radius);
    background: var(--bg-deep);
    margin-bottom: 1.2rem;
}
.color-card__media img {
    width: 100%; height: 100%; object-fit: cover;
    transition: transform .6s;
}
.color-card__media:hover img { transform: scale(1.04); }
.color-card__kicker {
    font-size: .7rem;
    letter-spacing: .35em;
    color: var(--accent);
    text-transform: uppercase;
    margin: 0 0 .6rem;
}
.color-card__name {
    font-family: var(--serif-jp);
    font-size: 1.15rem;
    font-weight: 500;
    letter-spacing: .08em;
    margin: 0 0 .8rem;
    padding-bottom: .8rem;
    border-bottom: 1px solid var(--line-soft);
}
.color-card__mood {
    color: var(--text);
    font-size: .88rem;
    line-height: 1.85;
    letter-spacing: .03em;
    margin: 0 0 .8em;
}
.color-card__scene {
    color: var(--text-mute);
    font-size: .82rem;
    line-height: 1.8;
    letter-spacing: .02em;
    margin: 0 0 1rem;
}

/* Words x Scenes */
.spot-words { padding: 5rem 0; border-bottom: 1px solid var(--line-soft); }
.spot-words__header { text-align: center; margin-bottom: 3rem; }
.spot-words__title {
    font-family: var(--serif-jp);
    font-size: clamp(1.5rem, 3vw, 1.9rem);
    font-weight: 500;
    letter-spacing: .14em;
    margin: 0;
}
.spot-words__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
    max-width: 920px;
    margin: 0 auto;
}
.word-scene {
    position: relative;
    padding: 1.8rem 1.6rem 1.6rem;
    border: 1px solid var(--line-soft);
    border-radius: var(--radius);
    background: var(--bg-soft);
}
.word-scene__num {
    position: absolute;
    top: 1rem; right: 1.2rem;
    font-family: var(--serif);
    font-style: italic;
    color: var(--accent);
    font-size: .85rem;
    letter-spacing: .15em;
}
.word-scene__word {
    font-family: var(--serif-jp);
    font-size: 1.3rem;
    font-weight: 500;
    letter-spacing: .12em;
    margin: 0 0 .8rem;
    padding-bottom: .8rem;
    border-bottom: 1px solid var(--line);
    color: var(--accent-deep);
}
.word-scene__scene {
    color: var(--text);
    font-size: .85rem;
    line-height: 1.85;
    letter-spacing: .03em;
    margin: 0;
}

/* Gift scenes */
.spot-gift { padding: 5rem 0; border-bottom: 1px solid var(--line-soft); }
.spot-gift__header { text-align: center; margin-bottom: 3rem; }
.spot-gift__title {
    font-family: var(--serif-jp);
    font-size: clamp(1.5rem, 3vw, 1.9rem);
    font-weight: 500;
    letter-spacing: .14em;
    margin: 0;
}
.spot-gift__list {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.8rem;
    max-width: 920px;
    margin: 0 auto;
}
.gift-scene {
    padding: 2rem 1.8rem;
    border: 1px solid var(--line-soft);
    border-radius: var(--radius);
    background: var(--bg);
}
.gift-scene__title {
    font-family: var(--serif-jp);
    font-size: 1.05rem;
    font-weight: 500;
    letter-spacing: .08em;
    margin: 0 0 1rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid var(--line-soft);
}
.gift-scene__body {
    color: var(--text-mute);
    font-size: .88rem;
    line-height: 1.95;
    letter-spacing: .03em;
    margin: 0;
}

/* Shop */
.spot-shop { padding: 5rem 0; border-bottom: 1px solid var(--line-soft); }
.spot-shop__header { text-align: center; margin-bottom: 3rem; }
.spot-shop__title {
    font-family: var(--serif-jp);
    font-size: clamp(1.5rem, 3vw, 1.9rem);
    font-weight: 500;
    letter-spacing: .14em;
    margin: 0 0 1rem;
}
.spot-shop__lead {
    color: var(--text-mute);
    font-size: .9rem;
    line-height: 1.9;
    letter-spacing: .04em;
    margin: 0 auto;
    max-width: 540px;
}
.spot-shop__more { text-align: center; margin-top: 3rem; }

/* Related / FAQ */
.spot-related { padding: 4rem 0; border-bottom: 1px solid var(--line-soft); }
.spot-related__cols {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 2rem;
    max-width: 600px;
    margin: 1.5rem auto 0;
}
.spot-related__cols ul { list-style: none; padding: 0; margin: .5rem 0 0; }
.spot-related__cols li { border-bottom: 1px solid var(--line-soft); }
.spot-related__cols a { display: block; padding: .75rem 0; font-size: .9rem; }
.spot-related__cols a:hover { color: var(--accent-deep); }

.spot-faq { padding: 4rem 0 6rem; }
.spot-faq .charm-faq__list { max-width: 640px; margin: 1rem auto 0; }

/* Products grid */
.products-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 2rem 1.4rem;
}
.products-grid .product-card { display: block; color: var(--text); }
.products-grid .product-card__img {
    aspect-ratio: 1 / 1;
    overflow: hidden;
    border-radius: var(--radius);
    background: var(--bg-deep);
    margin-bottom: .9rem;
}
.products-grid .product-card__img img {
    width: 100%; height: 100%; object-fit: cover;
    transition: transform .6s;
}
.products-grid .product-card:hover .product-card__img img { transform: scale(1.04); }
.products-grid .product-card__title {
    font-family: var(--sans);
    font-size: .82rem;
    line-height: 1.55;
    letter-spacing: .02em;
    margin: 0 0 .3em;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.products-grid .product-card__price {
    font-family: var(--serif);
    font-size: .92rem;
    color: var(--text-mute);
    margin: 0;
}

@media (max-width: 880px) {
    .spot-hero { grid-template-columns: 1fr; gap: 2rem; padding: 2rem 0 3rem; }
    .spot-hero__media { aspect-ratio: 1 / 1; max-width: 480px; margin: 0 auto; }
    .spot-colors__grid { grid-template-columns: 1fr; gap: 2.4rem; max-width: 480px; margin: 0 auto; }
    .spot-words__grid { grid-template-columns: 1fr 1fr; gap: 1rem; }
    .spot-gift__list { grid-template-columns: 1fr; gap: 1.2rem; }
    .products-grid { grid-template-columns: repeat(2, 1fr); }
    .spot-related__cols { grid-template-columns: 1fr; }
}
@media (max-width: 600px) {
    .spot-hero__title { letter-spacing: .14em; }
    .spot-editorial { padding: 0 0 3.5rem; }
    .spot-editorial p { font-size: .92rem; line-height: 1.95; }
    .spot-editorial p:first-child::first-letter { font-size: 2.4rem; }
    .spot-colors, .spot-words, .spot-gift, .spot-shop, .spot-related, .spot-faq { padding: 3.5rem 0; }
    .spot-words__grid { grid-template-columns: 1fr; }
    .word-scene { padding: 1.4rem 1.4rem 1.3rem; }
    .word-scene__word { font-size: 1.15rem; }
    .gift-scene { padding: 1.6rem 1.4rem; }
}

/* Home featured stone (re-uses calendar-banner styling) */
.home-explore__featured { margin-top: 1rem; }

/* ======================================
   ERROR PAGES (404 / 410)
   ====================================== */
.error-page {
    max-width: var(--container);
    margin: 0 auto;
    padding: 4rem 1.6rem 6rem;
}
.error-page__inner {
    max-width: 760px;
    margin: 0 auto;
    text-align: center;
}
.error-page__code {
    font-family: var(--serif);
    font-style: italic;
    font-size: clamp(4rem, 12vw, 6.5rem);
    color: var(--accent);
    letter-spacing: .05em;
    margin: 0 0 1.4rem;
    line-height: 1;
}
.error-page__title {
    font-family: var(--serif-jp);
    font-size: clamp(1.5rem, 4vw, 2rem);
    font-weight: 500;
    letter-spacing: .14em;
    line-height: 1.5;
    margin: 0 0 1.6rem;
}
.error-page__lead {
    color: var(--text-mute);
    font-size: .96rem;
    line-height: 2.0;
    letter-spacing: .04em;
    margin: 0 auto 3rem;
    max-width: 560px;
}
.error-page__cards {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1rem;
    text-align: left;
    margin-top: 2.5rem;
}
.error-card {
    display: block;
    padding: 1.8rem 1.6rem;
    border: 1px solid var(--line-soft);
    border-radius: var(--radius);
    background: var(--bg);
    color: var(--text);
    transition: all .25s ease;
}
.error-card:hover {
    border-color: var(--line-strong);
    transform: translateY(-2px);
    box-shadow: var(--shadow-card);
    color: var(--text);
}
.error-card__kicker {
    font-size: .65rem;
    letter-spacing: .3em;
    color: var(--accent);
    text-transform: uppercase;
    margin: 0 0 .7rem;
}
.error-card__title {
    font-family: var(--serif-jp);
    font-size: 1.05rem;
    font-weight: 500;
    letter-spacing: .08em;
    margin: 0 0 .7rem;
    padding-bottom: .7rem;
    border-bottom: 1px solid var(--line-soft);
}
.error-card__lead {
    color: var(--text-mute);
    font-size: .82rem;
    line-height: 1.8;
    letter-spacing: .03em;
    margin: 0;
}

@media (max-width: 600px) {
    .error-page { padding: 2.5rem 1.2rem 4rem; }
    .error-page__lead { font-size: .9rem; line-height: 1.95; margin-bottom: 2.5rem; }
    .error-page__cards { grid-template-columns: 1fr; gap: .8rem; }
    .error-card { padding: 1.4rem 1.4rem; }
}

/* ======================================
   DESTINY · 365 日守護石
   ====================================== */
.destiny, .destiny-index {
    max-width: var(--container);
    margin: 0 auto;
    padding: 0 1.6rem;
}
.destiny-hero, .destiny-index__hero {
    text-align: center;
    padding: 3rem 0 2rem;
    max-width: 760px;
    margin: 0 auto;
}
.destiny-hero__title, .destiny-index__title {
    font-family: var(--serif-jp);
    font-size: clamp(1.8rem, 4.4vw, 2.4rem);
    font-weight: 500;
    letter-spacing: .14em;
    margin: 0 0 1.4rem;
    line-height: 1.5;
}
.destiny-hero__stone {
    font-family: var(--serif-jp);
    font-size: clamp(1.4rem, 3.4vw, 1.8rem);
    letter-spacing: .1em;
    color: var(--accent-deep);
    margin: 0 0 1.6rem;
}
.destiny-hero__stone-wamei {
    color: var(--text-mute);
    font-size: .8em;
    letter-spacing: .08em;
}
.destiny-hero__lead {
    color: var(--text);
    font-size: .96rem;
    line-height: 2.0;
    letter-spacing: .04em;
    margin: 0 0 1rem;
}
.destiny-hero__note {
    color: var(--text-soft);
    font-size: .78rem;
    margin: 0;
}

.destiny-primary {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 3rem;
    align-items: center;
    padding: 3rem 0 4rem;
    border-top: 1px solid var(--line-soft);
    border-bottom: 1px solid var(--line-soft);
    max-width: 920px;
    margin: 0 auto;
}
.destiny-primary__media {
    aspect-ratio: 4 / 5;
    overflow: hidden;
    border-radius: var(--radius);
    background: var(--bg-deep);
}
.destiny-primary__media img {
    width: 100%; height: 100%; object-fit: cover;
}
.destiny-primary__placeholder {
    width: 100%; height: 100%;
    background: linear-gradient(135deg, var(--bg-deep), var(--bg-soft));
}
.destiny-primary__name {
    font-family: var(--serif-jp);
    font-size: clamp(1.8rem, 4vw, 2.4rem);
    letter-spacing: .12em;
    margin: 0 0 1rem;
    line-height: 1.3;
}
.destiny-primary__short {
    color: var(--text);
    font-size: .96rem;
    line-height: 2.0;
    letter-spacing: .04em;
    margin: 0 0 1.4rem;
}
.destiny-primary__reason {
    color: var(--text-mute);
    font-size: .9rem;
    line-height: 1.9;
    letter-spacing: .03em;
    margin: 0 0 1.8rem;
    padding-left: 1rem;
    border-left: 3px solid var(--accent);
}
.destiny-primary__reason small {
    color: var(--text-soft);
    font-size: .8rem;
}

.destiny-sub {
    padding: 4rem 0;
    max-width: 920px;
    margin: 0 auto;
}
.destiny-sub__list {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 2rem;
    margin-top: 2rem;
}
.destiny-sub__item {
    display: flex;
    flex-direction: column;
}
.destiny-sub__media {
    aspect-ratio: 1 / 1;
    overflow: hidden;
    border-radius: var(--radius);
    background: var(--bg-deep);
    margin-bottom: 1.2rem;
}
.destiny-sub__media img {
    width: 100%; height: 100%; object-fit: cover;
}
.destiny-sub__name {
    font-family: var(--serif-jp);
    font-size: 1.3rem;
    font-weight: 500;
    letter-spacing: .1em;
    margin: 0 0 .3em;
}
.destiny-sub__wamei {
    color: var(--text-mute);
    font-size: .82rem;
    letter-spacing: .08em;
    margin: 0 0 .8rem;
    padding-bottom: .8rem;
    border-bottom: 1px solid var(--line-soft);
}
.destiny-sub__short {
    color: var(--text-mute);
    font-size: .88rem;
    line-height: 1.95;
    margin: 0 0 1rem;
}

.destiny-context {
    padding: 4rem 0;
    border-top: 1px solid var(--line-soft);
}
.destiny-context__grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1.6rem;
    max-width: 920px;
    margin: 2rem auto 0;
}
.context-card {
    padding: 1.8rem 1.6rem;
    border: 1px solid var(--line-soft);
    border-radius: var(--radius);
    background: var(--bg-soft);
}
.context-card__kicker {
    font-size: .66rem;
    letter-spacing: .3em;
    color: var(--accent);
    text-transform: uppercase;
    margin: 0 0 .8rem;
}
.context-card__title {
    font-family: var(--serif-jp);
    font-size: 1.15rem;
    font-weight: 500;
    letter-spacing: .08em;
    margin: 0 0 1rem;
    padding-bottom: .8rem;
    border-bottom: 1px solid var(--line);
}
.context-card__body {
    color: var(--text);
    font-size: .9rem;
    line-height: 1.95;
    letter-spacing: .03em;
    margin: 0;
}
.context-card__link {
    margin: 1rem 0 0;
    font-size: .82rem;
    letter-spacing: .04em;
}
.context-card__link a {
    color: var(--accent-deep);
    border-bottom: 1px solid var(--line);
    padding-bottom: .2rem;
}
.context-card__link a:hover { color: var(--text); border-color: var(--accent); }

.destiny-related {
    padding: 4rem 0;
    border-top: 1px solid var(--line-soft);
}
.destiny-related__nav {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    max-width: 760px;
    margin: 0 auto 2.5rem;
    padding: 1rem 0;
    font-size: .88rem;
}
.destiny-related__nav a {
    color: var(--text-mute);
    padding: .5rem 0;
}
.destiny-related__nav a:hover { color: var(--text); }
.destiny-related__index {
    font-family: var(--serif-jp);
    font-weight: 500;
    letter-spacing: .08em;
    color: var(--text) !important;
}
.destiny-related__cols {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 2.4rem;
    max-width: 720px;
    margin: 0 auto;
}
.destiny-related__cols ul { list-style: none; padding: 0; margin: .5rem 0 0; }
.destiny-related__cols li { border-bottom: 1px solid var(--line-soft); }
.destiny-related__cols a { display: block; padding: .75rem 0; font-size: .9rem; color: var(--text); }
.destiny-related__cols a:hover { color: var(--accent-deep); }

.destiny-index__months {
    padding: 3rem 0 5rem;
    max-width: var(--container-narrow);
    margin: 0 auto;
}
.destiny-index__grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1.5rem;
    margin-top: 2rem;
}
.month-card {
    display: block;
    padding: 1.6rem 1.4rem 1.4rem;
    border: 1px solid var(--line-soft);
    border-radius: var(--radius);
    background: var(--bg);
    color: var(--text);
    text-align: center;
    transition: all .25s ease;
}
.month-card:hover {
    border-color: var(--line-strong);
    transform: translateY(-2px);
    box-shadow: var(--shadow-card);
    color: var(--text);
}
.month-card__num {
    font-family: var(--serif);
    font-style: italic;
    font-size: 1.4rem;
    color: var(--accent);
    letter-spacing: .1em;
    margin: 0 0 .4rem;
}
.month-card__name {
    font-family: var(--serif-jp);
    font-size: 1.05rem;
    font-weight: 500;
    letter-spacing: .08em;
    margin: 0 0 .6rem;
}
.month-card__stone {
    color: var(--text);
    font-size: .82rem;
    margin: 0 0 .3rem;
}
.month-card__zodiac {
    color: var(--text-soft);
    font-size: .72rem;
    letter-spacing: .06em;
    margin: 0;
}
.destiny-index__note {
    margin-top: 2.5rem;
    color: var(--text-soft);
    font-size: .78rem;
    text-align: center;
}
.destiny-index__note code {
    font-family: monospace;
    background: var(--bg-soft);
    padding: .15rem .4rem;
    border-radius: 2px;
}

@media (max-width: 880px) {
    .destiny-primary { grid-template-columns: 1fr; gap: 2rem; padding: 2rem 0 3rem; }
    .destiny-primary__media { max-width: 420px; margin: 0 auto; aspect-ratio: 4 / 4; }
    .destiny-context__grid { grid-template-columns: 1fr; gap: 1.2rem; }
    .destiny-index__grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 600px) {
    .destiny, .destiny-index { padding: 0 1.2rem; }
    .destiny-hero, .destiny-index__hero { padding: 2rem 0 1.5rem; }
    .destiny-primary { padding: 2rem 0 2.5rem; }
    .destiny-primary__name { font-size: 1.5rem; }
    .destiny-sub { padding: 2.5rem 0; }
    .destiny-sub__list { grid-template-columns: 1fr; gap: 2rem; }
    .destiny-sub__media { aspect-ratio: 4 / 3; max-width: 320px; margin-left: auto; margin-right: auto; }
    .destiny-context { padding: 2.5rem 0; }
    .destiny-related { padding: 2.5rem 0; }
    .destiny-related__nav { flex-direction: column; gap: .4rem; }
    .destiny-related__cols { grid-template-columns: 1fr; gap: 1.6rem; }
    .destiny-index__grid { grid-template-columns: repeat(2, 1fr); gap: 1rem; }
    .month-card { padding: 1.2rem 1rem; }
    .month-card__num { font-size: 1.2rem; }
}
@media (max-width: 380px) {
    .destiny-index__grid { grid-template-columns: 1fr; }
}

/* ======================================
   ZODIAC 12 LP
   ====================================== */
.zodiac, .zodiacs-index {
    max-width: var(--container);
    margin: 0 auto;
    padding: 0 1.6rem;
}
.zodiacs-index__hero {
    text-align: center;
    padding: 3rem 0 2rem;
    max-width: 760px;
    margin: 0 auto;
}
.zodiacs-index__title {
    font-family: var(--serif-jp);
    font-size: clamp(1.8rem, 4.4vw, 2.4rem);
    font-weight: 500;
    letter-spacing: .14em;
    margin: 0 0 1.4rem;
}
.zodiacs-index__lead {
    color: var(--text-mute);
    font-size: .96rem;
    line-height: 2.0;
    letter-spacing: .04em;
    margin: 0;
}
.zodiacs-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1.5rem;
    padding: 2rem 0 4rem;
}
.zodiac-card {
    display: block;
    padding: 1.8rem 1.4rem 1.6rem;
    border: 1px solid var(--line-soft);
    border-radius: var(--radius);
    background: var(--bg);
    color: var(--text);
    text-align: center;
    transition: all .25s ease;
}
.zodiac-card:hover {
    border-color: var(--line-strong);
    transform: translateY(-2px);
    box-shadow: var(--shadow-card);
    color: var(--text);
}
.zodiac-card__symbol {
    font-size: 1.8rem;
    color: var(--accent);
    line-height: 1;
    margin: 0 0 .8rem;
}
.zodiac-card__name {
    font-family: var(--serif-jp);
    font-size: 1.15rem;
    font-weight: 500;
    letter-spacing: .1em;
    margin: 0 0 .5rem;
}
.zodiac-card__range {
    color: var(--text-mute);
    font-size: .76rem;
    letter-spacing: .04em;
    margin: 0 0 .8rem;
    padding-bottom: .8rem;
    border-bottom: 1px solid var(--line-soft);
}
.zodiac-card__element {
    color: var(--text-soft);
    font-size: .72rem;
    letter-spacing: .12em;
    margin: 0 0 .4rem;
}
.zodiac-card__stone {
    color: var(--text);
    font-size: .9rem;
    font-family: var(--serif-jp);
    margin: 0 0 .3rem;
}
.zodiac-card__theme {
    color: var(--text-mute);
    font-size: .76rem;
    margin: 0;
}

/* ZODIAC SHOW */
.zodiac-hero {
    text-align: center;
    padding: 3rem 0 2rem;
    max-width: 760px;
    margin: 0 auto;
}
.zodiac-hero__symbol {
    font-size: clamp(3rem, 8vw, 4.5rem);
    color: var(--accent);
    line-height: 1;
    margin: 0 0 1rem;
}
.zodiac-hero__title {
    font-family: var(--serif-jp);
    font-size: clamp(1.8rem, 4.4vw, 2.4rem);
    font-weight: 500;
    letter-spacing: .14em;
    margin: 0 0 1rem;
}
.zodiac-hero__range {
    color: var(--text);
    font-size: 1rem;
    margin: 0 0 .5rem;
    letter-spacing: .06em;
}
.zodiac-hero__meta {
    color: var(--text-mute);
    font-size: .82rem;
    letter-spacing: .08em;
    margin: 0 0 1rem;
}
.zodiac-hero__theme {
    color: var(--accent-deep);
    font-family: var(--serif-jp);
    font-size: 1.1rem;
    letter-spacing: .1em;
    margin: 0;
}

.zodiac-intro {
    max-width: 720px;
    margin: 0 auto;
    padding: 1.5rem 0 4rem;
}
.zodiac-intro p {
    color: var(--text);
    font-size: .96rem;
    line-height: 2.0;
    letter-spacing: .04em;
    margin: 0 0 1.3em;
}
.zodiac-intro p:last-child { margin-bottom: 0; }

.zodiac-keywords {
    padding: 3rem 0 4rem;
    border-top: 1px solid var(--line-soft);
    text-align: center;
}
.zodiac-keywords__list {
    list-style: none;
    padding: 0;
    margin: 1.5rem 0 0;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: .6rem .8rem;
}
.zodiac-keywords__list li {
    padding: .45rem 1.1rem;
    border: 1px solid var(--line);
    border-radius: 999px;
    font-size: .82rem;
    letter-spacing: .08em;
    color: var(--text);
    background: var(--bg-soft);
}

.zodiacs-cross {
    padding: 3.5rem 1.4rem;
    background: var(--bg-soft);
    border-top: 1px solid var(--line-soft);
    border-bottom: 1px solid var(--line-soft);
    text-align: center;
    margin: 0 -1.6rem;
}
.zodiacs-cross__title {
    font-family: var(--serif-jp);
    font-size: clamp(1.3rem, 3vw, 1.7rem);
    font-weight: 500;
    letter-spacing: .12em;
    margin: 0 0 1rem;
}
.zodiacs-cross__lead {
    color: var(--text-mute);
    font-size: .9rem;
    line-height: 1.95;
    letter-spacing: .04em;
    margin: 0 auto 1.6rem;
    max-width: 560px;
}

@media (max-width: 880px) {
    .zodiacs-grid { grid-template-columns: repeat(3, 1fr); gap: 1rem; }
}
@media (max-width: 600px) {
    .zodiac, .zodiacs-index { padding: 0 1.2rem; }
    .zodiacs-grid { grid-template-columns: repeat(2, 1fr); gap: .9rem; padding: 1.5rem 0 3rem; }
    .zodiac-card { padding: 1.4rem 1rem; }
    .zodiac-card__symbol { font-size: 1.4rem; }
    .zodiac-hero__symbol { font-size: 3rem; }
    .zodiac-intro { padding: 1rem 0 3rem; }
    .zodiac-keywords { padding: 2.5rem 0 3rem; }
    .zodiacs-cross { padding: 2.5rem 1rem; margin: 0 -1.2rem; }
}
@media (max-width: 380px) {
    .zodiacs-grid { grid-template-columns: 1fr; }
}

/* ======================================
   DESTINY HUB
   ====================================== */
.destiny-hub {
    max-width: var(--container);
    margin: 0 auto;
    padding: 0 1.6rem;
}
.destiny-hub__hero {
    text-align: center;
    padding: 3rem 0 2.5rem;
    max-width: 760px;
    margin: 0 auto;
}
.destiny-hub__title {
    font-family: var(--serif-jp);
    font-size: clamp(2rem, 5vw, 2.6rem);
    font-weight: 500;
    letter-spacing: .2em;
    margin: 0 0 1.4rem;
}
.destiny-hub__lead {
    color: var(--text-mute);
    font-size: .96rem;
    line-height: 2.0;
    letter-spacing: .04em;
    margin: 0;
}
.destiny-hub__grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1.5rem;
    max-width: 920px;
    margin: 1.5rem auto 5rem;
}
.hub-card {
    display: block;
    padding: 2.4rem 2rem;
    border: 1px solid var(--line-soft);
    border-radius: var(--radius);
    background: var(--bg);
    color: var(--text);
    transition: all .25s ease;
}
.hub-card:hover {
    border-color: var(--line-strong);
    transform: translateY(-3px);
    box-shadow: var(--shadow-card-hover);
    color: var(--text);
}
.hub-card__kicker {
    font-size: .65rem;
    letter-spacing: .3em;
    color: var(--accent);
    text-transform: uppercase;
    margin: 0 0 1rem;
}
.hub-card__title {
    font-family: var(--serif-jp);
    font-size: 1.4rem;
    font-weight: 500;
    letter-spacing: .12em;
    margin: 0 0 1rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid var(--line-soft);
}
.hub-card__lead {
    color: var(--text-mute);
    font-size: .88rem;
    line-height: 1.95;
    letter-spacing: .03em;
    margin: 0 0 1.4rem;
}
.hub-card__link {
    display: inline-flex; align-items: center; gap: .45rem;
    font-size: .82rem;
    letter-spacing: .1em;
    color: var(--text);
    border-bottom: 1px solid var(--line-strong);
    padding-bottom: .25rem;
    transition: gap .2s, color .2s;
}
.hub-card:hover .hub-card__link { gap: .75rem; color: var(--accent-deep); }
.hub-card__link span { font-family: var(--serif); }

@media (max-width: 600px) {
    .destiny-hub__grid { grid-template-columns: 1fr; gap: 1rem; }
    .hub-card { padding: 1.8rem 1.6rem; }
    .hub-card__title { font-size: 1.2rem; }
}

/* ======================================
   FEATURED ITEMS (404/410 用商品グリッド)
   ====================================== */
.featured-items {
    margin-top: 4rem;
    padding-top: 3rem;
    border-top: 1px solid var(--line-soft);
}
.featured-items__title {
    font-family: var(--serif-jp);
    font-size: clamp(1.2rem, 2.6vw, 1.5rem);
    font-weight: 500;
    letter-spacing: .12em;
    text-align: center;
    margin: 0 0 2rem;
}
.featured-items__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 2rem 1.4rem;
    max-width: 920px;
    margin: 0 auto;
}
.featured-items__card {
    display: block;
    color: var(--text);
}
.featured-items__img {
    aspect-ratio: 1 / 1;
    overflow: hidden;
    border-radius: var(--radius);
    background: var(--bg-deep);
    margin-bottom: .8rem;
}
.featured-items__img img {
    width: 100%; height: 100%;
    object-fit: cover;
    transition: transform .6s;
}
.featured-items__card:hover .featured-items__img img { transform: scale(1.04); }
.featured-items__name {
    font-size: .82rem;
    line-height: 1.55;
    margin: 0 0 .3em;
    color: var(--text);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.featured-items__price {
    font-family: var(--serif);
    font-size: .9rem;
    color: var(--text-mute);
    margin: 0;
}
@media (max-width: 600px) {
    .featured-items__grid { grid-template-columns: repeat(2, 1fr); gap: 1.4rem 1rem; }
}
