/* ==========================================================================
   ACCOUNT — Trade Account membership system (F1: auth + minimal dashboard)
   ========================================================================== */

:root {
    --sa-navy:  #1c4586;
    --sa-paper: #fff;
    --sa-bg:    #f5f5f3;
    --sa-ink:   #1a1a1a;
    --sa-line:  #e7e9ee;
    --sa-muted: #6b7280;
    --sa-red:   #e01f27;
    --sa-ok:    #1c4586;
}

.sa-auth-page,
.sa-account-page {
    background: var(--sa-bg);
    padding: 64px 16px;
    min-height: calc(100vh - 240px);
    font-family: 'Axiforma', -apple-system, BlinkMacSystemFont, Segoe UI, Roboto, sans-serif;
    color: var(--sa-ink);
}

/* -------------------------------------------------------------------------- */
/* Auth shell (login/register/forgot/reset/verify/logout)                     */
/* -------------------------------------------------------------------------- */

.sa-auth-shell {
    max-width: 480px;
    margin: 0 auto;
    background: var(--sa-paper);
    box-shadow: 0 12px 40px rgba(28, 69, 134, 0.08);
    overflow: hidden;
}

.sa-auth-shell__head {
    padding: 32px 32px 24px;
    border-bottom: 1px solid var(--sa-line);
    text-align: center;
}

.sa-auth-shell__logo {
    display: inline-block;
    margin-bottom: 20px;
    line-height: 0;
}
.sa-auth-shell__logo img {
    display: block;
    height: 40px;
    width: auto;
    max-width: 100%;
}

.sa-auth-shell__title {
    font-size: clamp(22px, 2.4vw, 28px);
    line-height: 1.15;
    color: var(--sa-navy);
    margin: 0 0 8px;
    letter-spacing: -0.01em;
    font-weight: 700;
}
.sa-auth-shell__lede {
    color: var(--sa-muted);
    font-size: 14px;
    line-height: 1.55;
    margin: 0;
}

.sa-auth-shell__body { padding: 28px 32px; }
.sa-auth-shell__foot {
    padding: 16px 32px;
    border-top: 1px solid var(--sa-line);
    background: #fafafa;
    text-align: center;
    font-size: 13px;
    color: var(--sa-muted);
}
.sa-auth-shell__foot a {
    color: var(--sa-navy);
    font-weight: 600;
    text-decoration: none;
}
.sa-auth-shell__foot a:hover { color: #1c4586; text-decoration: underline; }

.sa-auth-extras {
    display: flex;
    justify-content: space-between;
    margin-top: 16px;
    font-size: 13px;
}
.sa-auth-extras a {
    color: var(--sa-navy);
    text-decoration: none;
}
.sa-auth-extras a:hover { color: #1c4586; text-decoration: underline; }

/* -------------------------------------------------------------------------- */
/* Form refinements specific to account pages (extends sa-qd-form)            */
/* -------------------------------------------------------------------------- */

.sa-account-form .sa-qd-field { margin-bottom: 16px; }

.sa-account-form .sa-qd-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
}
.sa-account-form .sa-qd-check {
    display: flex;
    align-items: flex-start;
}
.sa-account-form .sa-qd-check label {
    display: flex;
    gap: 8px;
    align-items: flex-start;
    font-size: 13px;
    color: var(--sa-ink);
    font-weight: 500;
    cursor: pointer;
}
.sa-account-form .sa-qd-check input[type="checkbox"] {
    width: 16px; height: 16px;
    margin-top: 2px;
    accent-color: var(--sa-navy);
}
.sa-qd-help {
    margin: 6px 0 0;
    font-size: 12px;
    color: var(--sa-muted);
}

@media (max-width: 600px) {
    .sa-account-form .sa-qd-row { grid-template-columns: 1fr; }
}

/* -------------------------------------------------------------------------- */
/* Flash messages                                                             */
/* -------------------------------------------------------------------------- */

.sa-account-flash {
    padding: 12px 16px;
    border-radius: 0;
    font-size: 14px;
    line-height: 1.5;
    margin-bottom: 20px;
    border-left: 3px solid;
}
.sa-account-flash--ok {
    background: #eef2f8;
    color: #1c4586;
    border-color: var(--sa-ok);
}
.sa-account-flash--err {
    background: #fef2f2;
    color: #b91c1c;
    border-color: var(--sa-red);
}

/* -------------------------------------------------------------------------- */
/* Dashboard (F1 minimal)                                                     */
/* -------------------------------------------------------------------------- */

.sa-account-shell {
    max-width: 1100px;
    margin: 0 auto;
    background: var(--sa-paper);
    padding: 40px clamp(20px, 4vw, 48px);
}

.sa-account-shell__head {
    padding-bottom: 32px;
    border-bottom: 1px solid var(--sa-line);
    margin-bottom: 32px;
}
.sa-account-shell__head h1 {
    font-size: clamp(28px, 3vw, 38px);
    color: var(--sa-navy);
    margin: 12px 0 4px;
    line-height: 1.1;
    letter-spacing: -0.015em;
    font-weight: 800;
}
.sa-account-shell__lede {
    color: var(--sa-muted);
    margin: 0;
    font-size: 15px;
}

.sa-account-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
    margin-bottom: 32px;
}
@media (max-width: 800px) {
    .sa-account-grid { grid-template-columns: 1fr; }
}

.sa-account-card {
    display: block;
    background: var(--sa-bg);
    padding: 24px;
    text-decoration: none;
    color: var(--sa-ink);
    transition: background 0.15s ease, transform 0.15s ease;
    border: 1px solid transparent;
}
.sa-account-card:hover {
    background: #fff;
    border-color: var(--sa-navy);
    transform: translateY(-2px);
}
.sa-account-card h3 {
    margin: 0 0 8px;
    color: var(--sa-navy);
    font-size: 17px;
    font-weight: 700;
}
.sa-account-card p {
    margin: 0 0 16px;
    font-size: 14px;
    color: var(--sa-muted);
    line-height: 1.5;
}
.sa-account-card__cta {
    color: var(--sa-navy);
    font-weight: 600;
    font-size: 13px;
    letter-spacing: 0.5px;
}

.sa-account-foot {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 16px;
    padding-top: 24px;
    border-top: 1px solid var(--sa-line);
    font-size: 13px;
    color: var(--sa-muted);
    line-height: 1.7;
}
.sa-account-foot a {
    color: var(--sa-red);
    font-weight: 600;
    text-decoration: none;
}
.sa-account-foot a:hover { text-decoration: underline; }

/* -------------------------------------------------------------------------- */
/* F2: Account shell — sidebar layout                                         */
/* -------------------------------------------------------------------------- */

.sa-account-page {
    padding: 48px 16px;
}

.sa-account-layout {
    max-width: 1180px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 260px 1fr;
    gap: 32px;
    align-items: start;
}

.sa-account-sidebar {
    background: var(--sa-paper);
    padding: 24px;
    position: sticky;
    top: 24px;
}

.sa-account-sidebar__user {
    display: flex;
    align-items: center;
    gap: 12px;
    padding-bottom: 20px;
    margin-bottom: 16px;
    border-bottom: 1px solid var(--sa-line);
}
.sa-account-sidebar__avatar {
    width: 40px; height: 40px;
    background: var(--sa-navy);
    color: #fff;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 14px;
    letter-spacing: 0.5px;
}
.sa-account-sidebar__user strong {
    display: block;
    font-size: 14px;
    color: var(--sa-ink);
    line-height: 1.2;
}
.sa-account-sidebar__user span {
    display: block;
    font-size: 12px;
    color: var(--sa-muted);
    margin-top: 2px;
}

.sa-account-sidebar__nav {
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.sa-account-sidebar__nav-item {
    display: block;
    padding: 10px 12px;
    font-size: 14px;
    color: var(--sa-ink);
    text-decoration: none;
    border-left: 2px solid transparent;
    transition: background 0.12s, border-color 0.12s, color 0.12s;
}
.sa-account-sidebar__nav-item:hover {
    background: var(--sa-bg);
    color: var(--sa-navy);
}
.sa-account-sidebar__nav-item.is-active {
    background: var(--sa-bg);
    border-color: var(--sa-navy);
    color: var(--sa-navy);
    font-weight: 600;
}
.sa-account-sidebar__nav-item--ext {
    margin-top: 8px;
    border-top: 1px solid var(--sa-line);
    padding-top: 14px;
    color: var(--sa-navy);
    font-weight: 600;
}
.sa-account-sidebar__nav-item--logout {
    color: var(--sa-red);
}
.sa-account-sidebar__nav-item--logout:hover { color: var(--sa-red); background: #fef2f2; }
.sa-account-sidebar__nav-item--ext:hover { color: var(--sa-navy); }

.sa-account-main {
    background: var(--sa-paper);
    padding: 32px clamp(20px, 3vw, 40px);
}

.sa-account-main__head {
    padding-bottom: 24px;
    border-bottom: 1px solid var(--sa-line);
    margin-bottom: 28px;
}
.sa-account-main__head h1 {
    font-size: clamp(24px, 2.4vw, 30px);
    color: var(--sa-navy);
    margin: 0 0 6px;
    line-height: 1.15;
    letter-spacing: -0.01em;
    font-weight: 800;
}
.sa-account-main__lede {
    color: var(--sa-muted);
    margin: 0;
    font-size: 14px;
}

@media (max-width: 900px) {
    .sa-account-layout { grid-template-columns: 1fr; }
    .sa-account-sidebar {
        position: static;
        padding: 16px;
    }
    .sa-account-sidebar__nav {
        flex-direction: row;
        flex-wrap: wrap;
        gap: 4px;
    }
    .sa-account-sidebar__nav-item {
        border-left: 0;
        border-bottom: 2px solid transparent;
        padding: 8px 12px;
        font-size: 13px;
    }
    .sa-account-sidebar__nav-item.is-active {
        border-color: var(--sa-navy);
        background: transparent;
    }
    .sa-account-sidebar__nav-item--ext,
    .sa-account-sidebar__nav-item--logout {
        margin-top: 0;
        border-top: 0;
        padding-top: 8px;
    }
}

/* KPI strip */
.sa-account-kpi-row {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 12px;
    margin-bottom: 28px;
}
@media (max-width: 700px) {
    .sa-account-kpi-row { grid-template-columns: repeat(2, 1fr); }
}

.sa-account-kpi {
    background: var(--sa-bg);
    padding: 18px 16px;
    text-align: left;
}
.sa-account-kpi__num {
    display: block;
    font-size: 28px;
    font-weight: 800;
    color: var(--sa-navy);
    line-height: 1;
    letter-spacing: -0.02em;
}
.sa-account-kpi__num small {
    font-size: 14px;
    font-weight: 600;
    color: var(--sa-muted);
    margin-left: 2px;
}
.sa-account-kpi__label {
    display: block;
    margin-top: 6px;
    font-size: 12px;
    color: var(--sa-muted);
    line-height: 1.3;
}

/* Info cards */
.sa-account-info-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
    margin-top: 32px;
}
@media (max-width: 800px) {
    .sa-account-info-row { grid-template-columns: 1fr; }
}

.sa-account-info-card {
    background: var(--sa-bg);
    padding: 24px;
}
.sa-account-info-card h4 {
    margin: 0 0 16px;
    color: var(--sa-navy);
    font-size: 14px;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    font-weight: 700;
}
.sa-account-info-card dl {
    margin: 0;
    display: grid;
    grid-template-columns: 110px 1fr;
    gap: 8px 16px;
    font-size: 14px;
}
.sa-account-info-card dt {
    color: var(--sa-muted);
}
.sa-account-info-card dd {
    margin: 0;
    color: var(--sa-ink);
}

.sa-account-section { margin-bottom: 32px; }
.sa-account-section__title {
    font-size: 18px;
    color: var(--sa-navy);
    margin: 0 0 16px;
    font-weight: 700;
}

/* Status pills */
.sa-status {
    display: inline-block;
    padding: 2px 10px;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: #fff;
    border-radius: 0;
}
.sa-status--active  { background: var(--sa-ok); }
.sa-status--pending,
.sa-status--awaiting_approval { background: #d97706; }
.sa-status--suspended { background: var(--sa-red); }

/* Wide forms (profile) */
.sa-account-form--wide {
    max-width: 720px;
}
.sa-account-form input:disabled {
    background: var(--sa-bg);
    color: var(--sa-muted);
    cursor: not-allowed;
}

/* Documents grid */
.sa-doc-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 16px;
}
.sa-doc-tile {
    background: var(--sa-bg);
    padding: 20px;
    display: flex;
    flex-direction: column;
    border: 1px solid transparent;
    transition: border-color 0.15s, transform 0.15s;
}
.sa-doc-tile:hover {
    border-color: var(--sa-navy);
    transform: translateY(-2px);
}
.sa-doc-tile__type {
    display: inline-block;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--sa-red);
    margin-bottom: 8px;
}
.sa-doc-tile__name {
    font-size: 15px;
    color: var(--sa-ink);
    margin: 0 0 8px;
    font-weight: 700;
    line-height: 1.3;
}
.sa-doc-tile__desc {
    font-size: 13px;
    color: var(--sa-muted);
    margin: 0 0 16px;
    line-height: 1.5;
    flex: 1 1 auto;
}
.sa-doc-tile__btn {
    align-self: flex-start;
    background: var(--sa-navy);
    color: #fff;
    border: 0;
    padding: 10px 16px;
    font-size: 13px;
    font-weight: 600;
    letter-spacing: 0.3px;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    transition: background 0.15s;
}
.sa-doc-tile__btn:hover:not(:disabled) {
    background: #163b73;
}
.sa-doc-tile__btn:disabled {
    background: var(--sa-muted);
    cursor: not-allowed;
}
.sa-doc-tile__msg {
    display: block;
    margin-top: 8px;
    font-size: 12px;
    line-height: 1.4;
}

/* -------------------------------------------------------------------------- */
/* F3: Quotes — list, single detail, status pills                             */
/* -------------------------------------------------------------------------- */

.sa-quote-list {
    display: flex;
    flex-direction: column;
    border-top: 1px solid var(--sa-line);
}
.sa-quote-list__loading {
    padding: 24px 16px;
    color: var(--sa-muted);
    font-size: 14px;
    text-align: center;
}

.sa-quote-row {
    display: grid;
    grid-template-columns: 130px 1fr auto auto;
    gap: 16px;
    align-items: center;
    padding: 14px 16px;
    border-bottom: 1px solid var(--sa-line);
    color: var(--sa-ink);
    text-decoration: none;
    transition: background 0.12s;
}
.sa-quote-row:hover {
    background: var(--sa-bg);
}
.sa-quote-row__ref {
    font-family: 'Axiforma', monospace;
    font-size: 13px;
    color: var(--sa-navy);
    font-weight: 700;
    letter-spacing: 0.02em;
}
.sa-quote-row__title {
    font-size: 14px;
    font-weight: 500;
    color: var(--sa-ink);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.sa-quote-row__date {
    font-size: 12px;
    color: var(--sa-muted);
}

@media (max-width: 700px) {
    .sa-quote-row {
        grid-template-columns: 1fr auto;
        grid-template-areas:
            "ref status"
            "title title"
            "date date";
        row-gap: 4px;
    }
    .sa-quote-row__ref    { grid-area: ref; }
    .sa-quote-row__title  { grid-area: title; font-size: 13px; white-space: normal; }
    .sa-quote-row__date   { grid-area: date; font-size: 11px; }
    .sa-quote-row .sa-status { grid-area: status; justify-self: end; }
}

/* Empty state */
.sa-quote-empty {
    padding: 48px 24px;
    text-align: center;
    background: var(--sa-bg);
}
.sa-quote-empty h3 {
    margin: 0 0 8px;
    color: var(--sa-navy);
    font-size: 18px;
}
.sa-quote-empty p {
    color: var(--sa-muted);
    font-size: 14px;
    margin: 0 0 12px;
    max-width: 420px;
    margin-left: auto;
    margin-right: auto;
}

/* Status pills — extend F2 with quote-specific statuses */
.sa-status--submitted { background: #3b82f6; }
.sa-status--in_review { background: #d97706; }
.sa-status--quoted    { background: #1c4586; }
.sa-status--won       { background: var(--sa-ok); }
.sa-status--lost      { background: #6b7280; }
.sa-status--cancelled { background: #dc2626; }

/* Single quote detail */
.sa-quote-detail {
    display: flex;
    flex-direction: column;
    gap: 20px;
}
.sa-quote-detail__head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 16px;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--sa-line);
}
.sa-quote-detail__ref {
    font-family: 'Axiforma', monospace;
    font-size: 14px;
    color: var(--sa-navy);
    font-weight: 700;
    letter-spacing: 0.04em;
}
.sa-quote-detail__title {
    font-size: 22px;
    color: var(--sa-ink);
    margin: 0;
    font-weight: 700;
}
.sa-quote-detail__meta {
    font-size: 13px;
    color: var(--sa-muted);
    margin: 0;
}
.sa-quote-detail__message {
    background: var(--sa-bg);
    padding: 24px;
}
.sa-quote-detail__message h4 {
    margin: 0 0 12px;
    color: var(--sa-navy);
    font-size: 14px;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    font-weight: 700;
}
.sa-quote-detail__message p {
    margin: 0;
    font-size: 14px;
    line-height: 1.6;
    color: var(--sa-ink);
    white-space: pre-wrap;
}

/* ── My Designs ──────────────────────────────────────────────── */
.sa-designs-bar {
    display: flex;
    justify-content: flex-end;
    margin-bottom: 16px;
}
.sa-designs-new {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 9px 18px;
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 0.04em;
    color: #fff !important;
    background: var(--sa-navy);
    border: 1.5px solid var(--sa-navy);
    border-radius: 4px;
    text-decoration: none;
    transition: background 0.12s, border-color 0.12s;
}
.sa-designs-new:hover {
    background: #163b73;
    border-color: #163b73;
    color: #fff !important;
}
.sa-designs-new__plus {
    font-size: 16px;
    line-height: 1;
    font-weight: 600;
}

.sa-designs-list {
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.sa-designs-empty {
    padding: 28px;
    text-align: center;
    color: var(--sa-muted);
    background: var(--sa-bg);
    border-radius: 6px;
    margin: 0;
}
.sa-design-row {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 14px 16px;
    background: var(--sa-paper);
    border: 1px solid var(--sa-line);
    border-radius: 6px;
}
.sa-design-row__main {
    flex: 1;
    min-width: 0;
}
.sa-design-row__name {
    font-weight: 600;
    color: var(--sa-ink);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.sa-design-row__meta {
    font-size: 12px;
    color: var(--sa-muted);
    margin-top: 2px;
}
.sa-design-row__actions {
    display: flex;
    gap: 8px;
    flex-shrink: 0;
}
.sa-design-row__actions .sa-design-btn,
a.sa-design-btn,
button.sa-design-btn {
    -webkit-appearance: none !important;
    -moz-appearance: none !important;
    appearance: none !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 7px 14px !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    line-height: 1.2 !important;
    font-family: inherit !important;
    color: var(--sa-navy) !important;
    background: #fff !important;
    border: 1.5px solid #d6dfeb !important;
    border-radius: 4px !important;
    cursor: pointer !important;
    text-decoration: none !important;
    box-shadow: none !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
    transition: background 0.12s, border-color 0.12s, color 0.12s !important;
}
.sa-design-row__actions .sa-design-btn:hover,
a.sa-design-btn:hover,
button.sa-design-btn:hover {
    background: var(--sa-bg) !important;
    border-color: var(--sa-navy) !important;
    color: var(--sa-navy) !important;
}
.sa-design-row__actions .sa-design-btn--primary,
a.sa-design-btn--primary,
button.sa-design-btn--primary {
    color: #fff !important;
    background: var(--sa-navy) !important;
    border-color: var(--sa-navy) !important;
}
.sa-design-row__actions .sa-design-btn--primary:hover,
a.sa-design-btn--primary:hover,
button.sa-design-btn--primary:hover {
    background: #163b73 !important;
    border-color: #163b73 !important;
    color: #fff !important;
}
.sa-design-row__actions .sa-design-btn--danger,
a.sa-design-btn--danger,
button.sa-design-btn--danger {
    color: var(--sa-red) !important;
    background: #fff !important;
    border-color: #f3c5c7 !important;
}
.sa-design-row__actions .sa-design-btn--danger:hover,
a.sa-design-btn--danger:hover,
button.sa-design-btn--danger:hover {
    background: #fef2f2 !important;
    border-color: var(--sa-red) !important;
    color: var(--sa-red) !important;
}
.sa-design-row__actions .sa-design-btn:disabled {
    opacity: 0.55 !important;
    cursor: not-allowed !important;
}

/* ── Membership Tier Badge ──────────────────────────────────── */
.sa-tier-badge {
    display: inline-block !important;
    margin-top: 4px !important;
    padding: 2px 8px !important;
    border-radius: 999px !important;
    font-size: 10px !important;
    font-weight: 800 !important;
    letter-spacing: 0.06em !important;
    text-transform: uppercase !important;
    line-height: 1.5 !important;
    white-space: nowrap !important;
    font-family: inherit !important;
}
.sa-account-sidebar__user .sa-tier-badge { margin-top: 6px; }
.sa-account-dropdown-head .sa-tier-badge { margin-top: 6px; align-self: flex-start; }

/* ── Quote Status Pills + Timeline ───────────────────────────── */
.sa-status.sa-status--submitted { background: #dbeafe !important; color: #1c4586 !important; }
.sa-status.sa-status--in_review { background: #fef3c7 !important; color: #a16400 !important; }
.sa-status.sa-status--quoted    { background: #ede9fe !important; color: #5b21b6 !important; }
.sa-status.sa-status--won       { background: #dcfce7 !important; color: #166534 !important; }
.sa-status.sa-status--lost      { background: #fee2e2 !important; color: #991b1b !important; }
.sa-status.sa-status--cancelled { background: #f3f4f6 !important; color: #6b7280 !important; }
.sa-status {
    padding: 4px 10px !important;
    border-radius: 999px !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    letter-spacing: 0.06em !important;
    text-transform: uppercase !important;
    line-height: 1.5 !important;
    white-space: nowrap !important;
}

.sa-quote-timeline {
    display: flex;
    align-items: center;
    gap: 0;
    padding: 18px 4px;
    margin: 20px 0 28px;
    background: var(--sa-paper);
    border: 1px solid var(--sa-line);
    border-radius: 8px;
}
.sa-quote-timeline__step {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
    flex: 0 0 auto;
    padding: 0 12px;
    color: var(--sa-muted);
}
.sa-quote-timeline__dot {
    width: 14px; height: 14px;
    background: #e2e8f0;
    border: 2px solid #cbd5e1;
    border-radius: 50%;
    transition: background 0.15s, border-color 0.15s;
}
.sa-quote-timeline__label {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}
.sa-quote-timeline__step.is-done .sa-quote-timeline__dot {
    background: var(--sa-navy);
    border-color: var(--sa-navy);
}
.sa-quote-timeline__step.is-done .sa-quote-timeline__label {
    color: var(--sa-navy);
}
.sa-quote-timeline__step.is-current .sa-quote-timeline__dot {
    box-shadow: 0 0 0 4px rgba(28, 69, 134, 0.16);
}
.sa-quote-timeline__step.is-lost .sa-quote-timeline__dot,
.sa-quote-timeline__step.is-cancelled .sa-quote-timeline__dot {
    background: var(--sa-red);
    border-color: var(--sa-red);
}
.sa-quote-timeline__step.is-lost .sa-quote-timeline__label,
.sa-quote-timeline__step.is-cancelled .sa-quote-timeline__label {
    color: var(--sa-red);
}
.sa-quote-timeline__bar {
    flex: 1;
    height: 2px;
    background: #e2e8f0;
    margin-bottom: 18px;
    transition: background 0.15s;
}
.sa-quote-timeline__bar.is-filled {
    background: var(--sa-navy);
}

/* Status history collapsible */
.sa-quote-history {
    margin: 0 0 24px;
    padding: 0;
}
.sa-quote-history summary {
    cursor: pointer;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--sa-navy);
    padding: 8px 0;
    list-style: none;
    user-select: none;
}
.sa-quote-history summary::-webkit-details-marker { display: none; }
.sa-quote-history summary::before {
    content: '▶';
    display: inline-block;
    margin-right: 8px;
    font-size: 10px;
    transition: transform 0.15s;
}
.sa-quote-history[open] summary::before { transform: rotate(90deg); }
.sa-quote-history ul {
    list-style: none;
    padding: 8px 0 0 18px;
    margin: 0;
    border-left: 2px solid var(--sa-line);
}
.sa-quote-history li {
    font-size: 13px;
    color: var(--sa-ink);
    padding: 4px 0;
    line-height: 1.5;
}
.sa-quote-history__time {
    display: inline-block;
    min-width: 130px;
    font-size: 11px;
    color: var(--sa-muted);
    font-family: ui-monospace, Menlo, monospace;
}

@media (max-width: 640px) {
    .sa-quote-timeline { flex-wrap: wrap; }
    .sa-quote-timeline__bar { display: none; }
    .sa-quote-timeline__step { flex: 1 1 50%; padding: 6px 8px; }
}
