/* =========================================================================
   IKIGAI — module-specific styles
   ========================================================================= */

/* -------------------------------------------------------------------------
   Cinematic layer — calligraphy, mountains, chapter markers, ink trail
   ------------------------------------------------------------------------- */

/* — Sumi-e mountain backdrop — */
.sumi-mountains {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    z-index: 0;
    pointer-events: none;
    opacity: 0;
    animation: sumiFade 2.4s 0.4s cubic-bezier(.2,.8,.2,1) forwards;
}
.mtn-far  { transform: translateY(8px); animation: mtnDriftFar 28s ease-in-out infinite alternate; }
.mtn-mid  { transform: translateY(6px); animation: mtnDriftMid 22s ease-in-out infinite alternate; }
.mtn-near { transform: translateY(4px); animation: mtnDriftNear 18s ease-in-out infinite alternate; }
@keyframes sumiFade { to { opacity: 1; } }
@keyframes mtnDriftFar  { to { transform: translateY(2px) translateX(-6px); } }
@keyframes mtnDriftMid  { to { transform: translateY(0)   translateX(8px);  } }
@keyframes mtnDriftNear { to { transform: translateY(-2px) translateX(-4px);} }

.hero-sun {
    transform-origin: 1180px 200px;
    animation: sunBreathe 7s ease-in-out infinite alternate;
}
@keyframes sunBreathe { to { opacity: 0.75; transform: scale(1.04); } }

.hero-bird { animation: birdGlide 32s linear infinite; }
@keyframes birdGlide {
    0%   { transform: translate(360px, 220px) scale(1); opacity: 0; }
    10%  { opacity: 1; }
    90%  { opacity: 0.7; }
    100% { transform: translate(1100px, 80px)  scale(0.55); opacity: 0; }
}

/* — Animated calligraphy 生き甲斐 (paint-in left to right) — */
.calligraphy {
    font-family: 'Noto Serif JP', 'Shippori Mincho', serif;
    font-weight: 700;
    font-size: clamp(3.6rem, 9vw, 7rem);
    line-height: 1;
    color: var(--c-ink);
    margin: 0 0 var(--s-5);
    display: inline-flex;
    gap: 0.18em;
    position: relative;
    z-index: 2;
}
.cal-char {
    display: inline-block;
    background-image:
        linear-gradient(90deg, var(--c-ink) 0 50%, transparent 50% 100%);
    background-size: 200% 100%;
    background-position: 100% 0;
    -webkit-background-clip: text;
            background-clip: text;
    color: transparent;
    -webkit-text-fill-color: transparent;
    opacity: 0;
    transform: translateY(20px);
    filter: blur(3px);
    animation: calPaint 1.4s var(--d, 0s) cubic-bezier(.2,.8,.2,1) forwards;
    text-shadow: 0 1px 0 rgba(0,0,0,0.04);
}
@keyframes calPaint {
    0%   { opacity: 0; transform: translateY(20px); filter: blur(4px); background-position: 100% 0; }
    25%  { opacity: 1; filter: blur(2.5px); }
    100% { opacity: 1; transform: translateY(0); filter: blur(0); background-position: 0% 0; }
}
[data-theme="dark"] .cal-char {
    background-image: linear-gradient(90deg, var(--c-ink) 0 50%, transparent 50% 100%);
}
@media (prefers-reduced-motion: reduce) {
    .cal-char { opacity: 1; transform: none; filter: none; background-position: 0% 0; animation: none; -webkit-text-fill-color: var(--c-ink); }
}

/* — Cursor ink trail canvas — */
.ink-trail {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
    z-index: 1;
    mix-blend-mode: multiply;
    opacity: 0.55;
}
[data-theme="dark"] .ink-trail { mix-blend-mode: screen; opacity: 0.4; }

/* — Hero rotating elder quote — */
.hero-quote-wrap { margin: var(--s-5) 0 var(--s-6); max-width: 540px; }
.hero-quote {
    border-left: 2px solid var(--c-gold);
    padding: var(--s-2) var(--s-4);
    margin: 0;
    transition: opacity 0.6s ease;
}
.hero-quote.is-fading { opacity: 0; }
.hq-text {
    font-family: var(--f-serif);
    font-style: italic;
    font-size: 1.1rem;
    line-height: 1.4;
    color: var(--c-ink-soft);
    margin: 0 0 var(--s-2);
}
.hq-cite { color: var(--c-mute); font-size: 0.85rem; }

/* — Chapter markers — fixed-position kanji that fade in per section — */
.chapter-marker {
    position: fixed;
    top: 50%;
    right: max(1.2rem, calc((100vw - var(--content-width)) / 2 - 60px));
    transform: translateY(-50%);
    z-index: 30;
    pointer-events: none;
    text-align: center;
    opacity: 0;
    transition: opacity 0.6s ease, transform 0.6s ease;
    color: var(--c-gold);
    font-family: var(--f-jp);
    user-select: none;
    mix-blend-mode: multiply;
}
[data-theme="dark"] .chapter-marker { mix-blend-mode: normal; }
.chapter-marker.is-visible {
    opacity: 0.8;
    transform: translateY(-50%) translateX(0);
}
.chapter-kanji {
    display: block;
    font-size: 4.5rem;
    line-height: 1;
    font-weight: 500;
    text-shadow: 0 1px 0 rgba(0,0,0,0.06);
}
.chapter-name {
    display: block;
    font-family: var(--f-sans);
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.18em;
    color: var(--c-mute);
    margin-top: var(--s-2);
    max-width: 14ch;
    margin-left: auto;
    margin-right: auto;
    line-height: 1.3;
}
@media (max-width: 1100px) {
    .chapter-marker { right: 1rem; }
    .chapter-kanji { font-size: 3rem; }
    .chapter-name { font-size: 0.6rem; max-width: 10ch; }
}
@media (max-width: 720px) { .chapter-marker { display: none; } }

/* — "Take a breath" ritual overlay before discovery — */
.breath-overlay {
    position: fixed;
    inset: 0;
    background: radial-gradient(ellipse at center, rgba(253,251,246,0.96), rgba(253,251,246,0.99));
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    z-index: 80;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.7s ease;
}
[data-theme="dark"] .breath-overlay {
    background: radial-gradient(ellipse at center, rgba(15,15,20,0.96), rgba(15,15,20,0.99));
}
.breath-overlay.is-active {
    opacity: 1;
    pointer-events: auto;
}
.breath-circle {
    width: 180px;
    height: 180px;
    border: 1.5px solid var(--c-gold);
    border-radius: 50%;
    margin-bottom: var(--s-6);
    animation: breathe 7s ease-in-out infinite;
    background: radial-gradient(circle, rgba(184,134,11,0.05), transparent 70%);
}
@keyframes breathe {
    0%, 100% { transform: scale(0.7); opacity: 0.8; }
    50%      { transform: scale(1.0); opacity: 1; }
}
.breath-text {
    font-family: var(--f-serif);
    font-style: italic;
    font-size: clamp(1.4rem, 3vw, 2.2rem);
    color: var(--c-ink);
    margin: 0 0 var(--s-5);
    max-width: 600px;
    padding: 0 var(--s-5);
}
.breath-skip {
    background: transparent;
    border: 1px solid var(--c-line);
    color: var(--c-mute);
    padding: 0.5rem 1.2rem;
    border-radius: var(--r-pill);
    font-family: var(--f-sans);
    cursor: pointer;
    font-size: 0.85rem;
    transition: all var(--t-fast);
}
.breath-skip:hover { border-color: var(--c-gold); color: var(--c-gold); }

/* — HHB animated bowl — */
.hhb-bowl {
    text-align: center;
    margin-bottom: var(--s-4);
    padding-bottom: var(--s-3);
    border-bottom: 1px dashed var(--c-line);
}
.bowl-svg {
    width: 100%;
    max-width: 150px;
    max-height: 110px;
    height: auto;
    overflow: visible;
}
.bowl-fill {
    transform-origin: bottom;
    transform: translateY(120px);
    transition: transform 1.4s cubic-bezier(.2,.8,.2,1);
}
.bowl-fill.is-filled { transform: translateY(20px); } /* 80% line */
.bowl-fill.is-overfull { transform: translateY(8px); }
.bowl-steam path {
    transform-origin: center bottom;
    animation: steamRise 4s ease-in-out infinite;
}
.bowl-steam path:nth-child(1) { animation-delay: 0s; }
.bowl-steam path:nth-child(2) { animation-delay: 0.6s; }
.bowl-steam path:nth-child(3) { animation-delay: 1.2s; }
@keyframes steamRise {
    0%, 100% { opacity: 0.15; transform: translateY(0)   scaleY(0.9); }
    50%      { opacity: 0.5;  transform: translateY(-6px) scaleY(1.1); }
}
.hhb-bowl-cap {
    margin: var(--s-4) 0 0;
    font-family: var(--f-serif);
    font-size: 1rem;
    color: var(--c-ink);
}
.hhb-bowl-cap span {
    font-weight: 600;
    color: var(--c-gold);
    font-size: 1.4rem;
    margin-right: 0.2em;
}
.hhb-bowl-cap em { color: var(--c-mute); font-style: italic; }

/* — 30-Day stepping-stone path — */
.path-stage {
    position: relative;
    width: 100%;
    height: 600px;
    margin: var(--s-5) 0 var(--s-7);
}
@media (max-width: 720px) { .path-stage { height: 760px; } }
.path-river {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
}
.path-line {
    stroke-dasharray: 2 6;
    animation: pathFlow 60s linear infinite;
}
@keyframes pathFlow { to { stroke-dashoffset: -240; } }

.path-stones {
    position: absolute;
    inset: 0;
}
.stone {
    position: absolute;
    width: 64px;
    height: 64px;
    transform: translate(-50%, -50%) rotate(var(--r, 0deg));
    background: var(--c-paper);
    border: 1px solid var(--c-line);
    border-radius: 56% 44% 50% 50% / 50% 56% 44% 50%;
    box-shadow: var(--shadow-sm);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    color: var(--c-ink);
    text-align: center;
    transition: transform var(--t-mid), box-shadow var(--t-mid), border-color var(--t-mid), background-color var(--t-mid);
    border-bottom: 1px solid var(--c-line) !important;
    opacity: 0;
    animation: stoneRise 0.7s cubic-bezier(.2,.8,.2,1) forwards;
    animation-delay: calc(var(--i, 0) * 60ms);
}
@keyframes stoneRise {
    from { opacity: 0; transform: translate(-50%, calc(-50% + 12px)) rotate(var(--r, 0deg)) scale(0.8); }
    to   { opacity: 1; transform: translate(-50%, -50%) rotate(var(--r, 0deg)) scale(1); }
}
.stone:hover {
    transform: translate(-50%, -50%) rotate(0deg) scale(1.12);
    background: var(--c-bg);
    border-color: var(--c-gold);
    z-index: 5;
    box-shadow: var(--shadow-md);
}
.stone-num {
    font-family: var(--f-serif);
    font-size: 1.05rem;
    font-weight: 600;
    color: var(--c-gold);
    line-height: 1;
}
.stone-theme {
    font-size: 0.6rem;
    color: var(--c-mute);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    line-height: 1.1;
    padding: 2px 4px;
    max-width: 56px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
@media (max-width: 720px) {
    .stone { width: 48px; height: 48px; }
    .stone-num { font-size: 0.85rem; }
    .stone-theme { display: none; }
}

.path-bookends {
    position: absolute;
    bottom: var(--s-2);
    left: 0;
    right: 0;
    display: flex;
    justify-content: space-between;
    padding: 0 var(--s-3);
    color: var(--c-mute);
    font-family: var(--f-jp);
    font-size: 0.85rem;
    pointer-events: none;
}
.path-start, .path-end { letter-spacing: 0.1em; }

/* — Calligraphy-paint reveal for the result panel — */
.discover-result.is-revealing .result-title,
.discover-result.is-revealing .r-card,
.discover-result.is-revealing .result-statement {
    opacity: 0;
    transform: translateY(14px);
    animation: inkPaint 0.9s cubic-bezier(.2,.8,.2,1) forwards;
}
.discover-result.is-revealing .result-title { animation-delay: 0s; }
.discover-result.is-revealing .r-passion    { animation-delay: 0.3s; }
.discover-result.is-revealing .r-mission    { animation-delay: 0.55s; }
.discover-result.is-revealing .r-vocation   { animation-delay: 0.8s; }
.discover-result.is-revealing .r-profession { animation-delay: 1.05s; }
.discover-result.is-revealing .result-statement { animation-delay: 1.45s; }
@keyframes inkPaint {
    0%   { opacity: 0; transform: translateY(14px); filter: blur(6px); }
    50%  { opacity: 0.9; filter: blur(1px); }
    100% { opacity: 1; transform: translateY(0); filter: blur(0); }
}

/* — Section ink-divider — single brushstroke between sections — */
[data-section]:not([data-section="hero"])::before {
    content: "";
    display: block;
    width: 80px;
    height: 22px;
    margin: 0 auto var(--s-7);
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 80 22'><path d='M2 14 Q 14 4 28 11 T 56 12 T 78 8' fill='none' stroke='%23B8860B' stroke-width='1.6' stroke-linecap='round' opacity='0.55'/></svg>");
    background-repeat: no-repeat;
    background-position: center;
    opacity: 0;
    transform: translateY(-8px);
    transition: opacity 0.8s ease, transform 0.8s ease;
}
[data-section]:not([data-section="hero"]).is-section-visible::before {
    opacity: 1;
    transform: translateY(0);
}

/* — Sound toggle in nav — */
.sound-toggle {
    background: transparent;
    border: 1px solid var(--c-line);
    width: 34px;
    height: 34px;
    border-radius: var(--r-pill);
    display: inline-block;
    cursor: pointer;
    color: var(--c-mute);
    transition: color var(--t-fast), border-color var(--t-fast), background-color var(--t-fast);
    position: relative;
    padding: 0;
    line-height: 0;
    vertical-align: middle;
}
.sound-toggle:hover { color: var(--c-gold); border-color: var(--c-gold); }
.sound-toggle.is-on {
    color: var(--c-gold);
    border-color: var(--c-gold);
    background: linear-gradient(135deg, rgba(184,134,11,0.10), transparent);
}
/* Both icons sit centred; we cross-fade by opacity instead of display
   (display:none was being overridden somewhere — opacity is bulletproof) */
.sound-toggle svg {
    position: absolute;
    top: 50%; left: 50%;
    transform: translate(-50%, -50%);
    transition: opacity 220ms ease;
}
.sound-toggle .icon-sound-on  { opacity: 0; pointer-events: none; }
.sound-toggle .icon-sound-off { opacity: 1; }
.sound-toggle.is-on .icon-sound-on  { opacity: 1; pointer-events: auto; }
.sound-toggle.is-on .icon-sound-off { opacity: 0; pointer-events: none; }
.sound-toggle.is-on::after {
    content: "";
    position: absolute;
    inset: -2px;
    border-radius: 50%;
    border: 1.5px solid rgba(184,134,11,0.35);
    animation: soundPulse 2.4s ease-out infinite;
    pointer-events: none;
}
@keyframes soundPulse {
    0%   { transform: scale(0.95); opacity: 1; }
    100% { transform: scale(1.4);  opacity: 0; }
}
@media (prefers-reduced-motion: reduce) {
    .sound-toggle.is-on::after { animation: none; }
}


/* -------------------------------------------------------------------------
   1. HERO
   ------------------------------------------------------------------------- */
.ikigai-hero {
    position: relative;
    min-height: 92vh;
    display: flex;
    align-items: center;
    overflow: hidden;
    padding: var(--s-9) 0 var(--s-8);
}

.hero-canvas {
    position: absolute;
    inset: 0;
    pointer-events: none;
}

.enso-circle {
    position: absolute;
    top: 50%;
    left: 60%;
    width: clamp(520px, 70vw, 880px);
    aspect-ratio: 1;
    transform: translate(-50%, -50%);
    background:
        url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 800 800'><path d='M 400 70 A 330 330 0 1 0 720 460 A 200 200 0 1 1 280 280' fill='none' stroke='%23B8860B' stroke-width='14' stroke-linecap='round' opacity='0.32'/></svg>") center/contain no-repeat;
    animation: ensoFade 2.4s cubic-bezier(.2,.8,.2,1);
}
@keyframes ensoFade {
    0% { opacity: 0; transform: translate(-50%, -50%) rotate(-30deg) scale(0.8); }
    100% { opacity: 1; transform: translate(-50%, -50%) rotate(0) scale(1); }
}

.sumi-wash {
    position: absolute;
    top: 0; right: 0;
    width: 60%;
    height: 100%;
    background:
        radial-gradient(ellipse 80% 60% at 80% 30%, rgba(184,134,11,0.10), transparent 70%),
        radial-gradient(ellipse 50% 40% at 60% 70%, rgba(192,57,43,0.05), transparent 70%);
}

.petals {
    position: absolute;
    inset: 0;
    overflow: hidden;
}
.petal {
    position: absolute;
    width: 14px; height: 14px;
    background: radial-gradient(ellipse at 30% 30%, #FCE4EC, #F8BBD0);
    border-radius: 60% 0 60% 0;
    opacity: 0.6;
    animation: petalFall linear infinite;
}
@keyframes petalFall {
    0%   { transform: translate(0, -30px) rotate(0); opacity: 0; }
    10%  { opacity: 0.7; }
    100% { transform: translate(40px, 110vh) rotate(360deg); opacity: 0; }
}

.hero-content { position: relative; max-width: 920px; }
.hero-content .eyebrow { color: var(--c-gold); }
.hero-title {
    font-family: var(--f-serif);
    font-size: clamp(2.6rem, 6vw, 5rem);
    font-weight: 500;
    line-height: 1.06;
    letter-spacing: -0.015em;
    margin-bottom: var(--s-5);
}
.hero-title-1 { display: block; font-style: italic; color: var(--c-gold); }
.hero-title-2 { display: block; font-style: italic; color: var(--c-ink-soft); font-weight: 400; }
.hero-title-3 { display: block; }
.hero-sub {
    font-size: clamp(1.1rem, 1.6vw, 1.25rem);
    line-height: 1.6;
    max-width: 780px;
    color: var(--c-ink-soft);
    margin-bottom: var(--s-4);
}
.hero-promise {
    font-family: var(--f-serif);
    font-style: italic;
    font-size: 1.2rem;
    color: var(--c-gold);
    border-left: 2px solid var(--c-gold);
    padding-left: var(--s-4);
    margin-bottom: var(--s-7);
    max-width: 600px;
}
.hero-cta { display: flex; gap: var(--s-3); flex-wrap: wrap; }

.hero-scroll {
    position: absolute;
    left: 50%;
    bottom: var(--s-5);
    width: 28px; height: 44px;
    border: 1.5px solid var(--c-mute);
    border-radius: 14px;
    transform: translateX(-50%);
    border-bottom: 1.5px solid var(--c-mute) !important;
}
.hero-scroll span {
    position: absolute;
    top: 8px; left: 50%;
    width: 4px; height: 8px;
    margin-left: -2px;
    border-radius: 2px;
    background: var(--c-mute);
    animation: scrollWheel 1.6s ease-in-out infinite;
}
@keyframes scrollWheel {
    0%, 100% { transform: translateY(0); opacity: 1; }
    60% { transform: translateY(14px); opacity: 0; }
    61% { transform: translateY(0); opacity: 0; }
}

/* -------------------------------------------------------------------------
   2. VENN DIAGRAM — sized to fit in one viewport (no scroll within section)
   ------------------------------------------------------------------------- */
.venn-section { padding: var(--s-8) 0; background: var(--c-bg-alt); }
.venn-section .section-head { margin-bottom: var(--s-5); }

.venn-stage {
    display: grid;
    grid-template-columns: 1.1fr 1fr;
    gap: var(--s-6);
    align-items: center;
    margin-bottom: var(--s-4);
}
@media (max-width: 920px) { .venn-stage { grid-template-columns: 1fr; gap: var(--s-5); } }

.venn-svg {
    width: 100%;
    max-width: 480px;
    max-height: 460px;
    margin: 0 auto;
    display: block;
}
.v-circle {
    cursor: pointer;
    transition: opacity var(--t-mid), transform var(--t-mid);
    transform-origin: center;
}
.v-circle:hover, .v-circle.is-active { opacity: 0.85; transform: scale(1.02); }
.v-label {
    font-family: var(--f-sans);
    font-size: 14px;
    font-weight: 600;
    fill: var(--c-ink);
    text-transform: uppercase;
    letter-spacing: 0.12em;
}
.v-overlap {
    font-family: var(--f-serif);
    font-style: italic;
    font-size: 12px;
    fill: var(--c-mute);
    text-anchor: middle;
}
.v-center {
    font-family: var(--f-serif);
    font-size: 28px;
    font-weight: 600;
    fill: var(--c-gold);
}

/* Cards stack at the same position; only the active one is visible.
   This collapses the right column from ~600px tall to a single card
   (~240px), letting the whole section fit in one viewport. */
.venn-cards {
    position: relative;
    min-height: 280px;
    padding-bottom: 32px; /* room for the pager dots below */
}
.venn-card {
    position: absolute;
    inset: 0 0 32px 0; /* leave bottom space for dots */
    background: var(--c-paper);
    border: 1px solid var(--c-line);
    border-radius: var(--r-md);
    padding: var(--s-5);
    border-left: 4px solid var(--c-mute);
    box-shadow: var(--shadow-sm);
    transition: opacity 420ms ease, transform 420ms cubic-bezier(.2,.8,.2,1), border-color 320ms ease, box-shadow 320ms ease;
    opacity: 0;
    transform: translateY(10px);
    pointer-events: none;
    overflow: hidden;
}
.venn-card.is-active {
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
    border-left-color: var(--c-gold);
    box-shadow: var(--shadow-md);
}
.venn-card h3 { margin: 0 0 var(--s-3); font-size: 1.2rem; }
.venn-card-q { color: var(--c-ink-soft); font-style: italic; margin: var(--s-3) 0 0; }
.venn-card-q b { color: var(--c-gold); font-style: normal; }

#card-love.is-active { border-left-color: var(--c-love); }
#card-good.is-active { border-left-color: var(--c-good); }
#card-need.is-active { border-left-color: var(--c-need); }
#card-paid.is-active { border-left-color: var(--c-paid); }

/* Pagination dots — show which card is active, click to jump */
.venn-card-pager {
    position: absolute;
    left: 0; right: 0;
    bottom: 0;
    display: flex;
    justify-content: center;
    gap: 10px;
    padding: 8px 0;
}
.vp-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    border: none;
    padding: 0;
    background: var(--c-line);
    cursor: pointer;
    transition: background-color 320ms ease, transform 320ms cubic-bezier(.2,.8,.2,1), width 320ms ease;
    position: relative;
}
.vp-dot:hover { background: var(--c-gold-soft); }
.vp-dot.is-on {
    background: var(--c-gold);
    width: 24px;
    border-radius: 4px;
}

.venn-overlaps {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: var(--s-3);
    text-align: center;
    color: var(--c-ink-soft);
    margin-top: var(--s-3);
}
.overlap { display: flex; align-items: center; justify-content: center; gap: var(--s-2); font-size: 0.9rem; }
.o-dot { display: inline-block; width: 10px; height: 10px; border-radius: 50%; }

/* -------------------------------------------------------------------------
   3. DISCOVERY TOOL
   ------------------------------------------------------------------------- */
.discover-section { padding: var(--s-8) 0; }
.discover-form { max-width: 820px; margin: 0 auto; }

.discover-progress {
    margin-bottom: var(--s-6);
    text-align: center;
}
.progress-track {
    height: 4px;
    background: var(--c-line);
    border-radius: 2px;
    overflow: hidden;
    margin-bottom: var(--s-3);
}
.progress-fill {
    height: 100%;
    width: 0%;
    background: linear-gradient(90deg, var(--c-love), var(--c-good), var(--c-need), var(--c-paid));
    transition: width var(--t-mid);
}
.progress-meta { font-size: 0.85rem; color: var(--c-mute); }

.discover-step {
    border: none;
    padding: 0;
    margin: 0 0 var(--s-4);
    display: none;
}
.discover-step.is-active { display: block; animation: fadeUp 0.5s ease-out; }
.discover-step legend {
    display: flex;
    align-items: center;
    gap: var(--s-3);
    margin-bottom: var(--s-6);
    padding: 0;
    width: 100%;
    border-bottom: 1px solid var(--c-line);
    padding-bottom: var(--s-4);
}
.step-kanji {
    font-family: var(--f-jp);
    font-size: 2.4rem;
    color: var(--cat-color, var(--c-gold));
    line-height: 1;
}
.step-num { font-size: 0.78rem; color: var(--c-mute); text-transform: uppercase; letter-spacing: 0.16em; }
.step-label { font-family: var(--f-serif); font-size: 1.4rem; font-weight: 500; flex: 1; }

.q-block {
    margin-bottom: var(--s-5);
    padding: var(--s-4) 0;
    border-bottom: 1px dashed var(--c-line);
}
.q-block:last-of-type { border-bottom: none; }
.q-block label {
    font-family: var(--f-serif);
    font-size: 1.15rem;
    color: var(--c-ink);
    font-weight: 500;
    line-height: 1.4;
    margin-bottom: var(--s-3);
}
.q-hint {
    font-size: 0.82rem;
    color: var(--c-mute);
    margin: var(--s-2) 0 0;
    font-style: italic;
}

.step-nav {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: var(--s-3);
    margin-top: var(--s-6);
    padding-top: var(--s-5);
    border-top: 1px solid var(--c-line);
}

.discover-finish-extra {
    max-width: 540px;
    margin: 0 auto;
    padding: var(--s-5);
    background: var(--c-paper);
    border-radius: var(--r-md);
    display: none;
}
.discover-finish-extra.is-visible { display: block; }

/* Result */
.discover-result {
    margin-top: var(--s-7);
    background: var(--c-paper);
    border: 1px solid var(--c-line);
    border-radius: var(--r-lg);
    padding: var(--s-7);
    box-shadow: var(--shadow-md);
    animation: fadeUp 0.7s ease-out;
}
.result-title {
    text-align: center;
    font-size: 2rem;
    margin-bottom: var(--s-6);
    font-family: var(--f-serif);
    color: var(--c-gold);
}
.result-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--s-4);
    margin-bottom: var(--s-6);
}
.result-grid-lg { gap: var(--s-5); margin-bottom: var(--s-7); }
@media (max-width: 700px) { .result-grid { grid-template-columns: 1fr; } }
.r-card {
    background: var(--c-bg);
    padding: var(--s-5);
    border-radius: var(--r-md);
    border-left: 4px solid;
}
.r-card h4 {
    margin: 0 0 var(--s-3);
    text-transform: uppercase;
    letter-spacing: 0.14em;
    font-size: 0.85rem;
    font-family: var(--f-sans);
    color: var(--c-mute);
    display: flex;
    justify-content: space-between;
    align-items: baseline;
}
.r-card p { margin: 0; font-family: var(--f-serif); font-size: 1.05rem; line-height: 1.5; color: var(--c-ink); }
.r-card-formula { font-size: 0.7rem; opacity: 0.7; font-style: italic; }
.r-passion    { border-color: var(--c-passion); }
.r-mission    { border-color: var(--c-mission); }
.r-vocation   { border-color: var(--c-vocation); }
.r-profession { border-color: var(--c-profession); }

.result-statement, .result-statement-lg {
    text-align: center;
    font-family: var(--f-serif);
    font-style: italic;
    font-size: 1.4rem;
    line-height: 1.5;
    color: var(--c-ink);
    border: none;
    margin: var(--s-6) auto;
    max-width: 720px;
}
.result-statement-lg { font-size: 1.6rem; }

.result-actions { display: flex; gap: var(--s-3); justify-content: center; flex-wrap: wrap; }
.result-share {
    display: flex;
    gap: var(--s-3);
    align-items: center;
    margin-bottom: var(--s-6);
    padding: var(--s-4);
    background: var(--c-paper);
    border-radius: var(--r-md);
}
.result-share input { flex: 1; }
.result-next h3 { margin-bottom: var(--s-3); }
.result-next ol { padding-left: var(--s-5); color: var(--c-ink-soft); line-height: 1.8; }

/* -------------------------------------------------------------------------
   4. THE 10 RULES
   ------------------------------------------------------------------------- */
.rules-section { padding: var(--s-8) 0; }

.rules-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: var(--s-5);
}
.rule-card {
    background: var(--c-paper);
    border: 1px solid var(--c-line);
    border-radius: var(--r-md);
    padding: var(--s-6);
    position: relative;
    overflow: hidden;
    transition: transform var(--t-mid), box-shadow var(--t-mid), border-color var(--t-mid);
}
.rule-card::before {
    content: "";
    position: absolute;
    top: 0; left: 0;
    height: 4px;
    width: 100%;
    background: var(--accent, var(--c-gold));
    transform-origin: left;
    transform: scaleX(0.3);
    transition: transform var(--t-mid);
}
.rule-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-md);
}
.rule-card:hover::before { transform: scaleX(1); }
.rule-num {
    font-family: var(--f-serif);
    font-size: 2.2rem;
    color: var(--accent, var(--c-gold));
    font-weight: 600;
    line-height: 1;
    margin-bottom: var(--s-3);
}
.rule-title { font-size: 1.3rem; line-height: 1.3; margin-bottom: var(--s-3); }
.rule-title a { color: inherit; }
.rule-desc { color: var(--c-ink-soft); font-size: 0.95rem; }
.rule-action {
    margin-top: var(--s-4);
    padding-top: var(--s-3);
    border-top: 1px dashed var(--c-line);
}
.rule-action summary {
    cursor: pointer;
    font-size: 0.9rem;
    color: var(--accent, var(--c-gold));
    font-weight: 500;
    list-style: none;
}
.rule-action summary::-webkit-details-marker { display: none; }
.rule-action[open] summary::after { content: " ↓"; }
.rule-action p {
    margin-top: var(--s-3);
    font-style: italic;
    font-size: 0.95rem;
    color: var(--c-ink);
}

.rule-nav {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: var(--s-7);
    padding-top: var(--s-5);
    border-top: 1px solid var(--c-line);
    gap: var(--s-3);
    flex-wrap: wrap;
}
.rule-nav a { color: var(--c-ink-soft); font-size: 0.95rem; }
.rule-nav .all-rules { color: var(--c-gold); font-weight: 600; }

.practice-p {
    background: var(--c-paper);
    border-left: 3px solid var(--c-gold);
    padding: var(--s-4) var(--s-5);
    border-radius: var(--r-sm);
    font-size: 1.05rem;
    color: var(--c-ink);
}

/* -------------------------------------------------------------------------
   5. HARA HACHI BU — fits in one viewport
   ------------------------------------------------------------------------- */
.hhb-section { padding: var(--s-8) 0; background: var(--c-bg-alt); }

.hhb-grid {
    display: grid;
    grid-template-columns: 1.2fr 1fr;
    gap: var(--s-6);
    align-items: center;
}
@media (max-width: 920px) { .hhb-grid { grid-template-columns: 1fr; gap: var(--s-5); } }

.hhb-text h2 { margin-bottom: var(--s-3); text-align: left; font-size: clamp(1.7rem, 3vw, 2.4rem); }
.hhb-text > p { font-size: 0.98rem; line-height: 1.6; margin-bottom: var(--s-3); }
.hhb-text h3 { margin: var(--s-5) 0 var(--s-3); font-size: 1.05rem; }

.hhb-script {
    list-style: none;
    counter-reset: step;
    padding: 0;
    margin: 0;
}
.hhb-script li {
    counter-increment: step;
    position: relative;
    padding-left: 38px;
    margin-bottom: var(--s-3);
    color: var(--c-ink-soft);
    font-size: 0.92rem;
    line-height: 1.5;
}
.hhb-script li:last-child { margin-bottom: 0; }
.hhb-script li::before {
    content: counter(step);
    position: absolute;
    left: 0; top: 0;
    width: 26px; height: 26px;
    border-radius: 50%;
    background: var(--c-gold);
    color: var(--c-bg);
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--f-serif);
    font-weight: 600;
    font-size: 0.85rem;
}
.hhb-warning {
    margin-top: var(--s-4);
    padding: var(--s-3) var(--s-4);
    border-left: 3px solid var(--c-vermillion);
    background: rgba(192,57,43,0.05);
    font-size: 0.85rem;
    color: var(--c-ink-soft);
}

.hhb-calc {
    background: var(--c-paper);
    border: 1px solid var(--c-line);
    border-radius: var(--r-md);
    padding: var(--s-5);
    box-shadow: var(--shadow-sm);
    /* No more sticky — it added vertical drift on short screens. */
}
.hhb-calc-h {
    margin: 0 0 4px;
    font-size: 1.1rem;
    font-family: var(--f-serif);
    font-style: italic;
    color: var(--c-gold);
}
.hhb-calc-sub { color: var(--c-mute); font-size: 0.85rem; margin: 0 0 var(--s-4); }

/* Result panel — compact two-column big numbers */
.hhb-result {
    margin-top: var(--s-4);
    padding-top: var(--s-4);
    border-top: 1px dashed var(--c-line);
    text-align: center;
}
.hhb-result-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--s-3);
    margin-bottom: var(--s-3);
}
.hhb-result-cell {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 2px;
}
.hhb-num {
    font-family: var(--f-serif);
    font-size: clamp(1.8rem, 3.4vw, 2.4rem);
    color: var(--c-gold);
    line-height: 1;
}
.hhb-unit {
    text-transform: uppercase;
    letter-spacing: 0.14em;
    font-size: 0.62rem;
    color: var(--c-mute);
    font-weight: 600;
}
.hhb-note { color: var(--c-mute); font-size: 0.74rem; margin: 0; font-style: italic; }

/* -------------------------------------------------------------------------
   6. CENTENARIANS  — walk through the village
   ------------------------------------------------------------------------- */
.centenarians-section {
    padding: var(--s-8) 0;
    position: relative;
    overflow: hidden;
}

/* Ogimi village horizon backdrop */
.ogimi-horizon-wrap {
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 280px;
    color: var(--c-ink);
    opacity: 0.55;
    pointer-events: none;
    mask-image: linear-gradient(to bottom, rgba(0,0,0,1) 30%, rgba(0,0,0,0));
    -webkit-mask-image: linear-gradient(to bottom, rgba(0,0,0,1) 30%, rgba(0,0,0,0));
}
.ogimi-horizon-wrap.is-page-hero { height: 100%; opacity: 0.45; }
.ogimi-horizon { width: 100%; height: 100%; }

[data-theme="dark"] .ogimi-horizon-wrap { opacity: 0.7; }

.centenarians-section .container,
.centenarians-page .container { position: relative; z-index: 2; }

.centenarian-strip {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: var(--s-6);
}
.centenarian-grid { gap: var(--s-6); }

.cent-card {
    background: var(--c-paper);
    border: 1px solid var(--c-line);
    border-radius: var(--r-md);
    overflow: hidden;
    position: relative;
    transition: transform var(--t-mid), box-shadow var(--t-mid), border-color var(--t-mid);
    display: flex;
    flex-direction: column;
}
.cent-card::after {
    /* subtle washi grain inside the card */
    content: "";
    position: absolute;
    inset: 0;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='80' height='80' viewBox='0 0 80 80'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='1' numOctaves='1' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.05 0 0 0 0 0.04 0 0 0 0 0.02 0 0 0 0.04 0'/></filter><rect width='80' height='80' filter='url(%23n)'/></svg>");
    background-size: 80px 80px;
    pointer-events: none;
    opacity: 0.5;
    mix-blend-mode: multiply;
    z-index: 0;
}
[data-theme="dark"] .cent-card::after { mix-blend-mode: screen; opacity: 0.2; }

.cent-card:hover {
    transform: translateY(-6px);
    box-shadow: var(--shadow-md);
    border-color: var(--c-gold);
}

/* The art frame — top of card */
.cent-art-frame {
    position: relative;
    background: linear-gradient(180deg, rgba(184,134,11,0.05), rgba(253,251,246,0));
    border-bottom: 1px solid var(--c-line);
    padding: var(--s-3) var(--s-2) 0;
    z-index: 1;
}
.cent-art {
    width: 100%;
    height: auto;
    color: var(--c-ink);
    display: block;
    transition: transform 0.7s cubic-bezier(.2,.8,.2,1), filter 0.5s ease;
    filter: blur(0);
}
.cent-card:hover .cent-art {
    transform: scale(1.05);
    filter: blur(0.3px);
}
.cent-art .hanko, .cent-art rect[stroke="#C0392B"], .cent-art text[fill="#C0392B"] {
    transition: opacity 0.3s ease;
}

/* Body */
.cent-body {
    padding: var(--s-5) var(--s-5) var(--s-6);
    position: relative;
    z-index: 1;
}
.cent-head {
    display: flex;
    align-items: flex-start;
    gap: var(--s-4);
    margin-bottom: var(--s-4);
    padding-bottom: var(--s-4);
    border-bottom: 1px dashed var(--c-line);
}
.cent-age {
    font-family: var(--f-serif);
    font-size: 2.6rem;
    color: var(--c-gold);
    line-height: 1;
    flex-shrink: 0;
    margin: 0;
}
.cent-age span {
    display: block;
    font-size: 0.7rem;
    color: var(--c-mute);
    text-transform: uppercase;
    letter-spacing: 0.16em;
    margin-top: var(--s-1);
    font-family: var(--f-sans);
}
.cent-name-block { flex: 1; min-width: 0; }
.cent-name { margin: 0 0 var(--s-1); font-size: 1.2rem; line-height: 1.2; }
.cent-village { color: var(--c-mute); font-size: 0.85rem; margin: 0; }

.cent-ikigai { font-size: 0.92rem; color: var(--c-ink); margin: 0 0 var(--s-3); }
.cent-ikigai b { color: var(--c-gold); font-weight: 600; }
.cent-quote {
    font-family: var(--f-serif);
    font-style: italic;
    color: var(--c-ink-soft);
    border-left: 2px solid var(--c-gold);
    padding-left: var(--s-3);
    margin: var(--s-4) 0;
    font-size: 1rem;
    line-height: 1.45;
}
.cent-story { font-size: 0.9rem; color: var(--c-mute); margin: 0; }

/* Page-hero variant for /ikigai/centenarians */
.page-hero.with-ogimi {
    position: relative;
    overflow: hidden;
    color: var(--c-ink);
}
.page-hero.with-ogimi .container { position: relative; z-index: 2; }

.centenarian-note {
    margin-top: var(--s-7);
    text-align: center;
    color: var(--c-mute);
    font-size: 0.85rem;
    font-style: italic;
}

/* -------------------------------------------------------------------------
   7. MOAI — five lanterns on one string of light
   ------------------------------------------------------------------------- */
.moai-section {
    padding: var(--s-8) 0;
    background: var(--c-bg-alt);
    position: relative;
    overflow: hidden;
}

/* Lantern arrangement — sits above the section header */
.moai-lantern-wrap {
    position: relative;
    width: 100%;
    max-width: 1100px;
    margin: 0 auto var(--s-7);
    color: var(--c-ink);
    pointer-events: none;
}
.moai-lantern-wrap.is-page-hero {
    margin-top: var(--s-6);
    margin-bottom: 0;
}
.moai-lanterns {
    width: 100%;
    height: auto;
    display: block;
    overflow: visible;
}

/* Each lantern breathes — soft glow + gentle sway, staggered via --d */
.moai-lantern {
    transform-origin: center top;
    animation: lanternSway 6.5s ease-in-out infinite alternate;
    animation-delay: var(--d, 0s);
}
@keyframes lanternSway {
    0%   { transform: translate(var(--tx, 0), var(--ty, 0)) scale(var(--sc, 1)) rotate(-1.6deg); }
    100% { transform: translate(var(--tx, 0), var(--ty, 0)) scale(var(--sc, 1)) rotate(1.6deg); }
}

/* The body glow pulses slightly */
.lantern-body {
    transform-origin: center;
    animation: lanternPulse 3.8s ease-in-out infinite alternate;
    animation-delay: var(--d, 0s);
}
.lantern-halo {
    transform-origin: center;
    animation: lanternHaloPulse 3.8s ease-in-out infinite alternate;
    animation-delay: var(--d, 0s);
}
@keyframes lanternPulse {
    0%   { opacity: 0.85; }
    100% { opacity: 1; }
}
@keyframes lanternHaloPulse {
    0%   { opacity: 0.55; transform: scale(0.94); }
    100% { opacity: 1;    transform: scale(1.08); }
}

/* The light string drifts gently */
.lantern-string {
    animation: stringDrift 12s ease-in-out infinite alternate;
    transform-origin: center;
}
@keyframes stringDrift {
    0%   { transform: translateY(0); opacity: 0.3; }
    100% { transform: translateY(-3px); opacity: 0.5; }
}

@media (prefers-reduced-motion: reduce) {
    .moai-lantern, .lantern-body, .lantern-halo, .lantern-string { animation: none; }
}

/* Page-hero variant for /ikigai/moai */
.page-hero.with-lanterns {
    position: relative;
    overflow: hidden;
    padding-bottom: var(--s-7);
}
.page-hero.with-lanterns .container { position: relative; z-index: 2; }
.page-hero.with-lanterns .moai-lantern-wrap {
    max-width: 900px;
    margin: var(--s-5) auto 0;
}

.moai-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: var(--s-5);
    margin-bottom: var(--s-7);
}
.moai-card {
    background: var(--c-paper);
    border: 1px solid var(--c-line);
    border-radius: var(--r-md);
    padding: var(--s-5);
    transition: transform var(--t-mid), box-shadow var(--t-mid);
    display: flex;
    flex-direction: column;
}
.moai-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); }
.moai-name { margin: 0 0 var(--s-2); font-size: 1.2rem; }
.moai-focus {
    color: var(--c-gold);
    font-size: 0.85rem;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    margin: 0 0 var(--s-3);
}
.moai-desc { color: var(--c-ink-soft); font-size: 0.95rem; flex: 1; }
.moai-meta {
    display: flex;
    flex-wrap: wrap;
    gap: var(--s-3);
    color: var(--c-mute);
    font-size: 0.82rem;
    margin: var(--s-3) 0;
}
.moai-meta span { padding: 3px 10px; background: var(--c-bg); border-radius: var(--r-pill); border: 1px solid var(--c-line); }

.moai-create { margin-top: var(--s-5); }
.moai-create > summary {
    list-style: none;
    cursor: pointer;
    width: max-content;
    margin: 0 auto;
}
.moai-create > summary::-webkit-details-marker { display: none; }
.moai-form {
    margin-top: var(--s-6);
    background: var(--c-paper);
    border: 1px solid var(--c-line);
    border-radius: var(--r-md);
    padding: var(--s-6);
    display: flex;
    flex-direction: column;
    gap: var(--s-4);
}

.moai-detail .lead-p { font-size: 1.2rem; }

/* -------------------------------------------------------------------------
   8. FLOW
   ------------------------------------------------------------------------- */
.flow-section { padding: var(--s-8) 0; }
.flow-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--s-7);
    align-items: start;
}
@media (max-width: 920px) { .flow-grid { grid-template-columns: 1fr; } }

.flow-text h2 { text-align: left; }
.flow-form, .flow-summary {
    background: var(--c-paper);
    border: 1px solid var(--c-line);
    border-radius: var(--r-md);
    padding: var(--s-6);
}
.flow-form h3, .flow-summary h3 { margin-bottom: var(--s-4); }
.flow-form { display: flex; flex-direction: column; gap: var(--s-3); }

.flow-stat {
    margin: 0 0 var(--s-3);
    color: var(--c-ink-soft);
    font-size: 0.95rem;
}
.flow-stat span {
    display: inline-block;
    font-family: var(--f-serif);
    font-size: 2rem;
    color: var(--c-gold);
    margin-right: var(--s-2);
    min-width: 60px;
}
.flow-summary h4 { margin-top: var(--s-5); }
.flow-recent { list-style: none; padding: 0; margin: 0; }
.flow-recent li {
    padding: var(--s-3) 0;
    border-bottom: 1px dashed var(--c-line);
    color: var(--c-ink-soft);
    font-size: 0.9rem;
}
.flow-recent li.empty { color: var(--c-mute); font-style: italic; }

/* -------------------------------------------------------------------------
   9. 30-DAY CHALLENGE
   ------------------------------------------------------------------------- */
.challenge-section { padding: var(--s-8) 0; background: var(--c-bg-alt); }

.challenge-stats {
    display: flex;
    justify-content: center;
    gap: var(--s-7);
    margin-bottom: var(--s-7);
    color: var(--c-ink-soft);
}
.challenge-stats div { display: flex; align-items: baseline; gap: var(--s-2); font-size: 0.9rem; color: var(--c-mute); }
.challenge-stats span {
    font-family: var(--f-serif);
    font-size: 2rem;
    color: var(--c-gold);
}

.challenge-cal {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: var(--s-3);
    margin-bottom: var(--s-7);
}
.challenge-cal-lg { grid-template-columns: repeat(6, 1fr); }
@media (max-width: 720px) {
    .challenge-cal, .challenge-cal-lg { grid-template-columns: repeat(4, 1fr); }
}
@media (max-width: 480px) {
    .challenge-cal, .challenge-cal-lg { grid-template-columns: repeat(3, 1fr); }
}

.cal-day {
    aspect-ratio: 1;
    background: var(--c-paper);
    border: 1px solid var(--c-line);
    border-radius: var(--r-md);
    padding: var(--s-3);
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    color: var(--c-ink);
    transition: transform var(--t-fast), border-color var(--t-fast), background-color var(--t-fast);
    position: relative;
    overflow: hidden;
    text-align: left;
    border-bottom: 1px solid var(--c-line) !important;
}
.cal-day:hover {
    transform: translateY(-2px);
    border-color: var(--c-gold);
    background: var(--c-bg);
}
.cal-num {
    font-family: var(--f-serif);
    font-size: 1.4rem;
    font-weight: 600;
    color: var(--c-gold);
}
.cal-theme {
    font-size: 0.78rem;
    color: var(--c-mute);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    line-height: 1.2;
}
.cal-day.is-done {
    background: linear-gradient(135deg, rgba(184,134,11,0.10), transparent);
    border-color: var(--c-gold);
}
.cal-day.is-done .cal-num { color: var(--c-gold); }
.cal-tick {
    position: absolute;
    top: 6px; right: 8px;
    color: var(--c-gold);
    font-weight: 600;
    font-size: 1.1rem;
}

.challenge-cta { text-align: center; }

.challenge-day .practice-card {
    background: var(--c-paper);
    border: 1px solid var(--c-line);
    border-left: 3px solid var(--c-gold);
    border-radius: var(--r-md);
    padding: var(--s-5);
    margin-bottom: var(--s-7);
}
.challenge-day .practice-card h2 { font-size: 1.4rem; text-align: left; margin-bottom: var(--s-3); }

.reflect-form { margin-bottom: var(--s-7); }
.reflect-form h2 { font-size: 1.4rem; text-align: left; margin-bottom: var(--s-4); }
.mood-pick {
    margin: var(--s-4) 0;
    border: none;
    padding: 0;
    display: flex;
    gap: var(--s-3);
    flex-wrap: wrap;
}
.mood-pick legend { font-size: 0.92rem; margin-bottom: var(--s-3); color: var(--c-ink-soft); }
.mood-pick label {
    cursor: pointer;
    margin: 0;
}
.mood-pick label input { display: none; }
.mood-pick label span {
    display: inline-block;
    padding: 0.55rem 1.1rem;
    border: 1.5px solid var(--c-line);
    border-radius: var(--r-pill);
    font-size: 0.88rem;
    transition: all var(--t-fast);
}
.mood-pick label input:checked + span {
    border-color: var(--c-gold);
    background: var(--c-gold);
    color: var(--c-bg);
}

/* -------------------------------------------------------------------------
   10. COMMUNITY WALL — under the cherry tree
   ------------------------------------------------------------------------- */
.community-section {
    padding: var(--s-8) 0;
    position: relative;
    overflow: hidden;
}

.sakura-wrap {
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 240px;
    pointer-events: none;
    z-index: 0;
}
.sakura-wrap.is-page-hero { height: 100%; }
.sakura-branch {
    width: 100%;
    height: 100%;
    display: block;
    opacity: 0.92;
    filter: drop-shadow(0 6px 20px rgba(92,58,31,0.08));
}
[data-theme="dark"] .sakura-branch { opacity: 0.7; filter: drop-shadow(0 6px 20px rgba(0,0,0,0.4)); }

/* Blossoms have a barely-there breath */
.sakura-bloom {
    transform-origin: center;
    animation: bloomBreath 7s ease-in-out infinite alternate;
}
.sakura-bloom:nth-child(odd)  { animation-duration: 9s; }
.sakura-bloom:nth-child(3n)   { animation-duration: 11s; animation-delay: -2s; }
@keyframes bloomBreath {
    0%   { opacity: 0.92; transform: scale(0.96); }
    100% { opacity: 1;    transform: scale(1.03); }
}

/* Falling-petal layer for this section (separate from hero petals) */
.sakura-petals {
    position: absolute;
    inset: 0;
    overflow: hidden;
    pointer-events: none;
}
.sakura-petals .sk-petal {
    position: absolute;
    width: 12px;
    height: 12px;
    background: radial-gradient(ellipse 60% 50% at 50% 30%, #FFE3EC, #F8C5D0);
    border-radius: 60% 0 60% 0;
    opacity: 0;
    animation: skPetalFall linear infinite;
}
@keyframes skPetalFall {
    0%   { transform: translate(0, -20px) rotate(0); opacity: 0; }
    8%   { opacity: 0.9; }
    100% { transform: translate(60px, 600px) rotate(560deg); opacity: 0; }
}
.community-section .sakura-petals .sk-petal { animation-duration: 14s; }
.page-hero.with-sakura .sakura-petals .sk-petal { animation-duration: 16s; }

@media (prefers-reduced-motion: reduce) {
    .sakura-bloom, .sakura-petals .sk-petal { animation: none; }
    .sakura-petals .sk-petal { display: none; }
}

.community-section .container { position: relative; z-index: 2; }
.community-section .section-head { padding-top: var(--s-7); }

.page-hero.with-sakura {
    position: relative;
    overflow: hidden;
}
.page-hero.with-sakura .container { position: relative; z-index: 2; }

.reflection-form-wrap { max-width: 720px; margin: 0 auto var(--s-7); }
.reflection-form-wrap > summary {
    list-style: none;
    cursor: pointer;
    width: max-content;
    margin: 0 auto;
}
.reflection-form-wrap > summary::-webkit-details-marker { display: none; }
.reflection-form {
    margin-top: var(--s-5);
    background: var(--c-paper);
    border: 1px solid var(--c-line);
    border-radius: var(--r-md);
    padding: var(--s-5);
    display: flex;
    flex-direction: column;
    gap: var(--s-4);
}

.reflection-masonry {
    columns: 3 320px;
    column-gap: var(--s-5);
}
.reflection-card {
    break-inside: avoid;
    background: var(--c-paper);
    border: 1px solid var(--c-line);
    border-radius: var(--r-md);
    padding: var(--s-5);
    margin-bottom: var(--s-5);
    transition: transform var(--t-mid), box-shadow var(--t-mid);
}
.reflection-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); }
.reflection-text {
    font-family: var(--f-serif);
    font-size: 1.05rem;
    line-height: 1.55;
    color: var(--c-ink);
    margin: 0 0 var(--s-4);
}
.reflection-meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-size: 0.85rem;
    color: var(--c-mute);
}
.heart-btn {
    background: transparent;
    border: 1px solid var(--c-line);
    border-radius: var(--r-pill);
    padding: 4px 10px;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: 4px;
    color: var(--c-mute);
    transition: all var(--t-fast);
}
.heart-btn:hover, .heart-btn.is-liked {
    color: var(--c-vermillion);
    border-color: var(--c-vermillion);
    background: rgba(192,57,43,0.05);
}
.heart-btn.is-liked svg { fill: currentColor; }
.heart-count { font-size: 0.82rem; }

/* -------------------------------------------------------------------------
   11. RESOURCES
   ------------------------------------------------------------------------- */
.resources-section { padding: var(--s-8) 0; background: var(--c-bg-alt); }

.resource-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: var(--s-5);
}
.resource-card {
    background: var(--c-paper);
    border: 1px solid var(--c-line);
    border-radius: var(--r-md);
    padding: var(--s-5);
    transition: transform var(--t-mid), box-shadow var(--t-mid);
}
.resource-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); }
.resource-type {
    display: inline-block;
    padding: 2px 10px;
    border-radius: var(--r-pill);
    background: var(--c-gold);
    color: var(--c-bg);
    font-size: 0.7rem;
    font-weight: 600;
    letter-spacing: 0.16em;
    margin-bottom: var(--s-3);
}
.resource-title { font-size: 1.15rem; margin: 0 0 var(--s-2); }
.resource-author { color: var(--c-mute); font-size: 0.9rem; font-style: italic; margin-bottom: var(--s-3); }
.resource-desc { font-size: 0.92rem; color: var(--c-ink-soft); margin: 0; }

/* -------------------------------------------------------------------------
   12. FINAL — the whisper
   ------------------------------------------------------------------------- */
.final-section {
    padding: var(--s-9) 0;
    text-align: center;
    background: var(--c-bg);
    position: relative;
    overflow: hidden;
}
.final-section::before {
    content: "";
    position: absolute;
    top: 50%; left: 50%;
    width: 700px; height: 700px;
    transform: translate(-50%, -50%);
    background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 800 800'><circle cx='400' cy='400' r='300' fill='none' stroke='%23B8860B' stroke-width='2' opacity='0.15'/></svg>") center/contain no-repeat;
    pointer-events: none;
}
.final-kanji {
    font-family: var(--f-jp);
    font-size: clamp(4rem, 12vw, 8rem);
    color: var(--c-gold);
    opacity: 0.3;
    margin: 0 0 var(--s-5);
    line-height: 1;
}
.final-quote {
    font-family: var(--f-serif);
    font-style: italic;
    font-size: clamp(1.4rem, 3vw, 2.2rem);
    line-height: 1.4;
    max-width: 720px;
    margin: 0 auto var(--s-3);
    color: var(--c-ink);
}
.final-cite { color: var(--c-mute); margin-bottom: var(--s-7); font-size: 0.9rem; }

/* -------------------------------------------------------------------------
   Misc page styles
   ------------------------------------------------------------------------- */
.single-rule { padding: var(--s-9) 0; }
.single-rule .lead-p {
    font-size: clamp(1.2rem, 2vw, 1.5rem);
    color: var(--c-ink);
    margin-bottom: var(--s-7);
}

.discover-standalone { padding-top: var(--s-7); }
.result-page { padding: var(--s-7) 0 var(--s-9); }

.challenge-day { padding: var(--s-7) 0 var(--s-9); }

.moai-detail { padding: var(--s-7) 0 var(--s-9); }

/* Print — make share pages clean to print or screenshot */
@media print {
    .site-header, .site-footer, .header-actions, .nav-toggle, .reading-progress { display: none; }
    .page-hero { padding: 1rem 0; border: none; }
    body { background: white; }
    a { color: inherit; }
}
