/* bada.coffee — deep-water minimalism · sci-fi HUD */

:root {
    --bada-abyss: #070A0E;
    --bada-deep: #0F1620;
    --bada-tide: #1B2838;
    --bada-mist: #8A97A8;
    --bada-foam: #E8EDF2;
    --bada-ember: #D2541A;
    --bada-ember-hot: #F0711C;
    --bada-ember-glow: rgba(210, 84, 26, 0.18);

    --motion-fast: 120ms;
    --motion-base: 220ms;
    --motion-slow: 400ms;
    --ease-hud: cubic-bezier(0.2, 0.8, 0.2, 1);

    --gutter: clamp(24px, 4vw, 72px);
    --hud-pad: 28px;

    --font-display: 'Commissioner', 'Inter', system-ui, sans-serif;
    --font-body: 'Commissioner', 'Inter', system-ui, sans-serif;
    --font-mono: 'Space Mono', 'Inter', ui-monospace, monospace;
}

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

html, body {
    background: var(--bada-abyss);
    color: var(--bada-foam);
    font-family: var(--font-body);
    font-weight: 380;
    font-size: 17px;
    line-height: 1.65;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
    overflow-x: hidden;
}

body {
    min-height: 100vh;
    position: relative;
    background:
        radial-gradient(1200px 700px at 12% -10%, rgba(27, 40, 56, 0.55), transparent 60%),
        radial-gradient(900px 600px at 95% 20%, rgba(210, 84, 26, 0.05), transparent 60%),
        var(--bada-abyss);
}

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

/* HUD frame */
.hud-frame {
    position: fixed;
    inset: var(--hud-pad);
    pointer-events: none;
    z-index: 5;
}
.hud-corner {
    position: absolute;
    width: 22px;
    height: 22px;
    border: 1px solid var(--bada-tide);
}
.hud-corner--tl { top: 0; left: 0; border-right: none; border-bottom: none; }
.hud-corner--tr { top: 0; right: 0; border-left: none; border-bottom: none; }
.hud-corner--bl { bottom: 0; left: 0; border-right: none; border-top: none; }
.hud-corner--br { bottom: 0; right: 0; border-left: none; border-top: none; }

/* cursor companion */
.cursor-companion {
    position: fixed;
    width: 8px; height: 8px;
    border-radius: 50%;
    background: var(--bada-ember);
    pointer-events: none;
    transform: translate(-50%, -50%);
    transition: opacity var(--motion-base) var(--ease-hud);
    opacity: 0;
    z-index: 9999;
    box-shadow: 0 0 14px var(--bada-ember-glow);
    mix-blend-mode: screen;
}
.cursor-companion.is-active { opacity: 0.7; }
@media (hover: none) { .cursor-companion { display: none; } }

/* HEADER */
.site-header {
    position: fixed;
    top: 0; left: 0; right: 0;
    z-index: 50;
    height: 64px;
    padding: 0 calc(var(--gutter) + 12px);
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: 32px;
    backdrop-filter: blur(10px) saturate(120%);
    -webkit-backdrop-filter: blur(10px) saturate(120%);
    background: linear-gradient(180deg, rgba(7, 10, 14, 0.85) 0%, rgba(7, 10, 14, 0.55) 100%);
    border-bottom: 1px solid var(--bada-tide);
}
.brand {
    display: flex;
    align-items: center;
    gap: 12px;
    color: var(--bada-foam);
    font-weight: 700;
    letter-spacing: -0.01em;
    font-size: 1rem;
}
.brand__mark {
    position: relative;
    width: 32px; height: 32px;
    color: var(--bada-ember);
    display: inline-flex;
    align-items: center; justify-content: center;
}
.brand__svg { width: 100%; height: 100%; display: block; }
.brand__pulse {
    position: absolute;
    inset: -4px;
    border-radius: 50%;
    background: radial-gradient(circle, var(--bada-ember-glow), transparent 60%);
    opacity: 0;
    pointer-events: none;
}
.brand__pulse.is-pinging {
    animation: sonar 1200ms var(--ease-hud);
}
@keyframes sonar {
    0% { opacity: 0; transform: scale(0.8); }
    30% { opacity: 1; }
    100% { opacity: 0; transform: scale(2.4); }
}
.brand__name { display: inline-flex; align-items: baseline; }
.brand__dot { color: var(--bada-ember); }

.primary-nav {
    display: flex;
    justify-content: center;
    gap: 28px;
    font-size: 0.74rem;
    text-transform: uppercase;
    letter-spacing: 0.18em;
    font-weight: 500;
    color: var(--bada-mist);
}
.primary-nav a {
    position: relative;
    padding: 8px 4px;
    color: var(--bada-mist);
    transition: color var(--motion-base) var(--ease-hud);
}
.primary-nav a::before,
.primary-nav a::after {
    content: '';
    position: absolute;
    width: 6px; height: 6px;
    border: 1px solid var(--bada-ember);
    opacity: 0;
    transition: opacity var(--motion-fast) var(--ease-hud);
}
.primary-nav a::before {
    top: 0; left: 0;
    border-right: none; border-bottom: none;
}
.primary-nav a::after {
    bottom: 0; right: 0;
    border-left: none; border-top: none;
}
.primary-nav a:hover,
.primary-nav a.is-active { color: var(--bada-foam); }
.primary-nav a:hover::before,
.primary-nav a:hover::after,
.primary-nav a.is-active::before,
.primary-nav a.is-active::after { opacity: 1; }
.nav__en {
    display: inline-block;
    margin-inline-start: 6px;
    color: var(--bada-tide);
    letter-spacing: 0.16em;
    font-size: 0.66rem;
}

.header-meta {
    display: flex;
    align-items: baseline;
    gap: 10px;
    font-size: 0.7rem;
    letter-spacing: 0.16em;
    text-transform: uppercase;
}
.meta__label { color: var(--bada-mist); }
.meta__value {
    font-family: var(--font-mono);
    color: var(--bada-foam);
    font-feature-settings: 'tnum';
    letter-spacing: 0.04em;
}

/* DEPTH RULER */
.depth-ruler {
    position: fixed;
    top: 96px;
    left: var(--gutter);
    bottom: 32px;
    width: 14px;
    z-index: 30;
    display: flex;
    flex-direction: column;
    align-items: center;
    pointer-events: none;
    color: var(--bada-mist);
}
.ruler__label,
.ruler__readout {
    writing-mode: vertical-rl;
    text-orientation: mixed;
    font-size: 0.62rem;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    padding-block: 8px;
    color: var(--bada-mist);
    font-family: var(--font-mono);
}
.ruler__readout { color: var(--bada-ember); }
.ruler__track {
    flex: 1;
    width: 1px;
    background: linear-gradient(var(--bada-tide), var(--bada-tide) 50%, transparent 50%);
    background-size: 1px 8px;
    position: relative;
    margin-block: 6px;
}
.ruler__tick {
    position: absolute;
    left: -5px;
    top: calc(var(--p) * 100%);
    width: 11px;
    height: 1px;
    background: var(--bada-tide);
}
.ruler__tick:nth-child(5n+1) { width: 14px; left: -7px; background: var(--bada-mist); }
.ruler__cursor {
    position: absolute;
    left: -7px;
    top: 0;
    width: 14px;
    height: 2px;
    background: var(--bada-ember);
    box-shadow: 0 0 10px var(--bada-ember);
    transition: top var(--motion-fast) linear;
}

/* MAIN content */
main {
    margin-left: calc(var(--gutter) + 30px);
    margin-right: calc(var(--gutter) + 14px);
    padding-top: 64px;
}

/* HERO */
.hero {
    position: relative;
    min-height: 100vh;
    display: flex;
    align-items: center;
    padding-block: clamp(80px, 12vh, 160px);
    overflow: hidden;
}
.wave-field {
    position: absolute;
    inset: 0;
    width: 100%; height: 100%;
    z-index: 0;
    opacity: 0.6;
    pointer-events: none;
}
.hero__inner {
    position: relative;
    z-index: 2;
    width: min(100%, 1200px);
    display: grid;
    gap: clamp(24px, 4vh, 48px);
}
.hero__hudline {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    font-family: var(--font-mono);
    font-size: 0.72rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--bada-mist);
    border-top: 1px solid var(--bada-tide);
    border-bottom: 1px solid var(--bada-tide);
    padding-block: 10px;
    width: fit-content;
}
.hero__hudline .dot {
    width: 6px; height: 6px;
    border-radius: 50%;
    background: var(--bada-ember);
    box-shadow: 0 0 12px var(--bada-ember);
    animation: emberPulse 2400ms ease-in-out infinite;
}
@keyframes emberPulse {
    0%, 100% { opacity: 0.5; transform: scale(0.85); }
    50% { opacity: 1; transform: scale(1); }
}

.hero__title {
    font-family: var(--font-display);
    font-weight: 200;
    letter-spacing: -0.025em;
    line-height: 0.95;
    font-size: clamp(3.4rem, 9vw, 9rem);
    color: var(--bada-foam);
    text-transform: lowercase;
}
.hero__line { display: block; }
.hero__line--accent { color: var(--bada-ember); font-weight: 380; font-style: italic; }
.hero__line--small {
    font-weight: 380;
    font-size: clamp(1rem, 1.6vw, 1.4rem);
    letter-spacing: 0.02em;
    margin-top: clamp(14px, 2vh, 24px);
    color: var(--bada-mist);
    text-transform: none;
}
.hero__lede {
    max-width: 56ch;
    color: var(--bada-foam);
    font-size: 1.08rem;
    line-height: 1.65;
    opacity: 0.86;
}
.hero__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
}
.hero__readouts {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: 0;
    border-top: 1px solid var(--bada-tide);
    border-bottom: 1px solid var(--bada-tide);
    margin-top: clamp(20px, 3vh, 40px);
}
.readout {
    padding: 16px 18px;
    border-right: 1px solid var(--bada-tide);
    display: grid;
    gap: 6px;
}
.readout:last-child { border-right: none; }
.readout__label {
    font-family: var(--font-mono);
    font-size: 0.66rem;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--bada-mist);
}
.readout__value {
    font-family: var(--font-mono);
    font-weight: 700;
    font-size: 1.4rem;
    color: var(--bada-foam);
    font-feature-settings: 'tnum';
    letter-spacing: 0.02em;
}

.hero__scanbar {
    position: absolute;
    inset: auto 0 22% 0;
    height: 1px;
    background: linear-gradient(90deg, transparent, var(--bada-ember) 50%, transparent);
    opacity: 0.5;
    transform: translateX(-100%);
    animation: scanSweep 6s var(--ease-hud) infinite;
}
@keyframes scanSweep {
    0% { transform: translateX(-100%); opacity: 0; }
    25% { opacity: 0.9; }
    100% { transform: translateX(100%); opacity: 0; }
}

/* CTAs */
.cta {
    position: relative;
    display: inline-flex;
    align-items: center;
    gap: 14px;
    padding: 14px 22px;
    font-family: var(--font-mono);
    font-size: 0.78rem;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    border: 1px solid var(--bada-ember);
    color: var(--bada-foam);
    overflow: hidden;
    transition: color var(--motion-base) var(--ease-hud), border-color var(--motion-base) var(--ease-hud);
    cursor: pointer;
    background: transparent;
}
.cta::before {
    content: '';
    position: absolute; inset: 0;
    background: var(--bada-ember);
    transform: scaleX(0);
    transform-origin: left center;
    transition: transform var(--motion-base) var(--ease-hud);
    z-index: -1;
}
.cta:hover { color: var(--bada-abyss); border-color: var(--bada-ember-hot); }
.cta:hover::before { transform: scaleX(1); background: var(--bada-ember-hot); }
.cta__arrow { transition: transform var(--motion-base) var(--ease-hud); }
.cta:hover .cta__arrow { transform: translateX(4px); }
.cta--ghost {
    border-color: var(--bada-tide);
    color: var(--bada-mist);
}
.cta--ghost::before { background: var(--bada-foam); }
.cta--ghost:hover { color: var(--bada-abyss); border-color: var(--bada-foam); }

/* Section heads */
.section-head {
    display: grid;
    gap: 14px;
    margin-block: clamp(60px, 10vh, 120px) clamp(40px, 6vh, 80px);
    max-width: 60ch;
}
.section-head__kicker {
    font-family: var(--font-mono);
    font-size: 0.72rem;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--bada-ember);
    display: inline-flex;
    align-items: center;
    gap: 12px;
}
.section-head__kicker::after {
    content: '';
    width: 80px; height: 1px;
    background: var(--bada-ember);
    opacity: 0.6;
}
.section-head__title {
    font-family: var(--font-display);
    font-weight: 700;
    font-size: clamp(2rem, 4.4vw, 4rem);
    line-height: 1.05;
    letter-spacing: -0.015em;
    color: var(--bada-foam);
    text-transform: lowercase;
}
.section-head__title em {
    font-style: italic;
    font-weight: 200;
    color: var(--bada-mist);
}
.section-head__sub {
    color: var(--bada-mist);
    max-width: 50ch;
}

/* COORDINATES grid */
.origin-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 0;
    border-top: 1px solid var(--bada-tide);
}
.origin {
    position: relative;
    padding: 28px;
    border-right: 1px solid var(--bada-tide);
    border-bottom: 1px solid var(--bada-tide);
    display: grid;
    gap: 18px;
    align-content: start;
    background: linear-gradient(180deg, transparent, rgba(15, 22, 32, 0.3));
    transition: background var(--motion-base) var(--ease-hud);
}
.origin:last-child { border-right: none; }
.origin:hover { background: linear-gradient(180deg, rgba(15, 22, 32, 0.4), rgba(15, 22, 32, 0.7)); }
.origin::before {
    content: '';
    position: absolute;
    top: 0; left: 0;
    width: 0;
    height: 1px;
    background: var(--bada-ember);
    transition: width var(--motion-slow) var(--ease-hud);
}
.origin:hover::before { width: 100%; }
.origin__header {
    display: flex;
    justify-content: space-between;
    font-family: var(--font-mono);
    font-size: 0.7rem;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--bada-mist);
}
.origin__country { color: var(--bada-ember); }
.origin__map {
    aspect-ratio: 1 / 1;
    border: 1px solid var(--bada-tide);
    background: var(--bada-deep);
    display: grid;
    place-items: center;
    overflow: hidden;
}
.origin__map svg { width: 100%; height: 100%; display: block; }
.origin__title {
    font-family: var(--font-display);
    font-weight: 700;
    font-size: 1.4rem;
    letter-spacing: -0.01em;
    color: var(--bada-foam);
}
.origin__notes { color: var(--bada-mist); font-size: 0.96rem; line-height: 1.6; }
.origin__specs {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    border-top: 1px solid var(--bada-tide);
    padding-top: 14px;
    gap: 10px 14px;
}
.origin__specs > div { display: grid; gap: 4px; }
.origin__specs dt {
    font-family: var(--font-mono);
    font-size: 0.62rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--bada-mist);
}
.origin__specs dd {
    font-family: var(--font-mono);
    font-weight: 700;
    color: var(--bada-foam);
    font-size: 0.95rem;
    font-feature-settings: 'tnum';
    letter-spacing: 0.04em;
}
.origin__foot {
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-top: 1px solid var(--bada-tide);
    padding-top: 14px;
    margin-top: 6px;
}
.origin__price {
    font-family: var(--font-mono);
    font-weight: 700;
    color: var(--bada-foam);
    letter-spacing: 0.04em;
}
.origin__link {
    position: relative;
    font-family: var(--font-mono);
    font-size: 0.78rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--bada-ember);
    padding-bottom: 2px;
}
.origin__link::after {
    content: '';
    position: absolute;
    left: 0; bottom: 0;
    width: 100%;
    height: 1px;
    background: var(--bada-ember);
    transform: scaleX(0);
    transform-origin: left;
    transition: transform var(--motion-base) var(--ease-hud);
}
.origin__link:hover::after { transform: scaleX(1); }

/* DEPTH section */
.depth-section {
    position: relative;
    padding-block: clamp(60px, 8vh, 120px);
}
.depth__head { margin-bottom: clamp(40px, 6vh, 80px); display: grid; gap: 14px; }
.depth__grid {
    display: grid;
    grid-template-columns: 1fr 1.2fr;
    gap: clamp(40px, 6vw, 100px);
    align-items: start;
}
.depth__diagram {
    border: 1px solid var(--bada-tide);
    padding: 30px;
    background: linear-gradient(180deg, rgba(15, 22, 32, 0.4), transparent);
}
.depth__diagram svg { width: 100%; height: auto; display: block; }
.depth__copy { display: grid; gap: 18px; max-width: 56ch; }
.depth__copy p { color: var(--bada-foam); }
.depth__list {
    list-style: none;
    display: grid;
    gap: 10px;
    margin-top: 12px;
    border-top: 1px solid var(--bada-tide);
    padding-top: 18px;
}
.depth__list li {
    display: grid;
    grid-template-columns: 40px 1fr;
    gap: 16px;
    align-items: baseline;
    color: var(--bada-mist);
    line-height: 1.55;
    padding-block: 8px;
    border-bottom: 1px dotted var(--bada-tide);
}
.depth__num {
    font-family: var(--font-mono);
    color: var(--bada-ember);
    font-size: 0.78rem;
    letter-spacing: 0.18em;
}

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

/* SHOP */
.shop__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 18px;
}
.log {
    position: relative;
    padding: 24px;
    border: 1px solid var(--bada-tide);
    background:
        linear-gradient(180deg, rgba(15, 22, 32, 0.55), rgba(7, 10, 14, 0.7)),
        repeating-linear-gradient(
            0deg,
            transparent 0,
            transparent 22px,
            rgba(27, 40, 56, 0.18) 22px,
            rgba(27, 40, 56, 0.18) 23px
        );
    display: grid;
    gap: 16px;
    transition: border-color var(--motion-base) var(--ease-hud), transform var(--motion-base) var(--ease-hud);
}
.log:hover { border-color: var(--bada-ember); transform: translateY(-2px); }
.log__head {
    display: flex;
    justify-content: space-between;
    font-family: var(--font-mono);
    font-size: 0.66rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--bada-mist);
    border-bottom: 1px solid var(--bada-tide);
    padding-bottom: 10px;
}
.log__status { color: var(--bada-ember); }
.log__title {
    font-family: var(--font-display);
    font-weight: 700;
    font-size: 1.3rem;
    color: var(--bada-foam);
    letter-spacing: -0.01em;
}
.log__notes {
    color: var(--bada-mist);
    font-size: 0.96rem;
    font-style: italic;
}
.log__bars { display: grid; gap: 10px; }
.bar {
    display: grid;
    grid-template-columns: 56px 1fr 40px;
    align-items: center;
    gap: 10px;
}
.bar__l, .bar__v {
    font-family: var(--font-mono);
    font-size: 0.68rem;
    letter-spacing: 0.16em;
    text-transform: uppercase;
}
.bar__l { color: var(--bada-mist); }
.bar__v { color: var(--bada-foam); text-align: right; font-feature-settings: 'tnum'; }
.bar__t {
    position: relative;
    height: 4px;
    background: var(--bada-tide);
    overflow: hidden;
}
.bar__t i {
    position: absolute;
    inset: 0 auto 0 0;
    width: var(--w, 0%);
    background: linear-gradient(90deg, var(--bada-ember), var(--bada-ember-hot));
    transform-origin: left;
    transform: scaleX(0);
    animation: barFill 1200ms var(--ease-hud) forwards;
    animation-play-state: paused;
}
.log.in-view .bar__t i { animation-play-state: running; }
@keyframes barFill { to { transform: scaleX(1); } }

.log__foot {
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-top: 1px solid var(--bada-tide);
    padding-top: 12px;
}
.log__price {
    font-family: var(--font-mono);
    font-weight: 700;
    color: var(--bada-foam);
    letter-spacing: 0.04em;
    font-size: 1rem;
}
.log__buy {
    background: transparent;
    border: 1px solid var(--bada-ember);
    color: var(--bada-ember);
    padding: 8px 14px;
    font-family: var(--font-mono);
    font-size: 0.7rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    cursor: pointer;
    transition: background var(--motion-base) var(--ease-hud), color var(--motion-base) var(--ease-hud);
}
.log__buy:hover {
    background: var(--bada-ember-hot);
    color: var(--bada-abyss);
    border-color: var(--bada-ember-hot);
}

/* JOURNAL */
.journal__list {
    list-style: none;
    display: grid;
    gap: 0;
    border-top: 1px solid var(--bada-tide);
}
.journal__entry {
    display: grid;
    grid-template-columns: 180px 1fr;
    gap: 32px;
    padding: 28px 4px;
    border-bottom: 1px solid var(--bada-tide);
    transition: background var(--motion-base) var(--ease-hud);
}
.journal__entry:hover { background: rgba(15, 22, 32, 0.4); }
.journal__date {
    font-family: var(--font-mono);
    font-size: 0.74rem;
    letter-spacing: 0.18em;
    color: var(--bada-mist);
    align-self: start;
    padding-top: 4px;
}
.journal__title {
    font-family: var(--font-display);
    font-weight: 700;
    font-size: 1.3rem;
    color: var(--bada-foam);
    letter-spacing: -0.005em;
    margin-bottom: 8px;
    transition: color var(--motion-base) var(--ease-hud);
}
.journal__entry:hover .journal__title { color: var(--bada-ember); }
.journal__entry p { color: var(--bada-mist); max-width: 60ch; }

@media (max-width: 720px) {
    .journal__entry { grid-template-columns: 1fr; gap: 6px; }
}

/* CONTACT */
.contact {
    position: relative;
    padding-block: clamp(80px, 12vh, 140px);
    background:
        radial-gradient(800px 400px at 30% 0%, rgba(210, 84, 26, 0.06), transparent 60%),
        linear-gradient(180deg, transparent, rgba(15, 22, 32, 0.5));
    border-top: 1px solid var(--bada-tide);
    margin-top: clamp(60px, 8vh, 100px);
}
.contact__inner {
    max-width: 880px;
    display: grid;
    gap: 18px;
}
.contact__lede { color: var(--bada-mist); max-width: 56ch; }
.contact__form {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 18px;
    margin-top: 24px;
    padding-top: 24px;
    border-top: 1px solid var(--bada-tide);
}
.field { display: grid; gap: 8px; }
.field--full { grid-column: 1 / -1; }
.field__label {
    font-family: var(--font-mono);
    font-size: 0.66rem;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--bada-mist);
}
.field input,
.field textarea {
    background: transparent;
    border: none;
    border-bottom: 1px solid var(--bada-tide);
    padding: 12px 2px;
    color: var(--bada-foam);
    font-family: var(--font-body);
    font-size: 1rem;
    outline: none;
    transition: border-color var(--motion-base) var(--ease-hud);
    resize: vertical;
}
.field input:focus,
.field textarea:focus { border-color: var(--bada-ember); }

.contact__form .cta {
    grid-column: 1 / -1;
    justify-self: start;
    margin-top: 8px;
}

.contact__meta {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 24px;
    margin-top: 40px;
    padding-top: 24px;
    border-top: 1px solid var(--bada-tide);
}
.contact__meta > div {
    display: grid;
    gap: 6px;
}

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

/* FOOTER */
.site-footer {
    margin: clamp(60px, 8vh, 120px) calc(var(--gutter) + 14px) calc(var(--hud-pad) + 30px) calc(var(--gutter) + 30px);
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 32px;
    padding-top: 40px;
    border-top: 1px solid var(--bada-tide);
}
.foot__col { display: grid; gap: 12px; align-content: start; font-size: 0.92rem; }
.foot__col ul { list-style: none; display: grid; gap: 6px; color: var(--bada-mist); }
.foot__col a {
    position: relative;
    color: var(--bada-mist);
    transition: color var(--motion-base) var(--ease-hud);
}
.foot__col a::after {
    content: '';
    position: absolute;
    left: 0; bottom: -2px;
    width: 0; height: 1px;
    background: var(--bada-ember);
    transition: width var(--motion-base) var(--ease-hud);
}
.foot__col a:hover { color: var(--bada-foam); }
.foot__col a:hover::after { width: 100%; }
.foot__col--meta { gap: 8px; }
.ember-dot {
    display: inline-block;
    width: 6px; height: 6px; border-radius: 50%;
    background: var(--bada-ember);
    box-shadow: 0 0 10px var(--bada-ember);
    margin-inline-end: 8px;
    vertical-align: middle;
    animation: emberPulse 2400ms ease-in-out infinite;
}
.meta__small {
    font-family: var(--font-mono);
    font-size: 0.7rem;
    color: var(--bada-tide);
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

@media (max-width: 880px) {
    .site-footer { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 520px) {
    .site-footer { grid-template-columns: 1fr; }
}

/* REVEAL */
.reveal {
    opacity: 0;
    transform: translateY(28px);
    transition: opacity var(--motion-slow) var(--ease-hud), transform var(--motion-slow) var(--ease-hud);
}
.reveal.in-view {
    opacity: 1;
    transform: translateY(0);
}

/* responsive header tweaks */
@media (max-width: 980px) {
    .primary-nav { gap: 16px; font-size: 0.66rem; }
    .nav__en { display: none; }
    .header-meta { display: none; }
    .site-header { grid-template-columns: auto 1fr; }
}
@media (max-width: 720px) {
    .primary-nav { display: none; }
    .depth-ruler { display: none; }
    main { margin-left: var(--gutter); margin-right: var(--gutter); }
    .site-footer { margin-left: var(--gutter); margin-right: var(--gutter); }
}
