/* =================================================================
   AUDIRA LTD · STAGE PROGRAMME EDITION
   Lighting & sound for the stage. London.
   ================================================================= */

:root {
    /* Palette — kept from the brand */
    --ink:        #050709;
    --bg:         #0a0d12;
    --bg-1:       #0e1319;
    --bg-2:       #131a23;
    --paper:      #ece9e3;        /* warm off-white text — programme paper */
    --paper-mute: #8c93a0;
    --paper-dim:  #5b626d;
    --rule:       rgba(236, 233, 227, 0.10);
    --rule-soft:  rgba(236, 233, 227, 0.06);

    --cyan:       #78d3ff;
    --purple:     #b889ff;

    /* Fonts */
    --serif: "Geist", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;
    --sans:  "Geist", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;
    --mono:  "Geist Mono", ui-monospace, "SFMono-Regular", Menlo, Consolas, monospace;

    /* Layout */
    --container: 1280px;
    --gutter: clamp(20px, 4vw, 56px);
    --section-y: clamp(80px, 12vh, 160px);
}

/* ---------- Reset & base ---------- */

*, *::before, *::after { box-sizing: border-box; }

html, body { margin: 0; padding: 0; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }

body {
    font-family: var(--sans);
    font-size: 16px;
    line-height: 1.6;
    color: var(--paper);
    background: var(--bg);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
    font-feature-settings: "ss01", "kern", "liga";
    overflow-x: hidden;
}

img, svg { display: block; max-width: 100%; }

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

button { font: inherit; color: inherit; background: none; border: 0; padding: 0; cursor: pointer; }

ul, ol, dl { margin: 0; padding: 0; list-style: none; }
dd { margin: 0; }

::selection { background: var(--cyan); color: var(--ink); }

[hidden] { display: none !important; }

.sr-only {
    position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
    overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap; border: 0;
}

.skip {
    position: absolute; left: -9999px; top: 8px;
    background: var(--paper); color: var(--ink);
    padding: 8px 14px; border-radius: 2px; z-index: 9999;
    font: 500 0.8rem/1 var(--mono); text-transform: uppercase; letter-spacing: 0.1em;
}
.skip:focus { left: 12px; }

.container {
    width: 100%;
    max-width: var(--container);
    margin: 0 auto;
    padding: 0 var(--gutter);
}

/* ---------- Typography helpers ---------- */

.overline {
    font: 400 0.72rem/1.4 var(--mono);
    text-transform: uppercase;
    letter-spacing: 0.18em;
    color: var(--paper-mute);
    margin: 0;
}
.overline em {
    font-style: italic;
    color: var(--cyan);
    font-family: var(--serif);
    text-transform: none;
    letter-spacing: 0;
    font-size: 0.95rem;
    margin: 0 2px;
}
.overline-dot::before {
    content: "";
    display: inline-block;
    width: 6px; height: 6px;
    background: var(--cyan);
    border-radius: 50%;
    margin-right: 12px;
    vertical-align: 2px;
    box-shadow: 0 0 0 4px rgba(120, 211, 255, 0.12);
    animation: pulse 2.4s ease-in-out infinite;
}
@keyframes pulse {
    0%, 100% { box-shadow: 0 0 0 4px rgba(120, 211, 255, 0.12); }
    50%      { box-shadow: 0 0 0 8px rgba(120, 211, 255, 0.04); }
}

.display, .display-h, .display-sub {
    font-family: var(--serif);
    font-weight: 600;
    line-height: 1.05;
    letter-spacing: -0.015em;
    color: var(--paper);
    margin: 0;
    text-wrap: balance;
}
.display em, .display-h em, .display-sub em {
    font-style: italic;
    color: var(--cyan);
}

.display    { font-size: clamp(3rem, 9vw, 7.6rem); }
.display-h  { font-size: clamp(2.4rem, 5vw, 4.8rem); line-height: 1.02; }
.display-sub{ font-size: clamp(1.8rem, 2.8vw, 2.6rem); line-height: 1.05; }

.lede { font-size: 1.075rem; color: var(--paper); max-width: 60ch; }
.muted { color: var(--paper-mute); }

/* ============================================================
   MASTHEAD
   ============================================================ */

.masthead {
    position: sticky;
    top: 0;
    z-index: 50;
    background: rgba(10, 13, 18, 0.92);
    border-bottom: 1px solid var(--rule);
    transition: border-color 200ms ease;
}
.masthead-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    height: 72px;
    width: 100%;
    max-width: var(--container);
    margin: 0 auto;
    padding: 0 var(--gutter);
}
.brand {
    display: inline-flex; align-items: center;
    height: 36px;
}
.brand img { height: 32px; width: auto; }

.masthead-meta {
    display: flex;
    align-items: center;
    gap: clamp(14px, 2vw, 24px);
}
.tel {
    display: inline-grid;
    grid-template-columns: auto auto;
    align-items: baseline;
    gap: 10px;
}
.tel-label {
    font: 500 0.7rem/1 var(--mono);
    text-transform: uppercase;
    letter-spacing: 0.18em;
    color: var(--paper-mute);
}
.tel-number {
    font: 500 0.85rem/1 var(--sans);
    color: var(--paper);
    letter-spacing: 0;
}
.tel:hover .tel-number { color: var(--cyan); }

.nav-signin {
    display: inline-flex;
    align-items: center;
    font: 500 0.72rem/1 var(--mono);
    text-transform: uppercase;
    letter-spacing: 0.16em;
    color: var(--paper);
    border: 1px solid rgba(120, 211, 255, 0.45);
    border-radius: 2px;
    padding: 9px 14px;
    transition: background 200ms ease, border-color 200ms ease, color 200ms ease;
}
.nav-signin:hover,
.nav-signin:focus-visible {
    background: var(--cyan);
    border-color: var(--cyan);
    color: var(--ink);
    outline: none;
}

@media (max-width: 640px) {
    .tel-label { display: none; }
    .tel-number { font-size: 0.78rem; max-width: 38vw; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
    .nav-signin { padding: 8px 12px; font-size: 0.66rem; }
}

/* ============================================================
   HERO
   ============================================================ */

.hero {
    position: relative;
    min-height: 100vh;
    min-height: 100svh;
    display: flex;
    isolation: isolate;
    overflow: hidden;
    border-bottom: 1px solid var(--rule);
}

.hero-stage {
    position: absolute;
    inset: 0;
    z-index: -1;
    overflow: hidden;
}
.hero-stage img {
    width: 100%; height: 100%;
    object-fit: cover;
    object-position: center;
    filter: contrast(1.08) saturate(0.92) brightness(0.78);
    transform: scale(1.04);
    animation: heroDrift 28s ease-in-out infinite alternate;
}
@keyframes heroDrift {
    from { transform: scale(1.04) translate(0, 0); }
    to   { transform: scale(1.08) translate(-1%, -1%); }
}

.hero-veil {
    position: absolute; inset: 0;
    background:
        radial-gradient(900px 600px at 20% 30%, rgba(120, 211, 255, 0.18), transparent 60%),
        radial-gradient(700px 500px at 90% 70%, rgba(184, 137, 255, 0.16), transparent 60%),
        linear-gradient(180deg, rgba(10, 13, 18, 0.55) 0%, rgba(10, 13, 18, 0.62) 50%, var(--bg) 100%);
}
.hero-grain {
    position: absolute; inset: 0;
    pointer-events: none;
    opacity: 0.18;
    mix-blend-mode: overlay;
    background-image: url("data:image/svg+xml;utf8,<svg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.92 0 0 0 0 0.91 0 0 0 0 0.89 0 0 0 0.6 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}

.hero-rule {
    position: absolute;
    top: 96px; left: 0; right: 0;
    height: 1px;
    background: var(--rule);
    z-index: 1;
}

.hero-grid {
    position: relative;
    width: 100%;
    max-width: var(--container);
    margin: 0 auto;
    padding: 32px var(--gutter) 28px;
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: auto 1fr auto;
    grid-template-areas:
        "tl tr"
        "body body"
        "bl br";
    gap: 24px;
}
.tl { grid-area: tl; }
.tr { grid-area: tr; justify-self: end; }
.bl { grid-area: bl; align-self: end; max-width: 60ch; }
.br { grid-area: br; align-self: end; justify-self: end; }

.hero-body {
    grid-area: body;
    align-self: center;
    padding: 56px 0;
}

.display .line { display: block; overflow: hidden; }
.display .reveal {
    display: inline-block;
    transform: translateY(105%);
    opacity: 0;
    animation: revealUp 1100ms cubic-bezier(.2,.7,.2,1) forwards;
}
.display .line:nth-child(1) .reveal { animation-delay: 100ms; }
.display .line:nth-child(2) .reveal { animation-delay: 240ms; }
.display .line:nth-child(3) .reveal { animation-delay: 380ms; }
.display .line:nth-child(4) .reveal { animation-delay: 520ms; }

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

.hero-foot {
    margin-top: clamp(24px, 4vh, 48px);
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: end;
    gap: clamp(20px, 4vw, 56px);
    opacity: 0;
    transform: translateY(20px);
    animation: fadeUp 800ms 700ms cubic-bezier(.2,.7,.2,1) forwards;
}
@keyframes fadeUp {
    to { opacity: 1; transform: translateY(0); }
}

.hero-lede {
    color: var(--paper);
    max-width: 44ch;
    font-size: 1.05rem;
    line-height: 1.55;
    margin: 0;
}

.hero-cta {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    align-items: center;
}

.scroll-hint {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    color: var(--paper-mute);
    transition: color 200ms ease;
}
.scroll-hint:hover { color: var(--paper); }
.scroll-hint svg { width: 14px; height: 14px; animation: scrollNudge 1.8s ease-in-out infinite; }
@keyframes scrollNudge {
    0%, 100% { transform: translateY(0); }
    50%      { transform: translateY(4px); }
}

@media (max-width: 760px) {
    .hero-grid {
        grid-template-columns: 1fr;
        grid-template-areas:
            "tl"
            "tr"
            "body"
            "bl"
            "br";
        padding: 24px var(--gutter);
    }
    .tr, .br { justify-self: start; }
    .hero-body { padding: 32px 0; }
    .hero-foot { grid-template-columns: 1fr; align-items: start; }
}

/* ============================================================
   BUTTONS / LINKS
   ============================================================ */

.btn {
    --pad-y: 14px;
    --pad-x: 22px;
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: var(--pad-y) var(--pad-x);
    font: 500 0.78rem/1 var(--mono);
    text-transform: uppercase;
    letter-spacing: 0.14em;
    border: 1px solid currentColor;
    border-radius: 2px;
    transition: background 180ms ease, color 180ms ease, transform 200ms ease, border-color 180ms ease;
    cursor: pointer;
    will-change: transform;
}
.btn svg { width: 14px; height: 14px; transition: transform 220ms cubic-bezier(.4,0,.2,1); }
.btn:hover svg { transform: translateX(3px); }

.btn-primary {
    background: var(--paper);
    color: var(--ink);
    border-color: var(--paper);
}
.btn-primary:hover {
    background: var(--cyan);
    border-color: var(--cyan);
}
.btn-ghost {
    color: var(--paper);
    border-color: rgba(236, 233, 227, 0.4);
}
.btn-ghost:hover {
    color: var(--cyan);
    border-color: var(--cyan);
}

.link-arrow {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    font: 500 0.78rem/1 var(--mono);
    text-transform: uppercase;
    letter-spacing: 0.14em;
    color: var(--paper);
    padding: 10px 0;
    border-bottom: 1px solid var(--rule);
    transition: color 200ms ease, border-color 200ms ease, gap 220ms ease;
    cursor: pointer;
    align-self: flex-start;
}
.link-arrow svg {
    width: 14px; height: 14px;
    transition: transform 240ms cubic-bezier(.4,0,.2,1);
}
.link-arrow:hover {
    color: var(--cyan);
    border-color: var(--cyan);
    gap: 16px;
}
.link-arrow:hover svg { transform: translateX(2px); }
.link-arrow.inline {
    border: none;
    padding: 4px 0 6px;
    background-image: linear-gradient(currentColor, currentColor);
    background-size: 100% 1px;
    background-position: 0 100%;
    background-repeat: no-repeat;
}

/* ============================================================
   SECTION SCAFFOLD
   ============================================================ */

.section {
    position: relative;
    padding: var(--section-y) 0;
    border-bottom: 1px solid var(--rule);
    background: var(--bg);
    scroll-margin-top: 72px;
}
.section:last-of-type { border-bottom: 0; }

.section-services { background: var(--bg); }
.section-hire     { background: var(--bg-1); }
.section-work     { background: var(--bg); padding: clamp(56px, 8vh, 96px) 0; }
.section-about    { background: var(--bg-1); }
.section-contact  { background: var(--bg); }

.section-mark {
    display: grid;
    grid-template-columns: auto auto 1fr;
    align-items: baseline;
    gap: 28px;
    margin-bottom: clamp(40px, 8vh, 88px);
}
.section-num {
    font: 400 1rem/1 var(--mono);
    color: var(--cyan);
    font-variant-numeric: tabular-nums;
    letter-spacing: 0.05em;
}
.section-label {
    font: 500 0.78rem/1 var(--mono);
    text-transform: uppercase;
    letter-spacing: 0.18em;
    color: var(--paper-mute);
}
.section-rule {
    display: block;
    height: 1px;
    background: var(--rule);
    transform-origin: left;
    transform: scaleX(0);
    transition: transform 1100ms cubic-bezier(.2,.7,.2,1);
}
.section.is-visible .section-rule { transform: scaleX(1); }

.section .display-h {
    margin: 0 0 clamp(40px, 6vh, 72px);
    max-width: 22ch;
}

/* ---------- SERVICES ---------- */

.services-list {
    display: grid;
    gap: 0;
}
.service {
    display: grid;
    grid-template-columns: 80px 1fr;
    gap: clamp(20px, 4vw, 56px);
    padding: clamp(36px, 6vh, 64px) 0;
    border-top: 1px solid var(--rule);
    align-items: start;
    position: relative;
}
.service:last-child { border-bottom: 1px solid var(--rule); }
.service::before {
    content: "";
    position: absolute;
    left: 0; right: 0; top: 0;
    height: 1px;
    background: var(--cyan);
    transform-origin: left;
    transform: scaleX(0);
    transition: transform 600ms cubic-bezier(.4,0,.2,1);
}
.service:hover::before { transform: scaleX(0.06); }
.service-num {
    font: 400 1rem/1 var(--mono);
    color: var(--paper-mute);
    padding-top: 14px;
    font-variant-numeric: tabular-nums;
}
.service-body { display: grid; gap: 18px; max-width: 60ch; }
.service-body h3 { color: var(--paper); }
.service-body p { color: var(--paper); margin: 0; max-width: 52ch; }

.caps-list {
    display: flex;
    flex-wrap: wrap;
    gap: 8px 18px;
    margin-top: 6px;
}
.caps-list li {
    position: relative;
    font: 500 0.72rem/1.4 var(--mono);
    text-transform: uppercase;
    letter-spacing: 0.14em;
    color: var(--paper-mute);
    padding-left: 14px;
}
.caps-list li::before {
    content: "";
    position: absolute;
    left: 0; top: 0.55em;
    width: 6px; height: 1px;
    background: var(--cyan);
}

@media (max-width: 720px) {
    .service { grid-template-columns: 48px 1fr; gap: 16px; }
    .service-num { padding-top: 10px; font-size: 0.85rem; }
}

/* ---------- INVENTORY — REQUEST ---------- */

.hire-request {
    display: grid;
    grid-template-columns: 1.2fr 1fr;
    gap: clamp(40px, 6vw, 96px);
    align-items: start;
    border-top: 1px solid var(--rule);
    padding-top: clamp(40px, 6vh, 64px);
}
.hire-request-copy { display: grid; gap: 24px; max-width: 56ch; }
.hire-request-copy p { margin: 0; }
.hire-request-btn { justify-self: start; margin-top: 8px; }

.hire-request-steps {
    border-left: 1px solid var(--cyan);
    padding-left: clamp(24px, 3vw, 40px);
}
.hire-request-steps .overline {
    color: var(--cyan);
    margin-bottom: 24px;
}
.hire-request-steps ol {
    display: grid;
    gap: 22px;
}
.hire-request-steps li {
    display: grid;
    grid-template-columns: 36px 1fr;
    gap: 18px;
    align-items: baseline;
    padding-bottom: 22px;
    border-bottom: 1px solid var(--rule);
}
.hire-request-steps li:last-child {
    padding-bottom: 0;
    border-bottom: 0;
}
.step-num {
    font: 400 0.85rem/1 var(--mono);
    color: var(--cyan);
    font-variant-numeric: tabular-nums;
}
.step-body {
    font-family: var(--serif);
    font-size: 1.15rem;
    line-height: 1.35;
    color: var(--paper);
}

@media (max-width: 880px) {
    .hire-request { grid-template-columns: 1fr; }
    .hire-request-steps {
        border-left: 0;
        border-top: 1px solid var(--cyan);
        padding-left: 0;
        padding-top: 32px;
    }
}

/* ---------- RECENT WORK ---------- */

.work-strip {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: clamp(12px, 1.6vw, 20px);
}
.work-thumb { margin: 0; }
.work-thumb img {
    width: 100%;
    aspect-ratio: 4 / 5;
    object-fit: cover;
    filter: contrast(1.04) saturate(0.94);
    transition: transform 600ms cubic-bezier(.2,.7,.2,1);
}
.work-thumb:hover img { transform: scale(1.03); }

.work-thumb-placeholder {
    width: 100%;
    aspect-ratio: 4 / 5;
    background:
        repeating-linear-gradient(135deg, rgba(120, 211, 255, 0.04) 0 2px, transparent 2px 14px),
        var(--bg-2);
    border: 1px solid var(--rule);
    display: grid;
    place-content: center;
    gap: 10px;
    text-align: center;
    transition: background 400ms ease;
}
.work-thumb--placeholder:hover .work-thumb-placeholder {
    background:
        repeating-linear-gradient(135deg, rgba(120, 211, 255, 0.07) 0 2px, transparent 2px 14px),
        var(--bg-2);
}
.placeholder-mark {
    font: 400 1.2rem/1 var(--mono);
    color: var(--cyan);
    font-variant-numeric: tabular-nums;
    letter-spacing: 0.04em;
}
.placeholder-note {
    font: 500 0.62rem/1.4 var(--mono);
    text-transform: uppercase;
    letter-spacing: 0.18em;
    color: var(--paper-mute);
}

.work-thumb figcaption {
    display: grid;
    grid-template-columns: auto 1fr;
    align-items: baseline;
    column-gap: 8px;
    row-gap: 2px;
    margin-top: 10px;
    padding-bottom: 10px;
    border-bottom: 1px solid var(--rule);
}
.cap-num {
    font: 400 0.7rem/1 var(--mono);
    color: var(--cyan);
    font-variant-numeric: tabular-nums;
    grid-row: 1;
}
.cap-title {
    font-family: var(--serif);
    font-size: 1rem;
    color: var(--paper);
    line-height: 1.15;
    grid-row: 1;
}
.cap-meta {
    grid-column: 1 / -1;
    font: 500 0.62rem/1 var(--mono);
    text-transform: uppercase;
    letter-spacing: 0.14em;
    color: var(--paper-mute);
    padding-top: 2px;
}

@media (max-width: 1100px) {
    .work-strip { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 760px) {
    .work-strip { grid-template-columns: repeat(2, 1fr); }
}

/* ---------- ABOUT ---------- */

.about-grid {
    display: grid;
    grid-template-columns: 1.5fr 1fr;
    gap: clamp(40px, 6vw, 96px);
    align-items: start;
}
.about-copy { display: grid; gap: 24px; max-width: 60ch; }
.about-copy p { color: var(--paper); margin: 0; }
.about-copy .link-arrow { margin-top: 8px; }

.about-stats {
    border-top: 1px solid var(--cyan);
    padding-top: 24px;
}
.about-stats dl { display: grid; gap: 0; }
.stat {
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: baseline;
    gap: 16px;
    padding: 22px 0;
    border-bottom: 1px solid var(--rule);
}
.stat dt {
    font: 500 0.72rem/1 var(--mono);
    text-transform: uppercase;
    letter-spacing: 0.18em;
    color: var(--paper-mute);
}
.stat dd {
    font-family: var(--serif);
    font-size: 1.2rem;
    color: var(--paper);
    text-align: right;
}
.stat-cta dd { text-align: right; }
.stat-cta .link-arrow { padding: 0; border: none; background: none; }
.stat-cta .link-arrow span {
    background-image: linear-gradient(currentColor, currentColor);
    background-size: 100% 1px;
    background-position: 0 100%;
    background-repeat: no-repeat;
    padding-bottom: 3px;
}

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

/* ---------- CONTACT ---------- */

.contact-grid {
    display: grid;
    grid-template-columns: 1fr 1.2fr;
    gap: clamp(40px, 6vw, 96px);
    align-items: start;
}
.contact-info { display: grid; gap: 28px; }
.contact-info p { margin: 0; max-width: 40ch; }

.contact-list {
    display: grid;
    gap: 0;
    border-top: 1px solid var(--rule);
    margin-top: 8px;
}
.contact-list > div {
    display: grid;
    grid-template-columns: 140px 1fr;
    gap: 16px;
    padding: 18px 0;
    border-bottom: 1px solid var(--rule);
    align-items: baseline;
}
.contact-list dt {
    font: 500 0.72rem/1 var(--mono);
    text-transform: uppercase;
    letter-spacing: 0.18em;
    color: var(--paper-mute);
}
.contact-list dd {
    font-family: var(--sans);
    font-size: 1rem;
    font-weight: 500;
    color: var(--paper);
}
.contact-list dd a {
    background-image: linear-gradient(var(--cyan), var(--cyan));
    background-size: 0% 1px;
    background-position: 0 100%;
    background-repeat: no-repeat;
    padding-bottom: 4px;
    transition: background-size 320ms cubic-bezier(.4,0,.2,1), color 200ms ease;
}
.contact-list dd a:hover { color: var(--cyan); background-size: 100% 1px; }

.contact-form {
    background: var(--bg-1);
    padding: clamp(28px, 4vw, 48px);
    border: 1px solid var(--rule);
    border-radius: 2px;
}
.form-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 22px;
}
.form-grid .span-2 { grid-column: 1 / -1; }
.field { display: grid; gap: 10px; }
.field > span {
    font: 500 0.7rem/1 var(--mono);
    text-transform: uppercase;
    letter-spacing: 0.18em;
    color: var(--paper-mute);
}
.field > span em {
    font-family: var(--serif);
    font-style: italic;
    text-transform: none;
    letter-spacing: 0;
    color: var(--paper-dim);
    font-size: 0.9rem;
}

input, textarea {
    width: 100%;
    background: transparent;
    border: 0;
    border-bottom: 1px solid var(--rule);
    padding: 8px 0 12px;
    color: var(--paper);
    font: 400 1rem/1.4 var(--sans);
    border-radius: 0;
    transition: border-color 200ms ease;
}
textarea { resize: vertical; min-height: 120px; line-height: 1.55; }
input::placeholder, textarea::placeholder {
    color: var(--paper-dim);
    font-style: italic;
}
input:focus, textarea:focus {
    outline: none;
    border-color: var(--cyan);
}

.field.is-invalid input,
.field.is-invalid textarea {
    border-color: var(--purple);
    background: rgba(184, 137, 255, 0.05);
}
.field.is-invalid > span {
    color: var(--purple);
}

.form-honeypot {
    position: absolute;
    left: -9999px;
    width: 1px;
    height: 1px;
    overflow: hidden;
}

.btn[data-submit][aria-busy="true"] {
    opacity: 0.7;
    cursor: progress;
    pointer-events: none;
}

.form-actions {
    display: flex;
    align-items: center;
    gap: 24px;
    margin-top: 32px;
    padding-top: 24px;
    border-top: 1px solid var(--rule);
    flex-wrap: wrap;
}
.form-status {
    font: 500 0.72rem/1.4 var(--mono);
    text-transform: uppercase;
    letter-spacing: 0.16em;
    color: var(--paper-mute);
    margin: 0;
    min-height: 1em;
}
.form-status[data-state="ok"] { color: var(--cyan); }
.form-status[data-state="error"] { color: var(--purple); }

@media (max-width: 880px) {
    .contact-grid { grid-template-columns: 1fr; }
    .form-grid { grid-template-columns: 1fr; }
    .contact-list > div { grid-template-columns: 1fr; gap: 4px; }
}

/* ============================================================
   FOOTER
   ============================================================ */

.site-footer {
    padding: clamp(48px, 8vh, 80px) 0 clamp(28px, 4vh, 40px);
    background: var(--ink);
    border-top: 1px solid var(--rule);
    text-align: center;
}
.footer-mark {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto;
    opacity: 0.95;
    transition: opacity 200ms ease;
}
.footer-mark:hover { opacity: 1; }
.footer-mark img { height: clamp(36px, 4vw, 48px); width: auto; }

.footer-links {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: 8px 28px;
    margin: clamp(20px, 3vh, 28px) 0 0;
}
.footer-links a {
    font: 500 0.72rem/1 var(--mono);
    text-transform: uppercase;
    letter-spacing: 0.18em;
    color: var(--paper-mute);
    padding: 6px 0;
    background-image: linear-gradient(var(--cyan), var(--cyan));
    background-size: 0% 1px;
    background-position: 50% 100%;
    background-repeat: no-repeat;
    transition: background-size 280ms cubic-bezier(.4,0,.2,1), color 200ms ease;
}
.footer-links a:hover,
.footer-links a[aria-current="page"] { color: var(--cyan); background-size: 100% 1px; }

.footer-legal {
    margin: clamp(16px, 2.5vh, 24px) 0 0;
    font: 500 0.7rem/1.6 var(--mono);
    text-transform: uppercase;
    letter-spacing: 0.18em;
    color: var(--paper-dim);
}

/* ============================================================
   404
   ============================================================ */

.notfound { min-height: calc(100vh - 72px); display: flex; }
.notfound-section {
    position: relative;
    width: 100%;
    overflow: hidden;
    padding: clamp(72px, 14vh, 160px) 0 clamp(72px, 12vh, 140px);
    border-bottom: 1px solid var(--rule);
}
.notfound-grid {
    position: relative;
    z-index: 2;
    max-width: 720px;
    display: grid;
    gap: 22px;
}
.notfound-eyebrow { color: var(--purple); }
.notfound-title {
    font-family: var(--serif);
    font-weight: 400;
    font-size: clamp(3rem, 8vw, 6rem);
    line-height: 1.0;
    letter-spacing: -0.02em;
    color: var(--paper);
    margin: 0;
}
.notfound-title em { font-style: italic; color: var(--cyan); }
.notfound-lede {
    color: var(--paper-mute);
    margin: 0;
    max-width: 52ch;
    font-size: 1.05rem;
}
.notfound-cta {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 14px;
}
.notfound-links {
    display: flex;
    flex-wrap: wrap;
    gap: 8px 28px;
    margin-top: clamp(36px, 6vh, 56px);
    padding-top: 24px;
    border-top: 1px solid var(--rule);
    list-style: none;
    padding-left: 0;
}
.notfound-links a {
    font: 500 0.78rem/1 var(--mono);
    text-transform: uppercase;
    letter-spacing: 0.16em;
    color: var(--paper-mute);
    padding: 8px 0;
    background-image: linear-gradient(var(--cyan), var(--cyan));
    background-size: 0% 1px;
    background-position: 0 100%;
    background-repeat: no-repeat;
    transition: background-size 280ms cubic-bezier(.4,0,.2,1), color 200ms ease;
    display: inline-block;
}
.notfound-links a:hover { color: var(--cyan); background-size: 100% 1px; }

.notfound-mark {
    position: absolute;
    right: -2vw;
    bottom: -8vw;
    z-index: 1;
    font-family: var(--serif);
    font-size: clamp(18rem, 36vw, 36rem);
    line-height: 0.8;
    letter-spacing: -0.04em;
    color: rgba(120, 211, 255, 0.05);
    user-select: none;
    pointer-events: none;
    font-style: italic;
}

@media (max-width: 760px) {
    .notfound-mark { right: -6vw; bottom: -14vw; }
}

/* ============================================================
   AUTH / PORTAL PAGES (login / account)
   ============================================================ */

.auth-page { min-height: calc(100vh - 72px); display: flex; }
.auth-section {
    width: 100%;
    padding: clamp(56px, 10vh, 120px) 0;
    border-bottom: 1px solid var(--rule);
}
.auth-wrap { max-width: 540px; }

.auth-eyebrow { color: var(--cyan); margin-bottom: 18px; }
.auth-title {
    font-family: var(--serif);
    font-weight: 400;
    font-size: clamp(2.4rem, 5vw, 3.8rem);
    line-height: 1.05;
    letter-spacing: -0.02em;
    color: var(--paper);
    margin: 0 0 18px;
}
.auth-title em { font-style: italic; color: var(--cyan); }
.auth-lede {
    color: var(--paper-mute);
    margin: 0 0 36px;
    max-width: 50ch;
    font-size: 1.02rem;
}

.auth-banner {
    margin: 0 0 24px;
    padding: 14px 18px;
    border: 1px solid rgba(184, 137, 255, 0.35);
    background: rgba(184, 137, 255, 0.06);
    border-radius: 4px;
    color: var(--paper);
    font-size: 0.95rem;
}

.auth-form {
    display: grid;
    gap: 28px;
    padding: 0;
    border: 0;
    background: none;
}
.auth-form .form-actions {
    margin-top: 0;
    padding-top: 0;
    border-top: 0;
    gap: 18px;
}

.auth-success {
    margin-top: 8px;
    padding: 28px 32px;
    background: var(--bg-1);
    border-left: 1px solid var(--cyan);
}
.auth-success .overline { color: var(--cyan); margin-bottom: 12px; }
.auth-success-title {
    font-family: var(--serif);
    font-weight: 400;
    font-size: 1.6rem;
    line-height: 1.2;
    color: var(--paper);
    margin: 0 0 14px;
}
.auth-success p { margin: 0 0 8px; max-width: 48ch; }
.auth-success p:last-child { margin-bottom: 0; }
.auth-success a {
    color: var(--paper);
    background-image: linear-gradient(var(--cyan), var(--cyan));
    background-size: 100% 1px;
    background-position: 0 100%;
    background-repeat: no-repeat;
}

.auth-foot {
    margin-top: clamp(40px, 6vh, 64px);
    padding-top: 24px;
    border-top: 1px solid var(--rule);
    display: flex;
    flex-wrap: wrap;
    gap: 8px 16px;
    align-items: baseline;
    font: 500 0.72rem/1.4 var(--mono);
    text-transform: uppercase;
    letter-spacing: 0.16em;
    color: var(--paper-mute);
}
.auth-foot a {
    color: var(--paper);
    background-image: linear-gradient(var(--cyan), var(--cyan));
    background-size: 0% 1px;
    background-position: 0 100%;
    background-repeat: no-repeat;
    transition: background-size 280ms cubic-bezier(.4,0,.2,1), color 200ms ease;
    padding-bottom: 3px;
}
.auth-foot a:hover { color: var(--cyan); background-size: 100% 1px; }

/* ---------- account dashboard ---------- */

.account-loading {
    padding: 40px 0;
    color: var(--paper-mute);
}

.account-shell { display: grid; gap: clamp(28px, 4vh, 40px); }

.account-header {
    display: flex;
    flex-wrap: wrap;
    gap: 24px;
    align-items: end;
    justify-content: space-between;
    padding-bottom: clamp(28px, 4vh, 40px);
    border-bottom: 1px solid var(--rule);
}
.account-header .overline { color: var(--cyan); margin-bottom: 14px; }
.account-greeting {
    font-family: var(--serif);
    font-weight: 400;
    font-size: clamp(2rem, 4vw, 3rem);
    line-height: 1.05;
    letter-spacing: -0.02em;
    color: var(--paper);
    margin: 0 0 8px;
}
.account-greeting em { font-style: italic; color: var(--cyan); }

.account-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 4px 28px;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--rule);
}
.account-tabs a {
    font: 500 0.78rem/1 var(--mono);
    text-transform: uppercase;
    letter-spacing: 0.16em;
    color: var(--paper-mute);
    padding: 12px 0;
    position: relative;
    transition: color 200ms ease;
}
.account-tabs a::after {
    content: "";
    position: absolute;
    left: 0; right: 100%;
    bottom: -1px;
    height: 1px;
    background: var(--cyan);
    transition: right 280ms cubic-bezier(.4,0,.2,1);
}
.account-tabs a.is-active { color: var(--paper); }
.account-tabs a.is-active::after { right: 0; }
.account-tabs a[aria-disabled="true"] {
    opacity: 0.5;
    cursor: not-allowed;
    pointer-events: none;
}

.account-panel { display: grid; gap: 24px; padding-top: clamp(20px, 3vh, 32px); }
.account-panel-head { display: grid; gap: 8px; }
.account-panel-head .display-sub { color: var(--paper); }
.account-panel-head p { color: var(--paper-mute); margin: 0; max-width: 60ch; }

.account-empty {
    padding: clamp(28px, 4vh, 44px);
    background: var(--bg-1);
    border: 1px solid var(--rule);
    border-radius: 4px;
    display: grid;
    gap: 12px;
}

/* ---- admin ---- */
.admin-quick-links { display: flex; gap: 12px; flex-wrap: wrap; }

.admin-form .form-grid { grid-template-columns: 1fr 1fr; }
.admin-form-hint {
    margin: 18px 0 0;
    padding: 12px 16px;
    background: rgba(120, 211, 255, 0.04);
    border-left: 1px solid var(--cyan);
    font-size: 0.92rem;
}

.admin-total {
    margin-top: 24px;
    padding: clamp(20px, 3vw, 28px);
    background: var(--bg-1);
    border: 1px solid var(--rule);
    border-radius: 4px;
}
.admin-total .overline { color: var(--cyan); margin-bottom: 12px; }
.admin-total-lines {
    display: grid;
    gap: 8px;
    margin: 0 0 16px;
    padding-bottom: 16px;
    border-bottom: 1px solid var(--rule);
}
.admin-total-lines > div {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 12px;
}
.admin-total-lines dt {
    font: 500 0.78rem/1.4 var(--mono);
    text-transform: uppercase;
    letter-spacing: 0.14em;
    color: var(--paper-mute);
}
.admin-total-lines dt .muted { font-style: normal; text-transform: none; letter-spacing: 0; font-size: 0.95em; }
.admin-total-lines dd {
    font-family: var(--sans);
    font-variant-numeric: tabular-nums;
    color: var(--paper);
    margin: 0;
}
.admin-total-final {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 12px;
}
.admin-total-final .overline { margin: 0; color: var(--paper-mute); }
.admin-total-amount {
    font-family: var(--serif);
    font-size: clamp(1.8rem, 3vw, 2.4rem);
    line-height: 1;
    color: var(--cyan);
    font-variant-numeric: tabular-nums;
}
.admin-form select {
    width: 100%;
    background: transparent;
    border: 0;
    border-bottom: 1px solid var(--rule);
    padding: 8px 0 12px;
    color: var(--paper);
    font: 400 1rem/1.4 var(--sans);
    border-radius: 0;
    transition: border-color 200ms ease;
}
.admin-form select:focus { outline: none; border-color: var(--cyan); }
.admin-form input[type="date"] {
    color-scheme: dark;
}
.admin-form input[type="number"] { -moz-appearance: textfield; }
.admin-form input[type="number"]::-webkit-outer-spin-button,
.admin-form input[type="number"]::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }

.admin-users { display: grid; gap: 12px; }

/* ---- shared files ---- */
.files-list-heading { margin-top: clamp(32px, 5vh, 48px); margin-bottom: 16px; }
.files { list-style: none; padding: 0; margin: 0; display: grid; gap: 12px; }
.file-row {
    display: grid;
    gap: 14px;
    padding: 16px 18px;
    background: var(--bg-1);
    border: 1px solid var(--rule);
    border-radius: 4px;
}
.file-row-main {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 18px;
    align-items: start;
}
.file-log {
    margin-top: 4px;
    padding-top: 12px;
    border-top: 1px solid var(--rule);
}
.file-log-table th, .file-log-table td { padding: 8px 12px; }
.file-log-table code {
    font: 400 0.78rem/1 var(--mono);
    color: var(--paper-mute);
}
.file-meta { display: grid; gap: 4px; min-width: 0; }
.file-name {
    margin: 0;
    font-family: var(--serif);
    font-size: 1.1rem;
    color: var(--paper);
    overflow-wrap: anywhere;
}
.file-meta-line {
    margin: 0;
    font: 500 0.7rem/1.4 var(--mono);
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--paper-mute);
}
.file-actions {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 6px;
}
.file-url {
    font: 400 0.78rem/1.4 var(--mono);
    color: var(--paper-mute);
    background: var(--bg);
    padding: 6px 10px;
    border: 1px solid var(--rule);
    border-radius: 2px;
    max-width: 320px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    user-select: all;
    text-transform: none;
    letter-spacing: 0;
}
.file-actions .link-arrow { padding: 4px 0; border: 0; }
.file-actions .link-arrow svg { display: none; }
.file-delete:hover { color: var(--purple); border-color: var(--purple); }

.file-upload-form input[type="file"] {
    border: 1px dashed var(--rule);
    padding: 10px 12px;
    border-radius: 2px;
    color: var(--paper);
}
.file-upload-form input[type="file"]:hover { border-color: var(--cyan); }

@media (max-width: 720px) {
    .file-row-main { grid-template-columns: 1fr; }
    .file-actions { align-items: flex-start; flex-direction: row; flex-wrap: wrap; }
    .file-url { max-width: 100%; }
}

/* ---- stock picker ---- */
.stock-picker {
    margin-top: 32px;
    padding: clamp(20px, 3vw, 28px);
    background: var(--bg);
    border: 1px solid var(--rule);
    border-radius: 4px;
    display: grid;
    gap: 18px;
}
.stock-picker-head {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
}
.stock-picker-head .overline { color: var(--cyan); margin-bottom: 6px; }
.stock-picker-title { font-size: clamp(1.3rem, 2vw, 1.6rem); margin: 0 0 4px; }
.stock-picker-note  { margin: 0; max-width: 60ch; }

.stock-picker-summary { text-align: right; display: grid; gap: 4px; }
.stock-picker-summary .overline { color: var(--paper-mute); }
.stock-count {
    font-family: var(--serif);
    font-size: 2rem;
    line-height: 1;
    color: var(--cyan);
    font-variant-numeric: tabular-nums;
}

.stock-picker-controls {
    display: flex;
    align-items: center;
    gap: 16px;
    flex-wrap: wrap;
}
.stock-search {
    flex: 1 1 240px;
    background: transparent;
    border: 0;
    border-bottom: 1px solid var(--rule);
    padding: 8px 0 10px;
    color: var(--paper);
    font: 400 1rem/1.4 var(--sans);
    border-radius: 0;
}
.stock-search:focus { outline: none; border-color: var(--cyan); }
.stock-search::placeholder { color: var(--paper-dim); font-style: italic; }

.stock-list {
    max-height: 420px;
    overflow-y: auto;
    border: 1px solid var(--rule);
    border-radius: 4px;
    background: var(--bg-1);
    padding: 4px 4px;
}
.stock-list::-webkit-scrollbar { width: 6px; }
.stock-list::-webkit-scrollbar-thumb { background: var(--rule); border-radius: 3px; }

.stock-group { padding: 8px 4px 0; }
.stock-group + .stock-group { border-top: 1px solid var(--rule); margin-top: 8px; }
.stock-group-head {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    padding: 6px 12px;
    font: 500 0.7rem/1 var(--mono);
    text-transform: uppercase;
    letter-spacing: 0.16em;
    color: var(--paper-mute);
}
.stock-group-name { color: var(--paper); }

.stock-items { list-style: none; padding: 0; margin: 0 0 6px; }
.stock-item label {
    display: grid;
    grid-template-columns: auto 1fr auto auto;
    align-items: baseline;
    gap: 12px;
    padding: 9px 12px;
    border-radius: 2px;
    cursor: pointer;
    font-size: 0.92rem;
    transition: background 140ms ease;
}
.stock-item label:hover { background: rgba(120, 211, 255, 0.04); }
.stock-item.is-selected label { background: rgba(120, 211, 255, 0.08); }
.stock-item input[type="checkbox"] {
    accent-color: var(--cyan);
    width: 16px; height: 16px;
    cursor: pointer;
}
.stock-item-name { color: var(--paper); }
.stock-item-barcode {
    font: 500 0.78rem/1 var(--mono);
    color: var(--paper-mute);
    letter-spacing: 0.04em;
    font-variant-numeric: tabular-nums;
}
.stock-item-meta {
    font: 400 0.72rem/1 var(--mono);
    text-transform: uppercase;
    letter-spacing: 0.14em;
    color: var(--paper-dim);
}

@media (max-width: 600px) {
    .stock-item label {
        grid-template-columns: auto 1fr;
        grid-auto-rows: auto;
    }
    .stock-item-barcode, .stock-item-meta {
        grid-column: 2;
        font-size: 0.7rem;
    }
}
.admin-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.92rem;
}
.admin-table th, .admin-table td {
    text-align: left;
    padding: 14px 16px;
    border-bottom: 1px solid var(--rule);
    vertical-align: top;
}
.admin-table th {
    font: 500 0.7rem/1 var(--mono);
    text-transform: uppercase;
    letter-spacing: 0.16em;
    color: var(--paper-mute);
    background: var(--bg-1);
    border-bottom-color: var(--cyan);
}
.admin-table td { color: var(--paper); }
.admin-pill {
    display: inline-block;
    margin-left: 6px;
    padding: 2px 8px;
    font: 500 0.62rem/1.4 var(--mono);
    text-transform: uppercase;
    letter-spacing: 0.16em;
    color: var(--ink);
    background: var(--cyan);
    border-radius: 999px;
}
.status-dot {
    display: inline-block;
    width: 8px; height: 8px;
    border-radius: 50%;
    margin-right: 8px;
    background: var(--paper-mute);
    vertical-align: 1px;
}
.status-dot.status-active   { background: var(--cyan); }
.status-dot.status-disabled { background: var(--purple); }
.status-dot.status-invited  { background: #ffd28a; }

@media (max-width: 720px) {
    .admin-form .form-grid { grid-template-columns: 1fr; }
    .admin-table thead { display: none; }
    .admin-table tr {
        display: grid;
        grid-template-columns: 1fr;
        gap: 4px;
        padding: 14px 0;
        border-bottom: 1px solid var(--rule);
    }
    .admin-table td { border: 0; padding: 2px 0; }
    .admin-table td::before {
        content: attr(data-label);
        display: inline-block;
        min-width: 100px;
        font: 500 0.65rem/1 var(--mono);
        text-transform: uppercase;
        letter-spacing: 0.14em;
        color: var(--paper-mute);
        margin-right: 8px;
    }
}

/* ---- contract cards ---- */
.contract-card {
    display: grid;
    gap: 22px;
    padding: clamp(22px, 3vw, 32px);
    background: var(--bg-1);
    border: 1px solid var(--rule);
    border-radius: 4px;
    margin-bottom: 16px;
    transition: border-color 200ms ease;
}
.contract-card.status-signed { border-left: 2px solid var(--cyan); }
.contract-card.status-cancelled { opacity: 0.5; }

.contract-head {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: space-between;
    gap: 14px;
}
.contract-head .overline { color: var(--cyan); margin-bottom: 8px; }
.contract-title {
    font-family: var(--serif);
    font-weight: 400;
    font-size: clamp(1.4rem, 2vw, 1.7rem);
    line-height: 1.1;
    color: var(--paper);
    margin: 0;
}

.contract-status {
    font: 500 0.65rem/1 var(--mono);
    text-transform: uppercase;
    letter-spacing: 0.18em;
    padding: 6px 10px;
    border: 1px solid var(--rule);
    border-radius: 999px;
    color: var(--paper-mute);
}
.contract-status.status-signed { color: var(--cyan); border-color: rgba(120, 211, 255, 0.4); }
.contract-status.status-cancelled { color: var(--purple); border-color: rgba(184, 137, 255, 0.4); }

.contract-meta {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 16px 28px;
    padding: 18px 0;
    border-top: 1px solid var(--rule);
    border-bottom: 1px solid var(--rule);
    margin: 0;
}
.contract-meta > div { display: grid; gap: 4px; }
.contract-meta dt {
    font: 500 0.7rem/1 var(--mono);
    text-transform: uppercase;
    letter-spacing: 0.16em;
    color: var(--paper-mute);
}
.contract-meta dd {
    font-family: var(--sans);
    font-size: 1rem;
    color: var(--paper);
    margin: 0;
}

.contract-actions { display: flex; gap: 16px; flex-wrap: wrap; }
.contract-tag {
    font: 500 0.72rem/1 var(--mono);
    text-transform: uppercase;
    letter-spacing: 0.16em;
    color: var(--paper-mute);
    padding: 10px 0;
}
.contract-tag.tag-signed { color: var(--cyan); }
.contract-tag.tag-cancelled { color: var(--purple); }

/* ---- sign modal ---- */
.contract-modal-overlay {
    position: fixed;
    inset: 0;
    z-index: 200;
    background: rgba(5, 7, 9, 0.78);
    backdrop-filter: blur(4px);
    display: grid;
    place-items: center;
    padding: clamp(16px, 4vh, 40px);
    animation: modalFade 200ms ease;
}
@keyframes modalFade { from { opacity: 0; } to { opacity: 1; } }

.contract-modal {
    width: 100%;
    max-width: 680px;
    max-height: 86vh;
    background: var(--bg-1);
    border: 1px solid var(--rule);
    border-radius: 4px;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    animation: modalRise 320ms cubic-bezier(.2,.7,.2,1);
}
@keyframes modalRise { from { transform: translateY(20px); opacity: 0; } to { transform: translateY(0); opacity: 1; } }

.contract-modal-head {
    position: relative;
    padding: clamp(20px, 3vw, 28px) clamp(24px, 4vw, 36px);
    border-bottom: 1px solid var(--rule);
}
.contract-modal-head .overline { color: var(--cyan); margin-bottom: 8px; }
.contract-modal-head .display-sub { font-size: clamp(1.4rem, 2.2vw, 1.8rem); }
.contract-modal-close {
    position: absolute;
    top: 12px;
    right: 12px;
    width: 36px; height: 36px;
    display: grid;
    place-items: center;
    color: var(--paper-mute);
    font-size: 24px;
    line-height: 1;
    border-radius: 2px;
}
.contract-modal-close:hover { color: var(--paper); background: rgba(255,255,255,0.04); }

.contract-modal-body {
    flex: 1 1 auto;
    overflow-y: auto;
    padding: clamp(20px, 3vw, 28px) clamp(24px, 4vw, 36px);
}
.contract-body {
    margin: 0;
    font-family: var(--sans);
    font-size: 0.95rem;
    line-height: 1.6;
    color: var(--paper);
    white-space: pre-wrap;
    word-wrap: break-word;
}

.contract-modal-sign {
    padding: clamp(20px, 3vw, 28px) clamp(24px, 4vw, 36px);
    border-top: 1px solid var(--rule);
    background: var(--bg);
    display: grid;
    gap: 14px;
}
.contract-modal-sign .overline { color: var(--cyan); }
.contract-modal-disclaimer {
    margin: 0;
    font-size: 0.85rem;
    line-height: 1.5;
    max-width: 60ch;
}
.contract-modal-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 6px;
}
.contract-modal-sign .form-status { margin: 0; }
.account-empty .overline { color: var(--cyan); }
.account-empty p { margin: 0; max-width: 56ch; }
.account-empty a {
    color: var(--paper);
    background-image: linear-gradient(var(--cyan), var(--cyan));
    background-size: 100% 1px;
    background-position: 0 100%;
    background-repeat: no-repeat;
}

@media (max-width: 640px) {
    .account-header { flex-direction: column; align-items: flex-start; }
    .account-header .btn { align-self: flex-start; }
}

/* ============================================================
   LEGAL PAGES (terms / privacy)
   ============================================================ */

.legal-hero {
    padding: clamp(64px, 10vh, 112px) 0 clamp(36px, 6vh, 56px);
    border-bottom: 1px solid var(--rule);
}
.legal-hero .container { display: grid; gap: 22px; }

.legal-back {
    font: 500 0.72rem/1 var(--mono);
    text-transform: uppercase;
    letter-spacing: 0.18em;
    color: var(--paper-mute);
    display: inline-flex;
    align-items: center;
    gap: 10px;
    transition: color 200ms ease, gap 220ms ease;
    justify-self: start;
}
.legal-back:hover { color: var(--cyan); gap: 14px; }
.legal-back svg { width: 14px; height: 14px; transform: rotate(180deg); }

.legal-title {
    font-family: var(--serif);
    font-weight: 400;
    font-size: clamp(2.4rem, 5.6vw, 5rem);
    line-height: 1.02;
    letter-spacing: -0.02em;
    color: var(--paper);
    margin: 0;
    max-width: 22ch;
}
.legal-title em { font-style: italic; color: var(--cyan); }

.legal-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 18px 28px;
    font: 500 0.72rem/1 var(--mono);
    text-transform: uppercase;
    letter-spacing: 0.18em;
    color: var(--paper-mute);
    margin: 0;
}
.legal-meta span em {
    font-family: var(--serif);
    font-style: italic;
    text-transform: none;
    letter-spacing: 0;
    color: var(--paper);
    font-size: 0.95rem;
    margin-left: 6px;
}

.legal-body { padding: clamp(48px, 7vh, 80px) 0 clamp(64px, 10vh, 112px); }
.legal-body .container {
    max-width: 820px;
    padding: 0 var(--gutter);
}

.legal-prose {
    color: var(--paper);
    font-size: 1.02rem;
    line-height: 1.7;
}
.legal-prose .lede {
    font-size: 1.15rem;
    color: var(--paper);
    line-height: 1.55;
    margin: 0 0 8px;
    max-width: none;
}

.legal-prose section {
    padding: clamp(28px, 4vh, 44px) 0;
    border-top: 1px solid var(--rule);
}
.legal-prose section:first-of-type {
    border-top: 0;
    padding-top: 0;
}

.legal-prose h2 {
    font-family: var(--serif);
    font-weight: 400;
    font-size: clamp(1.6rem, 2.6vw, 2.2rem);
    line-height: 1.1;
    letter-spacing: -0.015em;
    color: var(--paper);
    margin: 0 0 24px;
    display: grid;
    grid-template-columns: 56px 1fr;
    gap: 16px;
    align-items: baseline;
}
.legal-prose h2 .num {
    font: 400 0.95rem/1 var(--mono);
    color: var(--cyan);
    font-variant-numeric: tabular-nums;
}
.legal-prose h3 {
    font-family: var(--sans);
    font-weight: 600;
    font-size: 1rem;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--paper);
    margin: 28px 0 12px;
}

.legal-prose p { margin: 0 0 16px; }
.legal-prose p:last-child { margin-bottom: 0; }

.legal-prose ol.alpha {
    list-style: none;
    padding: 0;
    margin: 18px 0;
    counter-reset: alpha;
}
.legal-prose ol.alpha > li {
    position: relative;
    padding-left: 44px;
    margin: 16px 0;
    counter-increment: alpha;
}
.legal-prose ol.alpha > li::before {
    content: counter(alpha, lower-alpha) ")";
    position: absolute;
    left: 0;
    top: 1px;
    font: 500 0.82rem/1.7 var(--mono);
    color: var(--cyan);
    width: 36px;
    text-transform: none;
}
.legal-prose ol.alpha.dbl {
    counter-reset: dbl;
}
.legal-prose ol.alpha.dbl > li {
    counter-increment: dbl;
}
.legal-prose ol.alpha.dbl > li::before {
    content: counter(dbl, lower-alpha) counter(dbl, lower-alpha) ")";
}

.legal-prose ol.roman {
    list-style: none;
    padding: 0;
    margin: 12px 0 12px 24px;
    counter-reset: roman;
}
.legal-prose ol.roman > li {
    position: relative;
    padding-left: 36px;
    margin: 8px 0;
    counter-increment: roman;
}
.legal-prose ol.roman > li::before {
    content: "(" counter(roman, lower-roman) ")";
    position: absolute;
    left: 0;
    top: 0;
    font: 500 0.82rem/1.7 var(--mono);
    color: var(--paper-mute);
    width: 28px;
}

.legal-prose ul {
    list-style: none;
    padding: 0;
    margin: 12px 0;
}
.legal-prose ul > li {
    position: relative;
    padding-left: 22px;
    margin: 8px 0;
}
.legal-prose ul > li::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0.7em;
    width: 8px; height: 1px;
    background: var(--cyan);
}

.legal-prose strong { color: var(--paper); font-weight: 600; }

.legal-prose a {
    color: var(--paper);
    background-image: linear-gradient(var(--cyan), var(--cyan));
    background-size: 100% 1px;
    background-position: 0 100%;
    background-repeat: no-repeat;
    transition: color 200ms ease;
}
.legal-prose a:hover { color: var(--cyan); }

.legal-toc {
    margin: 0 0 clamp(48px, 7vh, 72px);
    padding: clamp(20px, 3vh, 28px) 0;
    border-top: 1px solid var(--rule);
    border-bottom: 1px solid var(--rule);
}
.legal-toc-label {
    font: 500 0.7rem/1 var(--mono);
    text-transform: uppercase;
    letter-spacing: 0.18em;
    color: var(--paper-mute);
    margin: 0 0 16px;
}
.legal-toc ol {
    list-style: none;
    padding: 0;
    margin: 0;
    columns: 2;
    column-gap: 32px;
}
.legal-toc li {
    break-inside: avoid;
    padding: 4px 0;
}
.legal-toc a {
    display: grid;
    grid-template-columns: 36px 1fr;
    gap: 12px;
    align-items: baseline;
    color: var(--paper);
    font-size: 0.96rem;
    padding: 4px 0;
}
.legal-toc a span:first-child {
    font: 400 0.78rem/1 var(--mono);
    color: var(--cyan);
    font-variant-numeric: tabular-nums;
}
.legal-toc a:hover { color: var(--cyan); }

@media (max-width: 720px) {
    .legal-prose h2 { grid-template-columns: 36px 1fr; gap: 12px; }
    .legal-toc ol { columns: 1; }
}

/* ============================================================
   REVEALS / MOTION
   ============================================================ */

.section .display-h,
.section .about-stats,
.section .work-strip,
.section .contact-info,
.section .contact-form,
.section .services-list,
.section .hire-request {
    opacity: 0;
    transform: translateY(24px);
    transition: opacity 900ms cubic-bezier(.2,.7,.2,1), transform 900ms cubic-bezier(.2,.7,.2,1);
}
.section.is-visible .display-h,
.section.is-visible .about-stats,
.section.is-visible .work-strip,
.section.is-visible .contact-info,
.section.is-visible .contact-form,
.section.is-visible .services-list,
.section.is-visible .hire-request {
    opacity: 1;
    transform: translateY(0);
}
.section.is-visible .display-h     { transition-delay: 150ms; }
.section.is-visible .services-list { transition-delay: 250ms; }
.section.is-visible .hire-request  { transition-delay: 250ms; }
.section.is-visible .work-strip    { transition-delay: 250ms; }
.section.is-visible .about-stats   { transition-delay: 250ms; }
.section.is-visible .contact-form  { transition-delay: 250ms; }

@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: 0.01ms !important;
        transition-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
    }
    .display .reveal { transform: none; opacity: 1; }
    .hero-stage img { animation: none; transform: none; }
    .section .display-h,
    .section .services-list,
    .section .hire-request,
    .section .work-strip,
    .section .about-stats,
    .section .contact-info,
    .section .contact-form { opacity: 1; transform: none; }
}
