/* ============================================================
   EDITORIAL.CSS — Premium $10K-tier home sections
   Refined ink + sand + brass · Editorial typography · Restraint
   ============================================================ */

/* ── Body & section base for editorial pages ─────────────────── */
body { background: var(--dm-bone); color: var(--dm-ink); }

.dm-section-editorial {
    padding: var(--dm-section-y) 0;
    position: relative;
}
.dm-section-editorial--sand   { background: var(--dm-sand); }
.dm-section-editorial--ink    { background: var(--dm-ink); color: rgba(255,255,255,0.78); }
.dm-section-editorial--ink h2,
.dm-section-editorial--ink h3 { color: #fff; }

/* Refined eyebrow */
.dm-edi-eyebrow {
    display: inline-block;
    font-family: var(--dm-font-body);
    font-size: 11px;
    letter-spacing: 0.24em;
    text-transform: uppercase;
    color: var(--dm-brass);
    font-weight: 600;
    margin-bottom: 18px;
}

/* Editorial h2 — bigger, italic */
.dm-edi-h2 {
    font-family: var(--dm-font-display);
    font-style: italic;
    font-weight: 500;
    font-size: var(--dm-fs-h2-xl);
    line-height: 1.04;
    letter-spacing: -0.01em;
    color: var(--dm-ink);
    margin: 0 0 var(--dm-space-4);
}

/* Hairline dividers */
.dm-hairline { border: 0; border-top: 1px solid var(--dm-stone); margin: var(--dm-space-7) 0; }
.dm-hairline--brass { border-top-color: var(--dm-brass-soft); }

/* Reveal on scroll */
[data-reveal] {
    opacity: 0;
    transform: translateY(40px);
    transition: opacity 800ms var(--dm-ease), transform 800ms var(--dm-ease);
}
[data-reveal].is-revealed { opacity: 1; transform: none; }

/* Ink button variant for hero */
.dm-btn--ink {
    background: var(--dm-ink);
    color: var(--dm-bone);
    border: 1px solid var(--dm-ink);
    border-radius: 0;
    padding: 16px 32px;
    font-size: 11px;
    letter-spacing: 0.16em;
}
.dm-btn--ink:hover { background: transparent; color: var(--dm-ink); }
.dm-btn--brass {
    background: transparent;
    color: var(--dm-ink);
    border: 1px solid var(--dm-ink);
    border-radius: 0;
    padding: 16px 32px;
    font-size: 11px;
    letter-spacing: 0.16em;
}
.dm-btn--brass:hover { background: var(--dm-ink); color: var(--dm-bone); }


/* ─── 01 · EDITORIAL HERO ─────────────────────────────────── */
.dm-eh {
    padding: clamp(48px, 8vw, 96px) 0 clamp(40px, 6vw, 72px);
    background: var(--dm-bone);
}
.dm-eh__inner {
    max-width: var(--dm-container);
    margin: 0 auto;
    padding: 0 var(--dm-space-5);
    display: grid;
    grid-template-columns: 1.1fr 0.9fr;
    gap: clamp(32px, 6vw, 96px);
    align-items: center;
    min-height: 70vh;
}
.dm-eh__copy { max-width: 560px; }
.dm-eh__eyebrow {
    display: inline-block;
    font-family: var(--dm-font-body);
    font-size: 11px;
    letter-spacing: 0.28em;
    text-transform: uppercase;
    color: var(--dm-brass);
    font-weight: 600;
    margin-bottom: 28px;
}
.dm-eh__headline {
    font-family: var(--dm-font-display);
    font-weight: 500;
    font-size: var(--dm-fs-display);
    line-height: 0.95;
    letter-spacing: -0.02em;
    color: var(--dm-ink);
    margin: 0 0 28px;
}
.dm-eh__headline em { font-style: italic; display: block; }
.dm-eh__sub {
    font-size: 17px;
    line-height: 1.7;
    color: var(--dm-ink-soft);
    margin: 0 0 36px;
    max-width: 460px;
}
.dm-eh__cta {
    display: flex;
    align-items: center;
    gap: 24px;
    flex-wrap: wrap;
}
.dm-eh__quietlink {
    color: var(--dm-ink);
    font-size: 13px;
    letter-spacing: 0.06em;
    border-bottom: 1px solid var(--dm-stone);
    padding-bottom: 2px;
    transition: border-color var(--dm-dur-1);
}
.dm-eh__quietlink:hover { border-bottom-color: var(--dm-brass); color: var(--dm-brass); }

.dm-eh__visual {
    position: relative;
    aspect-ratio: 4 / 5;
    background: var(--dm-sand);
    overflow: hidden;
}
.dm-eh__visual img {
    width: 100%; height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 1200ms var(--dm-ease);
}
.dm-eh:hover .dm-eh__visual img { transform: scale(1.03); }
.dm-eh__seal {
    position: absolute;
    top: 24px; right: 24px;
    width: 56px; height: 56px;
    border-radius: 50%;
    background: rgba(255,255,255,0.92);
    backdrop-filter: blur(8px);
    display: flex; align-items: center; justify-content: center;
    font-size: 24px;
    color: var(--dm-brass);
    font-family: var(--dm-font-display);
    font-style: italic;
}
.dm-eh__placeholder {
    width: 100%; height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, var(--dm-sand) 0%, var(--dm-stone) 100%);
    color: var(--dm-brass);
    font-family: var(--dm-font-display);
    font-style: italic;
    font-size: 96px;
    opacity: 0.4;
}

.dm-eh__numbered {
    max-width: var(--dm-container);
    margin: clamp(48px, 8vw, 96px) auto 0;
    padding: 0 var(--dm-space-5);
    list-style: none;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0;
    border-top: 1px solid var(--dm-stone);
}
.dm-eh__numbered li {
    padding: 28px 24px 0;
    display: flex;
    gap: 16px;
    align-items: baseline;
    color: var(--dm-ink);
    font-family: var(--dm-font-display);
    font-style: italic;
    font-size: 22px;
    border-right: 1px solid var(--dm-stone);
}
.dm-eh__numbered li:last-child { border-right: 0; }
.dm-eh__numbered li span {
    font-family: var(--dm-font-body);
    font-style: normal;
    font-size: 11px;
    letter-spacing: 0.20em;
    color: var(--dm-brass);
    font-weight: 600;
}

@media (max-width: 900px) {
    .dm-eh__inner { grid-template-columns: 1fr; min-height: auto; }
    .dm-eh__visual { order: -1; aspect-ratio: 4 / 3; }
    .dm-eh__numbered { grid-template-columns: 1fr; }
    .dm-eh__numbered li { border-right: 0; border-bottom: 1px solid var(--dm-stone); padding: 20px 0; }
    .dm-eh__numbered li:last-child { border-bottom: 0; }
}


/* ─── 02 · PROMISE BAR ────────────────────────────────────── */
.dm-promise {
    background: var(--dm-ink);
    color: rgba(255,255,255,0.85);
    padding: 28px 0;
}
.dm-promise__inner {
    max-width: var(--dm-container);
    margin: 0 auto;
    padding: 0 var(--dm-space-5);
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 0;
}
.dm-promise__item {
    display: flex;
    align-items: baseline;
    gap: 12px;
    padding: 0 24px;
    border-right: 1px solid rgba(255,255,255,0.10);
}
.dm-promise__item:last-child { border-right: 0; }
.dm-promise__item:first-child { padding-left: 0; }
.dm-promise__item span {
    font-family: var(--dm-font-body);
    font-size: 11px;
    letter-spacing: 0.20em;
    color: var(--dm-brass-soft);
    font-weight: 600;
}
.dm-promise__item b {
    font-family: var(--dm-font-display);
    font-style: italic;
    font-weight: 500;
    font-size: 18px;
    color: #fff;
}

@media (max-width: 900px) {
    .dm-promise__inner { grid-template-columns: repeat(2, 1fr); gap: 16px 0; }
    .dm-promise__item { border-right: 0; padding: 8px 0; }
    .dm-promise__item:nth-child(odd) { padding-right: 16px; border-right: 1px solid rgba(255,255,255,0.10); }
}


/* ─── 03 · THE CURATED EDIT ───────────────────────────────── */
.dm-edit { padding: var(--dm-section-y) 0; }
.dm-edit__inner {
    max-width: var(--dm-container);
    margin: 0 auto;
    padding: 0 var(--dm-space-5);
}
.dm-edit__head {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    flex-wrap: wrap;
    gap: 32px;
    margin-bottom: 48px;
}
.dm-edit__head .dm-edi-h2 { margin: 0; max-width: 580px; }

.dm-edit__tabs {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    align-items: center;
}
.dm-edit__tabs button {
    background: transparent;
    border: 1px solid var(--dm-stone);
    color: var(--dm-ink-soft);
    padding: 10px 20px;
    border-radius: 999px;
    font-family: var(--dm-font-body);
    font-size: 12px;
    letter-spacing: 0.10em;
    text-transform: uppercase;
    font-weight: 500;
    cursor: pointer;
    transition: background var(--dm-dur-1), color var(--dm-dur-1), border-color var(--dm-dur-1);
}
.dm-edit__tabs button:hover { border-color: var(--dm-ink); color: var(--dm-ink); }
.dm-edit__tabs button.is-active {
    background: var(--dm-ink);
    color: var(--dm-bone);
    border-color: var(--dm-ink);
    font-weight: 600;
}

.dm-edit__grid {
    display: grid;
    grid-template-columns: 2fr 1fr 1fr;
    grid-template-rows: auto auto;
    gap: var(--dm-space-4);
}
.dm-edit__grid > .dm-prod:first-child {
    grid-column: 1;
    grid-row: 1 / 3;
}
.dm-edit__grid > .dm-prod:first-child .dm-prod__media { aspect-ratio: 4 / 5; }
.dm-edit__grid > .dm-prod:first-child .dm-prod__title { font-size: var(--dm-fs-lg); }

@media (max-width: 1024px) {
    .dm-edit__grid {
        grid-template-columns: 1fr 1fr;
        grid-template-rows: auto;
    }
    .dm-edit__grid > .dm-prod:first-child { grid-column: 1 / -1; grid-row: auto; }
    .dm-edit__grid > .dm-prod:first-child .dm-prod__media { aspect-ratio: 16 / 9; }
}
@media (max-width: 600px) {
    .dm-edit__grid { grid-template-columns: 1fr; }
    .dm-edit__head { flex-direction: column; align-items: flex-start; }
}


/* ─── 04 · BRAND STORY SPLIT ──────────────────────────────── */
.dm-story { padding: var(--dm-section-y) 0; background: var(--dm-bone); }
.dm-story__inner {
    max-width: var(--dm-container);
    margin: 0 auto;
    padding: 0 var(--dm-space-5);
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: clamp(48px, 8vw, 120px);
    align-items: center;
}
.dm-story__visual {
    aspect-ratio: 4 / 5;
    background: var(--dm-sand);
    overflow: hidden;
    position: relative;
}
.dm-story__visual img { width: 100%; height: 100%; object-fit: cover; display: block; }
.dm-story__visual::after {
    content: '';
    position: absolute;
    inset: 12px;
    border: 1px solid rgba(160, 124, 58, 0.30);
    pointer-events: none;
}
.dm-story__copy { max-width: 480px; }
.dm-story__quote {
    font-family: var(--dm-font-display);
    font-style: italic;
    font-weight: 500;
    font-size: var(--dm-fs-pull);
    line-height: 1.25;
    color: var(--dm-ink);
    margin: 32px 0;
    padding: 24px 0;
    border-top: 1px solid var(--dm-brass-soft);
    border-bottom: 1px solid var(--dm-brass-soft);
}
.dm-story__body {
    font-size: 17px;
    line-height: 1.85;
    color: var(--dm-ink-soft);
    margin-bottom: 28px;
}
.dm-story__signature {
    font-family: var(--dm-font-display);
    font-style: italic;
    font-size: 28px;
    color: var(--dm-brass);
    margin: 24px 0 6px;
    letter-spacing: -0.01em;
}
.dm-story__name-role {
    font-size: 12px;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--dm-ink-soft);
    font-weight: 600;
}

@media (max-width: 900px) {
    .dm-story__inner { grid-template-columns: 1fr; }
}


/* ─── 05 · HERITAGE NUMBERS ───────────────────────────────── */
.dm-heritage {
    padding: var(--dm-section-y) 0;
    background: var(--dm-ink);
    color: rgba(255,255,255,0.75);
    text-align: center;
}
.dm-heritage__inner {
    max-width: var(--dm-container);
    margin: 0 auto;
    padding: 0 var(--dm-space-5);
}
.dm-heritage__eyebrow { color: var(--dm-brass-soft); }
.dm-heritage h2 { color: #fff; margin-bottom: 64px; }
.dm-heritage__grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 0;
    margin-top: 48px;
}
.dm-heritage__item {
    padding: 0 24px;
    border-right: 1px solid rgba(255,255,255,0.10);
    text-align: center;
}
.dm-heritage__item:last-child { border-right: 0; }
.dm-heritage__num {
    font-family: var(--dm-font-display);
    font-style: italic;
    font-weight: 500;
    font-size: clamp(48px, 6vw, 84px);
    line-height: 1;
    color: #fff;
    display: block;
    margin-bottom: 12px;
}
.dm-heritage__label {
    font-family: var(--dm-font-body);
    font-size: 12px;
    letter-spacing: 0.20em;
    text-transform: uppercase;
    color: var(--dm-brass-soft);
    font-weight: 600;
}

@media (max-width: 768px) {
    .dm-heritage__grid { grid-template-columns: repeat(2, 1fr); gap: 48px 0; }
    .dm-heritage__item:nth-child(2) { border-right: 0; }
}


/* ─── 06 · CATEGORIES MOSAIC ──────────────────────────────── */
.dm-mosaic-section { padding: var(--dm-section-y) 0; }
.dm-mosaic-section__inner {
    max-width: var(--dm-container);
    margin: 0 auto;
    padding: 0 var(--dm-space-5);
}
.dm-mosaic-section__head {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    flex-wrap: wrap;
    gap: 32px;
    margin-bottom: 48px;
}
.dm-mosaic {
    display: grid;
    grid-template-columns: 2fr 1fr 1fr;
    grid-template-rows: 280px 280px;
    gap: var(--dm-space-3);
}
.dm-mosaic__tile {
    position: relative;
    overflow: hidden;
    background: var(--dm-sand);
    text-decoration: none;
    color: var(--dm-ink);
    display: block;
}
.dm-mosaic__tile:nth-child(1) { grid-row: 1 / 3; }
.dm-mosaic__tile:nth-child(4) { grid-column: 2 / 4; }
.dm-mosaic__bg {
    position: absolute; inset: 0;
    background-size: cover;
    background-position: center;
    transition: transform 800ms var(--dm-ease);
}
.dm-mosaic__tile:hover .dm-mosaic__bg { transform: scale(1.05); }
.dm-mosaic__overlay {
    position: absolute; inset: 0;
    background: linear-gradient(180deg, rgba(21,17,14,0) 40%, rgba(21,17,14,0.78) 100%);
}
.dm-mosaic__caption {
    position: absolute;
    left: 28px; right: 28px; bottom: 24px;
    color: #fff;
    z-index: 2;
}
.dm-mosaic__caption h3 {
    font-family: var(--dm-font-display);
    font-style: italic;
    font-weight: 500;
    font-size: 28px;
    margin: 0 0 6px;
    color: #fff;
}
.dm-mosaic__caption span {
    font-size: 11px;
    letter-spacing: 0.24em;
    text-transform: uppercase;
    color: rgba(255,255,255,0.75);
    border-bottom: 1px solid rgba(255,255,255,0.40);
    padding-bottom: 2px;
    transition: border-color var(--dm-dur-1), color var(--dm-dur-1);
}
.dm-mosaic__tile:hover .dm-mosaic__caption span { border-color: var(--dm-brass-soft); color: var(--dm-brass-soft); }

@media (max-width: 900px) {
    .dm-mosaic { grid-template-columns: 1fr 1fr; grid-template-rows: 220px 220px 220px; }
    .dm-mosaic__tile:nth-child(1) { grid-row: 1; grid-column: 1 / -1; }
    .dm-mosaic__tile:nth-child(4) { grid-column: 1 / -1; grid-row: 3; }
}


/* ─── 07 · PULL QUOTE ─────────────────────────────────────── */
.dm-pull {
    padding: var(--dm-section-y) 0;
    background: var(--dm-sand);
    text-align: center;
    position: relative;
}
.dm-pull__inner {
    max-width: 880px;
    margin: 0 auto;
    padding: 0 var(--dm-space-5);
    position: relative;
}
.dm-pull__marks {
    font-family: var(--dm-font-display);
    font-style: italic;
    font-size: 200px;
    line-height: 0.4;
    color: var(--dm-brass);
    opacity: 0.20;
    margin-bottom: -40px;
    user-select: none;
}
.dm-pull__text {
    font-family: var(--dm-font-display);
    font-style: italic;
    font-weight: 500;
    font-size: var(--dm-fs-pull);
    line-height: 1.35;
    color: var(--dm-ink);
    margin: 0 0 40px;
    quotes: none;
    border: 0;
    padding: 0;
}
.dm-pull__cite {
    font-style: normal;
    font-size: 13px;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--dm-ink-soft);
    font-weight: 500;
    display: inline-block;
    padding-top: 24px;
    border-top: 1px solid var(--dm-brass-soft);
}
.dm-pull__cite strong { color: var(--dm-ink); font-weight: 700; margin-right: 6px; }


/* ─── 08 · PRESS MENTIONS ─────────────────────────────────── */
.dm-press {
    padding: 64px 0;
    background: var(--dm-bone);
    border-top: 1px solid var(--dm-stone);
    border-bottom: 1px solid var(--dm-stone);
}
.dm-press__inner {
    max-width: var(--dm-container);
    margin: 0 auto;
    padding: 0 var(--dm-space-5);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 40px;
    flex-wrap: wrap;
}
.dm-press__label {
    font-size: 11px;
    letter-spacing: 0.24em;
    text-transform: uppercase;
    color: var(--dm-brass);
    font-weight: 600;
    flex-shrink: 0;
}
.dm-press__list {
    display: flex;
    gap: 48px;
    flex-wrap: wrap;
    list-style: none;
    margin: 0; padding: 0;
    align-items: center;
}
.dm-press__list li {
    font-family: var(--dm-font-display);
    font-style: italic;
    font-weight: 500;
    font-size: 22px;
    color: var(--dm-ink-soft);
    opacity: 0.65;
    transition: opacity var(--dm-dur-1), color var(--dm-dur-1);
}
.dm-press__list li:hover { opacity: 1; color: var(--dm-ink); }


/* ─── 09 · MAILING LIST ───────────────────────────────────── */
.dm-mailing {
    padding: var(--dm-section-y) 0;
    background: var(--dm-bone);
    text-align: center;
}
.dm-mailing__inner {
    max-width: 580px;
    margin: 0 auto;
    padding: 0 var(--dm-space-5);
}
.dm-mailing h2 { margin: 0 0 16px; }
.dm-mailing__sub {
    font-size: 16px;
    line-height: 1.7;
    color: var(--dm-ink-soft);
    margin: 0 0 40px;
}
.dm-mailing__form {
    display: flex;
    align-items: stretch;
    border-bottom: 1px solid var(--dm-ink);
    max-width: 480px;
    margin: 0 auto;
}
.dm-mailing__form input {
    flex: 1;
    border: 0;
    background: transparent;
    padding: 16px 0;
    font-family: var(--dm-font-body);
    font-size: 15px;
    color: var(--dm-ink);
    outline: none;
}
.dm-mailing__form input::placeholder { color: var(--dm-ink-soft); opacity: 0.55; }
.dm-mailing__form button {
    background: transparent;
    border: 0;
    padding: 16px 0 16px 24px;
    font-family: var(--dm-font-body);
    font-size: 11px;
    letter-spacing: 0.20em;
    text-transform: uppercase;
    font-weight: 700;
    color: var(--dm-brass);
    cursor: pointer;
    transition: color var(--dm-dur-1), letter-spacing var(--dm-dur-1);
}
.dm-mailing__form button:hover { color: var(--dm-ink); letter-spacing: 0.24em; }
.dm-mailing__note {
    margin-top: 16px;
    font-size: 11px;
    letter-spacing: 0.10em;
    color: var(--dm-ink-soft);
    opacity: 0.65;
}


/* ============================================================
   PREMIUM MICRO-INTERACTIONS — $10K polish layer
   ============================================================ */

/* ─── Custom cursor (desktop only) ─────────────────────────── */
@media (hover: hover) and (prefers-reduced-motion: no-preference) {
    body { cursor: auto; }
    a, button, input, textarea, select, [data-edit-tab] { cursor: auto; }
}
.dm-cursor-dot,
.dm-cursor-ring {
    position: fixed;
    top: 0; left: 0;
    pointer-events: none;
    z-index: 99999;
    will-change: transform;
}
.dm-cursor-dot {
    width: 6px; height: 6px;
    background: var(--dm-ink);
    border-radius: 50%;
    margin: -3px 0 0 -3px;
    transition: transform 80ms ease, background var(--dm-dur-1);
}
.dm-cursor-ring {
    width: 32px; height: 32px;
    border: 1px solid var(--dm-ink);
    border-radius: 50%;
    margin: -16px 0 0 -16px;
    transition: width 200ms var(--dm-ease), height 200ms var(--dm-ease),
                margin 200ms var(--dm-ease), border-color var(--dm-dur-2),
                background 200ms var(--dm-ease), opacity 200ms;
}
.dm-cursor-active .dm-cursor-ring {
    width: 56px; height: 56px;
    margin: -28px 0 0 -28px;
    border-color: var(--dm-brass);
    background: rgba(160, 124, 58, 0.06);
}
.dm-cursor-active .dm-cursor-dot {
    background: var(--dm-brass);
    transform: scale(0);
}
.dm-cursor-hidden .dm-cursor-dot,
.dm-cursor-hidden .dm-cursor-ring { opacity: 0; }
@media (hover: none), (prefers-reduced-motion: reduce) {
    .dm-cursor-dot, .dm-cursor-ring { display: none; }
}

/* ─── Scroll progress bar ──────────────────────────────────── */
.dm-scroll-progress {
    position: fixed;
    top: 0; left: 0;
    width: 100%;
    height: 2px;
    background: rgba(21, 17, 14, 0.05);
    z-index: 99998;
    pointer-events: none;
}
.dm-scroll-progress span {
    display: block;
    height: 100%;
    width: 0%;
    background: linear-gradient(90deg, var(--dm-brass) 0%, var(--dm-saffron) 50%, var(--dm-brass) 100%);
    transition: width 80ms linear;
}

/* ─── Magnetic buttons (transform set by JS, this just smooths) ── */
.dm-btn--ink, .dm-btn--brass, [data-magnetic] {
    transition: transform 240ms cubic-bezier(0.34, 1.56, 0.64, 1),
                background var(--dm-dur-1), color var(--dm-dur-1), border-color var(--dm-dur-1);
    will-change: transform;
}

/* ─── Animated link underline (slide in from left) ─────────── */
.dm-edi-link,
.dm-eh__quietlink,
.dm-mosaic__caption span {
    position: relative;
    text-decoration: none;
}
.dm-edi-link {
    color: var(--dm-ink);
    border: 0 !important;
    padding: 2px 0;
    background: linear-gradient(currentColor, currentColor) 0 100% / 0 1px no-repeat;
    transition: background-size 400ms var(--dm-ease);
}
.dm-edi-link:hover { background-size: 100% 1px; color: var(--dm-brass); }

/* Underline animation on quiet link */
.dm-eh__quietlink {
    border-bottom: 0;
    background: linear-gradient(var(--dm-brass), var(--dm-brass)) 0 100% / 0 1px no-repeat,
                linear-gradient(var(--dm-stone), var(--dm-stone)) 0 100% / 100% 1px no-repeat;
    padding-bottom: 4px;
    transition: background-size 500ms var(--dm-ease), color var(--dm-dur-1);
}
.dm-eh__quietlink:hover { background-size: 100% 1px, 100% 1px; color: var(--dm-brass); }

/* ─── Drop cap on brand story body ─────────────────────────── */
.dm-story__body::first-letter {
    font-family: var(--dm-font-display);
    font-style: italic;
    font-weight: 500;
    font-size: 4.6em;
    line-height: 0.85;
    float: left;
    margin: 6px 12px 0 0;
    color: var(--dm-brass);
    letter-spacing: -0.02em;
}

/* ─── Hero ornament (corner mandala accent) ────────────────── */
.dm-eh__inner { position: relative; }
.dm-eh__inner::before {
    content: '';
    position: absolute;
    top: 0; left: -8px;
    width: 1px;
    height: 60%;
    background: linear-gradient(to bottom, transparent, var(--dm-brass-soft), transparent);
    opacity: 0.5;
}
.dm-eh__corner {
    position: absolute;
    width: 80px; height: 80px;
    pointer-events: none;
    opacity: 0.20;
    color: var(--dm-brass);
}
.dm-eh__corner--tl { top: -12px; left: -12px; }
.dm-eh__corner--br { bottom: -12px; right: -12px; transform: rotate(180deg); }

/* ─── Press marquee (auto-scrolling) ───────────────────────── */
.dm-press__marquee {
    overflow: hidden;
    flex: 1;
    mask-image: linear-gradient(90deg, transparent 0, #000 12%, #000 88%, transparent 100%);
    -webkit-mask-image: linear-gradient(90deg, transparent 0, #000 12%, #000 88%, transparent 100%);
}
.dm-press__marquee-track {
    display: flex;
    width: max-content;
    animation: dm-marquee 40s linear infinite;
    gap: 64px;
    align-items: center;
}
.dm-press__marquee-track > * { flex-shrink: 0; }
.dm-press__marquee:hover .dm-press__marquee-track { animation-play-state: paused; }
@keyframes dm-marquee {
    from { transform: translateX(0); }
    to   { transform: translateX(calc(-100% / 3)); } /* 3 because we duplicate ×3 in JS */
}
@media (prefers-reduced-motion: reduce) {
    .dm-press__marquee-track { animation: none; }
}

/* ─── Image mask reveal (clip-path animation) ──────────────── */
[data-mask-reveal] {
    clip-path: inset(0 100% 0 0);
    transition: clip-path 1100ms cubic-bezier(0.65, 0.05, 0.35, 1);
}
[data-mask-reveal].is-revealed { clip-path: inset(0 0 0 0); }
[data-mask-reveal][data-mask-reveal="bottom"] {
    clip-path: inset(100% 0 0 0);
}
[data-mask-reveal][data-mask-reveal="bottom"].is-revealed { clip-path: inset(0 0 0 0); }

/* ─── Section index counter (floating side number) ─────────── */
.dm-section-index {
    position: absolute;
    top: 32px; right: 32px;
    font-family: var(--dm-font-body);
    font-size: 11px;
    letter-spacing: 0.24em;
    color: var(--dm-brass);
    opacity: 0.6;
    z-index: 1;
}
.dm-section-index strong { color: var(--dm-ink); font-weight: 700; }

/* ─── Headline letter-by-letter reveal ─────────────────────── */
.dm-eh__headline em {
    overflow: hidden;
    transform: translateY(100%);
    opacity: 0;
    animation: dm-rise 900ms var(--dm-ease) forwards;
}
.dm-eh__headline em:nth-child(1) { animation-delay: 100ms; }
.dm-eh__headline em:nth-child(2) { animation-delay: 280ms; }
.dm-eh__headline em:nth-child(3) { animation-delay: 460ms; }
.dm-eh__eyebrow {
    opacity: 0;
    transform: translateY(20px);
    animation: dm-rise 700ms var(--dm-ease) 50ms forwards;
}
.dm-eh__sub, .dm-eh__cta {
    opacity: 0;
    transform: translateY(20px);
    animation: dm-rise 800ms var(--dm-ease) 700ms forwards;
}
.dm-eh__cta { animation-delay: 800ms; }
@keyframes dm-rise {
    to { opacity: 1; transform: translateY(0); }
}
@media (prefers-reduced-motion: reduce) {
    .dm-eh__headline em,
    .dm-eh__eyebrow,
    .dm-eh__sub,
    .dm-eh__cta { animation: none; opacity: 1; transform: none; }
}

/* ─── Hover lift on tabs ────────────────────────────────────── */
.dm-edit__tabs button:not(.is-active):hover { transform: translateY(-2px); }

/* ─── Mosaic tile classy hover ─────────────────────────────── */
.dm-mosaic__tile { transition: transform 600ms var(--dm-ease); }
.dm-mosaic__tile:hover { transform: translateY(-4px); }

/* ─── Heritage number subtle reveal stagger ────────────────── */
.dm-heritage__item { opacity: 0; transform: translateY(20px); transition: opacity 800ms var(--dm-ease), transform 800ms var(--dm-ease); }
[data-reveal].is-revealed .dm-heritage__item { opacity: 1; transform: none; }
[data-reveal].is-revealed .dm-heritage__item:nth-child(1) { transition-delay: 100ms; }
[data-reveal].is-revealed .dm-heritage__item:nth-child(2) { transition-delay: 220ms; }
[data-reveal].is-revealed .dm-heritage__item:nth-child(3) { transition-delay: 340ms; }
[data-reveal].is-revealed .dm-heritage__item:nth-child(4) { transition-delay: 460ms; }

/* ─── Promise bar items stagger ────────────────────────────── */
.dm-promise__item { opacity: 0; transform: translateY(8px); animation: dm-rise 600ms var(--dm-ease) forwards; }
.dm-promise__item:nth-child(1) { animation-delay: 100ms; }
.dm-promise__item:nth-child(2) { animation-delay: 200ms; }
.dm-promise__item:nth-child(3) { animation-delay: 300ms; }
.dm-promise__item:nth-child(4) { animation-delay: 400ms; }
