/* ==========================================================
   hangul.name — wabi-sabi watercolor calligraphic gallery
   Palette
   #faf5ee  rice paper
   #2d2520  sumi ink
   #4a6fa5  indigo wash
   #c47a93  plum blossom
   #5a8a6e  pine needle
   #c49a3c  vermillion gold
   #7a7068  stone gray
   #b44333  cinnabar red
   ========================================================== */

:root {
    --paper: #faf5ee;
    --ink: #2d2520;
    --indigo: #4a6fa5;
    --plum: #c47a93;
    --pine: #5a8a6e;
    --gold: #c49a3c;
    --stone: #7a7068;
    --cinnabar: #b44333;

    --font-brush: "Nanum Brush Script", "Noto Serif KR", cursive;
    --font-han: "Noto Serif KR", "Noto Serif CJK KR", serif;
    --font-body: "Crimson Pro", "Georgia", serif;
    --font-ui: "Noto Sans KR", "Inter", sans-serif;
}

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

html, body {
    background: var(--paper);
    color: var(--ink);
    font-family: var(--font-body);
    font-weight: 300;
    line-height: 1.8;
    -webkit-font-smoothing: antialiased;
    overflow-x: hidden;
}

/* Page-wide watercolor wash */
body::before {
    content: "";
    position: fixed;
    inset: 0;
    pointer-events: none;
    z-index: 0;
    background:
        radial-gradient(ellipse 60% 40% at 12% 14%, rgba(74,111,165,0.07) 0%, transparent 60%),
        radial-gradient(ellipse 50% 35% at 88% 22%, rgba(196,122,147,0.06) 0%, transparent 65%),
        radial-gradient(ellipse 70% 50% at 50% 95%, rgba(196,154,60,0.05) 0%, transparent 70%);
}

/* Subtle paper-grain noise overlay */
body::after {
    content: "";
    position: fixed;
    inset: 0;
    pointer-events: none;
    z-index: 0;
    background-image:
        radial-gradient(circle at 20% 30%, rgba(45,37,32,0.025) 0.5px, transparent 1px),
        radial-gradient(circle at 70% 65%, rgba(45,37,32,0.02) 0.5px, transparent 1px),
        radial-gradient(circle at 40% 80%, rgba(45,37,32,0.025) 0.5px, transparent 1px);
    background-size: 7px 7px, 11px 11px, 13px 13px;
    opacity: 0.6;
    mix-blend-mode: multiply;
}

main, header, section, footer { position: relative; z-index: 1; }

/* ==========================================================
   TOP NAV
   ========================================================== */
.topnav {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1.6rem clamp(1.5rem, 4vw, 4rem);
    position: fixed;
    top: 0; left: 0; right: 0;
    z-index: 50;
    background: linear-gradient(to bottom, rgba(250,245,238,0.92), rgba(250,245,238,0.0));
    backdrop-filter: blur(2px);
}

.brand {
    display: flex;
    align-items: center;
    gap: 0.7rem;
    font-family: var(--font-ui);
    font-weight: 500;
    color: var(--ink);
    letter-spacing: 0.02em;
}

.brand-mark {
    font-family: var(--font-brush);
    font-size: 2.2rem;
    color: var(--cinnabar);
    line-height: 0.8;
    transform: translateY(2px);
}

.brand-text { font-size: 0.95rem; }
.brand-dot { color: var(--cinnabar); }

.navlinks {
    display: flex;
    gap: clamp(0.8rem, 2vw, 2rem);
    font-family: var(--font-ui);
    font-size: 0.85rem;
    color: var(--stone);
}

.navlinks a {
    color: var(--stone);
    text-decoration: none;
    padding: 0.4rem 0.2rem;
    border-bottom: 1px solid transparent;
    transition: color 0.4s ease, border-color 0.4s ease;
}

.navlinks a:hover { color: var(--ink); border-bottom-color: var(--cinnabar); }

/* ==========================================================
   HERO — The Name Scroll
   ========================================================== */
.hero-scroll {
    min-height: 100vh;
    padding: 12vh 6vw 8vh;
    display: flex;
    align-items: center;
    justify-content: center;
}

.hero-paper {
    position: relative;
    width: min(88vw, 1100px);
    padding: clamp(3rem, 8vh, 8rem) clamp(2rem, 8vw, 6rem);
    text-align: center;
    background:
        radial-gradient(ellipse 60% 50% at 22% 28%, rgba(74,111,165,0.13) 0%, transparent 55%),
        radial-gradient(ellipse 55% 45% at 78% 38%, rgba(196,122,147,0.11) 0%, transparent 55%),
        radial-gradient(ellipse 70% 50% at 50% 88%, rgba(90,138,110,0.10) 0%, transparent 60%),
        radial-gradient(ellipse 40% 30% at 65% 18%, rgba(196,154,60,0.08) 0%, transparent 55%);
    border-radius: 6px;
}

.hero-eyebrow {
    font-family: var(--font-ui);
    font-size: 0.78rem;
    letter-spacing: 0.32em;
    text-transform: uppercase;
    color: var(--stone);
    margin-bottom: 2.4rem;
}

.hero-name {
    font-family: var(--font-brush);
    font-weight: 400;
    font-size: clamp(5rem, 14vw, 11rem);
    line-height: 1.0;
    color: var(--ink);
    letter-spacing: 0.06em;
    display: inline-block;
}

.hero-name .syllable {
    display: inline-block;
    transition: transform 0.8s cubic-bezier(0.22, 1, 0.36, 1), color 0.8s;
}

.hero-name .syllable:hover {
    transform: translateY(-6px) rotate(-2deg);
    color: var(--cinnabar);
}

.hero-underline {
    display: block;
    margin: -0.4rem auto 1.4rem;
    width: clamp(220px, 36vw, 460px);
    height: 28px;
    opacity: 0.85;
}

.hero-hanja {
    font-family: var(--font-han);
    font-weight: 600;
    font-size: clamp(1.4rem, 2.6vw, 2.2rem);
    color: var(--cinnabar);
    letter-spacing: 0.4em;
    margin-bottom: 1.6rem;
}

.hero-meaning {
    font-family: var(--font-body);
    font-style: italic;
    font-size: clamp(1rem, 1.4vw, 1.2rem);
    color: var(--ink);
    max-width: 38em;
    margin: 0 auto 2rem;
    line-height: 1.7;
}

.hero-meaning em { color: var(--cinnabar); font-style: italic; }

.hero-meta {
    display: inline-flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.8rem;
    font-family: var(--font-ui);
    font-size: 0.82rem;
    color: var(--stone);
    letter-spacing: 0.06em;
}

.hero-meta .dot { color: var(--gold); }

.hero-seal {
    position: absolute;
    right: clamp(1.2rem, 4vw, 3.2rem);
    bottom: clamp(1.2rem, 4vw, 3.2rem);
    width: clamp(56px, 7vw, 84px);
    height: clamp(56px, 7vw, 84px);
    transform: rotate(-5deg);
    opacity: 0.92;
}

.hero-seal svg { width: 100%; height: 100%; }

/* Ink splatter accents around hero */
.ink-splatter {
    position: absolute;
    width: 60px;
    height: 60px;
    pointer-events: none;
    opacity: 0.7;
}
.ink-splatter svg { width: 100%; height: 100%; }
.splatter-a { top: 8%; left: 12%; transform: rotate(-15deg) scale(0.9); }
.splatter-b { top: 18%; right: 14%; transform: rotate(35deg) scale(1.1); }
.splatter-c { bottom: 22%; left: 22%; transform: rotate(-50deg) scale(0.7); }

.scroll-hint {
    margin-top: 3rem;
    display: inline-flex;
    align-items: center;
    gap: 1rem;
    font-family: var(--font-ui);
    font-size: 0.8rem;
    color: var(--stone);
    letter-spacing: 0.18em;
}

.hint-line {
    display: inline-block;
    width: 60px;
    height: 1px;
    background: linear-gradient(to right, var(--stone), transparent);
}

/* ==========================================================
   Section heads (shared)
   ========================================================== */
.section-head {
    padding: 0 clamp(1.5rem, 6vw, 6rem);
    margin: 0 auto 4rem;
    max-width: 1100px;
    text-align: left;
}

.section-title {
    font-weight: 400;
    line-height: 1.2;
    margin-bottom: 1rem;
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
}

.section-title .kr {
    font-family: var(--font-brush);
    font-size: clamp(2.4rem, 5vw, 3.8rem);
    color: var(--ink);
    letter-spacing: 0.04em;
}

.section-title .en {
    font-family: var(--font-body);
    font-style: italic;
    font-weight: 300;
    font-size: clamp(0.95rem, 1.3vw, 1.15rem);
    color: var(--cinnabar);
    letter-spacing: 0.08em;
}

.section-lede {
    font-family: var(--font-body);
    font-size: 1rem;
    color: var(--stone);
    max-width: 38em;
    line-height: 1.8;
}

/* ==========================================================
   GALLERY — horizontal scroll of name cards
   ========================================================== */
.gallery-section {
    padding: 8vh 0 4vh;
}

.scroll-rail {
    display: flex;
    overflow-x: auto;
    overflow-y: hidden;
    scroll-snap-type: x mandatory;
    scroll-behavior: smooth;
    gap: 2rem;
    padding: 2rem clamp(1.5rem, 6vw, 6rem) 4rem;
    scrollbar-width: thin;
    scrollbar-color: var(--stone) transparent;
}

.scroll-rail::-webkit-scrollbar { height: 6px; }
.scroll-rail::-webkit-scrollbar-thumb {
    background: var(--stone);
    border-radius: 3px;
    opacity: 0.4;
}
.scroll-rail::-webkit-scrollbar-track { background: transparent; }

.scroll-card {
    flex: 0 0 auto;
    min-width: min(80vw, 760px);
    max-width: 80vw;
    scroll-snap-align: center;
    padding: clamp(2.5rem, 6vh, 5rem) clamp(2rem, 6vw, 5rem);
    position: relative;
    border-radius: 4px;
    background:
        radial-gradient(ellipse 60% 45% at 28% 30%, color-mix(in srgb, var(--w1) 18%, transparent) 0%, transparent 60%),
        radial-gradient(ellipse 55% 45% at 75% 60%, color-mix(in srgb, var(--w2) 14%, transparent) 0%, transparent 55%),
        radial-gradient(ellipse 70% 55% at 45% 90%, color-mix(in srgb, var(--w3) 11%, transparent) 0%, transparent 65%),
        linear-gradient(180deg, rgba(250,245,238,0.6), rgba(250,245,238,0.4));
    transition: transform 0.6s cubic-bezier(0.22, 1, 0.36, 1);
}

.scroll-card:hover { transform: translateY(-6px); }

.card-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-family: var(--font-ui);
    font-size: 0.78rem;
    letter-spacing: 0.18em;
    color: var(--stone);
    margin-bottom: 2rem;
}

.card-num {
    color: var(--gold);
    font-weight: 500;
}

.card-cat {
    text-transform: uppercase;
}

.card-name {
    font-family: var(--font-brush);
    font-size: clamp(4.5rem, 11vw, 8rem);
    color: var(--ink);
    line-height: 1.0;
    letter-spacing: 0.08em;
    margin-bottom: 0.2rem;
}

.card-underline {
    display: block;
    width: clamp(180px, 30vw, 320px);
    height: 22px;
    margin: -0.2rem 0 1.4rem;
    opacity: 0.75;
}

.card-hanja {
    font-family: var(--font-han);
    font-weight: 600;
    font-size: 2rem;
    letter-spacing: 0.5em;
    color: var(--cinnabar);
    margin-bottom: 1.2rem;
}

.card-meaning {
    font-family: var(--font-body);
    font-style: italic;
    font-size: 1.15rem;
    color: var(--ink);
    margin-bottom: 1.4rem;
}

.card-body {
    font-family: var(--font-body);
    font-size: 0.98rem;
    color: var(--ink);
    line-height: 1.85;
    max-width: 42em;
    margin-bottom: 2rem;
    opacity: 0.88;
}

.card-stats {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: 1.2rem;
    border-top: 1px solid color-mix(in srgb, var(--stone) 30%, transparent);
    padding-top: 1.4rem;
    max-width: 540px;
}

.card-stats > div {
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
}

.card-stats span {
    font-family: var(--font-ui);
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.18em;
    color: var(--stone);
}

.card-stats strong {
    font-family: var(--font-han);
    font-weight: 600;
    font-size: 1.05rem;
    color: var(--ink);
}

.card-seal {
    position: absolute;
    right: clamp(1.2rem, 3vw, 2.4rem);
    bottom: clamp(1.2rem, 3vw, 2.4rem);
    width: clamp(48px, 5.5vw, 70px);
    height: clamp(48px, 5.5vw, 70px);
    transform: rotate(-5deg);
    opacity: 0.88;
}

.card-seal svg { width: 100%; height: 100%; }

.rail-controls {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1.5rem;
    padding: 1rem 0 3rem;
}

.rail-btn {
    background: transparent;
    border: 1px solid color-mix(in srgb, var(--stone) 50%, transparent);
    color: var(--ink);
    width: 44px;
    height: 44px;
    border-radius: 50%;
    font-family: var(--font-body);
    font-size: 1.2rem;
    cursor: pointer;
    transition: background 0.4s, color 0.4s, border-color 0.4s;
}

.rail-btn:hover {
    background: var(--cinnabar);
    color: var(--paper);
    border-color: var(--cinnabar);
}

.rail-dots {
    display: flex;
    gap: 0.6rem;
}

.rail-dots .dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: color-mix(in srgb, var(--stone) 35%, transparent);
    transition: background 0.4s, transform 0.4s;
    cursor: pointer;
}

.rail-dots .dot.is-active {
    background: var(--cinnabar);
    transform: scale(1.4);
}

/* ==========================================================
   ANATOMY
   ========================================================== */
.anatomy-section {
    padding: 10vh 0 8vh;
    background:
        radial-gradient(ellipse 50% 40% at 18% 20%, rgba(74,111,165,0.06) 0%, transparent 70%),
        radial-gradient(ellipse 50% 40% at 82% 80%, rgba(196,122,147,0.06) 0%, transparent 70%);
}

.anatomy-stage {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 clamp(1.5rem, 6vw, 6rem);
    position: relative;
}

.anatomy-name {
    text-align: center;
    margin-bottom: 1rem;
    display: flex;
    justify-content: center;
    gap: clamp(2rem, 8vw, 6rem);
}

.big-syl {
    font-family: var(--font-brush);
    font-size: clamp(5rem, 12vw, 9rem);
    line-height: 1;
    color: var(--ink);
    cursor: pointer;
    transition: color 0.6s, transform 0.6s;
}

.big-syl:hover, .big-syl.is-focused {
    color: var(--cinnabar);
    transform: translateY(-4px) rotate(-1deg);
}

.anatomy-flow {
    display: block;
    width: 100%;
    height: 200px;
    margin: -1rem 0 -2rem;
    opacity: 0.55;
    pointer-events: none;
}

.flow-curve {
    fill: none;
    stroke: var(--ink);
    stroke-width: 1.2;
    stroke-linecap: round;
    stroke-dasharray: 600;
    stroke-dashoffset: 600;
    animation: drawFlow 3s ease-out forwards;
}

.anatomy-flow .flow-curve:nth-of-type(2) { animation-delay: 0.4s; }

@keyframes drawFlow {
    to { stroke-dashoffset: 0; }
}

.flow-node {
    fill: var(--cinnabar);
    opacity: 0;
    animation: nodeIn 0.6s 2.4s ease-out forwards;
}

@keyframes nodeIn { to { opacity: 0.9; } }

.anatomy-grid {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    gap: 2rem;
    align-items: stretch;
    margin-top: 1rem;
}

.syl-card {
    padding: 2rem 2.2rem;
    background:
        radial-gradient(ellipse 60% 40% at 25% 25%, rgba(74,111,165,0.10) 0%, transparent 60%),
        radial-gradient(ellipse 55% 45% at 75% 75%, rgba(196,154,60,0.08) 0%, transparent 60%),
        rgba(250,245,238,0.5);
    border-radius: 4px;
    transition: transform 0.6s, box-shadow 0.6s;
}

.syl-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 18px 36px -28px rgba(45,37,32,0.4);
}

.syl-han {
    font-family: var(--font-han);
    font-weight: 600;
    font-size: clamp(3.5rem, 6vw, 5rem);
    color: var(--cinnabar);
    line-height: 1;
    margin-bottom: 1rem;
}

.syl-gloss {
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
    margin-bottom: 1.6rem;
}

.syl-rom {
    font-family: var(--font-ui);
    font-size: 0.78rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--stone);
}

.syl-mean {
    font-family: var(--font-body);
    font-style: italic;
    font-size: 1.15rem;
    color: var(--ink);
}

.syl-detail {
    list-style: none;
    display: grid;
    gap: 0.6rem;
    margin-bottom: 1.4rem;
    padding-bottom: 1.2rem;
    border-bottom: 1px dashed color-mix(in srgb, var(--stone) 40%, transparent);
}

.syl-detail li {
    display: flex;
    justify-content: space-between;
    font-family: var(--font-ui);
    font-size: 0.85rem;
}

.syl-detail span { color: var(--stone); letter-spacing: 0.06em; }
.syl-detail strong { color: var(--ink); font-weight: 500; }

.syl-note {
    font-family: var(--font-body);
    font-size: 0.95rem;
    line-height: 1.8;
    color: var(--ink);
    opacity: 0.9;
}

.syl-bridge {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 0 1rem;
}

.bridge-glyph {
    font-family: var(--font-brush);
    font-size: 4rem;
    color: var(--gold);
    line-height: 1;
    margin-bottom: 0.6rem;
}

.bridge-text {
    font-family: var(--font-body);
    font-style: italic;
    font-size: 0.9rem;
    color: var(--stone);
    line-height: 1.7;
}

.bridge-text em { color: var(--cinnabar); font-style: italic; }

.anatomy-coda {
    margin-top: 3rem;
    text-align: center;
    font-family: var(--font-body);
    font-style: italic;
    font-size: 1.05rem;
    color: var(--ink);
    max-width: 40em;
    margin-left: auto;
    margin-right: auto;
}

.anatomy-coda em {
    color: var(--cinnabar);
    font-family: var(--font-han);
    font-style: normal;
    letter-spacing: 0.2em;
}

/* ==========================================================
   GENERATOR
   ========================================================== */
.generator-section {
    padding: 10vh 0 12vh;
}

.gen-stage {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 clamp(1.5rem, 6vw, 6rem);
    display: grid;
    grid-template-columns: minmax(280px, 360px) 1fr;
    gap: 3rem;
    align-items: start;
}

.gen-controls {
    display: flex;
    flex-direction: column;
    gap: 1.6rem;
    padding: 2rem;
    background:
        radial-gradient(ellipse 70% 40% at 30% 20%, rgba(196,122,147,0.10) 0%, transparent 60%),
        radial-gradient(ellipse 60% 40% at 70% 80%, rgba(74,111,165,0.08) 0%, transparent 60%);
    border-radius: 4px;
}

.gen-field {
    display: flex;
    flex-direction: column;
    gap: 0.6rem;
}

.gen-label {
    font-family: var(--font-ui);
    font-size: 0.75rem;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--stone);
}

#genSurname {
    font-family: var(--font-han);
    font-size: 1.1rem;
    color: var(--ink);
    background: rgba(250,245,238,0.7);
    border: 1px solid color-mix(in srgb, var(--stone) 35%, transparent);
    padding: 0.7rem 1rem;
    border-radius: 3px;
    cursor: pointer;
    transition: border-color 0.4s;
}

#genSurname:hover { border-color: var(--cinnabar); }

.gen-radio {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.gen-radio button {
    font-family: var(--font-ui);
    font-size: 0.82rem;
    background: transparent;
    border: 1px solid color-mix(in srgb, var(--stone) 35%, transparent);
    color: var(--stone);
    padding: 0.5rem 0.9rem;
    border-radius: 999px;
    cursor: pointer;
    transition: background 0.4s, color 0.4s, border-color 0.4s;
}

.gen-radio button:hover { color: var(--ink); border-color: var(--ink); }
.gen-radio button.active {
    background: var(--ink);
    color: var(--paper);
    border-color: var(--ink);
}

.gen-btn {
    font-family: var(--font-body);
    cursor: pointer;
    background: var(--cinnabar);
    color: var(--paper);
    border: none;
    padding: 1rem 1.4rem;
    border-radius: 3px;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 0.15rem;
    line-height: 1;
    transition: background 0.4s, transform 0.4s;
}

.gen-btn:hover {
    background: #9a3a2c;
    transform: translateY(-2px);
}

.btn-kr {
    font-family: var(--font-brush);
    font-size: 1.6rem;
}

.btn-en {
    font-family: var(--font-ui);
    font-size: 0.7rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    opacity: 0.85;
}

.gen-results {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 1.4rem;
    min-height: 340px;
}

.gen-result {
    position: relative;
    padding: 2rem 1.6rem 2.4rem;
    background:
        radial-gradient(ellipse 60% 45% at 28% 30%, var(--gw1) 0%, transparent 60%),
        radial-gradient(ellipse 55% 45% at 75% 70%, var(--gw2) 0%, transparent 60%),
        rgba(250,245,238,0.55);
    border-radius: 4px;
    opacity: 0;
    transform: translateY(20px);
    animation: fadeUp 0.9s cubic-bezier(0.22, 1, 0.36, 1) forwards;
}

@keyframes fadeUp {
    to { opacity: 1; transform: translateY(0); }
}

.gen-result-name {
    font-family: var(--font-brush);
    font-size: clamp(3rem, 5vw, 4.4rem);
    color: var(--ink);
    line-height: 1;
    margin-bottom: 0.4rem;
}

.gen-result-rom {
    font-family: var(--font-ui);
    font-size: 0.78rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--stone);
    margin-bottom: 1rem;
}

.gen-result-hanja {
    font-family: var(--font-han);
    font-weight: 600;
    font-size: 1.4rem;
    letter-spacing: 0.4em;
    color: var(--cinnabar);
    margin-bottom: 0.8rem;
}

.gen-result-meaning {
    font-family: var(--font-body);
    font-style: italic;
    font-size: 0.98rem;
    color: var(--ink);
    line-height: 1.7;
}

.gen-result-seal {
    position: absolute;
    right: 0.9rem;
    bottom: 0.9rem;
    width: 38px;
    height: 38px;
    transform: rotate(-5deg);
    opacity: 0.85;
}

.gen-empty {
    grid-column: 1 / -1;
    text-align: center;
    font-family: var(--font-body);
    font-style: italic;
    color: var(--stone);
    padding: 4rem 2rem;
    border: 1px dashed color-mix(in srgb, var(--stone) 30%, transparent);
    border-radius: 4px;
}

/* ==========================================================
   FOOTER
   ========================================================== */
.page-footer {
    display: flex;
    align-items: center;
    gap: 2rem;
    padding: 4rem clamp(1.5rem, 6vw, 6rem);
    border-top: 1px solid color-mix(in srgb, var(--stone) 25%, transparent);
    background: rgba(250,245,238,0.4);
}

.footer-mark {
    width: 60px;
    height: 60px;
    transform: rotate(-5deg);
    flex-shrink: 0;
    opacity: 0.85;
}

.footer-mark svg { width: 100%; height: 100%; }

.footer-line {
    font-family: var(--font-brush);
    font-size: 1.6rem;
    color: var(--ink);
    margin-bottom: 0.4rem;
}

.footer-line em {
    font-style: normal;
    color: var(--cinnabar);
}

.footer-credit {
    font-family: var(--font-ui);
    font-size: 0.78rem;
    color: var(--stone);
    line-height: 1.7;
}

/* ==========================================================
   RESPONSIVE
   ========================================================== */
@media (max-width: 880px) {
    .topnav { padding: 1rem 1.2rem; }
    .navlinks { display: none; }
    .anatomy-grid {
        grid-template-columns: 1fr;
        gap: 1.4rem;
    }
    .syl-bridge { padding: 0.6rem; }
    .anatomy-flow { display: none; }
    .gen-stage { grid-template-columns: 1fr; }
    .scroll-card { min-width: 88vw; padding: 2.5rem 1.8rem; }
    .card-stats { grid-template-columns: 1fr 1fr; }
    .page-footer { flex-direction: column; align-items: flex-start; gap: 1rem; }
}

@media (max-width: 540px) {
    .hero-paper { padding: 3rem 1.2rem; }
    .hero-name { font-size: clamp(4rem, 22vw, 7rem); }
    .scroll-card { min-width: 92vw; }
    .card-name { font-size: clamp(3.6rem, 16vw, 5rem); }
    .anatomy-name { gap: 1.6rem; }
}
