/* ============================================================
   Aspired Websites LLC — main.css
   Premium layered dark system. Mobile-first. Pure CSS.
   ============================================================ */

/* ── 1. Tokens ──────────────────────────────────────────────── */
:root {
    /* Surfaces */
    --color-bg-deep: #070614;
    --color-bg-raised: #0F172A;

    /* Brand — orange */
    --color-orange: #E8650A;
    --color-orange-dark: #C45508;
    --color-orange-light: #FF7B1E;
    --color-gold: var(--color-orange);

    /* Brand — teal (secondary accent) */
    --color-teal: #0D9488;
    --color-teal-dark: #0F766E;
    --color-teal-light: #14B8A6;

    /* Glows (for card shadow halos and accent tints) */
    --color-orange-glow: rgba(232, 101, 10, 0.15);
    --color-teal-glow: rgba(13, 148, 136, 0.15);

    /* Text */
    --color-text: #FFFFFF;
    --color-text-muted: #94A3B8;

    /* Borders */
    --color-border: rgba(255, 255, 255, 0.08);
    --color-border-strong: rgba(255, 255, 255, 0.14);

    /* Status */
    --color-success: #4ADE80;
    --color-danger: #F87171;

    /* Typography — system stack now; @font-face for Inter/Playfair
       can be dropped in later under core/static/fonts/ without
       touching any selector. */
    --font-serif: 'Playfair Display', 'Georgia', 'Times New Roman', serif;
    --font-sans: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', 'Roboto', 'Helvetica Neue', Arial, sans-serif;
    --font-base: var(--font-sans);

    /* Spacing */
    --space-1: 0.5rem;
    --space-2: 1rem;
    --space-3: 1.5rem;
    --space-4: 2rem;
    --space-5: 3rem;
    --space-6: 4rem;
    --space-7: 6rem;
    --space-8: 8rem;

    /* Radii */
    --radius-sm: 4px;
    --radius: 8px;
    --radius-lg: 16px;

    /* Shadows */
    --shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.4);
    --shadow: 0 6px 18px rgba(0, 0, 0, 0.45);
    --shadow-lg: 0 16px 40px rgba(0, 0, 0, 0.55);

    /* Layout */
    --container: 1200px;
    --container-narrow: 900px;

    /* Motion */
    --transition: 200ms ease;
    --transition-slow: 350ms ease;
}

/* ── 2. Reset ───────────────────────────────────────────────── */
*, *::before, *::after {
    box-sizing: border-box;
}

html {
    -webkit-text-size-adjust: 100%;
    scroll-behavior: smooth;
    background-color: var(--color-bg-deep);
}

body, h1, h2, h3, h4, h5, h6, p, ul, ol, figure, blockquote, dl, dd {
    margin: 0;
}

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

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

a {
    color: var(--color-orange);
    text-decoration: none;
    transition: color var(--transition);
}

a:hover {
    color: var(--color-orange-light);
}

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

input, textarea, select {
    font: inherit;
}

:focus-visible {
    outline: 2px solid var(--color-orange);
    outline-offset: 2px;
}

/* ── 3. Base typography ─────────────────────────────────────── */
body {
    font-family: var(--font-sans);
    font-size: 16px;
    line-height: 1.6;
    color: var(--color-text);
    background-color: var(--color-bg-deep);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

h1, h2, h3, h4 {
    line-height: 1.2;
    color: var(--color-text);
    font-weight: 700;
    letter-spacing: -0.01em;
}

h1 { font-size: clamp(2rem, 5vw, 3.25rem); }
h2 { font-size: clamp(1.75rem, 4vw, 2.5rem); }
h3 { font-size: clamp(1.25rem, 2.5vw, 1.5rem); }
h4 { font-size: 1.125rem; }

p {
    margin-bottom: var(--space-2);
}

.lead {
    font-size: 1.125rem;
    color: var(--color-text-muted);
}

/* ── 4. Layout utilities ────────────────────────────────────── */
.container {
    width: 100%;
    max-width: var(--container);
    margin-inline: auto;
    padding-inline: var(--space-3);
}

.container--narrow {
    max-width: var(--container-narrow);
}

.section {
    padding-block: var(--space-6);
    background-color: var(--color-bg-deep);
    position: relative;
}

.section--alt {
    background-color: var(--color-bg-raised);
}

.text-center { text-align: center; }
.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-link {
    position: absolute;
    top: -100px;
    left: 0;
    background: var(--color-bg-raised);
    color: var(--color-text);
    padding: var(--space-1) var(--space-2);
    z-index: 1000;
}

.skip-link:focus {
    top: 0;
    color: var(--color-text);
}

/* ── 4b. Accent utilities (sparkle decoration, pure CSS) ───── */
.accent-line {
    width: 60px;
    height: 2px;
    background: linear-gradient(90deg, var(--color-orange), transparent);
    display: block;
    margin: 0 auto;
    border: 0;
}

.accent-line--teal {
    background: linear-gradient(90deg, var(--color-teal), transparent);
}

.accent-line--centered {
    background: linear-gradient(90deg, transparent, var(--color-orange), transparent);
}

.accent-dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--color-orange);
    opacity: 0.4;
    display: inline-block;
}

/* ── 4c. Section dividers — gradient lines between sections ─ */
.section-divider {
    height: 1px;
    background: linear-gradient(
        90deg,
        transparent,
        rgba(232, 101, 10, 0.3),
        transparent
    );
    margin: 0;
    border: 0;
}

.section-divider--teal {
    background: linear-gradient(
        90deg,
        transparent,
        rgba(13, 148, 136, 0.3),
        transparent
    );
}

/* ── 4d. Section heading pattern (teal label, white h2, muted p) ── */
.section-header {
    text-align: center;
    max-width: 720px;
    margin: 0 auto var(--space-5);
}

.eyebrow,
.section-header .eyebrow {
    display: inline-block;
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    color: var(--color-teal);
    font-weight: 700;
    margin-bottom: var(--space-2);
}

.section-header h2 {
    margin-bottom: var(--space-2);
}

.section-header p {
    color: var(--color-text-muted);
    font-size: 1.0625rem;
    margin-top: var(--space-2);
}

/* ── 5. Buttons ─────────────────────────────────────────────── */
.btn,
.btn-primary,
.btn-secondary {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-1);
    padding: 14px 32px;
    border-radius: 8px;
    font-weight: 600;
    font-size: 1rem;
    letter-spacing: 0.02em;
    text-align: center;
    text-decoration: none;
    cursor: pointer;
    border: 1px solid transparent;
    line-height: 1.2;
    transition: background-color var(--transition), color var(--transition), transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}

.btn--primary,
.btn-primary {
    background: var(--color-orange);
    color: #FFFFFF;
    border-color: var(--color-orange);
    box-shadow: 0 0 24px rgba(232, 101, 10, 0.3);
}

.btn--primary:hover,
.btn-primary:hover {
    background: var(--color-orange-light);
    border-color: var(--color-orange-light);
    color: #FFFFFF;
    box-shadow: 0 0 40px rgba(232, 101, 10, 0.5);
    transform: translateY(-2px);
}

.btn--outline,
.btn--outline-light,
.btn-secondary {
    background: transparent;
    color: var(--color-orange);
    border-color: rgba(232, 101, 10, 0.4);
}

.btn--outline:hover,
.btn--outline-light:hover,
.btn-secondary:hover {
    border-color: var(--color-orange);
    background: rgba(232, 101, 10, 0.08);
    color: var(--color-orange-light);
    box-shadow: 0 0 24px rgba(232, 101, 10, 0.15);
}

.btn--lg,
.btn-lg {
    padding: 18px 40px;
    font-size: 1.0625rem;
}

.btn--block,
.btn-block {
    width: 100%;
}

/* ── 6. Header / Navigation (frosted glass) ─────────────────── */
.site-header {
    position: sticky;
    top: 0;
    z-index: 100;
    background: rgba(7, 6, 20, 0.85);
    -webkit-backdrop-filter: blur(12px);
    backdrop-filter: blur(12px);
    border-bottom: 1px solid var(--color-border);
}

@supports not ((-webkit-backdrop-filter: blur(1px)) or (backdrop-filter: blur(1px))) {
    .site-header {
        background: var(--color-bg-deep);
    }
}

.nav {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-block: var(--space-2);
}

.logo {
    display: inline-flex;
    align-items: center;
    text-decoration: none;
}

.logo:hover {
    opacity: 0.85;
}

.logo-img {
    height: 40px;
    width: auto;
    display: block;
}

.site-footer .logo-img {
    height: 48px;
}

.nav-toggle {
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 5px;
    width: 40px;
    height: 40px;
    padding: 8px;
    border-radius: var(--radius-sm);
}

.nav-toggle:hover {
    background-color: var(--color-bg-raised);
}

.nav-toggle span {
    display: block;
    width: 100%;
    height: 2px;
    background-color: var(--color-text);
    border-radius: 1px;
    transition: transform var(--transition), opacity var(--transition);
}

.nav-toggle[aria-expanded="true"] span:nth-child(1) {
    transform: translateY(7px) rotate(45deg);
}

.nav-toggle[aria-expanded="true"] span:nth-child(2) {
    opacity: 0;
}

.nav-toggle[aria-expanded="true"] span:nth-child(3) {
    transform: translateY(-7px) rotate(-45deg);
}

.nav-menu {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: rgba(7, 6, 20, 0.95);
    -webkit-backdrop-filter: blur(12px);
    backdrop-filter: blur(12px);
    border-bottom: 1px solid var(--color-border);
    box-shadow: var(--shadow);
    padding: var(--space-2);
}

.nav-menu.is-open {
    display: block;
}

.nav-menu ul {
    display: flex;
    flex-direction: column;
    gap: 0;
}

.nav-link {
    display: block;
    padding: var(--space-2);
    color: var(--color-text);
    font-weight: 600;
    font-size: 0.9375rem;
    border-radius: var(--radius-sm);
    border-bottom: 2px solid transparent;
}

.nav-link:hover {
    color: var(--color-orange);
    background-color: rgba(255, 255, 255, 0.04);
}

.nav-link.is-active {
    color: var(--color-orange);
}

@media (min-width: 1024px) {
    .nav-link.is-active {
        border-radius: 0;
        border-bottom-color: var(--color-orange);
    }
}

.nav-link--cta {
    background: var(--color-orange);
    color: #FFFFFF;
    text-align: center;
    margin-top: var(--space-1);
    box-shadow: 0 0 24px rgba(232, 101, 10, 0.3);
    border-bottom: 1px solid transparent;
}

.nav-link--cta:hover {
    background: var(--color-orange-light);
    color: #FFFFFF;
    box-shadow: 0 0 40px rgba(232, 101, 10, 0.5);
}

/* ── Nav dropdown — Services submenu ─────────────────────────
   Mobile (default, stacked nav): submenu is shown inline, always
   expanded. The Services button still acts as a toggle in case the
   user wants to collapse it. On desktop (≥1024px) the submenu
   becomes an absolutely-positioned floating panel that opens on
   hover or keyboard focus. */
.nav-item--has-children {
    position: relative;
}
.nav-link--toggle {
    display: flex;
    align-items: center;
    gap: 6px;
    width: 100%;
    background: none;
    border: none;
    cursor: pointer;
    font: inherit;
    text-align: left;
    padding: var(--space-2);
    color: var(--color-text);
    font-weight: 600;
    font-size: 0.9375rem;
    border-radius: var(--radius-sm);
}
.nav-link--toggle:hover,
.nav-link--toggle.is-active {
    color: var(--color-orange);
}
.nav-caret {
    font-size: 0.7em;
    transition: transform 0.15s ease;
    opacity: 0.7;
}
.nav-link--toggle[aria-expanded="true"] .nav-caret {
    transform: rotate(180deg);
}
/* Specificity bump — `.nav-menu ul { display: flex }` further up
   the file would otherwise force this open. `.nav-menu .nav-submenu`
   is (0,2,0) which beats `.nav-menu ul` (0,1,1) — wait, the same.
   We override by SOURCE ORDER (this rule comes later) AND specificity
   parity. Belt-and-suspenders: also reset flex-direction so the items
   stack vertically when shown, not in a wrapping row. */
.nav-menu .nav-submenu {
    list-style: none;
    padding: 0 0 0 var(--space-2);
    margin: 0;
    display: none;
    flex-direction: column;
}
.nav-menu .nav-submenu.is-open,
.nav-link--toggle[aria-expanded="true"] + .nav-submenu {
    display: block;
}
.nav-sublink {
    display: block;
    padding: 8px var(--space-2);
    color: var(--color-text-muted, #94A3B8);
    font-weight: 500;
    font-size: 0.9rem;
    text-decoration: none;
    border-radius: var(--radius-sm);
}
.nav-sublink:hover {
    color: var(--color-orange);
    background-color: rgba(255, 255, 255, 0.04);
}
.nav-sublink.is-active {
    color: var(--color-orange);
    font-weight: 600;
}

@media (min-width: 1024px) {
    .nav-menu .nav-submenu {
        position: absolute;
        top: 100%;
        left: 0;
        min-width: 260px;
        background: var(--color-bg-deep, #0F172A);
        border: 1px solid rgba(148, 163, 184, 0.18);
        border-radius: 8px;
        padding: 8px;
        box-shadow: 0 12px 32px rgba(0, 0, 0, 0.45);
        z-index: 50;
        margin-top: 4px;
    }
    /* Open on hover OR explicit toggle (keyboard / click) */
    .nav-item--has-children:hover .nav-menu .nav-submenu,
    .nav-item--has-children:focus-within .nav-menu .nav-submenu,
    .nav-menu .nav-item--has-children:hover .nav-submenu,
    .nav-menu .nav-item--has-children:focus-within .nav-submenu {
        display: block;
    }
    .nav-sublink {
        padding: 10px 14px;
    }
    .nav-sublink:hover {
        background-color: rgba(232, 101, 10, 0.08);
    }
}

/* ── 7. Hero — cinematic, serif headline ────────────────────── */
.hero {
    background-color: var(--color-bg-deep);
    color: var(--color-text);
    padding-block: var(--space-7);
    position: relative;
    overflow: hidden;
}

.hero::before {
    content: '';
    position: absolute;
    inset: 0;
    background:
        radial-gradient(ellipse 80% 50% at 50% 0%, rgba(232, 101, 10, 0.10) 0%, transparent 70%),
        radial-gradient(circle at 85% 80%, rgba(13, 148, 136, 0.06), transparent 50%);
    pointer-events: none;
}

.hero__inner {
    position: relative;
    max-width: 820px;
    margin: 0 auto;
    text-align: center;
}

.hero__eyebrow {
    display: inline-block;
    background-color: rgba(232, 101, 10, 0.15);
    color: var(--color-orange-light);
    padding: 0.375rem 0.875rem;
    border-radius: 999px;
    font-size: 0.8125rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    margin-bottom: var(--space-3);
    border: 1px solid rgba(232, 101, 10, 0.25);
}

.hero h1 {
    font-family: var(--font-serif);
    font-size: clamp(2.5rem, 6vw, 5rem);
    font-weight: 700;
    line-height: 1.1;
    letter-spacing: -0.02em;
    color: var(--color-text);
    margin-bottom: var(--space-3);
}

.hero h1 .accent {
    color: var(--color-orange);
    font-style: italic;
}

.hero__divider {
    margin-block: var(--space-3) var(--space-4);
}

.hero__lead {
    font-size: clamp(1rem, 2vw, 1.25rem);
    color: var(--color-text-muted);
    margin: 0 auto var(--space-4);
    max-width: 600px;
    line-height: 1.6;
}

.hero__ctas {
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
    align-items: center;
}

.hero__meta {
    margin-top: var(--space-5);
    color: var(--color-text-muted);
    font-size: 0.875rem;
    opacity: 0.8;
}

/* ── 8. Premium layered card system ─────────────────────────── */
/*
   .card and .testimonial use the orange glow by default.
   .value-tile and .portfolio-item use the teal glow for
   per-section tonal variety. Featured value-tile overrides
   back to orange so its "Differentiator" badge reads coherent.
*/

.cards {
    display: grid;
    gap: var(--space-3);
}

.card {
    background: var(--color-bg-raised);
    border: 1px solid rgba(232, 101, 10, 0.2);
    border-radius: 16px;
    padding: var(--space-4);
    box-shadow:
        0 0 0 1px rgba(232, 101, 10, 0.05),
        0 4px 24px rgba(0, 0, 0, 0.4),
        0 0 40px rgba(232, 101, 10, 0.06);
    transition: transform var(--transition), box-shadow var(--transition);
}

.card:hover {
    transform: translateY(-4px);
    box-shadow:
        0 0 0 1px rgba(232, 101, 10, 0.15),
        0 8px 40px rgba(0, 0, 0, 0.5),
        0 0 60px rgba(232, 101, 10, 0.12);
}

.card--teal {
    border-color: rgba(13, 148, 136, 0.2);
    box-shadow:
        0 0 0 1px rgba(13, 148, 136, 0.05),
        0 4px 24px rgba(0, 0, 0, 0.4),
        0 0 40px rgba(13, 148, 136, 0.06);
}

.card--teal:hover {
    box-shadow:
        0 0 0 1px rgba(13, 148, 136, 0.15),
        0 8px 40px rgba(0, 0, 0, 0.5),
        0 0 60px rgba(13, 148, 136, 0.12);
}

.card__icon {
    width: 56px;
    height: 56px;
    border-radius: 12px;
    background-color: rgba(232, 101, 10, 0.12);
    color: var(--color-orange);
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: var(--space-3);
    border: 1px solid rgba(232, 101, 10, 0.2);
}

.card--teal .card__icon {
    background-color: rgba(13, 148, 136, 0.12);
    color: var(--color-teal-light);
    border-color: rgba(13, 148, 136, 0.2);
}

.card__icon svg {
    width: 28px;
    height: 28px;
    stroke: currentColor;
    fill: none;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.card h3 {
    margin-bottom: var(--space-2);
    color: var(--color-text);
}

.card p {
    color: var(--color-text-muted);
    margin-bottom: var(--space-2);
}

.card__link {
    font-weight: 700;
    font-size: 0.9375rem;
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    color: var(--color-orange);
}

.card__link::after {
    content: '→';
    transition: transform var(--transition);
}

.card__link:hover {
    color: var(--color-orange-light);
}

.card__link:hover::after {
    transform: translateX(3px);
}

/* ── 9. Value tiles — teal by default, featured = orange ───── */
.value-tiles {
    display: grid;
    gap: var(--space-3);
}

/* Force exactly 3 columns on desktop (the default responsive grid
   later in this file forces 2 cols at tablet and 4 cols at desktop,
   which on 6 tiles produces a lopsided 4 + 2). Used by the service
   pages so 6 tiles read as a clean 3 × 2 at every breakpoint above
   tablet. Selector specificity is .value-tiles.value-tiles--3col
   (0,2,0) so it beats the later `.value-tiles` (0,1,0) breakpoints
   regardless of source order. !important is a sledgehammer here —
   we don't need it. */
@media (min-width: 768px) {
    .value-tiles.value-tiles--3col {
        grid-template-columns: repeat(3, 1fr);
    }
}

/* Centered button row under a pricing / tile grid. Adds the
   breathing room between the cards above and the CTAs below that
   the un-styled version was missing. Used at the bottom of the
   pricing-teaser sections on every service page. */
.section-cta {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    gap: var(--space-2);
    margin-top: var(--space-4);
}

.value-tile {
    text-align: left;
    padding: var(--space-3);
    border-radius: 16px;
    background: var(--color-bg-raised);
    border: 1px solid rgba(13, 148, 136, 0.2);
    position: relative;
    box-shadow:
        0 0 0 1px rgba(13, 148, 136, 0.05),
        0 4px 24px rgba(0, 0, 0, 0.4),
        0 0 40px rgba(13, 148, 136, 0.06);
    transition: transform var(--transition), box-shadow var(--transition);
}

.value-tile:hover {
    transform: translateY(-4px);
    box-shadow:
        0 0 0 1px rgba(13, 148, 136, 0.15),
        0 8px 40px rgba(0, 0, 0, 0.5),
        0 0 60px rgba(13, 148, 136, 0.12);
}

.value-tile__icon {
    width: 48px;
    height: 48px;
    border-radius: 10px;
    background-color: rgba(13, 148, 136, 0.12);
    color: var(--color-teal-light);
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: var(--space-2);
    border: 1px solid rgba(13, 148, 136, 0.2);
}

.value-tile__icon svg {
    width: 24px;
    height: 24px;
    stroke: currentColor;
    fill: none;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.value-tile h3 {
    font-size: 1.125rem;
    margin-bottom: var(--space-1);
    color: var(--color-text);
}

.value-tile p {
    font-size: 0.9375rem;
    color: var(--color-text-muted);
    margin: 0;
}

/* Featured tile — orange-themed override (matches its badge) */
.value-tile--featured {
    border-color: rgba(232, 101, 10, 0.35);
    background-image: linear-gradient(180deg, rgba(232, 101, 10, 0.06) 0%, transparent 60%);
    box-shadow:
        0 0 0 1px rgba(232, 101, 10, 0.12),
        0 4px 24px rgba(0, 0, 0, 0.4),
        0 0 40px rgba(232, 101, 10, 0.10);
}

.value-tile--featured:hover {
    box-shadow:
        0 0 0 1px rgba(232, 101, 10, 0.25),
        0 8px 40px rgba(0, 0, 0, 0.5),
        0 0 60px rgba(232, 101, 10, 0.16);
}

.value-tile--featured .value-tile__icon {
    background-color: var(--color-orange);
    color: #FFFFFF;
    border-color: var(--color-orange);
}

.value-tile__badge {
    position: absolute;
    top: var(--space-2);
    right: var(--space-2);
    background-color: var(--color-orange);
    color: #FFFFFF;
    font-size: 0.6875rem;
    font-weight: 700;
    padding: 0.25rem 0.5rem;
    border-radius: 999px;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    box-shadow: 0 0 12px rgba(232, 101, 10, 0.4);
}

/* ── 10. Steps (How It Works) ──────────────────────────────── */
.steps {
    display: grid;
    gap: var(--space-4);
    counter-reset: step;
}

.step {
    text-align: center;
    position: relative;
}

.step__num {
    counter-increment: step;
    width: 64px;
    height: 64px;
    border-radius: 50%;
    background: var(--color-orange);
    color: #FFFFFF;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.5rem;
    font-weight: 700;
    margin-bottom: var(--space-2);
    box-shadow: 0 0 32px rgba(232, 101, 10, 0.35);
    border: 1px solid rgba(232, 101, 10, 0.4);
}

.step__num::before {
    content: counter(step);
}

.step h3 {
    margin-bottom: var(--space-1);
    color: var(--color-text);
}

.step p {
    color: var(--color-text-muted);
    max-width: 320px;
    margin-inline: auto;
}

/* ── 11. Testimonials — orange premium card ────────────────── */
.testimonials {
    display: grid;
    gap: var(--space-3);
}

.testimonial {
    background: var(--color-bg-raised);
    border: 1px solid rgba(232, 101, 10, 0.2);
    border-radius: 16px;
    padding: var(--space-4);
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
    box-shadow:
        0 0 0 1px rgba(232, 101, 10, 0.05),
        0 4px 24px rgba(0, 0, 0, 0.4),
        0 0 40px rgba(232, 101, 10, 0.06);
    transition: transform var(--transition), box-shadow var(--transition);
}

.testimonial:hover {
    transform: translateY(-4px);
    box-shadow:
        0 0 0 1px rgba(232, 101, 10, 0.15),
        0 8px 40px rgba(0, 0, 0, 0.5),
        0 0 60px rgba(232, 101, 10, 0.12);
}

.testimonial__stars {
    display: flex;
    gap: 2px;
    color: var(--color-orange);
}

.testimonial__stars svg {
    width: 18px;
    height: 18px;
    fill: currentColor;
}

.testimonial__quote {
    font-size: 1rem;
    color: var(--color-text);
    line-height: 1.65;
    margin: 0;
}

.testimonial__author {
    border-top: 1px solid var(--color-border);
    padding-top: var(--space-2);
    margin-top: auto;
}

.testimonial__name {
    font-weight: 700;
    color: var(--color-text);
}

.testimonial__title {
    font-size: 0.875rem;
    color: var(--color-text-muted);
}

/* ── 12. Portfolio strip — teal premium card ───────────────── */
.portfolio-strip {
    display: grid;
    gap: var(--space-3);
}

.portfolio-item {
    border-radius: 16px;
    overflow: hidden;
    background: var(--color-bg-raised);
    border: 1px solid rgba(13, 148, 136, 0.2);
    box-shadow:
        0 0 0 1px rgba(13, 148, 136, 0.05),
        0 4px 24px rgba(0, 0, 0, 0.4),
        0 0 40px rgba(13, 148, 136, 0.06);
    transition: transform var(--transition), box-shadow var(--transition);
}

.portfolio-item:hover {
    transform: translateY(-4px);
    box-shadow:
        0 0 0 1px rgba(13, 148, 136, 0.15),
        0 8px 40px rgba(0, 0, 0, 0.5),
        0 0 60px rgba(13, 148, 136, 0.12);
}

.portfolio-item__visual {
    aspect-ratio: 16 / 10;
    background: linear-gradient(135deg, var(--color-bg-deep) 0%, #1E293B 100%);
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-text);
    font-weight: 700;
    font-size: 1.125rem;
    padding: var(--space-3);
    text-align: center;
    border-bottom: 1px solid rgba(13, 148, 136, 0.15);
}

.portfolio-item__visual::after {
    content: '';
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at 70% 30%, rgba(232, 101, 10, 0.25), transparent 60%),
        radial-gradient(circle at 30% 70%, rgba(13, 148, 136, 0.18), transparent 60%);
}

.portfolio-item__visual span {
    position: relative;
    z-index: 1;
}

.portfolio-item__body {
    padding: var(--space-3);
}

.portfolio-item__type {
    font-size: 0.75rem;
    color: var(--color-teal-light);
    text-transform: uppercase;
    letter-spacing: 0.15em;
    font-weight: 700;
    margin-bottom: var(--space-1);
}

.portfolio-item__title {
    font-size: 1.0625rem;
    font-weight: 700;
    color: var(--color-text);
    margin-bottom: var(--space-1);
}

.portfolio-item__desc {
    font-size: 0.875rem;
    color: var(--color-text-muted);
    margin: 0;
}

/* ── 12b. Card inversion: deep cards on raised sections ───── */
.section--alt .card,
.section--alt .testimonial,
.section--alt .portfolio-item,
.section--alt .value-tile {
    background-color: var(--color-bg-deep);
}

.section--alt .value-tile--featured {
    background-color: var(--color-bg-deep);
    background-image: linear-gradient(180deg, rgba(232, 101, 10, 0.06) 0%, transparent 60%);
}

/* ── 13. CTA blocks ────────────────────────────────────────── */
.cta-block {
    background: var(--color-bg-raised);
    color: var(--color-text);
    padding-block: var(--space-7);
    text-align: center;
    position: relative;
    overflow: hidden;
    border-top: 1px solid var(--color-border);
    border-bottom: 1px solid var(--color-border);
}

.cta-block--deep {
    background: var(--color-bg-deep);
}

.cta-block::before {
    content: '';
    position: absolute;
    inset: 0;
    background:
        radial-gradient(ellipse 60% 40% at 50% 50%, rgba(232, 101, 10, 0.16), transparent 70%),
        radial-gradient(circle at 20% 50%, rgba(13, 148, 136, 0.08), transparent 50%);
    pointer-events: none;
}

.cta-block__inner {
    position: relative;
    max-width: 720px;
    margin: 0 auto;
}

.cta-block h2 {
    color: var(--color-text);
    font-family: var(--font-serif);
    font-weight: 700;
    line-height: 1.15;
    letter-spacing: -0.02em;
    font-size: clamp(1.875rem, 4.5vw, 3rem);
    margin-bottom: var(--space-2);
}

.cta-block p {
    color: var(--color-text-muted);
    font-size: 1.0625rem;
    margin-bottom: var(--space-4);
}

/* ── 14. Forms ─────────────────────────────────────────────── */
.form {
    display: grid;
    gap: var(--space-3);
}

.form-group {
    display: flex;
    flex-direction: column;
    gap: 0.375rem;
}

.form-group label {
    font-weight: 600;
    font-size: 0.9375rem;
    color: var(--color-text);
}

.form-group .required {
    color: var(--color-orange);
}

.form-control {
    padding: 0.75rem 0.875rem;
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    background-color: var(--color-bg-raised);
    color: var(--color-text);
    font-size: 1rem;
    width: 100%;
    transition: border-color var(--transition), box-shadow var(--transition);
}

.form-control::placeholder {
    color: var(--color-text-muted);
    opacity: 0.7;
}

.form-control:focus {
    outline: none;
    border-color: var(--color-orange);
    box-shadow: 0 0 0 3px rgba(232, 101, 10, 0.2);
}

.form-control:invalid:not(:placeholder-shown) {
    border-color: var(--color-danger);
}

textarea.form-control {
    min-height: 140px;
    resize: vertical;
}

.form-help {
    font-size: 0.8125rem;
    color: var(--color-text-muted);
}

/* ── 15. Footer ────────────────────────────────────────────── */
.site-footer {
    background-color: var(--color-bg-deep);
    color: var(--color-text-muted);
    padding-top: var(--space-6);
    border-top: 1px solid var(--color-border);
}

.site-footer a {
    color: var(--color-text-muted);
    text-decoration: none;
}

.site-footer a:hover {
    color: var(--color-orange);
}

.footer-grid {
    display: grid;
    gap: var(--space-4);
    padding-bottom: var(--space-5);
}

.footer-col h4 {
    color: var(--color-text);
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    margin-bottom: var(--space-2);
}

.footer-col ul {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.footer-col li {
    font-size: 0.9375rem;
}

.footer-brand p {
    font-size: 0.9375rem;
    color: var(--color-text-muted);
    margin-bottom: var(--space-2);
    margin-top: var(--space-2);
}

.footer-locations {
    font-size: 0.875rem;
    color: var(--color-text-muted);
    opacity: 0.7;
}

.footer-bottom {
    border-top: 1px solid var(--color-border);
    padding-block: var(--space-3);
    display: flex;
    flex-direction: column;
    gap: var(--space-1);
    align-items: center;
    text-align: center;
    font-size: 0.8125rem;
    color: var(--color-text-muted);
    opacity: 0.7;
}

/* ── 16. Misc ───────────────────────────────────────────────── */
.muted { color: var(--color-text-muted); }
.mt-2 { margin-top: var(--space-2); }
.mt-3 { margin-top: var(--space-3); }
.mt-4 { margin-top: var(--space-4); }
.mb-0 { margin-bottom: 0; }

.coming-soon {
    text-align: center;
    padding-block: var(--space-7);
}

.coming-soon .badge {
    display: inline-block;
    background-color: rgba(13, 148, 136, 0.15);
    color: var(--color-teal-light);
    padding: 0.25rem 0.75rem;
    border-radius: 999px;
    font-size: 0.75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    margin-bottom: var(--space-3);
    border: 1px solid rgba(13, 148, 136, 0.25);
}

/* ── 16b. Page utilities — cards with visuals, lists, tables ── */

/* Card grid variant: 2 columns instead of 3 */
.cards.cards--2col {
    grid-template-columns: 1fr;
}

/* Card modifier: thin teal ribbon on the left edge */
.card--accent-left {
    position: relative;
    overflow: hidden;
}

.card--accent-left::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 3px;
    background: var(--color-teal);
}

/* Card modifier: image/gradient visual at top + body below */
.card--with-visual {
    padding: 0;
    overflow: hidden;
    display: flex;
    flex-direction: column;
}

.card--with-visual .card__visual {
    aspect-ratio: 16 / 10;
    border-bottom: 1px solid rgba(232, 101, 10, 0.15);
    position: relative;
}

.card--with-visual.card--teal .card__visual {
    border-bottom-color: rgba(13, 148, 136, 0.15);
}

.card--with-visual .card__visual::after {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at 70% 30%, rgba(232, 101, 10, 0.18), transparent 60%);
    pointer-events: none;
}

.card--with-visual.card--teal .card__visual::after {
    background: radial-gradient(circle at 70% 30%, rgba(13, 148, 136, 0.18), transparent 60%);
}

.card--with-visual .card__body {
    padding: var(--space-3);
    display: flex;
    flex-direction: column;
    gap: var(--space-1);
    flex: 1;
}

.card--with-visual .card__body > .btn-secondary,
.card--with-visual .card__body > .btn-primary {
    margin-top: auto;
    align-self: flex-start;
}

/* Small pill label (used above titles in cards) */
.pill-tag {
    display: inline-block;
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    color: var(--color-orange);
    font-weight: 700;
    margin-bottom: var(--space-1);
}

.card--teal .pill-tag {
    color: var(--color-teal-light);
}

/* Pull-quote inside a card */
.card__quote {
    margin: var(--space-2) 0;
    padding-left: var(--space-2);
    border-left: 3px solid var(--color-orange);
    font-style: italic;
    color: var(--color-text);
    line-height: 1.6;
}

.card--teal .card__quote {
    border-left-color: var(--color-teal);
}

.card__quote cite {
    display: block;
    margin-top: var(--space-1);
    font-style: normal;
    font-size: 0.875rem;
    color: var(--color-text-muted);
    font-weight: 600;
}

/* Bullet list — two columns on tablet+, orange diamond markers */
.bullet-list {
    display: grid;
    gap: var(--space-3);
    margin: 0;
    padding: 0;
    list-style: none;
}

.bullet-list__item {
    display: flex;
    gap: var(--space-2);
    align-items: flex-start;
    line-height: 1.6;
}

.bullet-list__icon {
    color: var(--color-orange);
    font-size: 1rem;
    line-height: 1.5;
    flex-shrink: 0;
    margin-top: 0.125rem;
}

.bullet-list__text {
    color: var(--color-text);
}

/* Comparison table */
.compare-table-wrapper {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    border-radius: var(--radius-lg);
    border: 1px solid var(--color-border);
    background: var(--color-bg-deep);
    box-shadow: var(--shadow);
}

.compare-table {
    width: 100%;
    min-width: 600px;
    border-collapse: separate;
    border-spacing: 0;
}

.compare-table th,
.compare-table td {
    padding: var(--space-2) var(--space-3);
    text-align: left;
    border-bottom: 1px solid var(--color-border);
    vertical-align: top;
    font-size: 0.9375rem;
}

.compare-table tr:last-child th,
.compare-table tr:last-child td {
    border-bottom: 0;
}

.compare-table thead th {
    background: var(--color-bg-raised);
    color: var(--color-text);
    font-weight: 700;
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.15em;
}

.compare-table thead th:last-child {
    color: var(--color-orange);
}

.compare-table tbody th {
    color: var(--color-text);
    font-weight: 700;
    background: transparent;
}

.compare-table tbody td:nth-child(2) {
    color: var(--color-text-muted);
}

.compare-table tbody td:last-child,
.compare-table thead th:last-child {
    border-left: 2px solid var(--color-orange);
    background: rgba(232, 101, 10, 0.06);
}

.compare-table tbody td:last-child {
    color: var(--color-text);
    font-weight: 600;
}

.compare-icon--no {
    color: #EF4444;
    font-weight: 700;
    margin-right: 0.375rem;
}

.compare-icon--yes {
    color: #10B981;
    font-weight: 700;
    margin-right: 0.375rem;
}

/* Gradient utilities for card visuals / image placeholders */
.gradient-blue   { background: linear-gradient(135deg, #1E3A5F 0%, var(--color-bg-deep) 100%); }
.gradient-teal   { background: linear-gradient(135deg, #0F3D38 0%, var(--color-bg-deep) 100%); }
.gradient-rust   { background: linear-gradient(135deg, #3D1A00 0%, var(--color-bg-deep) 100%); }
.gradient-purple { background: linear-gradient(135deg, #1A1A3D 0%, var(--color-bg-deep) 100%); }
.gradient-forest { background: linear-gradient(135deg, #0F2D1A 0%, var(--color-bg-deep) 100%); }

/* Responsive overrides for page utilities */
@media (min-width: 720px) {
    .cards.cards--2col {
        grid-template-columns: repeat(2, 1fr);
    }
    .bullet-list {
        grid-template-columns: repeat(2, 1fr);
        column-gap: var(--space-4);
    }
}

/* ── 16c. Pricing / plan utilities ─────────────────────────── */

/* Pricing card layout */
.card--pricing {
    display: flex;
    flex-direction: column;
    text-align: left;
}

.card--pricing > .btn-primary,
.card--pricing > .btn-secondary {
    margin-top: auto;
    width: 100%;
}

.card--pricing .feature-list {
    flex: 1;
}

.card__title {
    font-size: 1.5rem;
    color: var(--color-text);
    margin: 0;
}

/* Featured pricing card — stronger orange glow */
.card--featured {
    border-color: rgba(232, 101, 10, 0.5);
    box-shadow:
        0 0 0 1px rgba(232, 101, 10, 0.2),
        0 8px 32px rgba(0, 0, 0, 0.5),
        0 0 80px rgba(232, 101, 10, 0.18);
}

.card--featured:hover {
    box-shadow:
        0 0 0 1px rgba(232, 101, 10, 0.35),
        0 12px 48px rgba(0, 0, 0, 0.55),
        0 0 100px rgba(232, 101, 10, 0.25);
}

/* "Most Popular" pill badge straddling the top of a card */
.card__badge {
    position: absolute;
    top: -12px;
    left: 50%;
    transform: translateX(-50%);
    background: var(--color-orange);
    color: #FFFFFF;
    font-size: 0.6875rem;
    font-weight: 700;
    padding: 0.375rem 0.875rem;
    border-radius: 999px;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    box-shadow: 0 0 16px rgba(232, 101, 10, 0.5);
    border: 1px solid rgba(255, 255, 255, 0.15);
    white-space: nowrap;
}

/* Timeline pill (e.g. "Launches in 3 weeks") */
.card__timeline-badge {
    display: inline-block;
    font-size: 0.6875rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--color-teal-light);
    font-weight: 700;
    padding: 0.3125rem 0.75rem;
    border-radius: 999px;
    background: rgba(13, 148, 136, 0.12);
    border: 1px solid rgba(13, 148, 136, 0.25);
    margin-bottom: var(--space-2);
    align-self: flex-start;
}

.card--featured .card__timeline-badge {
    color: var(--color-orange-light);
    background: rgba(232, 101, 10, 0.12);
    border-color: rgba(232, 101, 10, 0.3);
}

/* Price block — serif numeral, raised $ glyph, muted /mo suffix.
   Clamp ceiling sized to fit the worst-case "$1,199/month" string
   inside a 3-column grid card (~340px content width on a 1280px
   viewport). overflow-wrap is the safety net for any future price
   we add. */
.card__price {
    font-family: var(--font-serif);
    font-size: clamp(2rem, 4.5vw, 3rem);
    font-weight: 700;
    color: var(--color-orange);
    line-height: 1.05;
    margin-block: var(--space-2);
    letter-spacing: -0.02em;
    overflow-wrap: anywhere;
    word-break: normal;
    max-width: 100%;
}

.card__price-currency {
    font-size: 0.55em;
    vertical-align: super;
    margin-right: 0.05em;
    line-height: 1;
}

.card__price-unit {
    font-size: 0.32em;
    color: var(--color-text-muted);
    font-family: var(--font-sans);
    font-weight: 400;
    margin-left: 0.25rem;
    vertical-align: baseline;
    letter-spacing: 0;
}

.card__price-meta {
    font-size: 0.8125rem;
    color: var(--color-text-muted);
    margin: 0 0 var(--space-3);
}

/* Checklist used inside pricing cards */
.feature-list {
    margin: 0 0 var(--space-3);
    padding: 0;
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.feature-list li {
    display: flex;
    gap: 0.625rem;
    align-items: flex-start;
    font-size: 0.9375rem;
    line-height: 1.5;
    color: var(--color-text);
}

.feature-list li::before {
    content: '✓';
    color: var(--color-orange);
    font-weight: 700;
    flex-shrink: 0;
    line-height: 1.5;
}

.card--teal .feature-list li::before {
    color: var(--color-teal-light);
}

/* Pricing note (between/below card sections) */
.pricing-note {
    text-align: center;
    color: var(--color-text-muted);
    font-size: 0.875rem;
    margin-top: var(--space-4);
}

/* Callout — emphasized box for important inline notes */
.callout {
    margin-top: var(--space-4);
    padding: var(--space-3);
    border-radius: var(--radius-lg);
    border: 1px solid rgba(232, 101, 10, 0.35);
    background: rgba(232, 101, 10, 0.05);
    color: var(--color-text);
    text-align: center;
    font-size: 0.9375rem;
    line-height: 1.55;
}

.callout strong {
    color: var(--color-orange);
}

.callout--teal {
    border-color: rgba(13, 148, 136, 0.35);
    background: rgba(13, 148, 136, 0.05);
}

.callout--teal strong {
    color: var(--color-teal-light);
}

/* Hero guarantee badge (orange pill below subhead) */
.badge-guarantee {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    background-color: rgba(232, 101, 10, 0.12);
    color: var(--color-orange-light);
    padding: 0.625rem 1.125rem;
    border-radius: 999px;
    font-size: 0.875rem;
    font-weight: 700;
    border: 1px solid rgba(232, 101, 10, 0.3);
    margin-top: var(--space-2);
}

.badge-guarantee__icon {
    color: var(--color-orange);
    font-weight: 700;
}

/* Three-column feature row (Hosting section) */
.feature-row {
    display: grid;
    gap: var(--space-3);
    margin-top: var(--space-5);
}

.feature-row__item {
    text-align: center;
    padding: var(--space-3);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--space-1);
}

.feature-row__icon {
    width: 56px;
    height: 56px;
    border-radius: 14px;
    background: rgba(232, 101, 10, 0.12);
    color: var(--color-orange);
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: var(--space-1);
    border: 1px solid rgba(232, 101, 10, 0.2);
}

.feature-row__icon svg {
    width: 28px;
    height: 28px;
    stroke: currentColor;
    fill: none;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.feature-row__title {
    font-weight: 700;
    font-size: 1.0625rem;
    color: var(--color-text);
}

.feature-row__desc {
    color: var(--color-text-muted);
    font-size: 0.9375rem;
    margin: 0;
    max-width: 280px;
}

@media (min-width: 720px) {
    .feature-row {
        grid-template-columns: repeat(3, 1fr);
        gap: var(--space-4);
    }
}

/* ── 16d. Contact page utilities ────────────────────────────── */

.contact-grid {
    display: grid;
    gap: var(--space-3);
}

@media (min-width: 900px) {
    .contact-grid {
        grid-template-columns: 1.4fr 1fr;
        gap: var(--space-4);
        align-items: start;
    }
    /* --stack modifier overrides the side-by-side grid and keeps both
       cards on the same column. Used by /design/schedule/ so Step 1
       (pick a time) sits on its own row and Step 2 (project form)
       appears below it — instead of the form being a long scroll
       parallel to the calendar. */
    .contact-grid--stack {
        grid-template-columns: 1fr;
    }
}

/* Contact section: keep both cards on raised bg so deep inputs contrast */
.section--alt .contact-grid > .card {
    background-color: var(--color-bg-raised);
}

/* Form labels — teal, small, uppercase, letter-spaced (per spec) */
.contact-form .form-group label {
    color: var(--color-teal-light);
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    font-weight: 700;
    margin-bottom: 0.375rem;
}

/* Form inputs — deep bg so they stand out against the raised card */
.contact-form .form-control {
    background-color: var(--color-bg-deep);
}

.contact-form select.form-control {
    appearance: none;
    -webkit-appearance: none;
    background-image: linear-gradient(45deg, transparent 50%, var(--color-text-muted) 50%),
                      linear-gradient(135deg, var(--color-text-muted) 50%, transparent 50%);
    background-position: calc(100% - 18px) 50%, calc(100% - 12px) 50%;
    background-size: 6px 6px;
    background-repeat: no-repeat;
    padding-right: 2.5rem;
}

/* Form errors */
.form-error {
    padding: var(--space-2) var(--space-3);
    border-radius: var(--radius);
    background: rgba(248, 113, 113, 0.08);
    border: 1px solid rgba(248, 113, 113, 0.3);
    color: var(--color-danger);
    font-size: 0.9375rem;
    margin-bottom: var(--space-3);
}

.form-error ul {
    margin: 0;
    padding-left: var(--space-2);
    list-style: disc;
}

.form-field-error {
    color: var(--color-danger);
    font-size: 0.8125rem;
    margin-top: 0.375rem;
    line-height: 1.4;
}

.contact-form .form-control[aria-invalid="true"] {
    border-color: var(--color-danger);
}

/* Card-level eyebrow + title (used in the form card) */
.card > .eyebrow {
    margin-bottom: var(--space-1);
}

.card > .card__title {
    margin-bottom: var(--space-3);
}

/* Right-column contact info list */
.contact-list {
    margin: 0 0 var(--space-3);
    padding: 0;
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
}

.contact-list__item {
    display: flex;
    gap: var(--space-2);
    align-items: center;
}

.contact-list__icon {
    width: 44px;
    height: 44px;
    border-radius: 12px;
    background: rgba(13, 148, 136, 0.12);
    color: var(--color-teal-light);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    border: 1px solid rgba(13, 148, 136, 0.2);
}

.contact-list__icon svg {
    width: 20px;
    height: 20px;
    stroke: currentColor;
    fill: none;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.contact-list__detail {
    display: flex;
    flex-direction: column;
    gap: 0.125rem;
    min-width: 0;
}

.contact-list__label {
    font-size: 0.6875rem;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    color: var(--color-text-muted);
    font-weight: 700;
}

.contact-list__value,
a.contact-list__value {
    color: var(--color-text);
    font-weight: 600;
    font-size: 1rem;
    text-decoration: none;
    word-break: break-word;
}

a.contact-list__value:hover {
    color: var(--color-orange);
}

/* Hairline dividers inside the contact-info card */
.contact-divider {
    height: 1px;
    background: var(--color-border);
    margin: var(--space-3) 0;
    border: 0;
}

.contact-promise {
    text-align: center;
    color: var(--color-text);
    font-weight: 600;
    margin: 0;
}

.contact-cta-prompt {
    color: var(--color-text-muted);
    font-size: 0.9375rem;
    text-align: center;
    margin: 0 0 var(--space-2);
}

.contact-fine-print {
    font-size: 0.75rem;
    color: var(--color-text-muted);
    text-align: center;
    margin: 0;
    line-height: 1.55;
}

.contact-fine-print a {
    color: var(--color-text-muted);
    text-decoration: underline;
    text-decoration-color: rgba(255, 255, 255, 0.2);
}

.contact-fine-print a:hover {
    color: var(--color-orange);
}

/* Thank-you page */
.thanks-page {
    text-align: center;
    padding-block: var(--space-7);
}

.thanks-page__card {
    max-width: 540px;
    margin: 0 auto;
    padding: var(--space-5);
    background: var(--color-bg-raised);
    border: 1px solid rgba(232, 101, 10, 0.25);
    border-radius: 16px;
    box-shadow:
        0 0 0 1px rgba(232, 101, 10, 0.08),
        0 8px 32px rgba(0, 0, 0, 0.5),
        0 0 80px rgba(232, 101, 10, 0.12);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--space-2);
}

.thanks-page__card h1 {
    font-family: var(--font-serif);
    font-size: clamp(2rem, 5vw, 3rem);
    margin: 0;
}

.thanks-page__card .lead {
    margin: 0;
}

.success-checkmark {
    width: 72px;
    height: 72px;
    border-radius: 50%;
    background: var(--color-orange);
    color: #FFFFFF;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: var(--space-2);
    box-shadow: 0 0 32px rgba(232, 101, 10, 0.4);
    border: 1px solid rgba(232, 101, 10, 0.4);
}

.success-checkmark svg {
    width: 36px;
    height: 36px;
    stroke: currentColor;
    fill: none;
    stroke-width: 3;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.thanks-page__hint {
    color: var(--color-text-muted);
    margin: var(--space-1) 0 var(--space-3);
    font-size: 0.9375rem;
}

.thanks-page__hint a {
    color: var(--color-orange);
    font-weight: 600;
}

/* ── 16e. About page utilities ──────────────────────────────── */

.bio-grid {
    display: grid;
    gap: var(--space-4);
}

@media (min-width: 900px) {
    .bio-grid {
        grid-template-columns: 320px 1fr;
        gap: var(--space-5);
        align-items: start;
    }
}

.bio-photo {
    width: 200px;
    height: 200px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--color-orange) 0%, var(--color-teal) 100%);
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto var(--space-3);
    box-shadow:
        0 0 0 1px rgba(255, 255, 255, 0.08),
        0 0 48px rgba(232, 101, 10, 0.3),
        0 0 80px rgba(13, 148, 136, 0.2);
}

.bio-photo__initials {
    font-family: var(--font-serif);
    font-size: 4rem;
    font-weight: 700;
    color: #FFFFFF;
    line-height: 1;
    letter-spacing: -0.02em;
}

.bio-name {
    font-family: var(--font-serif);
    font-size: 1.75rem;
    color: var(--color-text);
    margin: 0;
    text-align: center;
    letter-spacing: -0.01em;
}

.bio-title {
    color: var(--color-text-muted);
    margin: 0 0 var(--space-3);
    text-align: center;
    font-size: 0.9375rem;
}

.credential-pills {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    justify-content: center;
    margin: 0;
    padding: 0;
    list-style: none;
}

.credential-pill {
    display: inline-flex;
    align-items: center;
    background: rgba(232, 101, 10, 0.12);
    color: var(--color-orange-light);
    font-size: 0.75rem;
    font-weight: 700;
    padding: 0.375rem 0.75rem;
    border-radius: 999px;
    border: 1px solid rgba(232, 101, 10, 0.25);
    letter-spacing: 0.02em;
}

.credential-pill--teal {
    background: rgba(13, 148, 136, 0.12);
    color: var(--color-teal-light);
    border-color: rgba(13, 148, 136, 0.25);
}

.bio-prose p {
    font-size: 1.0625rem;
    line-height: 1.75;
    color: var(--color-text);
    margin-bottom: var(--space-3);
}

.bio-prose p:last-child {
    margin-bottom: 0;
}

.bio-prose p:first-child::first-letter {
    font-family: var(--font-serif);
    font-size: 3.25rem;
    font-weight: 700;
    color: var(--color-orange);
    float: left;
    line-height: 0.9;
    padding-right: 0.5rem;
    padding-top: 0.3rem;
}

/* ── 16f. Audit tool utilities ──────────────────────────────── */

/* Audit form — single-input card, centered */
.audit-form-card {
    max-width: 600px;
    margin: 0 auto;
}

.audit-form-card .form-group label {
    color: var(--color-teal-light);
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    font-weight: 700;
    margin-bottom: 0.5rem;
}

.audit-form-card .form-control {
    background-color: var(--color-bg-deep);
    font-size: 1.0625rem;
    padding: 0.875rem 1rem;
}

.audit-form-card .audit-note {
    font-size: 0.8125rem;
    color: var(--color-text-muted);
    text-align: center;
    margin: var(--space-3) 0 0;
    line-height: 1.55;
}

/* Don't invert the audit card inside .section--alt — keep raised so the
   deep input bg contrasts cleanly. */
.section--alt .card.audit-form-card,
.section--alt .card.audit-results-summary {
    background-color: var(--color-bg-raised);
}

/* Audit results — URL display */
.audit-results-url {
    font-family: 'Courier New', monospace;
    font-size: 0.9375rem;
    color: var(--color-text-muted);
    background: rgba(255, 255, 255, 0.04);
    padding: 0.5rem 0.875rem;
    border-radius: var(--radius);
    border: 1px solid var(--color-border);
    display: inline-block;
    word-break: break-all;
    max-width: 100%;
}

/* Score grid — 2x2 mobile, 1x4 desktop */
.score-grid {
    display: grid;
    gap: var(--space-3);
    grid-template-columns: repeat(2, 1fr);
}

@media (min-width: 720px) {
    .score-grid {
        grid-template-columns: repeat(4, 1fr);
    }
}

.score-card {
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 16px;
    padding: var(--space-3);
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--space-2);
    box-shadow:
        0 0 0 1px rgba(232, 101, 10, 0.05),
        0 4px 24px rgba(0, 0, 0, 0.4);
}

.section--alt .score-card {
    background-color: var(--color-bg-deep);
}

.score-card__label {
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    color: var(--color-text-muted);
    font-weight: 700;
    margin: 0;
}

/* SVG score circle — color via class, progress via SVG attr (no inline style → CSP safe) */
.score-circle {
    width: 110px;
    height: 110px;
}

.score-circle__bg {
    fill: none;
    stroke: rgba(255, 255, 255, 0.08);
    stroke-width: 8;
}

.score-circle__fill {
    fill: none;
    stroke-width: 8;
    stroke-linecap: round;
    transition: stroke-dasharray 800ms ease;
}

.score-card--good .score-circle__fill { stroke: var(--color-success); }
.score-card--ok   .score-circle__fill { stroke: var(--color-orange); }
.score-card--bad  .score-circle__fill { stroke: var(--color-danger); }

.score-circle__text {
    font-family: var(--font-serif);
    font-size: 30px;
    font-weight: 700;
    fill: var(--color-text);
}

.score-card--good .score-circle__text { fill: var(--color-success); }
.score-card--ok   .score-circle__text { fill: var(--color-orange); }
.score-card--bad  .score-circle__text { fill: var(--color-danger); }

.score-card--good { border-color: rgba(74, 222, 128, 0.25); }
.score-card--ok   { border-color: rgba(232, 101, 10, 0.25); }
.score-card--bad  { border-color: rgba(248, 113, 113, 0.3); }

/* Impact badge on issue cards */
.audit-impact {
    display: inline-block;
    font-size: 0.6875rem;
    font-weight: 700;
    padding: 0.25rem 0.625rem;
    border-radius: 999px;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    margin-bottom: var(--space-2);
    align-self: flex-start;
}

.audit-impact--high {
    background: rgba(248, 113, 113, 0.12);
    color: var(--color-danger);
    border: 1px solid rgba(248, 113, 113, 0.3);
}

.audit-impact--medium {
    background: rgba(232, 101, 10, 0.12);
    color: var(--color-orange-light);
    border: 1px solid rgba(232, 101, 10, 0.25);
}

.audit-impact--good {
    background: rgba(74, 222, 128, 0.12);
    color: var(--color-success);
    border: 1px solid rgba(74, 222, 128, 0.25);
}

.audit-issue {
    display: flex;
    flex-direction: column;
}

.audit-issue h3 {
    font-size: 1.0625rem;
    margin: 0 0 var(--space-1);
}

.audit-issue p {
    color: var(--color-text-muted);
    font-size: 0.9375rem;
    line-height: 1.55;
    margin: 0;
}

/* ── Audit results — overall summary line ──────────────────── */
.audit-summary-line {
    text-align: center;
    font-family: var(--font-serif);
    font-size: 1.375rem;
    line-height: 1.4;
    font-weight: 700;
    margin: 0 0 var(--space-4);
}

.audit-summary-line--strong     { color: #10B981; }
.audit-summary-line--needs-work { color: #E8650A; }
.audit-summary-line--critical   { color: #EF4444; }

/* ── Audit results — 4-card grid (2x2 desktop, stacked mobile) ── */
.audit-results-grid {
    display: grid;
    gap: var(--space-3);
    grid-template-columns: 1fr;
}

@media (min-width: 720px) {
    .audit-results-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

.audit-result-card {
    display: flex;
    flex-direction: column;
    text-align: left;
    border-width: 1px;
    border-style: solid;
}

.audit-result-card--strong     { border-color: #10B981; }
.audit-result-card--needs-work { border-color: #E8650A; }
.audit-result-card--critical   { border-color: #EF4444; }

.audit-result-card__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-2);
    margin-bottom: var(--space-2);
}

.audit-result-card__category {
    font-family: var(--font-serif);
    font-size: 1.5rem;
    margin: 0;
    color: var(--color-text);
}

.audit-result-badge {
    flex-shrink: 0;
    font-size: 0.6875rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    padding: 0.3rem 0.7rem;
    border-radius: 999px;
}

.audit-result-badge--strong {
    background: rgba(16, 185, 129, 0.14);
    color: #10B981;
    border: 1px solid rgba(16, 185, 129, 0.4);
}

.audit-result-badge--needs-work {
    background: rgba(232, 101, 10, 0.14);
    color: var(--color-orange-light);
    border: 1px solid rgba(232, 101, 10, 0.4);
}

.audit-result-badge--critical {
    background: rgba(239, 68, 68, 0.14);
    color: #EF4444;
    border: 1px solid rgba(239, 68, 68, 0.4);
}

.audit-result-card__score {
    font-family: var(--font-serif);
    font-size: 3.25rem;
    font-weight: 700;
    line-height: 1;
    margin: 0 0 var(--space-2);
}

.audit-result-card--strong     .audit-result-card__score { color: #10B981; }
.audit-result-card--needs-work .audit-result-card__score { color: #E8650A; }
.audit-result-card--critical   .audit-result-card__score { color: #EF4444; }

.audit-result-card__score-max {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--color-text-muted);
}

.audit-result-card__impact {
    color: var(--color-text);
    font-size: 0.9375rem;
    line-height: 1.6;
    margin: 0;
}

/* "All clear" line — score >= 90 */
.audit-result-clear {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin: var(--space-3) 0 0;
    padding-top: var(--space-3);
    border-top: 1px solid var(--color-border);
    color: #10B981;
    font-size: 0.9375rem;
    font-weight: 600;
}

.audit-result-clear__icon {
    width: 20px;
    height: 20px;
    flex-shrink: 0;
    fill: none;
    stroke: #10B981;
    stroke-width: 2.5;
    stroke-linecap: round;
    stroke-linejoin: round;
}

/* Issue list — score < 90 */
.audit-result-issues {
    list-style: none;
    margin: var(--space-3) 0 0;
    padding: var(--space-3) 0 0;
    border-top: 1px solid var(--color-border);
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
}

.audit-result-issue {
    display: flex;
    gap: 0.625rem;
    align-items: flex-start;
}

.audit-result-issue__bullet {
    flex-shrink: 0;
    width: 8px;
    height: 8px;
    margin-top: 0.4rem;
    border-radius: 50%;
    background: var(--color-orange);
}

.audit-result-issue__text {
    display: block;
    font-size: 0.9375rem;
    line-height: 1.55;
}

.audit-result-issue__text strong {
    color: var(--color-text);
    font-weight: 700;
}

.audit-result-issue__desc {
    display: block;
    color: var(--color-text-muted);
    margin-top: 0.15rem;
}

/* Email capture form on results page */
.audit-email-form {
    display: flex;
    gap: var(--space-2);
    margin-top: var(--space-3);
    flex-wrap: wrap;
}

.audit-email-form .form-control {
    flex: 1;
    min-width: 200px;
    background-color: var(--color-bg-deep);
}

.audit-email-form .btn-primary {
    flex-shrink: 0;
}

.audit-email-confirmation {
    margin-top: var(--space-3);
    padding: var(--space-2) var(--space-3);
    border-radius: var(--radius);
    background: rgba(74, 222, 128, 0.08);
    border: 1px solid rgba(74, 222, 128, 0.3);
    color: var(--color-success);
    font-weight: 600;
    text-align: center;
}

/* Submit button loading state (used by audit form, reusable elsewhere) */
.btn__spinner {
    display: inline-block;
    width: 14px;
    height: 14px;
    border: 2px solid currentColor;
    border-right-color: transparent;
    border-radius: 50%;
    margin-right: 0.5rem;
    vertical-align: -2px;
    animation: btn-spin 0.8s linear infinite;
}

@keyframes btn-spin {
    to { transform: rotate(360deg); }
}

.btn-primary.is-loading,
.btn-secondary.is-loading {
    cursor: progress;
    opacity: 0.85;
}

.btn-primary[disabled],
.btn-secondary[disabled],
.btn-primary.is-loading,
.btn-secondary.is-loading {
    pointer-events: none;
}

.audit-note--running {
    color: var(--color-orange-light);
    font-weight: 600;
}

/* AI review section */
.ai-review {
    max-width: 720px;
    margin: 0 auto;
}

.ai-review .card {
    text-align: left;
}

.ai-review-body p {
    font-size: 1.0625rem;
    line-height: 1.75;
    color: var(--color-text);
    margin: 0 0 var(--space-3);
}

.ai-review-body p:last-child {
    margin-bottom: 0;
}

.ai-review-attribution {
    margin-top: var(--space-3);
    padding-top: var(--space-2);
    border-top: 1px solid var(--color-border);
    color: var(--color-text-muted);
    font-size: 0.8125rem;
    text-align: right;
    font-style: italic;
}

/* AI loading state — replaced by partial response */
.ai-loading {
    text-align: center;
    padding: var(--space-4) var(--space-3);
}

.ai-loading__spinner {
    display: inline-block;
    width: 28px;
    height: 28px;
    border: 2px solid rgba(13, 148, 136, 0.25);
    border-top-color: var(--color-teal-light);
    border-radius: 50%;
    margin-bottom: var(--space-2);
    animation: btn-spin 0.9s linear infinite;
}

.ai-loading__text {
    color: var(--color-text-muted);
    font-size: 0.9375rem;
    margin: 0;
}

/* Login page — centered card on deep bg */
.login-page {
    padding-block: var(--space-7);
}

.login-card {
    max-width: 440px;
    margin: 0 auto;
    text-align: center;
}

.login-card__logo {
    display: block;
    text-align: center;
    margin: 0 0 var(--space-3);
}

.login-card__logo img {
    height: 56px;
    width: auto;
    display: inline-block;
}

.login-card__title {
    font-family: var(--font-serif);
    font-size: 2rem;
    margin: 0 0 var(--space-1);
    color: var(--color-text);
    letter-spacing: -0.01em;
}

.login-card__subtitle {
    margin: 0 0 var(--space-3);
    font-size: 0.9375rem;
    color: var(--color-text-muted);
}

.login-form {
    text-align: left;
    margin-top: var(--space-2);
}

.login-form .form-group label {
    color: var(--color-teal-light);
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    font-weight: 700;
    margin-bottom: 0.375rem;
}

.login-form .form-control {
    background-color: var(--color-bg-deep);
}

.login-helper {
    margin: var(--space-3) 0 0;
    font-size: 0.8125rem;
    color: var(--color-text-muted);
    text-align: center;
    line-height: 1.55;
}

.login-forgot-row {
    text-align: right;
    margin: calc(var(--space-2) * -0.5) 0 var(--space-2);
}

.login-forgot-link {
    font-size: 0.8125rem;
    color: var(--color-text-muted);
}

.login-forgot-link:hover {
    color: var(--color-orange);
}

/* ── Contract signing page ─────────────────────────────────── */
.contract-wrap {
    max-width: 760px;
    margin: 0 auto;
}

.contract-scroll {
    max-height: 460px;
    overflow-y: auto;
    margin: var(--space-3) 0;
    padding: var(--space-3) var(--space-4);
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 12px;
}

.contract-scroll:focus-visible {
    outline: 2px solid var(--color-orange);
    outline-offset: 2px;
}

.contract-doc h1 {
    font-size: 1.5rem;
    margin: 0 0 0.25rem;
}

.contract-doc h2 {
    font-size: 1.125rem;
    margin: var(--space-3) 0 var(--space-1);
    color: var(--color-text);
}

.contract-doc p,
.contract-doc li {
    color: var(--color-text-muted);
    font-size: 0.9375rem;
    line-height: 1.65;
}

.contract-doc ul {
    margin: 0 0 var(--space-2);
    padding-left: 1.25rem;
}

.contract-doc__meta {
    font-size: 0.8125rem;
    margin-top: 0;
}

.contract-doc__sigblock {
    margin-top: var(--space-3);
    padding-top: var(--space-2);
    border-top: 1px solid var(--color-border);
}

.contract-sign-form {
    margin-top: var(--space-3);
}

.contract-agree {
    display: flex;
    gap: 0.625rem;
    align-items: flex-start;
    margin: var(--space-2) 0;
    font-size: 0.9375rem;
    color: var(--color-text);
    cursor: pointer;
}

.contract-agree input {
    margin-top: 0.2rem;
    flex-shrink: 0;
}

.contract-scroll-hint {
    font-size: 0.8125rem;
    color: var(--color-orange-light);
    margin: 0 0 var(--space-2);
}

.contract-check {
    width: 64px;
    height: 64px;
    margin: 0 auto var(--space-3);
    border-radius: 50%;
    background: rgba(232, 101, 10, 0.14);
    border: 1px solid rgba(232, 101, 10, 0.35);
    display: flex;
    align-items: center;
    justify-content: center;
}

.contract-check svg {
    width: 32px;
    height: 32px;
    fill: none;
    stroke: var(--color-orange);
    stroke-width: 3;
    stroke-linecap: round;
    stroke-linejoin: round;
}

/* Graceful fallback when AI review can't run (dev key missing, API error) */
.ai-review-fallback {
    text-align: center;
    color: var(--color-text-muted);
    font-size: 0.9375rem;
    padding: var(--space-3);
    background: rgba(255, 255, 255, 0.02);
    border-radius: var(--radius);
    border: 1px dashed var(--color-border);
}

/* ── 16g. Admin dashboard ──────────────────────────────────── */

.admin-body {
    background-color: var(--color-bg-deep);
    color: var(--color-text);
    min-height: 100vh;
}

/* Top nav bar — full width, sticky */
.admin-header {
    position: sticky;
    top: 0;
    z-index: 100;
    background: rgba(7, 6, 20, 0.92);
    -webkit-backdrop-filter: blur(12px);
    backdrop-filter: blur(12px);
    border-bottom: 1px solid var(--color-border);
}

.admin-header__inner {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    padding: 0.75rem var(--space-3);
    max-width: 1600px;
    margin: 0 auto;
}

.admin-logo {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    color: var(--color-text);
    text-decoration: none;
    font-weight: 700;
    flex-shrink: 0;
}

.admin-logo img { height: 28px; width: auto; display: block; }

.admin-nav {
    display: flex;
    gap: 0.25rem;
    margin-left: var(--space-2);
    flex: 1;
    flex-wrap: wrap;
}

.admin-nav__link {
    color: var(--color-text-muted);
    text-decoration: none;
    padding: 0.5rem 0.875rem;
    border-radius: var(--radius-sm);
    font-weight: 600;
    font-size: 0.9375rem;
    transition: color var(--transition), background-color var(--transition);
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
}

.admin-nav__link:hover {
    color: var(--color-text);
    background-color: rgba(255, 255, 255, 0.04);
}

.admin-nav__link.is-active {
    color: var(--color-orange);
    background-color: rgba(232, 101, 10, 0.08);
}

.admin-nav__badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 22px;
    height: 22px;
    padding: 0 0.5rem;
    background: var(--color-orange);
    color: #FFFFFF;
    font-size: 0.6875rem;
    font-weight: 700;
    border-radius: 999px;
    line-height: 1;
}

.admin-user {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    flex-shrink: 0;
}

.admin-user__email {
    color: var(--color-text-muted);
    font-size: 0.875rem;
    max-width: 200px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.admin-user__logout {
    display: inline-block;
    margin: 0;
}

/* Small button variant — used in admin nav + table action cells */
.btn-sm {
    padding: 0.375rem 0.75rem;
    font-size: 0.8125rem;
    border-radius: var(--radius-sm);
}

/* Main content area — see sidebar block below for the active rules.
   The old .admin-header / .admin-nav / .admin-user selectors above are
   orphaned (no template uses them) but kept so older snapshots still
   degrade cleanly. */

.admin-container {
    max-width: 1600px;
    margin: 0 auto;
    padding: 0 var(--space-3);
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
}

.admin-page-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    gap: var(--space-3);
    flex-wrap: wrap;
}

.admin-page-title {
    font-family: var(--font-serif);
    font-size: clamp(1.75rem, 3vw, 2.25rem);
    color: var(--color-text);
    margin: 0;
    letter-spacing: -0.01em;
}

.admin-page-actions {
    display: inline-flex;
    align-items: center;
    gap: var(--space-1);
    flex-wrap: wrap;
}

.admin-back-link {
    color: var(--color-text-muted);
    text-decoration: none;
    font-weight: 600;
    text-transform: uppercase;
    font-size: 0.75rem;
    letter-spacing: 0.15em;
}

.admin-back-link:hover { color: var(--color-orange); }

/* Stat card grid (Dashboard home) */
.admin-stat-grid {
    display: grid;
    gap: var(--space-3);
    grid-template-columns: repeat(2, 1fr);
}

@media (min-width: 720px) {
    .admin-stat-grid { grid-template-columns: repeat(4, 1fr); }
}

.admin-stat {
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 16px;
    padding: var(--space-3);
    text-decoration: none;
    color: var(--color-text);
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
    transition: transform var(--transition), border-color var(--transition);
    box-shadow:
        0 0 0 1px rgba(232, 101, 10, 0.05),
        0 4px 24px rgba(0, 0, 0, 0.4);
}

.admin-stat:hover {
    transform: translateY(-2px);
    border-color: rgba(232, 101, 10, 0.25);
    color: var(--color-text);
}

.admin-stat__label {
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    color: var(--color-text-muted);
    font-weight: 700;
}

.admin-stat__value {
    font-family: var(--font-serif);
    font-size: 2.5rem;
    line-height: 1;
    color: var(--color-text);
    font-weight: 700;
}

.admin-stat--urgent {
    border-color: rgba(232, 101, 10, 0.4);
    box-shadow:
        0 0 0 1px rgba(232, 101, 10, 0.15),
        0 4px 24px rgba(0, 0, 0, 0.4),
        0 0 40px rgba(232, 101, 10, 0.1);
}

.admin-stat--urgent .admin-stat__value { color: var(--color-orange); }

/* Sections + activity lists */
.admin-section {
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 16px;
    padding: var(--space-3);
}

.admin-section__header { margin-bottom: var(--space-2); }
.admin-section__header h2 { font-size: 1.25rem; margin: 0; }
.admin-subsection-title {
    margin-top: var(--space-3);
    margin-bottom: var(--space-1);
    color: var(--color-text-muted);
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    font-weight: 700;
}

.admin-two-col {
    display: grid;
    gap: var(--space-3);
}

@media (min-width: 1024px) {
    .admin-two-col { grid-template-columns: 1.4fr 1fr; }
}

.admin-activity-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
}

.admin-activity-item {
    padding: var(--space-2) 0;
    border-bottom: 1px solid var(--color-border);
}

.admin-activity-item:last-child { border-bottom: 0; }

.admin-activity-item__title {
    color: var(--color-text);
    font-weight: 600;
    text-decoration: none;
    display: block;
    margin-bottom: 0.25rem;
}

a.admin-activity-item__title:hover { color: var(--color-orange); }

.admin-activity-item__meta {
    color: var(--color-text-muted);
    font-size: 0.8125rem;
}

/* Pipeline strip */
.admin-pipeline {
    display: grid;
    gap: var(--space-1);
    grid-template-columns: repeat(2, 1fr);
}

@media (min-width: 720px) {
    .admin-pipeline { grid-template-columns: repeat(4, 1fr); }
}

@media (min-width: 1024px) {
    .admin-pipeline { grid-template-columns: repeat(8, 1fr); }
}

.admin-pipeline__item {
    display: flex;
    flex-direction: column;
    text-decoration: none;
    color: var(--color-text);
    background: var(--color-bg-deep);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    padding: 0.625rem 0.75rem;
    transition: border-color var(--transition);
}

.admin-pipeline__item:hover {
    border-color: rgba(232, 101, 10, 0.35);
    color: var(--color-text);
}

.admin-pipeline__label {
    font-size: 0.6875rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--color-text-muted);
    font-weight: 700;
}

.admin-pipeline__count {
    font-family: var(--font-serif);
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--color-text);
}

/* Status / temperature / score badges (reused across table + detail) */
.status-badge {
    display: inline-block;
    font-size: 0.6875rem;
    font-weight: 700;
    padding: 0.25rem 0.5rem;
    border-radius: 999px;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    border: 1px solid transparent;
    white-space: nowrap;
}

.status-badge--new           { background: rgba(13, 148, 136, 0.12); color: var(--color-teal-light);  border-color: rgba(13, 148, 136, 0.3); }
.status-badge--contacted     { background: rgba(255, 255, 255, 0.06); color: var(--color-text-muted); border-color: var(--color-border); }
.status-badge--replied       { background: rgba(232, 101, 10, 0.12); color: var(--color-orange-light); border-color: rgba(232, 101, 10, 0.3); }
.status-badge--call_booked   { background: rgba(232, 101, 10, 0.18); color: var(--color-orange-light); border-color: rgba(232, 101, 10, 0.45); }
.status-badge--proposal_sent { background: rgba(232, 101, 10, 0.22); color: #FFFFFF; border-color: rgba(232, 101, 10, 0.55); }
.status-badge--won           { background: rgba(74, 222, 128, 0.15); color: var(--color-success); border-color: rgba(74, 222, 128, 0.35); }
.status-badge--lost          { background: rgba(148, 163, 184, 0.1); color: var(--color-text-muted); border-color: var(--color-border); }
.status-badge--unsubscribed  { background: rgba(248, 113, 113, 0.12); color: var(--color-danger); border-color: rgba(248, 113, 113, 0.3); }
.status-badge--archived      { background: rgba(148, 163, 184, 0.08); color: var(--color-text-muted); border-color: var(--color-border); }

.temp-badge {
    display: inline-block;
    font-size: 0.6875rem;
    font-weight: 700;
    padding: 0.25rem 0.5rem;
    border-radius: 999px;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    border: 1px solid transparent;
    white-space: nowrap;
}

.temp-badge--hot  { background: rgba(248, 113, 113, 0.12); color: var(--color-danger); border-color: rgba(248, 113, 113, 0.3); }
.temp-badge--warm { background: rgba(232, 101, 10, 0.12); color: var(--color-orange-light); border-color: rgba(232, 101, 10, 0.3); }
.temp-badge--cold { background: rgba(13, 148, 136, 0.12); color: var(--color-teal-light); border-color: rgba(13, 148, 136, 0.3); }

.score-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 32px;
    height: 24px;
    padding: 0 0.5rem;
    font-family: var(--font-serif);
    font-weight: 700;
    font-size: 0.875rem;
    border-radius: 999px;
    border: 1px solid transparent;
}

.score-pill--hot  { background: rgba(248, 113, 113, 0.15); color: var(--color-danger); border-color: rgba(248, 113, 113, 0.35); }
.score-pill--warm { background: rgba(232, 101, 10, 0.15); color: var(--color-orange-light); border-color: rgba(232, 101, 10, 0.35); }
.score-pill--cold { background: rgba(13, 148, 136, 0.15); color: var(--color-teal-light); border-color: rgba(13, 148, 136, 0.35); }

/* Lead filter bar */
.lead-filter-bar {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    align-items: center;
    padding: var(--space-2);
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 12px;
}

.lead-filter-bar .form-control {
    background-color: var(--color-bg-deep);
    padding: 0.5rem 0.75rem;
    font-size: 0.875rem;
    width: auto;
    min-width: 130px;
}

.lead-filter-bar__search { flex: 1; min-width: 240px; }

.lead-filter-bar__clear {
    color: var(--color-text-muted);
    font-size: 0.8125rem;
    margin-left: 0.5rem;
}

/* Lead table */
.lead-table-wrapper {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 12px;
}

.lead-table {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
    min-width: 1100px;
}

.lead-table th,
.lead-table td {
    padding: 0.75rem var(--space-2);
    text-align: left;
    vertical-align: middle;
    border-bottom: 1px solid var(--color-border);
    font-size: 0.875rem;
}

.lead-table tr:last-child td { border-bottom: 0; }

.lead-table thead th {
    background: var(--color-bg-deep);
    color: var(--color-text-muted);
    font-weight: 700;
    font-size: 0.6875rem;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    position: sticky;
    top: 0;
}

.lead-row { transition: background-color var(--transition); }
.lead-row:hover { background: rgba(255, 255, 255, 0.02); }

/* Color-coded left border by temperature */
.lead-row--hot  td:first-child { border-left: 3px solid var(--color-danger); }
.lead-row--warm td:first-child { border-left: 3px solid var(--color-orange); }
.lead-row--cold td:first-child { border-left: 3px solid var(--color-teal); }

.lead-table__col-score, .lead-table__col-actions { white-space: nowrap; }

.lead-table__firm {
    color: var(--color-text);
    font-weight: 700;
    text-decoration: none;
}

.lead-table__firm:hover { color: var(--color-orange); }

.lead-table__sub {
    color: var(--color-text-muted);
    font-size: 0.75rem;
    margin-top: 0.125rem;
}

/* Pagination strip */
.admin-pagination {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: var(--space-2);
    flex-wrap: wrap;
    gap: var(--space-2);
}

.admin-pagination__info {
    color: var(--color-text-muted);
    font-size: 0.875rem;
}

.admin-pagination__links {
    display: inline-flex;
    gap: 0.5rem;
}

/* Empty / fallback state */
.admin-empty {
    background: var(--color-bg-raised);
    border: 1px dashed var(--color-border);
    border-radius: 12px;
    padding: var(--space-5);
    text-align: center;
    color: var(--color-text-muted);
}

.admin-empty p { margin: 0.5rem 0; }

/* Lead detail layout */
.lead-detail-grid {
    display: grid;
    gap: var(--space-3);
}

@media (min-width: 1024px) {
    .lead-detail-grid { grid-template-columns: 340px 1fr; align-items: start; }
}

.lead-detail-info,
.lead-detail-activity {
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
}

.admin-card {
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 12px;
    padding: var(--space-3);
}

.admin-card__title {
    margin: 0 0 var(--space-2);
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    color: var(--color-text-muted);
    font-weight: 700;
}

.kv {
    display: grid;
    grid-template-columns: minmax(80px, max-content) 1fr;
    column-gap: var(--space-2);
    row-gap: 0.5rem;
    margin: 0;
}

.kv dt {
    color: var(--color-text-muted);
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    font-weight: 700;
}

.kv dd { color: var(--color-text); margin: 0; word-break: break-word; }

.kv dd a { color: var(--color-orange); }

.badge-yes {
    color: var(--color-success);
    font-weight: 700;
}

.badge-no {
    color: var(--color-text-muted);
    font-weight: 700;
}

.lead-inquiry {
    margin: 0;
    color: var(--color-text);
    line-height: 1.65;
}

/* Inline editor (used for HTMX status update on lead detail) */
.inline-editor {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    margin: 0;
}

.inline-editor__label {
    color: var(--color-text-muted);
    font-size: 0.6875rem;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    font-weight: 700;
    margin: 0;
}

.inline-editor__select {
    background-color: var(--color-bg-deep);
    width: 100%;
    font-weight: 600;
}

/* Add-note form (HTMX) */
.add-note-form {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.add-note-form .note-input {
    background-color: var(--color-bg-deep);
}

.add-note-form__actions {
    display: flex;
    justify-content: flex-end;
}

/* Subtle highlight for a freshly-added note (HTMX response) */
.admin-activity-item--new {
    animation: note-flash 1.4s ease-out;
}

@keyframes note-flash {
    0%   { background-color: rgba(232, 101, 10, 0.18); }
    100% { background-color: transparent; }
}

/* Stacked activity lists on lead detail */
.admin-activity-list--mt { margin-top: var(--space-2); }

/* Add-lead form layout */
.lead-add-form {
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
}

.lead-add-form__grid {
    display: grid;
    gap: var(--space-2);
    grid-template-columns: 1fr;
}

@media (min-width: 720px) {
    .lead-add-form__grid { grid-template-columns: repeat(2, 1fr); }
}

.lead-add-form__grid .form-group--full { grid-column: 1 / -1; }

.lead-add-form .form-group label {
    color: var(--color-teal-light);
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    font-weight: 700;
    margin-bottom: 0.375rem;
}

.lead-add-form .form-control {
    background-color: var(--color-bg-deep);
}

.lead-add-form__actions {
    display: flex;
    justify-content: flex-end;
    gap: var(--space-1);
    margin-top: var(--space-2);
}

.required {
    color: var(--color-orange);
    font-weight: 700;
    margin-left: 0.125rem;
}

/* ── Kanban board ─────────────────────────────────────────── */

/* Container needs to break out of admin-container's max-width-ish constraints
   for the horizontal scroll experience to feel right. */
.kanban-container {
    /* keep at admin-container width but allow internal scroll */
}

.kanban-board {
    display: flex;
    gap: var(--space-2);
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    padding-bottom: var(--space-2);
    /* Negative margin pulls the board flush with the page container edges,
       so the horizontal scroll uses full viewport width on smaller screens. */
    margin-inline: calc(-1 * var(--space-3));
    padding-inline: var(--space-3);
    scrollbar-width: thin;
    scrollbar-color: var(--color-border) transparent;
}

.kanban-board::-webkit-scrollbar { height: 8px; }
.kanban-board::-webkit-scrollbar-track { background: transparent; }
.kanban-board::-webkit-scrollbar-thumb {
    background: var(--color-border);
    border-radius: 4px;
}

.kanban-column {
    flex: 0 0 290px;
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 12px;
    padding: var(--space-2);
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
    max-height: 78vh;
    min-height: 200px;
}

/* Won / Lost tinting per spec */
.kanban-column--won {
    background: rgba(74, 222, 128, 0.04);
    border-color: rgba(74, 222, 128, 0.25);
}
.kanban-column--won .kanban-column__count {
    background: rgba(74, 222, 128, 0.15);
    color: var(--color-success);
}

.kanban-column--lost {
    background: rgba(148, 163, 184, 0.04);
    border-color: rgba(148, 163, 184, 0.18);
    opacity: 0.85;
}

.kanban-column__header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-bottom: 0.5rem;
    border-bottom: 1px solid var(--color-border);
    flex-shrink: 0;
}

.kanban-column__title {
    font-size: 0.6875rem;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    color: var(--color-text-muted);
    font-weight: 700;
    margin: 0;
}

.kanban-column__count {
    background: rgba(255, 255, 255, 0.06);
    color: var(--color-text);
    padding: 0.125rem 0.5rem;
    border-radius: 999px;
    font-size: 0.75rem;
    font-weight: 700;
    min-width: 24px;
    text-align: center;
}

.kanban-column__cards {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    overflow-y: auto;
    flex: 1;
    padding-right: 0.25rem;  /* breathing room for scrollbar */
    scrollbar-width: thin;
    scrollbar-color: var(--color-border) transparent;
}

.kanban-column__cards::-webkit-scrollbar { width: 6px; }
.kanban-column__cards::-webkit-scrollbar-thumb {
    background: var(--color-border);
    border-radius: 3px;
}

.kanban-column__empty {
    color: var(--color-text-muted);
    font-size: 0.8125rem;
    text-align: center;
    padding: var(--space-3) 0;
    margin: 0;
    opacity: 0.6;
}

/* Card */
.kanban-card {
    background: var(--color-bg-deep);
    border: 1px solid var(--color-border);
    border-radius: 8px;
    padding: 0.625rem 0.75rem;
    display: flex;
    flex-direction: column;
    gap: 0.375rem;
    transition: border-color var(--transition), transform var(--transition), box-shadow var(--transition);
}

.kanban-card:hover {
    border-color: rgba(232, 101, 10, 0.3);
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
}

.kanban-card--hot  { border-left: 3px solid var(--color-danger); }
.kanban-card--warm { border-left: 3px solid var(--color-orange); }
.kanban-card--cold { border-left: 3px solid var(--color-teal); }

.kanban-card__firm {
    color: var(--color-text);
    font-weight: 700;
    text-decoration: none;
    font-size: 0.875rem;
    line-height: 1.3;
}

.kanban-card__firm:hover { color: var(--color-orange); }

.kanban-card__meta {
    color: var(--color-text-muted);
    font-size: 0.75rem;
    line-height: 1.3;
}

.kanban-card__meta--dim { opacity: 0.6; font-style: italic; }

.kanban-card__row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
}

.kanban-card__actions {
    display: flex;
    gap: 0.25rem;
}

.kanban-card__action {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 26px;
    height: 26px;
    color: var(--color-text-muted);
    background: rgba(255, 255, 255, 0.02);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    text-decoration: none;
    transition: color var(--transition), border-color var(--transition), background var(--transition);
}

.kanban-card__action:hover {
    color: var(--color-orange);
    border-color: rgba(232, 101, 10, 0.4);
    background: rgba(232, 101, 10, 0.06);
}

.kanban-card__action svg {
    width: 12px;
    height: 12px;
    stroke: currentColor;
    fill: none;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.kanban-card__move { margin: 0; }

.kanban-card__move-select {
    width: 100%;
    padding: 0.3125rem 0.5rem;
    font-size: 0.6875rem;
    background-color: var(--color-bg-raised);
    color: var(--color-text-muted);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    cursor: pointer;
    transition: border-color var(--transition), color var(--transition);
}

.kanban-card__move-select:hover,
.kanban-card__move-select:focus {
    color: var(--color-text);
    border-color: rgba(232, 101, 10, 0.4);
    outline: none;
}

/* ── HTMX loading state ───────────────────────────────────── */
/* HTMX adds .htmx-request to the triggering element during a request. */
button.htmx-request {
    opacity: 0.6;
    cursor: progress;
    pointer-events: none;
}

.htmx-indicator { display: none; }
.htmx-request .htmx-indicator,
.htmx-request.htmx-indicator { display: inline-flex; }

/* Danger button modifier (pairs with .btn-secondary) */
.btn-danger {
    color: var(--color-danger);
    border-color: rgba(248, 113, 113, 0.4);
}

.btn-danger:hover {
    color: var(--color-danger);
    background: rgba(248, 113, 113, 0.08);
    border-color: var(--color-danger);
}

/* ── Needs You queue ──────────────────────────────────────── */
.needs-you-list {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
}

/* Section grouping inside the Needs You page — "New intakes" +
   "Email replies" both render as sections of cards. */
.needs-you-section {
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
}
.needs-you-section__title {
    display: flex;
    align-items: center;
    gap: 10px;
    margin: 0;
    font-size: 1.05rem;
    color: var(--color-text);
}
.needs-you-section__count {
    background: var(--color-orange);
    color: #FFFFFF;
    font-size: 0.75rem;
    font-weight: 700;
    padding: 2px 9px;
    border-radius: 999px;
    line-height: 1.4;
}
.needs-you-section__sub {
    margin: 0 0 6px;
    font-size: 0.875rem;
}

/* Intake-review card — slimmer than the email-reply card; orange
   left-border so the section reads as the priority block above the
   email-reply queue. */
.needs-you-card--intake {
    border-left: 3px solid var(--color-orange);
}
.needs-you-card__badge {
    display: inline-block;
    padding: 2px 8px;
    border-radius: 4px;
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    background: rgba(232, 101, 10, 0.15);
    color: #E8650A;
}
.needs-you-card__badge--intake { /* matches default; placeholder for future kinds */ }
.needs-you-card__when {
    color: var(--color-text-muted);
    font-size: 0.8125rem;
    margin-left: 10px;
}
.needs-you-card__head {
    display: flex;
    align-items: center;
}
.needs-you-card__title {
    margin: 6px 0 4px;
    font-size: 1.05rem;
}
.needs-you-card__title a {
    color: var(--color-text);
    text-decoration: none;
}
.needs-you-card__title a:hover {
    color: var(--color-orange);
}
.needs-you-card__dl {
    margin: 8px 0 0;
    display: grid;
    grid-template-columns: minmax(80px, 110px) 1fr;
    gap: 4px 14px;
    font-size: 0.875rem;
}
.needs-you-card__dl dt {
    color: var(--color-text-muted);
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    font-weight: 600;
    padding-top: 2px;
}
.needs-you-card__dl dd {
    margin: 0;
    color: var(--color-text);
    line-height: 1.45;
    word-break: break-word;
}
.needs-you-card__truncate {
    color: var(--color-text-muted);
}
.needs-you-card__actions {
    margin-top: 12px;
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

/* Admin client-detail Project Progress section — stage chips row +
   quick-move form. Read-only display only; the form below the chips
   does the actual transitions. */
.admin-stage-bar {
    list-style: none;
    padding: 0;
    margin: 0 0 18px;
    display: flex;
    flex-wrap: wrap;
    gap: 8px 12px;
}
.admin-stage-bar__step {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    background: var(--color-bg);
    border: 1px solid var(--color-border);
    border-radius: 999px;
    font-size: 13px;
    color: var(--color-text-muted);
}
.admin-stage-bar__step.is-current {
    background: rgba(232, 101, 10, 0.12);
    border-color: rgba(232, 101, 10, 0.45);
    color: var(--color-text);
    font-weight: 600;
}
.admin-stage-bar__dot {
    color: var(--color-orange);
    font-size: 10px;
    line-height: 1;
}
.admin-stage-bar__step:not(.is-current) .admin-stage-bar__dot {
    color: var(--color-border);
}

.admin-stage-form {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 10px;
    padding-top: 12px;
    border-top: 1px solid var(--color-border);
}
.admin-stage-form__manual {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}
.admin-stage-form__note {
    flex: 1 1 100%;
    margin-top: 4px;
    font-size: 13px;
}

.admin-stage-log {
    margin-top: 14px;
    border-top: 1px solid var(--color-border);
    padding-top: 10px;
}
.admin-stage-log summary {
    cursor: pointer;
    color: var(--color-text-muted);
    font-size: 13px;
}
.admin-stage-log__list {
    list-style: none;
    padding: 8px 0 0;
    margin: 0;
}
.admin-stage-log__list li {
    padding: 6px 0;
    border-bottom: 1px solid var(--color-border);
    font-size: 13px;
}
.admin-stage-log__list li:last-child { border-bottom: none; }


/* ── Portal subscriptions page ─────────────────────────────────── */
.sub-list,
.pm-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.sub-card {
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 10px;
    padding: 16px 18px;
}
.sub-card__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    flex-wrap: wrap;
    margin-bottom: 6px;
}
.sub-card__title {
    margin: 0;
    color: var(--color-text);
    font-size: 1rem;
}
.sub-card__badge {
    display: inline-block;
    padding: 3px 9px;
    border-radius: 4px;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.sub-card__badge--ok {
    background: rgba(13, 148, 136, 0.15);
    color: #5EEAD4;
}
.sub-card__badge--info {
    background: rgba(59, 130, 246, 0.15);
    color: #93C5FD;
}
.sub-card__badge--warn {
    background: rgba(234, 179, 8, 0.15);
    color: #FBBF24;
}
.sub-card__badge--danger {
    background: rgba(239, 68, 68, 0.15);
    color: #FCA5A5;
}
.sub-card__meta {
    color: var(--color-text-muted);
    font-size: 0.875rem;
}
.sub-card__meta strong {
    color: var(--color-text);
    font-size: 1.05rem;
    font-variant-numeric: tabular-nums;
}

/* Card on the payment methods list. */
.pm-card {
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 10px;
    padding: 14px 18px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    flex-wrap: wrap;
}
.pm-card.is-default {
    border-color: rgba(232, 101, 10, 0.5);
    background: rgba(232, 101, 10, 0.04);
}
.pm-card__visual {
    display: inline-flex;
    align-items: center;
    gap: 14px;
    color: var(--color-text);
    font-variant-numeric: tabular-nums;
}
.pm-card__brand {
    font-weight: 700;
    font-size: 12px;
    padding: 4px 8px;
    background: var(--color-bg);
    border: 1px solid var(--color-border);
    border-radius: 4px;
    letter-spacing: 0.04em;
}
.pm-card__last4 { font-weight: 600; }
.pm-card__exp {
    color: var(--color-text-muted);
    font-size: 0.875rem;
}
.pm-card__actions {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}
.pm-card__default-badge {
    background: var(--color-orange);
    color: #FFFFFF;
    padding: 4px 10px;
    border-radius: 4px;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.pm-card__remove {
    color: #FCA5A5;
    background: none;
    border: none;
    cursor: pointer;
    font-size: 13px;
    padding: 4px 6px;
}
.pm-card__remove:hover { text-decoration: underline; }

/* Add-card modal. */
.add-card-modal {
    position: fixed;
    inset: 0;
    z-index: 50;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px;
}
.add-card-modal[hidden] { display: none; }
.add-card-modal__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(7, 6, 20, 0.75);
}
.add-card-modal__panel {
    position: relative;
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 12px;
    padding: 24px;
    width: 100%;
    max-width: 460px;
    box-shadow: 0 24px 64px rgba(0, 0, 0, 0.5);
    /* Stripe's Payment Element can render tall (card form +
       optional "save my info" Link section + email + phone). Cap
       at viewport height minus the wrapper padding so the panel
       scrolls instead of getting cut off on short screens. */
    max-height: calc(100vh - 40px);
    overflow-y: auto;
    /* iOS / Safari momentum scrolling. */
    -webkit-overflow-scrolling: touch;
}
.add-card-modal__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 16px;
}
.add-card-modal__head h3 {
    margin: 0;
    color: var(--color-text);
    font-size: 1.1rem;
}
.add-card-modal__close {
    background: none;
    border: none;
    color: var(--color-text-muted);
    font-size: 24px;
    cursor: pointer;
    padding: 0;
    line-height: 1;
}
.add-card-modal__close:hover { color: var(--color-text); }
.add-card-modal__message {
    margin-top: 12px;
    padding: 10px 12px;
    border-radius: 8px;
    font-size: 13px;
}
.add-card-modal__message--error {
    background: rgba(239, 68, 68, 0.1);
    border: 1px solid rgba(239, 68, 68, 0.3);
    color: #FCA5A5;
}
.add-card-modal__secure {
    margin-top: 14px;
    text-align: center;
    color: var(--color-text-muted);
    font-size: 12px;
}
#add-card-submit {
    margin-top: 14px;
    width: 100%;
    background: #E8650A;
    color: #FFFFFF;
    border: none;
    border-radius: 8px;
    padding: 13px;
    font-size: 15px;
    font-weight: 600;
    cursor: pointer;
}
#add-card-submit:disabled { opacity: 0.7; cursor: wait; }

.needs-you-card {
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 12px;
    padding: var(--space-3);
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
}

.needs-you-card__header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: var(--space-2);
    flex-wrap: wrap;
}

.needs-you-card__who {
    display: flex;
    flex-direction: column;
    gap: 0.125rem;
}

.needs-you-card__firm {
    color: var(--color-text);
    font-weight: 700;
    font-size: 1.0625rem;
    text-decoration: none;
}

.needs-you-card__firm:hover { color: var(--color-orange); }

.needs-you-card__attorney {
    color: var(--color-text-muted);
    font-size: 0.875rem;
}

/* Reply classification badge */
.reply-class {
    display: inline-block;
    font-size: 0.6875rem;
    font-weight: 700;
    padding: 0.25rem 0.625rem;
    border-radius: 999px;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    border: 1px solid transparent;
    white-space: nowrap;
}

.reply-class--question { background: rgba(13, 148, 136, 0.12); color: var(--color-teal-light); border-color: rgba(13, 148, 136, 0.3); }
.reply-class--unclear  { background: rgba(232, 101, 10, 0.12); color: var(--color-orange-light); border-color: rgba(232, 101, 10, 0.3); }
.reply-class--hostile  { background: rgba(248, 113, 113, 0.12); color: var(--color-danger); border-color: rgba(248, 113, 113, 0.35); }
.reply-class--interested,
.reply-class--maybe_later,
.reply-class--not_interested,
.reply-class--wrong_person,
.reply-class--already_have_someone,
.reply-class--unsubscribe {
    background: rgba(255, 255, 255, 0.06);
    color: var(--color-text-muted);
    border-color: var(--color-border);
}

/* Email thread blocks */
.email-thread {
    border-radius: var(--radius);
    padding: var(--space-2);
    border: 1px solid var(--color-border);
}

.email-thread--sent {
    background: rgba(255, 255, 255, 0.02);
}

.email-thread--received {
    background: var(--color-bg-deep);
    border-left: 3px solid var(--color-orange);
}

.email-thread__label {
    font-size: 0.625rem;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    color: var(--color-text-muted);
    font-weight: 700;
    margin-bottom: 0.375rem;
}

.email-thread__subject {
    color: var(--color-text);
    font-weight: 700;
    font-size: 0.9375rem;
    margin-bottom: 0.375rem;
}

.email-thread__body {
    color: var(--color-text);
    font-size: 0.9375rem;
    line-height: 1.6;
}

.email-thread--sent .email-thread__body {
    color: var(--color-text-muted);
}

.email-thread__meta {
    margin-top: 0.5rem;
    color: var(--color-text-muted);
    font-size: 0.75rem;
}

/* Reply composer */
.needs-you-card__reply {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.needs-you-card__reply-label {
    font-size: 0.625rem;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    color: var(--color-teal-light);
    font-weight: 700;
}

.needs-you-card__textarea {
    background-color: var(--color-bg-deep);
    width: 100%;
    resize: vertical;
}

.needs-you-card__actions {
    display: flex;
    gap: 0.5rem;
    justify-content: flex-end;
}

.needs-you-card__secondary {
    display: flex;
    gap: 0.5rem;
    justify-content: flex-end;
    padding-top: var(--space-2);
    border-top: 1px solid var(--color-border);
}

.needs-you-card__secondary form {
    margin: 0;
}

/* ── Outreach Settings ────────────────────────────────────── */
.settings-saved {
    background: rgba(74, 222, 128, 0.08);
    border: 1px solid rgba(74, 222, 128, 0.3);
    color: var(--color-success);
    font-weight: 600;
    padding: var(--space-2) var(--space-3);
    border-radius: var(--radius);
}

.settings-grid {
    display: grid;
    gap: var(--space-3);
}

@media (min-width: 1024px) {
    .settings-grid { grid-template-columns: 1.5fr 1fr; align-items: start; }
}

.settings-form,
.settings-side {
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
}

.settings-help {
    font-size: 0.875rem;
    margin: 0 0 var(--space-2);
}

.settings-field {
    display: flex;
    align-items: center;
    gap: 0.625rem;
}

.settings-number {
    background-color: var(--color-bg-deep);
    width: 120px;
    text-align: center;
    font-weight: 700;
    font-size: 1.0625rem;
}

.settings-field__suffix {
    color: var(--color-text-muted);
    font-size: 0.9375rem;
}

.settings-form__actions {
    display: flex;
    justify-content: flex-end;
}

/* Multi-column form row — used on settings (city / state / zip) and
   anywhere else we want fields side-by-side on desktop, stacked on
   mobile. The form-group--N modifier sets the flex basis. */
.form-row {
    display: flex;
    gap: 14px;
    flex-wrap: wrap;
}
.form-row > .form-group { flex: 1 1 100%; }
@media (min-width: 720px) {
    .form-row > .form-group--two-thirds { flex: 0 0 calc(66.66% - 10px); }
    .form-row > .form-group--sixth      { flex: 0 0 calc(16.66% - 10px); }
    .form-row > .form-group--third      { flex: 0 0 calc(33.33% - 10px); }
    .form-row > .form-group--half       { flex: 0 0 calc(50%    - 7px); }
}
.form-error {
    color: var(--color-danger);
    font-size: 0.82rem;
    margin: 4px 0 0;
}

/* Trust-level segmented control — pure CSS, driven by hidden radios */
.trust-control { position: relative; }

.trust-radio {
    position: absolute;
    opacity: 0;
    width: 1px;
    height: 1px;
    pointer-events: none;
}

.trust-segments {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 0.375rem;
    margin-bottom: var(--space-2);
}

.trust-segment {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.25rem;
    padding: 0.625rem 0.25rem;
    background: var(--color-bg-deep);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    cursor: pointer;
    text-align: center;
    transition: background var(--transition), border-color var(--transition), color var(--transition);
}

.trust-segment:hover { border-color: rgba(232, 101, 10, 0.35); }

.trust-segment__num {
    font-family: var(--font-serif);
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--color-text);
    line-height: 1;
}

.trust-segment__name {
    font-size: 0.625rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--color-text-muted);
    font-weight: 700;
}

/* Selected segment — one rule per level */
#tl-1:checked ~ .trust-segments label[for="tl-1"],
#tl-2:checked ~ .trust-segments label[for="tl-2"],
#tl-3:checked ~ .trust-segments label[for="tl-3"],
#tl-4:checked ~ .trust-segments label[for="tl-4"],
#tl-5:checked ~ .trust-segments label[for="tl-5"] {
    background: rgba(232, 101, 10, 0.12);
    border-color: var(--color-orange);
}

#tl-1:checked ~ .trust-segments label[for="tl-1"] .trust-segment__num,
#tl-2:checked ~ .trust-segments label[for="tl-2"] .trust-segment__num,
#tl-3:checked ~ .trust-segments label[for="tl-3"] .trust-segment__num,
#tl-4:checked ~ .trust-segments label[for="tl-4"] .trust-segment__num,
#tl-5:checked ~ .trust-segments label[for="tl-5"] .trust-segment__num {
    color: var(--color-orange);
}

#tl-1:checked ~ .trust-segments label[for="tl-1"] .trust-segment__name,
#tl-2:checked ~ .trust-segments label[for="tl-2"] .trust-segment__name,
#tl-3:checked ~ .trust-segments label[for="tl-3"] .trust-segment__name,
#tl-4:checked ~ .trust-segments label[for="tl-4"] .trust-segment__name,
#tl-5:checked ~ .trust-segments label[for="tl-5"] .trust-segment__name {
    color: var(--color-orange-light);
}

/* Keyboard focus ring on the visible segment when its hidden radio is focused */
#tl-1:focus-visible ~ .trust-segments label[for="tl-1"],
#tl-2:focus-visible ~ .trust-segments label[for="tl-2"],
#tl-3:focus-visible ~ .trust-segments label[for="tl-3"],
#tl-4:focus-visible ~ .trust-segments label[for="tl-4"],
#tl-5:focus-visible ~ .trust-segments label[for="tl-5"] {
    outline: 2px solid var(--color-orange);
    outline-offset: 2px;
}

/* Descriptions — hide all, reveal the one matching the checked radio */
.trust-descriptions {
    background: var(--color-bg-deep);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    padding: var(--space-2);
    min-height: 3.25rem;
}

.trust-desc {
    display: none;
    margin: 0;
    color: var(--color-text);
    line-height: 1.6;
}

.trust-desc::before {
    content: 'Level ' attr(data-level) ' — ';
    color: var(--color-orange);
    font-weight: 700;
}

#tl-1:checked ~ .trust-descriptions .trust-desc[data-level="1"],
#tl-2:checked ~ .trust-descriptions .trust-desc[data-level="2"],
#tl-3:checked ~ .trust-descriptions .trust-desc[data-level="3"],
#tl-4:checked ~ .trust-descriptions .trust-desc[data-level="4"],
#tl-5:checked ~ .trust-descriptions .trust-desc[data-level="5"] {
    display: block;
}

/* Outreach Active toggle switch — pure CSS, driven by hidden checkbox */
.outreach-toggle { position: relative; }

.outreach-toggle__input {
    position: absolute;
    opacity: 0;
    width: 1px;
    height: 1px;
    pointer-events: none;
}

.outreach-toggle__switch {
    display: inline-flex;
    align-items: center;
    gap: 0.75rem;
    cursor: pointer;
}

.outreach-toggle__track {
    width: 46px;
    height: 26px;
    background: var(--color-bg-deep);
    border: 1px solid var(--color-border);
    border-radius: 999px;
    position: relative;
    flex-shrink: 0;
    transition: background var(--transition), border-color var(--transition);
}

.outreach-toggle__thumb {
    position: absolute;
    top: 2px;
    left: 2px;
    width: 20px;
    height: 20px;
    background: var(--color-text-muted);
    border-radius: 50%;
    transition: transform var(--transition), background var(--transition);
}

.outreach-toggle__text {
    color: var(--color-text);
    font-weight: 600;
}

.outreach-toggle__input:checked ~ .outreach-toggle__switch .outreach-toggle__track {
    background: var(--color-orange);
    border-color: var(--color-orange);
}

.outreach-toggle__input:checked ~ .outreach-toggle__switch .outreach-toggle__thumb {
    transform: translateX(20px);
    background: #FFFFFF;
}

.outreach-toggle__input:focus-visible ~ .outreach-toggle__switch .outreach-toggle__track {
    outline: 2px solid var(--color-orange);
    outline-offset: 2px;
}

/* Warning — shown only when the toggle is ON */
.outreach-toggle__warning {
    display: none;
    margin-top: var(--space-2);
    padding: var(--space-2) var(--space-3);
    background: rgba(232, 101, 10, 0.08);
    border: 1px solid rgba(232, 101, 10, 0.35);
    border-radius: var(--radius);
    color: var(--color-text);
    font-size: 0.9375rem;
    line-height: 1.55;
}

.outreach-toggle__warning strong { color: var(--color-orange); }

.outreach-toggle__input:checked ~ .outreach-toggle__warning {
    display: block;
}

/* ── Scraper page ─────────────────────────────────────────── */
.scrape-form {
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
}

.scrape-form__grid {
    display: grid;
    gap: var(--space-2);
    grid-template-columns: 1fr;
}

@media (min-width: 720px) {
    .scrape-form__grid { grid-template-columns: repeat(2, 1fr); }
}

.scrape-form .form-group label {
    color: var(--color-teal-light);
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    font-weight: 700;
    margin-bottom: 0.375rem;
}

.scrape-form .form-control {
    background-color: var(--color-bg-deep);
}

.scrape-form__actions {
    display: flex;
    justify-content: flex-end;
}

.scrape-form__note {
    font-size: 0.8125rem;
    margin: 0;
    text-align: center;
}

/* Result panel */
.scrape-result {
    background: var(--color-bg-raised);
    border: 1px solid rgba(74, 222, 128, 0.3);
    border-radius: 12px;
    padding: var(--space-3);
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
}

.scrape-result__headline {
    font-size: 1.125rem;
    color: var(--color-text);
}

.scrape-result__headline strong {
    color: var(--color-success);
    font-family: var(--font-serif);
}

.scrape-result__counts {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2);
}

.scrape-stat {
    display: inline-flex;
    align-items: baseline;
    gap: 0.375rem;
    background: var(--color-bg-deep);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    padding: 0.375rem 0.75rem;
    font-family: var(--font-serif);
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--color-text);
}

.scrape-stat em {
    font-family: var(--font-sans);
    font-size: 0.6875rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--color-text-muted);
    font-style: normal;
}

.scrape-stat--good { border-color: rgba(74, 222, 128, 0.35); }
.scrape-stat--good { color: var(--color-success); }
.scrape-stat--bad { border-color: rgba(248, 113, 113, 0.35); color: var(--color-danger); }

.scrape-result__hint {
    font-size: 0.875rem;
    margin: 0;
}

/* ── 17. Responsive — tablet (≥ 720px) ─────────────────────── */
@media (min-width: 720px) {
    .hero__ctas {
        flex-direction: row;
        justify-content: center;
    }

    .cards {
        /* minmax(0, 1fr) so columns can shrink under their intrinsic
           size — otherwise long pricing labels ("$1,199/month") or
           full-width CTA buttons push the grid past the container,
           which spills both the leftmost and rightmost cards past
           the viewport (horizontal scroll). */
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .value-tiles {
        grid-template-columns: repeat(2, 1fr);
    }

    .steps {
        grid-template-columns: repeat(3, 1fr);
        gap: var(--space-3);
    }

    .testimonials {
        grid-template-columns: repeat(2, 1fr);
    }

    .portfolio-strip {
        grid-template-columns: repeat(2, 1fr);
    }

    .footer-grid {
        grid-template-columns: 1.4fr 1fr 1fr 1fr;
    }

    .footer-bottom {
        flex-direction: row;
        justify-content: space-between;
        text-align: left;
    }
}

/* ── 18. Responsive — desktop (≥ 1024px) ───────────────────── */
@media (min-width: 1024px) {
    .nav-toggle {
        display: none;
    }

    .nav-menu {
        display: block;
        position: static;
        background: transparent;
        -webkit-backdrop-filter: none;
        backdrop-filter: none;
        border: none;
        box-shadow: none;
        padding: 0;
    }

    .nav-menu ul {
        flex-direction: row;
        align-items: center;
        gap: var(--space-1);
    }

    .nav-link {
        padding: 0.625rem 0.875rem;
        font-size: 0.9375rem;
    }

    .nav-link--cta {
        margin-top: 0;
        margin-left: var(--space-1);
        padding: 0.625rem 1.25rem;
    }

    .hero {
        padding-block: var(--space-8);
    }

    .value-tiles {
        grid-template-columns: repeat(4, 1fr);
    }

    .testimonials {
        grid-template-columns: repeat(3, 1fr);
    }

    .portfolio-strip {
        grid-template-columns: repeat(4, 1fr);
    }
}

/* ══ 20. Client portal ══════════════════════════════════════ */
.portal-body {
    background-color: var(--color-bg-deep);
    color: var(--color-text);
}

.portal-layout {
    display: flex;
    min-height: 100vh;
}

.portal-sidebar {
    width: 248px;
    flex-shrink: 0;
    background: var(--color-bg-raised);
    border-right: 1px solid var(--color-border);
    display: flex;
    flex-direction: column;
    padding: var(--space-3) var(--space-2);
    position: sticky;
    top: 0;
    height: 100vh;
    /* The portal nav has 14+ items in 5 groups — when the viewport
       is shorter than the full list (laptops, half-screens), let
       the sidebar scroll on its own without taking the page with
       it. The logout form below the nav stays in view because
       flex-grow on .portal-nav lets the nav own the slack. */
    overflow-y: auto;
}
/* Slimmer scrollbar so it doesn't dominate the 248px column. */
.portal-sidebar::-webkit-scrollbar { width: 6px; }
.portal-sidebar::-webkit-scrollbar-track { background: transparent; }
.portal-sidebar::-webkit-scrollbar-thumb {
    background: rgba(255,255,255,0.08); border-radius: 3px;
}
.portal-sidebar::-webkit-scrollbar-thumb:hover {
    background: rgba(255,255,255,0.15);
}

.portal-nav-group-label {
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: #64748B;
    padding: 14px var(--space-2) 4px;
    /* No top padding on the first group — its parent already has
       the logo + section break. */
}
.portal-nav-group-label--first {
    padding-top: 4px;
}

/* Sidebar notice shown only in intake-only mode — when the client
   is still in `pending_intake`. Tells them why every other portal
   link is missing, so the sidebar doesn't feel broken. */
.portal-nav-notice {
    margin: 4px var(--space-2) 12px;
    padding: 12px;
    border-radius: 8px;
    background: rgba(232, 101, 10, 0.08);
    border: 1px solid rgba(232, 101, 10, 0.25);
    color: #FBBF24;
    font-size: 12px;
    line-height: 1.45;
}

.portal-logo {
    display: block;
    padding: 0 var(--space-2) var(--space-3);
}

.portal-logo img {
    height: 48px;
    width: auto;
}

.portal-nav {
    display: flex;
    flex-direction: column;
    gap: 2px;
    flex-grow: 1;
}

.portal-nav__link {
    display: flex;
    align-items: center;
    gap: 0.7rem;
    padding: 0.6rem 0.8rem;
    border-radius: 10px;
    color: var(--color-text-muted);
    font-size: 0.9375rem;
    font-weight: 600;
    border: none;
    background: transparent;
    width: 100%;
    cursor: pointer;
    text-align: left;
    font-family: inherit;
}

.portal-nav__link svg {
    width: 20px;
    height: 20px;
    flex-shrink: 0;
    fill: none;
    stroke: currentColor;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.portal-nav__link:hover {
    background: rgba(255, 255, 255, 0.04);
    color: var(--color-text);
}

.portal-nav__link.is-active {
    background: rgba(232, 101, 10, 0.14);
    color: var(--color-orange-light);
}

.portal-nav__link--logout {
    color: var(--color-text-muted);
}

.portal-nav__logout {
    margin-top: var(--space-2);
    border-top: 1px solid var(--color-border);
    padding-top: var(--space-2);
}

.portal-badge {
    margin-left: auto;
    min-width: 20px;
    height: 20px;
    padding: 0 6px;
    border-radius: 999px;
    background: var(--color-orange);
    color: #fff;
    font-size: 0.6875rem;
    font-weight: 700;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.portal-main {
    flex-grow: 1;
    padding: var(--space-4);
    max-width: 1100px;
}

.portal-messages {
    margin-bottom: var(--space-3);
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.portal-message {
    padding: 0.75rem 1rem;
    border-radius: 8px;
    font-size: 0.9375rem;
    font-weight: 600;
    border: 1px solid var(--color-border);
}

.portal-message--success {
    background: rgba(74, 222, 128, 0.1);
    border-color: rgba(74, 222, 128, 0.3);
    color: var(--color-success);
}

.portal-message--warning,
.portal-message--error {
    background: rgba(232, 101, 10, 0.1);
    border-color: rgba(232, 101, 10, 0.3);
    color: var(--color-orange-light);
}

/* Phase C4 — per-subscription payment-method picker on the
   subscription card. JS-less change submits via onchange; noscript
   fallback shows a Save button. */
.sub-card__pm {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-top: 0.75rem;
    padding-top: 0.75rem;
    border-top: 1px solid var(--color-border-subtle, #2a2a2a);
}
.sub-card__pm-label {
    color: var(--color-text-muted);
    font-size: 0.85rem;
}
.sub-card__pm-select {
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    color: var(--color-text);
    border-radius: 6px;
    padding: 4px 8px;
    font-size: 0.85rem;
    min-width: 220px;
}

/* Phase C — active-website header bar on portal pages. Renders
   only when the account has more than one Website. Uses portal
   dark-theme tokens (admin theme tokens would be wrong here). */
.portal-site-bar {
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 8px;
    padding: 0.625rem 1rem;
    margin-bottom: var(--space-4);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    flex-wrap: wrap;
}
.portal-site-bar__left {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex-wrap: wrap;
}
.portal-site-bar__label {
    color: var(--color-text-muted);
    font-size: 0.85rem;
}
.portal-site-bar__name {
    color: var(--color-text);
    font-size: 0.95rem;
}
.portal-site-bar__stage {
    background: var(--color-orange-soft, rgba(232, 101, 10, 0.15));
    color: var(--color-orange-light, #E8650A);
    padding: 2px 8px;
    border-radius: 999px;
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    font-weight: 600;
}
.portal-site-bar__switch {
    color: var(--color-orange-light, #E8650A);
    text-decoration: none;
    font-size: 0.85rem;
    font-weight: 500;
}
.portal-site-bar__switch:hover {
    text-decoration: underline;
}

.portal-page-head {
    margin-bottom: var(--space-4);
}

.portal-page-head h1 {
    font-size: 1.875rem;
    margin: 0;
}

.portal-page-head__sub {
    color: var(--color-text-muted);
    margin: 0.25rem 0 0;
}

.portal-section {
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 14px;
    padding: var(--space-3);
    margin-bottom: var(--space-3);
}

.portal-section__title {
    font-size: 1.125rem;
    margin: 0 0 var(--space-3);
}

.portal-section__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-2);
}

.portal-section__head .portal-section__title {
    margin-bottom: 0;
}

.portal-cols {
    display: grid;
    gap: var(--space-3);
    grid-template-columns: 1fr;
}

@media (min-width: 900px) {
    .portal-cols {
        grid-template-columns: 1fr 1fr;
        align-items: start;
    }
    .portal-section--grow {
        grid-row: span 1;
    }
}

.portal-empty {
    color: var(--color-text-muted);
    font-size: 0.9375rem;
    margin: 0;
}

/* Stat cards */
.stat-grid {
    display: grid;
    gap: var(--space-2);
    grid-template-columns: repeat(2, 1fr);
    margin-bottom: var(--space-3);
}

@media (min-width: 760px) {
    .stat-grid {
        grid-template-columns: repeat(4, 1fr);
    }
}

.stat-card {
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 14px;
    padding: var(--space-3);
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}

.stat-card__label {
    font-size: 0.6875rem;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--color-text-muted);
    font-weight: 700;
}

.stat-card__value {
    font-size: 1.5rem;
    font-weight: 700;
    font-family: var(--font-serif);
}

.stat-card__meta {
    font-size: 0.8125rem;
    color: var(--color-text-muted);
}

/* Horizontal stepper */
.stepper {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2);
}

.stepper__step {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    flex: 1 1 auto;
    min-width: 110px;
}

.stepper__dot {
    width: 22px;
    height: 22px;
    border-radius: 50%;
    border: 2px solid var(--color-border-strong);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.75rem;
    font-weight: 700;
    flex-shrink: 0;
    color: var(--color-bg-deep);
}

.stepper__label {
    font-size: 0.8125rem;
    color: var(--color-text-muted);
}

.stepper__step--completed .stepper__dot {
    background: var(--color-teal-light, #2dd4bf);
    border-color: var(--color-teal-light, #2dd4bf);
}

.stepper__step--current .stepper__dot {
    border-color: var(--color-orange);
    background: var(--color-orange);
}

.stepper__step--current .stepper__label {
    color: var(--color-orange-light);
    font-weight: 700;
}

.stepper__step--completed .stepper__label {
    color: var(--color-text);
}

/* Activity feed */
.activity-feed {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
}

.activity-feed__item {
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
    padding: 0.7rem 0;
    border-bottom: 1px solid var(--color-border);
}

.activity-feed__item:last-child {
    border-bottom: none;
}

.activity-feed__title {
    font-weight: 700;
    font-size: 0.9375rem;
}

.activity-feed__note {
    font-size: 0.875rem;
    color: var(--color-text-muted);
}

.activity-feed__date {
    font-size: 0.75rem;
    color: var(--color-text-muted);
}

/* Quick actions */
.quick-actions {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.quick-action {
    display: block;
    padding: 0.7rem 0.9rem;
    border-radius: 10px;
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid var(--color-border);
    color: var(--color-text);
    font-weight: 600;
    font-size: 0.9375rem;
}

.quick-action:hover {
    border-color: var(--color-orange);
    color: var(--color-orange-light);
}

/* Definition list */
.detail-list {
    margin: 0;
    display: flex;
    flex-direction: column;
}

.detail-list > div {
    display: flex;
    justify-content: space-between;
    gap: var(--space-2);
    padding: 0.55rem 0;
    border-bottom: 1px solid var(--color-border);
}

.detail-list > div:last-child {
    border-bottom: none;
}

.detail-list dt {
    color: var(--color-text-muted);
    font-size: 0.875rem;
    font-weight: 600;
}

.detail-list dd {
    margin: 0;
    text-align: right;
    font-size: 0.9375rem;
    word-break: break-word;
}

/* Status pills */
.status-pill {
    display: inline-block;
    font-size: 0.6875rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    padding: 0.2rem 0.55rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.06);
    border: 1px solid var(--color-border);
    color: var(--color-text-muted);
}

.status-pill--stage,
.status-pill--current,
.status-pill--in_progress,
.status-pill--sent,
.status-pill--open,
.status-pill--priority-medium {
    background: rgba(232, 101, 10, 0.14);
    color: var(--color-orange-light);
    border-color: rgba(232, 101, 10, 0.3);
}

.status-pill--complete,
.status-pill--completed,
.status-pill--paid,
.status-pill--resolved {
    background: rgba(74, 222, 128, 0.12);
    color: var(--color-success);
    border-color: rgba(74, 222, 128, 0.3);
}

.status-pill--out_of_scope,
.status-pill--priority-high {
    background: rgba(248, 113, 113, 0.12);
    color: var(--color-danger);
    border-color: rgba(248, 113, 113, 0.3);
}

/* Vertical timeline */
.timeline {
    list-style: none;
    margin: 0;
    padding: 0;
}

.timeline__item {
    display: flex;
    gap: 0.9rem;
    padding-bottom: var(--space-3);
    position: relative;
}

.timeline__item:not(:last-child)::before {
    content: '';
    position: absolute;
    left: 8px;
    top: 20px;
    bottom: 0;
    width: 2px;
    background: var(--color-border);
}

.timeline__marker {
    width: 18px;
    height: 18px;
    border-radius: 50%;
    border: 2px solid var(--color-border-strong);
    flex-shrink: 0;
    margin-top: 2px;
    background: var(--color-bg-raised);
    z-index: 1;
}

.timeline__item--completed .timeline__marker {
    background: var(--color-teal-light, #2dd4bf);
    border-color: var(--color-teal-light, #2dd4bf);
}

.timeline__item--current .timeline__marker {
    background: var(--color-orange);
    border-color: var(--color-orange);
}

.timeline__body {
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
}

.timeline__stage {
    font-weight: 700;
    font-size: 0.9375rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.timeline__status {
    font-size: 0.625rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--color-text-muted);
    font-weight: 700;
}

.timeline__date,
.timeline__note {
    font-size: 0.8125rem;
    color: var(--color-text-muted);
}

.timeline__link {
    font-size: 0.8125rem;
    font-weight: 700;
    color: var(--color-orange);
}

.support-window {
    margin: var(--space-2) 0 0;
    padding: 0.6rem 0.85rem;
    border-radius: 8px;
    font-size: 0.875rem;
    font-weight: 600;
}

.support-window--open {
    background: rgba(74, 222, 128, 0.1);
    color: var(--color-success);
}

.support-window--closed {
    background: rgba(255, 255, 255, 0.04);
    color: var(--color-text-muted);
}

.revision-warning {
    padding: 0.7rem 0.95rem;
    border-radius: 8px;
    font-size: 0.875rem;
    font-weight: 600;
    margin-bottom: var(--space-3);
    background: rgba(232, 101, 10, 0.12);
    color: var(--color-orange-light);
    border: 1px solid rgba(232, 101, 10, 0.3);
}

.revision-warning--over {
    background: rgba(248, 113, 113, 0.12);
    color: var(--color-danger);
    border-color: rgba(248, 113, 113, 0.3);
}

/* Generic record list */
.record-list {
    list-style: none;
    margin: 0;
    padding: 0;
}

.record-list__item {
    display: flex;
    justify-content: space-between;
    gap: var(--space-2);
    padding: 0.8rem 0;
    border-bottom: 1px solid var(--color-border);
    flex-wrap: wrap;
}

.record-list__item:last-child {
    border-bottom: none;
}

.record-list__main {
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
    font-size: 0.9375rem;
    flex: 1 1 240px;
}

.record-list__sub {
    font-size: 0.8125rem;
    color: var(--color-text-muted);
}

.record-list__meta {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.8125rem;
    color: var(--color-text-muted);
    flex-wrap: wrap;
}

/* Intake form */
.intake-progress {
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 14px;
    padding: var(--space-3);
    margin-bottom: var(--space-3);
}

.intake-progress__head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 0.5rem;
}

.intake-progress__saved {
    color: var(--color-success);
    font-size: 0.8125rem;
    font-weight: 700;
}

.intake-progress__bar {
    width: 100%;
    height: 10px;
    border: none;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.07);
    overflow: hidden;
    -webkit-appearance: none;
    appearance: none;
}

.intake-progress__bar::-webkit-progress-bar {
    background: rgba(255, 255, 255, 0.07);
    border-radius: 999px;
}

.intake-progress__bar::-webkit-progress-value {
    background: var(--color-orange);
    border-radius: 999px;
}

.intake-progress__bar::-moz-progress-bar {
    background: var(--color-orange);
    border-radius: 999px;
}

.intake-progress__steps {
    list-style: none;
    margin: var(--space-2) 0 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem 1rem;
}

.intake-progress__steps li {
    font-size: 0.8125rem;
    color: var(--color-text-muted);
    display: flex;
    align-items: center;
    gap: 0.35rem;
}

.intake-progress__steps li.is-done {
    color: var(--color-success);
}

.intake-progress__check {
    width: 16px;
    display: inline-block;
    text-align: center;
}

/* Clickable step buttons in the progress chip — render as plain
   text + checkmark with an underline-on-hover affordance. No browser
   button chrome. Locked steps render as <span class="...--locked"> */
.intake-progress__jump {
    background: none;
    border: none;
    padding: 0;
    margin: 0;
    color: inherit;
    font: inherit;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    text-align: left;
}
.intake-progress__jump:hover {
    color: var(--color-orange);
    text-decoration: underline;
}
.intake-progress__jump.is-done {
    color: var(--color-success);
}
.intake-progress__jump.is-done:hover {
    color: var(--color-orange);
}
.intake-progress__step--locked {
    cursor: default;
    opacity: 0.65;
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
}

.checkbox-row {
    display: flex;
    align-items: flex-start;
    gap: 0.6rem;
    margin: var(--space-2) 0;
    font-size: 0.9375rem;
}

.checkbox-row input {
    margin-top: 0.2rem;
}

.form-hint {
    font-size: 0.8125rem;
    color: var(--color-text-muted);
    margin: 0.5rem 0 0;
    line-height: 1.45;
}
.form-hint--block {
    margin: 0 0 0.75rem 0;
}
.form-hint code {
    background: var(--color-bg-raised);
    padding: 1px 5px;
    border-radius: 3px;
    font-size: 0.8em;
}

/* Section subhead inside intake — visual break above the split-out
   social-profile inputs without using a full <h2>. */
.form-subhead {
    margin: var(--space-3) 0 0.5rem 0;
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--color-text);
    border-top: 1px solid var(--color-border);
    padding-top: var(--space-3);
}

/* Conditional reveals on the intake form — controlled by intake_form.js
   via the `is-revealed` class. Hidden by default so a flash of the
   "Other registrar" field never appears for clients whose answer is
   not "Other". */
.intake-reveal {
    display: none;
    margin-top: var(--space-2);
}
.intake-reveal.is-revealed {
    display: block;
}

/* ── Intake wizard ──
   The form is JS-driven (intake_form.js): exactly one section is
   visible at a time, navigation lives in a sticky bottom bar. The
   `[data-wizard]` attribute on the <form> opts the form into wizard
   mode — when JS isn't loaded (very rare these days), all sections
   stay visible so the form is still usable. */
.intake-form[data-wizard] .intake-step {
    display: none;
}
.intake-form[data-wizard] .intake-step.is-current {
    display: block;
}

.intake-wizard-nav {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 14px 18px;
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 12px;
    margin-top: 16px;
}
.intake-wizard-nav__status {
    color: var(--color-text-muted);
    font-size: 13px;
    font-variant-numeric: tabular-nums;
    white-space: nowrap;
}
.intake-wizard-nav button:disabled {
    opacity: 0.45;
    cursor: not-allowed;
}

.intake-final-submit {
    margin-top: 14px;
    padding: 18px;
    text-align: center;
}
.intake-final-submit__btn {
    padding: 14px 32px;
    font-size: 16px;
}
.intake-final-submit__btn:disabled {
    opacity: 0.45;
    cursor: not-allowed;
}
.intake-final-submit__hint {
    margin: 10px 0 0;
    color: var(--color-text-muted);
    font-size: 13px;
}

/* Required-asterisk colour. */
.form-required {
    color: var(--color-orange);
    margin-left: 2px;
}

/* Yes/No radio row for Step 2 (photos). */
.intake-radio-row {
    display: flex;
    flex-wrap: wrap;
    gap: 18px;
    margin-top: 6px;
}
.intake-radio {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    cursor: pointer;
    color: var(--color-text);
    font-size: 14px;
}
.intake-radio input {
    width: 18px;
    height: 18px;
    accent-color: var(--color-orange);
}
.intake-label {
    display: block;
    color: var(--color-text);
    font-weight: 600;
    font-size: 0.9375rem;
    margin-bottom: 4px;
}

/* Step 6 review cards — read-only summary of each prior step with
   an Edit button that jumps the wizard back to the matching step.
   Tighter padding than .portal-section so 5 cards stack visibly
   without scrolling forever. */
.review-card {
    background: var(--color-bg);
    border: 1px solid var(--color-border);
    border-radius: 10px;
    padding: 16px 18px;
    margin-top: 12px;
}
.review-card__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 10px;
    padding-bottom: 10px;
    border-bottom: 1px solid var(--color-border);
}
.review-card__title {
    margin: 0;
    font-size: 1rem;
    color: var(--color-text);
}
.review-card__optional {
    font-weight: 400;
    color: var(--color-text-muted);
    font-size: 0.75em;
    margin-left: 4px;
}
.review-card__edit {
    color: var(--color-orange);
    font-size: 0.85rem;
    background: none;
    border: none;
    padding: 4px 8px;
    cursor: pointer;
    font-weight: 600;
}
.review-card__edit:hover {
    text-decoration: underline;
}

.review-dl {
    margin: 0;
    display: grid;
    grid-template-columns: minmax(120px, 180px) 1fr;
    gap: 8px 16px;
}
.review-dl dt {
    color: var(--color-text-muted);
    font-size: 0.8125rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    font-weight: 600;
    padding-top: 2px;
}
.review-dl dd {
    margin: 0;
    color: var(--color-text);
    font-size: 0.9375rem;
    line-height: 1.5;
    word-break: break-word;
}
.review-pre {
    white-space: pre-wrap;
    line-height: 1.55;
}
.review-muted {
    color: var(--color-text-muted);
    font-style: italic;
}
.review-social-list {
    list-style: none;
    padding: 0;
    margin: 0;
}
.review-social-list li {
    margin: 4px 0;
    font-size: 0.875rem;
}
.review-social-list a {
    color: var(--color-orange);
    text-decoration: none;
    word-break: break-all;
}
.review-social-list a:hover { text-decoration: underline; }

/* Read-only photo thumbnail grid for the Step 6 review card.
   Smaller than the Step 2 .intake-photo-grid (no delete button,
   no labels) — these are at-a-glance previews; click to open full
   size in a new tab. */
.review-photo-grid {
    list-style: none;
    padding: 0;
    margin: 10px 0 0;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(96px, 1fr));
    gap: 8px;
}
.review-photo-grid__item {
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 6px;
    overflow: hidden;
    aspect-ratio: 1 / 1;
}
.review-photo-grid__item a {
    display: block;
    width: 100%;
    height: 100%;
}
.review-photo-grid__item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: opacity 0.15s;
}
.review-photo-grid__item:hover img {
    opacity: 0.85;
}

@media (max-width: 540px) {
    .review-dl {
        grid-template-columns: 1fr;
        gap: 2px 0;
    }
    .review-dl dt {
        padding-top: 8px;
    }
    .review-dl dt:first-child {
        padding-top: 0;
    }
}

/* Inline opt-out checkbox shown under a field that it modifies
   (e.g. the "I don't have a logo yet" toggle under the Logo upload).
   Sits flush under the field with a smaller font weight so it reads
   as secondary to the primary input above it. */
.intake-inline-check {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin-top: 10px;
    color: var(--color-text-muted);
    font-size: 13px;
    cursor: pointer;
}
.intake-inline-check input {
    width: 16px;
    height: 16px;
    accent-color: var(--color-orange);
    cursor: pointer;
}

/* Intake-specific spacing — the global .form-group is intentionally tight
   (used in dense admin forms) but the intake is a long, scrolling client-
   facing form where every field deserves breathing room. Scope these
   overrides to .intake-form so other forms keep their compact layout.
   Tall textareas make the previous 1.5rem gap feel cramped in textarea
   blocks (Step 3/4) compared to short text-input blocks (Step 1); 2rem
   gives every field the same generous visual rhythm regardless of input
   height. */
.intake-form .form-group {
    gap: 0.625rem;            /* label → hint → input vertical rhythm */
    margin-bottom: 2rem;      /* breathing room between fields */
}
.intake-form .form-group label {
    margin-bottom: 0.25rem;   /* extra nudge under the bold label */
}
.intake-form .form-group .form-hint {
    margin: 0 0 0.25rem 0;    /* tuck the hint up under the label */
}
.intake-form .checkbox-row {
    margin: 0.5rem 0 1.25rem 0;
}
/* Section subhead (the "Social profiles" header inside step 5) — give
   it the same generous breathing room as the gap between fields so
   the layout feels consistent end-to-end. */
.intake-form .form-subhead {
    margin-top: 1.25rem;
}
/* Last field in a section shouldn't double up on space with the next
   section's own padding. */
.intake-form .form-group:last-of-type {
    margin-bottom: 0.5rem;
}

/* Intake step 2 — photo uploader gallery. */
.intake-photos {
    margin-top: var(--space-3);
}
.intake-photo-grid {
    list-style: none;
    padding: 0;
    margin: 0 0 var(--space-3) 0;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
    gap: 12px;
}
.intake-photo-grid__item {
    position: relative;
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 8px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
}
.intake-photo-grid__item img {
    width: 100%;
    height: 120px;
    object-fit: cover;
    display: block;
}
.intake-photo-grid__meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 6px;
    padding: 6px 8px;
    font-size: 11px;
    color: var(--color-text-muted);
    min-height: 28px;
}
.intake-photo-grid__meta span {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.intake-photo-grid__delete {
    background: transparent;
    border: none;
    color: var(--color-text-muted);
    cursor: pointer;
    font-size: 18px;
    line-height: 1;
    padding: 0 4px;
}
.intake-photo-grid__delete:hover { color: #ef4444; }

.intake-photo-uploader__label {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 10px 16px;
    background: var(--color-bg-raised);
    border: 1px dashed var(--color-border);
    border-radius: 8px;
    cursor: pointer;
    color: var(--color-text);
    font-size: 0.9rem;
    transition: border-color 0.15s, background 0.15s;
}
.intake-photo-uploader__label:hover {
    border-color: #E8650A;
    background: var(--color-bg);
}
.intake-photo-uploader__label input[type="file"] {
    /* Visually hidden but still focusable via the label click. */
    position: absolute;
    width: 1px; height: 1px;
    padding: 0; margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    border: 0;
}

/* Invoice table */
.invoice-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.9375rem;
}

.invoice-table th,
.invoice-table td {
    text-align: left;
    padding: 0.7rem 0.6rem;
    border-bottom: 1px solid var(--color-border);
}

.invoice-table th {
    font-size: 0.6875rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--color-text-muted);
}

.invoice-table__actions {
    display: flex;
    gap: 0.4rem;
    justify-content: flex-end;
}

/* Small button modifier */
.btn-sm {
    padding: 0.35rem 0.75rem;
    font-size: 0.8125rem;
}

@media (max-width: 720px) {
    .portal-layout {
        flex-direction: column;
    }
    .portal-sidebar {
        width: 100%;
        height: auto;
        position: static;
        flex-direction: row;
        flex-wrap: wrap;
        align-items: center;
    }
    .portal-nav {
        flex-direction: row;
        flex-wrap: wrap;
        flex-grow: 1;
    }
    .portal-nav__link span:not(.portal-badge) {
        display: none;
    }
    .portal-nav__logout {
        border-top: none;
        margin-top: 0;
        padding-top: 0;
    }
    .portal-main {
        padding: var(--space-3);
    }
}

/* ── Maintenance handoff plan picker ───────────────────────── */
.maintenance-plans {
    display: grid;
    gap: var(--space-3);
    grid-template-columns: 1fr;
    margin-top: var(--space-4);
}

@media (min-width: 860px) {
    .maintenance-plans {
        grid-template-columns: repeat(3, 1fr);
        align-items: start;
    }
}

.plan-card {
    display: flex;
    flex-direction: column;
    position: relative;
}

.plan-card--popular {
    border-color: var(--color-orange);
}

.plan-card__badge {
    position: absolute;
    top: -12px;
    left: 50%;
    transform: translateX(-50%);
    background: var(--color-orange);
    color: #fff;
    font-size: 0.6875rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    padding: 0.25rem 0.75rem;
    border-radius: 999px;
    white-space: nowrap;
}

.plan-card__name {
    font-size: 1.375rem;
    margin: 0;
}

.plan-card__price {
    font-family: var(--font-serif);
    font-size: 2.5rem;
    font-weight: 700;
    margin: 0.25rem 0 var(--space-2);
    color: var(--color-orange-light);
}

.plan-card__price span {
    font-size: 1rem;
    color: var(--color-text-muted);
    font-family: var(--font-sans, Arial, sans-serif);
}

.plan-features {
    list-style: none;
    margin: 0 0 var(--space-3);
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    flex-grow: 1;
}

.plan-features li {
    font-size: 0.9375rem;
    color: var(--color-text-muted);
    padding-left: 1.4rem;
    position: relative;
}

.plan-features li::before {
    content: '\2713';
    position: absolute;
    left: 0;
    color: var(--color-orange);
    font-weight: 700;
}

.maintenance-note {
    text-align: center;
    margin-top: var(--space-3);
    color: var(--color-text-muted);
    font-weight: 600;
}

/* ══ 22. Admin pricing manager ══════════════════════════════ */
.admin-pricing {
    max-width: 1000px;
    margin: 0 auto;
    padding: var(--space-4) var(--space-3);
}

.admin-pricing__head {
    margin-bottom: var(--space-3);
}

.admin-pricing__head h1 {
    font-size: 1.75rem;
    margin: 0;
}

.admin-pricing__head p {
    color: var(--color-text-muted);
    margin: 0.25rem 0 0;
}

.pricing-saved-banner {
    background: rgba(74, 222, 128, 0.12);
    border: 1px solid rgba(74, 222, 128, 0.3);
    color: var(--color-success);
    padding: 0.75rem 1rem;
    border-radius: 8px;
    font-weight: 600;
    margin-bottom: var(--space-3);
}

.pricing-warning-banner {
    background: var(--color-orange);
    color: #fff;
    padding: 0.85rem 1.1rem;
    border-radius: 8px;
    font-weight: 600;
    margin-bottom: var(--space-3);
    line-height: 1.5;
}

.pricing-warning-banner code,
.pricing-empty code {
    background: rgba(0, 0, 0, 0.25);
    padding: 0.1rem 0.4rem;
    border-radius: 4px;
    font-size: 0.875rem;
}

.pricing-group {
    margin-bottom: var(--space-4);
}

.pricing-group__title {
    font-size: 1.125rem;
    margin: 0 0 var(--space-2);
    padding-bottom: 0.4rem;
    border-bottom: 1px solid var(--color-border);
}

.pricing-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.9375rem;
}

.pricing-table th,
.pricing-table td {
    text-align: left;
    padding: 0.65rem 0.6rem;
    border-bottom: 1px solid var(--color-border);
    vertical-align: middle;
}

.pricing-table th {
    font-size: 0.6875rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--color-text-muted);
}

.pricing-stripe-id {
    font-size: 0.8125rem;
    color: var(--color-text-muted);
}

.pricing-stripe-missing {
    color: var(--color-orange-light);
    font-weight: 700;
    font-size: 0.8125rem;
}

.pricing-empty {
    color: var(--color-text-muted);
}

.pricing-toggle {
    border: 1px solid var(--color-border-strong);
    background: rgba(255, 255, 255, 0.04);
    color: var(--color-text-muted);
    font-size: 0.75rem;
    font-weight: 700;
    padding: 0.3rem 0.7rem;
    border-radius: 999px;
    cursor: pointer;
    font-family: inherit;
}

.pricing-toggle--on {
    background: rgba(74, 222, 128, 0.14);
    border-color: rgba(74, 222, 128, 0.4);
    color: var(--color-success);
}

/* Pricing edit form */
.pricing-form {
    max-width: 640px;
}

.pricing-form__subhead {
    font-size: 1.0625rem;
    margin: var(--space-4) 0 var(--space-1);
    padding-bottom: 0.4rem;
    border-bottom: 1px solid var(--color-border);
}

.pricing-form__actions {
    margin-top: var(--space-4);
    display: flex;
    gap: 0.75rem;
}

.pricing-feature-row {
    display: flex;
    gap: 0.5rem;
    align-items: center;
    margin-bottom: 0.5rem;
}

.pricing-feature-row__order {
    width: 70px;
    flex-shrink: 0;
}

.pricing-feature-row input[type="text"] {
    flex-grow: 1;
}

.pricing-add-feature {
    margin-top: 0.5rem;
}

/* ══ 24. Deployment dashboard ═══════════════════════════════ */
.admin-deploy {
    max-width: 1000px;
    margin: 0 auto;
    padding: var(--space-4) var(--space-3);
}

.admin-deploy__head {
    margin-bottom: var(--space-3);
}

.admin-deploy__head h1 {
    font-size: 1.75rem;
    margin: 0;
}

.admin-deploy__head p {
    color: var(--color-text-muted);
    margin: 0.25rem 0 0;
}

.admin-nav__icon {
    width: 14px;
    height: 14px;
    vertical-align: -2px;
    margin-right: 4px;
    fill: none;
    stroke: currentColor;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
}

/* Deploy-type cards */
.deploy-cards {
    display: grid;
    gap: var(--space-3);
    grid-template-columns: 1fr;
    margin-bottom: var(--space-4);
}

@media (min-width: 760px) {
    .deploy-cards { grid-template-columns: repeat(3, 1fr); }
}

.deploy-card {
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 14px;
    padding: var(--space-3);
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.deploy-card__icon {
    width: 44px;
    height: 44px;
    border-radius: 10px;
    background: rgba(232, 101, 10, 0.12);
    display: flex;
    align-items: center;
    justify-content: center;
}

.deploy-card__icon svg {
    width: 24px;
    height: 24px;
    fill: none;
    stroke: var(--color-orange);
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.deploy-card h2 {
    font-size: 1.0625rem;
    margin: 0;
}

.deploy-card p {
    color: var(--color-text-muted);
    font-size: 0.9375rem;
    flex-grow: 1;
    margin: 0;
}

.deploy-card .btn-primary {
    align-self: flex-start;
}

.deploy-client-picker {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.deploy-client-picker .form-control { flex: 1; min-width: 160px; }

/* Sections + tables */
.deploy-section { margin-top: var(--space-4); }

.deploy-section__title {
    font-size: 1.125rem;
    margin: 0 0 var(--space-2);
    padding-bottom: 0.4rem;
    border-bottom: 1px solid var(--color-border);
}

.deploy-section__foot { margin-top: var(--space-2); font-size: 0.875rem; }

.deploy-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.9375rem;
}

.deploy-table th,
.deploy-table td {
    text-align: left;
    padding: 0.6rem 0.6rem;
    border-bottom: 1px solid var(--color-border);
    vertical-align: top;
}

.deploy-table th {
    font-size: 0.6875rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--color-text-muted);
}

.deploy-table__notes { color: var(--color-text-muted); }

.deploy-muted { color: var(--color-text-muted); }

.deploy-badge {
    display: inline-block;
    font-size: 0.625rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    padding: 0.2rem 0.5rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.06);
    border: 1px solid var(--color-border);
    color: var(--color-text-muted);
}

.deploy-badge--fresh { background: rgba(232, 101, 10, 0.14); color: var(--color-orange-light); border-color: rgba(232, 101, 10, 0.3); }
.deploy-badge--redeploy { background: rgba(56, 139, 253, 0.14); color: #79c0ff; border-color: rgba(56, 139, 253, 0.3); }
.deploy-badge--client { background: rgba(13, 148, 136, 0.14); color: var(--color-teal-light, #2dd4bf); border-color: rgba(13, 148, 136, 0.3); }
.deploy-badge--ok { background: rgba(74, 222, 128, 0.12); color: var(--color-success); border-color: rgba(74, 222, 128, 0.3); }
.deploy-badge--fail { background: rgba(248, 113, 113, 0.12); color: var(--color-danger); border-color: rgba(248, 113, 113, 0.3); }

/* Input section — dark card, orange border */
.deploy-inputs {
    background: var(--color-bg-raised);
    border: 1px solid rgba(232, 101, 10, 0.4);
    border-radius: 14px;
    padding: var(--space-3);
    margin-bottom: var(--space-3);
}

.deploy-inputs h2 { font-size: 1.125rem; margin: 0; }

.deploy-inputs__sub {
    color: var(--color-text-muted);
    font-size: 0.875rem;
    margin: 0.25rem 0 var(--space-3);
}

.deploy-prefill {
    display: flex;
    gap: 0.5rem;
    margin-bottom: var(--space-3);
    flex-wrap: wrap;
}

.deploy-prefill .form-control { flex: 1; min-width: 200px; }

.deploy-field { margin-bottom: var(--space-2); }

.deploy-field label {
    display: block;
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--color-text-muted);
    font-weight: 700;
    margin-bottom: 0.3rem;
}

.deploy-field__pw {
    display: flex;
    gap: 0.5rem;
}

.deploy-field__pw .form-control { flex: 1; }

.deploy-client-banner {
    background: rgba(13, 148, 136, 0.12);
    border: 1px solid rgba(13, 148, 136, 0.3);
    color: var(--color-teal-light, #2dd4bf);
    border-radius: 10px;
    padding: 0.7rem 1rem;
    margin-bottom: var(--space-3);
    font-size: 0.9375rem;
}

/* Collapsible steps */
.deploy-step {
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 12px;
    margin-bottom: var(--space-2);
    overflow: hidden;
}

.deploy-step > summary {
    cursor: pointer;
    padding: 0.8rem 1rem;
    font-weight: 700;
    font-size: 0.9375rem;
    list-style-position: inside;
}

.deploy-step > summary:hover { color: var(--color-orange-light); }

.deploy-step > *:not(summary) { margin-left: 1rem; margin-right: 1rem; }

.deploy-step > *:last-child { margin-bottom: 1rem; }

/* Terminal-style command block */
.command-block {
    position: relative;
    background: #0D1117;
    border-left: 4px solid var(--color-orange);
    border-radius: 8px;
    margin: 0.75rem 1rem;
    overflow: hidden;
}

.command-block pre {
    margin: 0;
    padding: 0.9rem 1rem;
    overflow-x: auto;
}

.command-block code {
    font-family: 'Courier New', Courier, monospace;
    font-size: 0.8125rem;
    line-height: 1.6;
    white-space: pre;
}

.cmd-line { display: block; color: #FF7B1E; }
.cmd-line--comment { color: #8b949e; }
.cmd-token { color: #6e7681; }
.cmd-val { color: #ffffff; font-weight: 700; }

.cmd-copy {
    position: absolute;
    top: 0.4rem;
    right: 0.4rem;
    font-family: inherit;
    font-size: 0.6875rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    padding: 0.25rem 0.6rem;
    border-radius: 6px;
    border: 1px solid var(--color-border-strong);
    background: rgba(255, 255, 255, 0.06);
    color: var(--color-text-muted);
    cursor: pointer;
}

.cmd-copy:hover { color: var(--color-text); }
.cmd-copy.is-copied { color: var(--color-success); border-color: rgba(74, 222, 128, 0.4); }

/* Note / warning boxes */
.deploy-note {
    font-size: 0.875rem;
    color: var(--color-text-muted);
    background: rgba(255, 255, 255, 0.03);
    border-left: 3px solid var(--color-border-strong);
    padding: 0.55rem 0.85rem;
    border-radius: 0 6px 6px 0;
    margin: 0.5rem 1rem;
}

.deploy-note--warn {
    color: var(--color-orange-light);
    background: rgba(232, 101, 10, 0.1);
    border-left-color: var(--color-orange);
}

/* History log form */
.deploy-logform {
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 12px;
    margin-bottom: var(--space-3);
    padding: 0 1rem;
}

.deploy-logform > summary {
    cursor: pointer;
    padding: 0.8rem 0;
    font-weight: 700;
}

.deploy-form { padding-bottom: 1rem; max-width: 480px; }

.deploy-check {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin: var(--space-2) 0;
    font-size: 0.9375rem;
}

.deploy-saved-banner {
    background: rgba(74, 222, 128, 0.12);
    border: 1px solid rgba(74, 222, 128, 0.3);
    color: var(--color-success);
    padding: 0.7rem 1rem;
    border-radius: 8px;
    font-weight: 600;
    margin-bottom: var(--space-3);
}

/* ══ 26. Vault — encrypted credential manager ═══════════════ */
.admin-vault {
    max-width: 1000px;
    margin: 0 auto;
    padding: var(--space-4) var(--space-3);
}

/* PIN gate (setup / enter / locked) */
.vault-gate {
    display: flex;
    justify-content: center;
    padding: var(--space-6) var(--space-3);
}

.vault-gate__card {
    width: 100%;
    max-width: 400px;
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 16px;
    padding: var(--space-4);
    text-align: center;
}

.vault-gate__card h1 {
    font-size: 1.5rem;
    margin: 0 0 var(--space-2);
}

.vault-gate__sub {
    color: var(--color-text-muted);
    font-size: 0.9375rem;
    margin: 0 0 var(--space-3);
}

.vault-icon {
    width: 56px;
    height: 56px;
    margin: 0 auto var(--space-3);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
}

.vault-icon svg {
    width: 28px;
    height: 28px;
    fill: none;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.vault-icon--orange { background: rgba(232, 101, 10, 0.14); }
.vault-icon--orange svg { stroke: var(--color-orange); }
.vault-icon--danger { background: rgba(248, 113, 113, 0.14); }
.vault-icon--danger svg { stroke: var(--color-danger); }
.vault-icon--success { background: rgba(74, 222, 128, 0.14); }
.vault-icon--success svg { stroke: var(--color-success); }
.vault-icon--sm { width: 34px; height: 34px; margin: 0; }
.vault-icon--sm svg { width: 18px; height: 18px; }

.vault-pin-form { margin-top: var(--space-2); text-align: left; }

.vault-pw-wrap { display: flex; gap: 0.5rem; }
.vault-pw-wrap .form-control { flex: 1; }

.vault-pw-toggle {
    flex-shrink: 0;
    font-family: inherit;
    font-size: 0.75rem;
    font-weight: 700;
    padding: 0 0.7rem;
    border-radius: 8px;
    border: 1px solid var(--color-border-strong);
    background: rgba(255, 255, 255, 0.05);
    color: var(--color-text-muted);
    cursor: pointer;
}

.vault-warning {
    background: rgba(232, 101, 10, 0.12);
    border: 1px solid rgba(232, 101, 10, 0.35);
    color: var(--color-orange-light);
    font-size: 0.8125rem;
    line-height: 1.5;
    padding: 0.7rem 0.85rem;
    border-radius: 8px;
    margin: var(--space-2) 0 var(--space-3);
}

.vault-digits {
    display: flex;
    gap: 0.6rem;
    justify-content: center;
    margin: var(--space-2) 0 var(--space-3);
}

.vault-digit {
    width: 56px;
    height: 64px;
    text-align: center;
    font-size: 1.75rem;
    font-weight: 700;
    background: var(--color-bg-deep);
    border: 1px solid var(--color-border-strong);
    border-radius: 10px;
    color: var(--color-text);
}

.vault-digit:focus {
    outline: 2px solid var(--color-orange);
    outline-offset: 1px;
}

.vault-locked-timer { font-size: 1.0625rem; }
.vault-locked-timer strong { color: var(--color-danger); font-size: 1.25rem; }

/* Header / session */
.vault-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: var(--space-2);
    flex-wrap: wrap;
    margin-bottom: var(--space-3);
}

.vault-header__title { display: flex; align-items: center; gap: 0.6rem; flex-wrap: wrap; }
.vault-header__title h1 { font-size: 1.625rem; margin: 0; }
.vault-header__actions { display: flex; align-items: center; gap: 0.75rem; flex-wrap: wrap; }

.vault-breadcrumb { width: 100%; font-size: 0.8125rem; color: var(--color-text-muted); margin: 0 0 0.15rem; }

.vault-session {
    font-size: 0.8125rem;
    color: var(--color-text-muted);
    background: rgba(74, 222, 128, 0.1);
    border: 1px solid rgba(74, 222, 128, 0.25);
    color: var(--color-success);
    padding: 0.3rem 0.7rem;
    border-radius: 999px;
}

.vault-toolbar {
    display: flex;
    gap: var(--space-2);
    align-items: flex-start;
    flex-wrap: wrap;
    margin-bottom: var(--space-3);
}

.vault-search { display: flex; gap: 0.5rem; }
.vault-search .form-control { flex: 1; min-width: 200px; max-width: 360px; }

.vault-newvault > summary {
    list-style: none;
    cursor: pointer;
    display: inline-block;
}

.vault-newvault > summary::-webkit-details-marker { display: none; }

.vault-newvault__form {
    display: flex;
    gap: 0.5rem;
    margin-top: 0.5rem;
    flex-wrap: wrap;
}

.vault-newvault__form .form-control { min-width: 260px; }

/* Vault grid (home) */
.vault-grid {
    display: grid;
    gap: var(--space-2);
    grid-template-columns: 1fr;
}

@media (min-width: 700px) {
    .vault-grid { grid-template-columns: repeat(3, 1fr); }
}

.vault-card {
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 12px;
    padding: var(--space-3);
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
}

.vault-card__name { font-size: 1rem; margin: 0; }
.vault-card__count { font-size: 0.8125rem; color: var(--color-text-muted); margin: 0; }
.vault-card__cats { display: flex; flex-wrap: wrap; gap: 0.3rem; flex-grow: 1; }

.vault-cat-badge {
    font-size: 0.625rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    padding: 0.15rem 0.45rem;
    border-radius: 999px;
    background: rgba(13, 148, 136, 0.14);
    color: var(--color-teal-light, #2dd4bf);
    border: 1px solid rgba(13, 148, 136, 0.3);
}

.vault-muted { color: var(--color-text-muted); }
.vault-foot { margin-top: var(--space-3); font-size: 0.875rem; }

/* One-time info banner — e.g. auto-provisioned credentials secured. */
.vault-banner {
    padding: 0.85rem 1rem;
    border-radius: 8px;
    margin-bottom: var(--space-4);
    font-size: 0.9rem;
    line-height: 1.45;
}
.vault-banner--info {
    background: rgba(13, 148, 136, 0.18);
    border: 1px solid rgba(13, 148, 136, 0.45);
    color: var(--color-text);
}
.vault-banner strong { margin-right: 0.25rem; }

/* Expiry overlay */
.vault-expired-overlay {
    position: fixed;
    inset: 0;
    background: rgba(7, 6, 20, 0.88);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 100;
}

/* The [hidden] attribute must win over the display:flex above — otherwise
   the overlay shows on top of a perfectly valid session. */
.vault-expired-overlay[hidden] {
    display: none;
}

.vault-expired-overlay__card {
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border-strong);
    border-radius: 14px;
    padding: var(--space-4);
    max-width: 380px;
    text-align: center;
}

.vault-expired-overlay__card h2 { margin: 0 0 var(--space-1); }
.vault-expired-overlay__card p { color: var(--color-text-muted); margin: 0 0 var(--space-3); }

/* Credential groups + cards */
.vault-catgroup {
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 12px;
    margin-bottom: var(--space-2);
}

.vault-catgroup > summary {
    cursor: pointer;
    padding: 0.8rem 1rem;
    font-weight: 700;
}

.vault-catgroup__count {
    font-size: 0.75rem;
    color: var(--color-text-muted);
    font-weight: 600;
}

.vault-cred-list { padding: 0 1rem 1rem; display: flex; flex-direction: column; gap: 0.75rem; }

.vault-cred {
    background: var(--color-bg-deep);
    border: 1px solid var(--color-border);
    border-left: 3px solid var(--color-teal-light, #2dd4bf);
    border-radius: 10px;
    padding: 0.85rem 1rem;
}

.vault-cred__head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 0.6rem;
}

.vault-cred__label { font-weight: 700; }

.vault-cred__grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.75rem;
}

@media (max-width: 560px) {
    .vault-cred__grid { grid-template-columns: 1fr; }
}

.vault-cred__fieldlabel {
    display: block;
    font-size: 0.625rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--color-text-muted);
    font-weight: 700;
}

.vault-cred__value {
    font-family: 'Courier New', monospace;
    font-size: 0.9375rem;
    word-break: break-all;
}

.vault-cred__revealrow { display: flex; align-items: center; gap: 0.6rem; margin-top: 0.6rem; }

.vault-reveal-bar {
    flex: 1;
    height: 4px;
    background: rgba(255, 255, 255, 0.08);
    border-radius: 999px;
    overflow: hidden;
}

.vault-reveal-bar span {
    display: block;
    height: 100%;
    width: 100%;
    background: var(--color-orange);
}

.vault-reveal-bar.is-counting span {
    animation: vault-countdown 30s linear forwards;
}

@keyframes vault-countdown {
    from { width: 100%; }
    to { width: 0%; }
}

.vault-copy-btn {
    margin-left: 0.4rem;
    font-family: inherit;
    font-size: 0.625rem;
    font-weight: 700;
    text-transform: uppercase;
    padding: 0.1rem 0.4rem;
    border-radius: 5px;
    border: 1px solid var(--color-border-strong);
    background: rgba(255, 255, 255, 0.06);
    color: var(--color-text-muted);
    cursor: pointer;
}

.vault-cred__url { margin: 0.6rem 0 0; font-size: 0.875rem; word-break: break-all; }
.vault-cred__notes { margin-top: 0.5rem; font-size: 0.875rem; }
.vault-cred__notes summary { cursor: pointer; color: var(--color-text-muted); }

.vault-cred__foot {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 0.5rem;
    flex-wrap: wrap;
    margin-top: 0.7rem;
    padding-top: 0.6rem;
    border-top: 1px solid var(--color-border);
}

.vault-cred__actions { display: flex; gap: 0.4rem; }
.vault-cred__delete { display: inline; }

.vault-visible-toggle {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    font-size: 0.8125rem;
    color: var(--color-text-muted);
    cursor: pointer;
}

/* Credential form */
.vault-templates {
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem;
    align-items: center;
    margin-bottom: var(--space-3);
}

.vault-templates__label {
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--color-text-muted);
    font-weight: 700;
}

.vault-tpl-btn {
    font-family: inherit;
    font-size: 0.8125rem;
    padding: 0.3rem 0.7rem;
    border-radius: 999px;
    border: 1px solid var(--color-border-strong);
    background: rgba(255, 255, 255, 0.05);
    color: var(--color-text);
    cursor: pointer;
}

.vault-tpl-btn:hover { border-color: var(--color-orange); color: var(--color-orange-light); }

.vault-cred-form { max-width: 520px; }
.vault-cred-form__actions { display: flex; gap: 0.75rem; margin-top: var(--space-3); }

.vault-form-note {
    font-size: 0.8125rem;
    color: var(--color-text-muted);
    background: rgba(255, 255, 255, 0.03);
    padding: 0.5rem 0.75rem;
    border-radius: 6px;
}

.vault-change-flag {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    font-size: 0.8125rem;
    color: var(--color-text-muted);
    margin: 0.3rem 0;
}

/* Access log */
.vault-log-filters {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-bottom: var(--space-3);
}

.vault-log-table { width: 100%; border-collapse: collapse; font-size: 0.875rem; }

.vault-log-table th,
.vault-log-table td {
    text-align: left;
    padding: 0.55rem 0.55rem;
    border-bottom: 1px solid var(--color-border);
    vertical-align: top;
}

.vault-log-table th {
    font-size: 0.625rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--color-text-muted);
}

.vault-log-note { color: var(--color-text-muted); }

.vault-log-action {
    font-size: 0.6875rem;
    font-weight: 700;
    padding: 0.15rem 0.45rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.06);
    border: 1px solid var(--color-border);
    color: var(--color-text-muted);
    white-space: nowrap;
}

.vault-log-action--pin_verified,
.vault-log-action--pin_set,
.vault-log-action--credential_created { color: var(--color-success); border-color: rgba(74,222,128,0.3); }
.vault-log-action--pin_failed,
.vault-log-action--pin_locked,
.vault-log-action--credential_deleted { color: var(--color-danger); border-color: rgba(248,113,113,0.3); }
.vault-log-action--credential_viewed { color: var(--color-orange-light); border-color: rgba(232,101,10,0.3); }

/* ══ 27. Portal credentials vault (client PIN gate) ═════════ */
.vault-gate__hint {
    font-size: 0.8125rem;
    color: var(--color-text-muted);
    line-height: 1.5;
    margin: var(--space-2) 0 var(--space-3);
}

.pvault-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: var(--space-2);
    flex-wrap: wrap;
}

.pvault-session {
    flex-shrink: 0;
    font-size: 0.8125rem;
    background: rgba(74, 222, 128, 0.1);
    border: 1px solid rgba(74, 222, 128, 0.25);
    color: var(--color-success);
    padding: 0.35rem 0.8rem;
    border-radius: 999px;
    white-space: nowrap;
}

.pvault-session.is-expired {
    background: rgba(248, 113, 113, 0.1);
    border-color: rgba(248, 113, 113, 0.3);
    color: var(--color-danger);
}

.pvault-warning { margin-bottom: var(--space-3); }

.pcred-list {
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
}

.pcred {
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-left: 3px solid var(--color-orange);
    border-radius: 12px;
    padding: var(--space-3);
}

.pcred__head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 0.85rem;
}

.pcred__label { font-size: 1rem; }

.pcred__row {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    flex-wrap: wrap;
    padding: 0.45rem 0;
}

.pcred__fieldlabel {
    flex: 0 0 84px;
    font-size: 0.625rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--color-text-muted);
    font-weight: 700;
}

.pcred__value {
    flex: 1 1 160px;
    font-family: 'Courier New', monospace;
    font-size: 0.9375rem;
    word-break: break-all;
}

.pcred__secret { display: inline-flex; align-items: center; }
.pcred__dots { letter-spacing: 0.15em; }
.pcred__link { color: var(--color-orange-light); }

.pcred__btn {
    flex-shrink: 0;
    font-family: inherit;
    font-size: 0.6875rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    padding: 0.25rem 0.6rem;
    border-radius: 6px;
    border: 1px solid var(--color-border-strong);
    background: rgba(255, 255, 255, 0.05);
    color: var(--color-text-muted);
    cursor: pointer;
}

.pcred__btn:hover { border-color: var(--color-orange); color: var(--color-orange-light); }
.pcred__btn.is-copied { color: var(--color-success); border-color: rgba(74, 222, 128, 0.4); }

.pcred__notes {
    margin: 0.6rem 0 0;
    font-size: 0.875rem;
    color: var(--color-text-muted);
    background: rgba(255, 255, 255, 0.03);
    padding: 0.5rem 0.7rem;
    border-radius: 6px;
}

/* ══ 28. Site changelog — admin + client portal ═════════════ */

/* Change-type badge — colour-coded per type */
.cl-badge {
    display: inline-block;
    font-size: 0.625rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.07em;
    padding: 0.2rem 0.5rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.06);
    border: 1px solid var(--color-border);
    color: var(--color-text-muted);
    white-space: nowrap;
}

.cl-badge--page_added,
.cl-badge--image_optimization {
    background: rgba(20, 184, 166, 0.14);
    color: var(--color-teal-light);
    border-color: rgba(20, 184, 166, 0.32);
}
.cl-badge--page_updated,
.cl-badge--content_update {
    background: rgba(56, 139, 253, 0.14);
    color: #79c0ff;
    border-color: rgba(56, 139, 253, 0.32);
}
.cl-badge--security_patch {
    background: rgba(248, 113, 113, 0.15);
    color: var(--color-danger);
    border-color: rgba(248, 113, 113, 0.36);
}
.cl-badge--dependency_update,
.cl-badge--bug_fix {
    background: rgba(232, 101, 10, 0.14);
    color: var(--color-orange-light);
    border-color: rgba(232, 101, 10, 0.32);
}
.cl-badge--blog_published,
.cl-badge--performance {
    background: rgba(74, 222, 128, 0.13);
    color: var(--color-success);
    border-color: rgba(74, 222, 128, 0.3);
}
.cl-badge--seo_update {
    background: rgba(167, 139, 250, 0.16);
    color: #c4b5fd;
    border-color: rgba(167, 139, 250, 0.34);
}
.cl-badge--deployment {
    background: rgba(148, 163, 184, 0.14);
    color: #cbd5e1;
    border-color: rgba(148, 163, 184, 0.3);
}
/* .cl-badge--other uses the muted base */

/* Admin — list table */
.cl-visible { font-weight: 700; }
.cl-visible--yes { color: var(--color-success); }
.cl-visible--no { color: var(--color-text-muted); }
.cl-delete-form { display: inline; }

/* Admin — add/edit form */
.cl-form-grid {
    display: grid;
    gap: var(--space-3);
    grid-template-columns: 1fr;
}
@media (min-width: 720px) {
    .cl-form-grid { grid-template-columns: 1fr 1fr 1fr; }
}
.cl-form-grid .form-group--full { grid-column: 1 / -1; }

.cl-check {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-weight: 600;
    cursor: pointer;
}
.cl-check input { width: 16px; height: 16px; accent-color: var(--color-orange); }

/* Admin — deploy.sh bulk import */
.cl-import { margin-top: var(--space-3); }
.cl-import code {
    background: rgba(255, 255, 255, 0.07);
    padding: 0.05rem 0.3rem;
    border-radius: 4px;
    font-size: 0.85em;
}
.cl-import-preview {
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid var(--color-border);
    border-radius: 10px;
    padding: 0.85rem 1rem;
    margin: var(--space-2) 0;
}
.cl-import-preview__head { margin: 0 0 0.5rem; font-size: 0.875rem; }
.cl-import-list { list-style: none; margin: 0; padding: 0; }
.cl-import-list li {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.3rem 0;
    font-size: 0.875rem;
}
.cl-import-actions {
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
    margin-top: var(--space-2);
}
.cl-import-note {
    margin: 0.75rem 0 0;
    padding: 0.55rem 0.75rem;
    font-size: 0.8125rem;
    line-height: 1.5;
    color: var(--color-text-muted);
    background: rgba(56, 139, 253, 0.08);
    border: 1px solid rgba(56, 139, 253, 0.22);
    border-radius: 8px;
}
.cl-import-note strong { color: var(--color-text); }

/* Portal — Activity Log */
.cl-portal-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: var(--space-2);
    flex-wrap: wrap;
}

.cl-month-filter {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex-shrink: 0;
}
.cl-month-filter__label {
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--color-text-muted);
    font-weight: 700;
}
.cl-month-filter .form-control { min-width: 170px; }

.cl-month-head {
    font-size: 0.8125rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--color-teal-light);
    margin: var(--space-4) 0 var(--space-2);
}
.cl-month-head:first-of-type { margin-top: var(--space-2); }

.cl-entries {
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
}

.cl-entry {
    display: flex;
    gap: var(--space-3);
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-left: 4px solid var(--color-teal);
    border-radius: 12px;
    padding: var(--space-3);
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
}
.cl-entry:hover {
    border-color: rgba(232, 101, 10, 0.45);
    border-left-color: var(--color-teal);
    box-shadow: 0 6px 24px rgba(232, 101, 10, 0.12);
}

.cl-entry__date {
    flex: 0 0 64px;
    display: flex;
    flex-direction: column;
    line-height: 1.2;
}
.cl-entry__day { font-weight: 700; color: var(--color-orange-light); }
.cl-entry__year { font-size: 0.75rem; color: var(--color-text-muted); }

.cl-entry__body {
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
    min-width: 0;
}
.cl-entry__title { font-size: 1rem; margin: 0; }
.cl-entry__desc {
    margin: 0;
    font-size: 0.9375rem;
    color: var(--color-text-muted);
}
.cl-entry__link {
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--color-orange-light);
    align-self: flex-start;
}

.cl-empty {
    text-align: center;
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 16px;
    padding: var(--space-6) var(--space-3);
}
.cl-empty__icon {
    width: 48px;
    height: 48px;
    margin: 0 auto var(--space-2);
    color: var(--color-teal-light);
}
.cl-empty__icon svg {
    width: 48px;
    height: 48px;
    fill: none;
    stroke: currentColor;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
}
.cl-empty h2 { margin: 0 0 var(--space-1); font-size: 1.25rem; }
.cl-empty p {
    margin: 0 auto var(--space-2);
    max-width: 420px;
    color: var(--color-text-muted);
}

/* Portal — new-activity dot on the sidebar nav item */
.portal-nav__dot {
    margin-left: auto;
    width: 9px;
    height: 9px;
    border-radius: 50%;
    background: var(--color-success);
    flex-shrink: 0;
}

/* ══ 29. Phase 5a — uptime, GBP, keywords, conversions ══════ */

.admin-card__head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: var(--space-2);
    flex-wrap: wrap;
    margin-bottom: var(--space-2);
}
.admin-card__head .admin-card__title { margin-bottom: 0; }

/* Status dot */
.dot {
    display: inline-block;
    width: 9px;
    height: 9px;
    border-radius: 50%;
    background: var(--color-text-muted);
    flex-shrink: 0;
}
.dot--up { background: var(--color-success); }
.dot--down { background: var(--color-danger); }
.dot--unknown { background: var(--color-text-muted); }

.mon-status {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    font-size: 0.875rem;
    font-weight: 600;
}
.mon-status--lg { font-size: 1rem; }

/* Uptime widget (admin client detail) */
.mon-widget {
    display: flex;
    align-items: center;
    gap: var(--space-4);
    flex-wrap: wrap;
}
.mon-widget__stat { display: flex; flex-direction: column; }
.mon-widget__stat strong { font-size: 1.25rem; }

/* Tool links (admin client detail) */
.mon-toollinks { display: flex; flex-wrap: wrap; gap: 0.5rem; }
.mon-toollink {
    padding: 0.5rem 0.9rem;
    border-radius: 8px;
    border: 1px solid var(--color-border-strong);
    background: rgba(255, 255, 255, 0.04);
    font-weight: 600;
    font-size: 0.875rem;
}
.mon-toollink:hover { border-color: var(--color-orange); color: var(--color-orange-light); }

/* Uptime % colour bands */
.uptime-good { color: var(--color-success); }
.uptime-warn { color: var(--color-orange-light); }
.uptime-bad  { color: var(--color-danger); }

/* Admin response-time chart */
.mon-chart {
    display: flex;
    align-items: flex-end;
    gap: 2px;
    height: 140px;
    margin-top: var(--space-2);
}
.mon-chart__col { flex: 1; height: 100%; display: flex; align-items: flex-end; }
.mon-chart__bar {
    width: 100%;
    min-height: 2px;
    height: 0;
    background: var(--color-orange);
    border-radius: 2px 2px 0 0;
}
.mon-chart__cap { margin-top: 0.5rem; font-size: 0.8125rem; }

/* Portal 6-month bar chart */
.mon-barchart {
    display: flex;
    align-items: flex-end;
    gap: var(--space-2);
    margin-top: var(--space-2);
}
.mon-barchart__col {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.35rem;
}
.mon-barchart__count { font-size: 0.8125rem; font-weight: 700; }
.mon-barchart__track {
    height: 130px;
    width: 100%;
    display: flex;
    align-items: flex-end;
    justify-content: center;
}
.mon-barchart__bar {
    width: 60%;
    max-width: 42px;
    min-height: 3px;
    height: 0;
    background: var(--color-orange);
    border-radius: 5px 5px 0 0;
}
.mon-barchart__label {
    font-size: 0.75rem;
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

/* Portal response-time sparkline */
.mon-spark {
    display: inline-flex;
    align-items: flex-end;
    gap: 1px;
    height: 34px;
}
.mon-spark__bar {
    width: 4px;
    min-height: 2px;
    height: 0;
    background: var(--color-teal-light);
    border-radius: 2px 2px 0 0;
}

/* Uptime row (portal project page) */
.uptime-row {
    display: flex;
    align-items: center;
    gap: var(--space-4);
    flex-wrap: wrap;
    margin-bottom: var(--space-2);
}
.uptime-row__stat { font-size: 0.9375rem; color: var(--color-text-muted); }
.uptime-row__stat strong { font-size: 1.125rem; color: var(--color-text); margin-right: 0.25rem; }
.uptime-spark-cap { margin-top: 0.4rem; }

/* Keyword rank badge */
.rank {
    display: inline-block;
    font-weight: 700;
    font-size: 0.9375rem;
    padding: 0.15rem 0.55rem;
    border-radius: 8px;
    border: 1px solid var(--color-border);
}
.rank--top    { color: var(--color-success); border-color: rgba(74,222,128,0.35); background: rgba(74,222,128,0.1); }
.rank--page1  { color: var(--color-teal-light); border-color: rgba(20,184,166,0.35); background: rgba(20,184,166,0.1); }
.rank--page2  { color: var(--color-orange-light); border-color: rgba(232,101,10,0.35); background: rgba(232,101,10,0.1); }
.rank--low    { color: var(--color-danger); border-color: rgba(248,113,113,0.35); background: rgba(248,113,113,0.1); }
.rank--muted  { color: var(--color-text-muted); }

/* Keyword trend indicator */
.trend { font-size: 0.8125rem; font-weight: 700; white-space: nowrap; }
.trend--up { color: var(--color-success); }
.trend--down { color: var(--color-danger); }
.trend--new { color: var(--color-teal-light); }
.trend--same, .trend--muted { color: var(--color-text-muted); }

/* Month-over-month delta */
.delta { font-size: 0.8125rem; font-weight: 600; }
.delta--up { color: var(--color-success); }
.delta--down { color: var(--color-danger); }
.delta--same { color: var(--color-text-muted); }

/* 3-up stat grid (portal SEO conversions) */
@media (min-width: 760px) {
    .stat-grid--3 { grid-template-columns: repeat(3, 1fr); }
}

/* Portal SEO page */
.seo-subnote { margin-top: -0.35rem; margin-bottom: var(--space-3); }
.seo-rankmeta { flex-direction: column; align-items: flex-end; gap: 0.25rem; }
.seo-subhead { font-size: 1rem; margin: var(--space-3) 0 var(--space-1); }
.seo-insight {
    margin: var(--space-2) 0 0;
    padding: 0.6rem 0.85rem;
    font-size: 0.875rem;
    background: rgba(20, 184, 166, 0.1);
    border: 1px solid rgba(20, 184, 166, 0.25);
    border-radius: 8px;
    color: var(--color-teal-light);
}

/* Tracker snippet generator */
.mon-snippet {
    font-family: 'Courier New', monospace;
    font-size: 0.8125rem;
    margin-bottom: var(--space-2);
}
.mon-steps { margin: 0; padding-left: 1.2rem; line-height: 1.8; }
.mon-steps code {
    background: rgba(255, 255, 255, 0.07);
    padding: 0.05rem 0.3rem;
    border-radius: 4px;
    font-size: 0.85em;
}

/* ══ 30. Phase 5b — reports, NPS, blog, chatbot ═════════════ */

.stat-card__value--sm { font-size: 1.1rem; }

/* Report / blog status badges */
.rep-badge {
    display: inline-block;
    font-size: 0.625rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.07em;
    padding: 0.2rem 0.5rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.06);
    border: 1px solid var(--color-border);
    color: var(--color-text-muted);
    white-space: nowrap;
}
.rep-badge--sent,
.rep-badge--approved,
.rep-badge--published {
    background: rgba(74, 222, 128, 0.13);
    color: var(--color-success);
    border-color: rgba(74, 222, 128, 0.3);
}
.rep-badge--failed,
.rep-badge--rejected {
    background: rgba(248, 113, 113, 0.13);
    color: var(--color-danger);
    border-color: rgba(248, 113, 113, 0.32);
}
.rep-badge--ready,
.rep-badge--review {
    background: rgba(232, 101, 10, 0.13);
    color: var(--color-orange-light);
    border-color: rgba(232, 101, 10, 0.3);
}

/* NPS score chips */
.nps-score {
    display: inline-block;
    font-weight: 700;
    padding: 0.1rem 0.5rem;
    border-radius: 7px;
}
.nps-score--promoter { background: rgba(74,222,128,0.14); color: var(--color-success); }
.nps-score--passive { background: rgba(232,101,10,0.14); color: var(--color-orange-light); }
.nps-score--detractor { background: rgba(248,113,113,0.14); color: var(--color-danger); }

/* Freshness score */
.fresh-score {
    display: inline-block;
    font-weight: 700;
    min-width: 38px;
    text-align: center;
    padding: 0.15rem 0.45rem;
    border-radius: 7px;
}
.fresh-score--high { background: rgba(248,113,113,0.16); color: var(--color-danger); }
.fresh-score--medium { background: rgba(232,101,10,0.16); color: var(--color-orange-light); }
.fresh-score--good { background: rgba(74,222,128,0.14); color: var(--color-success); }

/* Blog review */
.blog-content-area { font-family: 'Courier New', monospace; font-size: 0.85rem; }
.blog-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem;
    margin: var(--space-3) 0;
}
.blog-preview {
    background: var(--color-bg-deep);
    border: 1px solid var(--color-border);
    border-radius: 10px;
    padding: var(--space-3);
}
.blog-preview h2 { font-size: 1.25rem; margin: 1rem 0 0.4rem; }
.blog-preview h3 { font-size: 1.05rem; margin: 0.85rem 0 0.3rem; }
.blog-preview p, .blog-preview li { color: var(--color-text); line-height: 1.6; }
.blog-preview ul { padding-left: 1.3rem; }

/* Chatbot conversation transcript */
.chat-transcript { display: flex; flex-direction: column; gap: 0.75rem; }
.chat-msg { display: flex; flex-direction: column; max-width: 80%; }
.chat-msg--user { align-self: flex-end; align-items: flex-end; }
.chat-msg--assistant { align-self: flex-start; }
.chat-msg__role {
    font-size: 0.625rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--color-text-muted);
    margin-bottom: 0.2rem;
}
.chat-msg__bubble {
    padding: 0.6rem 0.85rem;
    border-radius: 12px;
    font-size: 0.9375rem;
    line-height: 1.5;
    white-space: pre-wrap;
}
.chat-msg--user .chat-msg__bubble {
    background: rgba(232, 101, 10, 0.16);
    color: var(--color-orange-light);
}
.chat-msg--assistant .chat-msg__bubble {
    background: var(--color-bg-deep);
    border: 1px solid var(--color-border);
}

/* NPS public landing page */
.nps-body {
    background: var(--color-bg-deep);
    color: var(--color-text);
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--space-4);
    margin: 0;
}
.nps-card {
    width: 100%;
    max-width: 460px;
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 16px;
    padding: var(--space-5);
    text-align: center;
}
.nps-card h1 { font-size: 1.5rem; margin: 0 0 var(--space-2); }
.nps-muted { color: var(--color-text-muted); }
.nps-icon {
    font-size: 2.5rem;
    color: var(--color-orange);
    margin-bottom: var(--space-1);
}
.nps-form { margin-top: var(--space-3); text-align: left; }
.nps-form .form-control { margin-bottom: var(--space-2); }

/* ══ 31. Phase 6a — SSH terminal + TOTP ═════════════════════ */

.is-hidden { display: none !important; }

/* TOTP setup / verify */
.vault-gate__card--wide { max-width: 460px; }

/* Step blocks on the combined PIN + TOTP unlock page */
.vault-step { margin-bottom: var(--space-4); text-align: left; }
.vault-step__label {
    font-size: 0.78rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.07em;
    color: var(--color-text-muted, #666);
    margin: 0 0 0.35rem;
    text-align: center;
}
.vault-step__sub {
    font-size: 0.85rem;
    color: var(--color-text-muted, #666);
    margin: 0 0 0.6rem;
    text-align: center;
}
.vault-digits--6 { gap: 0.4rem; }
.vault-digits--6 .vault-digit { width: 2.4rem; }

/* Branded TOTP setup heading */
.vault-totp-title {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.55rem;
    font-size: 1.35rem;
    margin: 0 0 0.4rem;
}
.vault-totp-title__icon { display: inline-block; }

/* Manual-entry block on the TOTP setup page */
.totp-manual-details {
    margin: 0 0 var(--space-3);
    font-size: 0.85rem;
    display: grid;
    grid-template-columns: max-content 1fr;
    gap: 0.25rem 0.75rem;
    text-align: left;
}
.totp-manual-details dt {
    font-weight: 600;
    color: var(--color-text-muted, #666);
}
.totp-manual-details dd { margin: 0; word-break: break-all; }

/* Recovery codes — show-once page + settings regen block */
.recovery-codes {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 0.5rem;
    margin: var(--space-3) 0;
}
@media (min-width: 480px) {
    .recovery-codes { grid-template-columns: repeat(4, 1fr); }
}
.recovery-codes__code {
    background: var(--color-bg-deep);
    color: var(--color-text);
    border: 1px solid var(--color-border);
    border-radius: 6px;
    padding: 0.55rem 0.6rem;
    text-align: center;
    font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
    font-size: 0.95rem;
    letter-spacing: 0.08em;
    word-break: break-all;
}
.recovery-codes__form { margin-top: var(--space-3); }
.recovery-codes__actions {
    display: flex;
    gap: 0.6rem;
    justify-content: center;
    margin-bottom: var(--space-3);
    flex-wrap: wrap;
}
.recovery-codes__ack {
    display: flex;
    align-items: center;
    gap: 0.55rem;
    margin: 0 0 var(--space-3);
    font-size: 0.9rem;
    cursor: pointer;
}
.recovery-codes__ack input { width: 1.05rem; height: 1.05rem; }

/* Settings page cards — admin dark theme */
.vault-settings-card {
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 12px;
    padding: 1.1rem 1.3rem;
    margin-bottom: var(--space-3);
    color: var(--color-text);
}
.vault-settings-card h2 {
    margin: 0 0 0.4rem;
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    color: var(--color-text-muted);
    font-weight: 700;
}
.vault-settings-card__sub {
    font-size: 0.9rem;
    color: var(--color-text-muted);
    margin: 0 0 0.6rem;
}
.vault-settings-form { margin-top: var(--space-3); }

/* Recovery code text input — wider letter-spacing for readability */
.recovery-input {
    font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

/* One-time upgrade notice on the unlock page */
.vault-gate__hint--upgrade {
    margin-top: var(--space-3);
    padding: 0.7rem 0.9rem;
    background: rgba(232, 101, 10, 0.10);
    border: 1px solid rgba(232, 101, 10, 0.3);
    border-radius: 6px;
    color: var(--color-text);
    font-size: 0.82rem;
}

.totp-qr {
    display: block;
    width: 200px;
    height: 200px;
    margin: var(--space-2) auto;
    background: #ffffff;
    padding: 8px;
    border-radius: 10px;
}
.totp-manual {
    font-size: 0.8125rem;
    color: var(--color-text-muted);
    margin: var(--space-2) 0 0.25rem;
}
.totp-secret {
    display: block;
    font-family: 'Courier New', monospace;
    font-size: 0.875rem;
    letter-spacing: 0.06em;
    background: var(--color-bg-deep);
    border: 1px solid var(--color-border);
    border-radius: 8px;
    padding: 0.5rem;
    margin-bottom: var(--space-3);
    word-break: break-all;
}
.vault-fieldset-label {
    display: block;
    font-size: 0.8125rem;
    font-weight: 700;
    color: var(--color-text-muted);
    margin-bottom: 0.3rem;
}

/* SSH fields in the credential form */
.vault-ssh-fields {
    display: none;
    margin: var(--space-2) 0;
    padding: var(--space-3);
    border: 1px solid rgba(13, 148, 136, 0.3);
    border-radius: 10px;
    background: rgba(13, 148, 136, 0.05);
}
.vault-ssh-fields.is-visible { display: block; }
.vault-connect-btn {
    background: var(--color-teal) !important;
    border-color: var(--color-teal) !important;
}

/* ── SSH terminal — full-screen page ── */
.term-body {
    margin: 0;
    height: 100vh;
    overflow: hidden;
    background: #070614;
    color: #e8e8e8;
}
.term-wrap { display: flex; flex-direction: column; height: 100vh; }

.term-bar {
    flex-shrink: 0;
    height: 46px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-2);
    padding: 0 var(--space-3);
    background: #0F172A;
    border-bottom: 1px solid var(--color-border);
}
.term-bar__seg { display: flex; align-items: center; gap: 0.6rem; }
.term-bar__seg--center { flex: 1; justify-content: center; }
.term-bar__hint { color: var(--color-text-muted); font-size: 0.8125rem; }
.term-bar__clock {
    width: 18px; height: 18px; fill: none;
    stroke: var(--color-orange); stroke-width: 2;
    stroke-linecap: round; stroke-linejoin: round;
}
#session-timer {
    font-family: 'Courier New', monospace;
    font-weight: 700;
    color: var(--color-orange-light);
}
.term-timer--low { color: var(--color-danger) !important; }

.term-btn {
    font-family: inherit;
    font-size: 0.8125rem;
    font-weight: 700;
    padding: 0.35rem 0.8rem;
    border-radius: 7px;
    border: 1px solid var(--color-border-strong);
    background: rgba(255, 255, 255, 0.06);
    color: var(--color-text);
    cursor: pointer;
}
.term-btn--teal { border-color: rgba(13,148,136,0.5); color: var(--color-teal-light); }
.term-btn--danger { border-color: rgba(248,113,113,0.5); color: var(--color-danger); }

.term-main { flex: 1; display: flex; min-height: 0; }
.term-screen { flex: 1; min-width: 0; padding: 6px 8px; overflow: hidden; }

.term-cmds {
    width: 290px;
    flex-shrink: 0;
    overflow-y: auto;
    padding: var(--space-2);
    background: #0B1120;
    border-left: 1px solid var(--color-border);
}
.term-cmds.is-hidden { display: none; }
.term-cmds__heading {
    font-size: 0.6875rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--color-orange-light);
    margin: var(--space-2) 0 0.4rem;
}
.term-cmds__empty { color: var(--color-text-muted); font-size: 0.875rem; }

.term-cmd {
    background: #0F172A;
    border: 1px solid var(--color-border);
    border-radius: 8px;
    padding: 0.55rem 0.65rem;
    margin-bottom: 0.5rem;
}
.term-cmd__label { font-weight: 700; font-size: 0.875rem; }
.term-cmd__danger { color: var(--color-danger); }
.term-cmd__text {
    display: block;
    font-family: 'Courier New', monospace;
    font-size: 0.75rem;
    color: var(--color-text-muted);
    word-break: break-all;
    margin: 0.2rem 0 0.4rem;
}
.term-cmd__run {
    font-family: inherit;
    font-size: 0.6875rem;
    font-weight: 700;
    text-transform: uppercase;
    padding: 0.25rem 0.7rem;
    border-radius: 6px;
    border: 1px solid rgba(13, 148, 136, 0.5);
    background: rgba(13, 148, 136, 0.14);
    color: var(--color-teal-light);
    cursor: pointer;
}
.term-cmd__run--confirm {
    border-color: rgba(232, 101, 10, 0.5);
    background: rgba(232, 101, 10, 0.14);
    color: var(--color-orange-light);
}

/* ── 31b. Legacy-client onboarding board ───────────────────── */
.onboarding-warn {
    padding: 0.9rem 1.1rem;
    background: rgba(232, 101, 10, 0.12);
    border: 1px solid rgba(232, 101, 10, 0.35);
    border-radius: 8px;
    color: var(--color-text);
    margin-bottom: var(--space-4);
    font-size: 0.95rem;
    line-height: 1.5;
}
.onboarding-warn strong { display: block; margin-bottom: 0.2rem; }

.onboarding-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: var(--space-4);
}

.onboarding-card {
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-left: 5px solid #999;
    border-radius: 12px;
    padding: 1.1rem 1.2rem;
    display: flex;
    flex-direction: column;
    gap: 0.7rem;
    color: var(--color-text);
}
.onboarding-card--teal { border-left-color: #0d9488; }
.onboarding-card--orange { border-left-color: #E8650A; }
.onboarding-card--red { border-left-color: #c0392b; }

.onboarding-card__head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 0.75rem;
}
.onboarding-card__title { margin: 0; font-size: 1.05rem; color: var(--color-text); }
.onboarding-card__sub { margin: 0.25rem 0 0; font-size: 0.8rem; }
.onboarding-card__progress-num {
    font-size: 1.4rem;
    font-weight: 600;
    color: var(--color-text-muted);
}

.onboarding-badge {
    display: inline-block;
    padding: 0.15rem 0.5rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.08);
    color: var(--color-text-muted);
    font-size: 0.7rem;
    margin-right: 0.3rem;
}
.onboarding-badge--tester {
    background: rgba(232, 101, 10, 0.18);
    color: #FFB680;
    font-weight: 600;
}

.onboarding-card__ip {
    margin: 0;
    font-size: 0.85rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}
.onboarding-card__ip code {
    background: var(--color-bg-deep);
    color: var(--color-text);
    padding: 0.15rem 0.45rem;
    border-radius: 4px;
    border: 1px solid var(--color-border);
}

.onboarding-checks {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 0.3rem;
    font-size: 0.9rem;
}
.onboarding-checks li {
    display: flex;
    align-items: center;
    gap: 0.55rem;
    color: var(--color-text-muted);
    flex-wrap: wrap;
}
.onboarding-checks li.is-done { color: var(--color-text); }
.onboarding-checks__icon {
    display: inline-flex;
    width: 1.1rem;
    height: 1.1rem;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.06);
    color: var(--color-text-muted);
    font-size: 0.75rem;
    font-weight: 700;
    flex-shrink: 0;
}
.onboarding-checks li.is-done .onboarding-checks__icon {
    background: #0d9488;
    color: #fff;
}
.onboarding-checks__detail {
    width: 100%;
    margin-left: 1.65rem;
    font-size: 0.75rem;
    color: var(--color-text-muted);
}

.onboarding-card__actions {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
    margin-top: 0.4rem;
}

.onboarding-copy {
    border: 1px solid var(--color-border);
    background: rgba(255, 255, 255, 0.06);
    color: var(--color-text);
    border-radius: 4px;
    padding: 0.15rem 0.55rem;
    font-size: 0.75rem;
    cursor: pointer;
}
.onboarding-copy:hover { background: rgba(255, 255, 255, 0.12); }

/* Modal */
.onboarding-modal {
    position: fixed;
    inset: 0;
    background: rgba(7, 6, 20, 0.7);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 200;
    padding: 1rem;
}
.onboarding-modal[hidden] { display: none; }
.onboarding-modal__card {
    background: var(--color-bg-raised);
    color: var(--color-text);
    border: 1px solid var(--color-border);
    border-radius: 12px;
    max-width: 640px;
    width: 100%;
    padding: 1.6rem 1.8rem;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.5);
}
.onboarding-modal__head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 1rem;
}
.onboarding-modal__head h2 { margin: 0; font-size: 1.15rem; color: var(--color-text); }
.onboarding-modal__close {
    border: 0;
    background: none;
    font-size: 1.6rem;
    line-height: 1;
    cursor: pointer;
    padding: 0 0.5rem;
    color: var(--color-text-muted);
}
.onboarding-modal__close:hover { color: var(--color-text); }
.onboarding-cmd {
    background: #1A1A1A;
    color: #f5f5f5;
    padding: 0.7rem 0.9rem;
    border-radius: 6px;
    font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
    font-size: 0.85rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    margin: 0.4rem 0 0.9rem;
    overflow-x: auto;
}
.onboarding-cmd code {
    background: transparent;
    color: inherit;
    padding: 0;
    flex: 1;
    word-break: break-all;
}
.onboarding-cmd .onboarding-copy {
    background: #333;
    color: #fff;
    border-color: #444;
    flex-shrink: 0;
}
.onboarding-cmd .onboarding-copy:hover { background: #444; }
.onboarding-modal__hint {
    font-size: 0.85rem;
    color: var(--color-text-muted, #666);
    margin-bottom: 0;
}

/* ── 31c. Droplet dashboard ─────────────────────────────────── */
.droplet-banner {
    padding: 0.85rem 1rem;
    border-radius: 8px;
    margin-bottom: var(--space-4);
    font-size: 0.9rem;
    line-height: 1.5;
    color: var(--color-text);
}
.droplet-banner--info {
    background: rgba(13, 148, 136, 0.18);
    border: 1px solid rgba(13, 148, 136, 0.45);
}
.droplet-banner--warn,
.droplet-banner--warning {
    background: rgba(232, 101, 10, 0.18);
    border: 1px solid rgba(232, 101, 10, 0.45);
}
.droplet-banner--error {
    background: rgba(192, 57, 43, 0.20);
    border: 1px solid rgba(192, 57, 43, 0.5);
}
.droplet-banner--success {
    background: rgba(16, 185, 129, 0.18);
    border: 1px solid rgba(16, 185, 129, 0.4);
}

.droplet-stats {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: var(--space-3);
    margin-bottom: var(--space-4);
}
.droplet-stat {
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-left: 4px solid #999;
    border-radius: 12px;
    padding: 0.9rem 1rem;
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
    color: var(--color-text);
}
.droplet-stat--green { border-left-color: #10B981; }
.droplet-stat--orange { border-left-color: #E8650A; }
.droplet-stat__num {
    font-size: 1.7rem;
    font-weight: 700;
    line-height: 1;
}
.droplet-stat__num--sm {
    font-size: 1rem;
    font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
}
.droplet-stat__label {
    font-size: 0.78rem;
    color: var(--color-text-muted, #666);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.droplet-table-wrap {
    overflow-x: auto;
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 12px;
    color: var(--color-text);
}
.droplet-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.88rem;
    color: var(--color-text);
}
.droplet-table thead th {
    text-align: left;
    padding: 0.6rem 0.75rem;
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--color-text-muted);
    border-bottom: 1px solid var(--color-border);
}
.droplet-table tbody td {
    padding: 0.6rem 0.75rem;
    border-bottom: 1px solid var(--color-border);
    vertical-align: middle;
}
.droplet-table tbody tr:last-child td { border-bottom: none; }

.droplet-row { border-left: 4px solid #999; }
.droplet-row--green > td:first-child { box-shadow: inset 4px 0 0 #10B981; }
.droplet-row--orange > td:first-child { box-shadow: inset 4px 0 0 #E8650A; }
.droplet-row--red > td:first-child { box-shadow: inset 4px 0 0 #EF4444; }

.droplet-dot {
    display: inline-block;
    width: 0.6rem;
    height: 0.6rem;
    border-radius: 50%;
    background: #999;
}
.droplet-dot--green { background: #10B981; }
.droplet-dot--orange { background: #E8650A; }
.droplet-dot--red { background: #EF4444; }
.droplet-table__status { width: 1.5rem; text-align: center; padding-right: 0; }
.droplet-table__actions {
    white-space: nowrap;
    text-align: right;
    /* Sticky to the right edge so actions are always visible even
       if a wide row forces horizontal scroll. */
    position: sticky;
    right: 0;
    background: var(--color-bg-raised);
    z-index: 1;
    box-shadow: -8px 0 12px -6px rgba(0, 0, 0, 0.5);
}
.droplet-table__actions .btn-sm {
    margin-right: 0.2rem;
    padding: 0.2rem 0.55rem;
    font-size: 0.78rem;
}
.droplet-table__actions .btn-sm:last-child { margin-right: 0; }
.droplet-inline-form { display: inline-block; }

.droplet-name { font-weight: 600; }
.droplet-meta {
    font-size: 0.72rem;
    color: var(--color-text-muted);
    margin-top: 2px;
    white-space: nowrap;
}

/* Linked-website cell — limit width AND wrap on whole words instead
   of per-word so 'Food Trucks of San Antonio' doesn't stack 4 lines
   tall. Reserves enough room that the actions column stays visible. */
.droplet-linked {
    max-width: 220px;
    overflow-wrap: break-word;
    word-break: normal;
    line-height: 1.3;
}
.droplet-linked a {
    color: var(--color-orange);
    text-decoration: none;
    font-weight: 600;
}
.droplet-linked a:hover { text-decoration: underline; }
.droplet-linked .droplet-muted {
    font-size: 0.72rem;
    margin-top: 2px;
}
.droplet-linked .droplet-link-btn {
    margin-top: 6px;
    padding: 0.2rem 0.55rem;
    font-size: 0.75rem;
}
.droplet-ip {
    font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
    font-size: 0.83rem;
    white-space: nowrap;
}
.droplet-ip code {
    background: var(--color-bg-deep);
    color: var(--color-text);
    border: 1px solid var(--color-border);
    padding: 0.1rem 0.4rem;
    border-radius: 4px;
    margin-right: 0.3rem;
}
.droplet-copy-btn {
    border: 1px solid var(--color-border);
    background: rgba(255, 255, 255, 0.06);
    color: var(--color-text);
    border-radius: 4px;
    padding: 0.05rem 0.4rem;
    font-size: 0.7rem;
    cursor: pointer;
}
.droplet-copy-btn:hover { background: rgba(255, 255, 255, 0.12); }

.droplet-tags { font-size: 0.75rem; }
.droplet-tag {
    display: inline-block;
    background: rgba(255, 255, 255, 0.08);
    color: var(--color-text-muted);
    padding: 0.1rem 0.45rem;
    border-radius: 999px;
    margin-right: 0.2rem;
}
.droplet-muted { color: var(--color-text-muted); }

.droplet-inline-form { display: inline-block; margin: 0; }
.droplet-btn-on { color: #6EE7B7; border-color: rgba(16, 185, 129, 0.5); }
.droplet-btn-off { color: #FFB680; border-color: rgba(232, 101, 10, 0.5); }
.droplet-destroy-btn { color: #FCA5A5; border-color: rgba(239, 68, 68, 0.5); }
.droplet-destroy-btn.is-disabled,
.droplet-destroy-btn[disabled] {
    color: var(--color-text-muted);
    border-color: var(--color-border);
    cursor: not-allowed;
}

/* Form */
.droplet-form { max-width: 720px; }
.droplet-form__group { margin-bottom: var(--space-4); }
.droplet-form__group > label,
.droplet-form__group > legend {
    display: block;
    font-weight: 600;
    margin-bottom: 0.35rem;
    font-size: 0.92rem;
}
.droplet-form__hint {
    margin: 0.35rem 0 0;
    font-size: 0.82rem;
    color: var(--color-text-muted);
}
.droplet-form__actions {
    display: flex;
    gap: 0.6rem;
    align-items: center;
    margin-top: var(--space-3);
}
.droplet-readonly {
    background: var(--color-bg-deep);
    color: var(--color-text);
    border: 1px solid var(--color-border);
    border-radius: 6px;
    padding: 0.55rem 0.75rem;
    font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
    font-size: 0.88rem;
}
.droplet-readonly--big { font-size: 1.1rem; font-weight: 600; }

.droplet-sizes {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0.55rem;
    border: none;
    padding: 0;
    margin: 0;
}
@media (min-width: 640px) {
    .droplet-sizes { grid-template-columns: 1fr 1fr; }
}
.droplet-size { position: relative; cursor: pointer; margin: 0; }
.droplet-size input { position: absolute; opacity: 0; pointer-events: none; }
.droplet-size__card {
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
    padding: 0.75rem 0.9rem;
    border: 2px solid var(--color-border);
    border-radius: 8px;
    background: var(--color-bg-raised);
    color: var(--color-text);
    transition: border-color 0.15s, background 0.15s;
}
.droplet-size input:checked + .droplet-size__card {
    border-color: #E8650A;
    background: rgba(232, 101, 10, 0.12);
}
.droplet-size__slug {
    font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
    font-size: 0.85rem;
    font-weight: 600;
}
.droplet-size__specs {
    font-size: 0.8rem;
    color: var(--color-text-muted);
}
.droplet-size__price { font-weight: 700; }

/* Destroy modal-style card */
.droplet-destroy-card {
    max-width: 560px;
    background: var(--color-bg-raised);
    color: var(--color-text);
    border: 1px solid var(--color-border);
    border-left: 4px solid #EF4444;
    border-radius: 12px;
    padding: 1.5rem;
}
.droplet-destroy-card__warn { color: #FCA5A5; font-size: 0.95rem; }
.droplet-destroy-card__name {
    font-size: 1.5rem;
    font-weight: 700;
    color: #FCA5A5;
    font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
    margin: 0.6rem 0;
}
.droplet-destroy-card__meta {
    list-style: none;
    padding: 0;
    margin: 0 0 var(--space-3);
    font-size: 0.88rem;
}
.droplet-destroy-card__meta li { margin: 0.2rem 0; }
.droplet-destroy-form input[type="text"] { margin: 0.4rem 0; }
.droplet-destroy-confirm-btn { background: #c0392b; border-color: #c0392b; color: #fff; }
.droplet-destroy-confirm-btn[disabled],
.droplet-destroy-confirm-btn:disabled {
    background: rgba(255, 255, 255, 0.06);
    border-color: var(--color-border);
    color: var(--color-text-muted);
    cursor: not-allowed;
}
.droplet-destroy-confirm-btn--armed:hover { background: #a83224; }

/* Metrics page */
.droplet-metric-card {
    background: var(--color-bg-raised);
    color: var(--color-text);
    border: 1px solid var(--color-border);
    border-radius: 12px;
    padding: 1.1rem 1.3rem;
    margin-bottom: var(--space-3);
}
.droplet-metric-card h2 {
    margin: 0 0 0.6rem;
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    color: var(--color-text-muted);
    font-weight: 700;
}
.droplet-meta-list {
    list-style: none; padding: 0; margin: 0;
    display: grid;
    grid-template-columns: 1fr;
    gap: 0.35rem;
    font-size: 0.9rem;
    color: var(--color-text);
}
@media (min-width: 640px) {
    .droplet-meta-list { grid-template-columns: 1fr 1fr; }
}
.droplet-meta-list strong {
    display: inline-block;
    min-width: 8rem;
    color: var(--color-text-muted);
    font-weight: 500;
}
.droplet-meta-list code {
    background: var(--color-bg-deep);
    border: 1px solid var(--color-border);
    color: var(--color-text);
    padding: 0.1rem 0.4rem;
    border-radius: 4px;
}
.droplet-cmd { margin: 0.6rem 0; }
.droplet-cmd summary {
    cursor: pointer;
    font-weight: 600;
    padding: 0.3rem 0;
    color: var(--color-text);
}
.droplet-cmd pre {
    background: var(--color-bg-deep);
    color: var(--color-text);
    border: 1px solid var(--color-border);
    padding: 0.75rem 0.9rem;
    border-radius: 6px;
    font-size: 0.8rem;
    overflow-x: auto;
    margin: 0.3rem 0 0;
}

/* ── 31d. Vulnerability scans ─────────────────────────────── */
.scan-badge {
    display: inline-block;
    padding: 0.15rem 0.5rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.08);
    color: var(--color-text-muted);
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}
.scan-badge--scheduled {
    background: rgba(13, 148, 136, 0.18);
    color: #5EEAD4;
}
.scan-badge--manual {
    background: rgba(232, 101, 10, 0.18);
    color: #FFB680;
}

.scan-status {
    display: inline-block;
    padding: 0.15rem 0.5rem;
    border-radius: 4px;
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.scan-status--pending   { background: rgba(255, 255, 255, 0.08); color: var(--color-text-muted); }
.scan-status--running   { background: rgba(232, 101, 10, 0.18); color: #FFB680; }
.scan-status--complete  { background: rgba(16, 185, 129, 0.18); color: #6EE7B7; }
.scan-status--failed    { background: rgba(239, 68, 68, 0.18);  color: #FCA5A5; }
.scan-status--sev-critical { background: rgba(192, 57, 43, 0.25); color: #FCA5A5; }
.scan-status--sev-high     { background: rgba(232, 101, 10, 0.22); color: #FFB680; }
.scan-status--sev-medium   { background: rgba(234, 179, 8, 0.18); color: #FDE68A; }
.scan-status--sev-low      { background: rgba(59, 130, 246, 0.18); color: #93C5FD; }
.scan-status--sev-info     { background: rgba(255, 255, 255, 0.08); color: var(--color-text-muted); }

.scan-findings { white-space: nowrap; }
.scan-pill {
    display: inline-block;
    padding: 0.1rem 0.45rem;
    border-radius: 999px;
    font-size: 0.75rem;
    margin-right: 0.2rem;
    background: rgba(255, 255, 255, 0.06);
    color: var(--color-text);
}

.scan-banner--info {
    padding: 0.7rem 0.9rem;
    border-radius: 6px;
    background: rgba(13, 148, 136, 0.18);
    border: 1px solid rgba(13, 148, 136, 0.45);
    color: var(--color-text);
    margin-top: 0.6rem;
    font-size: 0.9rem;
}

/* ── 31e. Vulnerability scans (Part 2) ────────────────────── */
/* Every surface explicitly uses --color-bg-raised / --color-text /
   --color-border. No --color-surface, no white fallbacks. */

.scans-filter-bar {
    display: flex;
    align-items: flex-end;
    gap: var(--space-3);
    margin-bottom: var(--space-3);
    flex-wrap: wrap;
}
.scans-filter-bar__field {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
    font-size: 0.78rem;
    color: var(--color-text-muted);
}
.scans-filter-bar__field select { min-width: 180px; }
.scans-filter-bar__clear {
    font-size: 0.85rem;
    color: var(--color-text-muted);
}

.scans-pagination {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.6rem 0.9rem;
    border-top: 1px solid var(--color-border);
    background: var(--color-bg-raised);
}
.scans-pagination__counter {
    color: var(--color-text-muted);
    font-size: 0.85rem;
}

/* Scan type pill (table cells + scan_detail header) */
.scan-type {
    display: inline-block;
    padding: 0.15rem 0.55rem;
    border-radius: 999px;
    font-size: 0.7rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    background: rgba(255, 255, 255, 0.06);
    color: var(--color-text-muted);
}
.scan-type--full   { background: rgba(13, 148, 136, 0.22); color: #5EEAD4; }
.scan-type--ssl    { background: rgba(59, 130, 246, 0.22); color: #93C5FD; }
.scan-type--ports  { background: rgba(255, 255, 255, 0.08); color: var(--color-text-muted); }
.scan-type--web    { background: rgba(232, 101, 10, 0.22); color: #FFB680; }
.scan-type--quick  { background: rgba(148, 163, 184, 0.18); color: #CBD5E1; }

.scan-row-pulse,
.scans-row-pulse { animation: scan-pulse 2s ease-in-out infinite; }
@keyframes scan-pulse {
    0%, 100% { background: transparent; }
    50%      { background: rgba(13, 148, 136, 0.06); }
}

.scan-clean {
    color: #6EE7B7;
    font-weight: 600;
}

/* Severity row border (extend droplet-row colours with red/orange/green/
   teal/muted that the scan rows use) */
.droplet-row--teal  > td:first-child { box-shadow: inset 4px 0 0 #14B8A6; }
.droplet-row--muted > td:first-child { box-shadow: inset 4px 0 0 #475569; }
.droplet-dot--teal  { background: #14B8A6; }
.droplet-dot--muted { background: #475569; }

/* ── Run-New-Scan modal ──────────────────────────────────── */
.scan-modal {
    position: fixed;
    inset: 0;
    background: rgba(7, 6, 20, 0.7);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 200;
    padding: 1rem;
}
.scan-modal[hidden] { display: none; }
.scan-modal__card {
    background: var(--color-bg-raised);
    color: var(--color-text);
    border: 1px solid var(--color-border);
    border-radius: 12px;
    max-width: 560px;
    width: 100%;
    padding: 1.4rem 1.6rem;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.55);
}
.scan-modal__head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 1rem;
}
.scan-modal__head h2 { margin: 0; font-size: 1.1rem; color: var(--color-text); }
.scan-modal__close {
    border: 0;
    background: none;
    color: var(--color-text-muted);
    font-size: 1.6rem;
    line-height: 1;
    cursor: pointer;
    padding: 0 0.5rem;
}
.scan-modal__close:hover { color: var(--color-text); }
.scan-modal__readonly {
    background: var(--color-bg-deep);
    color: var(--color-text);
    border: 1px solid var(--color-border);
    border-radius: 6px;
    padding: 0.5rem 0.7rem;
    font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
    font-size: 0.85rem;
}
.scan-modal__hint {
    margin: 0.3rem 0 0;
    font-size: 0.78rem;
    color: var(--color-text-muted);
}
.scan-modal__actions {
    display: flex;
    gap: 0.6rem;
    margin-top: var(--space-3);
}

/* ── Scan detail page ────────────────────────────────────── */
.scan-header-card {
    background: var(--color-bg-raised);
    color: var(--color-text);
    border: 1px solid var(--color-border);
    border-radius: 12px;
    padding: 1.4rem 1.6rem;
    margin-bottom: var(--space-3);
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-4);
}
@media (min-width: 860px) {
    .scan-header-card { grid-template-columns: 1.2fr 1fr; }
}
.scan-header-card__client {
    margin: 0 0 0.4rem;
    font-size: 1.4rem;
    color: var(--color-text);
}
.scan-header-card__client a {
    color: var(--color-text);
    text-decoration: none;
}
.scan-header-card__client a:hover { color: var(--color-orange); }
.scan-header-card__badges {
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem;
    margin: 0 0 0.7rem;
}
.scan-header-card__meta {
    display: grid;
    grid-template-columns: max-content 1fr;
    gap: 0.3rem 0.9rem;
    margin: 0 0 0.9rem;
    font-size: 0.88rem;
    color: var(--color-text);
}
.scan-header-card__meta dt {
    color: var(--color-text-muted);
    font-weight: 500;
}
.scan-header-card__meta dd { margin: 0; word-break: break-word; }
.scan-header-card__meta code {
    background: var(--color-bg-deep);
    border: 1px solid var(--color-border);
    color: var(--color-text);
    padding: 0.05rem 0.4rem;
    border-radius: 4px;
}
.scan-header-card__meta a {
    color: var(--color-orange);
    text-decoration: none;
}
.scan-header-card__meta a:hover { text-decoration: underline; }
.scan-header-card__actions {
    display: flex;
    gap: 0.6rem;
    flex-wrap: wrap;
}
.scan-header-card__right {
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
}

.scan-severity-grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 0.5rem;
}
.scan-severity-grid__cell {
    background: var(--color-bg-deep);
    border: 1px solid var(--color-border);
    border-top: 3px solid #475569;
    border-radius: 8px;
    padding: 0.7rem 0.5rem;
    text-align: center;
    color: var(--color-text);
}
.scan-severity-grid__cell--critical { border-top-color: #EF4444; }
.scan-severity-grid__cell--high     { border-top-color: #F97316; }
.scan-severity-grid__cell--medium   { border-top-color: #EAB308; }
.scan-severity-grid__cell--low      { border-top-color: #3B82F6; }
.scan-severity-grid__cell--info     { border-top-color: #6B7280; }
.scan-severity-grid__num {
    display: block;
    font-size: 1.5rem;
    font-weight: 700;
    line-height: 1;
}
.scan-severity-grid__label {
    display: block;
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--color-text-muted);
    margin-top: 0.2rem;
}

.scan-ssl-grade {
    display: flex;
    align-items: center;
    gap: 0.9rem;
    background: var(--color-bg-deep);
    border: 1px solid var(--color-border);
    border-radius: 8px;
    padding: 0.7rem 0.9rem;
}
.scan-ssl-grade__letter {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 3rem;
    height: 3rem;
    border-radius: 50%;
    font-size: 1.3rem;
    font-weight: 700;
    color: #fff;
    background: #475569;
}
.scan-ssl-grade--a .scan-ssl-grade__letter { background: #10B981; }
.scan-ssl-grade--b .scan-ssl-grade__letter { background: #EAB308; }
.scan-ssl-grade--c .scan-ssl-grade__letter { background: #F97316; }
.scan-ssl-grade--f .scan-ssl-grade__letter { background: #EF4444; }
.scan-ssl-grade__label {
    font-size: 0.85rem;
    color: var(--color-text-muted);
}

/* Banner used for scan-launch confirmations + error states */
.scan-banner {
    padding: 0.75rem 0.9rem;
    border-radius: 8px;
    margin-bottom: var(--space-3);
    color: var(--color-text);
}
.scan-banner--info {
    background: rgba(13, 148, 136, 0.18);
    border: 1px solid rgba(13, 148, 136, 0.45);
}
.scan-banner--error {
    background: rgba(192, 57, 43, 0.20);
    border: 1px solid rgba(192, 57, 43, 0.5);
}

/* Tools-used block */
.scan-tools-card {
    background: var(--color-bg-raised);
    color: var(--color-text);
    border: 1px solid var(--color-border);
    border-radius: 12px;
    padding: 1.1rem 1.3rem;
    margin-bottom: var(--space-3);
}
.scan-tools-card__title {
    margin: 0 0 0.6rem;
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    color: var(--color-text-muted);
    font-weight: 700;
}
.scan-tools-card__list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 0.5rem 0.9rem;
    font-size: 0.9rem;
}
.scan-tool {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    color: var(--color-text);
}
.scan-tool__glyph {
    display: inline-flex;
    width: 1.2rem;
    height: 1.2rem;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.06);
    color: var(--color-text-muted);
    font-size: 0.75rem;
    font-weight: 700;
    flex-shrink: 0;
}
.scan-tool--ok      .scan-tool__glyph { background: rgba(16, 185, 129, 0.25); color: #6EE7B7; }
.scan-tool--skipped .scan-tool__glyph { background: rgba(148, 163, 184, 0.20); color: #CBD5E1; }
.scan-tool--error   .scan-tool__glyph { background: rgba(239, 68, 68, 0.25); color: #FCA5A5; }
.scan-tool__label  { font-weight: 600; }
.scan-tool__summary { color: var(--color-text-muted); }

/* Findings groups (collapsible per-severity) */
.scan-findings-group {
    background: var(--color-bg-raised);
    color: var(--color-text);
    border: 1px solid var(--color-border);
    border-radius: 12px;
    margin-bottom: var(--space-3);
    overflow: hidden;
}
.scan-findings-group > summary {
    list-style: none;
    cursor: pointer;
    padding: 0.85rem 1.1rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
    user-select: none;
    background: var(--color-bg-raised);
    color: var(--color-text);
}
.scan-findings-group > summary::-webkit-details-marker { display: none; }
.scan-findings-group__sev { font-size: 1rem; }
.scan-findings-group__label { font-weight: 700; }
.scan-findings-group__count { color: var(--color-text-muted); font-size: 0.85rem; }
.scan-findings-group--critical > summary { border-left: 4px solid #EF4444; }
.scan-findings-group--high     > summary { border-left: 4px solid #F97316; }
.scan-findings-group--medium   > summary { border-left: 4px solid #EAB308; }
.scan-findings-group--low      > summary { border-left: 4px solid #3B82F6; }
.scan-findings-group--info     > summary { border-left: 4px solid #6B7280; }
.scan-findings-group__body {
    padding: 0.4rem 1.1rem 1.1rem;
    display: flex;
    flex-direction: column;
    gap: 0.6rem;
}
.scan-findings-group__empty {
    padding: 0 1.1rem 1.1rem;
    color: var(--color-text-muted);
    font-size: 0.85rem;
    margin: 0;
}

/* Individual finding card */
.finding-card {
    background: var(--color-bg-deep);
    color: var(--color-text);
    border: 1px solid var(--color-border);
    border-left: 4px solid #6B7280;
    border-radius: 8px;
}
.finding-card--sev-critical { border-left-color: #EF4444; }
.finding-card--sev-high     { border-left-color: #F97316; }
.finding-card--sev-medium   { border-left-color: #EAB308; }
.finding-card--sev-low      { border-left-color: #3B82F6; }
.finding-card--sev-info     { border-left-color: #6B7280; }
.finding-card--status-accepted_risk,
.finding-card--status-false_positive,
.finding-card--status-resolved { opacity: 0.75; }

.finding-card details summary { list-style: none; cursor: pointer; }
.finding-card details summary::-webkit-details-marker { display: none; }

.finding-card__head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 0.75rem;
    padding: 0.7rem 0.9rem;
}
.finding-card__title {
    font-weight: 600;
    color: var(--color-text);
}
.finding-card__badges {
    display: flex;
    gap: 0.35rem;
    flex-wrap: wrap;
    flex-shrink: 0;
}
.finding-card__body {
    padding: 0 0.9rem 0.9rem;
    color: var(--color-text);
    font-size: 0.9rem;
    line-height: 1.5;
}
.finding-card__body p { margin: 0.4rem 0; }
.finding-card__evidence summary {
    color: var(--color-text-muted);
    font-size: 0.8rem;
    padding: 0.2rem 0;
}
.finding-card__evidence pre {
    background: #0b1020;
    color: #e2e8f0;
    border: 1px solid var(--color-border);
    border-radius: 6px;
    padding: 0.65rem 0.8rem;
    font-size: 0.8rem;
    overflow-x: auto;
    white-space: pre-wrap;
    margin: 0.3rem 0 0;
}
.finding-card__cve a {
    color: var(--color-orange);
    text-decoration: none;
}
.finding-card__cve a:hover { text-decoration: underline; }
.finding-card__accept-meta {
    background: rgba(13, 148, 136, 0.12);
    border: 1px solid rgba(13, 148, 136, 0.3);
    border-radius: 6px;
    padding: 0.5rem 0.7rem;
    margin: 0.5rem 0;
    font-size: 0.85rem;
}
.finding-card__actions {
    display: flex;
    gap: 0.4rem;
    flex-wrap: wrap;
    margin-top: 0.6rem;
}
.finding-card__accept summary { display: inline-block; }
.finding-card__accept-form {
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
    margin-top: 0.5rem;
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 6px;
    padding: 0.6rem 0.75rem;
}

.finding-status {
    display: inline-block;
    padding: 0.1rem 0.45rem;
    border-radius: 4px;
    font-size: 0.7rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.finding-status--open           { background: rgba(255, 255, 255, 0.08); color: var(--color-text-muted); }
.finding-status--accepted_risk  { background: rgba(13, 148, 136, 0.22); color: #5EEAD4; }
.finding-status--false_positive { background: rgba(148, 163, 184, 0.18); color: #CBD5E1; }
.finding-status--resolved       { background: rgba(16, 185, 129, 0.22); color: #6EE7B7; }

/* Client list — last scan column */
.client-list__last-scan {
    white-space: nowrap;
    font-size: 0.85rem;
}
.scan-dot {
    display: inline-block;
    width: 0.65rem;
    height: 0.65rem;
    border-radius: 50%;
    margin-right: 0.3rem;
    vertical-align: middle;
    background: #475569;
}
.scan-dot--critical { background: #EF4444; }
.scan-dot--high     { background: #F97316; }
.scan-dot--clean    { background: #10B981; }
.scan-dot--never    { background: #475569; }

/* Scan-in-progress banner above the Security Scans card */
.scan-progress-banner {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    padding: 0.6rem 0.9rem;
    border-radius: 8px;
    background: rgba(13, 148, 136, 0.18);
    border: 1px solid rgba(13, 148, 136, 0.45);
    color: var(--color-text);
    font-size: 0.88rem;
    margin-bottom: 0.6rem;
}
.scan-progress-banner__dot {
    display: inline-block;
    width: 0.6rem;
    height: 0.6rem;
    border-radius: 50%;
    background: #5EEAD4;
    animation: scan-progress-pulse 1.4s ease-in-out infinite;
    flex-shrink: 0;
}
@keyframes scan-progress-pulse {
    0%, 100% { opacity: 0.35; transform: scale(0.85); }
    50%      { opacity: 1;    transform: scale(1.15); }
}

/* Client detail — Security Scans card */
.client-scan-summary {
    margin: 0 0 0.5rem;
    font-size: 0.9rem;
    color: var(--color-text);
}
.client-scan-top {
    margin: 0 0 0.6rem;
    padding-left: 1.2rem;
    font-size: 0.88rem;
    color: var(--color-text);
}
.client-scan-top li { margin: 0.2rem 0; }
.client-scan-actions {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
    margin-top: 0.6rem;
}

/* ── 31f. Scan PDF buttons + auto-send toggle (admin, dark) ── */
.scan-action-result { margin-top: 0.6rem; }
.scan-action-result:empty { display: none; }
.scan-sent-stamp {
    font-size: 0.78rem;
    color: var(--color-text-muted);
    margin-left: 0.4rem;
}

.auto-send-toggle {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    margin: 0;
    cursor: pointer;
    font-size: 0.85rem;
    color: var(--color-text);
}
.auto-send-toggle__switch {
    appearance: none;
    -webkit-appearance: none;
    display: inline-block;
    width: 2.2rem;
    height: 1.2rem;
    border-radius: 999px;
    border: 1px solid var(--color-border);
    background: rgba(255, 255, 255, 0.06);
    position: relative;
    cursor: pointer;
    transition: background 0.15s, border-color 0.15s;
    padding: 0;
}
.auto-send-toggle__knob {
    position: absolute;
    top: 1px;
    left: 1px;
    width: 1rem;
    height: 1rem;
    border-radius: 50%;
    background: var(--color-text-muted);
    transition: transform 0.15s, background 0.15s;
}
.auto-send-toggle__switch.is-on {
    background: rgba(13, 148, 136, 0.35);
    border-color: rgba(13, 148, 136, 0.55);
}
.auto-send-toggle__switch.is-on .auto-send-toggle__knob {
    transform: translateX(1rem);
    background: #5EEAD4;
}
.auto-send-toggle__label strong {
    margin-left: 0.25rem;
    color: var(--color-text);
}
.client-scan-autosend {
    margin-top: 0.9rem;
    padding-top: 0.7rem;
    border-top: 1px solid var(--color-border);
}
.client-scan-summary--hint {
    font-size: 0.78rem;
    color: var(--color-text-muted);
    margin: 0.35rem 0 0;
}

/* ── 31g. Portal security page (light theme — matches portal) ── */
.portal-empty--centered {
    text-align: center;
    padding: 3rem 1rem;
}
.portal-empty__icon {
    width: 64px;
    height: 64px;
    margin: 0 auto 1rem;
    display: block;
}
.portal-empty--centered h2 { margin: 0 0 0.4rem; font-size: 1.25rem; }

.portal-security-card {
    background: #ffffff;
    border: 1px solid #E5E7EB;
    border-radius: 12px;
    padding: 1.4rem 1.6rem;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04);
}
.portal-security-card__date {
    margin: 0 0 0.6rem;
    font-size: 0.85rem;
    color: #6B7280;
}
.portal-security-pills {
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem;
    margin-bottom: 1rem;
}
.portal-sev {
    display: inline-block;
    padding: 0.2rem 0.6rem;
    border-radius: 999px;
    font-size: 0.78rem;
    font-weight: 600;
}
.portal-sev--critical { background: #FEE2E2; color: #991B1B; }
.portal-sev--high     { background: #FFEDD5; color: #9A3412; }
.portal-sev--medium   { background: #FEF3C7; color: #854D0E; }
.portal-sev--low      { background: #DBEAFE; color: #1E40AF; }
.portal-sev--clean    { background: #D1FAE5; color: #065F46; }

.portal-security-card__clean {
    color: #065F46;
    font-weight: 600;
    margin: 0 0 1rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}
.portal-security-card__check {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2rem;
    height: 2rem;
    border-radius: 50%;
    background: #10B981;
    color: #fff;
    font-weight: 700;
    font-size: 1.1rem;
}
.portal-security-card__warn {
    color: #991B1B;
    background: #FEF2F2;
    border: 1px solid #FECACA;
    border-radius: 6px;
    padding: 0.6rem 0.8rem;
    margin: 0 0 1rem;
    font-size: 0.9rem;
}
.portal-security-card__ok {
    color: #1F2937;
    margin: 0 0 1rem;
    font-size: 0.92rem;
}
.portal-security-card__pending {
    display: inline-block;
    color: #6B7280;
    font-style: italic;
}

.portal-nav__dot--alert { background: #EF4444; }
.portal-muted { color: #6B7280; }

/* ── 31h. Client edit form + inline quick-edit (admin dark) ─ */
.client-edit-form { max-width: 880px; }
.client-edit-section {
    background: var(--color-bg-raised);
    color: var(--color-text);
    border: 1px solid var(--color-border);
    border-radius: 12px;
    padding: 1.1rem 1.3rem;
    margin-bottom: var(--space-3);
}
.client-edit-section__title {
    margin: 0 0 0.8rem;
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    color: var(--color-text-muted);
    font-weight: 700;
}
.client-edit-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0.85rem 1rem;
}
@media (min-width: 640px) {
    .client-edit-grid { grid-template-columns: 1fr 1fr; }
}
.client-edit-field {
    display: flex;
    flex-direction: column;
    gap: 0.3rem;
    font-size: 0.85rem;
    color: var(--color-text);
}
.client-edit-field--wide { grid-column: 1 / -1; }
.client-edit-field > span {
    color: var(--color-text-muted);
    font-weight: 600;
}
.client-edit-hint {
    color: var(--color-text-muted);
    font-weight: 400;
    font-size: 0.78rem;
    margin-left: 0.3rem;
}
.client-edit-error {
    color: #FCA5A5;
    font-size: 0.8rem;
}
.client-edit-checkbox {
    display: flex;
    align-items: center;
    gap: 0.55rem;
    font-size: 0.9rem;
    color: var(--color-text);
}
.client-edit-checkbox input { width: 1.05rem; height: 1.05rem; }
.client-edit-actions {
    display: flex;
    gap: 0.6rem;
    margin-top: var(--space-3);
}

/* Inline quick-edit on the client detail page */
.quick-edit-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
}
.quick-edit {
    display: flex;
    align-items: center;
    gap: 0.55rem;
    padding: 0.4rem 0.55rem;
    border-radius: 6px;
    background: rgba(255, 255, 255, 0.03);
    font-size: 0.9rem;
    color: var(--color-text);
    flex-wrap: wrap;
}
.quick-edit__label {
    color: var(--color-text-muted);
    font-weight: 600;
    min-width: 7.5rem;
}
.quick-edit__value { color: var(--color-text); word-break: break-all; }
.quick-edit__empty {
    color: var(--color-text-muted);
    font-style: italic;
}
.quick-edit__btn {
    margin-left: auto;
    background: transparent;
    color: var(--color-text-muted);
    border: 1px solid var(--color-border);
    border-radius: 4px;
    padding: 0.1rem 0.55rem;
    font-size: 0.75rem;
    cursor: pointer;
}
.quick-edit__btn:hover {
    color: var(--color-text);
    background: rgba(255, 255, 255, 0.06);
}
.quick-edit--editing {
    background: rgba(232, 101, 10, 0.08);
    border: 1px solid rgba(232, 101, 10, 0.3);
}
.quick-edit__input {
    flex: 1;
    min-width: 12rem;
    padding: 0.35rem 0.5rem;
    font-size: 0.88rem;
}

/* ── 31i. Tester-account markers (list / detail / onboarding) ── */
.tester-badge {
    display: inline-block;
    padding: 0.1rem 0.5rem;
    border-radius: 4px;
    font-size: 0.65rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    background: rgba(232, 101, 10, 0.20);
    color: #FFB680;
    border: 1px solid rgba(232, 101, 10, 0.45);
    vertical-align: middle;
    margin-left: 0.5rem;
}

.client-row--tester {
    /* Mute tester rows visually so real clients stand out */
    opacity: 0.78;
}

.tester-banner {
    background: rgba(232, 101, 10, 0.10);
    border: 1px dashed rgba(232, 101, 10, 0.55);
    border-radius: 8px;
    padding: 0.7rem 1rem;
    margin-bottom: var(--space-3);
    color: var(--color-text);
    font-size: 0.9rem;
    line-height: 1.45;
}
.tester-banner strong {
    color: #FFB680;
    margin-right: 0.4rem;
    letter-spacing: 0.06em;
}

/* Onboarding card variants for tester clients */
.onboarding-card--tester { opacity: 0.85; }
.onboarding-card--tester .onboarding-card__title { color: var(--color-text-muted); }
.onboarding-card--tester .onboarding-card__title .tester-badge {
    opacity: 1;
    color: #FFB680;
}
.onboarding-checks li.is-na {
    color: var(--color-text-muted);
    font-style: italic;
}
.onboarding-checks li.is-na .onboarding-checks__icon {
    background: rgba(255, 255, 255, 0.04);
    color: var(--color-text-muted);
}

/* ── 31j. AI Ops Agent (Phase 6d) — full-screen split panel ── */
.ops-body {
    margin: 0;
    background: var(--color-bg-deep);
    color: var(--color-text);
    font-family: Arial, sans-serif;
    overflow: hidden;
}
.ops-agent {
    display: flex;
    flex-direction: column;
    height: 100vh;
    width: 100vw;
}

/* Top bar — mirrors .term-bar style for visual consistency */
.ops-bar {
    flex: 0 0 44px;
    display: flex;
    align-items: center;
    background: var(--color-bg-raised);
    border-bottom: 1px solid var(--color-border);
    padding: 0 1rem;
    gap: 1rem;
    color: var(--color-text);
}
.ops-bar__seg { display: flex; align-items: center; gap: 0.55rem; }
.ops-bar__seg--left { flex: 1; }
.ops-bar__seg--center { flex: 0 0 auto; }
.ops-bar__seg--right { flex: 1; justify-content: flex-end; gap: 0.4rem; }
.ops-bar__hint {
    color: var(--color-text-muted);
    font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
    font-size: 0.78rem;
}
.ops-bar__brand {
    color: #E8650A;
    font-weight: 700;
    letter-spacing: 0.06em;
}

.ops-main {
    flex: 1 1 auto;
    display: grid;
    grid-template-columns: 1fr;
    min-height: 0;
}
@media (min-width: 1080px) {
    .ops-main { grid-template-columns: 6fr 4fr; }
}

/* ── Chat panel ──────────────────────────────────────────── */
.ops-chat-panel {
    display: flex;
    flex-direction: column;
    background: var(--color-bg-raised);
    border-right: 1px solid var(--color-border);
    min-height: 0;
}
.ops-chat {
    flex: 1 1 auto;
    overflow-y: auto;
    padding: 1rem 1.2rem;
    display: flex;
    flex-direction: column;
    gap: 0.7rem;
}

.ops-msg {
    max-width: 78%;
    border-radius: 10px;
    padding: 0.7rem 0.9rem;
    background: #1E293B;
    color: var(--color-text);
    border: 1px solid var(--color-border);
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.18);
}
.ops-msg--user {
    align-self: flex-end;
    background: rgba(232, 101, 10, 0.12);
    border-color: rgba(232, 101, 10, 0.3);
}
.ops-msg--agent {
    align-self: flex-start;
    background: #1A2744;
    border-left: 3px solid #14B8A6;
}
.ops-msg--error {
    align-self: stretch;
    background: rgba(192, 57, 43, 0.20);
    border: 1px solid rgba(192, 57, 43, 0.5);
    color: #FCA5A5;
    font-size: 0.85rem;
}
.ops-msg__body { font-size: 0.92rem; line-height: 1.5; }
.ops-msg__body p { margin: 0.3rem 0; }
.ops-msg__body p:first-child { margin-top: 0; }
.ops-msg__body p:last-child { margin-bottom: 0; }
.ops-msg__body ul { margin: 0.4rem 0; padding-left: 1.3rem; }
.ops-msg__body code {
    background: var(--color-bg-deep);
    color: #FFB680;
    border: 1px solid var(--color-border);
    border-radius: 3px;
    padding: 0.05rem 0.35rem;
    font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
    font-size: 0.85em;
}
.ops-msg__body pre {
    background: var(--color-bg-deep);
    border: 1px solid var(--color-border);
    border-radius: 6px;
    padding: 0.65rem 0.8rem;
    font-size: 0.82rem;
    overflow-x: auto;
    margin: 0.5rem 0;
    color: var(--color-text);
}
.ops-msg__body pre code {
    background: transparent;
    border: 0;
    color: inherit;
    padding: 0;
}
.ops-msg__stamp {
    margin-top: 0.45rem;
    font-size: 0.7rem;
    color: var(--color-text-muted);
    text-align: right;
}

/* Command execution block (agent-suggested, auto-run) */
.ops-cmd {
    align-self: stretch;
    background: var(--color-bg-deep);
    border: 1px solid var(--color-border);
    border-left: 3px solid #E8650A;
    border-radius: 8px;
    padding: 0.65rem 0.9rem;
}
.ops-cmd--denied { border-left-color: #EF4444; opacity: 0.85; }
.ops-cmd--failed { border-left-color: #F97316; }
.ops-cmd__head {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex-wrap: wrap;
    margin-bottom: 0.4rem;
}
.ops-cmd__prompt { color: #FFB680; font-weight: 700; }
.ops-cmd__line {
    color: #FFB680;
    background: transparent;
    font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
    font-size: 0.86rem;
    flex: 1;
    word-break: break-all;
}
.ops-cmd__badge {
    margin-left: auto;
    background: rgba(255, 255, 255, 0.08);
    color: var(--color-text-muted);
    border-radius: 999px;
    font-size: 0.7rem;
    padding: 0.05rem 0.5rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.ops-cmd__badge--approved { background: rgba(13, 148, 136, 0.22); color: #5EEAD4; }
.ops-cmd__badge--denied { background: rgba(239, 68, 68, 0.22); color: #FCA5A5; }
.ops-cmd__badge--failed { background: rgba(232, 101, 10, 0.22); color: #FFB680; }
.ops-cmd__output {
    background: rgba(0, 0, 0, 0.35);
    border: 1px solid var(--color-border);
    border-radius: 6px;
    padding: 0.55rem 0.8rem;
    font-size: 0.8rem;
    overflow-x: auto;
    color: var(--color-text);
    margin: 0;
    white-space: pre-wrap;
    word-break: break-word;
}

/* Safety gate card */
.ops-gate {
    align-self: stretch;
    border: 1px dashed rgba(232, 101, 10, 0.6);
    background: rgba(232, 101, 10, 0.10);
    border-radius: 8px;
    padding: 0.85rem 1rem;
    color: var(--color-text);
}
.ops-gate__head {
    font-weight: 700;
    color: #FFB680;
    margin-bottom: 0.5rem;
}
.ops-gate__warn {
    display: inline-block;
    margin-right: 0.35rem;
    font-size: 1.05rem;
}
.ops-gate__cmd {
    display: block;
    background: var(--color-bg-deep);
    border: 1px solid var(--color-border);
    border-radius: 6px;
    padding: 0.55rem 0.75rem;
    font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
    color: #FFB680;
    font-size: 0.88rem;
    margin: 0.4rem 0;
    word-break: break-all;
}
.ops-gate__reason {
    margin: 0 0 0.6rem;
    font-size: 0.85rem;
    color: var(--color-text);
}
.ops-gate__actions { display: flex; gap: 0.5rem; }
.ops-gate__approve {
    background: #10B981; border-color: #10B981; color: #fff;
}
.ops-gate__approve:hover { background: #059669; }
.ops-gate__deny {
    background: rgba(239, 68, 68, 0.15);
    border-color: rgba(239, 68, 68, 0.5);
    color: #FCA5A5;
}

/* Typing indicator */
.ops-typing {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.4rem 1.2rem;
    color: var(--color-text-muted);
    font-size: 0.85rem;
}
.ops-typing[hidden] { display: none; }
.ops-dot {
    display: inline-block;
    width: 0.45rem;
    height: 0.45rem;
    background: #14B8A6;
    border-radius: 50%;
    animation: ops-bounce 1.2s infinite ease-in-out;
}
.ops-dot:nth-child(2) { animation-delay: 0.15s; }
.ops-dot:nth-child(3) { animation-delay: 0.30s; }
@keyframes ops-bounce {
    0%, 80%, 100% { opacity: 0.35; transform: scale(0.85); }
    40%           { opacity: 1;    transform: scale(1.15); }
}

/* Input area */
.ops-input-area {
    flex: 0 0 auto;
    border-top: 1px solid var(--color-border);
    padding: 0.7rem 1.2rem;
    display: flex;
    gap: 0.6rem;
    background: var(--color-bg-raised);
}
.ops-input {
    flex: 1;
    background: var(--color-bg-deep);
    color: var(--color-text);
    border: 1px solid var(--color-border);
    border-radius: 6px;
    padding: 0.55rem 0.7rem;
    font-family: inherit;
    font-size: 0.92rem;
    resize: vertical;
    min-height: 70px;
}
.ops-input:focus { outline: none; border-color: #E8650A; }

/* ── Right side panel ──────────────────────────────────── */
.ops-side-panel {
    background: var(--color-bg-deep);
    overflow-y: auto;
    padding: 0.75rem;
    display: flex;
    flex-direction: column;
    gap: 0.6rem;
    border-left: 1px solid var(--color-border);
    color: var(--color-text);
}
.ops-side-block {
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 8px;
    padding: 0.6rem 0.85rem;
}
.ops-side-block > summary {
    cursor: pointer;
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--color-text-muted);
    font-weight: 700;
    padding: 0.15rem 0;
}
.ops-side-block__hint {
    font-size: 0.78rem;
    color: var(--color-text-muted);
    margin: 0.35rem 0;
}
.ops-state {
    margin: 0.4rem 0 0;
    display: grid;
    grid-template-columns: max-content 1fr;
    gap: 0.3rem 0.7rem;
    font-size: 0.82rem;
}
.ops-state--compact { font-size: 0.85rem; }
.ops-state dt { color: var(--color-text-muted); }
.ops-state dd {
    margin: 0;
    color: var(--color-text);
    word-break: break-word;
}
.ops-state pre {
    background: var(--color-bg-deep);
    border: 1px solid var(--color-border);
    border-radius: 4px;
    padding: 0.35rem 0.5rem;
    font-size: 0.75rem;
    overflow-x: auto;
    margin: 0;
    color: var(--color-text);
    white-space: pre-wrap;
}
.ops-state__err { color: #FCA5A5; font-size: 0.78rem; }

.ops-quickgroup { margin-top: 0.55rem; }
.ops-quickgroup__label {
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--color-text-muted);
    margin-bottom: 0.25rem;
}
.ops-quickcmd {
    display: block;
    width: 100%;
    text-align: left;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid var(--color-border);
    color: var(--color-text);
    padding: 0.4rem 0.6rem;
    border-radius: 5px;
    font-size: 0.82rem;
    cursor: pointer;
    margin-bottom: 0.25rem;
}
.ops-quickcmd:hover {
    background: rgba(232, 101, 10, 0.10);
    border-color: rgba(232, 101, 10, 0.35);
}

.ops-recent {
    list-style: none;
    padding: 0;
    margin: 0.4rem 0 0;
    font-size: 0.82rem;
}
.ops-recent li {
    display: flex;
    justify-content: space-between;
    gap: 0.5rem;
    padding: 0.25rem 0;
    border-bottom: 1px solid var(--color-border);
}
.ops-recent li:last-child { border-bottom: 0; }
.ops-recent a { color: #FFB680; text-decoration: none; }
.ops-recent a:hover { text-decoration: underline; }
.ops-recent small { color: var(--color-text-muted); }

/* ── Session replay page ─────────────────────────────── */
.ops-replay {
    display: flex;
    flex-direction: column;
    gap: 0.6rem;
}
.ops-replay-msg {
    background: var(--color-bg-deep);
    border: 1px solid var(--color-border);
    border-radius: 8px;
    padding: 0.65rem 0.85rem;
    border-left: 3px solid #6B7280;
}
.ops-replay-msg--assistant { border-left-color: #14B8A6; }
.ops-replay-msg--user      { border-left-color: #E8650A; }
.ops-replay-msg--system    { border-left-color: #EAB308; opacity: 0.85; }
.ops-replay-msg__head {
    display: flex;
    justify-content: space-between;
    font-size: 0.75rem;
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin-bottom: 0.3rem;
}
.ops-replay-msg__role { font-weight: 700; color: var(--color-text); }
.ops-replay-msg__body {
    margin: 0;
    font-family: inherit;
    font-size: 0.9rem;
    white-space: pre-wrap;
    word-break: break-word;
    color: var(--color-text);
}
.ops-replay-cmd {
    background: var(--color-bg-deep);
    border: 1px solid var(--color-border);
    border-left: 3px solid #E8650A;
    border-radius: 8px;
    padding: 0.55rem 0.85rem;
}
.ops-replay-cmd--dangerous { border-left-color: #EAB308; }
.ops-replay-cmd--failed { border-left-color: #EF4444; }
.ops-replay-cmd__head {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex-wrap: wrap;
    margin-bottom: 0.35rem;
    font-size: 0.78rem;
}
.ops-replay-cmd__line {
    color: #FFB680;
    background: transparent;
    font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
    font-size: 0.82rem;
    flex: 1;
    word-break: break-all;
}
.ops-replay-cmd__output {
    background: rgba(0, 0, 0, 0.35);
    border: 1px solid var(--color-border);
    border-radius: 6px;
    padding: 0.5rem 0.7rem;
    font-size: 0.78rem;
    color: var(--color-text);
    margin: 0;
    overflow-x: auto;
    white-space: pre-wrap;
    word-break: break-word;
}
.ops-replay time {
    color: var(--color-text-muted);
    font-size: 0.72rem;
    margin-left: auto;
}

/* Vault credential AI Ops button — teal accent so it reads as
   distinct from the orange Connect button without screaming. */
.vault-ops-btn {
    color: #5EEAD4 !important;
    border-color: rgba(20, 184, 166, 0.45) !important;
    background: rgba(20, 184, 166, 0.12) !important;
}
.vault-ops-btn:hover {
    background: rgba(20, 184, 166, 0.22) !important;
}

/* ── 31k. Phase 7 — Business Intelligence dashboard ─────── */

.bi-section-title {
    margin: var(--space-4) 0 var(--space-3);
    font-size: 1.05rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--color-text-muted);
    font-weight: 700;
}

.bi-card {
    background: var(--color-bg-raised);
    color: var(--color-text);
    border: 1px solid var(--color-border);
    border-radius: 12px;
    padding: 1.1rem 1.3rem;
    margin-bottom: var(--space-3);
}
.bi-card__head {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 0.75rem;
    margin-bottom: 0.7rem;
    flex-wrap: wrap;
}
.bi-card__head h3 {
    margin: 0;
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--color-text-muted);
    font-weight: 700;
}
.bi-card__head small {
    color: var(--color-text-muted);
    font-size: 0.75rem;
}

/* MRR trend chart — CSS bars only, no JS */
.bi-chart {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(70px, 1fr));
    gap: 0.4rem;
    align-items: end;
    min-height: 180px;
    padding: 0.5rem 0;
}
.bi-chart__col {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.3rem;
}
.bi-chart__bar-wrap {
    width: 100%;
    height: 140px;
    display: flex;
    align-items: flex-end;
    background: linear-gradient(
        to bottom,
        rgba(255, 255, 255, 0.02) 0%,
        rgba(255, 255, 255, 0.05) 100%
    );
    border-radius: 4px;
}
.bi-chart__bar {
    width: 100%;
    background: linear-gradient(
        to top, #14B8A6, #5EEAD4
    );
    border-radius: 4px 4px 0 0;
    min-height: 2px;
    transition: height 0.4s ease;
}
.bi-chart__bar--current {
    background: linear-gradient(
        to top, #E8650A, #FFB680
    );
}
.bi-chart__label {
    font-size: 0.7rem;
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.bi-chart__value {
    font-size: 0.78rem;
    font-weight: 600;
    color: var(--color-text);
}

/* Health score number (big colored numeral) */
.bi-score {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 3rem;
    height: 2.4rem;
    padding: 0 0.6rem;
    border-radius: 6px;
    font-size: 1.15rem;
    font-weight: 700;
    background: rgba(255, 255, 255, 0.06);
    color: var(--color-text);
}
.bi-score--healthy  { background: rgba(16, 185, 129, 0.22); color: #6EE7B7; }
.bi-score--at_risk  { background: rgba(234, 179, 8, 0.22);  color: #FDE68A; }
.bi-score--critical { background: rgba(239, 68, 68, 0.25);  color: #FCA5A5; }

.bi-status--pulse { animation: bi-pulse 1.8s ease-in-out infinite; }
@keyframes bi-pulse {
    0%, 100% { opacity: 1; }
    50%      { opacity: 0.55; }
}

/* Mini per-axis bars (Payment / Engagement / NPS / Uptime / Support) */
.bi-breakdown {
    display: flex;
    gap: 0.35rem;
    align-items: end;
}
.bi-mini {
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    width: 1.6rem;
}
.bi-mini__bar {
    display: block;
    width: 0.7rem;
    background: linear-gradient(to top, #14B8A6, #5EEAD4);
    border-radius: 2px;
    margin-bottom: 0.15rem;
}
.bi-mini__label {
    font-size: 0.65rem;
    color: var(--color-text-muted);
    font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
}

/* Daily Focus card — orange left border */
.bi-focus { border-left: 4px solid #E8650A; }
.bi-focus__list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}
.bi-focus__item {
    display: flex;
    align-items: center;
    gap: 0.7rem;
    padding: 0.6rem 0.85rem;
    background: var(--color-bg-deep);
    border: 1px solid var(--color-border);
    border-radius: 8px;
    border-left: 3px solid #6B7280;
}
.bi-focus__item--p1 { border-left-color: #EF4444; }
.bi-focus__item--p2 { border-left-color: #F97316; }
.bi-focus__item--p3 { border-left-color: #EAB308; }
.bi-focus__icon {
    font-size: 1.05rem;
    flex-shrink: 0;
}
.bi-focus__body {
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
    flex: 1;
    min-width: 0;
}
.bi-focus__body strong {
    color: var(--color-text);
    font-size: 0.9rem;
}
.bi-focus__body small {
    color: var(--color-text-muted);
    font-size: 0.78rem;
}
.bi-focus__clear {
    text-align: center;
    color: #6EE7B7;
    font-weight: 600;
    padding: 1rem 0;
    margin: 0;
}

/* ── 32. Reduced motion ────────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: 0.01ms !important;
        transition-duration: 0.01ms !important;
        scroll-behavior: auto !important;
    }
}


/* ─────────────────────────────────────────────────────────────────────────
   Phase 7 Part 2 — Referrals · Proposals · Case Studies
   Admin dark theme only. No white fallbacks; use --color-bg-raised etc.
   ───────────────────────────────────────────────────────────────────────── */

/* Referral admin row — copy button next to read-only URL input */
.ref-row-link {
    display: flex; gap: 6px; align-items: center;
}
.ref-row-link .form-control--sm {
    flex: 1; min-width: 200px;
}

.ref-conv-detail summary {
    display: inline-block; cursor: pointer; list-style: none;
}
.ref-conv-detail summary::-webkit-details-marker { display: none; }
.ref-conv-form {
    margin-top: 8px; padding: 10px 12px;
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 8px;
    display: flex; flex-direction: column; gap: 8px;
    min-width: 280px;
}
.ref-conv-form label {
    display: flex; flex-direction: column; gap: 4px;
    font-size: 12px; color: var(--color-text-muted);
}
.ref-conv-form input {
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    color: var(--color-text);
    padding: 6px 8px; border-radius: 6px;
    font: inherit;
}

/* Portal referral page */
.portal-referral { max-width: 900px; }
.ref-link-card {
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 12px;
    padding: 22px 24px; margin: 18px 0;
}
.ref-link-card__label {
    display: block; font-size: 11px; letter-spacing: 0.1em;
    text-transform: uppercase; color: var(--color-text-muted);
    margin-bottom: 8px;
}
.ref-link-card__url-row {
    display: flex; gap: 8px; align-items: center;
    margin-bottom: 12px;
}
.ref-link-card__url {
    flex: 1; min-width: 0;
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border-strong);
    color: var(--color-text);
    padding: 10px 12px; border-radius: 8px;
    font: inherit; font-size: 14px;
}
.ref-link-card__actions { display: flex; gap: 8px; flex-wrap: wrap; }
.ref-link-card__code {
    margin-top: 12px; color: var(--color-text-muted);
    font-size: 13px;
}

.ref-stats {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: 12px; margin: 18px 0;
}
.ref-stat {
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 10px;
    padding: 14px 16px;
    text-align: center;
}
.ref-stat__label {
    display: block; font-size: 11px; letter-spacing: 0.1em;
    text-transform: uppercase; color: var(--color-text-muted);
    margin-bottom: 6px;
}
.ref-stat__value {
    display: block; font-size: 22px; font-weight: 700;
    color: var(--color-text);
}
.ref-stat--reward .ref-stat__value { color: var(--color-orange); }

.ref-how {
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 12px;
    padding: 18px 22px; margin-top: 18px;
}
.ref-how h2 {
    color: var(--color-text);
    font-size: 18px; margin: 0 0 10px 0;
}
.ref-how__steps {
    margin: 0; padding-left: 1.2em;
    color: var(--color-text-muted);
}
.ref-how__steps li { margin-bottom: 6px; }
.ref-how__steps strong { color: var(--color-text); }

/* Proposal status badges — dark theme palette */
.prop-badge {
    display: inline-block; padding: 3px 10px; border-radius: 999px;
    font-size: 11px; font-weight: 600; letter-spacing: 0.04em;
    text-transform: uppercase;
    border: 1px solid var(--color-border);
    background: rgba(255,255,255,0.04);
    color: var(--color-text-muted);
}
.prop-badge--draft    { color: var(--color-text-muted); border-color: var(--color-border); }
.prop-badge--sent     { color: var(--color-teal-light); border-color: rgba(20, 184, 166, 0.4); background: rgba(20, 184, 166, 0.1); }
.prop-badge--viewed   { color: var(--color-orange-light); border-color: rgba(255, 123, 30, 0.4); background: rgba(255, 123, 30, 0.12); }
.prop-badge--accepted { color: var(--color-success); border-color: rgba(74, 222, 128, 0.4); background: rgba(74, 222, 128, 0.12); }
.prop-badge--declined { color: var(--color-danger); border-color: rgba(248, 113, 113, 0.4); background: rgba(248, 113, 113, 0.12); }
.prop-badge--expired  { color: var(--color-danger); border-color: rgba(248, 113, 113, 0.25); background: rgba(248, 113, 113, 0.06); }

/* Proposal action buttons row */
.prop-actions {
    display: flex; flex-wrap: wrap; gap: 8px; align-items: center;
}

/* Proposal new form — case study picker */
.cs-picker {
    display: grid; gap: 6px;
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 10px; padding: 10px 12px;
}
.cs-picker__item {
    display: flex; gap: 8px; align-items: baseline;
    padding: 6px 4px; cursor: pointer;
    color: var(--color-text);
}
.cs-picker__item:hover { background: rgba(255,255,255,0.03); border-radius: 6px; }
.cs-picker__item input { margin-top: 4px; }

/* admin-form helpers shared by proposal_new + case_study_form */
.admin-form--wide { max-width: 980px; }
.admin-form .form-row {
    margin-bottom: 14px;
}
.admin-form .form-row > label {
    display: flex; flex-direction: column; gap: 4px;
    font-size: 13px; color: var(--color-text-muted);
    font-weight: 500;
}
.admin-form .form-row input[type=text],
.admin-form .form-row input[type=email],
.admin-form .form-row input[type=number],
.admin-form .form-row input[type=date],
.admin-form .form-row select,
.admin-form .form-row textarea {
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    color: var(--color-text);
    padding: 9px 11px; border-radius: 8px;
    font: inherit; font-size: 14px;
    width: 100%;
}
.admin-form .form-row textarea { min-height: 88px; resize: vertical; }
.admin-form .form-row select option {
    background: var(--color-bg-raised); color: var(--color-text);
}
.admin-form .form-row--split {
    display: grid; gap: 12px;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}
.admin-form .form-row--checkbox label {
    flex-direction: row; align-items: center; gap: 8px;
    color: var(--color-text);
}
.admin-form__actions {
    display: flex; gap: 10px; margin-top: 18px; flex-wrap: wrap;
}

/* admin-dl — definition list used on the proposal detail page */
.admin-dl {
    display: grid;
    grid-template-columns: 140px 1fr;
    gap: 8px 16px;
    margin: 0;
    color: var(--color-text);
}
.admin-dl dt {
    color: var(--color-text-muted);
    font-size: 12px; letter-spacing: 0.04em;
    text-transform: uppercase;
}
.admin-dl dd { margin: 0; }
.admin-dl--inline {
    grid-template-columns: 140px 1fr 140px 1fr;
}

.text-sm { font-size: 12px; }

.proposal-pending {
    min-height: 80vh; display: flex; align-items: center; justify-content: center;
    background: #FFFFFF;
}
.proposal-pending__card {
    max-width: 480px; text-align: center;
    padding: 36px 28px;
    border: 1px solid #E5E5E5; border-radius: 12px;
    background: #FAFAFA;
    color: #1A1A1A;
}
.proposal-pending__card h1 {
    color: #E8650A; font-size: 24px; margin: 16px 0 8px 0;
}


/* ─────────────────────────────────────────────────────────────────────────
   Phase 7 Part 3 — Website Intelligence & Upsell Engine
   Admin dark theme only. Dark tokens for every surface.
   ───────────────────────────────────────────────────────────────────────── */

/* ── Suggestion type chips (admin table + detail) ── */
.intel-type {
    display: inline-block; padding: 3px 9px; border-radius: 999px;
    font-size: 11px; font-weight: 600; letter-spacing: 0.04em;
    text-transform: uppercase;
    border: 1px solid var(--color-border);
    background: rgba(255,255,255,0.04);
    color: var(--color-text-muted);
}
.intel-type--seo         { color: #FFB870; border-color: rgba(255, 184, 112, 0.4); background: rgba(255, 184, 112, 0.10); }
.intel-type--performance { color: #93C5FD; border-color: rgba(147, 197, 253, 0.4); background: rgba(147, 197, 253, 0.10); }
.intel-type--content     { color: #C4B5FD; border-color: rgba(196, 181, 253, 0.4); background: rgba(196, 181, 253, 0.10); }
.intel-type--security    { color: var(--color-danger); border-color: rgba(248, 113, 113, 0.4); background: rgba(248, 113, 113, 0.10); }
.intel-type--conversion  { color: var(--color-orange-light); border-color: rgba(255, 123, 30, 0.4); background: rgba(255, 123, 30, 0.10); }
.intel-type--keyword     { color: var(--color-teal-light); border-color: rgba(20, 184, 166, 0.4); background: rgba(20, 184, 166, 0.10); }
.intel-type--competitor  { color: #F0ABFC; border-color: rgba(240, 171, 252, 0.4); background: rgba(240, 171, 252, 0.10); }
.intel-type--technical   { color: #FCD34D; border-color: rgba(252, 211, 77, 0.4); background: rgba(252, 211, 77, 0.10); }
.intel-type--design      { color: #FBA5C8; border-color: rgba(251, 165, 200, 0.4); background: rgba(251, 165, 200, 0.10); }

/* ── Suggestion status pills (admin + portal share these tokens) ── */
.intel-status {
    display: inline-block; padding: 2px 10px; border-radius: 999px;
    font-size: 11px; font-weight: 600; letter-spacing: 0.04em;
    text-transform: uppercase;
    border: 1px solid var(--color-border);
    background: rgba(255,255,255,0.04);
    color: var(--color-text-muted);
}
.intel-status--pending_review        { color: #FCD34D; border-color: rgba(252, 211, 77, 0.4); background: rgba(252, 211, 77, 0.10); }
.intel-status--approved_to_send      { color: var(--color-teal-light); border-color: rgba(20, 184, 166, 0.4); background: rgba(20, 184, 166, 0.10); }
.intel-status--sent_to_client        { color: var(--color-orange-light); border-color: rgba(255, 123, 30, 0.4); background: rgba(255, 123, 30, 0.10); }
.intel-status--client_approved       { color: var(--color-success); border-color: rgba(74, 222, 128, 0.4); background: rgba(74, 222, 128, 0.10); }
.intel-status--in_scope              { color: var(--color-success); border-color: rgba(74, 222, 128, 0.4); background: rgba(74, 222, 128, 0.10); }
.intel-status--out_of_scope_offered  { color: var(--color-orange); border-color: rgba(232, 101, 10, 0.4); background: rgba(232, 101, 10, 0.10); }
.intel-status--implemented           { color: var(--color-success); border-color: rgba(74, 222, 128, 0.55); background: rgba(74, 222, 128, 0.15); }
.intel-status--client_declined       { color: var(--color-danger); border-color: rgba(248, 113, 113, 0.4); background: rgba(248, 113, 113, 0.10); }
.intel-status--dismissed             { color: var(--color-text-muted); border-color: var(--color-border); background: rgba(255,255,255,0.03); }

.intel-row-title {
    font-weight: 600; color: var(--color-text);
}

.intel-filter-bar {
    display: flex; flex-wrap: wrap; gap: 12px; align-items: end;
    margin-bottom: 16px;
}
.intel-filter-bar label {
    display: flex; flex-direction: column; gap: 4px;
    font-size: 12px; color: var(--color-text-muted);
    font-weight: 500;
}
.intel-filter-bar select,
.intel-filter-bar input[type=month] {
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    color: var(--color-text);
    padding: 7px 10px; border-radius: 8px;
    font: inherit; font-size: 13px; min-width: 140px;
}

.client-intel { margin-top: 24px; }
.client-intel .admin-section__header {
    display: flex; justify-content: space-between; align-items: center;
    gap: 12px; flex-wrap: wrap;
}

.banner {
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    color: var(--color-text); border-radius: 8px;
    padding: 10px 14px; margin: 10px 0;
}
.banner--info {
    background: rgba(20, 184, 166, 0.10);
    border-color: rgba(20, 184, 166, 0.4);
    color: var(--color-teal-light);
}

/* Reusable in suggestion detail "raw AI" pre block. */
.ops-pre {
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    color: var(--color-text);
    padding: 12px 14px; border-radius: 8px;
    overflow-x: auto; max-height: 360px;
    white-space: pre-wrap; word-break: break-word;
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
    font-size: 12px; line-height: 1.5;
}

/* ── Client portal — recommendations list ── */
.portal-suggestions { max-width: 880px; }
.rec-list { display: flex; flex-direction: column; gap: 16px; margin-top: 18px; }
.rec-card {
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-left: 3px solid var(--color-border-strong);
    border-radius: 12px;
    padding: 18px 22px;
}
.rec-card--sent_to_client { border-left-color: var(--color-orange); }
.rec-card--client_approved,
.rec-card--in_scope,
.rec-card--implemented { border-left-color: var(--color-success); }
.rec-card--client_declined,
.rec-card--dismissed { border-left-color: var(--color-text-muted); }
.rec-card--out_of_scope_offered { border-left-color: var(--color-orange-light); }

.rec-card__head {
    display: flex; justify-content: space-between; gap: 12px;
    align-items: flex-start; margin-bottom: 8px;
}
.rec-card__title { margin: 4px 0 0 0; font-size: 18px; color: var(--color-text); }
.rec-card__desc { color: var(--color-text); margin: 8px 0; }
.rec-card__impact {
    background: rgba(232, 101, 10, 0.08);
    border: 1px solid rgba(232, 101, 10, 0.25);
    color: var(--color-text);
    padding: 10px 14px; border-radius: 8px; margin: 8px 0;
}
.rec-card__meta {
    display: flex; flex-wrap: wrap; gap: 14px; align-items: center;
    margin: 10px 0; color: var(--color-text-muted); font-size: 13px;
}
.rec-investment { color: var(--color-text); }
.rec-investment--included { color: var(--color-success); }
.rec-card__actions {
    display: flex; gap: 10px; margin-top: 14px;
}

.rec-type {
    display: inline-block; padding: 2px 9px; border-radius: 999px;
    font-size: 10.5px; font-weight: 700; letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--color-text-muted);
    background: rgba(255,255,255,0.04);
    border: 1px solid var(--color-border);
}
.rec-type--seo         { color: #FFB870; border-color: rgba(255, 184, 112, 0.4); }
.rec-type--performance { color: #93C5FD; border-color: rgba(147, 197, 253, 0.4); }
.rec-type--content     { color: #C4B5FD; border-color: rgba(196, 181, 253, 0.4); }
.rec-type--security    { color: var(--color-danger); border-color: rgba(248, 113, 113, 0.4); }
.rec-type--conversion  { color: var(--color-orange-light); border-color: rgba(255, 123, 30, 0.4); }
.rec-type--keyword     { color: var(--color-teal-light); border-color: rgba(20, 184, 166, 0.4); }

.rec-status {
    display: inline-block; padding: 2px 9px; border-radius: 999px;
    font-size: 10.5px; font-weight: 600; letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--color-text-muted);
    background: rgba(255,255,255,0.04);
    border: 1px solid var(--color-border);
}
.rec-status--sent_to_client       { color: var(--color-orange-light); border-color: rgba(255, 123, 30, 0.4); }
.rec-status--client_approved,
.rec-status--in_scope,
.rec-status--implemented          { color: var(--color-success); border-color: rgba(74, 222, 128, 0.4); }
.rec-status--client_declined,
.rec-status--dismissed            { color: var(--color-text-muted); }
.rec-status--out_of_scope_offered { color: var(--color-orange); border-color: rgba(232, 101, 10, 0.4); }

.portal-nav__dot--alert { background: var(--color-orange); }


/* ─────────────────────────────────────────────────────────────────────────
   Phase 7 Part 5 — Competitor Content Gap Tracker
   Admin dark theme only. No white fallbacks anywhere.
   ───────────────────────────────────────────────────────────────────────── */

/* Competitor list on client detail */
.competitor-list {
    list-style: none; margin: 0; padding: 0;
    display: flex; flex-direction: column; gap: 8px;
}
.competitor-list__item {
    display: flex; justify-content: space-between; align-items: flex-start;
    gap: 12px; padding: 12px 14px;
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 8px;
}
.competitor-list__main { flex: 1; min-width: 0; }
.competitor-list__main strong {
    display: block; color: var(--color-text); margin-bottom: 2px;
}
.competitor-list__domain {
    font-size: 12px; color: var(--color-text-muted);
    word-break: break-all;
}
.competitor-list__domain:hover { color: var(--color-orange-light); }
.competitor-list__actions { display: flex; gap: 6px; flex-shrink: 0; }

.competitor-empty {
    background: rgba(232, 101, 10, 0.08);
    border: 1px solid rgba(232, 101, 10, 0.3);
    border-radius: 8px;
    padding: 12px 14px; color: var(--color-text);
}
.competitor-empty p { margin: 0; }

.competitor-form {
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 8px;
    padding: 14px; margin-top: 10px;
}

/* Gap report — overall assessment block */
.gap-assessment {
    border-left: 3px solid var(--color-teal-light);
}

/* Gap cards on detail page */
.gap-list { display: flex; flex-direction: column; gap: 14px; }
.gap-card {
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-left: 3px solid var(--color-border-strong);
    border-radius: 10px;
    padding: 16px 20px;
    color: var(--color-text);
}
.gap-card--high   { border-left-color: var(--color-danger); }
.gap-card--medium { border-left-color: var(--color-orange); }
.gap-card--low    { border-left-color: var(--color-teal-light); }

.gap-card__head {
    display: flex; gap: 10px; flex-wrap: wrap; align-items: center;
    margin-bottom: 6px;
}
.gap-card__title {
    margin: 4px 0 8px 0; font-size: 17px; color: var(--color-text);
}

.gap-priority {
    display: inline-block; padding: 3px 10px; border-radius: 999px;
    font-size: 10.5px; font-weight: 700; letter-spacing: 0.04em;
    text-transform: uppercase;
    border: 1px solid var(--color-border);
    color: var(--color-text-muted);
    background: rgba(255,255,255,0.04);
}
.gap-priority--high {
    color: var(--color-danger);
    border-color: rgba(248, 113, 113, 0.4);
    background: rgba(248, 113, 113, 0.12);
}
.gap-priority--medium {
    color: var(--color-orange);
    border-color: rgba(232, 101, 10, 0.4);
    background: rgba(232, 101, 10, 0.10);
}
.gap-priority--low {
    color: var(--color-teal-light);
    border-color: rgba(20, 184, 166, 0.4);
    background: rgba(20, 184, 166, 0.10);
}

.gap-card__action {
    background: rgba(232, 101, 10, 0.08);
    border: 1px solid rgba(232, 101, 10, 0.25);
    border-radius: 8px;
    padding: 10px 14px; margin: 10px 0;
    color: var(--color-text);
}
.gap-card__action code {
    background: var(--color-bg-raised);
    padding: 1px 6px; border-radius: 4px;
    color: var(--color-orange-light);
    font-size: 12px;
}
.gap-card__cta { margin-top: 10px; }


/* ─────────────────────────────────────────────────────────────────────────
   Admin Sidebar Layout (Phase 7 — nav overhaul)
   Fixed left sidebar (240px desktop / 280px slide-in mobile). Replaces
   the legacy .admin-header top nav. Dark tokens throughout.
   ───────────────────────────────────────────────────────────────────────── */

.admin-wrapper {
    display: flex;
    min-height: 100vh;
}

#admin-sidebar {
    width: 240px;
    min-width: 240px;
    background: #070614;
    border-right: 1px solid var(--color-border);
    height: 100vh;
    position: fixed;
    top: 0;
    left: 0;
    overflow-y: auto;
    z-index: 1000;
    display: flex;
    flex-direction: column;
    color: var(--color-text);
}

#admin-sidebar::-webkit-scrollbar { width: 6px; }
#admin-sidebar::-webkit-scrollbar-track { background: transparent; }
#admin-sidebar::-webkit-scrollbar-thumb {
    background: rgba(255,255,255,0.08); border-radius: 3px;
}
#admin-sidebar::-webkit-scrollbar-thumb:hover {
    background: rgba(255,255,255,0.15);
}

/* Override .admin-main here — was minimal padding in the legacy
   top-nav layout, now needs to dodge the sidebar. */
.admin-main {
    margin-left: 240px;
    flex: 1;
    min-width: 0;
    padding: 24px;
    padding-bottom: 64px;
}

/* ── Logo block at top of sidebar ── */
.sidebar-logo {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    padding: 16px;
    border-bottom: 1px solid var(--color-border);
}
.sidebar-logo__link {
    display: flex;
    align-items: center;
    gap: 10px;
    color: var(--color-text);
    text-decoration: none;
    flex: 1;
    min-width: 0;
}
.sidebar-logo__link img {
    width: 32px; height: 32px; display: block;
    border-radius: 6px;
}
.sidebar-logo__text {
    display: flex; flex-direction: column;
    line-height: 1.2; min-width: 0;
}
.sidebar-logo__name {
    font-size: 13px;
    font-weight: 700;
    color: var(--color-text);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.sidebar-logo__badge {
    font-size: 10px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--color-orange);
    font-weight: 700;
    margin-top: 2px;
}

#sidebar-close {
    display: none;
    background: transparent;
    border: 1px solid var(--color-border);
    color: var(--color-text-muted);
    width: 32px; height: 32px;
    border-radius: 6px;
    font-size: 14px;
    cursor: pointer;
    line-height: 1;
}
#sidebar-close:hover {
    color: var(--color-text);
    background: rgba(255,255,255,0.04);
}

/* ── Nav list ── */
.sidebar-nav {
    flex: 1;
    padding: 8px 0 16px;
    display: flex;
    flex-direction: column;
}

.nav-group-label {
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: #64748B;
    padding: 16px 16px 4px;
}

/* Scoped to the admin sidebar so we don't bleed into the public
   site nav (which also uses a `.nav-link` class but with totally
   different colors + sizing). The unscoped rules used to clobber
   .nav-link--cta on the public Client Login button. */
#admin-sidebar .nav-link {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    padding: 8px 16px;
    margin: 1px 8px;
    border-radius: 6px;
    color: #94A3B8;
    text-decoration: none;
    font-size: 14px;
    font-weight: 500;
    transition: color 0.15s ease, background-color 0.15s ease;
    border-left: 3px solid transparent;
    /* Keep the 3px indicator from shifting text — compensate padding. */
    padding-left: 13px;
}
#admin-sidebar .nav-link:hover {
    color: #FFFFFF;
    background: #1E293B;
}
#admin-sidebar .nav-link.active {
    color: var(--color-orange);
    background: #1A1A2E;
    border-left-color: var(--color-orange);
}
.nav-link__text {
    flex: 1;
    min-width: 0;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* ── Availability windows page ─────────────────────────────────────
   Clean per-day rows for /admin-dashboard/schedule/availability/.
   Each window is one horizontal line: time → time, timezone, save,
   then the disable/delete cluster. Wraps to two lines only when the
   viewport is narrow. */
.admin-card--accent {
    border-left: 4px solid var(--color-orange, #E8650A);
}
.avail-empty__title { margin-top: 0; }
.avail-empty__desc { margin-bottom: 1rem; }
.avail-empty__cta { margin-top: .5rem; }

.avail-week {
    display: flex;
    flex-direction: column;
    gap: .25rem;
}
.avail-day {
    display: grid;
    grid-template-columns: 110px 1fr;
    align-items: start;
    gap: 1rem;
    padding: .85rem 0;
    border-bottom: 1px solid rgba(148, 163, 184, 0.12);
}
.avail-day:last-child { border-bottom: none; }
.avail-day__name {
    font-weight: 600;
    color: #E2E8F0;
    padding-top: .5rem;
}
.avail-day--closed .avail-day__name { color: #64748B; font-weight: 500; }
.avail-day__windows {
    display: flex;
    flex-direction: column;
    gap: .5rem;
    min-width: 0;
}

.avail-window {
    display: flex;
    align-items: center;
    gap: .75rem;
    flex-wrap: wrap;
}
.avail-window--off { opacity: 0.55; }
.avail-window__edit {
    display: flex;
    align-items: center;
    gap: .5rem;
    flex-wrap: wrap;
}
.avail-window__actions {
    display: flex;
    align-items: center;
    gap: .5rem;
    flex-wrap: wrap;
}

.avail-input {
    min-width: 0;
}
.avail-input--time {
    width: 13rem;
    padding-top: .55rem;
    padding-bottom: .55rem;
    font-size: 15px;
}
.avail-arrow {
    color: #94A3B8;
    font-weight: 600;
    padding: 0 .35rem;
    font-size: 1.05rem;
}
/* Native time-picker clock indicator. Chromium/Edge default is dark
   grey on dark backgrounds — invert it to white so it reads cleanly. */
.avail-input--time::-webkit-calendar-picker-indicator {
    filter: invert(1) brightness(1.4);
    cursor: pointer;
    opacity: 0.95;
}
.avail-input--time::-webkit-calendar-picker-indicator:hover {
    opacity: 1;
}

.avail-closed {
    color: #64748B;
    font-style: italic;
    padding-top: .55rem;
    display: inline-block;
}
.avail-pill {
    display: inline-block;
    padding: 2px 8px;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.avail-pill--off {
    background: rgba(148, 163, 184, 0.15);
    color: #94A3B8;
}

/* "Delete" deserves to be subordinate to Save / Disable.
   Treat as a destructive link, not a chunky button. */
.btn-link {
    background: transparent;
    border: none;
    color: #F87171;
    padding: 4px 6px;
    font-size: 13px;
    font-weight: 500;
    cursor: pointer;
    border-radius: 4px;
}
.btn-link:hover {
    color: #FCA5A5;
    background: rgba(248, 113, 113, 0.08);
}
.avail-delete { /* no extra rules — keeps a single class to target later */ }

/* Add-window form — one row of labeled fields, all inline. */
.avail-add {
    display: flex;
    align-items: flex-end;
    gap: .75rem;
    flex-wrap: wrap;
}
.avail-add__field {
    display: flex;
    flex-direction: column;
    gap: .25rem;
    min-width: 0;
}
.avail-add__label {
    font-size: .75rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: #94A3B8;
    font-weight: 600;
}
.avail-add__submit {
    padding-bottom: 1px;
}
.avail-add__hint {
    margin-top: .9rem;
    font-size: .85rem;
}

@media (max-width: 720px) {
    .avail-day {
        grid-template-columns: 1fr;
        gap: .35rem;
    }
    .avail-day__name { padding-top: 0; }
    .avail-window { padding-left: .25rem; }
    .avail-input--time { width: 100%; }
}

/* Sub-nav links shown beneath a top-level admin sidebar item when its
   section is active (e.g. Schedule → Google Calendar / Availability /
   Booked calls). Mirrors .nav-link sizing but smaller + indented. */
#admin-sidebar .nav-sublink {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    padding: 5px 16px 5px 36px;
    margin: 0 8px;
    border-radius: 6px;
    color: #64748B;
    text-decoration: none;
    font-size: 13px;
    font-weight: 500;
    transition: color 0.15s ease, background-color 0.15s ease;
}
#admin-sidebar .nav-sublink:hover {
    color: #FFFFFF;
    background: #1E293B;
}
#admin-sidebar .nav-sublink.active {
    color: var(--color-orange);
}

.nav-badge {
    background: var(--color-orange);
    color: #FFFFFF;
    font-size: 11px;
    font-weight: 600;
    padding: 1px 6px;
    border-radius: 10px;
    min-width: 18px;
    text-align: center;
    line-height: 1.4;
}
.nav-badge--empty {
    background: rgba(255,255,255,0.06);
    color: var(--color-text-muted);
}

/* ── Bottom block (user + sign out) ── */
.sidebar-bottom {
    margin-top: auto;
    padding: 16px;
    border-top: 1px solid var(--color-border);
}
.sidebar-user-email {
    font-size: 12px;
    color: #64748B;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    display: block;
    margin-bottom: 8px;
}
.sidebar-signout-form { margin: 0; display: block; }
.sidebar-signout {
    background: none;
    border: 0;
    padding: 0;
    font: inherit;
    font-size: 13px;
    color: #64748B;
    cursor: pointer;
    text-align: left;
}
.sidebar-signout:hover {
    color: var(--color-danger);
}

/* ── Mobile overlay + hamburger ── */
#sidebar-overlay {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.5);
    z-index: 998;
}
#sidebar-overlay.active { display: block; }

#hamburger-btn {
    display: none;
    position: fixed;
    top: 12px; left: 12px;
    z-index: 999;
    width: 40px; height: 40px;
    background: #0F172A;
    border: 1px solid var(--color-border);
    border-radius: 8px;
    cursor: pointer;
    padding: 10px 8px;
    flex-direction: column;
    justify-content: space-between;
    align-items: center;
}
#hamburger-btn span {
    display: block;
    width: 20px;
    height: 2px;
    background: var(--color-text);
    border-radius: 2px;
    transition: background 0.15s ease;
}
#hamburger-btn:hover span { background: var(--color-orange); }

/* ── Mobile: hide sidebar by default, hamburger visible ── */
@media (max-width: 768px) {
    #admin-sidebar {
        transform: translateX(-100%);
        transition: transform 0.25s ease;
        width: 280px;
        min-width: 280px;
    }
    #admin-sidebar.open {
        transform: translateX(0);
        box-shadow: 4px 0 24px rgba(0,0,0,0.5);
    }
    .admin-main {
        margin-left: 0;
        padding: 16px;
        padding-top: 60px;
    }
    #hamburger-btn { display: flex; }
    #sidebar-close { display: inline-flex;
                     align-items: center;
                     justify-content: center; }
}

@media (min-width: 769px) {
    #hamburger-btn,
    #sidebar-overlay,
    #sidebar-close { display: none !important; }
}


/* ─────────────────────────────────────────────────────────────────────────
   Public site fixes (Phase 7 round 2)
   - service-card CTA pinned to bottom (homepage)
   - pricing "Most Popular" badge positioning
   - hosting section as a centered horizontal banner
   - public Admin nav link (staff-only)
   ───────────────────────────────────────────────────────────────────────── */

/* Fix 3 — Pin .card__link to the bottom of each homepage service card
   regardless of how much text sits above it. Uses flex-column +
   space-between which only kicks in for cards with the eyebrow link. */
.cards .card {
    display: flex;
    flex-direction: column;
}
.cards .card > .card__link {
    margin-top: auto;
    align-self: flex-start;
    padding-top: var(--space-2);
}

/* Fix 6 BUG A — Pricing "Most Popular" badge sits ON the card, not in
   the gutter between cards. Card establishes positioning context;
   badge anchors to the card's top edge and centers via translateX. */
.card--pricing {
    position: relative;
    overflow: visible;
}
.card--pricing .card__badge {
    position: absolute;
    top: -16px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 10;
    white-space: nowrap;
}
/* Featured cards need extra top padding so the badge doesn't bump
   the title block. */
.card--pricing.card--featured {
    padding-top: calc(var(--space-4) + 8px);
}

/* Pricing card columns must be equal-width regardless of content
   length, so the badge always centers visually. */
.cards.cards--2col {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

/* Fix 6 BUG B — Hosting card spans the container as a horizontal
   banner: title + price + CTA on the left, feature bullets on the
   right. Centered on the page since it doesn't share the row with
   anything else. */
.hosting-banner {
    display: grid;
    grid-template-columns: minmax(220px, 1fr) 2fr;
    gap: var(--space-5);
    align-items: center;
    max-width: 920px;
    margin: 0 auto;
    padding: var(--space-4) var(--space-5);
}
.hosting-banner__lead {
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
}
.hosting-banner__lead .card__title {
    margin: 0;
    font-size: 1.5rem;
}
.hosting-banner__lead .card__price {
    margin: 0;
}
.hosting-banner__lead .btn-secondary {
    align-self: flex-start;
    margin-top: var(--space-2);
}
.hosting-banner__features {
    margin: 0;
    /* Looser spacing here than the pricing cards — the banner has
       fewer bullets and more horizontal room, so spacing it out
       reads as a real checklist instead of a tight block. */
    gap: 0.875rem;
}
.hosting-banner__features li {
    font-size: 1rem;
    line-height: 1.6;
}

@media (max-width: 720px) {
    .hosting-banner {
        grid-template-columns: 1fr;
        gap: var(--space-3);
        text-align: left;
    }
}

/* Fix 1 — Admin link for staff users in the public nav.
   Muted, small, no button styling — sits beside Client Login without
   competing for attention. */
.nav-link--admin {
    font-size: 0.8125rem;
    color: var(--color-text-muted);
    opacity: 0.7;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}
.nav-link--admin:hover {
    color: var(--color-orange);
    opacity: 1;
    background: transparent;
}


/* ─────────────────────────────────────────────────────────────────────────
   Lead delete (single + bulk) + admin flash messages
   ───────────────────────────────────────────────────────────────────────── */

.admin-messages {
    display: flex; flex-direction: column; gap: 8px;
    margin-bottom: 18px;
}
.admin-message {
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-left: 3px solid var(--color-orange);
    color: var(--color-text);
    padding: 10px 14px;
    border-radius: 8px;
    font-size: 14px;
}
.admin-message--success {
    border-left-color: var(--color-success);
    background: rgba(74, 222, 128, 0.06);
}
.admin-message--warning {
    border-left-color: var(--color-orange);
    background: rgba(232, 101, 10, 0.06);
}
.admin-message--error {
    border-left-color: var(--color-danger);
    background: rgba(248, 113, 113, 0.06);
}

.lead-bulk-bar {
    display: flex; gap: 12px; align-items: center;
    padding: 10px 14px; margin: 12px 0;
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 8px;
}
.lead-bulk-bar__check {
    display: inline-flex; gap: 6px; align-items: center;
    color: var(--color-text-muted); font-size: 13px;
    cursor: pointer;
}
.lead-bulk-bar__check input { cursor: pointer; }
.lead-table__col-check { width: 32px; text-align: center; }
.lead-table__col-check input { cursor: pointer; }

.lead-danger-zone {
    margin-top: 32px;
    border-top: 1px solid var(--color-border);
    padding-top: 18px;
}
.lead-danger-zone .admin-section__header h2 {
    color: var(--color-danger);
}


/* ─────────────────────────────────────────────────────────────────────────
   Legal pages — Privacy Policy + Terms of Service
   Centered max 800px, Georgia serif body, orange section headings.
   .hero--compact dials the hero down so it doesn't dominate a
   doc-heavy page.
   ───────────────────────────────────────────────────────────────────────── */

.hero--compact { padding-block: var(--space-5); }
.hero--compact h1 { font-size: clamp(2.25rem, 5vw, 3.25rem); }

.legal-doc {
    max-width: 800px;
    margin: 0 auto;
    color: var(--color-text);
    font-family: Georgia, 'Times New Roman', serif;
    font-size: 1.0625rem;
    line-height: 1.75;
}

.legal-doc h2 {
    font-family: var(--font-sans, Arial, Helvetica, sans-serif);
    color: var(--color-orange);
    font-size: 1.375rem;
    font-weight: 700;
    margin-top: var(--space-5);
    margin-bottom: var(--space-2);
    letter-spacing: -0.005em;
}
.legal-doc h2:first-of-type { margin-top: var(--space-3); }

.legal-doc h3 {
    font-family: var(--font-sans, Arial, Helvetica, sans-serif);
    color: var(--color-text);
    font-size: 1.0625rem;
    font-weight: 700;
    margin-top: var(--space-3);
    margin-bottom: var(--space-1);
}

.legal-doc p { margin-bottom: var(--space-2); }

.legal-doc ul {
    margin: 0 0 var(--space-3) 0;
    padding-left: 1.4em;
}
.legal-doc ul li {
    margin-bottom: 0.5rem;
}

.legal-doc strong { color: var(--color-text); font-weight: 700; }

.legal-doc a {
    color: var(--color-orange);
    text-decoration: underline;
    text-underline-offset: 2px;
}
.legal-doc a:hover { color: var(--color-orange-light); }

.legal-doc__effective {
    display: inline-block;
    padding: 6px 14px;
    border: 1px solid var(--color-border);
    border-radius: 999px;
    background: var(--color-bg-raised);
    color: var(--color-text-muted);
    font-family: var(--font-sans, Arial, Helvetica, sans-serif);
    font-size: 0.8125rem;
    font-weight: 600;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    margin-bottom: var(--space-4);
}

.legal-doc__address {
    margin-top: var(--space-3);
    padding: var(--space-3) var(--space-4);
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-left: 3px solid var(--color-orange);
    border-radius: 8px;
    font-style: normal;
}

/* Footer legal-link row */
.footer-legal {
    display: inline-flex;
    gap: 8px;
    align-items: center;
    font-size: 0.8125rem;
}
.footer-legal a {
    color: var(--color-text-muted);
    text-decoration: none;
    border-bottom: 1px solid transparent;
    transition: color var(--transition), border-color var(--transition);
}
.footer-legal a:hover {
    color: var(--color-orange);
    border-bottom-color: var(--color-orange);
}
.footer-legal span { opacity: 0.5; }


/* ─────────────────────────────────────────────────────────────────────────
   Tier 1 analytics — admin conversion dashboard + portal Visitor Analytics
   Dark tokens throughout for the admin views; portal cards use shared
   stat-card tokens.
   ───────────────────────────────────────────────────────────────────────── */

/* Stat-card colour bands (admin + portal share the modifiers). */
.ca-stat--good .admin-stat__value,
.va-stat--good .stat-card__value {
    color: var(--color-success);
}
.ca-stat--ok .admin-stat__value,
.va-stat--ok .stat-card__value {
    color: var(--color-orange);
}
.ca-stat--poor .admin-stat__value,
.va-stat--poor .stat-card__value {
    color: var(--color-danger);
}
.ca-stat--muted .admin-stat__value,
.va-stat--muted .stat-card__value {
    color: var(--color-text-muted);
}

/* ── Conversion funnel ── */
.funnel {
    display: flex; flex-direction: column;
    gap: 6px; margin-top: 6px;
    max-width: 720px;
}
.funnel__step {
    display: flex; justify-content: space-between;
    align-items: center; gap: 14px;
    padding: 12px 16px;
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-left: 3px solid var(--color-orange);
    border-radius: 8px;
    font-size: 14px;
}
.funnel__step--final {
    border-left-color: var(--color-success);
    background: rgba(74, 222, 128, 0.06);
}
.funnel__label { color: var(--color-text); }
.funnel__value {
    color: var(--color-text); font-weight: 700;
    font-variant-numeric: tabular-nums;
}
.funnel__arrow {
    color: var(--color-text-muted);
    text-align: center; line-height: 1;
    font-size: 18px;
}

/* ── Scroll-depth distribution bars ── */
.scroll-dist {
    display: flex; flex-direction: column;
    gap: 10px; margin-top: 6px;
}
.scroll-dist__row {
    display: grid;
    grid-template-columns: 80px 1fr 120px;
    gap: 12px; align-items: center;
}
.scroll-dist__label {
    color: var(--color-text-muted);
    font-size: 12px; letter-spacing: 0.04em;
    text-transform: uppercase;
}
.scroll-dist__bar-wrap {
    height: 14px; border-radius: 7px;
    background: rgba(255,255,255,0.05);
    border: 1px solid var(--color-border);
    overflow: hidden;
}
.scroll-dist__bar {
    height: 100%; border-radius: 7px 0 0 7px;
    min-width: 2px;
    transition: width 0.2s ease;
}
.scroll-dist__bar--poor { background: var(--color-danger); }
.scroll-dist__bar--ok   { background: var(--color-orange); }
.scroll-dist__bar--teal { background: var(--color-teal-light); }
.scroll-dist__bar--good { background: var(--color-success); }
.scroll-dist__count {
    color: var(--color-text-muted);
    font-size: 13px;
    font-variant-numeric: tabular-nums;
    text-align: right;
}

/* ── Click heatmap grid ── */
.heatmap-grid {
    display: flex; flex-direction: column; gap: 2px;
    margin-top: 6px;
    max-width: 600px;
    aspect-ratio: 1.4 / 1;
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 8px;
    padding: 6px;
}
.heatmap-grid__row {
    display: flex; gap: 2px; flex: 1;
}
.heatmap-cell {
    flex: 1; border-radius: 2px;
    background: rgba(255,255,255,0.03);
    transition: background 0.15s ease;
}
.heatmap-cell--b1 { background: rgba(20, 184, 166, 0.18); }
.heatmap-cell--b2 { background: rgba(20, 184, 166, 0.42); }
.heatmap-cell--b3 { background: rgba(232, 101, 10, 0.55); }
.heatmap-cell--b4 { background: var(--color-orange); }

/* ── Portal Visitor Analytics ── */
.va-section { margin-top: var(--space-5); }
.portal-section__sub {
    color: var(--color-text-muted);
    margin-bottom: var(--space-3);
}

.va-scroll-insight {
    margin: var(--space-3) 0;
    padding: var(--space-3) var(--space-4);
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 10px;
}
.va-scroll-bar {
    height: 10px; border-radius: 5px;
    background: rgba(255,255,255,0.05);
    border: 1px solid var(--color-border);
    overflow: hidden;
    margin-bottom: 10px;
}
.va-scroll-bar__fill {
    height: 100%;
    border-radius: 5px 0 0 5px;
    transition: width 0.2s ease;
}
.va-scroll-bar__fill--good { background: var(--color-success); }
.va-scroll-bar__fill--ok   { background: var(--color-orange); }
.va-scroll-bar__fill--poor { background: var(--color-danger); }
.va-scroll-bar__fill--muted { background: var(--color-text-muted); }
.va-insight {
    color: var(--color-text);
    margin: 0;
}

.va-callout {
    padding: 12px 16px;
    border-radius: 10px;
    margin: 14px 0;
    color: var(--color-text);
    border: 1px solid var(--color-border);
}
.va-callout--warn {
    border-color: rgba(232, 101, 10, 0.4);
    background: rgba(232, 101, 10, 0.08);
}
.va-callout--good {
    border-color: rgba(74, 222, 128, 0.4);
    background: rgba(74, 222, 128, 0.08);
}

.va-top-pages {
    list-style: none; margin: 0; padding: 0;
    display: flex; flex-direction: column; gap: 6px;
}
.va-top-pages__item {
    display: flex; justify-content: space-between;
    gap: 12px;
    padding: 10px 14px;
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 8px;
}
.va-top-pages__url {
    color: var(--color-text);
    overflow: hidden; text-overflow: ellipsis;
    white-space: nowrap;
}
.va-top-pages__views {
    color: var(--color-text-muted);
    font-size: 13px;
    white-space: nowrap;
}

.va-upsell {
    margin-top: var(--space-4);
    padding: var(--space-4);
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-left: 3px solid var(--color-orange);
    border-radius: 12px;
}
.va-upsell h3 {
    color: var(--color-orange);
    margin: 0 0 8px 0;
}
.va-upsell p { color: var(--color-text); }


/* ─────────────────────────────────────────────────────────────────────────
   Tier 2 — Session recording (rrweb) admin + portal styling
   Dark tokens. The replay stage gives the rrweb-player iframe a white
   surface (rrweb expects to render the original page on light bg).
   ───────────────────────────────────────────────────────────────────────── */

.recordings-toolbar {
    display: flex; justify-content: space-between;
    gap: 14px; align-items: center; flex-wrap: wrap;
    margin: 6px 0 12px;
}

.exp-pill {
    display: inline-block; padding: 2px 8px; border-radius: 999px;
    font-size: 11px; font-weight: 600;
    background: rgba(255,255,255,0.04);
    color: var(--color-text-muted);
    border: 1px solid var(--color-border);
}
.exp-pill--soon {
    color: var(--color-danger);
    border-color: rgba(248, 113, 113, 0.4);
    background: rgba(248, 113, 113, 0.08);
}

/* The replay container — give the player a white-ish backdrop and a
   max width so embedded site frames look natural. */
.rrweb-stage {
    margin: 18px auto;
    max-width: 1080px;
    background: #FFFFFF;
    border: 1px solid var(--color-border);
    border-radius: 12px;
    padding: 12px;
    overflow: auto;
}
.rrweb-stage .rr-player {
    margin: 0 auto;
}

/* Stat-card warning state used in the portal "Expiring < 7 days" tile. */
.stat-card--warn .stat-card__value {
    color: var(--color-orange);
}

/* Portal retention notice — orange info box at top of recordings page. */
.retention-notice {
    background: rgba(232, 101, 10, 0.10);
    border: 1px solid rgba(232, 101, 10, 0.35);
    border-left: 3px solid var(--color-orange);
    color: var(--color-text);
    padding: 12px 16px;
    border-radius: 10px;
    margin: 18px 0;
    font-size: 14px;
    line-height: 1.55;
}

/* Tighter admin-table action cell when buttons stack mostly icon-only. */
.admin-table__actions .btn-sm + .btn-sm {
    margin-left: 4px;
}
.admin-table__actions form {
    margin: 0;
    display: inline-block;
}


/* ─────────────────────────────────────────────────────────────────────────
   Click activity heatmap (replaces the old 10x10 grid) + replayer stage
   ───────────────────────────────────────────────────────────────────────── */

.click-activity {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 24px;
    align-items: start;
    margin-top: 8px;
}
@media (max-width: 900px) {
    .click-activity { grid-template-columns: 1fr; }
}

.section-bars {
    display: flex; flex-direction: column; gap: 10px;
}
.section-bar {
    display: grid;
    grid-template-columns: 140px 1fr 60px;
    gap: 12px; align-items: center;
}
.section-bar__label {
    color: var(--color-text-muted);
    font-size: 12px;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}
.section-bar__track {
    height: 18px; border-radius: 9px;
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    overflow: hidden;
}
.section-bar__fill {
    height: 100%; border-radius: 9px 0 0 9px;
    background: var(--color-orange);
    transition: width 0.2s ease;
    min-width: 2px;
}
.section-bar__count {
    color: var(--color-text);
    font-variant-numeric: tabular-nums;
    text-align: right;
    font-weight: 600;
}

.click-canvas {
    display: block;
    width: 100%; max-width: 600px;
    height: auto; aspect-ratio: 3 / 2;
    background: #0F172A;
    border: 1px solid var(--color-border);
    border-radius: 8px;
}

/* ── rrweb Replayer stage + simple controls ── */

.replayer-stage {
    background: #FFFFFF;
    border: 1px solid var(--color-border);
    border-radius: 8px;
    min-height: 540px;
    /* Hide horizontal overflow — the wrapper is scaled by JS to fit. */
    overflow: hidden;
    margin: 14px 0;
    padding: 10px;
    position: relative;
}
/* rrweb injects .replayer-wrapper at the captured viewport size
   (e.g. 1920x1080). We scale it down via transform so it always
   fits the stage width. recording_replay.js sets transform + the
   stage height; transform-origin must be top-left here so the
   scale shrinks from the corner, not from the wrapper's centre. */
.replayer-stage .replayer-wrapper {
    margin: 0;
    transform-origin: top left;
}

/* The rrweb Replayer creates a .replayer-mouse div for the cursor
   but the standalone bundle ships no default styling, so it's an
   invisible 0×0 element. Draw an arrow cursor as an inline SVG
   data URI (CSP allows data: in img-src). .active is the mousedown
   state — tint orange so clicks pop visually. */
.replayer-stage .replayer-mouse {
    position: absolute;
    width: 20px;
    height: 20px;
    margin: -3px 0 0 -3px;
    transition: top 0.05s linear, left 0.05s linear;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24'><path d='M2.5 1.5 L2.5 19 L7.5 14.5 L10.8 22 L13.6 20.8 L10.3 13.5 L17 13.5 Z' fill='white' stroke='black' stroke-width='1.4' stroke-linejoin='round'/></svg>");
    background-size: contain;
    background-repeat: no-repeat;
    background-position: 0 0;
    pointer-events: none;
    z-index: 10000;
}
.replayer-stage .replayer-mouse.active {
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24'><path d='M2.5 1.5 L2.5 19 L7.5 14.5 L10.8 22 L13.6 20.8 L10.3 13.5 L17 13.5 Z' fill='%23E8650A' stroke='black' stroke-width='1.4' stroke-linejoin='round'/></svg>");
}
/* The mouse-tail canvas rrweb draws for the trail (mouseTail option
   in recording_replay.js) — keep it above page content but below
   the cursor SVG so the cursor is always on top of its own trail. */
.replayer-stage .replayer-mouse-tail {
    position: absolute;
    pointer-events: none;
    z-index: 9999;
}

.replayer-empty {
    padding: 32px 24px;
    color: var(--color-text-muted);
    text-align: center;
    line-height: 1.6;
    font-size: 14px;
}

.replayer-controls {
    display: flex; gap: 8px; align-items: center; flex-wrap: wrap;
    padding: 10px 12px;
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 8px;
    margin-bottom: 14px;
}
.replayer-speed {
    display: inline-flex; gap: 6px; align-items: center;
    color: var(--color-text-muted);
    font-size: 13px;
}
.replayer-speed select {
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    color: var(--color-text);
    padding: 4px 8px; border-radius: 6px;
    font: inherit;
}


/* ── Replay diagnostics strip (admin + portal) ── */
.replayer-diag {
    margin-top: 4px;
    font-variant-numeric: tabular-nums;
}
.replayer-diag code {
    background: var(--color-bg-raised);
    padding: 1px 6px; border-radius: 4px;
    color: var(--color-text);
    font-size: 12px;
}
.replayer-diag--ok  { color: var(--color-success); font-weight: 600; }
.replayer-diag--bad { color: var(--color-danger);  font-weight: 600; }


/* ──────────────────────────────────────────────────────────────────
   Onboarding / account-setup page — full-screen, no chrome.
   Standalone templates (does NOT extend the public base.html). Uses
   the `.setup-*` prefix to avoid colliding with the unrelated admin
   widget that owns the `.onboarding-card` class earlier in this file.
   Colour palette mirrors the admin dark theme so the setup page
   visually reads as "inside the system" rather than a marketing page.
   ────────────────────────────────────────────────────────────────── */
.setup-body {
    background: #070614;
    color: #F8FAFC;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    min-height: 100vh;
    margin: 0;
    padding: 24px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}
.setup-logo {
    margin-bottom: 32px;
    text-align: center;
}
.setup-logo img { height: 48px; width: auto; }
.setup-card {
    background: #0F172A;
    border: 1px solid #1E293B;
    border-radius: 16px;
    padding: 48px;
    width: 100%;
    max-width: 520px;
    box-shadow: 0 24px 64px rgba(0, 0, 0, 0.4);
}
.setup-card--info { text-align: center; }
.setup-title {
    font-size: 28px;
    font-weight: 700;
    color: #F8FAFC;
    margin: 0 0 8px 0;
}
.setup-subtitle {
    color: #94A3B8;
    font-size: 15px;
    margin: 0 0 36px 0;
    line-height: 1.5;
}
.setup-section-label {
    font-size: 13px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: #E8650A;
    margin: 28px 0 16px 0;
    padding-bottom: 8px;
    border-bottom: 1px solid #1E293B;
}
.setup-section-label:first-of-type { margin-top: 0; }
.setup-field { margin-bottom: 20px; }
.setup-field label {
    display: block;
    font-size: 13px;
    font-weight: 500;
    color: #94A3B8;
    margin-bottom: 6px;
}
.setup-field input[type="password"],
.setup-field input[type="email"],
.setup-field input[type="text"] {
    width: 100%;
    background: #070614;
    border: 1px solid #1E293B;
    border-radius: 8px;
    padding: 12px 16px;
    color: #F8FAFC;
    font-size: 15px;
    outline: none;
    transition: border-color 0.15s;
    box-sizing: border-box;
}
.setup-field input:focus { border-color: #E8650A; }
.setup-field input[readonly],
.setup-field input[disabled] {
    opacity: 0.5;
    cursor: not-allowed;
}
.setup-hints {
    margin-top: 8px;
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.setup-hint {
    font-size: 12px;
    color: #64748B;
    display: flex;
    align-items: center;
    gap: 6px;
}
.setup-hint.is-valid { color: #0D9488; }
.setup-hint::before { content: '○'; font-size: 10px; }
.setup-hint.is-valid::before { content: '✓'; }
.setup-pin-section { margin-bottom: 20px; }
.setup-pin-label {
    display: block;
    font-size: 13px;
    font-weight: 500;
    color: #94A3B8;
    margin-bottom: 8px;
}
.setup-pin-row {
    display: flex;
    gap: 12px;
    margin-top: 8px;
}
.setup-pin-box {
    width: 56px;
    height: 56px;
    background: #070614;
    border: 1px solid #1E293B;
    border-radius: 8px;
    text-align: center;
    font-size: 24px;
    font-weight: 700;
    color: #F8FAFC;
    outline: none;
    transition: border-color 0.15s;
    -webkit-text-security: disc;        /* iOS / Safari */
}
.setup-pin-box:focus { border-color: #E8650A; }
.setup-pin-note {
    font-size: 12px;
    color: #64748B;
    margin: 10px 0 0 0;
    line-height: 1.4;
}
.setup-submit {
    width: 100%;
    background: #E8650A;
    color: #FFFFFF;
    border: none;
    border-radius: 8px;
    padding: 14px;
    font-size: 16px;
    font-weight: 600;
    cursor: pointer;
    margin-top: 32px;
    transition: background 0.15s, transform 0.1s;
}
.setup-submit:hover { background: #d4580a; }
.setup-submit:active { transform: scale(0.99); }
.setup-errors {
    background: rgba(239, 68, 68, 0.1);
    border: 1px solid rgba(239, 68, 68, 0.3);
    border-radius: 8px;
    padding: 12px 16px;
    margin-bottom: 20px;
    color: #FCA5A5;
    font-size: 14px;
}
.setup-errors div + div { margin-top: 4px; }
.setup-footer {
    margin-top: 24px;
    text-align: center;
    color: #64748B;
    font-size: 13px;
}
.setup-footer a { color: #E8650A; text-decoration: none; }
.setup-footer a:hover { text-decoration: underline; }

@media (max-width: 560px) {
    .setup-card { padding: 32px 24px; }
    .setup-title { font-size: 24px; }
    .setup-pin-box { width: 48px; height: 48px; font-size: 22px; }
}


/* ──────────────────────────────────────────────────────────────────
   Public payment page — /pay/<token>/  +  /pay/<token>/success/
   Standalone (no portal nav), dark theme. Mirrors .setup-* but
   prefixed `.pay-*` so the two pages stay independently style-able.
   ────────────────────────────────────────────────────────────────── */
.pay-body {
    background: #070614;
    color: #F8FAFC;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Arial, sans-serif;
    min-height: 100vh;
    margin: 0;
    padding: 24px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}
.pay-logo {
    margin-bottom: 28px;
    text-align: center;
}
.pay-logo img { height: 44px; width: auto; }
.pay-card {
    background: #0F172A;
    border: 1px solid #1E293B;
    border-radius: 16px;
    padding: 40px 40px 36px;
    width: 100%;
    max-width: 480px;
    box-shadow: 0 24px 64px rgba(0, 0, 0, 0.4);
}
.pay-card--info, .pay-card--success { text-align: center; }
.pay-card__head { margin-bottom: 24px; }
.pay-card__eyebrow {
    display: inline-block;
    font-size: 11px;
    font-weight: 700;
    color: #E8650A;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    margin-bottom: 6px;
}
.pay-card__title {
    font-size: 36px;
    font-weight: 700;
    margin: 0 0 4px;
    color: #F8FAFC;
    letter-spacing: -0.02em;
}
.pay-card__title--success {
    font-size: 24px;
    margin: 12px 0 12px;
}
.pay-card__sub {
    color: #94A3B8;
    font-size: 14px;
    margin: 0;
    line-height: 1.5;
}

.pay-lines {
    width: 100%;
    margin: 0 0 24px;
    border-collapse: collapse;
    color: #F8FAFC;
    font-size: 14px;
}
.pay-lines td {
    padding: 10px 0;
    border-bottom: 1px solid #1E293B;
}
.pay-lines__desc {
    color: #94A3B8;
}
.pay-lines__amt {
    text-align: right;
    font-variant-numeric: tabular-nums;
    color: #F8FAFC;
}
.pay-lines__total td {
    border-bottom: none;
    padding-top: 14px;
    font-size: 15px;
    font-weight: 600;
    color: #F8FAFC;
}
.pay-lines__total .pay-lines__desc { color: #F8FAFC; }

.pay-form-wrap {
    margin-top: 24px;
    padding-top: 24px;
    border-top: 1px solid #1E293B;
}
#payment-element { margin-bottom: 16px; }
.pay-message {
    padding: 10px 12px;
    border-radius: 8px;
    font-size: 13px;
    margin-bottom: 12px;
}
.pay-message--error {
    background: rgba(239, 68, 68, 0.1);
    border: 1px solid rgba(239, 68, 68, 0.3);
    color: #FCA5A5;
}
.pay-submit {
    display: block;
    width: 100%;
    background: #E8650A;
    color: #FFFFFF;
    border: none;
    border-radius: 8px;
    padding: 14px;
    font-size: 16px;
    font-weight: 600;
    cursor: pointer;
    transition: background 0.15s;
}
.pay-submit:hover:not(:disabled) { background: #d4580a; }
.pay-submit:disabled { opacity: 0.7; cursor: wait; }
.pay-submit--success { background: #0D9488; margin-top: 8px; }
.pay-submit--success:hover:not(:disabled) { background: #0B7E73; }

.pay-spinner {
    display: inline-block;
    width: 16px;
    height: 16px;
    border: 2px solid #FFFFFF;
    border-top-color: transparent;
    border-radius: 50%;
    animation: paySpin 0.7s linear infinite;
}
@keyframes paySpin { to { transform: rotate(360deg); } }

.pay-secure {
    color: #64748B;
    font-size: 11px;
    text-align: center;
    margin: 14px 0 0;
}
.pay-footer {
    margin-top: 24px;
    color: #64748B;
    font-size: 12px;
    text-align: center;
}
.pay-footer a { color: #E8650A; text-decoration: none; }

.pay-success-mark { margin: 0 auto 16px; line-height: 0; }
.pay-success-cta-help { color: #94A3B8; font-size: 14px; margin: 14px 0 12px; }
.pay-success-redirect {
    margin: 14px 0 0;
    font-size: 12px;
    color: #64748B;
}

@media (max-width: 560px) {
    .pay-card { padding: 28px 22px 26px; }
    .pay-card__title { font-size: 30px; }
}

/* ============================================================
   Maintenance upsell + signup pages (Phase 3)
   ============================================================ */

/* ── Maintenance upsell card on /portal/subscriptions/ ── */
.maint-upsell-card {
    position: relative;
    background: linear-gradient(160deg, rgba(232, 101, 10, 0.08), rgba(13, 148, 136, 0.06));
    border: 1px solid rgba(232, 101, 10, 0.35);
    border-radius: 14px;
    padding: 28px 28px 24px;
    margin: 24px 0;
    overflow: hidden;
}
.maint-upsell-card__pulse {
    position: absolute;
    inset: -1px;
    border-radius: 14px;
    pointer-events: none;
    background: radial-gradient(circle at 0% 0%, rgba(232, 101, 10, 0.18), transparent 55%);
    z-index: 0;
}
.maint-upsell-card__inner { position: relative; z-index: 1; }
.maint-upsell-card__chip {
    display: inline-block;
    padding: 4px 12px;
    border-radius: 999px;
    background: var(--color-orange);
    color: #fff;
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    margin-bottom: 12px;
}
.maint-upsell-card__chip--soft {
    background: rgba(232, 101, 10, 0.15);
    color: var(--color-orange-light);
}
.maint-upsell-card__title {
    margin: 0 0 8px;
    font-size: 1.65rem;
    line-height: 1.2;
    color: var(--color-text);
    font-weight: 700;
}
.maint-upsell-card__lead {
    margin: 0 0 22px;
    max-width: 760px;
    color: var(--color-text-muted);
    font-size: 0.95rem;
    line-height: 1.55;
}
.maint-upsell-card__mini-grid {
    list-style: none;
    margin: 0 0 22px;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 14px;
}
@media (max-width: 900px) {
    .maint-upsell-card__mini-grid { grid-template-columns: 1fr; }
}
.maint-upsell-mini {
    position: relative;
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 10px;
    padding: 16px 16px 14px;
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.maint-upsell-mini.is-featured {
    border-color: rgba(232, 101, 10, 0.55);
    box-shadow: 0 0 0 1px rgba(232, 101, 10, 0.25), 0 6px 24px rgba(232, 101, 10, 0.12);
}
.maint-upsell-mini__star {
    position: absolute;
    top: -10px; left: 12px;
    background: var(--color-orange);
    color: #fff;
    font-size: 0.65rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    padding: 3px 10px;
    border-radius: 999px;
    text-transform: uppercase;
}
.maint-upsell-mini__name {
    font-size: 1.1rem;
    color: var(--color-text);
    font-weight: 700;
}
.maint-upsell-mini__price {
    display: flex;
    align-items: baseline;
    gap: 4px;
    color: var(--color-text);
}
.maint-upsell-mini__price strong { font-size: 1.8rem; font-weight: 800; }
.maint-upsell-mini__price span { color: var(--color-text-muted); font-size: 0.85rem; }
.maint-upsell-mini__bullets {
    list-style: none;
    margin: 4px 0 12px;
    padding: 0;
    color: var(--color-text-muted);
    font-size: 0.85rem;
    line-height: 1.45;
    flex: 1;
}
.maint-upsell-mini__bullets li {
    padding-left: 16px;
    position: relative;
    margin-bottom: 4px;
}
.maint-upsell-mini__bullets li::before {
    content: '✓';
    position: absolute;
    left: 0;
    color: var(--color-orange);
    font-weight: 700;
}
.maint-upsell-card__foot {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    flex-wrap: wrap;
    padding-top: 8px;
    border-top: 1px dashed rgba(255, 255, 255, 0.06);
}
.maint-upsell-card__reassure {
    margin: 0;
    color: var(--color-text-muted);
    font-size: 0.85rem;
}

/* ── /portal/maintenance/ tier comparison page ── */
.maint-current {
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-left: 3px solid var(--color-orange);
    border-radius: 10px;
    padding: 14px 18px;
    margin: 12px 0 24px;
}
.maint-current__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    flex-wrap: wrap;
}
.maint-current__label {
    color: var(--color-text-muted);
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}
.maint-current__plan {
    color: var(--color-text);
    font-size: 1.15rem;
    font-weight: 700;
}

.maint-pitch {
    margin: 12px 0 36px;
}
.maint-pitch__title {
    margin: 0 0 16px;
    color: var(--color-text);
    font-size: 1.25rem;
    font-weight: 700;
}
.maint-pitch__grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
}
@media (max-width: 1100px) {
    .maint-pitch__grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
    .maint-pitch__grid { grid-template-columns: 1fr; }
}
.maint-pitch__item {
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 10px;
    padding: 18px;
}
.maint-pitch__icon { font-size: 1.6rem; margin-bottom: 6px; }
.maint-pitch__item h3 {
    margin: 0 0 6px;
    color: var(--color-text);
    font-size: 1rem;
    font-weight: 700;
}
.maint-pitch__item p {
    margin: 0;
    color: var(--color-text-muted);
    font-size: 0.88rem;
    line-height: 1.5;
}

.maint-tiers {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 18px;
    margin: 0 0 36px;
}
@media (max-width: 1100px) {
    .maint-tiers { grid-template-columns: 1fr; }
}
.maint-tier {
    position: relative;
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 14px;
    padding: 26px 22px 22px;
    display: flex;
    flex-direction: column;
    transition: border-color 0.18s ease, transform 0.18s ease;
}
.maint-tier:hover { border-color: var(--color-border-strong); transform: translateY(-2px); }
.maint-tier--featured {
    border-color: rgba(232, 101, 10, 0.55);
    box-shadow: 0 0 0 1px rgba(232, 101, 10, 0.18), 0 12px 36px rgba(232, 101, 10, 0.12);
}
.maint-tier--current {
    border-color: rgba(13, 148, 136, 0.55);
    box-shadow: 0 0 0 1px rgba(13, 148, 136, 0.2);
}
.maint-tier__ribbon {
    position: absolute;
    top: -12px;
    left: 50%;
    transform: translateX(-50%);
    background: var(--color-orange);
    color: #fff;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    padding: 4px 14px;
    border-radius: 999px;
    white-space: nowrap;
}
.maint-tier__ribbon--current {
    background: var(--color-teal);
}
.maint-tier__head { margin-bottom: 18px; }
.maint-tier__name {
    margin: 0 0 6px;
    color: var(--color-text);
    font-size: 1.4rem;
    font-weight: 700;
}
.maint-tier__price {
    display: flex;
    align-items: baseline;
    gap: 4px;
}
.maint-tier__amount {
    color: var(--color-text);
    font-size: 2.6rem;
    font-weight: 800;
    line-height: 1;
}
.maint-tier__interval {
    color: var(--color-text-muted);
    font-size: 0.9rem;
}
.maint-tier__tagline {
    margin: 6px 0 0;
    color: var(--color-text-muted);
    font-size: 0.85rem;
}
.maint-tier__features {
    list-style: none;
    padding: 0;
    margin: 0 0 20px;
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.maint-tier__features li {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    color: var(--color-text-muted);
    font-size: 0.9rem;
    line-height: 1.45;
}
.maint-tier__check {
    flex: 0 0 18px;
    width: 18px;
    height: 18px;
    color: var(--color-orange);
    margin-top: 2px;
}
.maint-tier__foot { margin-top: auto; }

.maint-reassure {
    border-top: 1px solid var(--color-border);
    padding-top: 24px;
    margin-top: 16px;
}
.maint-reassure__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
}
@media (max-width: 900px) {
    .maint-reassure__grid { grid-template-columns: 1fr; }
}
.maint-reassure h4 {
    margin: 0 0 6px;
    color: var(--color-text);
    font-size: 0.95rem;
    font-weight: 700;
}
.maint-reassure p {
    margin: 0;
    color: var(--color-text-muted);
    font-size: 0.85rem;
    line-height: 1.5;
}

/* ── /portal/maintenance/start/<slug>/ confirm page ── */
.portal-back {
    display: inline-block;
    color: var(--color-text-muted);
    text-decoration: none;
    font-size: 0.88rem;
    margin-bottom: 6px;
}
.portal-back:hover { color: var(--color-orange-light); }

.maint-confirm {
    display: grid;
    grid-template-columns: 1.1fr 1fr;
    gap: 22px;
    margin-top: 18px;
}
@media (max-width: 900px) {
    .maint-confirm { grid-template-columns: 1fr; }
}
.maint-confirm__plan,
.maint-confirm__payment {
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 12px;
    padding: 24px;
}
.maint-confirm__heading {
    margin: 0 0 6px;
    color: var(--color-text);
    font-size: 1.45rem;
    font-weight: 700;
}
.maint-confirm__price {
    display: flex;
    align-items: baseline;
    gap: 4px;
    margin-bottom: 18px;
}
.maint-confirm__amount {
    color: var(--color-text);
    font-size: 2.4rem;
    font-weight: 800;
    line-height: 1;
}
.maint-confirm__interval { color: var(--color-text-muted); font-size: 0.9rem; }
.maint-confirm__features {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.maint-confirm__features li {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    color: var(--color-text-muted);
    font-size: 0.9rem;
    line-height: 1.45;
}
.maint-confirm__sub {
    margin: 22px 0 10px;
    color: var(--color-text);
    font-size: 0.95rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.maint-confirm__sub:first-of-type { margin-top: 0; }
.maint-confirm__card {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    background: var(--color-bg-deep);
    border: 1px solid var(--color-border);
    border-radius: 8px;
    padding: 10px 14px;
    color: var(--color-text);
    font-size: 0.92rem;
    font-weight: 600;
}
.maint-confirm__no-card {
    background: rgba(248, 113, 113, 0.06);
    border: 1px solid rgba(248, 113, 113, 0.25);
    border-radius: 10px;
    padding: 14px;
    color: var(--color-text);
}
.maint-confirm__no-card p { margin: 0 0 10px; color: var(--color-text-muted); font-size: 0.9rem; }
.maint-confirm__terms {
    list-style: disc;
    padding-left: 20px;
    margin: 0;
    color: var(--color-text-muted);
    font-size: 0.88rem;
    line-height: 1.55;
}
.maint-confirm__terms li { margin-bottom: 6px; }
.maint-confirm__form { margin-top: 24px; }
.maint-confirm__secure {
    text-align: center;
    color: var(--color-text-muted);
    font-size: 0.78rem;
    margin: 10px 0 0;
}

/* ── /portal/maintenance/success/ ── */
.maint-success {
    max-width: 640px;
    margin: 24px auto 0;
    text-align: center;
    padding: 32px 24px;
}
.maint-success__icon {
    color: var(--color-orange);
    width: 96px;
    height: 96px;
    margin: 0 auto 18px;
}
.maint-success__icon svg { width: 100%; height: 100%; }
.maint-success__title {
    margin: 0 0 10px;
    color: var(--color-text);
    font-size: 1.85rem;
    font-weight: 800;
}
.maint-success__lead {
    margin: 0 auto 30px;
    color: var(--color-text-muted);
    font-size: 1rem;
    line-height: 1.55;
    max-width: 540px;
}
.maint-success__what {
    text-align: left;
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 10px;
    padding: 22px;
    margin: 0 auto 28px;
    max-width: 560px;
}
.maint-success__what h2 {
    margin: 0 0 12px;
    color: var(--color-text);
    font-size: 1.05rem;
    font-weight: 700;
}
.maint-success__what ol {
    margin: 0;
    padding-left: 22px;
    color: var(--color-text-muted);
    font-size: 0.93rem;
    line-height: 1.6;
}
.maint-success__what li { margin-bottom: 6px; }
.maint-success__cta {
    display: flex;
    gap: 12px;
    justify-content: center;
    flex-wrap: wrap;
}

/* ── Subscriptions page — per-card actions row ── */
.sub-card__actions {
    margin-top: 10px;
    padding-top: 10px;
    border-top: 1px dashed rgba(255, 255, 255, 0.06);
    display: flex;
    gap: 14px;
    align-items: center;
    flex-wrap: wrap;
}
.sub-card__link {
    background: none;
    border: 0;
    padding: 0;
    color: var(--color-orange-light);
    font-size: 0.88rem;
    font-weight: 600;
    cursor: pointer;
    text-decoration: none;
}
.sub-card__link:hover { color: var(--color-orange); text-decoration: underline; }
.sub-card__link--danger { color: var(--color-danger); }
.sub-card__link--danger:hover { color: #fca5a5; }

/* ============================================================
   Domain registration + DNS management
   ============================================================ */

.portal-page-head__row {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 18px;
    flex-wrap: wrap;
}

/* ── Domain list ── */
.domain-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 12px;
}
.domain-card {
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 10px;
    padding: 18px 20px;
}
.domain-card--grace { border-left: 3px solid var(--color-orange); }
.domain-card--failed,
.domain-card--expired { border-left: 3px solid var(--color-danger); }
.domain-card__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    flex-wrap: wrap;
    margin-bottom: 6px;
}
.domain-card__name {
    color: var(--color-text);
    font-size: 1.05rem;
    font-weight: 700;
    text-decoration: none;
}
.domain-card__name:hover { color: var(--color-orange-light); }
.domain-card__badge {
    padding: 3px 10px;
    border-radius: 999px;
    font-size: 0.72rem;
    text-transform: uppercase;
    font-weight: 700;
    letter-spacing: 0.05em;
}
.domain-card__badge--active   { background: rgba(74, 222, 128, 0.12); color: var(--color-success); }
.domain-card__badge--pending  { background: rgba(13, 148, 136, 0.15); color: var(--color-teal-light); }
.domain-card__badge--grace    { background: rgba(232, 101, 10, 0.15); color: var(--color-orange-light); }
.domain-card__badge--expired,
.domain-card__badge--failed,
.domain-card__badge--cancelled,
.domain-card__badge--transferred_out { background: rgba(248, 113, 113, 0.12); color: var(--color-danger); }
.domain-card__meta {
    color: var(--color-text-muted);
    font-size: 0.88rem;
    margin: 4px 0 10px;
}
.domain-card__meta span { margin-right: 6px; }
.domain-card__actions {
    display: flex;
    align-items: center;
    gap: 14px;
    flex-wrap: wrap;
}

/* Empty-state when client has no domains yet */
.domain-empty {
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 12px;
    padding: 32px 28px;
    text-align: center;
    margin-top: 12px;
}
.domain-empty__title {
    margin: 0 0 16px;
    color: var(--color-text);
    font-size: 1.25rem;
    font-weight: 700;
}
.domain-empty p {
    color: var(--color-text-muted);
    margin: 0 0 10px;
}
.domain-empty ul {
    list-style: none;
    padding: 0;
    margin: 0 0 24px;
    color: var(--color-text-muted);
    text-align: left;
    display: inline-block;
}
.domain-empty ul li {
    padding-left: 22px;
    position: relative;
    margin-bottom: 6px;
}
.domain-empty ul li::before {
    content: '✓';
    position: absolute;
    left: 0;
    color: var(--color-orange);
    font-weight: 700;
}
.domain-empty__price {
    color: var(--color-text-muted);
    font-size: 0.85rem;
    margin-top: 12px !important;
}

/* ── Domain search ── */
.domain-search-form {
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 12px;
    padding: 20px;
    margin: 16px 0 20px;
}
.domain-search-form__label {
    display: block;
    margin: 0 0 8px;
    color: var(--color-text);
    font-size: 0.85rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}
.domain-search-form__row {
    display: flex;
    gap: 10px;
    align-items: stretch;
}
.domain-search-form__row input {
    flex: 1;
    background: var(--color-bg-deep);
    border: 1px solid var(--color-border-strong);
    border-radius: 8px;
    padding: 12px 14px;
    color: var(--color-text);
    font-size: 1rem;
}
.domain-search-form__row input:focus { border-color: var(--color-orange); outline: none; }
.domain-search-form__hint {
    color: var(--color-text-muted);
    font-size: 0.82rem;
    margin: 8px 0 0;
}
.domain-search-error {
    background: rgba(248, 113, 113, 0.08);
    border: 1px solid rgba(248, 113, 113, 0.25);
    color: var(--color-danger);
    border-radius: 8px;
    padding: 12px 14px;
    margin: 16px 0;
}

/* ── Search results ── */
.domain-results { margin-top: 8px; }
.domain-results__title {
    color: var(--color-text);
    font-size: 1rem;
    font-weight: 700;
    margin: 0 0 12px;
}
.domain-results__title strong { color: var(--color-orange-light); }
.domain-results__list {
    list-style: none;
    padding: 0;
    margin: 0 0 18px;
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.domain-result {
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 10px;
    padding: 14px 18px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
}
.domain-result--taken { opacity: 0.55; }
.domain-result__name {
    color: var(--color-text);
    font-size: 1rem;
    font-weight: 600;
}
.domain-result__price {
    color: var(--color-text-muted);
    font-size: 0.88rem;
    margin-top: 4px;
}
.domain-result__taken { color: var(--color-danger); font-weight: 600; }
.domain-result__premium {
    display: inline-block;
    margin-left: 6px;
    padding: 2px 7px;
    border-radius: 999px;
    background: rgba(232, 101, 10, 0.15);
    color: var(--color-orange-light);
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    font-weight: 700;
}
.domain-results__note {
    color: var(--color-text-muted);
    font-size: 0.82rem;
    line-height: 1.55;
}

/* ── Register confirm page ── */
.domain-confirm {
    display: grid;
    grid-template-columns: 1.1fr 1fr;
    gap: 22px;
    margin-top: 16px;
}
@media (max-width: 900px) {
    .domain-confirm { grid-template-columns: 1fr; }
}
.domain-confirm__main,
.domain-confirm__side {
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 12px;
    padding: 24px;
}
.domain-confirm__heading {
    margin: 0 0 6px;
    color: var(--color-text);
    font-size: 1.6rem;
    font-weight: 700;
    word-break: break-all;
}
.domain-confirm__price {
    display: flex;
    align-items: baseline;
    gap: 4px;
    margin-bottom: 18px;
}
.domain-confirm__amount {
    color: var(--color-text);
    font-size: 2.4rem;
    font-weight: 800;
    line-height: 1;
}
.domain-confirm__interval { color: var(--color-text-muted); font-size: 0.9rem; }
.domain-confirm__features {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.domain-confirm__features li {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    color: var(--color-text-muted);
    font-size: 0.9rem;
    line-height: 1.45;
}
.domain-confirm__sub {
    margin: 22px 0 10px;
    color: var(--color-text);
    font-size: 0.95rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.domain-confirm__sub:first-of-type { margin-top: 0; }

/* ── Detail page ── */
.domain-detail__exp {
    color: var(--color-text-muted);
    margin-left: 10px;
    font-size: 0.9rem;
}
.domain-detail__grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 18px;
    margin: 18px 0 24px;
}
@media (max-width: 900px) {
    .domain-detail__grid { grid-template-columns: 1fr; }
}
.domain-detail__panel {
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 12px;
    padding: 20px;
}
.domain-detail__panel h2 {
    margin: 0 0 14px;
    color: var(--color-text);
    font-size: 1.05rem;
    font-weight: 700;
}
.domain-detail__panel--warning {
    border-color: rgba(232, 101, 10, 0.45);
    background: linear-gradient(140deg, rgba(232,101,10,0.08), rgba(15,23,42,1));
}
.domain-detail__dl {
    margin: 0;
    display: grid;
    grid-template-columns: max-content 1fr;
    gap: 8px 18px;
}
.domain-detail__dl dt {
    color: var(--color-text-muted);
    font-size: 0.85rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}
.domain-detail__dl dd {
    margin: 0;
    color: var(--color-text);
    font-size: 0.92rem;
}
.domain-detail__epp {
    margin: 14px 0 10px;
    background: var(--color-bg-deep);
    border: 1px solid var(--color-border-strong);
    border-radius: 8px;
    padding: 14px 16px;
}
.domain-detail__epp label {
    display: block;
    color: var(--color-text-muted);
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: 6px;
}
.domain-detail__epp code {
    color: var(--color-orange-light);
    font-size: 1.1rem;
    font-weight: 700;
    word-break: break-all;
    user-select: all;
}
.domain-detail__epp-help {
    color: var(--color-text-muted);
    font-size: 0.85rem;
    margin: 0;
}

.domain-dns-table {
    width: 100%;
    border-collapse: collapse;
    margin-bottom: 14px;
}
.domain-dns-table th,
.domain-dns-table td {
    text-align: left;
    padding: 8px 10px;
    border-bottom: 1px solid var(--color-border);
    font-size: 0.86rem;
    color: var(--color-text);
}
.domain-dns-table th {
    color: var(--color-text-muted);
    font-size: 0.74rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}
.domain-dns-table td code {
    color: var(--color-text);
    background: rgba(255,255,255,0.04);
    padding: 1px 5px;
    border-radius: 4px;
    font-size: 0.82rem;
}
.domain-dns-table__auto {
    display: inline-block;
    margin-left: 6px;
    padding: 1px 6px;
    background: rgba(13, 148, 136, 0.15);
    color: var(--color-teal-light);
    border-radius: 999px;
    font-size: 0.66rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    font-weight: 700;
}

/* ── Danger / cancel zone ── */
.domain-detail__danger {
    background: var(--color-bg-raised);
    border: 1px solid rgba(248, 113, 113, 0.25);
    border-radius: 12px;
    padding: 22px;
    margin-top: 18px;
}
.domain-detail__danger h2 {
    margin: 0 0 10px;
    color: var(--color-danger);
    font-size: 1.05rem;
    font-weight: 700;
}
.domain-detail__danger p {
    color: var(--color-text-muted);
    font-size: 0.9rem;
    margin: 0 0 14px;
}
.domain-detail__reason-label {
    display: block;
    color: var(--color-text);
    font-size: 0.85rem;
    font-weight: 600;
    margin-bottom: 6px;
}
.domain-detail__danger textarea {
    width: 100%;
    background: var(--color-bg-deep);
    border: 1px solid var(--color-border-strong);
    border-radius: 8px;
    padding: 10px 12px;
    color: var(--color-text);
    font-family: inherit;
    margin-bottom: 12px;
    resize: vertical;
}
.domain-detail__cancel-btn {
    border-color: rgba(248, 113, 113, 0.45);
    color: var(--color-danger);
}
.domain-detail__cancel-btn:hover {
    background: rgba(248, 113, 113, 0.08);
    border-color: var(--color-danger);
    color: #fca5a5;
}

/* ── DNS edit table ── */
.domain-dns-form { margin-top: 12px; }
.domain-dns-edit {
    width: 100%;
    border-collapse: collapse;
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 12px;
    overflow: hidden;
}
.domain-dns-edit thead th {
    text-align: left;
    padding: 12px 10px;
    background: rgba(255,255,255,0.02);
    color: var(--color-text-muted);
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    font-weight: 700;
    border-bottom: 1px solid var(--color-border);
}
.domain-dns-edit tbody td {
    padding: 8px 10px;
    border-bottom: 1px solid var(--color-border);
    vertical-align: top;
}
.domain-dns-edit tbody tr:last-child td { border-bottom: 0; }
.domain-dns-edit input,
.domain-dns-edit select {
    width: 100%;
    background: var(--color-bg-deep);
    border: 1px solid var(--color-border-strong);
    border-radius: 6px;
    padding: 8px 10px;
    color: var(--color-text);
    font-size: 0.88rem;
}
.domain-dns-edit input:focus,
.domain-dns-edit select:focus {
    border-color: var(--color-orange);
    outline: none;
}
.domain-dns-edit__remove {
    color: var(--color-danger);
    background: none;
    border: 0;
    padding: 0;
    font-size: 0.85rem;
    cursor: pointer;
}
.domain-dns-edit__remove:hover { color: #fca5a5; text-decoration: underline; }
.domain-dns-form__actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-top: 16px;
    flex-wrap: wrap;
}
.domain-dns-form__actions > div { display: flex; gap: 12px; align-items: center; }

/* ── Namecheap sandbox/live mode UI (admin) ── */
.admin-sandbox-banner {
    background: linear-gradient(120deg, rgba(232, 101, 10, 0.12), rgba(13, 148, 136, 0.06));
    border: 1px solid rgba(232, 101, 10, 0.4);
    border-radius: 10px;
    padding: 14px 18px;
    margin: 12px 0 16px;
    color: #F8FAFC;
    font-size: 0.92rem;
    line-height: 1.5;
}
.admin-sandbox-banner a {
    color: var(--color-orange-light);
    text-decoration: none;
    font-weight: 600;
    margin-left: 6px;
}
.admin-sandbox-banner a:hover { text-decoration: underline; }

.namecheap-mode {
    padding: 16px;
    border-radius: 10px;
    background: var(--color-bg-deep);
    border: 1px solid var(--color-border);
    margin-bottom: 16px;
}
.namecheap-mode--sandbox {
    border-left: 4px solid var(--color-teal);
}
.namecheap-mode--live {
    border-left: 4px solid var(--color-danger);
    background: linear-gradient(140deg, rgba(248, 113, 113, 0.06), var(--color-bg-deep));
}
.namecheap-mode__chip {
    display: inline-block;
    padding: 6px 14px;
    border-radius: 999px;
    background: var(--color-bg-raised);
    color: var(--color-text);
    font-size: 0.95rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    margin-bottom: 10px;
}
.namecheap-mode--live .namecheap-mode__chip {
    background: rgba(248, 113, 113, 0.15);
    color: var(--color-danger);
}
.namecheap-mode__desc {
    color: var(--color-text-muted);
    font-size: 0.9rem;
    line-height: 1.55;
    margin: 0 0 10px;
}
.namecheap-mode__desc code {
    background: rgba(255,255,255,0.04);
    padding: 1px 6px;
    border-radius: 4px;
    color: var(--color-orange-light);
}
.namecheap-mode__history {
    color: var(--color-text-muted);
    font-size: 0.82rem;
    margin: 0;
}

.namecheap-ping {
    padding: 14px 16px;
    border-radius: 10px;
    background: var(--color-bg-deep);
    border: 1px solid var(--color-border);
}
.namecheap-ping--ok {
    border-left: 4px solid var(--color-success);
}
.namecheap-ping--err {
    border-left: 4px solid var(--color-danger);
    background: rgba(248, 113, 113, 0.04);
}
.namecheap-ping strong {
    display: block;
    margin-bottom: 6px;
    color: var(--color-text);
}
.namecheap-ping--ok strong { color: var(--color-success); }
.namecheap-ping--err strong { color: var(--color-danger); }
.namecheap-ping p {
    margin: 0 0 8px;
    color: var(--color-text-muted);
    font-size: 0.88rem;
    line-height: 1.5;
}
.namecheap-ping code {
    background: rgba(255,255,255,0.04);
    padding: 1px 6px;
    border-radius: 4px;
    color: var(--color-orange-light);
}
.namecheap-ping ul {
    margin: 6px 0 0 0;
    padding-left: 20px;
    color: var(--color-text-muted);
    font-size: 0.85rem;
}

.admin-config-howto {
    color: var(--color-text-muted);
    font-size: 0.9rem;
    line-height: 1.6;
    padding-left: 22px;
    margin: 0;
}
.admin-config-howto li { margin-bottom: 6px; }
.admin-config-howto code {
    background: rgba(255,255,255,0.04);
    padding: 1px 6px;
    border-radius: 4px;
    color: var(--color-orange-light);
}

/* ── Client portal sandbox-mode banner ── */
.portal-sandbox-banner {
    display: flex;
    align-items: flex-start;
    gap: 16px;
    padding: 14px 18px;
    margin: 0 0 18px;
    border-radius: 10px;
    background: linear-gradient(120deg, rgba(232, 101, 10, 0.14), rgba(13, 148, 136, 0.06));
    border: 1px solid rgba(232, 101, 10, 0.45);
    border-left-width: 4px;
}
.portal-sandbox-banner__chip {
    flex: 0 0 auto;
    background: rgba(232, 101, 10, 0.18);
    color: var(--color-orange-light);
    font-weight: 700;
    font-size: 0.78rem;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    padding: 6px 12px;
    border-radius: 999px;
    white-space: nowrap;
}
.portal-sandbox-banner__body {
    flex: 1;
    color: var(--color-text);
    font-size: 0.92rem;
    line-height: 1.55;
}
.portal-sandbox-banner__body strong {
    color: var(--color-text);
    font-weight: 700;
}
@media (max-width: 640px) {
    .portal-sandbox-banner { flex-direction: column; gap: 8px; }
}

/* ── Admin .admin-stat-row + helpers (used on domains list) ── */
.admin-stat-row {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    margin: 14px 0 18px;
}
.admin-stat-row .admin-stat {
    flex: 0 1 auto;
    padding: 12px 16px;
    border-radius: 10px;
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    box-shadow: none;
    transition: border-color 0.15s ease;
}
.admin-stat-row .admin-stat:hover { transform: none; }
.admin-stat-row .admin-stat strong {
    display: block;
    font-size: 1.4rem;
    line-height: 1.1;
    color: var(--color-text);
    font-weight: 800;
}
.admin-stat-row .admin-stat span {
    display: block;
    font-size: 0.72rem;
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-top: 2px;
}
.admin-stat-row .admin-stat--bad {
    border-color: rgba(248, 113, 113, 0.35);
    background: rgba(248, 113, 113, 0.04);
}
.admin-stat-row .admin-stat--bad strong { color: var(--color-danger); }
.admin-stat-row .admin-stat--balance {
    border-color: rgba(232, 101, 10, 0.35);
    background: rgba(232, 101, 10, 0.04);
}
.admin-stat-row .admin-stat--balance strong { color: var(--color-orange-light); }

/* ── Admin form inputs — applies to BOTH .admin-form-stack and
   the lighter .admin-action-form (used for one-off action panels
   on detail pages and the HTMX check-availability widget). ── */
.admin-form-stack label,
.admin-action-form label {
    display: block;
    margin: 12px 0 6px;
    color: var(--color-text);
    font-size: 0.85rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.admin-form-stack label:first-of-type,
.admin-action-form label:first-of-type { margin-top: 0; }

.admin-form-stack input[type="text"],
.admin-form-stack input[type="number"],
.admin-form-stack input[type="email"],
.admin-form-stack select,
.admin-form-stack textarea,
.admin-action-form input[type="text"],
.admin-action-form input[type="number"],
.admin-action-form input[type="email"],
.admin-action-form select,
.admin-action-form textarea {
    width: 100%;
    background: var(--color-bg-deep);
    border: 1px solid var(--color-border-strong);
    border-radius: 8px;
    padding: 10px 12px;
    color: var(--color-text);
    font-family: inherit;
    font-size: 0.95rem;
}
.admin-form-stack input:focus,
.admin-form-stack select:focus,
.admin-form-stack textarea:focus,
.admin-action-form input:focus,
.admin-action-form select:focus,
.admin-action-form textarea:focus {
    border-color: var(--color-orange);
    outline: none;
}
.admin-form-stack select option,
.admin-action-form select option {
    background: var(--color-bg-raised);
    color: var(--color-text);
}
.admin-form-stack .muted,
.admin-action-form .muted {
    font-size: 0.78rem; text-transform: none;
    letter-spacing: 0; font-weight: 400;
    color: var(--color-text-muted);
}
.admin-form-submit { margin-top: 18px; }

/* When the action form needs a button BESIDE the input (like the
   HTMX check-availability widget) instead of below it. */
.admin-action-form button { margin-top: 14px; }


/* ═══════════════════════════════════════════════════════════════════
   Phase C — Account + Website admin styles.

   Loaded from main.css (not inline <style>) because the site's CSP
   is `style-src 'self'` — inline blocks are silently dropped by
   the browser. Same reason the Phase C modal JS lives in
   /static/js/website_detail.js, not inline.
   ═══════════════════════════════════════════════════════════════════ */

/* ── Website detail layout ────────────────────────────────────── */

.website-detail .admin-card { margin-bottom: 1.25rem; }

.website-detail .form-row--inline {
    display: grid;
    grid-template-columns: 220px 1fr;
    gap: 1rem;
    padding: 0.5rem 0;
    align-items: flex-start;
    border-bottom: 1px solid var(--color-border-subtle, #2a2a2a);
}
.website-detail .form-row--inline:last-child { border-bottom: 0; }
.website-detail .form-row__label {
    color: var(--color-text-muted);
    font-size: 0.875rem;
    padding-top: 0.5rem;
}
.website-detail .form-row__field-with-link {
    display: flex;
    gap: 0.5rem;
    align-items: center;
}
.website-detail .form-row__field-with-link .form-control { flex: 1; }
.website-detail .checkbox-row {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding-top: 0.5rem;
}
.website-detail .form-actions { margin: 2rem 0; }

/* ── Stage controls + stepper variants ────────────────────────── */

.admin-stage-controls {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.75rem;
    margin-top: 1rem;
    padding-top: 1rem;
    border-top: 1px solid var(--color-border);
}
.admin-stage-skip {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    margin-left: auto;
}

/* Completed (green-tinted) + upcoming (muted) variants on the stepper —
   the existing .admin-stage-bar only knew is-current. */
.admin-stage-bar--steps .admin-stage-bar__step--completed {
    background: rgba(16, 185, 129, 0.12);
    border-color: rgba(16, 185, 129, 0.45);
    color: var(--color-text);
}
.admin-stage-bar--steps .admin-stage-bar__step--completed .admin-stage-bar__dot {
    color: #10b981;
    font-weight: bold;
}
.admin-stage-bar--steps .admin-stage-bar__step--current {
    background: rgba(232, 101, 10, 0.12);
    border-color: rgba(232, 101, 10, 0.45);
    color: var(--color-text);
    font-weight: 600;
}
.admin-stage-bar--steps .admin-stage-bar__step--current .admin-stage-bar__dot {
    color: var(--color-orange);
}
.admin-stage-bar--steps .admin-stage-bar__step--upcoming {
    opacity: 0.6;
}

/* ── Back-a-phase button — red outline, transparent fill, hover
   flips to red fill + white text (per user spec) ───────────────── */
.btn-back-phase {
    background: transparent;
    border: 1px solid #ef4444;
    color: #ef4444;
    padding: 6px 14px;
    border-radius: 6px;
    font-weight: 500;
    font-size: 0.875rem;
    cursor: pointer;
    transition: background .15s, color .15s;
}
.btn-back-phase:hover {
    background: #ef4444;
    color: #FFFFFF;
}

/* ── Danger card framing (move-account section) ──────────────── */

.danger-card {
    margin-top: 3rem;
    border: 2px solid #ef4444 !important;
    background: rgba(239, 68, 68, 0.06);
    box-shadow: 0 0 0 4px rgba(239, 68, 68, 0.08);
}
.danger-card__title {
    color: #ef4444 !important;
}
.danger-card__select {
    border-color: var(--color-border) !important;
}
.danger-card__select:focus {
    border-color: var(--color-orange-light, #E8650A) !important;
    outline: none;
}

.admin-danger-form {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
    margin-top: 0.5rem;
}
.admin-danger-form select { flex: 1; min-width: 240px; }
.admin-danger-form label {
    flex-basis: 100%;
    color: var(--color-text-muted);
    font-size: 0.875rem;
    margin-bottom: 0.25rem;
}

/* Solid-red SUBMIT button — distinct class so it doesn't fight the
   subtle .btn-danger outline already defined above. */
.btn-danger-solid {
    background: #ef4444;
    border: 1px solid #ef4444;
    color: #FFFFFF;
    padding: 8px 18px;
    border-radius: 6px;
    font-weight: 600;
    font-size: 0.875rem;
    cursor: pointer;
    transition: background .15s, border-color .15s;
}
.btn-danger-solid:hover {
    background: #dc2626;
    border-color: #dc2626;
}

/* ── Confirmation modal (vanilla, no framework) ──────────────── */

.danger-modal {
    position: fixed;
    inset: 0;
    z-index: 1000;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1rem;
}
.danger-modal[hidden] { display: none; }
.danger-modal__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.6);
    backdrop-filter: blur(2px);
}
.danger-modal__card {
    position: relative;
    background: var(--color-bg-raised);
    border: 2px solid #ef4444;
    border-radius: 10px;
    max-width: 480px;
    width: 100%;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.5);
    overflow: hidden;
}
.danger-modal__head {
    padding: 1.25rem 1.5rem;
    border-bottom: 1px solid var(--color-border);
}
.danger-modal__head h2 {
    margin: 0;
    color: #ef4444;
    font-size: 1.125rem;
}
.danger-modal__body {
    padding: 1.5rem;
    color: var(--color-text);
    font-size: 0.9rem;
    line-height: 1.5;
}
.danger-modal__body p { margin: 0 0 0.75rem; }
.danger-modal__body p:last-child { margin-bottom: 0; }
.danger-modal__foot {
    padding: 1rem 1.5rem;
    border-top: 1px solid var(--color-border);
    display: flex;
    justify-content: flex-end;
    gap: 0.5rem;
}

/* Delete-account modal extras — impact list, expected-name display,
   external-state warning block, button disabled state. */
.danger-impact-list {
    margin: 0.75rem 0 1.25rem;
    padding-left: 1.25rem;
    color: var(--color-text-muted);
    font-size: 0.85rem;
    line-height: 1.5;
}
.danger-impact-list li { margin-bottom: 0.25rem; }
.danger-modal__warning {
    background: rgba(239, 68, 68, 0.08);
    border: 1px solid rgba(239, 68, 68, 0.3);
    border-radius: 6px;
    padding: 0.75rem 1rem;
    margin: 0.5rem 0 1rem;
    color: var(--color-text);
    font-size: 0.85rem;
}
.danger-modal__warning ul {
    margin: 0.5rem 0 0;
    padding-left: 1.25rem;
}
.danger-modal__warning li { margin-bottom: 0.25rem; }
.danger-modal__expected {
    margin: 0.5rem 0;
}
.danger-modal__expected code {
    background: rgba(255, 255, 255, 0.06);
    padding: 4px 10px;
    border-radius: 4px;
    font-size: 0.95rem;
    color: #FFFFFF;
    user-select: all;
}
.danger-modal__hint {
    font-size: 0.75rem;
    margin: 0.25rem 0 0;
}
/* When the type-to-unlock button is locked, dim it so the disabled
   state is obvious — browsers' default disabled styling is invisible
   on the solid-red background. */
.btn-danger-solid:disabled,
.btn-danger-solid[disabled] {
    background: #6b6b6b;
    border-color: #6b6b6b;
    cursor: not-allowed;
    opacity: 0.7;
}
.btn-danger-solid:disabled:hover,
.btn-danger-solid[disabled]:hover {
    background: #6b6b6b;
    border-color: #6b6b6b;
}

/* ── Account detail (single-page editor) ─────────────────────── */

/* Mirrors the website-detail form-row layout but scoped to the
   account-detail container so the global .form-row / .checkbox-row
   used elsewhere in the project keeps its existing layout. */
.account-detail .form-row--inline {
    display: grid;
    grid-template-columns: 220px 1fr;
    gap: 1rem;
    padding: 0.5rem 0;
    align-items: flex-start;
    border-bottom: 1px solid var(--color-border-subtle, #2a2a2a);
}
.account-detail .form-row--inline:last-child { border-bottom: 0; }
.account-detail .form-row__label {
    color: var(--color-text-muted);
    font-size: 0.875rem;
    padding-top: 0.5rem;
}
.account-detail .form-row__field { min-width: 0; }
.account-detail .checkbox-row {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding-top: 0.5rem;
}
.account-detail .form-actions { margin: 2rem 0; }
.account-detail .admin-card { margin-bottom: 1.25rem; }

.account-edit-section { margin-bottom: 1rem; }
.website-card-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 1rem;
}
.website-card {
    background: var(--color-bg-elevated, #1f1f1f);
    border: 1px solid var(--color-border);
    border-radius: 8px;
    padding: 1rem;
}
.website-card__head {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    margin-bottom: 0.5rem;
}
.website-card__url {
    color: var(--color-text-muted);
    font-size: 0.85rem;
    margin: 0 0 0.5rem;
    word-break: break-all;
}
.website-card__meta { font-size: 0.85rem; margin: 0 0 0.25rem; }
.website-card__slug { font-size: 0.75rem; margin: 0; }

/* ── Subscriptions — per-sub payment-method dropdown ─────────── */

.sub-card__pm {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-top: 0.75rem;
    padding-top: 0.75rem;
    border-top: 1px solid var(--color-border-subtle, #2a2a2a);
}
.sub-card__pm-label {
    color: var(--color-text-muted);
    font-size: 0.85rem;
}
.sub-card__pm-select {
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    color: var(--color-text);
    border-radius: 6px;
    padding: 4px 8px;
    font-size: 0.85rem;
    min-width: 220px;
}

/* ── Portal site-bar (multi-website accounts only) ───────────── */

.portal-site-bar {
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 8px;
    padding: 0.625rem 1rem;
    margin-bottom: var(--space-4);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    flex-wrap: wrap;
}
.portal-site-bar__left {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex-wrap: wrap;
}
.portal-site-bar__label {
    color: var(--color-text-muted);
    font-size: 0.85rem;
}
.portal-site-bar__name {
    color: var(--color-text);
    font-size: 0.95rem;
}
.portal-site-bar__stage {
    background: var(--color-orange-soft, rgba(232, 101, 10, 0.15));
    color: var(--color-orange-light, #E8650A);
    padding: 2px 8px;
    border-radius: 999px;
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    font-weight: 600;
}
.portal-site-bar__switch {
    color: var(--color-orange-light, #E8650A);
    text-decoration: none;
    font-size: 0.85rem;
    font-weight: 500;
}
.portal-site-bar__switch:hover {
    text-decoration: underline;
}

/* ── Vault group-by toggle + per-credential site tag ─────────── */

.vault-viewby {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    margin: 0 0 1rem;
    padding: 0.25rem 0.5rem;
    background: var(--color-bg-elevated, #1f1f1f);
    border-radius: 8px;
    border: 1px solid var(--color-border);
}
.vault-viewby__label {
    color: var(--color-text-muted);
    font-size: 0.8rem;
}
.vault-viewby__opt {
    padding: 4px 12px;
    border-radius: 6px;
    text-decoration: none;
    color: var(--color-text-muted);
    font-size: 0.85rem;
    font-weight: 500;
}
.vault-viewby__opt.is-active {
    background: var(--color-orange-soft, rgba(232, 101, 10, .15));
    color: var(--color-orange-light, #E8650A);
}
.vault-site-tag {
    display: inline-block;
    background: rgba(255, 255, 255, .05);
    color: var(--color-text-muted);
    font-size: 0.7rem;
    padding: 2px 8px;
    border-radius: 999px;
    margin-left: 0.5rem;
    font-weight: 400;
    text-transform: uppercase;
    letter-spacing: 0.03em;
}

/* ══════════════════════════════════════════════════════════════════
   Chooser page (multi-website account login chooser).
   Uses the same theme tokens as the portal + admin so the page
   reads as part of the app rather than a one-off black page.
   A subtle radial orange wash near the top echoes the brand glow
   that the rest of the dark-theme pages already use.
   ══════════════════════════════════════════════════════════════════ */

.chooser-shell {
    min-height: 100vh;
    background:
        radial-gradient(
            ellipse 900px 500px at 50% -100px,
            rgba(232, 101, 10, 0.12),
            transparent 60%),
        var(--color-bg-deep);
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 64px 24px 80px;
    color: var(--color-text);
    font-family: var(--font-sans);
}

/* ── Header — centred logo + greeting ──────────────────────────── */

.chooser-header {
    text-align: center;
    margin-bottom: 48px;
    max-width: 640px;
    display: flex;
    flex-direction: column;
    align-items: center;
}
.chooser-header img {
    height: 80px;
    width: auto;
    margin: 0 auto 28px;
    filter: drop-shadow(0 6px 20px rgba(232, 101, 10, 0.25));
}
.chooser-header h1 {
    font-size: 2rem;
    font-weight: 600;
    margin: 0 0 8px;
    color: var(--color-text);
    line-height: 1.2;
}
.chooser-header p {
    color: var(--color-text-muted);
    margin: 0;
    font-size: 1rem;
}

/* ── Section labels ───────────────────────────────────────────── */

.chooser-section-label {
    text-transform: uppercase;
    letter-spacing: 0.12em;
    font-size: 11px;
    color: var(--color-text-muted);
    margin: 32px 0 14px;
    font-weight: 700;
    width: 100%;
    max-width: 960px;
    display: flex;
    align-items: center;
    gap: 12px;
}
.chooser-section-label::before,
.chooser-section-label::after {
    content: '';
    flex: 1;
    height: 1px;
    background: var(--color-border);
}

/* ── Website cards — orange-glow + lift on hover ─────────────── */

.chooser-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 20px;
    width: 100%;
    max-width: 960px;
}
.chooser-card {
    background: var(--color-bg-raised);
    border: 1px solid rgba(232, 101, 10, 0.35);
    border-radius: 12px;
    padding: 22px;
    display: flex;
    flex-direction: column;
    transition: border-color .18s, transform .18s, box-shadow .18s;
    /* Permanent subtle orange halo — pops on a darker bg. */
    box-shadow:
        0 0 0 1px rgba(232, 101, 10, 0.06),
        0 6px 24px rgba(232, 101, 10, 0.10),
        0 1px 3px rgba(0, 0, 0, 0.35);
    margin: 0;
}
.chooser-card:hover {
    border-color: var(--color-orange);
    transform: translateY(-3px);
    box-shadow:
        0 0 0 1px rgba(232, 101, 10, 0.4),
        0 14px 36px rgba(232, 101, 10, 0.28),
        0 4px 8px rgba(0, 0, 0, 0.5);
}
.chooser-card__stage {
    display: inline-block;
    background: rgba(232, 101, 10, 0.18);
    color: var(--color-orange-light);
    padding: 4px 12px;
    border-radius: 999px;
    font-size: 10.5px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    margin-bottom: 14px;
    align-self: flex-start;
}
.chooser-card__name {
    font-size: 1.125rem;
    font-weight: 600;
    color: var(--color-text);
    margin: 0 0 6px;
    line-height: 1.3;
}
.chooser-card__meta {
    font-size: 0.85rem;
    color: var(--color-text-muted);
    margin: 0 0 18px;
    min-height: 1.4em;
}
.chooser-card__url {
    font-size: 0.75rem;
    color: var(--color-text-muted);
    margin: 0 0 18px;
    word-break: break-all;
    opacity: 0.75;
}
.chooser-card__button {
    margin-top: auto;
    display: block;
    background: var(--color-orange);
    color: #FFFFFF;
    text-align: center;
    padding: 11px 14px;
    border-radius: 8px;
    font-weight: 600;
    font-size: 0.9rem;
    border: 0;
    cursor: pointer;
    text-decoration: none;
    transition: background .15s;
}
.chooser-card__button:hover { background: var(--color-orange-light); }

/* ── Account-wide quick links ────────────────────────────────── */

.chooser-account-links {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 14px;
    width: 100%;
    max-width: 960px;
    margin-bottom: 40px;
}
.chooser-account-link {
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 10px;
    padding: 16px 18px;
    color: var(--color-text);
    text-decoration: none;
    font-size: 0.9rem;
    transition: border-color .15s, background .15s, transform .15s;
}
.chooser-account-link:hover {
    border-color: var(--color-border-strong);
    background: rgba(255, 255, 255, 0.02);
    transform: translateY(-1px);
}
.chooser-account-link__label {
    display: block;
    font-weight: 600;
    margin-bottom: 4px;
    color: var(--color-text);
}
.chooser-account-link__hint {
    font-size: 0.75rem;
    color: var(--color-text-muted);
}

/* ── Logout footer ───────────────────────────────────────────── */

.chooser-logout {
    margin-top: 16px;
    padding-top: 24px;
    border-top: 1px solid var(--color-border);
    width: 100%;
    max-width: 960px;
    text-align: center;
}
.chooser-logout button {
    background: transparent;
    border: 1px solid var(--color-border-strong);
    color: var(--color-text-muted);
    padding: 9px 22px;
    border-radius: 8px;
    cursor: pointer;
    font-size: 0.85rem;
    transition: color .15s, border-color .15s;
}
.chooser-logout button:hover {
    color: var(--color-text);
    border-color: var(--color-orange);
}

.chooser-empty {
    text-align: center;
    color: var(--color-text-muted);
    padding: 40px 0;
    width: 100%;
    max-width: 960px;
}


/* ── Lead detail — scraper-data + score-breakdown accordion ──────── */

.lead-debug {
    margin-top: 1.5rem;
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 10px;
    overflow: hidden;
}
.lead-debug__summary {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 1rem 1.25rem;
    cursor: pointer;
    list-style: none;
    user-select: none;
    color: var(--color-text);
    font-weight: 600;
    transition: background .12s;
}
.lead-debug__summary::-webkit-details-marker { display: none; }
.lead-debug__summary:hover { background: rgba(255, 255, 255, 0.02); }
.lead-debug__chevron {
    color: var(--color-orange);
    font-size: 0.85rem;
    transition: transform .2s ease;
    display: inline-block;
}
.lead-debug[open] .lead-debug__chevron { transform: rotate(90deg); }
.lead-debug__label { flex: 1; }
.lead-debug__hint {
    font-size: 0.75rem;
    font-weight: 400;
}

.lead-debug__body {
    display: grid;
    grid-template-columns: 1fr 1.4fr;
    gap: 1.5rem;
    padding: 0 1.25rem 1.25rem;
    border-top: 1px solid var(--color-border);
}
@media (max-width: 800px) {
    .lead-debug__body { grid-template-columns: 1fr; }
}
.lead-debug__col { min-width: 0; }
.lead-debug__title {
    font-size: 0.85rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--color-text-muted);
    margin: 1.25rem 0 0.75rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.lead-debug__total {
    color: var(--color-orange);
    font-size: 1rem;
    font-weight: 700;
}

.lead-debug__kv {
    display: grid;
    grid-template-columns: minmax(140px, max-content) 1fr;
    gap: 0.4rem 1rem;
    margin: 0;
    font-size: 0.85rem;
}
.lead-debug__kv dt {
    color: var(--color-text-muted);
}
.lead-debug__kv dd {
    margin: 0;
    color: var(--color-text);
    /* Break long URLs / unspaced tokens anywhere rather than letting
       them overflow the column. */
    overflow-wrap: anywhere;
    word-break: break-word;
}

/* Score breakdown rows — flexbox row layout. Each row is 3 flex
   siblings: label (fixed basis) | value (1fr with min-width: 0 so
   long URLs wrap) | pts (fixed width). Class prefix .score-row was
   chosen specifically to avoid any cached .lead-debug__rule rules
   in a stuck browser. */
.score-rows {
    width: 100%;
    font-size: 0.82rem;
}
.score-row {
    display: flex;
    flex-wrap: nowrap;
    align-items: flex-start;
    gap: 0.6rem;
    padding: 0.5rem 0.6rem;
    border-bottom: 1px solid var(--color-border-subtle, #2a2a2a);
}
.score-row:last-child { border-bottom: 0; }
.score-row--head {
    color: var(--color-text-muted);
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    padding: 0.4rem 0.6rem;
    border-bottom: 1px solid var(--color-border);
    font-weight: 600;
}
.score-row--miss { opacity: 0.55; }
.score-row__label {
    flex: 0 0 38%;
    min-width: 0;
    color: var(--color-text);
    overflow-wrap: anywhere;
}
.score-row__value {
    flex: 1 1 0;
    min-width: 0;
    color: var(--color-text);
    overflow-wrap: anywhere;
    word-break: break-all;
}
.score-row__pts {
    flex: 0 0 72px;
    text-align: right;
    white-space: nowrap;
}
.score-row__pill {
    display: inline-block;
    background: rgba(232, 101, 10, 0.16);
    color: var(--color-orange-light, #FF7B1E);
    padding: 2px 8px;
    border-radius: 999px;
    font-weight: 600;
    font-size: 0.75rem;
}
.score-row--miss .score-row__pill {
    background: rgba(255, 255, 255, 0.04);
    color: var(--color-text-muted);
}
.score-rows code {
    background: rgba(255, 255, 255, 0.04);
    padding: 1px 6px;
    border-radius: 4px;
    font-size: 0.78rem;
    overflow-wrap: anywhere;
    word-break: break-all;
    display: inline;
}
.lead-debug__pill {
    display: inline-block;
    background: rgba(232, 101, 10, 0.16);
    color: var(--color-orange-light, #FF7B1E);
    padding: 2px 8px;
    border-radius: 999px;
    font-weight: 600;
    font-size: 0.75rem;
}
.lead-debug__row--miss .lead-debug__pill {
    background: rgba(255, 255, 255, 0.04);
    color: var(--color-text-muted);
}
.lead-debug__legend {
    margin-top: 0.75rem;
    font-size: 0.75rem;
}

.lead-debug__nested {
    margin-top: 0.75rem;
    background: rgba(0, 0, 0, 0.2);
    border: 1px solid var(--color-border);
    border-radius: 6px;
    padding: 0.5rem 0.75rem;
}
.lead-debug__nested summary {
    cursor: pointer;
    color: var(--color-text-muted);
    font-size: 0.78rem;
    font-weight: 600;
    list-style: none;
}
.lead-debug__nested summary::-webkit-details-marker { display: none; }
.lead-debug__nested[open] summary { margin-bottom: 0.5rem; }
/* Brave Search API monthly-usage banner on /admin-dashboard/leads/.
   States: default (orange brand), --warn (>=80%, amber), --over
   (>=100%, red). Track + fill use plain divs so no JS / no CSP
   surprises. */
.brave-usage-bar {
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 8px;
    padding: 0.625rem 1rem;
    margin: 1rem 0 1.25rem;
}
.brave-usage-bar__label {
    color: var(--color-text);
    font-size: 0.85rem;
    margin-bottom: 0.5rem;
}
.brave-usage-bar__hint {
    color: var(--color-text-muted);
    font-size: 0.78rem;
}
.brave-usage-bar__track {
    background: rgba(255, 255, 255, 0.06);
    height: 6px;
    border-radius: 3px;
    overflow: hidden;
}
.brave-usage-bar__fill {
    background: var(--color-orange);
    height: 100%;
    transition: width .3s ease;
    min-width: 0%;
}
.brave-usage-bar--warn { border-color: rgba(245, 158, 11, 0.5); }
.brave-usage-bar--warn .brave-usage-bar__fill { background: #f59e0b; }
.brave-usage-bar--over { border-color: rgba(239, 68, 68, 0.6); }
.brave-usage-bar--over .brave-usage-bar__fill { background: #ef4444; }
.brave-usage-bar--over .brave-usage-bar__label { color: #ef4444; }


/* AI Usage widget on admin home — headline cost + per-model table. */
.ai-usage-section { margin-top: var(--space-4); }
.ai-usage-grid {
    display: grid;
    grid-template-columns: minmax(180px, 220px) 1fr;
    gap: 1.5rem;
    align-items: start;
}
@media (max-width: 720px) {
    .ai-usage-grid { grid-template-columns: 1fr; }
}
.ai-usage-headline {
    background: var(--color-bg-raised);
    border: 1px solid var(--color-orange);
    border-radius: 10px;
    padding: 1rem 1.25rem;
    box-shadow: 0 4px 14px rgba(232, 101, 10, 0.12);
}
.ai-usage-headline__cost {
    font-size: 2.2rem;
    font-weight: 700;
    color: var(--color-orange);
    line-height: 1;
}
.ai-usage-headline__hint {
    color: var(--color-text-muted);
    font-size: 0.78rem;
    margin-top: 0.4rem;
}

.ai-usage-models {
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 10px;
    padding: 0.75rem 1rem;
    overflow-x: auto;
}
.ai-usage-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.85rem;
}
.ai-usage-table thead th {
    color: var(--color-text-muted);
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    text-align: left;
    padding: 0.4rem 0.6rem;
    border-bottom: 1px solid var(--color-border);
    font-weight: 600;
}
.ai-usage-table tbody td {
    padding: 0.55rem 0.6rem;
    border-bottom: 1px solid var(--color-border-subtle, #2a2a2a);
    color: var(--color-text);
}
.ai-usage-table tbody tr:last-child td { border-bottom: 0; }
.ai-usage-table code {
    background: rgba(255, 255, 255, 0.04);
    padding: 2px 6px;
    border-radius: 4px;
    font-size: 0.78rem;
}
.ai-usage-table__num {
    text-align: right;
    font-variant-numeric: tabular-nums;
}

.lead-debug__pre {
    margin: 0;
    padding: 0.5rem;
    background: rgba(0, 0, 0, 0.3);
    border-radius: 4px;
    color: var(--color-text);
    font-family: ui-monospace, 'SF Mono', 'Cascadia Mono', Menlo, monospace;
    font-size: 0.72rem;
    white-space: pre-wrap;
    word-break: break-word;
    overflow-x: auto;
    max-height: 280px;
}


/* ── DMARC dashboard ────────────────────────────────────────────── */

.dmarc-trend-card { margin: 1rem 0; }
.dmarc-trend {
    display: flex;
    align-items: flex-end;
    gap: 4px;
    height: 140px;
    padding: 0.5rem 0 0;
}
.dmarc-trend__col {
    flex: 1 0 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    min-width: 18px;
    cursor: help;
}
.dmarc-trend__bar {
    flex: 1;
    width: 80%;
    display: flex;
    flex-direction: column-reverse;  /* pass on top, fail on bottom */
    background: rgba(255, 255, 255, 0.03);
    border-radius: 3px 3px 0 0;
    overflow: hidden;
}
.dmarc-trend__pass {
    background: #10b981;
    min-height: 1px;
}
.dmarc-trend__fail {
    background: #ef4444;
    min-height: 1px;
}
.dmarc-trend__empty {
    width: 100%;
    height: 2px;
    align-self: flex-end;
    background: rgba(255, 255, 255, 0.05);
}
.dmarc-trend__label {
    font-size: 0.65rem;
    color: var(--color-text-muted);
    margin-top: 4px;
    white-space: nowrap;
}
.dmarc-trend__legend {
    display: flex;
    gap: 1.25rem;
    font-size: 0.78rem;
    color: var(--color-text-muted);
    margin-top: 0.75rem;
}
.dmarc-swatch {
    display: inline-block;
    width: 10px;
    height: 10px;
    border-radius: 2px;
    margin-right: 4px;
    vertical-align: middle;
}
.dmarc-swatch--pass { background: #10b981; }
.dmarc-swatch--fail { background: #ef4444; }

.dmarc-two-col {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
    margin: 1rem 0;
}
@media (max-width: 900px) {
    .dmarc-two-col { grid-template-columns: 1fr; }
}

.dmarc-num {
    text-align: right;
    font-variant-numeric: tabular-nums;
}
.dmarc-num--good { color: #10b981; }
.dmarc-num--warn { color: #f59e0b; }
.dmarc-num--bad  { color: #ef4444; }
.dmarc-small { font-size: 0.78rem; }

.dmarc-upload-form {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin-top: 0.5rem;
    flex-wrap: wrap;
}
.dmarc-upload-form input[type="file"] {
    color: var(--color-text);
}
.dmarc-help {
    margin-top: 1rem;
    border-top: 1px solid var(--color-border);
    padding-top: 0.75rem;
}
.dmarc-help summary {
    cursor: pointer;
    color: var(--color-text-muted);
    font-size: 0.85rem;
    list-style: none;
    font-weight: 600;
}
.dmarc-help summary::-webkit-details-marker { display: none; }
.dmarc-help[open] summary { margin-bottom: 0.5rem; }


/* ── Outreach approvals queue ──────────────────────────────────────── */
.approval-card {
    margin-bottom: 1rem;
}
.approval-card .admin-card__header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
}
.approval-card__meta {
    margin: 0.25rem 0 0;
    font-size: 0.85rem;
    line-height: 1.5;
}
.approval-card__reason {
    color: var(--color-text-muted);
    font-style: italic;
}
.approval-card__kind {
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    padding: 0.2rem 0.6rem;
    border-radius: 999px;
    white-space: nowrap;
    flex-shrink: 0;
}
.approval-card__kind--cold {
    background: rgba(232, 101, 10, 0.15);
    color: #FB923C;
    border: 1px solid rgba(232, 101, 10, 0.3);
}
.approval-card__kind--reply {
    background: rgba(59, 130, 246, 0.15);
    color: #60A5FA;
    border: 1px solid rgba(59, 130, 246, 0.3);
}
.approval-card__form {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    padding: 0 1rem 1rem;
}
.approval-card__field-label {
    display: block;
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--color-text-muted);
    margin-bottom: 0.25rem;
}
.approval-card__subject,
.approval-card__body {
    width: 100%;
    background: rgba(0, 0, 0, 0.2);
    border: 1px solid var(--color-border);
    color: var(--color-text);
    border-radius: 6px;
    padding: 0.6rem 0.8rem;
    font-family: inherit;
    font-size: 0.9rem;
    line-height: 1.5;
}
.approval-card__body {
    resize: vertical;
    min-height: 200px;
    font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
    font-size: 0.85rem;
}
.approval-card__subject:focus,
.approval-card__body:focus {
    outline: none;
    border-color: var(--color-orange);
    background: rgba(0, 0, 0, 0.3);
}
.approval-card__actions {
    display: flex;
    gap: 0.5rem;
    justify-content: flex-end;
}


/* ── Scrape jobs ────────────────────────────────────────────────────── */
.status-pill--success {
    background: rgba(74, 222, 128, 0.12);
    color: var(--color-success);
    border-color: rgba(74, 222, 128, 0.3);
}
.status-pill--muted {
    background: rgba(255, 255, 255, 0.04);
    color: var(--color-text-muted);
    border-color: var(--color-border);
}
/* Compact button variant — for dense table action clusters. Half the
   padding of .btn-sm, smaller font, still tap-friendly on touch. */
.btn-xs {
    padding: 0.25rem 0.55rem;
    font-size: 0.72rem;
    font-weight: 600;
    border-radius: 4px;
    line-height: 1.2;
    text-transform: none;
    letter-spacing: 0;
    white-space: nowrap;
}
/* Scrape-jobs table action cell — keep every button on one row.
   Forms are inline-block siblings, not flex children, so the row
   degrades to a horizontal scroll bar rather than wrapping. */
.scrape-jobs-table__actions {
    white-space: nowrap;
    text-align: right;
}
.scrape-jobs-table__actions > form {
    display: inline-block;
    margin: 0 0 0 0.25rem;
}
.scrape-jobs-table__actions > a {
    margin-left: 0.25rem;
}
.scrape-jobs-table__actions > *:first-child {
    margin-left: 0;
}
.scrape-jobs-table__actions-col { text-align: right; }
.scrape-jobs-table__delete {
    color: var(--color-danger);
}
.scrape-jobs-table__delete:hover {
    border-color: rgba(248, 113, 113, 0.4);
}
.scrape-jobs-table code {
    font-size: 0.85rem;
    color: var(--color-text);
}


/* ── Enrichment status page ────────────────────────────────────────── */
.enrichment-stats {
    margin-bottom: 0.5rem;
}
.enrichment-stats__asof {
    font-size: 0.8rem;
    margin: 0 0 1.25rem;
}
.enrichment-chips {
    display: flex;
    gap: 0.3rem;
    flex-wrap: wrap;
}
.enrichment-chip {
    display: inline-block;
    font-size: 0.7rem;
    font-weight: 600;
    padding: 0.18rem 0.5rem;
    border-radius: 4px;
    line-height: 1.3;
    white-space: nowrap;
    border: 1px solid transparent;
}
.enrichment-chip--ok {
    background: rgba(74, 222, 128, 0.12);
    color: var(--color-success);
    border-color: rgba(74, 222, 128, 0.25);
}
.enrichment-chip--miss {
    background: rgba(248, 113, 113, 0.10);
    color: var(--color-danger);
    border-color: rgba(248, 113, 113, 0.22);
}
.enrichment-activity td { vertical-align: top; }


/* ── Briefs landing + blank builder ────────────────────────────────── */
.brief-card-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(380px, 1fr));
    gap: 1.5rem;
    margin-top: 1.5rem;
}
.brief-card {
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 12px;
    padding: 1.75rem;
    display: flex;
    flex-direction: column;
    gap: 1rem;
}
.brief-card__eyebrow {
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--color-orange);
}
.brief-card__title {
    margin: 0;
    font-size: 1.5rem;
    color: var(--color-text);
}
.brief-card__body {
    margin: 0;
    color: var(--color-text-muted);
    line-height: 1.6;
}
.brief-card__bullets {
    margin: 0;
    padding-left: 1.2rem;
    color: var(--color-text-muted);
    font-size: 0.9rem;
    line-height: 1.7;
}
.brief-card__bullets code {
    font-size: 0.85em;
    color: var(--color-text);
    background: rgba(255, 255, 255, 0.05);
    padding: 1px 5px;
    border-radius: 3px;
}
.brief-card > .btn-primary {
    align-self: flex-start;
    margin-top: 0.5rem;
}

/* The builder is a full-bleed split — escape the normal admin-container
   padding so the preview can be wide enough to read code blocks. */
.brief-builder {
    padding: 1.5rem 2rem;
    max-width: 100%;
}
.brief-builder__header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
    margin-bottom: 1.5rem;
    flex-wrap: wrap;
}
.brief-builder__header-actions {
    display: flex;
    gap: 0.5rem;
    align-items: center;
}
.brief-builder__split {
    display: grid;
    grid-template-columns: minmax(0, 440px) minmax(0, 1fr);
    gap: 1.5rem;
    align-items: start;
}
@media (max-width: 1100px) {
    .brief-builder__split {
        grid-template-columns: 1fr;
    }
}

.brief-builder__form {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    max-height: calc(100vh - 200px);
    overflow-y: auto;
    padding-right: 0.75rem;
}
.brief-section {
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 10px;
    padding: 1.25rem;
    margin: 0;
}
.brief-section__title {
    font-size: 0.78rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--color-orange);
    padding: 0 0.4rem;
    margin-bottom: 0.5rem;
}
.brief-field {
    margin-top: 0.85rem;
}
.brief-field__label {
    display: block;
    font-size: 0.78rem;
    font-weight: 600;
    color: var(--color-text-muted);
    margin-bottom: 0.3rem;
}
.brief-field__input {
    width: 100%;
    background: rgba(0, 0, 0, 0.25);
    border: 1px solid var(--color-border);
    color: var(--color-text);
    border-radius: 6px;
    padding: 0.55rem 0.75rem;
    font-family: inherit;
    font-size: 0.88rem;
    line-height: 1.5;
}
textarea.brief-field__input {
    font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
    font-size: 0.82rem;
    resize: vertical;
}
.brief-field__input:focus {
    outline: none;
    border-color: var(--color-orange);
    background: rgba(0, 0, 0, 0.35);
}
.brief-field__help {
    margin: 0.3rem 0 0;
    font-size: 0.75rem;
    color: var(--color-text-muted);
    line-height: 1.4;
}
.brief-field__default-label {
    color: var(--color-orange);
    font-weight: 700;
    margin-right: 0.25rem;
}
.brief-builder__form-footer {
    margin-top: 1rem;
    display: flex;
    justify-content: flex-end;
}

.brief-builder__preview {
    position: sticky;
    top: 1rem;
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 10px;
    overflow: hidden;
    max-height: calc(100vh - 120px);
    display: flex;
    flex-direction: column;
}
.brief-builder__preview-bar {
    padding: 0.6rem 1rem;
    border-bottom: 1px solid var(--color-border);
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 0.82rem;
}
.brief-builder__preview-body {
    margin: 0;
    padding: 1rem 1.25rem;
    background: rgba(0, 0, 0, 0.25);
    color: var(--color-text);
    font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
    font-size: 0.8rem;
    line-height: 1.55;
    overflow-y: auto;
    white-space: pre-wrap;
    word-wrap: break-word;
    flex: 1;
}


/* ── Onboarding wizard ─────────────────────────────────────────────── */
.onboarding-shell {
    max-width: 760px;
    margin: 2rem auto;
    padding: 0 1rem;
}
.ob-card {
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 12px;
    padding: 2rem;
    color: var(--color-text);
}
.ob-card + .ob-card { margin-top: 1.5rem; }
.ob-title {
    font-size: 1.75rem;
    margin: 0 0 1rem;
    color: var(--color-text);
}
.ob-intro {
    color: var(--color-text-muted);
    font-size: 1rem;
    line-height: 1.6;
}
.ob-section-list {
    color: var(--color-text-muted);
    margin: 1rem 0 1.25rem 1.2rem;
    line-height: 1.7;
}
.ob-warning {
    background: rgba(248, 113, 113, 0.08);
    border: 1px solid rgba(248, 113, 113, 0.3);
    color: var(--color-text);
    padding: 0.85rem 1rem;
    border-radius: 8px;
    margin: 1.25rem 0;
    line-height: 1.5;
}
.ob-warning strong { color: var(--color-danger); }
.ob-start-form { margin-top: 1.5rem; }

/* Breadcrumbs */
.ob-breadcrumbs {
    list-style: none;
    padding: 0;
    margin: 0 0 1rem;
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem 0.5rem;
    font-size: 0.75rem;
    color: var(--color-text-muted);
}
.ob-breadcrumb {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.2rem 0.55rem;
    border-radius: 999px;
    border: 1px solid var(--color-border);
}
.ob-breadcrumb--current {
    color: var(--color-orange);
    border-color: rgba(232, 101, 10, 0.4);
    background: rgba(232, 101, 10, 0.08);
}
.ob-breadcrumb--done {
    color: var(--color-success);
    border-color: rgba(74, 222, 128, 0.3);
}

/* Progress */
.ob-progress {
    height: 8px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.06);
    overflow: hidden;
    margin-bottom: 0.4rem;
}
.ob-progress__fill {
    height: 100%;
    background: linear-gradient(90deg, var(--color-orange), var(--color-orange-light));
    transition: width 0.3s ease;
}
.ob-progress__caption {
    margin: 0 0 1.25rem;
    color: var(--color-text-muted);
    font-size: 0.75rem;
}

/* Section header */
.ob-section-title {
    font-size: 1.1rem;
    margin: 1rem 0 0.5rem;
    color: var(--color-text);
}
.ob-section-intro {
    color: var(--color-text-muted);
    margin: 0 0 1rem;
    font-size: 0.9rem;
}

/* Questions */
.ob-question {
    margin: 1.25rem 0;
    padding: 1rem;
    background: rgba(0, 0, 0, 0.18);
    border: 1px solid var(--color-border);
    border-radius: 8px;
}
.ob-question__label {
    display: block;
    font-weight: 600;
    margin-bottom: 0.4rem;
    color: var(--color-text);
}
.ob-required {
    color: var(--color-danger);
    font-size: 0.7rem;
    font-weight: 700;
    margin-left: 0.4rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}
.ob-question__help {
    margin: 0 0 0.5rem;
    color: var(--color-text-muted);
    font-size: 0.8rem;
}
.ob-question__input {
    width: 100%;
    background: rgba(0, 0, 0, 0.3);
    border: 1px solid var(--color-border);
    color: var(--color-text);
    border-radius: 6px;
    padding: 0.55rem 0.75rem;
    font-family: inherit;
    font-size: 0.92rem;
}
.ob-question__input:disabled {
    opacity: 0.4;
    cursor: not-allowed;
}
.ob-question__input:focus {
    outline: none;
    border-color: var(--color-orange);
    background: rgba(0, 0, 0, 0.4);
}
.ob-question__skip {
    background: none;
    border: 0;
    color: var(--color-text-muted);
    font-size: 0.78rem;
    cursor: pointer;
    margin-top: 0.4rem;
    padding: 0.2rem 0;
}
.ob-question__skip:hover { color: var(--color-orange); }
.ob-question__skip[aria-pressed="true"] {
    color: var(--color-warning, var(--color-orange));
}
.ob-question__saved {
    display: inline-block;
    margin-top: 0.4rem;
    color: var(--color-success);
    font-size: 0.75rem;
}

/* Footer nav */
.ob-step-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 0.75rem;
    margin-top: 1.5rem;
    padding-top: 1.25rem;
    border-top: 1px solid var(--color-border);
}


/* ── Setup To-Do widget ───────────────────────────────────────────── */
.portal-nav__todo {
    border-bottom: 1px solid var(--color-border);
    margin-bottom: 0.6rem;
    padding-bottom: 0.9rem;
}
.portal-nav__badge {
    margin-left: auto;
    background: var(--color-orange);
    color: #fff;
    font-size: 0.7rem;
    font-weight: 700;
    padding: 0.1rem 0.45rem;
    border-radius: 999px;
    min-width: 1.4rem;
    text-align: center;
}

.todo-overlay {
    position: fixed;
    inset: 0;
    background: rgba(7, 6, 20, 0.78);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1rem;
    z-index: 5000;
}
.todo-overlay__shell {
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 14px;
    width: 100%;
    max-width: 560px;
    max-height: 80vh;
    overflow-y: auto;
    padding: 1.5rem;
    position: relative;
}
.todo-overlay__close {
    position: absolute;
    top: 0.75rem;
    right: 0.85rem;
    background: none;
    border: 0;
    color: var(--color-text-muted);
    font-size: 1.5rem;
    cursor: pointer;
    line-height: 1;
}
.todo-overlay__close:hover { color: var(--color-text); }
.todo-modal__title {
    margin: 0 0 1rem;
    font-size: 1.1rem;
    color: var(--color-text);
}
.todo-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}
.todo-item {
    background: rgba(0, 0, 0, 0.25);
    border: 1px solid var(--color-border);
    border-radius: 8px;
    padding: 0.75rem 0.9rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
}
.todo-item__main { flex: 1; min-width: 0; }
.todo-item__title { color: var(--color-text); }
.todo-item__desc {
    margin: 0.25rem 0 0;
    color: var(--color-text-muted);
    font-size: 0.8rem;
    line-height: 1.45;
}
.todo-item--done {
    opacity: 0.7;
    font-size: 0.85rem;
    padding: 0.5rem 0.9rem;
}
.todo-item__when { font-size: 0.75rem; }
.todo-completed { margin-top: 1.25rem; }
.todo-completed summary {
    cursor: pointer;
    color: var(--color-text-muted);
    font-size: 0.85rem;
    font-weight: 600;
    list-style: none;
}
.todo-completed[open] summary { margin-bottom: 0.5rem; }
.todo-completed summary::-webkit-details-marker { display: none; }
.todo-list--done { gap: 0.25rem; margin-top: 0.5rem; }
.todo-modal__empty {
    text-align: center;
    padding: 1.5rem 0;
}


/* ── Checkout (Stripe Elements) ───────────────────────────────────── */
.checkout-shell {
    max-width: 1080px;
    margin: 2.5rem auto;
    padding: 0 1.5rem;
    color: var(--color-text);
}
.checkout-grid {
    display: grid;
    grid-template-columns: 360px 1fr;
    gap: 2rem;
}
@media (max-width: 880px) {
    .checkout-grid { grid-template-columns: 1fr; }
}
.checkout-summary {
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 12px;
    padding: 1.5rem;
    align-self: start;
    position: sticky;
    top: 1.5rem;
}
.checkout-summary__title { margin: 0 0 0.25rem; font-size: 1.2rem; }
.checkout-summary__price { margin: 0 0 0.5rem; font-size: 1.5rem; color: var(--color-orange); }
.checkout-summary__tagline { color: var(--color-text-muted); margin: 0 0 1rem; }
.checkout-features {
    list-style: none;
    padding: 0;
    margin: 1rem 0;
    color: var(--color-text-muted);
    font-size: 0.9rem;
    line-height: 1.6;
}
.checkout-divider {
    border: 0;
    border-top: 1px solid var(--color-border);
    margin: 1rem 0;
}
.checkout-totals { font-size: 0.9rem; }
.checkout-total {
    display: flex;
    justify-content: space-between;
    align-items: center;
    color: var(--color-text);
    font-weight: 600;
}
.checkout-total-note { font-size: 0.75rem; margin: 0.4rem 0 0; }
.checkout-upsell {
    display: flex;
    gap: 0.6rem;
    background: rgba(232, 101, 10, 0.08);
    border: 1px solid rgba(232, 101, 10, 0.35);
    border-radius: 8px;
    padding: 0.75rem;
    margin-top: 1rem;
    color: var(--color-text);
    font-size: 0.85rem;
    cursor: pointer;
}
.checkout-form {
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 12px;
    padding: 1.75rem;
}
.checkout-form__title {
    margin: 0 0 1.25rem;
    font-size: 1.25rem;
}
.checkout-form .form-group {
    margin: 0 0 1rem;
}
.checkout-form label {
    display: block;
    font-weight: 600;
    font-size: 0.85rem;
    margin-bottom: 0.35rem;
    color: var(--color-text);
}
.checkout-form input[type="email"] {
    width: 100%;
    background: rgba(0, 0, 0, 0.3);
    border: 1px solid var(--color-border);
    color: var(--color-text);
    border-radius: 6px;
    padding: 0.55rem 0.75rem;
    font-family: inherit;
    font-size: 0.95rem;
}
#payment-element, #address-element {
    background: rgba(0, 0, 0, 0.18);
    padding: 0.85rem;
    border-radius: 8px;
    border: 1px solid var(--color-border);
}
.checkout-submit {
    width: 100%;
    margin-top: 0.5rem;
}
/* Button processing state — inline spinner so a click gives instant
   feedback while we talk to Stripe. */
.btn-spinner {
    display: inline-block;
    width: 1em;
    height: 1em;
    margin-right: 0.5em;
    border: 2px solid rgba(255, 255, 255, 0.45);
    border-top-color: #ffffff;
    border-radius: 50%;
    vertical-align: -0.15em;
    animation: btn-spin 0.6s linear infinite;
}
button.is-loading { cursor: progress; opacity: 0.85; }
@keyframes btn-spin { to { transform: rotate(360deg); } }

/* Live form-validation indicators (set-password screen). Green check
   when a rule/match is satisfied, red ✕ until then. Driven by JS adding
   the .valid / .ok class — no inline styles (CSP_PUBLIC is strict). */
.pw-rules {
    list-style: none;
    padding: 0;
    margin: 0.5rem 0 1rem;
    font-size: 0.85rem;
}
.pw-rules li {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    line-height: 1.85;
    color: var(--color-text-muted, #94A3B8);
}
.pw-rules li::before {
    content: '\2715'; /* ✕ */
    display: inline-block;
    width: 1.1em;
    text-align: center;
    font-weight: 700;
    color: #F87171;
}
.pw-rules li.valid { color: var(--color-text, #fff); }
.pw-rules li.valid::before { content: '\2713'; color: #34D399; } /* ✓ */

.match-hint {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.85rem;
    margin: 0.35rem 0 0;
    color: #F87171;
}
.match-hint::before {
    content: '\2715';
    font-weight: 700;
    color: #F87171;
}
.match-hint.ok { color: #34D399; }
.match-hint.ok::before { content: '\2713'; color: #34D399; }
.ob-pin-note { font-size: 0.8rem; }
.checkout-secure {
    text-align: center;
    margin-top: 1rem;
    font-size: 0.8rem;
}
.checkout-error {
    background: rgba(248, 113, 113, 0.12);
    border: 1px solid rgba(248, 113, 113, 0.4);
    color: var(--color-danger);
    padding: 0.65rem 0.85rem;
    border-radius: 6px;
    margin: 0 0 1rem;
    font-size: 0.85rem;
}
.checkout-success {
    text-align: center;
    padding: 3rem 1rem;
    max-width: 600px;
    margin: 0 auto;
}
.checkout-success__lead {
    font-size: 1.1rem;
    color: var(--color-text-muted);
    line-height: 1.6;
    margin: 1rem 0;
}


/* ── Schedule-a-Call page (matches contact-grid layout) ──────────── */
.schedule-slots__list {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    margin-top: 0.5rem;
}
.schedule-day {
    background: rgba(0, 0, 0, 0.18);
    border: 1px solid var(--color-border);
    border-radius: 8px;
    padding: 0.85rem 0.75rem;
}
.schedule-day__heading {
    font-weight: 700;
    color: var(--color-text);
    margin-bottom: 0.5rem;
    font-size: 0.92rem;
}
.schedule-slot {
    display: inline-block;
    background: var(--color-bg-raised);
    color: var(--color-text);
    border: 1px solid var(--color-border);
    border-radius: 6px;
    padding: 0.4rem 0.7rem;
    margin: 0.2rem 0.25rem 0 0;
    font-size: 0.82rem;
    cursor: pointer;
    font-family: inherit;
    transition: border-color 120ms, background 120ms;
}
.schedule-slot:hover {
    border-color: var(--color-orange);
    color: var(--color-orange);
}
.schedule-slot--picked {
    background: var(--color-orange);
    color: #fff;
    border-color: var(--color-orange);
}
.schedule-submit { width: 100%; }

/* ── Calendar booking widget (/design/schedule/) ──────────────────
   Month grid + per-day slot strip. Light theme, lives inside the
   .card on the schedule page. */
.cal {
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 10px;
    padding: 0.85rem 0.95rem 1rem;
}
.cal__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    margin-bottom: 0.75rem;
}
.cal__month-label {
    font-weight: 700;
    font-size: 1.02rem;
    color: var(--color-text);
}
.cal__nav {
    background: transparent;
    color: var(--color-text);
    border: 1px solid var(--color-border);
    border-radius: 6px;
    width: 32px;
    height: 32px;
    font-size: 1.1rem;
    cursor: pointer;
    transition: border-color 120ms, color 120ms;
    font-family: inherit;
    line-height: 1;
}
.cal__nav:hover:not(:disabled) {
    border-color: var(--color-orange);
    color: var(--color-orange);
}
.cal__nav:disabled {
    opacity: 0.35;
    cursor: not-allowed;
}

.cal__weekdays {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 4px;
    margin-bottom: 4px;
}
.cal__weekday {
    text-align: center;
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--color-text-muted, #94A3B8);
    padding: 4px 0;
}
.cal__grid {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 4px;
}
.cal__cell {
    background: rgba(255, 255, 255, 0.04);
    color: #E2E8F0;
    border: 1px solid rgba(148, 163, 184, 0.18);
    border-radius: 6px;
    aspect-ratio: 1 / 1;
    font-family: inherit;
    font-size: 0.95rem;
    font-weight: 500;
    cursor: pointer;
    transition: border-color 120ms, background 120ms, color 120ms;
    padding: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}
.cal__cell--pad {
    background: transparent;
    border-color: transparent;
    cursor: default;
}
.cal__cell--open {
    background: rgba(255, 255, 255, 0.06);
    border-color: rgba(148, 163, 184, 0.28);
}
.cal__cell--open:hover {
    border-color: var(--color-orange);
    color: var(--color-orange);
    background: rgba(232, 101, 10, 0.08);
}
.cal__cell--closed,
.cal__cell--past {
    color: rgba(148, 163, 184, 0.55);
    background: transparent;
    border-color: rgba(148, 163, 184, 0.10);
    cursor: not-allowed;
}
.cal__cell--today {
    border-color: var(--color-orange);
    font-weight: 700;
}
.cal__cell--selected,
.cal__cell--selected.cal__cell--today {
    background: var(--color-orange);
    color: #fff;
    border-color: var(--color-orange);
}

.cal-slots {
    margin-top: 1rem;
}
.cal-slots__empty {
    margin: 0;
    color: var(--color-text-muted, #94A3B8);
    font-size: 0.9rem;
}
.cal-slots__heading {
    font-weight: 700;
    margin-bottom: 0.5rem;
    color: var(--color-text);
    font-size: 0.95rem;
}
.cal-slots__grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(96px, 1fr));
    gap: 6px;
}
.cal-slot {
    background: var(--color-bg-raised);
    color: var(--color-text);
    border: 1px solid var(--color-border);
    border-radius: 6px;
    padding: 0.55rem 0.5rem;
    font-size: 0.9rem;
    font-family: inherit;
    cursor: pointer;
    transition: border-color 120ms, background 120ms, color 120ms;
    text-align: center;
}
.cal-slot:hover {
    border-color: var(--color-orange);
    color: var(--color-orange);
}
.cal-slot--picked {
    background: var(--color-orange);
    color: #fff;
    border-color: var(--color-orange);
}
.cal-error {
    color: #B91C1C;
    margin: 0;
}

@media (max-width: 520px) {
    .cal__cell { font-size: 0.85rem; }
    .cal-slots__grid {
        grid-template-columns: repeat(auto-fill, minmax(80px, 1fr));
    }
}

/* ── Addon opt-in fieldset (used on schedule + reusable elsewhere) ─ */
.addon-fieldset {
    border: 1px solid var(--color-border);
    border-radius: 8px;
    padding: 1rem 1.1rem;
    margin: 0;
}
.addon-fieldset__legend {
    padding: 0 0.5rem;
    font-weight: 700;
    color: var(--color-orange);
    font-size: 0.85rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}
.addon-fieldset__hint {
    margin: 0 0 0.85rem;
}
.addon-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0.5rem;
}
@media (min-width: 600px) {
    .addon-grid { grid-template-columns: 1fr 1fr; }
}
.addon-option {
    display: flex;
    align-items: flex-start;
    gap: 0.65rem;
    background: rgba(0, 0, 0, 0.2);
    border: 1px solid var(--color-border);
    border-radius: 8px;
    padding: 0.7rem 0.85rem;
    cursor: pointer;
    transition: border-color 120ms, background 120ms;
}
.addon-option:hover {
    border-color: var(--color-orange);
    background: rgba(232, 101, 10, 0.08);
}
.addon-option__check {
    margin-top: 0.18rem;
    accent-color: var(--color-orange);
}
.addon-option__body {
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
}
.addon-option__title {
    font-weight: 700;
    color: var(--color-text);
    font-size: 0.92rem;
}
.addon-option__meta {
    color: var(--color-text-muted);
    font-size: 0.8rem;
}
.addon-option__discount {
    color: var(--color-orange);
    font-weight: 600;
}
.addon-option__tagline {
    color: var(--color-text-muted);
    font-size: 0.78rem;
    line-height: 1.4;
}
.addon-group + .addon-group {
    margin-top: 1.25rem;
    padding-top: 1rem;
    border-top: 1px solid var(--color-border);
}
.addon-group__title {
    margin: 0 0 0.2rem;
    font-size: 0.95rem;
    color: var(--color-text);
    font-weight: 700;
}
.addon-group__sub {
    margin: 0 0 0.7rem;
    color: var(--color-text-muted);
    font-size: 0.82rem;
    line-height: 1.4;
}


/* ── System alerts ───────────────────────────────────────────────── */
.system-alerts-banner {
    background: rgba(248, 113, 113, 0.12);
    border: 1px solid rgba(248, 113, 113, 0.4);
    border-left: 4px solid var(--color-danger);
    color: var(--color-text);
    padding: 0.85rem 1.1rem;
    border-radius: 8px;
    margin-bottom: 1.25rem;
    display: flex;
    align-items: center;
    gap: 0.75rem;
}
.system-alerts-banner__icon {
    font-size: 1.3rem;
    color: var(--color-danger);
}
.system-alerts-banner a {
    color: var(--color-orange);
    font-weight: 600;
}
.alert-card { margin-bottom: 1rem; }
.alert-card--error,
.alert-card--critical { border-left: 4px solid var(--color-danger); }
.alert-card--warning  { border-left: 4px solid var(--color-orange); }
.alert-severity {
    display: inline-block;
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    padding: 0.15rem 0.55rem;
    border-radius: 999px;
    margin-right: 0.5rem;
}
.alert-severity--info     { background: rgba(96, 165, 250, 0.15); color: #60A5FA; }
.alert-severity--warning  { background: rgba(232, 101, 10, 0.15); color: var(--color-orange-light); }
.alert-severity--error    { background: rgba(248, 113, 113, 0.15); color: var(--color-danger); }
.alert-severity--critical { background: rgba(248, 113, 113, 0.25); color: var(--color-danger); font-weight: 800; }
/* ── Phase D5 — per-service portal cards ────────────────────────── */
.portal-section { margin-top: 2rem; }
.portal-section__title {
    margin: 0 0 0.75rem;
    font-size: 1.05rem;
    color: var(--color-text);
}
.service-card {
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 10px;
    padding: 1rem 1.15rem;
    margin-bottom: 0.75rem;
}
.service-card__head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 0.4rem;
}
.service-card__meta {
    color: var(--color-text-muted);
    font-size: 0.85rem;
    line-height: 1.5;
}
.service-card__since {
    font-size: 0.78rem;
    margin-top: 0.25rem;
}
.service-card__channels {
    margin: 0.5rem 0 0;
    padding-left: 1.1rem;
    color: var(--color-text-muted);
    font-size: 0.85rem;
}

.alert-detail {
    background: rgba(0, 0, 0, 0.3);
    padding: 0.75rem;
    border-radius: 6px;
    margin: 0.5rem 0 0;
    color: var(--color-text-muted);
    font-size: 0.78rem;
    font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
    white-space: pre-wrap;
    word-wrap: break-word;
    max-height: 400px;
    overflow-y: auto;
}

/* Accessible off-screen hiding — used by the contact-form honeypot
   (the project's strict 'style-src self' CSP blocks inline styles, so
   an inline `position:absolute;left:-9999px` no-ops and the honeypot
   leaks onto the page). */
.visually-hidden {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    padding: 0 !important;
    margin: -1px !important;
    overflow: hidden !important;
    clip: rect(0, 0, 0, 0) !important;
    white-space: nowrap !important;
    border: 0 !important;
}


/* ── Contact-triage chips on /admin-dashboard/leads/ ─────────────── */
.contact-chips {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
    margin-bottom: 1rem;
}
.contact-chip {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.4rem 0.85rem;
    font-size: 0.78rem;
    font-weight: 600;
    border-radius: 999px;
    text-decoration: none;
    background: rgba(255, 255, 255, 0.04);
    color: var(--color-text-muted);
    border: 1px solid var(--color-border);
    transition: all 120ms ease;
}
.contact-chip:hover {
    background: rgba(255, 255, 255, 0.08);
    color: var(--color-text);
}
.contact-chip--active {
    background: var(--color-orange);
    color: #fff;
    border-color: var(--color-orange);
}
.contact-chip--active:hover {
    background: var(--color-orange-dark, #C45508);
    color: #fff;
}
.contact-chip--warn {
    border-color: rgba(232, 101, 10, 0.4);
}
.contact-chip--ok.contact-chip--active {
    background: var(--color-success);
    border-color: var(--color-success);
}


/* ── Sent emails dashboard ────────────────────────────────────────── */
.sent-stats { margin-bottom: 1rem; }
.admin-stat__sub {
    display: inline-block;
    margin-left: 0.35rem;
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--color-text-muted);
}
.admin-stat--good { color: var(--color-success); }
.sent-filter-row {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    margin-bottom: 0.5rem;
}
.sent-table {
    min-width: 900px;
}
.sent-table__when {
    white-space: nowrap;
    font-variant-numeric: tabular-nums;
    width: 90px;
}
.sent-table__subject {
    max-width: 380px;
    overflow-wrap: anywhere;
}
.sent-table__none { font-size: 1.1rem; }
.sent-table td { vertical-align: top; }


/* ── Redis monitor ─────────────────────────────────────────────────── */
.redis-chart {
    display: flex;
    align-items: flex-end;
    gap: 4px;
    height: 140px;
    padding: 0.5rem 0;
}
.redis-chart__col {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-end;
    height: 100%;
}
.redis-chart__bar {
    width: 100%;
    background: rgba(232, 101, 10, 0.4);
    border-radius: 2px 2px 0 0;
    min-height: 2px;
    transition: background 120ms ease;
}
.redis-chart__bar--now {
    background: var(--color-orange);
    box-shadow: 0 0 8px rgba(232, 101, 10, 0.4);
}
.redis-chart__col:hover .redis-chart__bar {
    background: var(--color-orange-light);
}
.redis-chart__label {
    font-size: 0.65rem;
    color: var(--color-text-muted);
    margin-top: 0.3rem;
    font-variant-numeric: tabular-nums;
}
.redis-two-col {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
    margin-top: 1rem;
}
@media (max-width: 1100px) {
    .redis-two-col { grid-template-columns: 1fr; }
}
.redis-row-long {
    background: rgba(248, 113, 113, 0.06);
}
.redis-row-long td:first-child {
    border-left: 3px solid var(--color-danger);
}


/* ── Clients list (Phase C — multi-site expandable rows) ─────────── */
.client-list {
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 12px;
    overflow: hidden;
}
.client-list__head,
.client-list__summary {
    display: grid;
    grid-template-columns:
        minmax(180px, 2fr)   /* name */
        90px                 /* status */
        130px                /* onboarding */
        70px                 /* sites */
        80px                 /* droplets */
        minmax(160px, 1.5fr) /* packages */
        130px                /* scan */
        88px;                /* actions */
    column-gap: 0.75rem;
    align-items: center;
    padding: 0.65rem 1rem;
    font-size: 0.85rem;
}
.client-list__head {
    background: var(--color-bg-deep);
    color: var(--color-text-muted);
    font-size: 0.6875rem;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    font-weight: 700;
    border-bottom: 1px solid var(--color-border);
}
.client-list__row {
    border-bottom: 1px solid var(--color-border);
}
.client-list__row:last-child { border-bottom: 0; }
.client-list__row[open] {
    background: rgba(255, 255, 255, 0.02);
}
.client-list__summary {
    cursor: pointer;
    list-style: none;
    transition: background-color var(--transition);
}
.client-list__summary::-webkit-details-marker { display: none; }
.client-list__summary:hover {
    background: rgba(255, 255, 255, 0.03);
}
.client-list__chev {
    display: inline-block;
    margin-right: 0.4rem;
    color: var(--color-text-muted);
    transition: transform 120ms ease;
}
.client-list__row[open] .client-list__chev {
    transform: rotate(90deg);
}
.client-list__count {
    display: inline-block;
    min-width: 28px;
    padding: 0.15rem 0.5rem;
    border-radius: 999px;
    background: rgba(232, 101, 10, 0.16);
    color: var(--color-orange-light);
    font-weight: 700;
    font-size: 0.78rem;
    text-align: center;
}
.client-list__pkg {
    font-size: 0.78rem;
    overflow-wrap: anywhere;
}
.client-list__col-name a,
.client-list__col-scan a {
    /* These nested links inside the summary need their own click
       handling — the row itself toggles, the links navigate. */
    color: var(--color-orange-light);
}
.client-list__col-name a:hover {
    color: var(--color-orange);
}

.client-list__sub {
    padding: 0.5rem 1rem 1rem 2.5rem;
    display: grid;
    grid-template-columns: 1fr;
    gap: 0.5rem;
    background: rgba(0, 0, 0, 0.18);
}
.client-website {
    display: grid;
    grid-template-columns:
        minmax(180px, 1.5fr)  /* name */
        minmax(180px, 1fr)    /* stage + package */
        minmax(200px, 1fr)    /* droplet */
        minmax(200px, 1.5fr); /* url */
    gap: 0.75rem;
    padding: 0.6rem 0.8rem;
    background: var(--color-bg-raised);
    border: 1px solid var(--color-border);
    border-radius: 8px;
    font-size: 0.82rem;
    align-items: center;
}
.client-website--legacy {
    border-color: rgba(255, 255, 255, 0.12);
    background: rgba(0, 0, 0, 0.1);
}
.client-website__name {
    font-weight: 600;
    overflow-wrap: anywhere;
}
.client-website__name a {
    color: var(--color-text);
}
.client-website__name a:hover {
    color: var(--color-orange-light);
}
.client-website__legacy-pill {
    display: inline-block;
    margin-left: 0.4rem;
    padding: 0.1rem 0.5rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.06);
    color: var(--color-text-muted);
    font-size: 0.65rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}
.client-website__meta {
    display: flex;
    gap: 0.4rem;
    flex-wrap: wrap;
    align-items: center;
}
.client-website__droplet code {
    background: rgba(255, 255, 255, 0.04);
    padding: 1px 6px;
    border-radius: 4px;
    font-size: 0.78rem;
}
.client-website__url {
    overflow-wrap: anywhere;
    font-size: 0.78rem;
}

@media (max-width: 1200px) {
    .client-list__head,
    .client-list__summary {
        grid-template-columns:
            minmax(180px, 2fr)
            90px
            70px      /* sites */
            80px      /* droplets */
            130px     /* scan */
            88px;     /* actions */
    }
    .client-list__col-onboard,
    .client-list__col-package { display: none; }
}
@media (max-width: 800px) {
    .client-list__head { display: none; }
    .client-list__summary {
        grid-template-columns: 1fr auto;
        gap: 0.4rem;
    }
    .client-list__col-status,
    .client-list__col-sites,
    .client-list__col-droplets,
    .client-list__col-scan { display: none; }
    .client-website {
        grid-template-columns: 1fr;
    }
}
.scrape-job-form .form-row {
    margin-bottom: 1rem;
}
.scrape-job-form label {
    display: block;
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--color-text-muted);
    margin-bottom: 0.4rem;
}
.scrape-job-form input[type="text"],
.scrape-job-form input[type="number"],
.scrape-job-form select {
    width: 100%;
    max-width: 480px;
    background: rgba(0, 0, 0, 0.2);
    border: 1px solid var(--color-border);
    color: var(--color-text);
    border-radius: 6px;
    padding: 0.6rem 0.8rem;
    font-family: inherit;
    font-size: 0.95rem;
}
.scrape-job-form input:focus,
.scrape-job-form select:focus {
    outline: none;
    border-color: var(--color-orange);
    background: rgba(0, 0, 0, 0.3);
}
.scrape-job-form .form-help {
    margin-top: 0.35rem;
    font-size: 0.8rem;
}
.form-actions {
    display: flex;
    gap: 0.5rem;
    margin-top: 1.5rem;
}
