/* ─────────────────────────────────────────────────────────────────────────────
   Mode CRM — Client Portal Stylesheet
   ───────────────────────────────────────────────────────────────────────────── */

/* ── Portal nav — Canonical brand header pattern (see brand/APP-GUIDELINE.md) ── */
.portal-nav {
    position: sticky;
    top: 0;
    z-index: 100;
    background: rgba(10,10,10,0.96);
    border-bottom: 0.5px solid var(--gunmetal);
    backdrop-filter: blur(8px);
}
.portal-nav__inner {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    max-width: 1100px;
    margin: 0 auto;
    padding: 10px 32px;
    gap: 24px;
}

/* Canonical .brand-header__mark pattern */
.brand-header__mark {
    display: flex; flex-direction: column; align-items: flex-start; gap: 10px;
    margin-left: 0;
    text-decoration: none;
}
.brand-header__mark img { height: 56px; width: auto; display: block; }
.brand-header__name {
    font-size: 13px; font-weight: 500; color: var(--smoke);
    letter-spacing: 0.15em; text-transform: uppercase;
    margin: 0; line-height: 1; padding-left: 0;
}
.portal-nav__links {
    display: flex;
    align-items: center;
    gap: 24px;
}
.portal-nav__link {
    font-size: 12px;
    font-weight: 500;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--smoke);
    text-decoration: none;
    transition: color 200ms ease-out;
}
.portal-nav__link:hover,
.portal-nav__link--active { color: var(--chalk); }
.portal-nav__user {
    font-size: 12px;
    color: var(--dark-grey);
    letter-spacing: 0.04em;
}

/* ── Portal wrap / layout ────────────────────────────────────────────────────── */
.portal-wrap { max-width: 1100px; margin: 0 auto; padding: 24px 32px 32px; }
.portal-main  { width: 100%; }

/* ── Eyebrow ─────────────────────────────────────────────────────────────────── */
.portal-eyebrow {
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--volt);
    margin: 0 0 12px;
}

/* ── Greeting ────────────────────────────────────────────────────────────────── */
.portal-greeting { margin-bottom: 24px; }
.portal-greeting__name {
    font-size: 26px;
    font-weight: 600;
    color: var(--white);
    margin: 0 0 4px;
    line-height: 1.15;
}
.portal-greeting__company { font-size: 15px; color: var(--smoke); margin: 0; }

/* ── Stats ───────────────────────────────────────────────────────────────────── */
.portal-stats {
    display: flex;
    gap: 1px;
    background: var(--gunmetal);
    border: 0.5px solid var(--gunmetal);
    border-radius: var(--radius);
    overflow: hidden;
    margin-top: 12px;
    margin-bottom: 24px;
}
.portal-stat {
    flex: 1;
    background: var(--carbon);
    padding: 14px 20px;
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.portal-stat--alert { background: rgba(244,67,54,0.06); }
.portal-stat__val   { font-size: 22px; font-weight: 600; color: var(--white); line-height: 1.2; }
.portal-stat--alert .portal-stat__val { color: #F44336; }
.portal-stat__label { font-size: 12px; color: var(--smoke); letter-spacing: 0.06em; }

/* ── Sections ────────────────────────────────────────────────────────────────── */
.portal-section { margin-bottom: 32px; }
.portal-section__title {
    font-size: 14px;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--smoke);
    margin: 0 0 20px;
    padding-bottom: 12px;
    border-bottom: 0.5px solid var(--gunmetal);
}
.portal-section__more {
    display: inline-block;
    margin-top: 16px;
    font-size: 13px;
    color: var(--smoke);
    text-decoration: none;
    transition: color 200ms;
}
.portal-section__more:hover { color: var(--chalk); }

/* ── Project cards ───────────────────────────────────────────────────────────── */
.portal-projects { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px,1fr)); gap: 16px; }
.portal-project-card {
    display: block;
    background: var(--carbon);
    border: 0.5px solid var(--gunmetal);
    border-radius: var(--radius);
    padding: 24px;
    text-decoration: none;
    transition: border-color 200ms ease-out;
}
.portal-project-card:hover { border-color: var(--smoke); }
.portal-project-card__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 12px;
}
.portal-project-card__ref {
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 0.12em;
    color: var(--smoke);
    font-family: monospace;
}
.portal-project-card__name {
    font-size: 18px;
    font-weight: 600;
    color: var(--white);
    margin: 0 0 6px;
}
.portal-project-card__subject {
    font-size: 13px;
    color: var(--smoke);
    margin: 0 0 16px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.portal-project-card__foot {
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-size: 12px;
    color: var(--dark-grey);
}
.portal-project-card__invoice-flag {
    font-size: 11px;
    color: #FFD600;
    font-weight: 500;
}

/* ── Status badges ───────────────────────────────────────────────────────────── */
.portal-project-card__status,
.portal-project-status {
    font-size: 10px;
    font-weight: 500;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    padding: 2px 8px;
    border-radius: 2px;
}
.status--in-progress      { background: rgba(0,200,83,0.12);  color: #00C853; }
.status--waiting-customer { background: rgba(255,152,0,0.12); color: #FF9800; }
.status--customer-updated { background: rgba(33,150,243,0.12);color: #2196F3; }
.status--with-staff       { background: rgba(156,39,176,0.12);color: #9C27B0; }
.status--admin-approval   { background: rgba(255,152,0,0.12); color: #FF9800; }
.status--on-hold          { background: var(--gunmetal);       color: var(--smoke); }
.status--complete         { background: rgba(96,125,139,0.12); color: #607D8B; }

/* ── Invoice list (dashboard) ────────────────────────────────────────────────── */
.portal-invoice-list { display: flex; flex-direction: column; gap: 1px; background: var(--gunmetal); border: 0.5px solid var(--gunmetal); border-radius: var(--radius); overflow: hidden; }
.portal-invoice-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    background: var(--carbon);
    padding: 14px 20px;
    gap: 16px;
}
.portal-invoice-row__left { display: flex; flex-direction: column; gap: 2px; }
.portal-invoice-row__num  { font-size: 12px; font-weight: 500; color: var(--chalk); letter-spacing: 0.04em; }
.portal-invoice-row__desc { font-size: 13px; color: var(--smoke); }
.portal-invoice-row__right { display: flex; align-items: center; gap: 16px; }
.portal-invoice-row__amount { font-size: 15px; font-weight: 600; color: var(--white); }
.portal-invoice-row__dl {
    font-size: 12px;
    color: var(--smoke);
    text-decoration: none;
    border-bottom: 0.5px solid var(--gunmetal);
    transition: color 200ms;
}
.portal-invoice-row__dl:hover { color: var(--chalk); }

/* ── Invoice status pills ────────────────────────────────────────────────────── */
.portal-invoice-status {
    font-size: 10px;
    font-weight: 500;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    padding: 2px 8px;
    border-radius: 2px;
}
.portal-invoice-status--draft    { background: var(--gunmetal);       color: var(--smoke); }
.portal-invoice-status--sent     { background: rgba(33,150,243,0.12); color: #2196F3; }
.portal-invoice-status--paid     { background: rgba(0,200,83,0.12);   color: #00C853; }
.portal-invoice-status--overdue  { background: rgba(244,67,54,0.12);  color: #F44336; }
.portal-invoice-status--cancelled{ background: var(--gunmetal);       color: var(--smoke); }

/* ── Full invoices table ─────────────────────────────────────────────────────── */
.portal-invoice-table-wrap { overflow-x: auto; margin-bottom: 24px; }
.portal-invoice-table { width: 100%; border-collapse: collapse; font-size: 14px; }
.portal-invoice-table th {
    text-align: left; font-size: 11px; font-weight: 500;
    letter-spacing: 0.1em; text-transform: uppercase;
    color: var(--smoke); padding: 10px 12px;
    border-bottom: 0.5px solid var(--gunmetal);
}
.portal-invoice-table td {
    padding: 14px 12px;
    border-bottom: 0.5px solid var(--gunmetal);
    color: var(--chalk);
}
.portal-invoice-table__num { font-weight: 500; font-family: monospace; }
.portal-invoice-note { font-size: 13px; color: var(--smoke); margin-top: 16px; }
.portal-invoice-note a { color: var(--chalk); }

/* ── Project header (project.php) ────────────────────────────────────────────── */
.portal-back { font-size: 13px; color: var(--smoke); text-decoration: none; display: inline-block; margin-bottom: 20px; transition: color 200ms; }
.portal-back:hover { color: var(--chalk); }
.portal-project-header { margin-bottom: 32px; }
.portal-project-header__meta { display: flex; align-items: center; gap: 12px; margin-bottom: 10px; }
.portal-project-ref { font-size: 12px; font-weight: 500; color: var(--smoke); font-family: monospace; letter-spacing: 0.06em; }
.portal-project-title { font-size: 32px; font-weight: 600; color: var(--white); margin: 0; }

/* ── Project 2-col layout ────────────────────────────────────────────────────── */
.portal-project-layout { display: grid; grid-template-columns: 1fr 280px; gap: 32px; align-items: start; }
.portal-thread-col { min-width: 0; }

/* ── Thread ──────────────────────────────────────────────────────────────────── */
.portal-thread { display: flex; flex-direction: column; gap: 16px; margin-bottom: 32px; }
.portal-note {
    padding: 16px 20px;
    border-radius: var(--radius);
    border: 0.5px solid var(--gunmetal);
}
.portal-note--mode     { background: var(--carbon); }
.portal-note--customer { background: rgba(200,255,0,0.04); border-color: rgba(200,255,0,0.15); }
.portal-note--system   { background: transparent; border: none; padding: 6px 0; }
.portal-note__head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 10px; }
.portal-note__author { font-size: 12px; font-weight: 600; color: var(--chalk); letter-spacing: 0.04em; }
.portal-note--customer .portal-note__author { color: var(--volt); }
.portal-note__time { font-size: 11px; color: var(--smoke); }
.portal-note__body { font-size: 14px; color: var(--chalk); line-height: 1.7; }
.portal-note__system-text { font-size: 12px; color: var(--dark-grey); letter-spacing: 0.04em; }

/* ── Reply form ──────────────────────────────────────────────────────────────── */
.portal-reply { background: var(--carbon); border: 0.5px solid var(--gunmetal); border-radius: var(--radius); padding: 24px; }
.portal-reply__title { font-size: 14px; font-weight: 600; color: var(--chalk); margin: 0 0 16px; }

/* ── Sidebar (project.php) ───────────────────────────────────────────────────── */
.portal-project-sidebar { display: flex; flex-direction: column; gap: 16px; }
.portal-sidebar-block {
    background: var(--carbon);
    border: 0.5px solid var(--gunmetal);
    border-radius: var(--radius);
    padding: 20px;
}
.portal-sidebar-block--help { background: transparent; }
.portal-sidebar-block--help p { font-size: 13px; color: var(--smoke); margin: 0 0 12px; }
.portal-sidebar-block__title { font-size: 11px; font-weight: 500; letter-spacing: 0.1em; text-transform: uppercase; color: var(--smoke); margin: 0 0 14px; }
.portal-dl { display: grid; grid-template-columns: auto 1fr; gap: 6px 16px; margin: 0; font-size: 13px; }
.portal-dl dt { color: var(--smoke); }
.portal-dl dd { color: var(--chalk); margin: 0; }
.portal-sidebar-invoice { padding: 12px 0; border-bottom: 0.5px solid var(--gunmetal); }
.portal-sidebar-invoice:last-child { border-bottom: none; padding-bottom: 0; }
.portal-sidebar-invoice__top { display: flex; align-items: center; justify-content: space-between; margin-bottom: 4px; }
.portal-sidebar-invoice__num { font-size: 12px; font-weight: 500; color: var(--chalk); font-family: monospace; }
.portal-sidebar-invoice__desc { font-size: 12px; color: var(--smoke); margin-bottom: 4px; }
.portal-sidebar-invoice__amount { font-size: 15px; font-weight: 600; color: var(--white); }
.portal-sidebar-invoice__due { font-size: 11px; color: var(--smoke); margin-top: 4px; }
.portal-sidebar-invoice__dl { font-size: 12px; color: var(--volt); text-decoration: none; display: inline-block; margin-top: 6px; }

/* ── Invoice nudge (dashboard) ───────────────────────────────────────────────── */
.portal-invoice-nudge {
    display: flex;
    align-items: center;
    justify-content: space-between;
    background: rgba(255,214,0,0.06);
    border: 0.5px solid rgba(255,214,0,0.25);
    border-radius: var(--radius);
    padding: 14px 20px;
    font-size: 14px;
    color: var(--chalk);
    margin-bottom: 32px;
}
.portal-invoice-nudge a { color: #FFD600; text-decoration: none; font-weight: 500; }

/* ── Project status pipeline ─────────────────────────────────────────────────── */
.portal-pipeline {
    background: var(--carbon);
    border: 0.5px solid var(--gunmetal);
    padding: 28px 32px;
    margin-bottom: 32px;
}
.portal-pipeline--hold {
    border-color: #FF9F0A;
}
.portal-pipeline__hold-banner {
    font-size: 12px;
    font-weight: 500;
    color: #FF9F0A;
    letter-spacing: 0.04em;
    margin-bottom: 20px;
    padding-bottom: 16px;
    border-bottom: 0.5px solid #1E1E1E;
}
.portal-pipeline__track {
    display: flex;
    align-items: flex-start;
    gap: 0;
}
.portal-pipeline__step {
    display: flex;
    flex-direction: column;
    align-items: center;
    flex: 1;
    position: relative;
}
/* The connecting line sits between node and label, stretching to the next node */
.portal-pipeline__step {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    grid-template-rows: auto auto;
    grid-template-areas:
        "line-before node line-after"
        "label label label";
    align-items: center;
}
.portal-pipeline__step:first-child {
    grid-template-columns: 0 auto 1fr;
}
.portal-pipeline__step:last-child {
    grid-template-columns: 1fr auto 0;
}
.portal-pipeline__node {
    grid-area: node;
    width: 28px;
    height: 28px;
    border-radius: 50%;
    border: 1.5px solid var(--gunmetal);
    background: var(--void);
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    z-index: 1;
    flex-shrink: 0;
    color: var(--void);
    transition: border-color 200ms, background 200ms;
}
.portal-pipeline__step.is-done .portal-pipeline__node {
    background: var(--volt);
    border-color: var(--volt);
}
.portal-pipeline__step.is-current .portal-pipeline__node {
    border-color: var(--volt);
    background: var(--void);
}
.portal-pipeline__dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--volt);
    display: block;
}
.portal-pipeline__line {
    grid-area: line-after;
    height: 1.5px;
    background: var(--gunmetal);
    width: 100%;
}
.portal-pipeline__line.is-done {
    background: var(--volt);
}
/* line-before for all steps except first */
.portal-pipeline__step:not(:first-child) .portal-pipeline__node {
    /* handled via grid */
}
/* Fake line-before using ::before on the node wrapper */
.portal-pipeline__step::before {
    content: '';
    grid-area: line-before;
    height: 1.5px;
    background: var(--gunmetal);
    display: block;
    width: 100%;
}
.portal-pipeline__step.is-done::before,
.portal-pipeline__step.is-current::before {
    background: var(--volt);
}
.portal-pipeline__step:first-child::before {
    background: transparent;
}
.portal-pipeline__label {
    grid-area: label;
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--smoke);
    text-align: center;
    margin-top: 10px;
    padding: 0 4px;
    white-space: nowrap;
}
.portal-pipeline__step.is-current .portal-pipeline__label {
    color: var(--chalk);
}
.portal-pipeline__step.is-done .portal-pipeline__label {
    color: var(--dark-grey);
}
.portal-pipeline__tasks {
    font-size: 12px;
    color: var(--smoke);
    margin-top: 20px;
    padding-top: 16px;
    border-top: 0.5px solid var(--gunmetal);
}

/* ── Project tabs ────────────────────────────────────────────────────────────── */
.portal-tabs { margin-top: 8px; }

.portal-tabs__nav {
    display: flex;
    gap: 0;
    border-bottom: 0.5px solid var(--gunmetal);
    margin-bottom: 32px;
}
.portal-tabs__tab {
    display: flex;
    align-items: center;
    gap: 8px;
    background: none;
    border: none;
    border-bottom: 2px solid transparent;
    padding: 12px 24px;
    font-family: 'Exo', sans-serif;
    font-size: 13px;
    font-weight: 500;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--smoke);
    cursor: pointer;
    margin-bottom: -0.5px;
    transition: color 200ms ease-out, border-color 200ms ease-out;
}
.portal-tabs__tab:hover { color: var(--chalk); }
.portal-tabs__tab.is-active,
.portal-tabs__tab[aria-selected="true"] {
    color: var(--chalk);
    border-bottom-color: var(--volt);
}
.portal-tabs__count {
    background: var(--gunmetal);
    color: var(--smoke);
    font-size: 10px;
    font-weight: 600;
    padding: 2px 6px;
    border-radius: 10px;
    line-height: 1.4;
}
.portal-tabs__tab.is-active .portal-tabs__count,
.portal-tabs__tab[aria-selected="true"] .portal-tabs__count {
    background: var(--volt);
    color: var(--void);
}

/* ── Overview grid ───────────────────────────────────────────────────────────── */
.portal-overview-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
}
.portal-overview-card {
    background: var(--carbon);
    border: 0.5px solid var(--gunmetal);
    padding: 24px;
}
.portal-overview-card--full {
    grid-column: 1 / -1;
}
.portal-overview-card__title {
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--smoke);
    margin-bottom: 16px;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

/* Inline invoice rows (in overview) */
.portal-invoice-rows { display: flex; flex-direction: column; gap: 12px; }
.portal-invoice-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding-bottom: 12px;
    border-bottom: 0.5px solid var(--gunmetal);
}
.portal-invoice-row:last-child { border-bottom: none; padding-bottom: 0; }
.portal-invoice-row__left { display: flex; flex-direction: column; gap: 3px; }
.portal-invoice-row__num { font-size: 12px; font-weight: 500; color: var(--chalk); font-family: monospace; }
.portal-invoice-row__desc { font-size: 12px; color: var(--smoke); }
.portal-invoice-row__right { display: flex; align-items: center; gap: 12px; flex-shrink: 0; }
.portal-invoice-row__amount { font-size: 13px; font-weight: 500; color: var(--chalk); }
.portal-invoice-row__dl { font-size: 11px; color: var(--smoke); text-decoration: none; border: 0.5px solid var(--gunmetal); padding: 3px 8px; border-radius: 2px; }
.portal-invoice-row__dl:hover { color: var(--chalk); border-color: var(--smoke); }

/* Thread help footer */
.portal-thread-help {
    margin-top: 32px;
    padding-top: 24px;
    border-top: 0.5px solid var(--gunmetal);
    font-size: 13px;
    color: var(--smoke);
    font-weight: 300;
}
.portal-thread-help a { color: var(--chalk); text-decoration: none; }
.portal-thread-help a:hover { color: var(--volt); }

@media (max-width: 640px) {
    .portal-tabs__tab { padding: 10px 16px; font-size: 12px; }
    .portal-overview-grid { grid-template-columns: 1fr; }
    .portal-overview-card--full { grid-column: 1; }
}

/* ── Preview bar ─────────────────────────────────────────────────────────────── */
.portal-preview-bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    background: var(--carbon);
    border: 0.5px solid var(--gunmetal);
    border-left: 3px solid var(--volt);
    padding: 20px 24px;
    margin-bottom: 16px;
}
.portal-preview-bar__left {
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.portal-preview-bar__label {
    font-size: 15px;
    font-weight: 500;
    color: var(--chalk);
}
.portal-preview-bar__sub {
    font-size: 13px;
    color: var(--smoke);
    font-weight: 300;
}
.portal-preview-bar__btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: var(--volt);
    color: var(--void);
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    text-decoration: none;
    padding: 10px 20px;
    border-radius: 2px;
    white-space: nowrap;
    flex-shrink: 0;
    transition: background 200ms ease-out;
}
.portal-preview-bar__btn:hover { background: var(--volt-hover); }

/* ── Go live nudge ───────────────────────────────────────────────────────────── */
.portal-golive-nudge {
    display: flex;
    align-items: flex-start;
    gap: 16px;
    background: var(--carbon);
    border: 0.5px solid var(--gunmetal);
    padding: 20px 24px;
    margin-bottom: 32px;
}
.portal-golive-nudge__icon {
    color: var(--smoke);
    flex-shrink: 0;
    margin-top: 2px;
}
.portal-golive-nudge__content {
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.portal-golive-nudge__heading {
    font-size: 14px;
    font-weight: 500;
    color: var(--chalk);
}
.portal-golive-nudge__body {
    font-size: 13px;
    color: var(--smoke);
    font-weight: 300;
    line-height: 1.6;
    margin-bottom: 8px;
}
.portal-golive-nudge__link {
    font-size: 12px;
    font-weight: 500;
    color: var(--chalk);
    text-decoration: none;
    letter-spacing: 0.04em;
}
.portal-golive-nudge__link:hover { color: var(--volt); }

@media (max-width: 640px) {
    .portal-preview-bar { flex-direction: column; align-items: flex-start; }
    .portal-preview-bar__btn { width: 100%; justify-content: center; }
}

/* ── Portal checklist (sidebar) ──────────────────────────────────────────────── */
.portal-cl-count {
    font-size: 11px;
    font-weight: 400;
    color: var(--smoke);
    margin-left: 6px;
    letter-spacing: 0;
    text-transform: none;
}
.portal-checklist {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.portal-checklist__item {
    display: flex;
    align-items: flex-start;
    gap: 10px;
}
.portal-checklist__box {
    flex-shrink: 0;
    width: 18px;
    height: 18px;
    border: 1px solid var(--smoke);
    border-radius: 2px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-top: 1px;
    color: var(--void);
}
.portal-checklist__item.is-done .portal-checklist__box {
    background: var(--volt);
    border-color: var(--volt);
    color: var(--void);
}
.portal-checklist__text {
    font-size: 13px;
    color: var(--chalk);
    line-height: 1.5;
}
.portal-checklist__item.is-done .portal-checklist__text {
    color: var(--smoke);
    text-decoration: line-through;
    text-decoration-color: var(--dark-grey);
}

/* ── Past projects section ───────────────────────────────────────────────────── */
.portal-section--past { margin-top: 48px; padding-top: 40px; border-top: 0.5px solid var(--gunmetal); }
.portal-section__title--past { color: var(--smoke); font-size: 13px; font-weight: 500; letter-spacing: 0.12em; text-transform: uppercase; margin-bottom: 16px; }
.portal-projects--past { grid-template-columns: repeat(auto-fill, minmax(280px,1fr)); }
.portal-project-card--past {
    background: transparent;
    border-color: var(--gunmetal);
    opacity: 0.65;
    transition: opacity 200ms ease-out, border-color 200ms ease-out;
}
.portal-project-card--past:hover { opacity: 1; border-color: var(--smoke); }
.portal-project-card--past .portal-project-card__name { color: var(--smoke); font-size: 16px; }
.portal-project-card--past .portal-project-card__subject { -webkit-line-clamp: 1; }

/* ── Account page ────────────────────────────────────────────────────────────── */
.portal-account-section { margin-bottom: 56px; }
.portal-account-title {
    font-size: 26px;
    font-weight: 600;
    color: var(--white);
    margin: 0 0 28px;
}
.portal-account-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 24px;
}
.portal-account-card {
    background: var(--carbon);
    border: 0.5px solid var(--gunmetal);
    border-radius: var(--radius);
    padding: 28px 24px;
}
.portal-account-card__title {
    font-size: 14px;
    font-weight: 600;
    color: var(--chalk);
    margin: 0 0 20px;
    padding-bottom: 14px;
    border-bottom: 0.5px solid var(--gunmetal);
}
.field__hint { font-size: 11px; color: var(--smoke); margin: 4px 0 0; }

@media (max-width: 768px) {
    .portal-account-grid { grid-template-columns: 1fr; }
}

/* ── Login page ──────────────────────────────────────────────────────────────── */
.portal-login-page { display: flex; align-items: center; justify-content: center; min-height: 100vh; }
.portal-login-wrap { width: 100%; max-width: 400px; padding: 24px; }
.portal-login-card {
    background: var(--carbon);
    border: 0.5px solid var(--gunmetal);
    border-radius: var(--radius);
    padding: 40px 36px;
}
.portal-login-logo { display: flex; justify-content: center; margin-bottom: 24px; }
.portal-login-logo img { height: 100px; width: auto; }
.portal-login-title {
    font-size: 16px;
    font-weight: 600;
    color: var(--white);
    text-align: center;
    margin: 0 0 6px;
}
.portal-login-sub { font-size: 13px; color: var(--smoke); text-align: center; margin: 0 0 28px; }
.portal-login-help { font-size: 12px; color: var(--smoke); text-align: center; margin-top: 20px; }
.portal-login-help a { color: var(--chalk); }

/* ── Brief prompt card ───────────────────────────────────────────────────────── */
.portal-brief-prompt {
    display: flex;
    flex-direction: column;
    gap: 12px;
    background: var(--carbon);
    border: 0.5px solid var(--gunmetal);
    border-left: 3px solid var(--volt);
    padding: 20px 24px;
    margin-top: 12px;
    margin-bottom: 24px;
}
.portal-brief-prompt__heading {
    font-size: 16px; font-weight: 600; color: var(--white); margin: 0 0 4px;
}
.portal-brief-prompt__body {
    font-size: 13px; font-weight: 300; color: var(--smoke); margin: 0; line-height: 1.5;
}
.portal-brief-prompt .btn { align-self: flex-start; }

/* ── Report card (in project thread) ─────────────────────────────────────────── */
.portal-note--report {
    background: var(--carbon);
    border: 0.5px solid var(--gunmetal);
    border-left: 3px solid var(--volt);
    padding: 16px 20px;
    border-radius: var(--radius);
}
.portal-report-card {
    display: flex;
    align-items: center;
    gap: 16px;
    margin-top: 12px;
    padding: 16px;
    background: var(--void);
    border: 0.5px solid var(--gunmetal);
}
.portal-report-card__icon {
    color: var(--smoke);
    flex-shrink: 0;
}
.portal-report-card__content {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.portal-report-card__label {
    font-size: 14px;
    font-weight: 500;
    color: var(--chalk);
}
.portal-report-card__meta {
    font-size: 11px;
    color: var(--smoke);
    letter-spacing: 0.04em;
}
.portal-report-card__dl {
    display: inline-flex;
    align-items: center;
    background: var(--volt);
    color: var(--void);
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    text-decoration: none;
    padding: 8px 16px;
    border-radius: 2px;
    white-space: nowrap;
    flex-shrink: 0;
    transition: background 200ms ease-out;
}
.portal-report-card__dl:hover { background: var(--volt-hover); }
@media (max-width: 640px) {
    .portal-report-card { flex-direction: column; align-items: flex-start; }
    .portal-report-card__dl { width: 100%; justify-content: center; }
}

/* ── Empty state ─────────────────────────────────────────────────────────────── */
.portal-empty { padding: 48px 0; text-align: center; color: var(--smoke); font-size: 14px; }

/* ── Btn full width ──────────────────────────────────────────────────────────── */
.btn--full { width: 100%; justify-content: center; }

/* ── Responsive ──────────────────────────────────────────────────────────────── */
@media (max-width: 768px) {
    .portal-wrap { padding: 24px 16px; }
    .portal-project-layout { grid-template-columns: 1fr; }
    .portal-projects { grid-template-columns: 1fr; }
    .portal-stats { flex-direction: column; gap: 1px; }
    .portal-nav__inner { padding: 0 16px; }
    .portal-nav__logo-label { display: none; }
    .portal-greeting__name { font-size: 28px; }
}


/* Global animated background canvas — ported from main site */
#mode-global-bg {
    position: fixed;
    top: 0; left: 0;
    width: 100vw;
    height: 100vh;
    pointer-events: none;
    z-index: -1;
    background: transparent;
}


/* System notes — render pre-formatted text in monospace so column alignment works */
.portal-note--system .portal-note__system-text,
.portal-note--system .portal-note__body {
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, "Courier New", monospace;
    font-size: 12.5px;
    line-height: 1.7;
    white-space: pre-wrap;
    color: var(--chalk);
}
