/* ============================================================
   MONOLITH LABO EFFETS — labo.css
   Dark luxury amber theme · responsive · a11y-first
   ============================================================ */

:root {
    --c-ink: #0a0805;
    --c-stone: #15110b;
    --c-stone-2: #1f1812;
    --c-cream: #f4ead8;
    --c-bone: #e8dcc4;
    --c-amber: #c9a35e;
    --c-amber-hot: #e6b870;
    --c-blush: #b06e5b;
    --c-ember: #ff7b3d;
    --c-ok: #5e9a7c;
    --c-warn: #b8923d;
    --c-err: #c5564a;
    --c-line: rgba(244, 234, 216, 0.08);
    --c-line-2: rgba(244, 234, 216, 0.16);
    --c-glass: rgba(244, 234, 216, 0.04);

    --f-display: "Cormorant Garamond", ui-serif, Georgia, serif;
    --f-body: "Inter", ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
    --f-mono: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, Consolas, monospace;

    --gutter: clamp(1rem, 3vw, 2rem);
    --ease-out-expo: cubic-bezier(0.19, 1, 0.22, 1);
    --ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);
}

*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
html {
    background: var(--c-ink);
    color: var(--c-cream);
    font-family: var(--f-body);
    font-size: 16px;
    -webkit-font-smoothing: antialiased;
}
body {
    min-height: 100vh;
    background:
        radial-gradient(ellipse at 0% 0%, rgba(201,163,94,0.06), transparent 50%),
        radial-gradient(ellipse at 100% 100%, rgba(176,110,91,0.04), transparent 60%),
        var(--c-ink);
}
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
button, input, select, textarea { font: inherit; color: inherit; }
button { cursor: pointer; }

/* Skip-link */
.skip {
    position: absolute; left: -9999px; top: 0;
    background: var(--c-amber); color: var(--c-ink);
    padding: 0.6rem 1rem; z-index: 99999;
    border-radius: 4px;
}
.skip:focus { left: 1rem; top: 1rem; }

/* ============================================================
   LOGIN PAGE
   ============================================================ */
.login-body {
    min-height: 100vh;
    display: grid; place-items: center;
    padding: 2rem;
    background:
        radial-gradient(ellipse at 50% 30%, rgba(201,163,94,0.1), transparent 50%),
        var(--c-ink);
}
.login-card {
    width: 100%; max-width: 420px;
    background: linear-gradient(180deg, var(--c-stone), var(--c-ink));
    border: 1px solid var(--c-line);
    border-radius: 12px;
    padding: 2.5rem 2rem 2rem;
    box-shadow: 0 30px 60px -20px rgba(0,0,0,0.6), 0 0 0 1px var(--c-line);
}
.login-head { text-align: center; margin-bottom: 2rem; }
.login-mark svg {
    width: 56px; height: 56px;
    margin: 0 auto 1.2rem;
    display: block;
}
.login-mark svg path,
.login-mark svg circle {
    stroke: var(--c-amber);
    stroke-width: 1.5;
    fill: none;
    stroke-dasharray: 600;
    stroke-dashoffset: 600;
    animation: drawLogo 2.4s var(--ease-out-expo) forwards;
}
@keyframes drawLogo { to { stroke-dashoffset: 0; } }
.login-title {
    font-family: var(--f-display); font-weight: 400;
    font-size: 1.6rem; line-height: 1.15;
    color: var(--c-cream);
    margin: 0;
    letter-spacing: 0.05em;
}
.login-title em {
    font-style: italic;
    color: var(--c-amber);
    font-size: 1.4rem;
    display: block;
    margin-top: 0.3rem;
}
.login-sub {
    font-size: 0.7rem;
    letter-spacing: 0.25em;
    text-transform: uppercase;
    color: rgba(244,234,216,0.5);
    margin: 0.8rem 0 0;
}
.login-alert {
    padding: 0.85rem 1rem;
    border-radius: 6px;
    font-size: 0.85rem;
    margin-bottom: 1.2rem;
    line-height: 1.5;
}
.login-alert.error { background: rgba(197,86,74,0.1); border: 1px solid rgba(197,86,74,0.3); color: #f5b8a8; }
.login-alert.warn  { background: rgba(184,146,61,0.1); border: 1px solid rgba(184,146,61,0.3); color: var(--c-amber-hot); }
.login-alert code { background: rgba(0,0,0,0.3); padding: 0.1rem 0.4rem; border-radius: 3px; font-size: 0.85em; }
.login-alert strong { display: block; margin-bottom: 0.3rem; }

.login-form { display: grid; gap: 1rem; }
.login-form .field { position: relative; }
.login-form input {
    width: 100%;
    padding: 1.2rem 1rem 0.5rem;
    background: rgba(0,0,0,0.3);
    border: 1px solid var(--c-line);
    border-radius: 6px;
    color: var(--c-cream);
    outline: none;
    transition: border-color 0.3s, box-shadow 0.3s;
}
.login-form input:focus {
    border-color: var(--c-amber);
    box-shadow: 0 0 0 3px rgba(201,163,94,0.15);
}
.login-form label {
    position: absolute; left: 1rem; top: 1rem;
    pointer-events: none;
    color: rgba(244,234,216,0.45);
    transition: transform 0.3s var(--ease-out-expo), font-size 0.3s, color 0.3s;
}
.login-form input:focus + label,
.login-form input:not(:placeholder-shown) + label {
    transform: translateY(-12px);
    font-size: 0.7rem;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    color: var(--c-amber);
}
.login-submit {
    margin-top: 0.5rem;
    padding: 1rem;
    background: var(--c-amber);
    color: var(--c-ink);
    border: 0; border-radius: 999px;
    font-size: 0.85rem; letter-spacing: 0.18em; text-transform: uppercase;
    font-weight: 600;
    transition: background 0.3s, transform 0.3s;
}
.login-submit:hover { background: var(--c-amber-hot); transform: translateY(-1px); }
.login-hint {
    margin: 0; text-align: center;
    font-size: 0.7rem; color: rgba(244,234,216,0.4);
    letter-spacing: 0.05em;
}
.login-foot {
    display: flex; justify-content: space-between;
    margin-top: 2rem; padding-top: 1.5rem;
    border-top: 1px solid var(--c-line);
    font-size: 0.7rem; letter-spacing: 0.15em;
    color: rgba(244,234,216,0.3);
    text-transform: uppercase;
}

/* ============================================================
   LABO TOP BAR
   ============================================================ */
.top {
    position: sticky; top: 0; z-index: 100;
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: 1.5rem;
    padding: 0.85rem var(--gutter);
    background: rgba(10,8,5,0.85);
    backdrop-filter: blur(20px);
    border-bottom: 1px solid var(--c-line);
}
.brand {
    display: flex; align-items: center; gap: 0.6rem;
    font-size: 0.9rem;
    color: var(--c-cream);
}
.brand svg path, .brand svg circle {
    stroke: var(--c-amber); stroke-width: 2; fill: none;
}
.brand strong {
    font-weight: 600;
    letter-spacing: 0.08em;
}
.brand span {
    font-family: var(--f-display); font-style: italic;
}

.search-wrap {
    position: relative;
    max-width: 520px;
    width: 100%;
    margin: 0 auto;
    justify-self: center;
}
#search {
    width: 100%;
    padding: 0.65rem 3rem 0.65rem 1rem;
    background: var(--c-stone);
    border: 1px solid var(--c-line);
    border-radius: 999px;
    color: var(--c-cream);
    font-size: 0.9rem;
    outline: none;
    transition: border-color 0.3s, box-shadow 0.3s;
}
#search:focus {
    border-color: var(--c-amber);
    box-shadow: 0 0 0 3px rgba(201,163,94,0.15);
}
#search::placeholder { color: rgba(244,234,216,0.4); }
.search-wrap kbd {
    position: absolute; right: 0.8rem; top: 50%;
    transform: translateY(-50%);
    font-family: var(--f-mono);
    font-size: 0.65rem;
    background: var(--c-line);
    color: rgba(244,234,216,0.6);
    padding: 0.2rem 0.4rem;
    border-radius: 3px;
}

.top-right {
    display: flex; align-items: center; gap: 0.8rem;
}
.counter {
    font-family: var(--f-mono);
    font-size: 0.8rem;
    color: rgba(244,234,216,0.6);
    letter-spacing: 0.05em;
}
.filter-fav {
    display: inline-flex; align-items: center; gap: 0.4rem;
    padding: 0.4rem 0.8rem;
    background: var(--c-stone);
    border: 1px solid var(--c-line);
    border-radius: 999px;
    color: var(--c-cream);
    font-size: 0.8rem;
    transition: background 0.3s, border-color 0.3s, color 0.3s;
}
.filter-fav:hover { border-color: var(--c-amber); }
.filter-fav[aria-pressed="true"] {
    background: var(--c-amber);
    color: var(--c-ink);
    border-color: var(--c-amber);
}
.filter-fav .star { font-size: 0.9rem; }
.user-chip {
    padding: 0.3rem 0.7rem;
    background: var(--c-glass);
    border: 1px solid var(--c-line);
    border-radius: 999px;
    font-size: 0.75rem;
    color: var(--c-amber);
    font-family: var(--f-mono);
}
.logout {
    width: 36px; height: 36px;
    display: grid; place-items: center;
    background: var(--c-stone);
    border: 1px solid var(--c-line);
    border-radius: 50%;
    color: var(--c-cream);
    transition: background 0.3s, border-color 0.3s, transform 0.3s;
}
.logout:hover { background: var(--c-blush); transform: rotate(45deg); }

@media (max-width: 720px) {
    .top { grid-template-columns: 1fr auto; gap: 0.6rem; }
    .search-wrap { display: none; }
    .counter { display: none; }
}

/* ============================================================
   TABS
   ============================================================ */
.tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem;
    padding: 1rem var(--gutter);
    border-bottom: 1px solid var(--c-line);
    background: rgba(10,8,5,0.5);
    overflow-x: auto;
    scrollbar-width: thin;
}
.tab {
    display: inline-flex; align-items: center; gap: 0.4rem;
    padding: 0.5rem 0.9rem;
    background: transparent;
    border: 1px solid var(--c-line);
    border-radius: 999px;
    color: rgba(244,234,216,0.7);
    font-size: 0.85rem;
    transition: background 0.3s, border-color 0.3s, color 0.3s;
    white-space: nowrap;
}
.tab:hover { border-color: var(--c-line-2); color: var(--c-cream); }
.tab.active {
    background: var(--c-amber);
    color: var(--c-ink);
    border-color: var(--c-amber);
    font-weight: 500;
}
.tab .tab-icon { font-size: 1rem; }
.tab em {
    font-style: normal;
    font-size: 0.7rem;
    background: var(--c-line);
    color: rgba(244,234,216,0.7);
    padding: 0.1rem 0.4rem;
    border-radius: 999px;
    margin-left: 0.3rem;
}
.tab.active em { background: rgba(0,0,0,0.2); color: var(--c-ink); }

/* ============================================================
   CONTENT GRID
   ============================================================ */
.content { padding: 2rem var(--gutter) 5rem; }
.cat-panel { margin-bottom: 4rem; }
.cat-panel:not(.active) { display: none; }
.body--all .cat-panel { display: block; }

.cat-header { margin-bottom: 1.5rem; }
.cat-header h2 {
    font-family: var(--f-display);
    font-weight: 400;
    font-size: clamp(1.6rem, 3vw, 2.4rem);
    margin: 0 0 0.4rem;
    color: var(--c-cream);
    display: flex; align-items: center; gap: 0.7rem;
}
.cat-header h2 .cat-icon { color: var(--c-amber); font-size: 0.9em; }
.cat-header .cat-desc {
    margin: 0;
    color: rgba(244,234,216,0.6);
    font-size: 0.95rem;
}

.grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(290px, 1fr));
    gap: 1.2rem;
}

/* ============================================================
   CARDS
   ============================================================ */
.card {
    display: flex; flex-direction: column;
    background: var(--c-stone);
    border: 1px solid var(--c-line);
    border-radius: 10px;
    overflow: hidden;
    transition: border-color 0.3s, transform 0.4s var(--ease-out-expo), box-shadow 0.4s;
    isolation: isolate;
}
.card:hover {
    border-color: var(--c-amber);
    transform: translateY(-3px);
    box-shadow: 0 18px 40px -16px rgba(201,163,94,0.25);
}
.card.is-fav {
    border-color: rgba(201,163,94,0.4);
    background: linear-gradient(180deg, rgba(201,163,94,0.08), var(--c-stone) 30%);
}
.card.hidden { display: none; }

.card-head {
    display: flex; align-items: center; gap: 0.6rem;
    padding: 0.6rem 0.8rem;
    border-bottom: 1px solid var(--c-line);
    background: rgba(0,0,0,0.25);
}
.code {
    font-family: var(--f-mono);
    font-size: 0.78rem;
    color: var(--c-amber);
    font-weight: 500;
    letter-spacing: 0.05em;
}
.badges {
    display: flex; gap: 0.3rem;
    margin-left: auto;
}
.badge {
    font-size: 0.65rem;
    font-family: var(--f-mono);
    padding: 0.15rem 0.4rem;
    border-radius: 4px;
    border: 1px solid var(--c-line);
    background: var(--c-glass);
    color: rgba(244,234,216,0.7);
    letter-spacing: 0.04em;
}
.badge.wow {
    background: rgba(201,163,94,0.15);
    border-color: rgba(201,163,94,0.3);
    color: var(--c-amber-hot);
    font-weight: 600;
}
.fav-btn {
    width: 28px; height: 28px;
    display: grid; place-items: center;
    background: transparent;
    border: 1px solid var(--c-line);
    border-radius: 6px;
    color: rgba(244,234,216,0.4);
    font-size: 1.1rem;
    transition: background 0.3s, color 0.3s, transform 0.3s var(--ease-spring), border-color 0.3s;
}
.fav-btn:hover { color: var(--c-amber); border-color: var(--c-amber); }
.fav-btn[aria-pressed="true"] {
    background: var(--c-amber);
    color: var(--c-ink);
    border-color: var(--c-amber);
    transform: scale(1.05);
}
.fav-btn:active { transform: scale(0.9); }

.card-stage {
    aspect-ratio: 16 / 10;
    overflow: hidden;
    position: relative;
    background:
        radial-gradient(circle at 30% 30%, rgba(201,163,94,0.05), transparent 55%),
        var(--c-stone-2);
    display: grid; place-items: center;
}
.demo-mount {
    position: absolute; inset: 0;
    width: 100%; height: 100%;
}
.demo-static {
    display: grid; gap: 0.4rem; place-items: center;
    color: rgba(244,234,216,0.3);
}
.demo-static-icon {
    font-size: 3rem;
    color: var(--c-amber);
    opacity: 0.4;
}
.demo-static-label {
    font-size: 0.7rem;
    letter-spacing: 0.2em;
    text-transform: uppercase;
}

.card-body { padding: 1rem; flex: 1; }
.card-body h3 {
    font-family: var(--f-display);
    font-weight: 500;
    font-size: 1.15rem;
    margin: 0 0 0.4rem;
    color: var(--c-cream);
}
.card-body p {
    font-size: 0.85rem;
    line-height: 1.55;
    color: rgba(244,234,216,0.7);
    margin: 0 0 0.7rem;
}
.tags { display: flex; gap: 0.3rem; flex-wrap: wrap; }
.tag {
    font-size: 0.65rem;
    padding: 0.15rem 0.5rem;
    background: var(--c-glass);
    border-radius: 3px;
    color: rgba(244,234,216,0.55);
    border: 1px solid var(--c-line);
    letter-spacing: 0.04em;
}

.card-foot {
    display: flex; gap: 0.5rem;
    padding: 0.7rem 1rem;
    border-top: 1px solid var(--c-line);
    background: rgba(0,0,0,0.2);
}
.action {
    flex: 1;
    padding: 0.5rem 0.7rem;
    background: transparent;
    border: 1px solid var(--c-line);
    border-radius: 6px;
    color: var(--c-cream);
    font-size: 0.75rem;
    text-align: center;
    transition: background 0.3s, border-color 0.3s, color 0.3s;
}
.action:hover { background: var(--c-glass); border-color: var(--c-amber); color: var(--c-amber); }
.action.ref {
    background: rgba(201,163,94,0.08);
    color: var(--c-amber);
    border-color: rgba(201,163,94,0.2);
}
.action.ref:hover { background: var(--c-amber); color: var(--c-ink); }

/* ============================================================
   EMPTY STATE
   ============================================================ */
.empty-state {
    text-align: center;
    padding: 4rem 1rem;
    color: rgba(244,234,216,0.5);
}
.empty-icon {
    font-size: 3rem;
    color: var(--c-amber);
    opacity: 0.6;
    margin-bottom: 1rem;
}
.empty-state h3 {
    font-family: var(--f-display);
    font-weight: 400;
    margin: 0 0 0.4rem;
    color: var(--c-cream);
}

/* ============================================================
   MODAL DETAIL
   ============================================================ */
.modal {
    position: fixed; inset: 0;
    z-index: 1000;
    visibility: hidden;
    opacity: 0;
    transition: opacity 0.4s, visibility 0.4s;
}
.modal[aria-hidden="false"] { visibility: visible; opacity: 1; }
.modal-overlay {
    position: absolute; inset: 0;
    background: rgba(0,0,0,0.85);
    backdrop-filter: blur(8px);
}
.modal-card {
    position: relative;
    max-width: 720px;
    width: calc(100% - 2rem);
    max-height: 86vh;
    margin: 5vh auto;
    background: var(--c-stone);
    border: 1px solid var(--c-amber);
    border-radius: 12px;
    overflow: hidden;
    display: flex; flex-direction: column;
    transform: scale(0.95);
    transition: transform 0.4s var(--ease-out-expo);
    box-shadow: 0 30px 80px -20px rgba(0,0,0,0.7);
}
.modal[aria-hidden="false"] .modal-card { transform: scale(1); }
.modal-close {
    position: absolute; top: 0.8rem; right: 0.8rem;
    width: 36px; height: 36px;
    background: transparent;
    border: 1px solid var(--c-line);
    border-radius: 50%;
    color: var(--c-cream);
    font-size: 1.4rem;
    line-height: 1;
    transition: background 0.3s, transform 0.3s;
    z-index: 2;
}
.modal-close:hover { background: var(--c-blush); transform: rotate(90deg); }

.modal-head {
    padding: 1.6rem 1.6rem 1.2rem;
    border-bottom: 1px solid var(--c-line);
}
.modal-code {
    font-family: var(--f-mono);
    font-size: 0.85rem;
    color: var(--c-amber);
    letter-spacing: 0.05em;
}
.modal-head h2 {
    font-family: var(--f-display);
    font-weight: 400;
    font-size: 1.8rem;
    margin: 0.3rem 0 0.6rem;
}
.modal-head p {
    margin: 0 0 1rem;
    color: rgba(244,234,216,0.75);
    font-size: 0.95rem;
    line-height: 1.6;
}
.modal-meta {
    display: flex; gap: 0.4rem;
}

.modal-tabs {
    display: flex; gap: 0;
    border-bottom: 1px solid var(--c-line);
    padding: 0 1rem;
}
.mtab {
    padding: 0.7rem 1rem;
    background: transparent;
    border: 0;
    border-bottom: 2px solid transparent;
    color: rgba(244,234,216,0.6);
    font-size: 0.85rem;
    font-family: var(--f-mono);
    transition: color 0.3s, border-color 0.3s;
}
.mtab:hover { color: var(--c-cream); }
.mtab.active { color: var(--c-amber); border-color: var(--c-amber); }

.modal-pane {
    display: none;
    position: relative;
    overflow: auto;
    flex: 1;
}
.modal-pane.active { display: block; }
.modal-pane pre {
    margin: 0;
    padding: 1.2rem;
    font-family: var(--f-mono);
    font-size: 0.85rem;
    line-height: 1.6;
    color: var(--c-cream);
    background: var(--c-ink);
    overflow: auto;
    max-height: 50vh;
}
.modal-pane code {
    color: inherit;
    font-family: inherit;
    background: none;
    padding: 0;
    white-space: pre-wrap;
    word-break: break-word;
}
.copy-btn {
    position: absolute; top: 0.7rem; right: 0.7rem;
    z-index: 2;
    padding: 0.3rem 0.7rem;
    background: var(--c-stone);
    border: 1px solid var(--c-line);
    border-radius: 4px;
    color: var(--c-amber);
    font-size: 0.7rem;
    letter-spacing: 0.05em;
    transition: background 0.3s, color 0.3s;
}
.copy-btn:hover { background: var(--c-amber); color: var(--c-ink); }
.copy-btn.copied { background: var(--c-ok); color: var(--c-ink); }

.modal-pane[data-mpane="refs"] {
    padding: 1.2rem;
}
.modal-pane[data-mpane="refs"] ul {
    list-style: none;
    padding: 0; margin: 0;
    display: grid; gap: 0.6rem;
}
.modal-pane[data-mpane="refs"] li a {
    display: block;
    padding: 0.7rem 1rem;
    background: var(--c-glass);
    border: 1px solid var(--c-line);
    border-radius: 6px;
    color: var(--c-cream);
    transition: border-color 0.3s, background 0.3s;
}
.modal-pane[data-mpane="refs"] li a::before { content: "↗ "; color: var(--c-amber); }
.modal-pane[data-mpane="refs"] li a:hover { border-color: var(--c-amber); background: rgba(201,163,94,0.08); }

/* ============================================================
   TOAST
   ============================================================ */
.toast {
    position: fixed; bottom: 2rem; left: 50%;
    transform: translateX(-50%) translateY(150%);
    padding: 0.8rem 1.4rem;
    background: var(--c-amber);
    color: var(--c-ink);
    border-radius: 999px;
    font-size: 0.85rem;
    font-weight: 500;
    z-index: 9999;
    transition: transform 0.5s var(--ease-spring);
    box-shadow: 0 20px 40px -10px rgba(0,0,0,0.5);
    pointer-events: none;
}
.toast.show { transform: translateX(-50%) translateY(0); }

/* ============================================================
   DEMO STYLES (mini démos dans les cards)
   ============================================================ */
[data-mount] { width: 100%; height: 100%; }

.dm-magnet-btn {
    padding: 0.7rem 1.2rem;
    background: rgba(201,163,94,0.08);
    border: 1px solid var(--c-amber);
    border-radius: 999px;
    color: var(--c-amber);
    font-size: 0.7rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    will-change: transform;
}
.dm-tilt {
    width: 60%; aspect-ratio: 3/4;
    border-radius: 6px;
    background: linear-gradient(135deg, var(--c-amber), var(--c-blush));
    will-change: transform;
}
.dm-mesh {
    position: absolute; inset: 0;
    background:
        radial-gradient(circle at 25% 30%, var(--c-amber), transparent 35%),
        radial-gradient(circle at 80% 75%, var(--c-blush), transparent 40%),
        var(--c-ink);
    background-size: 200% 200%;
    animation: meshAnim 12s ease-in-out infinite;
}
@keyframes meshAnim { 0%,100% { background-position: 0 0,0 0; } 50% { background-position: 30% -20%,-20% 30%; } }
.dm-aurora {
    position: absolute; inset: 0;
    background:
        linear-gradient(45deg, transparent 0%, rgba(176,110,91,0.3) 30%, rgba(201,163,94,0.4) 50%, rgba(110,126,138,0.3) 70%, transparent 100%);
    background-size: 200% 200%;
    animation: aurora 8s ease-in-out infinite;
    filter: blur(8px);
}
@keyframes aurora { 0%,100% { background-position: 0 0; } 50% { background-position: 100% 100%; } }
.dm-stars { position: absolute; inset: 0; }
.dm-stars canvas { width: 100%; height: 100%; display: block; }
.dm-topo {
    position: absolute; inset: 0;
    background: var(--c-ink);
    background-image:
        repeating-radial-gradient(circle at 30% 50%, transparent 0 8px, rgba(201,163,94,0.4) 8px 9px),
        repeating-radial-gradient(circle at 70% 60%, transparent 0 12px, rgba(176,110,91,0.3) 12px 13px);
    animation: topoAnim 8s alternate infinite;
}
@keyframes topoAnim { from { background-position: 0 0,0 0; } to { background-position: 20px 10px,-15px 20px; } }
.dm-grid-anim {
    position: absolute; inset: 0;
    background:
        linear-gradient(var(--c-amber) 1px, transparent 1px) 0 0/30px 30px,
        linear-gradient(90deg, var(--c-amber) 1px, transparent 1px) 0 0/30px 30px,
        var(--c-ink);
    mask: radial-gradient(ellipse at center, black 30%, transparent 75%);
    animation: agrid 6s linear infinite;
    opacity: 0.6;
}
@keyframes agrid { from { background-position: 0 0,0 0,0 0; } to { background-position: 30px 30px,30px 30px,0 0; } }
.dm-blobs { position: absolute; inset: 0; overflow: hidden; }
.dm-blobs span {
    position: absolute; width: 60%; height: 60%;
    border-radius: 50%; filter: blur(40px); mix-blend-mode: screen;
    animation: blobMove 8s ease-in-out infinite;
}
.dm-blobs span:nth-child(1) { left: -10%; top: -10%; background: var(--c-amber); }
.dm-blobs span:nth-child(2) { right: -10%; bottom: -10%; background: var(--c-blush); animation-delay: -3s; }
@keyframes blobMove { 0%,100% { transform: translate(0,0); } 50% { transform: translate(20%,20%); } }
.dm-spotlight { position: absolute; inset: 0; background: var(--c-ink); cursor: none; overflow: hidden; }
.dm-spotlight::before {
    content: "MONOLITH"; position: absolute; inset: 0;
    display: grid; place-items: center;
    font-family: var(--f-display); font-style: italic;
    color: var(--c-amber); font-size: 1.2rem;
    pointer-events: none;
}
.dm-spotlight .spot {
    position: absolute; width: 200px; height: 200px;
    background: radial-gradient(circle, rgba(201,163,94,0.5), transparent 70%);
    pointer-events: none;
    transform: translate(-50%, -50%);
    transition: opacity 0.3s;
    opacity: 0;
}
.dm-halftone {
    position: absolute; inset: 0;
    background: var(--c-amber);
    background-image: radial-gradient(rgba(10,8,5,0.85) 24%, transparent 25%);
    background-size: 8px 8px;
    mask: radial-gradient(ellipse at center, black 40%, transparent 75%);
}
.dm-bigital {
    font-family: var(--f-display); font-style: italic;
    font-size: clamp(2rem, 5vw, 3.5rem);
    color: var(--c-amber);
}
.dm-sweep {
    font-family: var(--f-display); font-style: italic;
    font-size: 1.4rem;
    background: linear-gradient(90deg, var(--c-cream) 0%, var(--c-cream) 30%, var(--c-amber) 50%, var(--c-cream) 70%, var(--c-cream) 100%);
    background-size: 300% 100%;
    background-position: 100% 0;
    -webkit-background-clip: text; background-clip: text;
    -webkit-text-fill-color: transparent;
    animation: sweep 3s ease-in-out infinite;
}
@keyframes sweep { 0%,30% { background-position: 100% 0; } 70%,100% { background-position: -50% 0; } }
.dm-counter {
    font-family: var(--f-display); font-weight: 300;
    font-size: 2.4rem;
    color: var(--c-amber);
    font-variant-numeric: tabular-nums;
}
.dm-marquee {
    width: 100%; height: 100%;
    display: flex; align-items: center;
    overflow: hidden;
    background: rgba(0,0,0,0.3);
}
.dm-marquee span {
    white-space: nowrap;
    font-family: var(--f-display); font-style: italic;
    font-size: 1.1rem; color: var(--c-amber);
    animation: marfast 12s linear infinite;
    padding-left: 100%;
}
@keyframes marfast { to { transform: translateX(-100%); } }
.dm-dropcap { padding: 0.5rem; font-size: 0.85rem; }
.dm-dropcap span:first-child { float: left; font-family: var(--f-display); font-style: italic; font-size: 3rem; line-height: 0.85; padding-right: 0.4rem; color: var(--c-amber); }
.dm-skel { width: 90%; display: grid; gap: 0.4rem; }
.dm-skel div { height: 10px; border-radius: 3px; background: linear-gradient(90deg, rgba(244,234,216,0.06), rgba(244,234,216,0.18), rgba(244,234,216,0.06)); background-size: 200%; animation: shimmer 1.6s linear infinite; }
.dm-skel div:nth-child(2) { width: 75%; }
.dm-skel div:nth-child(3) { width: 60%; }
@keyframes shimmer { from { background-position: 200% 0; } to { background-position: -200% 0; } }
.dm-progold { width: 80%; height: 5px; background: rgba(244,234,216,0.1); border-radius: 3px; overflow: hidden; }
.dm-progold span { display: block; height: 100%; background: linear-gradient(90deg, var(--c-amber), var(--c-amber-hot), var(--c-amber)); box-shadow: 0 0 12px var(--c-amber); animation: prog 2s infinite; }
@keyframes prog { 0% { width: 0; } 60% { width: 100%; } 100% { width: 100%; opacity: 0; } }
.dm-svgdraw { width: 60%; height: 60%; }
.dm-svgdraw path, .dm-svgdraw circle { stroke: var(--c-amber); stroke-width: 1.5; fill: none; stroke-dasharray: 600; stroke-dashoffset: 600; animation: drawLogo 2.4s var(--ease-out-expo) infinite alternate; }
.dm-img-crop { width: 100%; height: 100%; overflow: hidden; }
.dm-img-crop > div { width: 100%; height: 100%; background: linear-gradient(135deg, var(--c-amber), var(--c-blush)); transition: transform 1s var(--ease-out-expo); }
.dm-img-crop:hover > div { transform: scale(1.18); }
.dm-vidbg {
    position: absolute; inset: 0;
    background:
        radial-gradient(circle at 30% 40%, rgba(255,123,61,0.35), transparent 40%),
        radial-gradient(circle at 70% 60%, rgba(201,163,94,0.4), transparent 50%),
        var(--c-ink);
    background-size: 200% 200%;
    animation: vidbg 8s ease-in-out infinite;
    filter: blur(8px) saturate(1.4);
}
@keyframes vidbg { 0%,100% { background-position: 0 0,0 0; } 50% { background-position: 30% 30%,-30% 20%; } }
.dm-konami {
    text-align: center;
    font-family: var(--f-display);
    font-style: italic;
    color: var(--c-amber);
    font-size: 0.9rem;
    line-height: 1.6;
}
.dm-text { color: var(--c-amber); font-family: var(--f-display); font-style: italic; font-size: 1.6rem; }
.dm-input { width: 80%; padding: 0.5rem 0.7rem; background: rgba(0,0,0,0.3); border: 1px solid var(--c-line); border-radius: 4px; color: var(--c-cream); font-size: 0.85rem; outline: none; transition: border-color 0.3s, box-shadow 0.3s; }
.dm-input:focus { border-color: var(--c-amber); box-shadow: 0 0 0 3px rgba(201,163,94,0.15); }
.dm-dock { display: flex; gap: 0.5rem; padding: 0.5rem 0.8rem; background: rgba(244,234,216,0.06); backdrop-filter: blur(10px); border: 1px solid var(--c-line); border-radius: 12px; }
.dm-dock span { width: 32px; height: 32px; display: grid; place-items: center; border-radius: 6px; background: linear-gradient(135deg, var(--c-amber), var(--c-blush)); color: var(--c-ink); transition: transform 0.3s var(--ease-spring); }
.dm-dock span:hover { transform: translateY(-10px) scale(1.3); }

/* ============================================================
   Reduced motion
   ============================================================ */
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: 0.001ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.001ms !important;
    }
}

/* ============================================================
   Scrollbar style (webkit)
   ============================================================ */
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: var(--c-stone); }
::-webkit-scrollbar-thumb { background: var(--c-line-2); border-radius: 5px; }
::-webkit-scrollbar-thumb:hover { background: var(--c-amber); }
