/**
 * Lawdika — component styles
 * Hero slider · about · practice index · team · customers · contact · landing
 */

/* ==========================================================================
   Hero slider (full-bleed editorial)
   ========================================================================== */
.hero {
    position: relative;
    min-height: 100svh;
    display: flex;
    align-items: flex-end;
    isolation: isolate;
    overflow: hidden;
}
.hero-slides { position: absolute; inset: 0; z-index: -2; }
.hero-slide {
    position: absolute; inset: 0;
    background-size: cover;
    background-position: center;
    opacity: 0;
    transition: opacity 1100ms var(--ease-out);
    transform: scale(1.06);
}
.hero-slide.is-active { opacity: 1; transform: scale(1); transition: opacity 1100ms var(--ease-out), transform 7000ms linear; }
.hero::after {
    content: ""; position: absolute; inset: 0; z-index: -1;
    background:
        linear-gradient(180deg, color-mix(in oklch, var(--bg) 40%, transparent) 0%, transparent 28%),
        linear-gradient(0deg, var(--bg) 4%, color-mix(in oklch, var(--bg) 78%, transparent) 34%, color-mix(in oklch, var(--bg) 30%, transparent) 72%);
}

.hero-inner {
    width: 100%;
    padding-bottom: clamp(4rem, 12vh, 8rem);
    padding-top: calc(var(--header-h) + 2rem);
}
.hero-kicker { color: var(--brass-bright); }
.hero-title {
    font-size: clamp(2.8rem, 1.6rem + 6vw, 6.5rem);
    font-weight: 800;
    line-height: 0.98;
    letter-spacing: -0.02em;
    max-width: 16ch;
    margin: 0;
}
.hero-title em { color: var(--brass); font-weight: 800; }
.hero-sub {
    font-size: var(--text-lg);
    color: var(--text-muted);
    max-width: 46ch;
    margin-top: var(--space-4);
}
.hero-cta { display: flex; gap: var(--space-3); flex-wrap: wrap; margin-top: var(--space-5); }

/* Crossfading headline/subtitle synced to slide images */
.hero-copy-stack { display: grid; margin-top: var(--space-4); }
.hero-copy { grid-area: 1 / 1; opacity: 0; visibility: hidden; transition: opacity 700ms var(--ease-out); }
.hero-copy.is-active { opacity: 1; visibility: visible; }
.hero-copy .hero-title { margin: 0; }

/* Slider controls */
.hero-controls {
    position: absolute;
    right: var(--gutter);
    bottom: clamp(4rem, 12vh, 8rem);
    z-index: 2;
    display: flex;
    align-items: center;
    gap: var(--space-3);
}
.hero-dots { display: flex; gap: 0.6rem; }
.hero-dot {
    width: 28px; height: 3px;
    background: color-mix(in oklch, var(--text) 30%, transparent);
    border: 0; padding: 0;
    transition: background var(--t-base) var(--ease-out);
}
.hero-dot.is-active { background: var(--brass); }
.hero-arrow {
    width: 48px; height: 48px;
    border: 1px solid var(--border-strong);
    border-radius: 50%;
    background: color-mix(in oklch, var(--bg) 40%, transparent);
    color: var(--text);
    display: inline-flex; align-items: center; justify-content: center;
    transition: border-color var(--t-base) var(--ease-out), color var(--t-base) var(--ease-out), background var(--t-base) var(--ease-out);
}
.hero-arrow:hover { border-color: var(--brass); color: var(--brass); }

.scroll-hint {
    position: absolute; left: var(--gutter); bottom: 1.5rem; z-index: 2;
    color: var(--text-faint); font-size: var(--text-xs);
    letter-spacing: 0.18em; text-transform: uppercase;
    writing-mode: vertical-rl;
}

@media (max-width: 600px) {
    .hero-controls { left: var(--gutter); right: auto; bottom: 1.5rem; }
    .hero-arrow { display: none; }
    .scroll-hint { display: none; }
}

/* ==========================================================================
   About (asymmetric, editorial)
   ========================================================================== */
.about {
    display: grid;
    grid-template-columns: 1.05fr 0.95fr;
    gap: clamp(2rem, 6vw, 5.5rem);
    align-items: center;
}
.about-figure {
    position: relative;
    aspect-ratio: 4 / 5;
    overflow: hidden;
    border-radius: var(--radius-lg);
}
.about-figure img { width: 100%; height: 100%; object-fit: cover; filter: saturate(0.92) contrast(1.02); }
.about-figure::after {
    content: ""; position: absolute; inset: 0;
    background: linear-gradient(160deg, transparent 55%, color-mix(in oklch, var(--bg) 55%, transparent));
}
.about-est {
    position: absolute; left: 0; bottom: 0;
    background: var(--brass);
    color: var(--bg);
    font-family: var(--font-display);
    font-weight: 800;
    padding: 0.9rem 1.4rem;
    font-size: var(--text-lg);
    letter-spacing: 0.02em;
}
.about-body .lead { margin-bottom: var(--space-4); }
.about-meta {
    display: flex; gap: var(--space-6);
    margin-top: var(--space-5);
    padding-top: var(--space-5);
    border-top: 1px solid var(--border);
}
.about-meta .num { font-family: var(--font-display); font-weight: 800; font-size: var(--text-2xl); color: var(--brass); line-height: 1; }
.about-meta .lbl { font-size: var(--text-xs); color: var(--text-muted); letter-spacing: 0.08em; text-transform: uppercase; margin-top: 0.4rem; }

@media (max-width: 820px) {
    .about { grid-template-columns: 1fr; }
    .about-figure { aspect-ratio: 16 / 11; max-height: 60vh; }
}

/* ==========================================================================
   Bookshelf — practice areas as a shelf of law volumes
   ========================================================================== */
.bookshelf-wrap {
    margin-top: var(--space-5);
    overflow-x: auto;
    overflow-y: hidden;
    padding-top: 2.75rem;          /* headroom for books rising on hover */
    scrollbar-width: thin;
    scrollbar-color: var(--brass-deep) transparent;
}
.bookshelf {
    display: flex;
    align-items: flex-end;
    gap: 6px;
    min-width: max-content;        /* horizontal scroll on small screens */
    padding: 0 2px;
    position: relative;
    border-bottom: 4px solid var(--brass-deep);   /* shelf edge */
}
.bookshelf::after {                /* shelf plank depth + shadow */
    content: ""; position: absolute; left: 0; right: 0; bottom: -4px; height: 20px;
    background: linear-gradient(180deg, color-mix(in oklch, var(--brass-deep) 45%, var(--bg)), var(--bg));
    box-shadow: 0 16px 28px oklch(0 0 0 / 0.5);
    z-index: -1;
}
.book { list-style: none; }
.book a {
    position: relative;
    display: flex; flex-direction: column; align-items: center; justify-content: space-between;
    width: clamp(56px, 6.2vw, 82px);
    height: clamp(268px, 34vh, 346px);
    padding: 0.95rem 0.35rem 1rem;
    background: linear-gradient(95deg,
        color-mix(in oklch, var(--bg) 28%, var(--surface)) 0%,
        var(--surface) 16%,
        var(--surface-2) 84%,
        color-mix(in oklch, var(--bg) 20%, var(--surface-2)) 100%);
    border: 1px solid var(--border);
    border-bottom: none;
    border-radius: 3px 3px 0 0;
    color: var(--text);
    box-shadow: inset -3px 0 7px oklch(0 0 0 / 0.35), inset 2px 0 3px oklch(1 0 0 / 0.03);
    transition: transform var(--t-slow) var(--ease-out-expo), box-shadow var(--t-base) var(--ease-out), color var(--t-base);
    will-change: transform;
}
.book a:hover, .book a:focus-visible {
    transform: translateY(-30px);
    box-shadow: -9px 24px 36px oklch(0 0 0 / 0.55), inset -3px 0 7px oklch(0 0 0 / 0.3);
    z-index: 3;
    outline: none;
}
.book a:focus-visible { box-shadow: -9px 24px 36px oklch(0 0 0 / 0.55), 0 0 0 2px var(--brass); }
.book-title {
    writing-mode: vertical-rl;
    text-orientation: mixed;
    font-family: var(--font-display);
    font-weight: 700;
    font-size: clamp(0.95rem, 0.82rem + 0.4vw, 1.16rem);
    letter-spacing: 0.01em;
    line-height: 1.12;
    flex: 1;
    display: flex; align-items: center; justify-content: center;
    margin: 0.5rem 0;
    text-align: center;
}
.book a:hover .book-title, .book a:focus-visible .book-title { color: var(--brass-bright); }
.book-vol { font-family: var(--font-display); font-weight: 700; color: var(--brass); font-size: var(--text-sm); }
.book-band { width: 62%; height: 1px; background: var(--brass-deep); opacity: 0.85; flex-shrink: 0; }
/* binding-tone variations so the shelf reads as different volumes */
.book--2 a { background: linear-gradient(95deg, color-mix(in oklch,var(--bg) 42%,var(--surface)), var(--surface) 58%, var(--surface-2)); }
.book--3 a { background: linear-gradient(95deg, var(--surface), color-mix(in oklch,var(--brass-deep) 16%, var(--surface)) 58%, var(--surface-2)); }
.book--4 a { background: linear-gradient(95deg, color-mix(in oklch,var(--bg) 24%,var(--surface-2)), var(--surface-2) 68%, var(--surface)); }
.book--5 a { background: linear-gradient(95deg, var(--surface-2), color-mix(in oklch,var(--brass-deep) 11%, var(--surface)) 55%, var(--surface)); }
/* gentle height variation for an organic shelf */
.book:nth-child(3n) a { height: clamp(256px, 32vh, 328px); }
.book:nth-child(4n) a { height: clamp(278px, 35vh, 352px); }
.book:nth-child(7n) a { height: clamp(264px, 33vh, 340px); }
.bookshelf-cue { margin-top: var(--space-6); }

@media (prefers-reduced-motion: reduce) {
    .book a { transition: box-shadow var(--t-base), color var(--t-base); }
    .book a:hover, .book a:focus-visible { transform: translateY(-12px); }
}

/* Mobile: lay the books flat as a stacked list; tap/hover slides them right */
@media (max-width: 640px) {
    .bookshelf-wrap { overflow: visible; padding-top: 0; }
    .bookshelf {
        flex-direction: column; align-items: stretch; gap: 8px;
        min-width: 0; padding: 0; border-bottom: none;
    }
    .bookshelf::after { display: none; }
    .book a,
    .book:nth-child(3n) a, .book:nth-child(4n) a, .book:nth-child(7n) a {
        flex-direction: row; align-items: center; justify-content: flex-start; gap: 0.85rem;
        width: 100%; height: auto; min-height: 58px;
        padding: 0.8rem 1rem;
        border: 1px solid var(--border); border-radius: var(--radius);
        transition: transform var(--t-base) var(--ease-out-expo), box-shadow var(--t-base), color var(--t-base), border-color var(--t-base);
    }
    .book a:hover, .book a:focus-visible, .book a:active {
        transform: translateX(12px);
        border-color: var(--border-strong);
        box-shadow: -10px 10px 26px oklch(0 0 0 / 0.4);
    }
    .book-title {
        writing-mode: horizontal-tb; text-orientation: mixed;
        flex: 1; justify-content: flex-start; text-align: left; margin: 0;
        font-size: 1.05rem; line-height: 1.2;
    }
    .book-vol {
        order: -1; flex: 0 0 auto;
        display: grid; place-items: center; width: 2.1rem; height: 2.1rem;
        border-radius: 50%; border: 1px solid color-mix(in oklch, var(--brass) 42%, transparent);
        background: color-mix(in oklch, var(--brass) 10%, transparent);
        font-size: var(--text-sm); line-height: 1;
    }
    .book a:hover .book-vol, .book a:focus-visible .book-vol, .book a:active .book-vol {
        background: var(--brass); color: var(--bg); border-color: var(--brass);
    }
    .book-band { display: none; }
}

/* Practice-area cards (What We Do page) */
.practice-cards {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: var(--space-4);
    margin-top: var(--space-6);
}
.practice-card {
    position: relative;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: var(--space-5);
    transition: border-color var(--t-base) var(--ease-out), transform var(--t-base) var(--ease-out), background var(--t-base);
}
.practice-card:hover { border-color: var(--brass-deep); transform: translateY(-4px); background: var(--surface-2); }
.practice-card__vol {
    position: absolute; top: var(--space-4); right: var(--space-5);
    font-family: var(--font-display); font-weight: 700; color: var(--text-faint);
    font-variant-numeric: tabular-nums;
}
.practice-card__icon {
    display: inline-flex; align-items: center; justify-content: center;
    width: 54px; height: 54px;
    border: 1px solid var(--brass-deep); border-radius: 50%;
    color: var(--brass); font-size: 1.3rem;
    margin-bottom: var(--space-4);
    transition: background var(--t-base) var(--ease-out), color var(--t-base) var(--ease-out), border-color var(--t-base);
}
.practice-card:hover .practice-card__icon { background: var(--brass); color: var(--bg); border-color: var(--brass); }
.practice-card h3 { font-size: var(--text-lg); margin: 0 0 var(--space-2); }
.practice-card p { color: var(--text-muted); font-size: var(--text-sm); margin: 0; }

/* ==========================================================================
   Team (honest typographic cards — no stock faces)
   ========================================================================== */
.team-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: var(--space-4);
}
.team-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: var(--space-5);
    transition: border-color var(--t-base) var(--ease-out), transform var(--t-base) var(--ease-out);
}
.team-card:hover { border-color: var(--brass-deep); transform: translateY(-4px); }
.team-monogram {
    width: 64px; height: 64px;
    border: 1px solid var(--brass-deep);
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-family: var(--font-display); font-weight: 800; font-size: 1.5rem;
    color: var(--brass);
    margin-bottom: var(--space-4);
}
.team-name { font-size: var(--text-lg); margin: 0 0 0.2rem; }
.team-role { color: var(--brass); font-size: var(--text-sm); font-weight: 600; margin: 0 0 var(--space-3); }
.team-expertise { color: var(--text-muted); font-size: var(--text-sm); margin: 0 0 var(--space-3); }
.team-contact { display: flex; gap: var(--space-3); font-size: var(--text-sm); }
.team-contact a { color: var(--text-faint); }
.team-contact a:hover { color: var(--brass); }

/* ==========================================================================
   Team rows (Who We Are) — bio left, portrait placeholder right
   ========================================================================== */
.team-rows { display: flex; flex-direction: column; gap: clamp(2.5rem, 6vw, 4.5rem); margin-top: var(--space-6); }
.team-row {
    display: grid;
    grid-template-columns: 1fr clamp(220px, 26vw, 300px);
    gap: clamp(1.5rem, 5vw, 4rem);
    align-items: center;
}
.team-row__text .team-name { font-size: var(--text-xl); margin: 0 0 0.2rem; }
.team-row__text .team-role { color: var(--brass); font-weight: 600; margin: 0 0 var(--space-3); }
.team-bio { color: var(--text-muted); max-width: 60ch; margin: 0 0 var(--space-3); }
.team-mail { font-size: var(--text-sm); color: var(--text-faint); display: inline-flex; gap: 0.4rem; align-items: center; }
.team-mail:hover { color: var(--brass); }

.team-portrait {
    aspect-ratio: 3 / 4;
    border-radius: var(--radius-lg);
    overflow: hidden;
    border: 1px solid var(--border);
    background:
        radial-gradient(120% 80% at 50% 0%, color-mix(in oklch, var(--brass-deep) 12%, transparent), transparent 60%),
        linear-gradient(160deg, var(--surface), var(--surface-2));
    display: flex; align-items: center; justify-content: center;
}
.team-portrait img { width: 100%; height: 100%; object-fit: cover; }
.team-portrait__ph { display: flex; flex-direction: column; align-items: center; gap: var(--space-3); color: var(--brass-deep); }
.team-portrait__ph i { font-size: clamp(3rem, 7vw, 4.5rem); }
.team-portrait__ph .mono { font-family: var(--font-display); font-weight: 800; font-size: var(--text-xl); color: var(--brass); letter-spacing: 0.04em; }

@media (max-width: 760px) {
    .team-row { grid-template-columns: 1fr; }
    .team-row__media { order: -1; max-width: 240px; }
}

/* ==========================================================================
   Customers (logo grid + featured note)
   ========================================================================== */
.customers-lead { max-width: 64ch; }
.customers-wall-title { margin-top: var(--space-7); margin-bottom: var(--space-4); font-size: var(--text-xl); }
.logo-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
    gap: var(--space-3);
}
.logo-cell {
    background: #fff;
    aspect-ratio: 3 / 2;
    display: flex; align-items: center; justify-content: center;
    padding: var(--space-4);
    border-radius: var(--radius-lg);
    border: 1px solid color-mix(in oklch, var(--brass) 55%, transparent);
    box-shadow: var(--shadow-sm);
    overflow: hidden;
    transition: border-color var(--t-base) var(--ease-out);
}
.logo-cell:hover {
    border-color: var(--brass);
}
.logo-cell img {
    max-height: 60px; max-width: 100%;
    width: auto; object-fit: contain;
    opacity: 0.82;
    transition: transform var(--t-base) var(--ease-out), opacity var(--t-base) var(--ease-out);
}
.logo-cell:hover img {
    transform: scale(1.08);
    opacity: 1;
}

/* ==========================================================================
   Contact
   ========================================================================== */
.contact-grid {
    display: grid;
    grid-template-columns: 0.9fr 1.1fr;
    gap: clamp(2rem, 5vw, 4.5rem);
    align-items: start;
}
.contact-list { margin-top: var(--space-5); }
.contact-item { display: flex; gap: var(--space-3); padding: var(--space-3) 0; border-bottom: 1px solid var(--border); }
.contact-item i { color: var(--brass); width: 1.4rem; margin-top: 0.3rem; }

/* Full-width horizontal contact info row (below the contact grid) */
.contact-list--row {
    margin-top: var(--space-7); padding-top: var(--space-5); border-top: 1px solid var(--border);
    display: grid; grid-template-columns: 1.7fr 1fr 1fr 1.2fr; column-gap: var(--space-6); row-gap: var(--space-4);
    align-items: start;
}
.contact-list--row .contact-item { padding: 0; border-bottom: none; }
@media (max-width: 820px) {
    .contact-list--row { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 460px) {
    .contact-list--row { grid-template-columns: 1fr; }
}
.contact-item h4 { margin: 0 0 0.1rem; font-size: var(--text-sm); color: var(--text-muted); font-family: var(--font-body); font-weight: 600; letter-spacing: 0.04em; text-transform: uppercase; }
.contact-item p, .contact-item a { margin: 0; color: var(--text); font-size: var(--text-base); }

.team-emails { display: flex; flex-direction: column; gap: var(--space-2); margin-top: var(--space-4); }
.team-email-card {
    display: flex; align-items: center; gap: var(--space-3);
    background: linear-gradient(160deg, color-mix(in oklch, var(--surface) 92%, var(--brass) 8%), var(--surface) 60%);
    border: 1px solid var(--border); border-radius: var(--radius);
    padding: 0.7rem var(--space-3); position: relative; overflow: hidden;
    transition: border-color var(--t-base), transform var(--t-base), box-shadow var(--t-base);
}
.team-email-card::before {
    content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 3px; background: var(--brass);
    opacity: 0; transform: scaleY(0.4); transform-origin: center;
    transition: opacity var(--t-base), transform var(--t-base);
}
.team-email-card:hover { border-color: var(--border-strong); box-shadow: 0 10px 24px -14px rgba(0,0,0,0.55); }
.team-email-card:hover::before { opacity: 1; transform: scaleY(1); }
.team-email-card__avatar {
    flex: 0 0 auto; display: grid; place-items: center;
    width: 40px; height: 40px; border-radius: 50%;
    font-family: var(--font-display); font-weight: 600; font-size: 0.85rem; letter-spacing: 0.02em;
    color: var(--brass); background: color-mix(in oklch, var(--brass) 12%, transparent);
    border: 1px solid color-mix(in oklch, var(--brass) 38%, transparent);
    transition: background var(--t-base), color var(--t-base), border-color var(--t-base);
}
.team-email-card:hover .team-email-card__avatar { background: var(--brass); color: var(--bg); border-color: var(--brass); }
.team-email-card__body { display: grid; grid-template-columns: 1fr auto; align-items: baseline; column-gap: var(--space-3); row-gap: 0.05rem; flex: 1; min-width: 0; }
.team-email-card .nm { font-family: var(--font-display); font-weight: 600; line-height: 1.2; color: var(--text); }
.team-email-card .role { grid-column: 1; font-size: var(--text-xs); letter-spacing: 0.12em; text-transform: uppercase; color: var(--brass-deep); }
.team-email-card .eml { grid-column: 2; grid-row: 1 / span 2; align-self: center; display: flex; align-items: center; gap: 0.4rem; font-size: var(--text-sm); color: var(--text-muted); white-space: nowrap; transition: color var(--t-base); }
.team-email-card .eml i { font-size: 0.8em; color: var(--brass-deep); }
.team-email-card:hover .eml { color: var(--text); }
@media (max-width: 520px) {
    .team-email-card__body { grid-template-columns: 1fr; }
    .team-email-card .eml { grid-column: 1; grid-row: auto; margin-top: 0.25rem; }
}

/* Form */
.contact-form .form-row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-3); }
.form-group { margin-bottom: var(--space-3); }
.form-group label { display: block; font-size: var(--text-sm); color: var(--text-muted); margin-bottom: 0.4rem; }
.contact-form input, .contact-form textarea {
    width: 100%;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    color: var(--text);
    font-family: inherit; font-size: var(--text-base);
    padding: 0.85rem 1rem;
    transition: border-color var(--t-base) var(--ease-out), box-shadow var(--t-base) var(--ease-out);
}
.contact-form input:focus, .contact-form textarea:focus {
    outline: none;
    border-color: var(--brass);
    box-shadow: 0 0 0 3px color-mix(in oklch, var(--brass) 22%, transparent);
}
.contact-form textarea { min-height: 150px; resize: vertical; }
.contact-form .btn { margin-top: var(--space-2); }

.contact-direct-title { margin-top: var(--space-6); }
.map-embed { width: 100%; height: clamp(320px, 45vh, 480px); border: 0; filter: grayscale(0.3) invert(0.92) hue-rotate(180deg) brightness(0.9) contrast(0.95); }

@media (max-width: 820px) {
    .contact-grid { grid-template-columns: 1fr; }
    .contact-form .form-row { grid-template-columns: 1fr; }
}

/* ==========================================================================
   Final CTA band
   ========================================================================== */
.cta-band {
    background:
        radial-gradient(120% 140% at 100% 0%, color-mix(in oklch, var(--brass) 14%, transparent), transparent 55%),
        var(--surface);
    border-top: 1px solid var(--border);
    border-bottom: 1px solid var(--border);
    text-align: center;
}
.cta-band h2 { font-size: var(--text-2xl); max-width: 22ch; margin-inline: auto; }
.cta-band p { color: var(--text-muted); max-width: 48ch; margin-inline: auto; }
.cta-buttons { display: flex; gap: var(--space-3); justify-content: center; flex-wrap: wrap; margin-top: var(--space-5); }

/* ==========================================================================
   News — newspaper / broadsheet layout
   ========================================================================== */
.news-paper .container { max-width: 1120px; }

/* Masthead rule */
.news-masthead {
    display: flex; flex-wrap: wrap; align-items: baseline; justify-content: space-between; gap: var(--space-2) var(--space-4);
    padding-bottom: var(--space-4);
    border-bottom: 3px double var(--border-strong);
}
.news-masthead__name {
    font-family: var(--font-display); font-weight: 800; font-size: clamp(1.5rem, 1.1rem + 1.6vw, 2.3rem);
    letter-spacing: 0.01em; color: var(--text);
}
.news-masthead__tag { font-size: var(--text-sm); color: var(--text-faint); letter-spacing: 0.04em; font-style: italic; }

/* Shared dateline kicker */
.news-kicker {
    display: flex; align-items: center; gap: 0.7rem; flex-wrap: wrap;
    margin: 0 0 0.6rem; font-family: var(--font-body);
    font-size: var(--text-xs); letter-spacing: 0.14em; text-transform: uppercase;
}
.news-kicker span { color: var(--brass); font-weight: 600; }
.news-kicker time { color: var(--text-faint); letter-spacing: 0.08em; }
.news-kicker time::before { content: ""; display: inline-block; width: 4px; height: 4px; margin-right: 0.7rem; border-radius: 50%; background: var(--border-strong); vertical-align: middle; }

.news-readon {
    align-self: start; display: inline-flex; align-items: center; gap: 0.45rem; margin-top: 0.6rem;
    font-family: var(--font-body); font-size: var(--text-sm); font-weight: 600; letter-spacing: 0.02em; color: var(--brass);
}
.news-readon i { transition: transform var(--t-base) var(--ease-out); }
.news-readon:hover { color: var(--brass-bright); }
.news-readon:hover i { transform: translateX(4px); }

/* Lead story */
.news-lead {
    display: grid; grid-template-columns: 1.15fr 1fr; gap: clamp(1.5rem, 4vw, 3.5rem);
    align-items: center;
    padding: var(--space-6) 0;
    border-bottom: 1px solid var(--border);
}
.news-lead--text { grid-template-columns: 1fr; }
.news-lead--text .news-lead__title { font-size: clamp(1.9rem, 1.3rem + 2.6vw, 3.2rem); max-width: 18ch; }
.news-lead--text .news-lead__dek { font-size: var(--text-lg); max-width: 62ch; }
.news-lead__media { display: block; overflow: hidden; aspect-ratio: 4 / 3; background: var(--surface); }
.news-lead__media img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--t-slow) var(--ease-out); }
.news-lead:hover .news-lead__media img { transform: scale(1.04); }
.news-lead__body { display: flex; flex-direction: column; }
.news-lead__title { font-size: clamp(1.7rem, 1.2rem + 2.2vw, 2.9rem); line-height: 1.06; margin: 0 0 var(--space-3); font-weight: 800; }
.news-lead__title a { color: var(--text); }
.news-lead__title a:hover { color: var(--brass); }
.news-lead__dek { color: var(--text-muted); font-size: var(--text-lg); line-height: 1.55; margin: 0; max-width: 56ch; }

/* Secondary stories — newspaper columns separated by rules */
.news-columns {
    display: grid; grid-template-columns: repeat(3, 1fr);
    margin-top: var(--space-2);
}
.news-item {
    display: flex; flex-direction: column;
    padding: var(--space-5) var(--space-5) var(--space-5) 0;
    border-top: 1px solid var(--border);
    border-right: 1px solid var(--border);
}
.news-item:not(:nth-child(3n)) { padding-right: var(--space-5); margin-right: var(--space-5); }
.news-item:nth-child(3n) { border-right: none; padding-right: 0; }
.news-item__title { font-size: clamp(1.15rem, 1rem + 0.6vw, 1.4rem); line-height: 1.18; margin: 0 0 0.5rem; font-weight: 700; }
.news-item__title a { color: var(--text); }
.news-item__title a:hover { color: var(--brass); }
.news-item__dek { color: var(--text-muted); font-size: var(--text-sm); line-height: 1.55; margin: 0; }

@media (max-width: 900px) {
    .news-lead { grid-template-columns: 1fr; gap: var(--space-4); }
    .news-lead__media { aspect-ratio: 16 / 9; }
    .news-columns { grid-template-columns: repeat(2, 1fr); }
    .news-item:not(:nth-child(3n)) { padding-right: var(--space-5); margin-right: var(--space-5); }
    .news-item:nth-child(2n) { border-right: none; padding-right: 0; margin-right: 0; }
    .news-item:nth-child(2n-1) { border-right: 1px solid var(--border); }
}
@media (max-width: 560px) {
    .news-columns { grid-template-columns: 1fr; }
    .news-item, .news-item:not(:nth-child(3n)) { border-right: none; padding: var(--space-4) 0; margin-right: 0; }
}

/* ==========================================================================
   Blog / news cards
   ========================================================================== */
.posts-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: var(--space-5); }
.post-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    overflow: hidden;
    display: flex; flex-direction: column;
    transition: border-color var(--t-base) var(--ease-out), transform var(--t-base) var(--ease-out);
}
.post-card:hover { border-color: var(--brass-deep); transform: translateY(-4px); }
.post-card .thumb { aspect-ratio: 16 / 10; overflow: hidden; }
.post-card .thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--t-slow) var(--ease-out); }
.post-card:hover .thumb img { transform: scale(1.05); }
.post-card .body { padding: var(--space-4); display: flex; flex-direction: column; gap: var(--space-2); flex: 1; }
.post-card .date { font-size: var(--text-xs); color: var(--brass); letter-spacing: 0.08em; text-transform: uppercase; }
.post-card .post-title { font-size: var(--text-lg); margin: 0; }
.post-card .post-title a { color: var(--text); }
.post-card .post-title a:hover { color: var(--brass); }
.post-card .excerpt { color: var(--text-muted); font-size: var(--text-sm); }
.read-more { margin-top: auto; font-size: var(--text-sm); font-weight: 600; color: var(--brass); display: inline-flex; gap: 0.4rem; align-items: center; }
.read-more i { transition: transform var(--t-base) var(--ease-out); }
.read-more:hover i { transform: translateX(4px); }

.pagination { display: flex; gap: 0.5rem; justify-content: center; margin-top: var(--space-6); }
.pagination .page-numbers {
    min-width: 44px; height: 44px; display: inline-flex; align-items: center; justify-content: center;
    border: 1px solid var(--border); border-radius: var(--radius); color: var(--text-muted);
}
.pagination .page-numbers.current { background: var(--brass); color: var(--bg); border-color: var(--brass); }
.pagination a.page-numbers:hover { border-color: var(--brass); color: var(--brass); }

/* Single post */
.post-body { max-width: var(--measure); }
.post-nav { display: flex; justify-content: space-between; gap: var(--space-4); margin-top: var(--space-7); padding-top: var(--space-5); border-top: 1px solid var(--border); }
.post-nav a { color: var(--text-muted); }
.post-nav a:hover { color: var(--brass); }

/* ==========================================================================
   Landing (dual choice) — restyled to system, see template-parts/landing.php
   ========================================================================== */
.landing { min-height: 100svh; min-height: 100vh; display: grid; grid-template-columns: 1fr 1fr; background: var(--bg); }
.landing-choice {
    position: relative;
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    text-align: center;
    padding: calc(var(--gutter) + 1rem) var(--gutter) calc(var(--gutter) + 3.5rem);
    min-height: 100svh;
    color: var(--text);
    isolation: isolate;
    overflow: hidden;
    transition: flex-grow var(--t-slow) var(--ease-out);
}
.landing-choice__inner {
    position: relative; z-index: 1;
    display: flex; flex-direction: column; align-items: center;
    max-width: 480px;
}
.landing-logo-img {
    width: min(320px, 78%); height: auto;
    margin-bottom: var(--space-4);
}
.landing-desc {
    color: var(--text-muted);
    font-size: var(--text-base);
    line-height: 1.6;
    max-width: 44ch;
    margin: var(--space-2) 0 0;
}
.landing-areas {
    display: flex; flex-wrap: wrap; justify-content: center;
    gap: 0.5rem 0.9rem;
    margin-top: var(--space-4);
    font-size: var(--text-xs);
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--text-faint);
}
.landing-areas li { position: relative; }
.landing-areas li + li::before {
    content: "·"; color: var(--brass-deep);
    position: absolute; left: -0.55rem;
}
.landing-foot {
    position: absolute; left: 0; right: 0; bottom: 1.25rem; z-index: 4;
    display: flex; flex-wrap: wrap; align-items: center; justify-content: center;
    gap: 0.4rem 0.9rem;
    color: var(--text-faint);
    font-size: var(--text-xs);
    letter-spacing: 0.02em;
    padding-inline: var(--gutter);
}
.landing-foot a { color: var(--text-faint); }
.landing-foot a:hover { color: var(--brass); }
.landing-foot i { color: var(--brass-deep); margin-right: 0.2rem; }
.landing-foot-sep { color: var(--border-strong); }
.landing-choice__bg {
    position: absolute; inset: 0; z-index: -2;
    background-size: cover; background-position: center;
    transform: scale(1.04);
    transition: transform 1200ms var(--ease-out);
}
.landing-choice::after {
    content: ""; position: absolute; inset: 0; z-index: -1;
    background: color-mix(in oklch, var(--bg) 72%, transparent);
    transition: background var(--t-base) var(--ease-out);
}
.landing-choice:hover::after { background: color-mix(in oklch, var(--bg) 55%, transparent); }
.landing-choice:hover .landing-choice__bg { transform: scale(1.1); }
.landing-logo { font-family: var(--font-display); font-weight: 800; font-size: clamp(2rem, 1.4rem + 2.4vw, 3.2rem); letter-spacing: -0.01em; margin: 0; }
.landing-logo b { color: var(--brass); }
.landing-kind { font-size: var(--text-xs); letter-spacing: 0.24em; text-transform: uppercase; color: var(--brass-bright); margin: var(--space-3) 0 var(--space-2); }
.landing-name { color: var(--text-muted); max-width: 30ch; }
.landing-enter {
    margin-top: var(--space-5);
    display: inline-flex; align-items: center; gap: 0.6rem;
    font-size: var(--text-sm); font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase;
    color: var(--text);
    border-bottom: 1px solid var(--brass-deep);
    padding-bottom: 0.35rem;
    transition: gap var(--t-base) var(--ease-out), color var(--t-base) var(--ease-out), border-color var(--t-base) var(--ease-out);
}
.landing-choice:hover .landing-enter { gap: 1.1rem; color: var(--brass); border-color: var(--brass); }
.landing-divider {
    position: absolute; left: 50%; top: 50%; z-index: 3;
    transform: translate(-50%, -50%);
    width: 64px; height: 64px; border-radius: 50%;
    background: var(--brass); color: var(--bg);
    display: flex; align-items: center; justify-content: center;
    font-family: var(--font-display); font-weight: 800; font-size: var(--text-base);
    box-shadow: var(--shadow-lg);
}
@media (max-width: 760px) {
    .landing { grid-template-columns: 1fr; }
    /* Let each panel grow to fit its content instead of clipping at a fixed
       height — the legal panel (logo + copy + tags + CTA) is too tall for 50svh. */
    .landing-choice {
        min-height: auto;
        padding: var(--space-7) var(--gutter);
    }
    /* Divider rides the seam between the stacked panels, in normal flow,
       instead of being pinned to the centre of the whole container. */
    .landing-divider {
        position: static;
        transform: none;
        margin: -28px auto;
        width: 56px; height: 56px;
        font-size: var(--text-sm);
    }
    /* Footer flows beneath the panels rather than overlapping them. */
    .landing-foot {
        position: static;
        margin: 0;
        padding: var(--space-5) var(--gutter);
    }
}

/* ==========================================================================
   Announcement bar (optional, Customizer-controlled) + maintenance page
   ========================================================================== */

/* Reserve no space by default; shift the fixed header + content when present. */
body.has-announce { --announce-h: 2.75rem; }
body.has-announce .site-header { top: var(--announce-h); }
body.has-announce .hero-inner { padding-top: calc(var(--header-h) + var(--announce-h) + 2rem); }
body.has-announce .page-header { padding-top: calc(var(--header-h) + var(--announce-h) + clamp(3rem, 8vh, 6rem)); }
body.has-announce .page-header--plain { padding-top: calc(var(--header-h) + var(--announce-h) + clamp(2.5rem, 6vh, 4rem)); }

.announce-bar {
    position: fixed;
    inset: 0 0 auto 0;
    z-index: 101;
    height: var(--announce-h, 2.75rem);
    display: flex;
    align-items: center;
    overflow: hidden;
    background: color-mix(in oklch, var(--brass-deep) 26%, var(--bg));
    border-bottom: 1px solid color-mix(in oklch, var(--brass) 22%, var(--border));
    font-size: var(--text-xs);
}
.announce-bar__inner {
    position: relative;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-3);
}
.announce-bar__text {
    margin: 0;
    display: inline-flex;
    align-items: center;
    gap: 0.6rem;
    color: var(--text);
    letter-spacing: 0.01em;
    max-width: 100%;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.announce-bar__link {
    color: var(--brass-bright);
    font-weight: 600;
    white-space: nowrap;
}
.announce-bar__link i { font-size: 0.72em; display: inline-block; transition: transform var(--t-base) var(--ease-out); }
.announce-bar__link:hover i { transform: translateX(4px); }
.announce-bar__close {
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    background: none;
    border: 0;
    padding: 0 0.35rem;
    font-size: 1.4rem;
    line-height: 1;
    color: var(--text-muted);
    cursor: pointer;
    transition: color var(--t-fast) var(--ease-out);
}
.announce-bar__close:hover { color: var(--text); }
@media (max-width: 600px) {
    body.has-announce { --announce-h: 3.1rem; }
    .announce-bar__text { font-size: 0.78rem; }
}

/* ---- Maintenance holding page ---- */
.maintenance-page { background: var(--bg); }
.maint {
    position: relative;
    isolation: isolate;
    min-height: 100svh;
    display: grid;
    place-items: center;
    padding: var(--gutter);
    overflow: hidden;
}
.maint::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: -2;
    background: url('../images/slider/2.jpg') center / cover no-repeat;
    opacity: 0.16;
}
.maint::after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: -1;
    background:
        radial-gradient(120% 90% at 50% 12%, color-mix(in oklch, var(--brass) 10%, transparent), transparent 60%),
        linear-gradient(180deg, color-mix(in oklch, var(--bg) 72%, transparent), color-mix(in oklch, var(--bg) 92%, transparent));
}
.maint__inner {
    position: relative;
    z-index: 1;
    max-width: 640px;
    text-align: center;
}
.maint__logo { display: block; height: 66px; width: auto; margin: 0 auto var(--space-5); }
.maint__word {
    display: block;
    margin-bottom: var(--space-5);
    font-family: var(--font-display);
    font-weight: 800;
    font-size: 2rem;
    color: var(--text);
}
.maint__word b { color: var(--brass); }
.maint__kicker {
    margin: 0 0 var(--space-3);
    text-transform: uppercase;
    letter-spacing: 0.2em;
    font-size: var(--text-xs);
    color: var(--brass-bright);
}
.maint__title {
    margin: 0 0 var(--space-4);
    font-family: var(--font-display);
    font-weight: 800;
    font-size: var(--text-2xl);
    line-height: var(--leading-tight);
    color: var(--text);
}
.maint__message {
    margin: 0 auto var(--space-6);
    max-width: 52ch;
    color: var(--text-muted);
    font-size: var(--text-lg);
    line-height: var(--leading-body);
}
.maint__contact {
    list-style: none;
    margin: 0;
    padding: var(--space-5) 0 0;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: var(--space-3) var(--space-5);
    border-top: 1px solid var(--border);
}
.maint__contact li {
    display: inline-flex;
    align-items: center;
    gap: 0.6rem;
    color: var(--text-muted);
    font-size: var(--text-sm);
}
.maint__contact i { color: var(--brass-deep); }
.maint__contact a { color: var(--text-muted); }
.maint__contact a:hover { color: var(--brass); }
