/* ============================================================
   Clinic Hub — modern 2027 clinic admin & support staff dashboard
   Used by templates/clinic/self_detail.html
   Design tokens align with dashboard.css / pipeline.css / detail.html.
   ============================================================ */

:root {
    --hub-radius:        1.125rem;
    --hub-radius-sm:     0.75rem;
    --hub-border:        rgba(15, 23, 42, 0.06);
    --hub-border-strong: rgba(15, 23, 42, 0.10);
    --hub-shadow-sm:     0 1px 2px rgba(15, 23, 42, 0.04);
    --hub-shadow-md:     0 8px 24px rgba(15, 23, 42, 0.06);
    --hub-shadow-lg:     0 18px 40px rgba(15, 23, 42, 0.08);
    --hub-text:          var(--bs-heading-color, #0f172a);
    --hub-text-sub:      #64748b;
    --hub-bg:            #ffffff;
    --hub-bg-soft:       #f8fafc;
    --hub-primary:       #0069a6;
    --hub-primary-soft:  rgba(0, 105, 166, 0.08);
    --hub-success:       #16a34a;
    --hub-success-soft:  rgba(22, 163, 74, 0.10);
    --hub-info:          #0891b2;
    --hub-info-soft:     rgba(8, 145, 178, 0.10);
    --hub-warning:       #d97706;
    --hub-warning-soft:  rgba(217, 119, 6, 0.10);
    --hub-danger:        #dc2626;
    --hub-danger-soft:   rgba(220, 38, 38, 0.10);
    --hub-accent:        #7c3aed;
    --hub-accent-soft:   rgba(124, 58, 237, 0.10);
}

[data-bs-theme="dark"], [data-theme="dark"] {
    --hub-border:        rgba(148, 163, 184, 0.10);
    --hub-border-strong: rgba(148, 163, 184, 0.18);
    --hub-shadow-sm:     0 1px 2px rgba(0, 0, 0, 0.30);
    --hub-shadow-md:     0 8px 24px rgba(0, 0, 0, 0.35);
    --hub-shadow-lg:     0 18px 40px rgba(0, 0, 0, 0.45);
    --hub-text:          #e2e8f0;
    --hub-text-sub:      #94a3b8;
    --hub-bg:            #1e293b;
    --hub-bg-soft:       #0f172a;
    --hub-primary:       #4ea7d8;
    --hub-primary-soft:  rgba(56, 189, 248, 0.14);
    --hub-success:       #34c98a;
    --hub-success-soft:  rgba(34, 197, 94, 0.15);
    --hub-info:          #38b9cf;
    --hub-info-soft:     rgba(34, 211, 238, 0.15);
    --hub-warning:       #f5b049;
    --hub-warning-soft:  rgba(251, 191, 36, 0.15);
    --hub-danger:        #ef6e94;
    --hub-danger-soft:   rgba(248, 113, 113, 0.15);
    --hub-accent:        #a78bfa;
    --hub-accent-soft:   rgba(168, 85, 247, 0.15);
}

/* ── Welcome Hero ───────────────────────────────────────────── */
.clinic-hub-hero {
    position: relative;
    border-radius: var(--hub-radius);
    background: linear-gradient(135deg, #0e3a5f 0%, #08527a 45%, #0891b2 100%);
    color: #fff;
    padding: 1rem 1.5rem;
    overflow: hidden;
    box-shadow: var(--hub-shadow-md);
}

.hub-hero-right {
    display: flex;
    flex-direction: column;
    gap: 0.6rem;
    align-items: flex-end;
}

.hub-hero-right > .hub-hero-snapshot { width: 100%; }

.hub-hero-actions--end {
    justify-content: flex-end;
    width: 100%;
    padding-top: 0.55rem;
    border-top: 1px solid rgba(255, 255, 255, 0.14);
}

.hub-hero-glow {
    position: absolute;
    top: -50%;
    right: -10%;
    width: 60%;
    height: 200%;
    background: radial-gradient(closest-side, rgba(255, 255, 255, 0.18), transparent 70%);
    pointer-events: none;
}

.hub-hero-row {
    position: relative;
    display: grid;
    grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr);
    gap: 1.5rem;
    align-items: center;
}

@media (max-width: 991.98px) {
    .clinic-hub-hero { padding: 1rem 1.25rem; }
    .hub-hero-row { grid-template-columns: 1fr; gap: 1rem; }
    .hub-hero-right { align-items: stretch; }
    .hub-hero-actions--end { justify-content: flex-start; }
}

.hub-hero-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    font-size: 0.65rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    padding: 0.2rem 0.6rem;
    border-radius: 2rem;
    background: rgba(255, 255, 255, 0.15);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    color: #e0f2fe;
    margin-bottom: 0.4rem;
}

.hub-hero-eyebrow i { font-size: 0.8rem; }

.hub-hero-title {
    font-size: clamp(1.25rem, 1.9vw, 1.6rem);
    font-weight: 800;
    letter-spacing: -0.025em;
    margin: 0 0 0.25rem;
    line-height: 1.15;
    color: #fff;
}

.hub-hero-sub {
    font-size: 0.875rem;
    color: rgba(255, 255, 255, 0.82);
    margin: 0 0 0.75rem;
    line-height: 1.4;
}

.hub-hero-sub strong {
    color: #fff;
    font-weight: 600;
}

.hub-hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.hub-hero-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.35rem 0.85rem;
    border-radius: 2rem;
    background: rgba(255, 255, 255, 0.12);
    color: #fff;
    font-size: 0.78rem;
    font-weight: 600;
    text-decoration: none;
    border: 1px solid rgba(255, 255, 255, 0.18);
    transition: background 0.2s ease, transform 0.2s ease, border-color 0.2s ease;
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
}

.hub-hero-btn:hover {
    background: rgba(255, 255, 255, 0.22);
    border-color: rgba(255, 255, 255, 0.32);
    color: #fff;
    transform: translateY(-1px);
}

.hub-hero-btn--primary {
    background: #ffffff;
    color: #0e3a5f;
    border-color: #ffffff;
}

.hub-hero-btn--primary:hover {
    background: #f1f5f9;
    color: #0e3a5f;
}

.hub-hero-snapshot {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0.75rem;
}

.hub-snap {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    padding: 0.55rem 0.75rem;
    border-radius: var(--hub-radius-sm);
    background: rgba(255, 255, 255, 0.10);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    border: 1px solid rgba(255, 255, 255, 0.18);
}

.hub-snap-icon {
    width: 2rem;
    height: 2rem;
    display: grid;
    place-items: center;
    border-radius: 0.55rem;
    background: rgba(255, 255, 255, 0.18);
    color: #fff;
    font-size: 0.95rem;
    flex-shrink: 0;
}

.hub-snap[data-tone="primary"] .hub-snap-icon { background: rgba(125, 211, 252, 0.30); }
.hub-snap[data-tone="success"] .hub-snap-icon { background: rgba(134, 239, 172, 0.28); }
.hub-snap[data-tone="info"]    .hub-snap-icon { background: rgba(165, 243, 252, 0.28); }

.hub-snap-value {
    font-size: 1.15rem;
    font-weight: 800;
    color: #fff;
    letter-spacing: -0.02em;
    line-height: 1;
}

.hub-snap-value span {
    font-size: 0.75em;
    font-weight: 700;
    margin-left: 0.1em;
    color: rgba(255, 255, 255, 0.7);
}

.hub-snap-label {
    font-size: 0.7rem;
    color: rgba(255, 255, 255, 0.78);
    margin-top: 0.1rem;
    line-height: 1;
}

@media (max-width: 575.98px) {
    .hub-hero-snapshot { grid-template-columns: 1fr; }
}

/* ── Tabs — modern segmented control ─────────────────────────── */
.clinic-detail-tabs-shell,
.patient-hub-tabs-shell {
    display: flex;
    justify-content: flex-start;
    margin: 0 0 1rem;
    overflow-x: auto;
}

.patient-hub-tabs {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    padding: 0.3125rem;
    margin: 0;
    list-style: none;
    background: linear-gradient(180deg, rgba(241, 245, 249, .9) 0%, rgba(241, 245, 249, .55) 100%);
    border: 1px solid var(--hub-border);
    border-radius: 0.875rem;
    flex-wrap: nowrap;
    max-width: 100%;
}

.patient-hub-tabs .nav-link {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.4rem 0.75rem;
    border-radius: 0.5rem;
    color: var(--hub-text-sub);
    font-size: 0.78rem;
    font-weight: 600;
    white-space: nowrap;
    transition: color .2s ease, background-color .2s ease;
}

.patient-hub-tabs .nav-link:hover { background: rgba(255, 255, 255, .55); color: var(--hub-text); }
.patient-hub-tabs .nav-link.active { background: #fff; color: var(--hub-text); box-shadow: 0 1px 2px rgba(15, 23, 42, .06); }
.patient-hub-tabs .nav-link i { font-size: 0.85rem; opacity: 0.7; }
.patient-hub-tabs .nav-link.active i { opacity: 1; color: var(--hub-primary); }



.clinic-detail-tabs {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    padding: 0.3125rem;
    margin: 0;
    list-style: none;
    background: linear-gradient(180deg, rgba(241, 245, 249, .9) 0%, rgba(241, 245, 249, .55) 100%);
    border: 1px solid var(--hub-border);
    border-radius: 0.875rem;
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, .85),
        0 1px 2px rgba(15, 23, 42, .04);
    flex-wrap: wrap;
    max-width: 100%;
}

.clinic-detail-tabs .nav-item { display: flex; }

.clinic-detail-tabs .nav-link {
    position: relative;
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.5rem 1rem;
    border: 0;
    border-radius: 0.625rem;
    background: transparent;
    color: var(--hub-text-sub);
    font-weight: 600;
    font-size: 0.875rem;
    line-height: 1.2;
    letter-spacing: -.005em;
    cursor: pointer;
    white-space: nowrap;
    transition:
        color .2s ease,
        background-color .2s ease,
        box-shadow .25s cubic-bezier(.4, 0, .2, 1),
        transform .15s ease;
}

.clinic-detail-tabs .nav-link i {
    font-size: 0.95rem;
    opacity: .7;
    transition: color .2s ease, opacity .2s ease, transform .25s cubic-bezier(.4, 0, .2, 1);
}

.clinic-detail-tabs .nav-link:hover {
    color: var(--hub-text);
    background: rgba(255, 255, 255, .55);
}
.clinic-detail-tabs .nav-link:hover i { opacity: 1; }

.clinic-detail-tabs .nav-link:focus-visible {
    outline: 2px solid var(--hub-primary);
    outline-offset: 2px;
}

.clinic-detail-tabs .nav-link.active {
    color: var(--hub-text);
    background: #fff;
    box-shadow:
        0 1px 2px rgba(15, 23, 42, .05),
        0 6px 16px -4px rgba(15, 23, 42, .08),
        0 0 0 1px rgba(15, 23, 42, .04);
}
.clinic-detail-tabs .nav-link.active i {
    opacity: 1;
    color: var(--hub-primary);
    transform: scale(1.05);
}

/* Remove the legacy underline indicator (replaced by elevated card) */
.clinic-detail-tabs .nav-link.active::after { content: none; }

/* Badge — refined pill */
.clinic-detail-tab-badge {
    display: inline-flex;
    align-items: center;
    padding: 0.0625rem 0.5rem;
    border-radius: 999px;
    font-size: 0.6875rem;
    font-weight: 700;
    line-height: 1.5;
    letter-spacing: 0;
    background: var(--hub-primary-soft);
    color: var(--hub-primary);
    margin-left: 0.15rem;
    transition: background-color .2s ease, color .2s ease, border-color .2s ease;
}

.clinic-detail-tabs .nav-link:not(.active) .clinic-detail-tab-badge {
    background: rgba(255, 255, 255, .85);
    color: var(--hub-text-sub);
    border: 1px solid var(--hub-border);
}

.clinic-detail-tab-badge.is-complete {
    background: var(--hub-success-soft);
    color: var(--hub-success);
}
.clinic-detail-tabs .nav-link:not(.active) .clinic-detail-tab-badge.is-complete {
    background: rgba(255, 255, 255, .85);
    color: var(--hub-success);
    border-color: var(--hub-success-soft);
}

@media (max-width: 575.98px) {
    .clinic-detail-tabs { width: 100%; display: flex; }
    .clinic-detail-tabs .nav-item { flex: 1 1 0; }
    .clinic-detail-tabs .nav-link { flex: 1 1 0; justify-content: center; padding: 0.5rem 0.625rem; }
    .clinic-detail-tabs .nav-link span:not(.clinic-detail-tab-badge) { font-size: 0.8125rem; }
}

/* ── KPI Grid ───────────────────────────────────────────────── */
.hub-kpi-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 0.875rem;
}

.hub-kpi {
    position: relative;
    display: grid;
    grid-template-columns: auto 1fr auto;
    grid-template-areas:
        "icon label value"
        "icon foot  value";
    align-items: center;
    column-gap: 0.875rem;
    row-gap: 0.15rem;
    padding: 0.9rem 1.1rem;
    min-height: 84px;
    border-radius: var(--hub-radius);
    background: var(--hub-bg);
    border: 1px solid var(--hub-border);
    box-shadow: var(--hub-shadow-sm);
    color: inherit;
    text-decoration: none;
    overflow: hidden;
    transition: box-shadow .3s cubic-bezier(.4,0,.2,1), transform .3s cubic-bezier(.4,0,.2,1), border-color .3s ease;
}

.hub-kpi::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, var(--tone-soft, var(--hub-primary-soft)) 0%, transparent 70%);
    opacity: 0.55;
    pointer-events: none;
}
.hub-kpi::after {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(120% 100% at 100% 0%, var(--tone-soft, rgba(58,160,198,.10)) 0%, transparent 55%);
    opacity: 0;
    transition: opacity .3s ease;
    pointer-events: none;
}

.hub-kpi:hover {
    transform: translateY(-3px);
    box-shadow: var(--hub-shadow-md);
    border-color: var(--hub-border-strong);
    color: inherit;
}
.hub-kpi:hover::after { opacity: 1; }
.hub-kpi:hover .hub-kpi-icon {
    transform: scale(1.08) rotate(-3deg);
    box-shadow: 0 6px 14px -4px var(--tone, var(--hub-primary));
}
.hub-kpi:hover .hub-kpi-icon i { animation: hub-kpi-icon-pulse 0.8s cubic-bezier(.4, 0, .2, 1); }
.hub-kpi:hover .hub-kpi-value { transform: scale(1.04); color: var(--tone, var(--hub-primary)); }
.hub-kpi:hover .hub-kpi-label { color: var(--hub-text); }

@keyframes hub-kpi-icon-pulse {
    0%   { transform: scale(1); }
    35%  { transform: scale(1.18); }
    65%  { transform: scale(0.94); }
    100% { transform: scale(1); }
}

.hub-kpi[data-tone="primary"] { --tone: var(--hub-primary); --tone-soft: var(--hub-primary-soft); }
.hub-kpi[data-tone="success"] { --tone: var(--hub-success); --tone-soft: var(--hub-success-soft); }
.hub-kpi[data-tone="info"]    { --tone: var(--hub-info);    --tone-soft: var(--hub-info-soft); }
.hub-kpi[data-tone="warning"] { --tone: var(--hub-warning); --tone-soft: var(--hub-warning-soft); }
.hub-kpi[data-tone="danger"]  { --tone: var(--hub-danger);  --tone-soft: var(--hub-danger-soft); }
.hub-kpi[data-tone="accent"]  { --tone: var(--hub-accent);  --tone-soft: var(--hub-accent-soft); }
.hub-kpi[data-tone="neutral"] { --tone: var(--hub-text-sub); --tone-soft: rgba(100, 116, 139, 0.08); }

.hub-kpi-head { display: contents; }
.hub-kpi-meta { display: contents; }

.hub-kpi-icon {
    grid-area: icon;
    width: 2.25rem;
    height: 2.25rem;
    border-radius: 0.65rem;
    display: grid;
    place-items: center;
    background: var(--tone-soft);
    color: var(--tone);
    font-size: 1rem;
    flex-shrink: 0;
    position: relative;
    z-index: 1;
    transition: transform .3s cubic-bezier(.34, 1.56, .64, 1), box-shadow .3s ease;
    will-change: transform;
}
.hub-kpi-icon i { transition: transform .3s cubic-bezier(.34, 1.56, .64, 1); }

.hub-kpi-label {
    grid-area: label;
    align-self: end;
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--hub-text-sub);
    margin-bottom: 0;
    position: relative;
    z-index: 1;
    transition: color .25s ease;
    line-height: 1.2;
}

.hub-kpi-value {
    grid-area: value;
    justify-self: end;
    align-self: center;
    font-size: 1.875rem;
    font-weight: 800;
    color: var(--hub-text);
    letter-spacing: -0.025em;
    line-height: 1;
    font-variant-numeric: tabular-nums;
    position: relative;
    z-index: 1;
    transition: transform .3s cubic-bezier(.34, 1.56, .64, 1), color .25s ease;
}

.hub-kpi-foot {
    grid-area: foot;
    align-self: start;
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    font-size: 0.72rem;
    color: var(--hub-text-sub);
    position: relative;
    z-index: 1;
    flex-wrap: nowrap;
    min-width: 0;
    line-height: 1.3;
}

.hub-kpi-delta {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    font-size: 0.65rem;
    font-weight: 700;
    padding: 0.15rem 0.5rem;
    border-radius: 1rem;
    background: rgba(100, 116, 139, 0.10);
    color: var(--hub-text-sub);
    line-height: 1.3;
    flex-shrink: 0;
}

.hub-kpi-delta.is-up { background: var(--hub-success-soft); color: var(--hub-success); }
.hub-kpi-delta.is-down { background: var(--hub-danger-soft); color: var(--hub-danger); }

.hub-kpi-sub {
    font-size: 0.7rem;
    color: var(--hub-text-sub);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    min-width: 0;
}

.hub-kpi-spark {
    width: 100%;
    height: 28px;
    color: var(--tone, var(--hub-primary));
    margin-top: 0.25rem;
    opacity: 0.85;
}

/* Click-affordance arrow — anchored top-right, quiet at rest, livens on hover */
.hub-kpi-arrow {
    position: absolute;
    top: 0.55rem;
    right: 0.65rem;
    z-index: 2;
    font-size: 0.85rem;
    color: var(--hub-text-sub);
    opacity: 0.5;
    transition: opacity .25s ease, color .25s ease, transform .25s cubic-bezier(.34, 1.56, .64, 1);
    pointer-events: none;
}
.hub-kpi:hover .hub-kpi-arrow {
    opacity: 1;
    color: var(--tone, var(--hub-primary));
    transform: translate(2px, -2px);
}

/* ── Card primitive ─────────────────────────────────────────── */
.hub-card {
    background: var(--hub-bg);
    border: 1px solid var(--hub-border);
    border-radius: var(--hub-radius);
    box-shadow: var(--hub-shadow-sm);
    overflow: hidden;
    transition: box-shadow 0.2s ease;
}

.hub-card:hover {
    box-shadow: var(--hub-shadow-md);
}

.hub-card-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.85rem 1.15rem;
    border-bottom: 1px solid var(--hub-border);
    flex-wrap: wrap;
}

.hub-card-title {
    display: flex;
    align-items: center;
    gap: 0.55rem;
    margin: 0;
}

.hub-card-title i {
    color: var(--hub-primary);
    font-size: 0.95rem;
}

.hub-card-title h6 {
    font-size: 0.8rem;
    font-weight: 700;
    color: var(--hub-text);
    margin: 0;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.hub-card-count {
    background: var(--hub-primary-soft);
    color: var(--hub-primary);
    font-size: 0.7rem;
    font-weight: 700;
    padding: 0.15rem 0.55rem;
    border-radius: 1rem;
    margin-left: 0.15rem;
}

.hub-link {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    font-size: 0.78rem;
    font-weight: 600;
    color: var(--hub-primary);
    text-decoration: none;
    padding: 0.3rem 0.65rem;
    border-radius: 1.5rem;
    transition: background 0.15s ease;
}

.hub-link:hover {
    background: var(--hub-primary-soft);
    color: var(--hub-primary);
}

/* ── Pills, tags ───────────────────────────────────────────── */
.hub-pill {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    font-size: 0.7rem;
    font-weight: 600;
    padding: 0.22rem 0.7rem;
    border-radius: 2rem;
    background: rgba(100, 116, 139, 0.10);
    color: var(--hub-text-sub);
}

.hub-pill-dot {
    width: 0.4rem;
    height: 0.4rem;
    border-radius: 50%;
    background: currentColor;
    box-shadow: 0 0 0 3px rgba(100, 116, 139, 0.18);
}

.hub-pill--success { background: var(--hub-success-soft); color: var(--hub-success); }
.hub-pill--success .hub-pill-dot { box-shadow: 0 0 0 3px var(--hub-success-soft); }
.hub-pill--info    { background: var(--hub-info-soft);    color: var(--hub-info); }
.hub-pill--info .hub-pill-dot    { box-shadow: 0 0 0 3px var(--hub-info-soft); }
.hub-pill--warning { background: var(--hub-warning-soft); color: var(--hub-warning); }
.hub-pill--warning .hub-pill-dot { box-shadow: 0 0 0 3px var(--hub-warning-soft); }
.hub-pill--muted   { background: rgba(100, 116, 139, 0.10); color: var(--hub-text-sub); }

.hub-tag {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    font-size: 0.68rem;
    font-weight: 600;
    padding: 0.1rem 0.5rem;
    border-radius: 0.5rem;
    background: rgba(100, 116, 139, 0.10);
    color: var(--hub-text-sub);
}

.hub-tag--success { background: var(--hub-success-soft); color: var(--hub-success); }
.hub-tag--info    { background: var(--hub-info-soft);    color: var(--hub-info); }
.hub-tag--warning { background: var(--hub-warning-soft); color: var(--hub-warning); }
.hub-tag--danger  { background: var(--hub-danger-soft);  color: var(--hub-danger); }

/* ── Subscription strip ─────────────────────────────────────── */
.hub-subs.is-active {
    background:
        linear-gradient(135deg, var(--hub-success-soft) 0%, transparent 60%),
        var(--hub-bg);
}

.hub-subs.is-trial {
    background:
        linear-gradient(135deg, var(--hub-info-soft) 0%, transparent 60%),
        var(--hub-bg);
}

.hub-subs-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: 1rem;
    padding: 1.15rem;
}

.hub-subs-cell { display: flex; flex-direction: column; gap: 0.2rem; }

.hub-subs-label {
    font-size: 0.68rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--hub-text-sub);
}

.hub-subs-value {
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--hub-text);
}

.hub-subs-value--xl {
    font-size: 1.25rem;
    font-weight: 800;
    letter-spacing: -0.02em;
}

/* ── Locations list ─────────────────────────────────────────── */
.hub-loc-list {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    padding: 0.85rem 1.15rem 1.05rem;
}

.hub-loc-item {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    padding: 0.7rem 0.85rem;
    border-radius: var(--hub-radius-sm);
    background: var(--hub-bg-soft);
    border: 1px solid transparent;
    transition: border-color 0.15s ease, background 0.15s ease;
}

.hub-loc-item:hover {
    border-color: var(--hub-border-strong);
    background: var(--hub-bg);
}

.hub-loc-marker {
    width: 2.25rem;
    height: 2.25rem;
    border-radius: 50%;
    display: grid;
    place-items: center;
    background: var(--hub-primary-soft);
    color: var(--hub-primary);
    font-size: 0.95rem;
    flex-shrink: 0;
}

.hub-loc-body { flex: 1 1 auto; min-width: 0; }

.hub-loc-title {
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--hub-text);
    display: flex;
    align-items: center;
    gap: 0.4rem;
    flex-wrap: wrap;
    margin-bottom: 0.2rem;
}

.hub-loc-meta {
    font-size: 0.75rem;
    color: var(--hub-text-sub);
    display: flex;
    flex-wrap: wrap;
    gap: 0.85rem;
}

.hub-loc-meta i { margin-right: 0.2rem; }

.hub-icon-btn {
    width: 2rem;
    height: 2rem;
    display: grid;
    place-items: center;
    border-radius: 50%;
    border: 1px solid var(--hub-border);
    background: var(--hub-bg);
    color: var(--hub-text-sub);
    text-decoration: none;
    transition: all 0.15s ease;
}

.hub-icon-btn:hover {
    color: var(--hub-primary);
    border-color: var(--hub-primary);
    background: var(--hub-primary-soft);
}

/* ── People list (patients, staff) ──────────────────────────── */
.hub-people-list {
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
    padding: 0.85rem 1.15rem 1.05rem;
}

.hub-people-item {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    padding: 0.6rem 0.85rem;
    border-radius: var(--hub-radius-sm);
    background: var(--hub-bg-soft);
    text-decoration: none;
    color: inherit;
    transition: background 0.15s ease, transform 0.15s ease;
    border: 1px solid transparent;
}

a.hub-people-item:hover {
    background: var(--hub-bg);
    border-color: var(--hub-border-strong);
    transform: translateX(2px);
    color: inherit;
}

.hub-avatar {
    width: 2.4rem;
    height: 2.4rem;
    border-radius: 50%;
    display: grid;
    place-items: center;
    font-weight: 700;
    font-size: 0.875rem;
    flex-shrink: 0;
    background: var(--hub-primary-soft);
    color: var(--hub-primary);
}

.hub-avatar--patient { background: rgba(244, 114, 182, 0.15); color: #be185d; }
.hub-avatar--staff   { background: rgba(99, 102, 241, 0.15); color: #4338ca; }

[data-bs-theme="dark"] .hub-avatar--patient,
[data-theme="dark"] .hub-avatar--patient { background: rgba(244, 114, 182, 0.20); color: #f9a8d4; }
[data-bs-theme="dark"] .hub-avatar--staff,
[data-theme="dark"] .hub-avatar--staff   { background: rgba(129, 140, 248, 0.22); color: #c7d2fe; }

.hub-people-body { flex: 1 1 auto; min-width: 0; }

.hub-people-name {
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--hub-text);
    display: flex;
    align-items: center;
    gap: 0.4rem;
    flex-wrap: wrap;
    margin-bottom: 0.2rem;
}

.hub-people-meta {
    font-size: 0.75rem;
    color: var(--hub-text-sub);
    display: flex;
    flex-wrap: wrap;
    gap: 0.85rem;
}

.hub-people-meta i { margin-right: 0.2rem; }

.hub-people-chevron {
    color: var(--hub-text-sub);
    opacity: 0.5;
    transition: opacity 0.15s ease, transform 0.15s ease;
}

a.hub-people-item:hover .hub-people-chevron {
    opacity: 1;
    transform: translateX(2px);
    color: var(--hub-primary);
}

/* ── Task list ─────────────────────────────────────────────── */
.hub-task-list {
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
    padding: 0.85rem 1.15rem 1.05rem;
}

.hub-task-item {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    padding: 0.65rem 0.85rem;
    border-radius: var(--hub-radius-sm);
    background: var(--hub-bg-soft);
    border-left: 3px solid var(--hub-border-strong);
}

.hub-task-item.is-overdue {
    background: var(--hub-danger-soft);
    border-left-color: var(--hub-danger);
}

.hub-task-priority {
    width: 0.5rem;
    height: 0.5rem;
    border-radius: 50%;
    background: var(--hub-text-sub);
    flex-shrink: 0;
}

.hub-task-priority--low      { background: #94a3b8; }
.hub-task-priority--medium   { background: #f59e0b; }
.hub-task-priority--high     { background: #f97316; }
.hub-task-priority--urgent   { background: #dc2626; box-shadow: 0 0 0 3px rgba(220, 38, 38, 0.18); }

.hub-task-body { flex: 1 1 auto; min-width: 0; }

.hub-task-title {
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--hub-text);
    margin-bottom: 0.2rem;
}

.hub-task-meta {
    font-size: 0.72rem;
    color: var(--hub-text-sub);
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
}

/* ── Empty state ───────────────────────────────────────────── */
.hub-empty {
    text-align: center;
    padding: 2rem 1.5rem;
    color: var(--hub-text-sub);
}

.hub-empty i {
    font-size: 1.75rem;
    color: var(--hub-text-sub);
    opacity: 0.45;
    margin-bottom: 0.5rem;
    display: block;
}

.hub-empty p {
    font-size: 0.85rem;
    margin: 0 0 0.75rem;
}

.hub-empty--inline { padding: 1.25rem 1.15rem; }

.hub-empty--centered { padding: 3rem 1.5rem; }

.hub-empty-cta {
    display: inline-flex;
    align-items: center;
    padding: 0.45rem 1rem;
    border-radius: 2rem;
    background: var(--hub-primary-soft);
    color: var(--hub-primary);
    font-size: 0.8rem;
    font-weight: 600;
    text-decoration: none;
    transition: background 0.15s ease;
}

.hub-empty-cta:hover {
    background: var(--hub-primary);
    color: #fff;
}

/* ── EHR card ──────────────────────────────────────────────── */
.hub-ehr.is-connected {
    background: linear-gradient(180deg, var(--hub-success-soft) 0%, transparent 35%), var(--hub-bg);
}

.hub-ehr-body {
    padding: 1rem 1.15rem 1.15rem;
}

.hub-ehr-name {
    font-size: 1rem;
    font-weight: 700;
    color: var(--hub-text);
    letter-spacing: -0.01em;
    margin-bottom: 0.1rem;
}

.hub-ehr-uid {
    font-size: 0.7rem;
    color: var(--hub-text-sub);
    font-family: 'SF Mono', Menlo, Consolas, monospace;
    margin-bottom: 0.85rem;
}

.hub-ehr-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0.5rem;
    margin-bottom: 0.85rem;
}

.hub-ehr-grid > div {
    text-align: center;
    padding: 0.65rem 0.4rem;
    background: var(--hub-bg-soft);
    border-radius: 0.625rem;
    border: 1px solid var(--hub-border);
}

.hub-ehr-num {
    font-size: 1.1rem;
    font-weight: 800;
    color: var(--hub-text);
    letter-spacing: -0.02em;
}

.hub-ehr-lbl {
    font-size: 0.65rem;
    font-weight: 600;
    color: var(--hub-text-sub);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-top: 0.15rem;
}

.hub-kv-line {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.45rem 0;
    border-top: 1px dashed var(--hub-border);
    font-size: 0.78rem;
}

.hub-kv-line span { color: var(--hub-text-sub); }
.hub-kv-line strong { color: var(--hub-text); font-weight: 600; }

.hub-alert {
    display: flex;
    gap: 0.5rem;
    align-items: flex-start;
    padding: 0.55rem 0.7rem;
    border-radius: 0.625rem;
    font-size: 0.75rem;
    margin: 0.65rem 0;
}

.hub-alert--warning {
    background: var(--hub-warning-soft);
    color: var(--hub-warning);
}

.hub-alert i {
    margin-top: 0.05rem;
    flex-shrink: 0;
}

.hub-ehr-form { margin-top: 0.85rem; }

.hub-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.4rem;
    padding: 0.55rem 1rem;
    border-radius: 2rem;
    border: 1px solid var(--hub-border);
    background: var(--hub-bg);
    color: var(--hub-text);
    font-size: 0.8125rem;
    font-weight: 600;
    text-decoration: none;
    cursor: pointer;
    transition: all 0.15s ease;
}

.hub-btn:hover {
    border-color: var(--hub-primary);
    color: var(--hub-primary);
    background: var(--hub-primary-soft);
}

.hub-btn--primary {
    background: linear-gradient(135deg, var(--hub-primary), #0891b2);
    color: #fff;
    border-color: transparent;
}

.hub-btn--primary:hover {
    background: linear-gradient(135deg, #064f7c, #0e7490);
    color: #fff;
    transform: translateY(-1px);
    box-shadow: var(--hub-shadow-md);
}

/* ── Connected accounts ─────────────────────────────────────── */
.hub-account-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 0.5rem;
    padding: 0.85rem 1.15rem 1.05rem;
}

.hub-account-tile {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.4rem;
    padding: 0.85rem 0.6rem;
    border-radius: var(--hub-radius-sm);
    background: var(--hub-bg-soft);
    border: 1px solid var(--hub-border);
    text-align: center;
    transition: border-color 0.15s ease;
}

.hub-account-tile.is-connected {
    border-color: var(--hub-success);
    background: var(--hub-success-soft);
}

.hub-account-icon {
    width: 2.25rem;
    height: 2.25rem;
    border-radius: 50%;
    display: grid;
    place-items: center;
    color: #fff;
    font-size: 1rem;
}

.hub-account-icon--google   { background: linear-gradient(135deg, #ea4335, #fbbc04); }
.hub-account-icon--facebook { background: #1877f2; }

.hub-account-name {
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--hub-text);
}

.hub-account-status {
    font-size: 0.68rem;
    color: var(--hub-text-sub);
    display: flex;
    align-items: center;
    gap: 0.25rem;
}

.hub-account-tile.is-connected .hub-account-status {
    color: var(--hub-success);
    font-weight: 600;
}

/* ── Quick links grid ──────────────────────────────────────── */
.hub-quicklinks {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 0.5rem;
    padding: 0.85rem 1.15rem 1.05rem;
}

.hub-quicklink {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.45rem;
    padding: 0.85rem 0.5rem;
    border-radius: var(--hub-radius-sm);
    background: var(--hub-bg-soft);
    border: 1px solid var(--hub-border);
    color: var(--hub-text);
    font-size: 0.78rem;
    font-weight: 600;
    text-decoration: none;
    text-align: center;
    transition: all 0.18s ease;
}

.hub-quicklink i {
    font-size: 1.15rem;
    color: var(--hub-primary);
}

.hub-quicklink:hover {
    background: var(--hub-primary-soft);
    border-color: var(--hub-primary);
    color: var(--hub-primary);
    transform: translateY(-2px);
    box-shadow: var(--hub-shadow-md);
}

/* Onboarding list pagination */
.copl-paginator {
    margin-top: 1rem;
    display: flex;
    justify-content: center;
}
.copl-page-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    background: var(--bs-body-bg, #fff);
    border: 1px solid var(--bs-border-color);
    border-radius: 999px;
    padding: 0.25rem 0.4rem;
    box-shadow: var(--hub-shadow-sm, 0 1px 2px rgba(0,0,0,0.04));
}
.copl-page-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2rem;
    height: 2rem;
    border-radius: 999px;
    color: var(--bs-emphasis-color, #1f2937);
    background: transparent;
    text-decoration: none;
    border: 0;
    transition: background-color 0.15s ease, color 0.15s ease;
}
.copl-page-btn:hover { background: var(--bs-secondary-bg, #f3f4f6); }
.copl-page-btn.is-disabled {
    color: var(--bs-secondary-color, #94a3b8);
    pointer-events: none;
    cursor: not-allowed;
}
.copl-page-info {
    font-size: 0.875rem;
    color: var(--bs-emphasis-color, #1f2937);
    padding: 0 0.6rem;
}
.copl-page-info strong { color: var(--hub-primary, #0069a6); font-weight: 600; }

/* ─────────────────────────────────────────────────────────────────
   Skeleton loaders — drop-in shimmer surfaces.
   Add `.is-loading` to a hub-card or hub-kpi to show shimmer until
   the real content swaps in.
   ───────────────────────────────────────────────────────────────── */
@keyframes hub-shimmer {
    0%   { background-position: -200% 0; }
    100% { background-position: 200% 0; }
}

.hub-skeleton,
.hub-card.is-loading .hub-skeleton-target,
.hub-kpi.is-loading .hub-kpi-num,
.hub-kpi.is-loading .hub-kpi-lbl {
    color: transparent !important;
    background: linear-gradient(
        90deg,
        var(--skeleton-base, color-mix(in srgb, var(--bs-body-color) 8%, transparent)) 0%,
        var(--skeleton-shine, color-mix(in srgb, var(--bs-body-color) 14%, transparent)) 50%,
        var(--skeleton-base, color-mix(in srgb, var(--bs-body-color) 8%, transparent)) 100%
    );
    background-size: 200% 100%;
    animation: hub-shimmer 1.4s ease-in-out infinite;
    border-radius: 0.5rem;
    user-select: none;
}

@media (prefers-reduced-motion: reduce) {
    .hub-skeleton,
    .hub-card.is-loading .hub-skeleton-target,
    .hub-kpi.is-loading .hub-kpi-num,
    .hub-kpi.is-loading .hub-kpi-lbl {
        animation: none;
    }
}

.hub-skeleton.is-line { height: 0.875rem; width: 60%; }
.hub-skeleton.is-line.is-short { width: 30%; }
.hub-skeleton.is-line.is-long  { width: 85%; }
.hub-skeleton.is-pill { height: 1.25rem; width: 4rem; border-radius: 999px; }
.hub-skeleton.is-avatar { width: 2.5rem; height: 2.5rem; border-radius: 999px; }

/* Stronger focus-visible rings for keyboard users */
.hub-btn:focus-visible,
.copl-page-btn:focus-visible,
.copl-card-name:focus-visible,
.copl-card-open:focus-visible {
    outline: 2px solid var(--hub-primary, #0069a6);
    outline-offset: 2px;
    border-radius: 0.5rem;
}

/* ============================================================
   CLINIC DIRECTORY TABLE — compact view of templates/clinic/list.html
   Conceptual neighbor: this is the platform-admin admin counterpart of
   the self-service hub above. Shared design tokens (--hub-*).
   ============================================================ */

.clinic-directory-table tbody tr {
    transition: background-color 120ms ease;
}

.clinic-directory-table tbody tr:hover {
    background: var(--hub-bg-soft);
}

/* Identity cell: avatar + name + slug chip */
.clinic-row-identity {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    min-width: 0;
}

.clinic-row-identity__avatar {
    flex-shrink: 0;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    object-fit: cover;
    border: 1px solid var(--hub-border);
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.08), inset 0 0 0 2px rgba(255, 255, 255, 0.4);
}

.clinic-row-identity__avatar--initial {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-size: 0.78rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.02em;
    border: none;
}

.clinic-row-identity__avatar--ehr {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, #a78bfa, #6366f1);
    color: #fff;
    font-size: 0.95rem;
    line-height: 1;
}
.clinic-row-identity__avatar--ehr > i { line-height: 1; }

.clinic-row--ehr-only {
    background: linear-gradient(90deg, rgba(139, 92, 246, .04), transparent 35%);
}
.clinic-row--ehr-only:hover {
    background: linear-gradient(90deg, rgba(139, 92, 246, .07), rgba(15, 23, 42, .02) 50%);
}

.dropdown-item.clinic-row-action--migrate {
    color: #4f46e5;
    font-weight: 600;
}

.clinic-row-identity__body {
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
    line-height: 1.2;
}

.clinic-row-identity__name {
    color: var(--hub-text);
    font-size: 0.85rem;
    font-weight: 600;
    text-decoration: none;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    max-width: 22rem;
}

.clinic-row-identity__name:hover {
    color: var(--hub-primary);
}

.clinic-row-identity__slug {
    align-self: flex-start;
    font-family: ui-monospace, "SF Mono", "Cascadia Code", "Roboto Mono", Menlo, Consolas, monospace;
    font-size: 0.65rem;
    font-weight: 500;
    color: var(--hub-text-sub);
    background: var(--hub-bg-soft);
    border: 1px solid var(--hub-border);
    border-radius: 0.3rem;
    padding: 0.05rem 0.35rem;
    line-height: 1.3;
    max-width: 22rem;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* Email cell — icon + truncated address */
.clinic-row-email {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    color: var(--hub-text);
    text-decoration: none;
    max-width: 16rem;
}

.clinic-row-email i {
    color: var(--hub-text-sub);
    font-size: 0.78rem;
    flex-shrink: 0;
}

.clinic-row-email__addr {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.clinic-row-email:hover { color: var(--hub-primary); }

/* Numeric metric (locations, providers, patients) */
.clinic-row-metric {
    display: inline-block;
    color: var(--hub-text);
    font-variant-numeric: tabular-nums;
    font-weight: 500;
    font-size: 0.85rem;
}

.clinic-row-metric--strong {
    font-weight: 700;
    color: var(--hub-text);
}

/* Primary location: pin icon + city/state on top, country sub */
.clinic-row-location {
    display: flex;
    align-items: flex-start;
    gap: 0.35rem;
}

.clinic-row-location > i {
    color: var(--hub-text-sub);
    font-size: 0.78rem;
    margin-top: 0.15rem;
    flex-shrink: 0;
}

.clinic-row-location__body {
    display: flex;
    flex-direction: column;
    line-height: 1.25;
    min-width: 0;
}

.clinic-row-location__city {
    color: var(--hub-text);
    font-weight: 500;
    font-size: 0.8125rem;
}

.clinic-row-location__country {
    color: var(--hub-text-sub);
    font-size: 0.68rem;
}

/* Subscription cell: tier name + status pill stacked */
.clinic-row-sub {
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
    align-items: flex-start;
}

.clinic-row-sub__tier {
    color: var(--hub-text);
    font-weight: 600;
    font-size: 0.8125rem;
    line-height: 1.2;
}

/* Phone cell */
.clinic-row-phone {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    color: var(--hub-text);
    text-decoration: none;
}

.clinic-row-phone i {
    color: var(--hub-text-sub);
    font-size: 0.75rem;
}

.clinic-row-phone:hover { color: var(--hub-primary); }

/* Onboarded date cell */
.clinic-row-date {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    color: var(--hub-text);
}

.clinic-row-date i {
    color: var(--hub-text-sub);
    font-size: 0.75rem;
}

/* ────────────────────────────────────────────────────────────
   New-clinic onboarding form  (used by /clinics/create/)
   Replaces the old title-summary-card layout with a hero band
   + single soft card. Reuses the dashboard's pastel palette so
   the surface feels coherent with the directory and detail page.
   ──────────────────────────────────────────────────────────── */
.clinic-onboard-form {
    --co-text: #0f172a;
    --co-sub: #64748b;
    --co-muted: #94a3b8;
    --co-border: #eef0f3;
    --co-border-strong: #e5e7eb;
    --co-accent: #6366f1;
    --co-accent-soft: #eef2ff;
    --co-success: #10b981;
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
    max-width: 1080px;
    margin: 0 auto;
}

[data-theme="dark"] .clinic-onboard-form {
    --co-text: var(--dark-text-primary);
    --co-sub: var(--dark-text-secondary);
    --co-muted: var(--dark-text-secondary);
    --co-border: var(--dark-border);
    --co-border-strong: rgba(255, 255, 255, 0.14);
    --co-accent: #818cf8;
    --co-accent-soft: rgba(99, 102, 241, 0.18);
    --co-success: #34d399;
    --co-bg: var(--dark-bg-surface);
    --co-bg-soft: var(--dark-bg-elevated);
}

[data-theme="dark"] .clinic-onboard-hero,
[data-theme="dark"] .clinic-onboard-card,
[data-theme="dark"] .clinic-onboard-section {
    background: var(--dark-bg-elevated);
    border-color: var(--dark-border);
    color: var(--dark-text-primary);
}

[data-theme="dark"] .clinic-onboard-form .form-control,
[data-theme="dark"] .clinic-onboard-form .form-select {
    background-color: var(--dark-bg-surface);
    border-color: var(--dark-border);
    color: var(--dark-text-primary);
    color-scheme: dark;
}

[data-theme="dark"] .clinic-onboard-form .form-control::placeholder {
    color: var(--dark-text-secondary);
}

[data-theme="dark"] .clinic-onboard-form .form-check-label,
[data-theme="dark"] .clinic-onboard-form label {
    color: var(--dark-text-primary);
}

[data-theme="dark"] .clinic-onboard-label {
    color: var(--dark-text-primary);
}
[data-theme="dark"] .clinic-onboard-help,
[data-theme="dark"] .clinic-onboard-hint {
    color: var(--dark-text-secondary);
}

[data-theme="dark"] .clinic-onboard-status {
    background: linear-gradient(180deg, var(--dark-bg-surface), var(--dark-bg-elevated));
    border-color: var(--dark-border);
}
[data-theme="dark"] .clinic-onboard-status__title {
    color: var(--dark-text-primary);
}
[data-theme="dark"] .clinic-onboard-status__sub {
    color: var(--dark-text-secondary);
}
[data-theme="dark"] .clinic-onboard-status__icon {
    background: var(--dark-bg-overlay);
    border-color: var(--dark-border);
    color: var(--dark-text-primary);
}
[data-theme="dark"] .clinic-onboard-status .clinic-onboard-field--toggle {
    background: var(--dark-bg-overlay);
    border-color: var(--dark-border);
    color: var(--dark-text-primary);
}

.clinic-onboard-hero {
    position: relative;
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: 1.1rem;
    padding: 1.1rem 1.35rem;
    background: linear-gradient(180deg, #fbfbff, #fff);
    border: 1px solid var(--co-border);
    border-radius: 16px;
    box-shadow: 0 1px 2px rgba(15, 23, 42, .04);
    overflow: hidden;
    isolation: isolate;
}
.clinic-onboard-hero__glow {
    position: absolute;
    inset: -55% 8% auto 8%;
    height: 180px;
    background: radial-gradient(closest-side, rgba(99, 102, 241, .10), transparent 70%);
    pointer-events: none;
    z-index: -1;
}
.clinic-onboard-hero__icon {
    width: 46px;
    height: 46px;
    border-radius: 12px;
    background: linear-gradient(135deg, var(--co-accent), #8b5cf6);
    color: #fff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.2rem;
    box-shadow: 0 8px 20px -10px rgba(99, 102, 241, .55), inset 0 0 0 1px rgba(255, 255, 255, .25);
    flex-shrink: 0;
}
.clinic-onboard-hero__body { min-width: 0; }
.clinic-onboard-hero__eyebrow {
    font-size: .58rem;
    font-weight: 800;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--co-accent);
    display: block;
    margin-bottom: .15rem;
}
.clinic-onboard-hero__title {
    font-size: 1.05rem;
    font-weight: 700;
    color: var(--co-text);
    letter-spacing: -.015em;
    margin: 0 0 .15rem;
    line-height: 1.25;
}
.clinic-onboard-hero__sub {
    font-size: .76rem;
    color: var(--co-sub);
    line-height: 1.45;
    margin: 0;
    max-width: 64ch;
}
.clinic-onboard-hero__steps {
    list-style: none;
    margin: 0;
    padding: .35rem;
    background: linear-gradient(180deg, rgba(99, 102, 241, .06), rgba(99, 102, 241, .02));
    border: 1px solid rgba(99, 102, 241, .18);
    border-radius: 12px;
    display: flex;
    flex-direction: row;
    gap: .25rem;
    counter-reset: onboard-step;
}
.clinic-onboard-hero__steps li {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    padding: .35rem .55rem;
    border-radius: 8px;
    font-size: .72rem;
    color: var(--co-muted);
    transition: background .2s ease;
    white-space: nowrap;
}
.clinic-onboard-hero__steps li.is-active {
    background: #fff;
    box-shadow: 0 1px 3px rgba(15, 23, 42, .06), 0 0 0 1px rgba(99, 102, 241, .25);
}
.clinic-onboard-step-num {
    width: 20px;
    height: 20px;
    border-radius: 6px;
    background: #fff;
    color: var(--co-muted);
    border: 1px solid var(--co-border-strong);
    font-size: .62rem;
    font-weight: 800;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    font-variant-numeric: tabular-nums;
}
.clinic-onboard-step-label {
    font-weight: 700;
    color: var(--co-sub);
    line-height: 1.2;
    letter-spacing: -.005em;
}
.clinic-onboard-step-tag { display: none; }
.clinic-onboard-hero__steps li.is-active .clinic-onboard-step-num {
    background: var(--co-accent);
    color: #fff;
    border-color: transparent;
    box-shadow: 0 4px 10px -4px rgba(99, 102, 241, .55);
}
.clinic-onboard-hero__steps li.is-active .clinic-onboard-step-label { color: var(--co-accent); }
.clinic-onboard-hero__steps li.is-active .clinic-onboard-step-tag {
    color: var(--co-accent);
    font-weight: 700;
}
.clinic-onboard-hero__steps li.is-after .clinic-onboard-step-num { opacity: .55; }
.clinic-onboard-hero__steps li.is-after .clinic-onboard-step-label { color: var(--co-muted); font-weight: 600; }

@media (max-width: 880px) {
    .clinic-onboard-hero {
        grid-template-columns: auto 1fr;
        padding: .9rem 1rem;
    }
    .clinic-onboard-hero__steps {
        grid-column: 1 / -1;
        flex-wrap: wrap;
        justify-content: flex-start;
    }
}

.clinic-onboard-card {
    background: #fff;
    border: 1px solid var(--co-border);
    border-radius: 22px;
    box-shadow: 0 1px 2px rgba(15, 23, 42, .04);
    padding: 1.85rem 2rem;
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}
.clinic-onboard-card__head {
    display: flex;
    align-items: center;
    gap: .85rem;
}
.clinic-onboard-card__head-icon {
    width: 42px;
    height: 42px;
    border-radius: 13px;
    background: var(--co-accent-soft);
    color: var(--co-accent);
    border: 1px solid rgba(99, 102, 241, .18);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.1rem;
    flex-shrink: 0;
}
.clinic-onboard-card__head-title {
    font-size: 1.05rem;
    font-weight: 700;
    color: var(--co-text);
    margin: 0;
    letter-spacing: -.018em;
    line-height: 1.2;
}
.clinic-onboard-card__head-sub {
    font-size: .76rem;
    color: var(--co-muted);
    margin: .15rem 0 0;
}

.clinic-logo-uploader {
    display: flex;
    align-items: center;
    gap: 1.25rem;
    padding: 1.1rem 1.25rem;
    background: linear-gradient(135deg, rgba(99, 102, 241, .06), rgba(139, 92, 246, .04));
    border: 1px dashed rgba(99, 102, 241, .35);
    border-radius: 16px;
}
.clinic-logo-uploader__tile {
    position: relative;
    width: 96px;
    height: 96px;
    border-radius: 22px;
    background: linear-gradient(135deg, var(--co-accent), #8b5cf6);
    color: #fff;
    box-shadow: 0 14px 28px -12px rgba(99, 102, 241, .55), inset 0 0 0 2px rgba(255, 255, 255, .25);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    overflow: hidden;
}
.clinic-logo-uploader__tile img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.clinic-logo-uploader__initial {
    font-size: 2.4rem;
    font-weight: 800;
    letter-spacing: -.04em;
    line-height: 1;
}
.clinic-logo-uploader__camera {
    position: absolute;
    bottom: -6px;
    right: -6px;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    border: 2px solid #fff;
    background: var(--co-accent);
    color: #fff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: .85rem;
    cursor: pointer;
    transition: transform .15s ease, box-shadow .15s ease;
    box-shadow: 0 4px 10px rgba(99, 102, 241, .4);
}
.clinic-logo-uploader__camera:hover {
    transform: scale(1.06);
    box-shadow: 0 6px 14px rgba(99, 102, 241, .55);
}
.clinic-logo-uploader__body {
    flex: 1;
    min-width: 0;
}
.clinic-logo-uploader__label {
    font-size: .82rem;
    font-weight: 700;
    color: var(--co-text);
    letter-spacing: -.01em;
}
.clinic-logo-uploader__hint {
    font-size: .72rem;
    color: var(--co-muted);
    margin-top: .15rem;
    margin-bottom: .65rem;
}
.clinic-logo-uploader__actions {
    display: flex;
    align-items: center;
    gap: .65rem;
    flex-wrap: wrap;
}
.clinic-logo-uploader__clear {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    font-size: .76rem;
    font-weight: 600;
    color: var(--co-muted);
    cursor: pointer;
    user-select: none;
    margin: 0;
}
.clinic-logo-uploader__clear input { accent-color: #ef4444; margin: 0; }
.clinic-logo-uploader__clear:has(input:checked) span { color: #ef4444; }
.clinic-logo-uploader__filename {
    max-width: 220px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.clinic-onboard-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 1.1rem 1.25rem;
}
.clinic-onboard-field { display: flex; flex-direction: column; min-width: 0; }
.clinic-onboard-field--full { grid-column: 1 / -1; }
.clinic-onboard-field--toggle {
    align-self: end;
    padding: .65rem .75rem;
    background: var(--co-accent-soft);
    border: 1px solid rgba(99, 102, 241, .18);
    border-radius: 12px;
}
.clinic-onboard-label {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    font-size: .76rem;
    font-weight: 700;
    color: var(--co-text);
    margin-bottom: .45rem;
    letter-spacing: -.005em;
}
.clinic-onboard-label i {
    color: var(--co-accent);
    opacity: .85;
    font-size: .85rem;
}
.clinic-onboard-form .form-control,
.clinic-onboard-form .form-select {
    height: 42px;
    padding: 0 .9rem;
    font-size: .88rem;
    border-radius: 11px;
    border: 1px solid var(--co-border-strong);
    background: #fff;
    color: var(--co-text);
    transition: border-color .15s ease, box-shadow .15s ease, background .15s ease;
}
.clinic-onboard-form .form-control:hover,
.clinic-onboard-form .form-select:hover { border-color: rgba(99, 102, 241, .28); }
.clinic-onboard-form .form-control:focus,
.clinic-onboard-form .form-select:focus {
    outline: none;
    border-color: var(--co-accent);
    box-shadow: 0 0 0 3px rgba(99, 102, 241, .15);
    background: #fff;
}
.clinic-onboard-form .form-control::placeholder { color: var(--co-muted); }
.clinic-onboard-help {
    font-size: .7rem;
    color: var(--co-muted);
    margin-top: .35rem;
    line-height: 1.4;
}
.clinic-onboard-error {
    font-size: .7rem;
    font-weight: 600;
    color: #b91c1c;
    margin-top: .35rem;
    display: inline-flex;
    align-items: center;
    gap: .3rem;
}
.clinic-onboard-error::before {
    content: "\F33A"; /* bi-exclamation-circle-fill */
    font-family: "bootstrap-icons";
    font-size: .8rem;
}

.clinic-onboard-actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: .75rem;
    padding: 1rem 1.5rem;
    background: #fff;
    border: 1px solid var(--co-border);
    border-radius: 16px;
    box-shadow: 0 1px 2px rgba(15, 23, 42, .04);
    position: sticky;
    bottom: 1rem;
    z-index: 5;
}

.clinic-onboard-status {
    background: linear-gradient(180deg, #fafbff, #f6f8ff);
    border: 1px solid rgba(99, 102, 241, .14);
    border-radius: 14px;
    padding: 1rem 1.15rem;
    display: flex;
    flex-direction: column;
    gap: .65rem;
}
.clinic-onboard-status__head {
    display: flex;
    align-items: center;
    gap: .75rem;
}
.clinic-onboard-status__icon {
    width: 34px;
    height: 34px;
    border-radius: 10px;
    background: var(--co-accent-soft);
    color: var(--co-accent);
    border: 1px solid rgba(99, 102, 241, .18);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: .9rem;
    flex-shrink: 0;
}
.clinic-onboard-status__title {
    font-size: .82rem;
    font-weight: 700;
    color: var(--co-text);
    margin: 0;
    letter-spacing: -.005em;
    line-height: 1.2;
}
.clinic-onboard-status__sub {
    font-size: .68rem;
    color: var(--co-muted);
    line-height: 1.4;
}

/* ════════════════════════════════════════════════════════════
   Clinic onboarding wizard — Bootstrap-Tab driven multi-step
   form with pill ribbon, tip-card guidance, and sticky submit
   bar. Mirrors the per-location wizard in location_form.html
   so Add / Edit Clinic and Add Location all feel identical.
   ──────────────────────────────────────────────────────────── */
.clinic-wizard {
    width: 100%;
    max-width: none;
}
.clinic-wizard-card {
    border-radius: 14px;
    overflow: hidden;
    width: 100%;
}
.clinic-wizard-card .tab-content { min-height: 220px; }

.clinic-wizard-head {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: .75rem;
    padding: 1rem 1.25rem .25rem;
}
.clinic-wizard-head__title {
    margin: 0;
    font-size: .98rem;
    font-weight: 700;
    color: var(--co-text);
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    letter-spacing: -.01em;
}
.clinic-wizard-head__title i { color: #6366f1; }
.clinic-wizard-head__chip {
    margin-left: auto;
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    padding: .25rem .65rem;
    background: rgba(99, 102, 241, .08);
    color: #4f46e5;
    border-radius: 50rem;
    font-size: .72rem;
    font-weight: 600;
    letter-spacing: .01em;
    line-height: 1.2;
}
.clinic-wizard-head__chip i { font-size: .82rem; line-height: 1; }
[data-bs-theme="dark"] .clinic-wizard-head__chip,
[data-theme="dark"] .clinic-wizard-head__chip {
    background: rgba(129, 140, 248, .14);
    color: #a5b4fc;
}

.clinic-wizard-progress {
    position: relative;
    height: 3px;
    background: rgba(15, 23, 42, .05);
    border-radius: 50rem;
    overflow: hidden;
    margin: .5rem 1.25rem 0;
}
.clinic-wizard-progress__fill {
    height: 100%;
    width: 0%;
    background: linear-gradient(90deg, #818cf8 0%, #6366f1 100%);
    border-radius: 50rem;
    transition: width .28s ease;
    opacity: .85;
}
[data-bs-theme="dark"] .clinic-wizard-progress,
[data-theme="dark"] .clinic-wizard-progress { background: rgba(255, 255, 255, .06); }
[data-bs-theme="dark"] .clinic-wizard-progress__fill,
[data-theme="dark"] .clinic-wizard-progress__fill {
    background: linear-gradient(90deg, #a5b4fc 0%, #818cf8 100%);
}

/* Pill-ribbon stepper. Class names mirror the location_form.html stepper
   so the same JS hook (bootstrap.Tab + .nav-substepper > .nav-link) works
   without modification. */
.clinic-wizard .nav-substepper {
    position: relative;
    display: flex;
    align-items: center;
    gap: .35rem;
    padding: .4rem 1rem .85rem;
    margin: 0;
    background: transparent;
    border: none;
    border-bottom: 1px solid rgba(15, 23, 42, .06);
    border-radius: 0;
    flex-wrap: nowrap;
    overflow-x: auto;
    scroll-snap-type: x proximity;
    scrollbar-width: thin;
    list-style: none;
}
.clinic-wizard .nav-substepper::-webkit-scrollbar { height: 4px; }
.clinic-wizard .nav-substepper::-webkit-scrollbar-thumb { background: rgba(15, 23, 42, .12); border-radius: 4px; }
.clinic-wizard .nav-substepper::-webkit-scrollbar-track { background: transparent; }
.clinic-wizard .nav-substepper .nav-item { flex-shrink: 0; scroll-snap-align: start; }
.clinic-wizard .nav-substepper .nav-link {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    padding: .5rem 1rem;
    border: none;
    background: transparent;
    border-radius: 50rem;
    color: #64748b;
    font-weight: 600;
    font-size: .82rem;
    line-height: 1.2;
    white-space: nowrap;
    transition: all 180ms ease;
}
.clinic-wizard .nav-substepper .nav-link i.bi {
    font-size: 1rem;
    line-height: 1;
    color: #94a3b8;
    transition: color 180ms ease;
}
.clinic-wizard .nav-substepper .nav-link:hover {
    color: #334155;
    background: rgba(15, 23, 42, .035);
}
.clinic-wizard .nav-substepper .nav-link:hover i.bi { color: #334155; }
.clinic-wizard .nav-substepper .nav-link.active {
    color: #4f46e5;
    background: rgba(99, 102, 241, .10);
    box-shadow: inset 0 0 0 1px rgba(99, 102, 241, .20);
}
.clinic-wizard .nav-substepper .nav-link.active i.bi { color: #4f46e5; }
.clinic-wizard .nav-substepper .nav-link.is-completed {
    color: #059669;
    background: rgba(16, 185, 129, .08);
}
.clinic-wizard .nav-substepper .nav-link.is-completed i.bi { color: #059669; }

.clinic-wizard .sub-num {
    width: 22px;
    height: 22px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: rgba(15, 23, 42, .06);
    color: #64748b;
    font-size: .7rem;
    font-weight: 700;
    line-height: 1;
    transition: all 180ms ease;
}
.clinic-wizard .nav-substepper .nav-link.active .sub-num {
    background: #6366f1;
    color: #fff;
    box-shadow: 0 2px 6px rgba(99, 102, 241, .25);
}
.clinic-wizard .nav-substepper .nav-link.is-completed .sub-num {
    background: #10b981;
    color: #fff;
    font-size: 0;
    box-shadow: none;
    position: relative;
}
.clinic-wizard .nav-substepper .nav-link.is-completed .sub-num::before {
    content: "\2713";
    font-size: .78rem;
    font-weight: 700;
    line-height: 1;
}
.clinic-wizard .sub-label { display: inline-block; }
@media (max-width: 575.98px) {
    .clinic-wizard .nav-substepper .nav-link { padding: .45rem .65rem; gap: .35rem; }
    .clinic-wizard .sub-label { display: none; }
}

/* Tab-pane spacing inside the wizard card — keep the existing
   .clinic-onboard-grid / .clinic-onboard-field layout intact. */
.clinic-wizard .tab-content { padding: 1.25rem 1.5rem 1.5rem; }
.clinic-wizard .tab-pane { display: none; }
.clinic-wizard .tab-pane.active { display: block; }

/* Sticky form-submit bar — same shape as location_form.html. */
.clinic-wizard-submit {
    position: sticky;
    bottom: 1rem;
    z-index: 5;
    margin-top: 1rem;
    padding: .85rem 1.25rem;
    background: #fff;
    border: 1px solid var(--co-border);
    border-radius: 16px;
    box-shadow: 0 1px 2px rgba(15, 23, 42, .04), 0 -4px 18px rgba(15, 23, 42, .04);
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: .75rem;
    justify-content: space-between;
}
.clinic-wizard-submit__progress {
    flex: 1 1 200px;
    text-align: center;
    font-size: .76rem;
    color: #64748b;
}
.clinic-wizard-submit__progress strong { color: #334155; font-weight: 600; }
.clinic-wizard-submit__progress .step-name { color: #4f46e5; font-weight: 600; }
[data-bs-theme="dark"] .clinic-wizard-submit,
[data-theme="dark"] .clinic-wizard-submit {
    background: rgba(15, 17, 21, .85);
    border-color: rgba(255, 255, 255, .06);
    box-shadow: 0 -4px 18px rgba(0, 0, 0, .25);
}

/* Guidance & Tips — slim one-line card; expands to a compact step list. */
.clinic-wizard-tips {
    margin-top: .85rem;
    border: 1px solid rgba(15, 23, 42, .07);
    border-radius: 12px;
    background: #fff;
    overflow: hidden;
    transition: border-color .18s ease, box-shadow .18s ease;
}
.clinic-wizard-tips:hover { border-color: rgba(99, 102, 241, .25); }
.clinic-wizard-tips__head {
    width: 100%;
    display: flex;
    align-items: center;
    gap: .55rem;
    padding: .55rem .85rem;
    background: transparent;
    border: 0;
    cursor: pointer;
    text-align: left;
    color: var(--co-text);
    font-size: .78rem;
    font-weight: 600;
}
.clinic-wizard-tips__head:hover { background: rgba(99, 102, 241, .04); }
.clinic-wizard-tips__icon {
    width: 22px;
    height: 22px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 7px;
    background: rgba(99, 102, 241, .10);
    color: #4f46e5;
    font-size: .78rem;
    flex-shrink: 0;
}
.clinic-wizard-tips__title { letter-spacing: -.005em; }
.clinic-wizard-tips__meta {
    margin-left: .35rem;
    color: #94a3b8;
    font-size: .7rem;
    font-weight: 500;
    letter-spacing: .015em;
}
.clinic-wizard-tips__chevron {
    margin-left: auto;
    color: #94a3b8;
    font-size: .8rem;
    transition: transform .18s ease;
}
.clinic-wizard-tips:not(.collapsed) .clinic-wizard-tips__chevron { transform: rotate(180deg); }
.clinic-wizard-tips__body {
    max-height: 240px;
    overflow: hidden;
    padding: .25rem .85rem .75rem;
    transition: max-height .25s ease, padding .2s ease, opacity .2s ease;
    opacity: 1;
    border-top: 1px dashed rgba(15, 23, 42, .07);
}
.clinic-wizard-tips.collapsed .clinic-wizard-tips__body {
    max-height: 0;
    padding-top: 0;
    padding-bottom: 0;
    opacity: 0;
    border-top-color: transparent;
}
.clinic-wizard-tips__list {
    list-style: none;
    margin: .35rem 0 .25rem;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: .25rem .85rem;
}
.clinic-wizard-tips__list li {
    display: flex;
    align-items: center;
    gap: .5rem;
    font-size: .74rem;
    color: #64748b;
    line-height: 1.35;
}
.clinic-wizard-tips__list li strong {
    color: var(--co-text);
    font-weight: 600;
}
.clinic-wizard-tips__list .bullet {
    width: 18px;
    height: 18px;
    border-radius: 6px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: .65rem;
    font-weight: 700;
    flex-shrink: 0;
}
.clinic-wizard-tips__list .bullet--primary { background: rgba(99, 102, 241, .10); color: #4f46e5; }
.clinic-wizard-tips__quick {
    margin-top: .4rem;
    padding: .4rem .55rem;
    border-radius: 8px;
    background: rgba(240, 180, 0, .08);
    color: #92651a;
    font-size: .72rem;
    display: inline-flex;
    align-items: center;
    gap: .4rem;
}
.clinic-wizard-tips__quick i { font-size: .8rem; color: #c79100; }

[data-bs-theme="dark"] .clinic-wizard-tips,
[data-theme="dark"] .clinic-wizard-tips {
    background: var(--surface-2, #1a1d23);
    border-color: rgba(255, 255, 255, .06);
}
[data-bs-theme="dark"] .clinic-wizard-tips__head,
[data-theme="dark"] .clinic-wizard-tips__head { color: #cbd5e1; }
[data-bs-theme="dark"] .clinic-wizard-tips__list li,
[data-theme="dark"] .clinic-wizard-tips__list li { color: #94a3b8; }
[data-bs-theme="dark"] .clinic-wizard-tips__list li strong,
[data-theme="dark"] .clinic-wizard-tips__list li strong { color: #e2e8f0; }
[data-bs-theme="dark"] .clinic-wizard-tips__quick,
[data-theme="dark"] .clinic-wizard-tips__quick {
    background: rgba(240, 180, 0, .12);
    color: #f6c560;
}

/* Legacy section nav (anchor scroll) — kept for backward compat
   but no longer rendered by the wizard templates. */
.clinic-onboard-nav {
    position: sticky;
    top: .75rem;
    z-index: 6;
    display: flex;
    gap: .5rem;
    padding: .5rem;
    margin-bottom: 1.25rem;
    background: rgba(255, 255, 255, .85);
    -webkit-backdrop-filter: saturate(140%) blur(10px);
    backdrop-filter: saturate(140%) blur(10px);
    border: 1px solid var(--co-border);
    border-radius: 18px;
    box-shadow: 0 6px 18px -10px rgba(15, 23, 42, .12);
    overflow-x: auto;
    scrollbar-width: thin;
}
.clinic-onboard-nav__chip {
    flex: 1 1 0;
    min-width: 0;
    display: inline-flex;
    align-items: center;
    gap: .65rem;
    padding: .55rem .85rem;
    border-radius: 14px;
    text-decoration: none;
    color: var(--co-muted);
    border: 1px solid transparent;
    transition: background .15s ease, color .15s ease, border-color .15s ease, box-shadow .15s ease;
    white-space: nowrap;
}
.clinic-onboard-nav__chip:hover {
    color: var(--co-text);
    background: rgba(99, 102, 241, .06);
}
.clinic-onboard-nav__chip.is-active {
    color: var(--co-text);
    background: linear-gradient(135deg, rgba(99, 102, 241, .14), rgba(139, 92, 246, .08));
    border-color: rgba(99, 102, 241, .28);
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, .6);
}
.clinic-onboard-nav__step {
    flex-shrink: 0;
    width: 26px;
    height: 26px;
    border-radius: 9px;
    background: rgba(99, 102, 241, .12);
    color: var(--co-accent);
    font-size: .72rem;
    font-weight: 800;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    letter-spacing: -.01em;
}
.clinic-onboard-nav__chip.is-active .clinic-onboard-nav__step {
    background: var(--co-accent);
    color: #fff;
    box-shadow: 0 4px 12px -4px rgba(99, 102, 241, .55);
}
.clinic-onboard-nav__icon {
    color: var(--co-accent);
    font-size: 1rem;
    flex-shrink: 0;
}
.clinic-onboard-nav__body {
    display: flex;
    flex-direction: column;
    min-width: 0;
    line-height: 1.15;
}
.clinic-onboard-nav__label {
    font-size: .8rem;
    font-weight: 700;
    color: inherit;
    letter-spacing: -.005em;
}
.clinic-onboard-nav__sub {
    font-size: .68rem;
    font-weight: 500;
    color: var(--co-muted);
    margin-top: .1rem;
}

/* ── Card head pill (subscription summary, etc.) ── */
.clinic-onboard-card__head {
    flex-wrap: wrap;
}
.clinic-onboard-card__head-pill {
    margin-left: auto;
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    padding: .3rem .7rem;
    border-radius: 999px;
    font-size: .7rem;
    font-weight: 700;
    color: var(--co-accent);
    background: var(--co-accent-soft);
    border: 1px solid rgba(99, 102, 241, .22);
    letter-spacing: -.005em;
}
.clinic-onboard-card__head-icon--accent {
    background: linear-gradient(135deg, rgba(99, 102, 241, .18), rgba(139, 92, 246, .14));
    color: #6366f1;
    border-color: rgba(99, 102, 241, .3);
}

/* ── Date-range groupings inside subscription section ── */
.clinic-onboard-daterange {
    border: 1px dashed rgba(99, 102, 241, .28);
    border-radius: 16px;
    padding: 1rem 1.15rem;
    background: linear-gradient(180deg, rgba(99, 102, 241, .04), rgba(139, 92, 246, .02));
    display: flex;
    flex-direction: column;
    gap: .85rem;
    transition: opacity .2s ease, filter .2s ease;
}
.clinic-onboard-daterange--accent {
    border-style: solid;
    border-color: rgba(34, 197, 94, .25);
    background: linear-gradient(180deg, rgba(34, 197, 94, .05), rgba(16, 185, 129, .03));
}
.clinic-onboard-daterange.is-muted {
    opacity: .55;
    filter: saturate(.6);
}
.clinic-onboard-daterange__head {
    display: flex;
    align-items: center;
    gap: .75rem;
}
.clinic-onboard-daterange__icon {
    width: 36px;
    height: 36px;
    border-radius: 11px;
    background: var(--co-accent-soft);
    color: var(--co-accent);
    border: 1px solid rgba(99, 102, 241, .2);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: .95rem;
    flex-shrink: 0;
}
.clinic-onboard-daterange--accent .clinic-onboard-daterange__icon {
    background: rgba(34, 197, 94, .12);
    color: #15803d;
    border-color: rgba(34, 197, 94, .28);
}
.clinic-onboard-daterange__title {
    font-size: .85rem;
    font-weight: 700;
    color: var(--co-text);
    margin: 0;
    letter-spacing: -.005em;
    line-height: 1.2;
}
.clinic-onboard-daterange__sub {
    font-size: .7rem;
    color: var(--co-muted);
    line-height: 1.4;
}

@media (max-width: 540px) {
    .clinic-onboard-hero,
    .clinic-onboard-card { padding: 1.25rem; }
    .clinic-onboard-actions { flex-direction: column; align-items: stretch; }
    .clinic-onboard-actions a,
    .clinic-onboard-actions button { width: 100%; justify-content: center; }
    .clinic-onboard-nav { gap: .35rem; padding: .35rem; }
    .clinic-onboard-nav__chip { padding: .45rem .6rem; }
    .clinic-onboard-nav__sub { display: none; }
    .clinic-onboard-card__head-pill { margin-left: 0; order: 3; }
    .clinic-onboard-daterange { padding: .85rem; }
}

/* ────────────────────────────────────────────────────────────
   Location directory table — clickable rows + sync pill stack
   ──────────────────────────────────────────────────────────── */
.location-directory-table .location-row {
    cursor: pointer;
    transition: background .15s ease;
}
.location-directory-table .location-row:hover {
    background: rgba(99, 102, 241, .04);
}
.location-directory-table .location-row:focus-visible {
    outline: 2px solid rgba(99, 102, 241, .55);
    outline-offset: -2px;
}
.location-directory-table .location-row td {
    position: relative;
}
.location-directory-table .stretched-link::after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 1;
    pointer-events: auto;
}

/* ── Sync source pill stack (shared by table cell + detail page) ──
   Single horizontal row by default — pills wrap onto a second line on
   narrow viewports. Each pill is a soft, lightweight tag: icon + short
   status text. The pill's color band carries the meaning; the icon
   carries the channel identity. */
.loc-sync-stack {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: .35rem;
    min-width: 0;
}

.loc-sync-pill {
    --pill-color: #64748b;
    --pill-bg: rgba(100, 116, 139, .07);
    --pill-edge: rgba(100, 116, 139, .14);
    --pill-icon-bg: rgba(100, 116, 139, .14);
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    padding: .2rem .55rem .2rem .25rem;
    border-radius: 999px;
    font-size: .7rem;
    font-weight: 600;
    color: var(--pill-color);
    background: var(--pill-bg);
    border: 1px solid var(--pill-edge);
    line-height: 1.4;
    white-space: nowrap;
    position: relative;
    z-index: 2;
    transition: background .15s ease, border-color .15s ease, transform .15s ease;
}
.loc-sync-pill:hover {
    transform: translateY(-1px);
    border-color: color-mix(in srgb, var(--pill-color) 30%, transparent);
}
.loc-sync-pill > i {
    width: 22px;
    height: 22px;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--pill-icon-bg);
    color: var(--pill-color);
    font-size: .72rem;
    flex-shrink: 0;
}
.loc-sync-pill__label {
    font-weight: 700;
    color: var(--pill-color);
    letter-spacing: .005em;
}
.loc-sync-pill__value {
    font-weight: 500;
    color: rgba(15, 23, 42, .65);
    margin-left: .15rem;
}
.loc-sync-pill--ok      { --pill-color: #047857; --pill-bg: rgba(16,185,129,.08);  --pill-edge: rgba(16,185,129,.20);  --pill-icon-bg: rgba(16,185,129,.16);  }
.loc-sync-pill--warn    { --pill-color: #b45309; --pill-bg: rgba(245,158,11,.08); --pill-edge: rgba(245,158,11,.22); --pill-icon-bg: rgba(245,158,11,.18); }
.loc-sync-pill--wait    { --pill-color: #1d4ed8; --pill-bg: rgba(59,130,246,.07); --pill-edge: rgba(59,130,246,.20); --pill-icon-bg: rgba(59,130,246,.16); }
.loc-sync-pill--danger  { --pill-color: #b91c1c; --pill-bg: rgba(239,68,68,.07);  --pill-edge: rgba(239,68,68,.22);  --pill-icon-bg: rgba(239,68,68,.16);  }
.loc-sync-pill--muted   { --pill-color: #64748b; --pill-bg: rgba(100,116,139,.05); --pill-edge: rgba(100,116,139,.16); --pill-icon-bg: rgba(100,116,139,.12); }

/* Compact variant — used inside table cells. Hides the channel label
   and the value; the icon + tone carry meaning, full text is in title. */
.loc-sync-stack.is-compact { gap: .3rem; }
.loc-sync-stack.is-compact .loc-sync-pill {
    padding: 0;
    background: transparent;
    border: none;
}
.loc-sync-stack.is-compact .loc-sync-pill > i {
    width: 26px;
    height: 26px;
    font-size: .8rem;
    border: 1px solid var(--pill-edge);
}
.loc-sync-stack.is-compact .loc-sync-pill__label,
.loc-sync-stack.is-compact .loc-sync-pill__value { display: none; }

/* ────────────────────────────────────────────────────────────
   Location detail page — setup progress card
   ──────────────────────────────────────────────────────────── */
.loc-setup-card {
    position: relative;
    padding: 1.4rem 1.5rem 1.25rem;
    background: linear-gradient(180deg, #fbfbff, #fff);
    border: 1px solid var(--hub-border, #eef0f3);
    border-radius: 18px;
    box-shadow: 0 1px 2px rgba(15, 23, 42, .04);
    overflow: hidden;
    isolation: isolate;
    display: flex;
    flex-direction: column;
    gap: 1rem;
}
.loc-setup-card::before {
    content: "";
    position: absolute;
    inset: -55% 8% auto 8%;
    height: 200px;
    background: radial-gradient(closest-side, rgba(99, 102, 241, .08), transparent 70%);
    pointer-events: none;
    z-index: -1;
}
.loc-setup-card[data-percent="100"]::before {
    background: radial-gradient(closest-side, rgba(16, 185, 129, .10), transparent 70%);
}
.loc-setup-card__head {
    display: flex;
    align-items: center;
    gap: 1.1rem;
}
.loc-setup-card__ring-wrap {
    position: relative;
    width: 88px;
    height: 88px;
    flex-shrink: 0;
    filter: drop-shadow(0 6px 14px rgba(99, 102, 241, .08));
}
.loc-setup-ring { width: 100%; height: 100%; transform: rotate(-90deg); }
.loc-setup-ring circle { fill: none; stroke-width: 8; stroke-linecap: round; }
.loc-setup-ring__track { stroke: var(--hub-border, #eef0f3); }
.loc-setup-ring__fill {
    stroke: #6366f1;
    transition: stroke-dasharray .9s cubic-bezier(.22, 1, .36, 1);
}
.loc-setup-card[data-percent="100"] .loc-setup-ring__fill { stroke: #10b981; }
.loc-setup-ring__label {
    position: absolute;
    inset: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    line-height: 1;
}
.loc-setup-ring__pct {
    font-size: 1.3rem;
    font-weight: 800;
    color: var(--hub-text, #0f172a);
    letter-spacing: -.028em;
    font-variant-numeric: tabular-nums;
}
.loc-setup-ring__pct span {
    font-size: .65rem;
    color: var(--hub-text-muted, #94a3b8);
    font-weight: 600;
    margin-left: 1px;
}
.loc-setup-ring__sub {
    margin-top: .2rem;
    font-size: .56rem;
    font-weight: 700;
    color: var(--hub-text-muted, #94a3b8);
    text-transform: uppercase;
    letter-spacing: .07em;
}
.loc-setup-card__head-body { min-width: 0; }
.loc-setup-card__eyebrow {
    font-size: .62rem;
    font-weight: 800;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: #6366f1;
    display: block;
    margin-bottom: .25rem;
}
.loc-setup-card[data-percent="100"] .loc-setup-card__eyebrow { color: #047857; }
.loc-setup-card__title {
    font-size: 1.05rem;
    font-weight: 700;
    color: var(--hub-text, #0f172a);
    margin: 0;
    letter-spacing: -.018em;
    line-height: 1.2;
}
.loc-setup-card__sub {
    font-size: .8rem;
    color: var(--hub-text-sub, #64748b);
    margin: .35rem 0 0;
    line-height: 1.5;
}
.loc-setup-card__error {
    display: flex;
    align-items: flex-start;
    gap: .55rem;
    padding: .65rem .85rem;
    background: rgba(239, 68, 68, .08);
    border: 1px solid rgba(239, 68, 68, .22);
    border-radius: 12px;
    font-size: .76rem;
    color: #b91c1c;
}
.loc-setup-card__error i { font-size: .9rem; flex-shrink: 0; margin-top: 1px; }

/* ────────────────────────────────────────────────────────────
   Embedded mode — when .loc-setup-card lives inside another
   card (location detail hero), strip its own chrome so it reads
   as an integrated strip rather than a nested card.
   ──────────────────────────────────────────────────────────── */
.loc-setup-card--embedded {
    padding: .25rem 0 0;
    background: transparent;
    border: 0;
    border-radius: 0;
    box-shadow: none;
}
.loc-setup-card--embedded::before,
.loc-setup-card--embedded[data-percent="100"]::before {
    content: none;
}
.loc-setup-card--embedded .loc-setup-card__head { gap: 1rem; }
.loc-setup-card--embedded .loc-setup-card__ring-wrap { width: 76px; height: 76px; }
.loc-setup-card--embedded .loc-setup-ring__pct { font-size: 1.15rem; }
.loc-setup-card--embedded .loc-setup-card__title { font-size: .95rem; }
.loc-setup-card--embedded .loc-setup-card__sub { font-size: .78rem; margin-top: .25rem; }

@media (max-width: 575.98px) {
    .loc-setup-card--embedded .loc-setup-card__head { flex-wrap: wrap; }
}

/* ════════════════════════════════════════════════════════════
   Clinic self-edit form — 2027-modern surface used by
   templates/clinic/self_form.html only. Scoped via .clinic-self
   so the older .clinic-onboard-* and .clinic-wizard-* surfaces
   stay untouched.
   ──────────────────────────────────────────────────────────── */
.clinic-self {
    --cs-text: #0b1220;
    --cs-sub: #4f5b75;
    --cs-muted: #94a0b8;
    --cs-line: rgba(15, 23, 42, .07);
    --cs-line-strong: rgba(15, 23, 42, .12);
    --cs-bg: rgba(255, 255, 255, .82);
    --cs-bg-solid: #fff;
    --cs-accent: #6366f1;
    --cs-accent-2: #8b5cf6;
    --cs-accent-3: #06b6d4;
    --cs-soft: rgba(99, 102, 241, .08);
    --cs-soft-strong: rgba(99, 102, 241, .15);
    --cs-success: #10b981;
    --cs-danger: #ef4444;
    --cs-radius: 22px;
    --cs-radius-sm: 14px;
    --cs-shadow-card: 0 1px 2px rgba(15, 23, 42, .04), 0 24px 60px -32px rgba(99, 102, 241, .25);
    --cs-shadow-dock: 0 -10px 30px -18px rgba(15, 23, 42, .25), 0 1px 2px rgba(15, 23, 42, .05);
    position: relative;
    max-width: 1280px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.clinic-self-shell {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: minmax(260px, 320px) minmax(0, 1fr);
    gap: 1.1rem;
    align-items: start;
}
@media (max-width: 960px) {
    .clinic-self-shell { grid-template-columns: 1fr; }
}

/* Animated mesh-orb hero backdrop — sits behind the card to give the
   page a soft, modern atmosphere without a hero-strip taking real estate. */
.clinic-self-hero {
    position: absolute;
    inset: -40px -20px auto -20px;
    height: 320px;
    pointer-events: none;
    z-index: 0;
    overflow: hidden;
    border-radius: 32px;
}
.clinic-self-hero__orb {
    position: absolute;
    border-radius: 50%;
    filter: blur(60px);
    opacity: .55;
    animation: csOrbFloat 18s ease-in-out infinite;
}
.clinic-self-hero__orb--a { top: -80px; left: 8%; width: 260px; height: 260px; background: radial-gradient(closest-side, var(--cs-accent), transparent 70%); }
.clinic-self-hero__orb--b { top: -60px; right: 6%; width: 220px; height: 220px; background: radial-gradient(closest-side, var(--cs-accent-2), transparent 70%); animation-delay: -6s; opacity: .45; }
.clinic-self-hero__orb--c { top: 40px; left: 42%; width: 180px; height: 180px; background: radial-gradient(closest-side, var(--cs-accent-3), transparent 70%); animation-delay: -12s; opacity: .35; }
@keyframes csOrbFloat {
    0%, 100% { transform: translate3d(0, 0, 0) scale(1); }
    50% { transform: translate3d(20px, 18px, 0) scale(1.06); }
}
@media (prefers-reduced-motion: reduce) {
    .clinic-self-hero__orb { animation: none; }
}

.clinic-self-card {
    position: relative;
    z-index: 1;
    background: var(--cs-bg);
    -webkit-backdrop-filter: saturate(160%) blur(18px);
    backdrop-filter: saturate(160%) blur(18px);
    border: 1px solid rgba(255, 255, 255, .65);
    border-radius: var(--cs-radius);
    box-shadow: var(--cs-shadow-card);
    overflow: hidden;
}

/* Header — eyebrow, title, sub, status chip, gradient progress hairline. */
.clinic-self-head {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 1rem 1.25rem;
    align-items: center;
    padding: 1.25rem 1.5rem .9rem;
}
.clinic-self-head__lead { display: flex; align-items: center; gap: .9rem; min-width: 0; }
.clinic-self-head__icon {
    flex-shrink: 0;
    width: 46px;
    height: 46px;
    border-radius: 14px;
    color: #fff;
    background: linear-gradient(135deg, var(--cs-accent), var(--cs-accent-2));
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.2rem;
    box-shadow: 0 12px 26px -12px rgba(99, 102, 241, .55), inset 0 0 0 1px rgba(255, 255, 255, .35);
}
.clinic-self-head__text { min-width: 0; }
.clinic-self-head__eyebrow {
    display: block;
    font-size: .6rem;
    font-weight: 800;
    letter-spacing: .18em;
    text-transform: uppercase;
    color: var(--cs-accent);
    margin-bottom: .15rem;
}
.clinic-self-head__title {
    margin: 0 0 .15rem;
    font-size: 1.18rem;
    font-weight: 750;
    color: var(--cs-text);
    letter-spacing: -.02em;
    line-height: 1.2;
}
.clinic-self-head__sub {
    margin: 0;
    font-size: .78rem;
    color: var(--cs-sub);
    line-height: 1.45;
    max-width: 60ch;
}
.clinic-self-head__chip {
    display: inline-flex;
    align-items: center;
    gap: .45rem;
    padding: .35rem .75rem;
    background: rgba(255, 255, 255, .8);
    border: 1px solid var(--cs-line);
    color: var(--cs-text);
    border-radius: 50rem;
    font-size: .72rem;
    font-weight: 600;
    letter-spacing: .005em;
    line-height: 1.2;
    box-shadow: 0 1px 2px rgba(15, 23, 42, .04);
}
.clinic-self-head__dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--cs-accent);
    box-shadow: 0 0 0 3px rgba(99, 102, 241, .18);
    flex-shrink: 0;
}
.clinic-self-progress {
    grid-column: 1 / -1;
    height: 4px;
    margin: .25rem 0 0;
    background: rgba(15, 23, 42, .06);
    border-radius: 50rem;
    overflow: hidden;
}
.clinic-self-progress .clinic-wizard-progress__fill {
    background: linear-gradient(90deg, var(--cs-accent) 0%, var(--cs-accent-2) 50%, var(--cs-accent-3) 100%);
    opacity: 1;
}

/* Step rail — extend nav-substepper with a frosted treatment + count badges. */
.clinic-self .clinic-self-rail.nav-substepper {
    padding: .5rem .75rem .85rem;
    margin: 0 1rem;
    background: rgba(248, 249, 255, .65);
    border: 1px solid var(--cs-line);
    border-radius: var(--cs-radius-sm);
}
.clinic-self .clinic-self-rail .nav-link {
    padding: .55rem 1rem;
    color: var(--cs-sub);
    font-weight: 600;
    font-size: .8rem;
    letter-spacing: -.005em;
}
.clinic-self .clinic-self-rail .nav-link:hover { background: rgba(99, 102, 241, .07); color: var(--cs-text); }
.clinic-self .clinic-self-rail .nav-link.active {
    color: #fff;
    background: linear-gradient(135deg, var(--cs-accent), var(--cs-accent-2));
    box-shadow: 0 8px 18px -10px rgba(99, 102, 241, .55), inset 0 0 0 1px rgba(255, 255, 255, .25);
}
.clinic-self .clinic-self-rail .nav-link.active i.bi { color: #fff; }
.clinic-self .clinic-self-rail .nav-link.active .sub-num {
    background: rgba(255, 255, 255, .25);
    color: #fff;
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, .35);
}
.clinic-self .clinic-self-rail .nav-link.is-completed {
    color: var(--cs-success);
    background: rgba(16, 185, 129, .08);
}
.clinic-self .clinic-self-rail .nav-link.is-completed i.bi { color: var(--cs-success); }

/* Body */
.clinic-self-body { padding: 1.4rem 1.5rem 1.5rem; min-height: 280px; }

/* Section heading inside a tab pane (Contact / EHR Sync). */
.clinic-self-section {
    display: flex;
    align-items: flex-start;
    gap: .85rem;
    margin-bottom: 1.1rem;
}
.clinic-self-section__icon {
    flex-shrink: 0;
    width: 38px;
    height: 38px;
    border-radius: 12px;
    background: var(--cs-soft);
    color: var(--cs-accent);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
    border: 1px solid rgba(99, 102, 241, .18);
}
.clinic-self-section__title {
    margin: 0;
    font-size: .92rem;
    font-weight: 700;
    color: var(--cs-text);
    letter-spacing: -.01em;
}
.clinic-self-section__sub {
    display: block;
    margin-top: .15rem;
    font-size: .75rem;
    color: var(--cs-sub);
    line-height: 1.45;
    max-width: 70ch;
}

/* Field grid */
.clinic-self-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 1rem 1.15rem;
}

/* Floating-label field — the visual hero of this redesign. */
.clinic-self-field {
    position: relative;
    display: block;
    background: #fff;
    border: 1px solid var(--cs-line-strong);
    border-radius: var(--cs-radius-sm);
    padding: 1.45rem .9rem .55rem 2.65rem;
    transition: border-color .18s ease, box-shadow .18s ease, background .18s ease;
    cursor: text;
    min-width: 0;
}
.clinic-self-field--full { grid-column: 1 / -1; }
.clinic-self-field:hover { border-color: rgba(99, 102, 241, .35); }
.clinic-self-field:focus-within {
    border-color: var(--cs-accent);
    box-shadow: 0 0 0 4px rgba(99, 102, 241, .14);
    background: #fff;
}
.clinic-self-field.is-invalid {
    border-color: var(--cs-danger);
    box-shadow: 0 0 0 4px rgba(239, 68, 68, .12);
}
.clinic-self-field__icon {
    position: absolute;
    left: .85rem;
    top: 50%;
    transform: translateY(-50%);
    width: 26px;
    height: 26px;
    border-radius: 8px;
    background: var(--cs-soft);
    color: var(--cs-accent);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: .82rem;
    transition: background .18s ease, color .18s ease;
    pointer-events: none;
}
.clinic-self-field:focus-within .clinic-self-field__icon {
    background: linear-gradient(135deg, var(--cs-accent), var(--cs-accent-2));
    color: #fff;
}
.clinic-self-field__label {
    position: absolute;
    left: 2.65rem;
    top: 50%;
    transform: translateY(-50%);
    font-size: .85rem;
    color: var(--cs-muted);
    font-weight: 500;
    letter-spacing: -.005em;
    pointer-events: none;
    transition: top .18s ease, transform .18s ease, font-size .18s ease, color .18s ease, left .18s ease;
}
.clinic-self-field__req { color: var(--cs-danger); font-style: normal; font-weight: 700; }
.clinic-self-field:focus-within .clinic-self-field__label,
.clinic-self-field.has-value .clinic-self-field__label,
.clinic-self-field.is-invalid .clinic-self-field__label {
    top: .55rem;
    transform: translateY(0);
    font-size: .65rem;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: var(--cs-accent);
    left: 2.65rem;
}
.clinic-self-field.is-invalid .clinic-self-field__label { color: var(--cs-danger); }
.clinic-self-field__lock {
    margin-left: .35rem;
    font-style: normal;
    font-size: .55rem;
    font-weight: 800;
    letter-spacing: .12em;
    text-transform: uppercase;
    padding: .1rem .35rem;
    border-radius: 50rem;
    background: rgba(15, 23, 42, .07);
    color: var(--cs-sub);
}
.clinic-self-field__help {
    display: block;
    margin: .4rem 0 0 -1.75rem;
    font-size: .7rem;
    color: var(--cs-muted);
    line-height: 1.4;
}
/* Inputs reset inside the floating wrapper. */
.clinic-self-field input.form-control,
.clinic-self-field select.form-select,
.clinic-self-field textarea.form-control,
.clinic-self-field input[type="text"],
.clinic-self-field input[type="email"],
.clinic-self-field input[type="url"],
.clinic-self-field input[type="tel"] {
    width: 100%;
    height: auto;
    padding: 0;
    border: none;
    background: transparent;
    box-shadow: none;
    outline: none;
    font-size: .92rem;
    color: var(--cs-text);
    letter-spacing: -.005em;
}
.clinic-self-field input::placeholder,
.clinic-self-field textarea::placeholder { color: transparent; }
.clinic-self-field--locked { background: linear-gradient(180deg, #f8fafc, #f1f4f9); }
.clinic-self-field--locked input.form-control { color: var(--cs-sub); -webkit-text-fill-color: var(--cs-sub); opacity: 1; }
.clinic-self-field select.form-select { appearance: none; -webkit-appearance: none; background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 16 16' fill='%2394a0b8'><path d='M3.204 5.5L8 10.296 12.796 5.5H3.204z'/></svg>"); background-repeat: no-repeat; background-position: right .25rem center; padding-right: 1.5rem; }

/* Custom static-label variant for the language picker (no input behind it). */
.clinic-self-field--lang { padding: .9rem 1rem 1rem; }
.clinic-self-field__static-label {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    font-size: .65rem;
    font-weight: 800;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--cs-accent);
    margin-bottom: .55rem;
}
.clinic-self-field__static-label i { font-size: .85rem; opacity: .9; }

/* Language segmented control */
.clinic-self-lang {
    display: flex;
    gap: .35rem;
    padding: .25rem;
    background: var(--cs-soft);
    border-radius: 12px;
    border: 1px solid rgba(99, 102, 241, .18);
}
.clinic-self-lang__opt {
    flex: 1;
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: .15rem;
    padding: .45rem .55rem;
    background: transparent;
    border: 0;
    border-radius: 9px;
    color: var(--cs-sub);
    font-weight: 600;
    transition: background .18s ease, color .18s ease, transform .18s ease, box-shadow .18s ease;
    cursor: pointer;
}
.clinic-self-lang__opt:hover { background: rgba(255, 255, 255, .65); color: var(--cs-text); }
.clinic-self-lang__opt.is-active {
    background: #fff;
    color: var(--cs-accent);
    box-shadow: 0 4px 10px -4px rgba(99, 102, 241, .35), inset 0 0 0 1px rgba(99, 102, 241, .25);
}
.clinic-self-lang__flag {
    font-size: .65rem;
    font-weight: 800;
    letter-spacing: .05em;
    padding: .12rem .35rem;
    border-radius: 6px;
    background: rgba(99, 102, 241, .12);
    color: var(--cs-accent);
}
.clinic-self-lang__opt.is-active .clinic-self-lang__flag {
    background: linear-gradient(135deg, var(--cs-accent), var(--cs-accent-2));
    color: #fff;
}
.clinic-self-lang__name { font-size: .72rem; }
.clinic-self-lang__custom { margin-top: .55rem; }
.clinic-self-lang__custom input.form-control {
    height: 38px;
    border-radius: 10px;
    border: 1px dashed var(--cs-line-strong);
    padding: 0 .75rem;
    font-size: .85rem;
}

/* Big iOS-style switch row */
.clinic-self-toggle {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1rem 1.15rem;
    background: linear-gradient(135deg, rgba(99, 102, 241, .08), rgba(139, 92, 246, .05));
    border: 1px solid rgba(99, 102, 241, .18);
    border-radius: var(--cs-radius-sm);
    margin-bottom: 1rem;
}
.clinic-self-toggle__copy { flex: 1; min-width: 0; }
.clinic-self-toggle__title {
    display: block;
    font-weight: 700;
    color: var(--cs-text);
    font-size: .88rem;
    letter-spacing: -.01em;
}
.clinic-self-toggle__sub {
    display: block;
    margin-top: .2rem;
    font-size: .72rem;
    color: var(--cs-sub);
    line-height: 1.45;
}
.clinic-self-toggle__switch .form-check-input {
    width: 3rem;
    height: 1.6rem;
    margin: 0;
    cursor: pointer;
    border: 1px solid rgba(99, 102, 241, .25);
    background-color: #e5e7ee;
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3e%3ccircle r='3' fill='%23fff'/%3e%3c/svg%3e");
    transition: background-color .25s ease, border-color .25s ease, background-position .25s ease;
}
.clinic-self-toggle__switch .form-check-input:checked {
    background-color: var(--cs-accent);
    border-color: var(--cs-accent);
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3e%3ccircle r='3' fill='%23fff'/%3e%3c/svg%3e");
}
.clinic-self-toggle__switch .form-check-input:focus {
    box-shadow: 0 0 0 4px rgba(99, 102, 241, .18);
    border-color: var(--cs-accent);
}

/* Sync status panel */
.clinic-self-status {
    margin-top: 1.1rem;
    padding: 1rem 1.15rem;
    background: linear-gradient(180deg, rgba(248, 250, 255, .9), rgba(243, 246, 255, .8));
    border: 1px solid rgba(99, 102, 241, .14);
    border-radius: var(--cs-radius-sm);
}
.clinic-self-status__head { display: flex; align-items: center; gap: .75rem; margin-bottom: .85rem; }
.clinic-self-status__icon {
    width: 34px;
    height: 34px;
    border-radius: 10px;
    background: var(--cs-soft);
    color: var(--cs-accent);
    border: 1px solid rgba(99, 102, 241, .18);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: .9rem;
    flex-shrink: 0;
}
.clinic-self-status__title { margin: 0; font-size: .82rem; font-weight: 700; color: var(--cs-text); letter-spacing: -.005em; }
.clinic-self-status__sub { display: block; font-size: .68rem; color: var(--cs-muted); margin-top: .1rem; }
.clinic-self-status__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: .75rem;
    margin: 0;
}
.clinic-self-status__grid > div {
    padding: .55rem .75rem;
    background: rgba(255, 255, 255, .7);
    border: 1px solid var(--cs-line);
    border-radius: 10px;
}
.clinic-self-status__grid dt {
    font-size: .58rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .12em;
    color: var(--cs-muted);
    margin-bottom: .3rem;
}
.clinic-self-status__grid dd { margin: 0; }

/* Pills */
.clinic-self-pill {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    padding: .25rem .6rem;
    background: rgba(99, 102, 241, .1);
    color: var(--cs-accent);
    border-radius: 50rem;
    font-size: .72rem;
    font-weight: 600;
}
.clinic-self-pill i { font-size: .78rem; }
.clinic-self-pill--success { background: rgba(16, 185, 129, .12); color: #047857; }
.clinic-self-pill--danger { background: rgba(239, 68, 68, .12); color: #b91c1c; cursor: help; }
.clinic-self-pill--muted { background: rgba(15, 23, 42, .05); color: var(--cs-muted); }

/* Inline error */
.clinic-self-error {
    display: inline-flex;
    align-items: center;
    gap: .3rem;
    margin-top: .35rem;
    font-size: .7rem;
    font-weight: 600;
    color: var(--cs-danger);
}
.clinic-self-error::before {
    content: "\F33A";
    font-family: "bootstrap-icons";
    font-size: .8rem;
}

/* ── Drag-and-drop logo dropzone ── */
.clinic-self-logo {
    display: flex;
    gap: 1.1rem;
    padding: 1rem 1.15rem;
    background: linear-gradient(135deg, rgba(99, 102, 241, .07), rgba(139, 92, 246, .04));
    border: 1px dashed rgba(99, 102, 241, .35);
    border-radius: var(--cs-radius-sm);
    margin-bottom: 1rem;
    transition: border-color .2s ease, background .2s ease;
}
.clinic-self-logo__tile {
    position: relative;
    width: 104px;
    height: 104px;
    border-radius: 22px;
    background: linear-gradient(135deg, var(--cs-accent), var(--cs-accent-2));
    color: #fff;
    box-shadow: 0 18px 32px -14px rgba(99, 102, 241, .55), inset 0 0 0 2px rgba(255, 255, 255, .25);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    overflow: hidden;
    cursor: pointer;
    outline: none;
}
.clinic-self-logo__tile:focus-visible { box-shadow: 0 0 0 4px rgba(99, 102, 241, .35); }
.clinic-self-logo__tile.is-dragover {
    transform: scale(1.02);
    box-shadow: 0 22px 40px -14px rgba(99, 102, 241, .65), inset 0 0 0 2px rgba(255, 255, 255, .45);
}
.clinic-self-logo__tile img { width: 100%; height: 100%; object-fit: cover; }
.clinic-self-logo__initial { font-size: 2.6rem; font-weight: 800; letter-spacing: -.04em; line-height: 1; }
.clinic-self-logo__overlay {
    position: absolute;
    inset: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: .25rem;
    background: rgba(15, 23, 42, .55);
    color: #fff;
    font-size: .7rem;
    font-weight: 700;
    letter-spacing: .04em;
    text-transform: uppercase;
    opacity: 0;
    transition: opacity .18s ease;
}
.clinic-self-logo__overlay i { font-size: 1.3rem; }
.clinic-self-logo__tile:hover .clinic-self-logo__overlay,
.clinic-self-logo__tile.is-dragover .clinic-self-logo__overlay,
.clinic-self-logo__tile:focus-visible .clinic-self-logo__overlay { opacity: 1; }
.clinic-self-logo__camera {
    position: absolute;
    bottom: -6px;
    right: -6px;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    border: 2px solid #fff;
    background: var(--cs-accent);
    color: #fff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: .85rem;
    cursor: pointer;
    box-shadow: 0 4px 10px rgba(99, 102, 241, .4);
    transition: transform .15s ease;
}
.clinic-self-logo__camera:hover { transform: scale(1.08); }
.clinic-self-logo__body { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: .55rem; }
.clinic-self-logo__head { display: flex; flex-direction: column; gap: .15rem; }
.clinic-self-logo__label { font-size: .85rem; font-weight: 700; color: var(--cs-text); letter-spacing: -.01em; }
.clinic-self-logo__hint { font-size: .72rem; color: var(--cs-sub); line-height: 1.4; }
.clinic-self-logo__chips { display: flex; flex-wrap: wrap; gap: .3rem; }
.clinic-self-logo__chip {
    display: inline-flex;
    align-items: center;
    gap: .3rem;
    padding: .15rem .5rem;
    background: rgba(255, 255, 255, .8);
    border: 1px solid var(--cs-line);
    color: var(--cs-sub);
    border-radius: 50rem;
    font-size: .65rem;
    font-weight: 700;
    letter-spacing: .04em;
}
.clinic-self-logo__chip i { font-size: .78rem; color: var(--cs-accent); }
.clinic-self-logo__actions { display: flex; align-items: center; gap: .65rem; flex-wrap: wrap; }
.clinic-self-logo__btn {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    padding: .45rem .85rem;
    background: #fff;
    border: 1px solid rgba(99, 102, 241, .25);
    border-radius: 50rem;
    color: var(--cs-accent);
    font-size: .78rem;
    font-weight: 700;
    letter-spacing: -.005em;
    cursor: pointer;
    transition: background .15s ease, color .15s ease, transform .12s ease, box-shadow .15s ease;
}
.clinic-self-logo__btn:hover {
    background: linear-gradient(135deg, var(--cs-accent), var(--cs-accent-2));
    color: #fff;
    border-color: transparent;
    box-shadow: 0 8px 18px -8px rgba(99, 102, 241, .55);
}
.clinic-self-logo__btn:active { transform: translateY(1px); }
.clinic-self-logo__clear {
    display: inline-flex;
    align-items: center;
    gap: .3rem;
    font-size: .72rem;
    font-weight: 600;
    color: var(--cs-muted);
    cursor: pointer;
    user-select: none;
    margin: 0;
}
.clinic-self-logo__clear input { accent-color: var(--cs-danger); margin: 0; }
.clinic-self-logo__clear:has(input:checked) span { color: var(--cs-danger); }
.clinic-self-logo__clear i { font-size: .8rem; margin-right: .15rem; }
.clinic-self-logo__filename {
    max-width: 220px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-size: .72rem;
    color: var(--cs-muted);
}

/* Tips card — uses native <details>/<summary> */
.clinic-self-tips {
    position: relative;
    z-index: 1;
    background: rgba(255, 255, 255, .82);
    -webkit-backdrop-filter: saturate(160%) blur(14px);
    backdrop-filter: saturate(160%) blur(14px);
    border: 1px solid var(--cs-line);
    border-radius: var(--cs-radius-sm);
    overflow: hidden;
    transition: border-color .18s ease;
}
.clinic-self-tips:hover { border-color: rgba(99, 102, 241, .25); }
.clinic-self-tips > summary {
    list-style: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: .55rem;
    padding: .65rem .9rem;
    color: var(--cs-text);
    font-size: .82rem;
    font-weight: 600;
}
.clinic-self-tips > summary::-webkit-details-marker { display: none; }
.clinic-self-tips__icon {
    width: 26px;
    height: 26px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 8px;
    background: linear-gradient(135deg, rgba(99, 102, 241, .15), rgba(139, 92, 246, .12));
    color: var(--cs-accent);
    font-size: .85rem;
    flex-shrink: 0;
}
.clinic-self-tips__title { letter-spacing: -.005em; }
.clinic-self-tips__meta { margin-left: .35rem; color: var(--cs-muted); font-size: .7rem; font-weight: 500; letter-spacing: .015em; }
.clinic-self-tips__chev { margin-left: auto; color: var(--cs-muted); font-size: .8rem; transition: transform .2s ease; }
.clinic-self-tips[open] .clinic-self-tips__chev { transform: rotate(180deg); }
.clinic-self-tips__body { padding: .25rem .9rem .9rem; border-top: 1px dashed var(--cs-line); }
.clinic-self-tips__list {
    list-style: none;
    margin: .55rem 0 .35rem;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: .35rem .9rem;
}
.clinic-self-tips__list li { display: flex; align-items: center; gap: .55rem; font-size: .75rem; color: var(--cs-sub); line-height: 1.4; }
.clinic-self-tips__list li strong { color: var(--cs-text); font-weight: 700; }
.clinic-self-tips__num {
    width: 20px;
    height: 20px;
    border-radius: 7px;
    background: linear-gradient(135deg, rgba(99, 102, 241, .15), rgba(139, 92, 246, .12));
    color: var(--cs-accent);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: .68rem;
    font-weight: 800;
    flex-shrink: 0;
}
.clinic-self-tips__note {
    margin-top: .55rem;
    padding: .45rem .65rem;
    border-radius: 10px;
    background: linear-gradient(135deg, rgba(245, 158, 11, .12), rgba(245, 158, 11, .04));
    color: #92651a;
    font-size: .72rem;
    display: inline-flex;
    align-items: center;
    gap: .4rem;
}
.clinic-self-tips__note i { font-size: .82rem; color: #d97706; }

/* Sticky action dock — frosted glass, full-width contact rail. */
.clinic-self-dock {
    position: sticky;
    bottom: .85rem;
    z-index: 5;
    margin-top: .25rem;
    padding: .85rem 1.1rem;
    background: rgba(255, 255, 255, .85);
    -webkit-backdrop-filter: saturate(160%) blur(18px);
    backdrop-filter: saturate(160%) blur(18px);
    border: 1px solid rgba(255, 255, 255, .65);
    border-radius: 18px;
    box-shadow: var(--cs-shadow-dock);
    display: flex;
    align-items: center;
    gap: .85rem;
    flex-wrap: wrap;
}
.clinic-self-dock__left, .clinic-self-dock__right { display: flex; align-items: center; gap: .5rem; }
.clinic-self-dock__progress {
    flex: 1 1 200px;
    text-align: center;
    font-size: .76rem;
    color: var(--cs-sub);
}
.clinic-self-dock__progress strong { color: var(--cs-text); font-weight: 700; }
.clinic-self-dock__progress .step-name { color: var(--cs-accent); font-weight: 700; }

/* Buttons — modernized, gradient-on-primary, soft hover lift. */
.clinic-self-btn {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    padding: .55rem 1.05rem;
    border-radius: 50rem;
    font-size: .82rem;
    font-weight: 700;
    letter-spacing: -.005em;
    border: 1px solid transparent;
    cursor: pointer;
    text-decoration: none;
    transition: transform .12s ease, box-shadow .18s ease, background .18s ease, color .18s ease, border-color .18s ease;
    line-height: 1.2;
}
.clinic-self-btn:active { transform: translateY(1px); }
.clinic-self-btn--ghost {
    background: transparent;
    color: var(--cs-sub);
    border-color: var(--cs-line-strong);
}
.clinic-self-btn--ghost:hover { color: var(--cs-text); background: rgba(15, 23, 42, .04); }
.clinic-self-btn--soft {
    background: rgba(99, 102, 241, .1);
    color: var(--cs-accent);
}
.clinic-self-btn--soft:hover { background: rgba(99, 102, 241, .15); }
.clinic-self-btn--primary {
    background: linear-gradient(135deg, var(--cs-accent), var(--cs-accent-2));
    color: #fff;
    box-shadow: 0 10px 22px -10px rgba(99, 102, 241, .55), inset 0 0 0 1px rgba(255, 255, 255, .15);
}
.clinic-self-btn--primary:hover { color: #fff; box-shadow: 0 14px 28px -10px rgba(99, 102, 241, .65); }
.clinic-self-btn--save {
    background: linear-gradient(135deg, #10b981, #059669);
    color: #fff;
    box-shadow: 0 10px 22px -10px rgba(16, 185, 129, .55), inset 0 0 0 1px rgba(255, 255, 255, .2);
}
.clinic-self-btn--save:hover { color: #fff; box-shadow: 0 14px 28px -10px rgba(16, 185, 129, .65); }

.clinic-self-aside {
    position: sticky;
    top: 1rem;
    align-self: start;
    background: var(--cs-bg);
    -webkit-backdrop-filter: saturate(160%) blur(18px);
    backdrop-filter: saturate(160%) blur(18px);
    border: 1px solid rgba(255, 255, 255, .65);
    border-radius: var(--cs-radius);
    box-shadow: var(--cs-shadow-card);
    padding: 1.15rem 1.1rem;
    display: flex;
    flex-direction: column;
    gap: 1rem;
}
@media (max-width: 960px) {
    .clinic-self-aside { position: static; }
}
.clinic-self-aside__brand {
    display: flex;
    align-items: center;
    gap: .85rem;
    padding-bottom: .9rem;
    border-bottom: 1px dashed var(--cs-line);
}
.clinic-self-aside__avatar {
    flex-shrink: 0;
    width: 56px;
    height: 56px;
    border-radius: 16px;
    overflow: hidden;
    background: linear-gradient(135deg, var(--cs-accent), var(--cs-accent-2));
    color: #fff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 12px 26px -14px rgba(99, 102, 241, .55), inset 0 0 0 1px rgba(255, 255, 255, .35);
}
.clinic-self-aside__avatar img { width: 100%; height: 100%; object-fit: cover; }
.clinic-self-aside__initial { font-size: 1.5rem; font-weight: 800; letter-spacing: -.02em; line-height: 1; }
.clinic-self-aside__meta { min-width: 0; display: flex; flex-direction: column; gap: .15rem; }
.clinic-self-aside__eyebrow {
    font-size: .58rem;
    font-weight: 800;
    letter-spacing: .18em;
    text-transform: uppercase;
    color: var(--cs-accent);
}
.clinic-self-aside__name {
    font-size: .98rem;
    font-weight: 750;
    color: var(--cs-text);
    letter-spacing: -.01em;
    line-height: 1.2;
    overflow: hidden;
    text-overflow: ellipsis;
}
.clinic-self-aside__slug { font-size: .7rem; color: var(--cs-muted); font-family: ui-monospace, "SFMono-Regular", monospace; }
.clinic-self-aside__stats {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: .45rem;
}
.clinic-self-aside__stats li {
    padding: .55rem .55rem;
    background: rgba(248, 249, 255, .65);
    border: 1px solid var(--cs-line);
    border-radius: 12px;
    text-align: center;
    display: flex;
    flex-direction: column;
    gap: .15rem;
}
.clinic-self-aside__stat-label {
    font-size: .55rem;
    font-weight: 800;
    letter-spacing: .1em;
    text-transform: uppercase;
    color: var(--cs-muted);
}
.clinic-self-aside__stat-value { font-size: .95rem; font-weight: 750; color: var(--cs-text); }
.clinic-self-aside__group { display: flex; flex-direction: column; gap: .4rem; }
.clinic-self-aside__group-title {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    font-size: .62rem;
    font-weight: 800;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--cs-sub);
}
.clinic-self-aside__group-title i { color: var(--cs-accent); font-size: .8rem; }
.clinic-self-aside__group .clinic-self-pill { align-self: flex-start; }
.clinic-self-aside__hint { font-size: .7rem; color: var(--cs-muted); line-height: 1.4; }
.clinic-self-aside__cta { margin-top: auto; padding-top: .8rem; border-top: 1px dashed var(--cs-line); }
.clinic-self-aside__link {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    font-size: .76rem;
    font-weight: 700;
    color: var(--cs-accent);
    text-decoration: none;
    transition: color .15s ease, gap .15s ease;
}
.clinic-self-aside__link:hover { color: var(--cs-accent-2); gap: .55rem; }
.clinic-self-aside__link i { font-size: .9rem; }

.clinic-self-callout {
    margin-top: 1rem;
    display: flex;
    align-items: flex-start;
    gap: .75rem;
    padding: .75rem 1rem;
    background: linear-gradient(135deg, rgba(6, 182, 212, .08), rgba(99, 102, 241, .05));
    border: 1px solid rgba(6, 182, 212, .22);
    border-radius: var(--cs-radius-sm);
}
.clinic-self-callout__icon {
    flex-shrink: 0;
    width: 32px;
    height: 32px;
    border-radius: 10px;
    background: rgba(6, 182, 212, .12);
    color: var(--cs-accent-3);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: .9rem;
}
.clinic-self-callout__title { display: block; font-size: .82rem; font-weight: 700; color: var(--cs-text); letter-spacing: -.005em; }
.clinic-self-callout__sub { display: block; font-size: .72rem; color: var(--cs-sub); line-height: 1.45; margin-top: .15rem; }

.clinic-self-channels {
    margin-top: 1.1rem;
    padding: .9rem 1rem 1rem;
    background: rgba(248, 249, 255, .65);
    border: 1px solid var(--cs-line);
    border-radius: var(--cs-radius-sm);
}
.clinic-self-channels__title {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    font-size: .62rem;
    font-weight: 800;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--cs-accent);
    margin-bottom: .65rem;
}
.clinic-self-channels__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: .55rem;
}
.clinic-self-channel {
    display: inline-flex;
    align-items: center;
    gap: .65rem;
    padding: .6rem .75rem;
    background: #fff;
    border: 1px solid var(--cs-line);
    border-radius: 12px;
}
.clinic-self-channel__ico {
    width: 30px;
    height: 30px;
    border-radius: 9px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: .92rem;
    color: #fff;
    flex-shrink: 0;
}
.clinic-self-channel__ico--sms { background: linear-gradient(135deg, #6366f1, #8b5cf6); }
.clinic-self-channel__ico--wa { background: linear-gradient(135deg, #25d366, #128c7e); }
.clinic-self-channel__ico--mfa { background: linear-gradient(135deg, #f59e0b, #d97706); }
.clinic-self-channel__copy { display: flex; flex-direction: column; gap: .1rem; min-width: 0; }
.clinic-self-channel__copy strong { font-size: .8rem; font-weight: 700; color: var(--cs-text); letter-spacing: -.005em; }
.clinic-self-channel__copy em { font-style: normal; font-size: .68rem; color: var(--cs-muted); line-height: 1.35; }

.clinic-self-bond {
    display: flex;
    align-items: center;
    gap: .9rem;
    padding: .85rem 1rem;
    border-radius: var(--cs-radius-sm);
    margin-bottom: 1rem;
    flex-wrap: wrap;
}
.clinic-self-bond--linked {
    background: linear-gradient(135deg, rgba(16, 185, 129, .1), rgba(99, 102, 241, .05));
    border: 1px solid rgba(16, 185, 129, .25);
}
.clinic-self-bond--missing {
    background: linear-gradient(135deg, rgba(245, 158, 11, .1), rgba(99, 102, 241, .04));
    border: 1px solid rgba(245, 158, 11, .25);
}
.clinic-self-bond__icon {
    flex-shrink: 0;
    width: 38px;
    height: 38px;
    border-radius: 12px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-size: 1rem;
}
.clinic-self-bond--linked .clinic-self-bond__icon { background: linear-gradient(135deg, #10b981, #059669); }
.clinic-self-bond--missing .clinic-self-bond__icon { background: linear-gradient(135deg, #f59e0b, #d97706); }
.clinic-self-bond__copy { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: .15rem; }
.clinic-self-bond__title { font-size: .85rem; font-weight: 700; color: var(--cs-text); letter-spacing: -.005em; }
.clinic-self-bond__sub { font-size: .72rem; color: var(--cs-sub); line-height: 1.4; }
.clinic-self-bond__sub code {
    padding: .05rem .35rem;
    border-radius: 5px;
    background: rgba(15, 23, 42, .06);
    color: var(--cs-text);
    font-size: .68rem;
}
.clinic-self-bond__action { margin: 0; }
.clinic-self-bond__btn {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    padding: .45rem .85rem;
    background: #fff;
    border: 1px solid rgba(16, 185, 129, .35);
    color: #047857;
    border-radius: 50rem;
    font-size: .75rem;
    font-weight: 700;
    cursor: pointer;
    transition: background .15s ease, color .15s ease, box-shadow .15s ease, transform .12s ease;
}
.clinic-self-bond__btn:hover {
    background: linear-gradient(135deg, #10b981, #059669);
    color: #fff;
    border-color: transparent;
    box-shadow: 0 8px 18px -8px rgba(16, 185, 129, .55);
}
.clinic-self-bond__btn:active { transform: translateY(1px); }

.clinic-self-status__error {
    margin-top: .85rem;
    display: flex;
    align-items: flex-start;
    gap: .5rem;
    padding: .6rem .8rem;
    background: rgba(239, 68, 68, .07);
    border: 1px solid rgba(239, 68, 68, .22);
    border-radius: 10px;
    color: #b91c1c;
    font-size: .72rem;
    line-height: 1.45;
}
.clinic-self-status__error i { font-size: .85rem; flex-shrink: 0; margin-top: .1rem; }

/* Responsive ─────────────────────────────────────────────── */
@media (max-width: 720px) {
    .clinic-self-head { grid-template-columns: 1fr; }
    .clinic-self-head__chip { justify-self: start; }
    .clinic-self-body { padding: 1.15rem 1.1rem 1.25rem; }
    .clinic-self .clinic-self-rail.nav-substepper { margin: 0 .75rem; }
    .clinic-self-logo { flex-direction: column; align-items: flex-start; }
    .clinic-self-logo__tile { width: 88px; height: 88px; border-radius: 18px; }
    .clinic-self-dock { flex-direction: column; align-items: stretch; }
    .clinic-self-dock__left, .clinic-self-dock__right { justify-content: space-between; }
    .clinic-self-dock__progress { order: -1; flex: 1 1 100%; }
    .clinic-self-aside__stats { grid-template-columns: repeat(3, 1fr); }
}

/* Dark theme ─────────────────────────────────────────────── */
[data-bs-theme="dark"] .clinic-self,
[data-theme="dark"] .clinic-self {
    --cs-text: #e6ebf5;
    --cs-sub: #a8b1c4;
    --cs-muted: #6c7790;
    --cs-line: rgba(255, 255, 255, .07);
    --cs-line-strong: rgba(255, 255, 255, .14);
    --cs-bg: rgba(20, 24, 33, .78);
    --cs-bg-solid: #14181f;
    --cs-soft: rgba(129, 140, 248, .15);
    --cs-soft-strong: rgba(129, 140, 248, .25);
    --cs-shadow-card: 0 1px 2px rgba(0, 0, 0, .3), 0 24px 60px -32px rgba(99, 102, 241, .35);
    --cs-shadow-dock: 0 -10px 30px -18px rgba(0, 0, 0, .5), 0 1px 2px rgba(0, 0, 0, .3);
}
[data-bs-theme="dark"] .clinic-self .clinic-self-card,
[data-theme="dark"] .clinic-self .clinic-self-card { border-color: rgba(255, 255, 255, .08); }
[data-bs-theme="dark"] .clinic-self .clinic-self-field,
[data-theme="dark"] .clinic-self .clinic-self-field { background: rgba(20, 24, 33, .65); }
[data-bs-theme="dark"] .clinic-self .clinic-self-field--locked,
[data-theme="dark"] .clinic-self .clinic-self-field--locked { background: rgba(15, 18, 25, .8); }
[data-bs-theme="dark"] .clinic-self .clinic-self-rail.nav-substepper,
[data-theme="dark"] .clinic-self .clinic-self-rail.nav-substepper { background: rgba(20, 24, 33, .55); }
[data-bs-theme="dark"] .clinic-self .clinic-self-status,
[data-theme="dark"] .clinic-self .clinic-self-status { background: linear-gradient(180deg, rgba(20, 24, 33, .55), rgba(15, 18, 25, .55)); }
[data-bs-theme="dark"] .clinic-self .clinic-self-status__grid > div,
[data-theme="dark"] .clinic-self .clinic-self-status__grid > div { background: rgba(20, 24, 33, .6); }
[data-bs-theme="dark"] .clinic-self .clinic-self-tips,
[data-theme="dark"] .clinic-self .clinic-self-tips { background: rgba(20, 24, 33, .7); }
[data-bs-theme="dark"] .clinic-self .clinic-self-dock,
[data-theme="dark"] .clinic-self .clinic-self-dock { background: rgba(20, 24, 33, .82); border-color: rgba(255, 255, 255, .08); }
[data-bs-theme="dark"] .clinic-self .clinic-self-head__chip,
[data-theme="dark"] .clinic-self .clinic-self-head__chip { background: rgba(20, 24, 33, .65); }
[data-bs-theme="dark"] .clinic-self .clinic-self-logo,
[data-theme="dark"] .clinic-self .clinic-self-logo { background: linear-gradient(135deg, rgba(129, 140, 248, .12), rgba(167, 139, 250, .06)); }
[data-bs-theme="dark"] .clinic-self .clinic-self-logo__btn,
[data-theme="dark"] .clinic-self .clinic-self-logo__btn { background: rgba(20, 24, 33, .8); border-color: rgba(129, 140, 248, .35); color: #c7d2fe; }
[data-bs-theme="dark"] .clinic-self .clinic-self-logo__chip,
[data-theme="dark"] .clinic-self .clinic-self-logo__chip { background: rgba(20, 24, 33, .6); }
[data-bs-theme="dark"] .clinic-self .clinic-self-pill,
[data-theme="dark"] .clinic-self .clinic-self-pill { background: rgba(129, 140, 248, .18); color: #c7d2fe; }
[data-bs-theme="dark"] .clinic-self .clinic-self-pill--success,
[data-theme="dark"] .clinic-self .clinic-self-pill--success { background: rgba(16, 185, 129, .18); color: #6ee7b7; }
[data-bs-theme="dark"] .clinic-self .clinic-self-pill--danger,
[data-theme="dark"] .clinic-self .clinic-self-pill--danger { background: rgba(239, 68, 68, .18); color: #fca5a5; }
[data-bs-theme="dark"] .clinic-self .clinic-self-pill--muted,
[data-theme="dark"] .clinic-self .clinic-self-pill--muted { background: rgba(255, 255, 255, .07); color: var(--cs-muted); }
[data-bs-theme="dark"] .clinic-self .clinic-self-tips__note,
[data-theme="dark"] .clinic-self .clinic-self-tips__note { background: rgba(245, 158, 11, .14); color: #fbbf24; }
[data-bs-theme="dark"] .clinic-self .clinic-self-lang,
[data-theme="dark"] .clinic-self .clinic-self-lang { background: rgba(129, 140, 248, .12); border-color: rgba(129, 140, 248, .25); }
[data-bs-theme="dark"] .clinic-self .clinic-self-lang__opt.is-active,
[data-theme="dark"] .clinic-self .clinic-self-lang__opt.is-active { background: rgba(20, 24, 33, .9); color: #a5b4fc; }
[data-bs-theme="dark"] .clinic-self .clinic-self-aside,
[data-theme="dark"] .clinic-self .clinic-self-aside { border-color: rgba(255, 255, 255, .08); }
[data-bs-theme="dark"] .clinic-self .clinic-self-aside__stats li,
[data-theme="dark"] .clinic-self .clinic-self-aside__stats li { background: rgba(20, 24, 33, .55); }
[data-bs-theme="dark"] .clinic-self .clinic-self-callout,
[data-theme="dark"] .clinic-self .clinic-self-callout { background: linear-gradient(135deg, rgba(6, 182, 212, .14), rgba(99, 102, 241, .08)); border-color: rgba(6, 182, 212, .28); }
[data-bs-theme="dark"] .clinic-self .clinic-self-channels,
[data-theme="dark"] .clinic-self .clinic-self-channels { background: rgba(20, 24, 33, .55); }
[data-bs-theme="dark"] .clinic-self .clinic-self-channel,
[data-theme="dark"] .clinic-self .clinic-self-channel { background: rgba(20, 24, 33, .8); }
[data-bs-theme="dark"] .clinic-self .clinic-self-bond--linked,
[data-theme="dark"] .clinic-self .clinic-self-bond--linked { background: linear-gradient(135deg, rgba(16, 185, 129, .16), rgba(99, 102, 241, .08)); border-color: rgba(16, 185, 129, .35); }
[data-bs-theme="dark"] .clinic-self .clinic-self-bond--missing,
[data-theme="dark"] .clinic-self .clinic-self-bond--missing { background: linear-gradient(135deg, rgba(245, 158, 11, .16), rgba(99, 102, 241, .06)); border-color: rgba(245, 158, 11, .35); }
[data-bs-theme="dark"] .clinic-self .clinic-self-bond__btn,
[data-theme="dark"] .clinic-self .clinic-self-bond__btn { background: rgba(20, 24, 33, .8); color: #6ee7b7; border-color: rgba(16, 185, 129, .4); }
[data-bs-theme="dark"] .clinic-self .clinic-self-status__error,
[data-theme="dark"] .clinic-self .clinic-self-status__error { background: rgba(239, 68, 68, .12); border-color: rgba(239, 68, 68, .3); color: #fca5a5; }

.clinic-provider-picker {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: .75rem;
    margin-bottom: 1.25rem;
}
.clinic-provider-picker__card {
    position: relative;
    display: grid;
    grid-template-columns: 2.25rem 1fr auto;
    align-items: start;
    gap: .75rem;
    padding: .9rem 1rem;
    border: 1px solid var(--co-border-strong, #e5e7eb);
    background: #fff;
    border-radius: 14px;
    cursor: pointer;
    transition: border-color .15s ease, box-shadow .15s ease, background .15s ease, transform .1s ease;
    margin: 0;
}
.clinic-provider-picker__card:hover {
    border-color: var(--co-accent, #6366f1);
    box-shadow: 0 4px 14px rgba(99, 102, 241, .08);
}
.clinic-provider-picker__card:focus-within {
    outline: none;
    border-color: var(--co-accent, #6366f1);
    box-shadow: 0 0 0 3px rgba(99, 102, 241, .18);
}
.clinic-provider-picker__card--active {
    border-color: var(--co-accent, #6366f1);
    background: var(--co-accent-soft, #eef2ff);
    box-shadow: 0 4px 14px rgba(99, 102, 241, .14);
}
.clinic-provider-picker__radio {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}
.clinic-provider-picker__card-icon {
    width: 2.25rem;
    height: 2.25rem;
    border-radius: 10px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--co-accent-soft, #eef2ff);
    color: var(--co-accent, #6366f1);
    font-size: 1.1rem;
    flex-shrink: 0;
}
.clinic-provider-picker__card--active .clinic-provider-picker__card-icon {
    background: var(--co-accent, #6366f1);
    color: #fff;
}
.clinic-provider-picker__card-body {
    display: flex;
    flex-direction: column;
    gap: .25rem;
    min-width: 0;
}
.clinic-provider-picker__card-title {
    font-size: .88rem;
    font-weight: 700;
    color: var(--co-text, #0f172a);
    display: inline-flex;
    align-items: center;
    flex-wrap: wrap;
    gap: .4rem;
}
.clinic-provider-picker__card-desc {
    font-size: .74rem;
    color: var(--co-sub, #64748b);
    line-height: 1.4;
}
.clinic-provider-picker__badge {
    display: inline-flex;
    align-items: center;
    font-size: .65rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .03em;
    color: var(--co-accent, #6366f1);
    background: rgba(99, 102, 241, .12);
    border-radius: 999px;
    padding: .12rem .55rem;
}
.clinic-provider-picker__check {
    color: var(--co-accent, #6366f1);
    font-size: 1.1rem;
    opacity: 0;
    transition: opacity .15s ease;
    align-self: center;
}
.clinic-provider-picker__card--active .clinic-provider-picker__check { opacity: 1; }

.clinic-comm-subsection {
    border: 1px solid var(--co-border, #eef0f3);
    border-radius: 14px;
    padding: 1rem 1.15rem;
    background: #fff;
    margin-top: .25rem;
}
.clinic-comm-subsection[hidden] { display: none !important; }
.clinic-comm-subsection__title {
    font-size: .78rem;
    font-weight: 700;
    color: var(--co-text, #0f172a);
    margin-bottom: .85rem;
    display: inline-flex;
    align-items: center;
    gap: .4rem;
}
.clinic-comm-subsection__title i { color: var(--co-accent, #6366f1); }

[data-theme="dark"] .clinic-provider-picker__card {
    background: var(--dark-bg-elevated);
    border-color: var(--dark-border);
    color: var(--dark-text-primary);
}
[data-theme="dark"] .clinic-provider-picker__card--active {
    background: rgba(99, 102, 241, .14);
    border-color: #818cf8;
}
[data-theme="dark"] .clinic-provider-picker__card-title { color: var(--dark-text-primary); }
[data-theme="dark"] .clinic-provider-picker__card-desc { color: var(--dark-text-secondary); }
[data-theme="dark"] .clinic-comm-subsection {
    background: var(--dark-bg-elevated);
    border-color: var(--dark-border);
}
[data-theme="dark"] .clinic-comm-subsection__title { color: var(--dark-text-primary); }

/* ═════════════════════════════════════════════════════════════════
   Communication Settings — Overview dashboard
   Modern dual-channel snapshot rendered inside the wizard's
   Overview tab. Stays adjacent to .clinic-comm-subsection rules
   so the whole communication-settings styling lives in one cluster.
   ═════════════════════════════════════════════════════════════════ */
.comm-overview {
    display: flex;
    flex-direction: column;
    gap: 1.15rem;
}

.comm-overview__banner {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1rem 1.25rem;
    border-radius: 18px;
    border: 1px solid transparent;
    background: linear-gradient(135deg, rgba(99, 102, 241, .08), rgba(99, 102, 241, .02));
    border-color: rgba(99, 102, 241, .18);
}
.comm-overview__banner--success {
    background: linear-gradient(135deg, rgba(16, 185, 129, .10), rgba(16, 185, 129, .02));
    border-color: rgba(16, 185, 129, .22);
}
.comm-overview__banner--warning {
    background: linear-gradient(135deg, rgba(245, 158, 11, .10), rgba(245, 158, 11, .02));
    border-color: rgba(245, 158, 11, .25);
}
.comm-overview__banner-icon {
    flex: 0 0 auto;
    width: 44px;
    height: 44px;
    border-radius: 14px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.35rem;
    background: #fff;
    color: #4f46e5;
    box-shadow: 0 1px 2px rgba(15, 23, 42, .04), 0 6px 14px rgba(99, 102, 241, .12);
}
.comm-overview__banner--success .comm-overview__banner-icon { color: #059669; box-shadow: 0 1px 2px rgba(15, 23, 42, .04), 0 6px 14px rgba(16, 185, 129, .15); }
.comm-overview__banner--warning .comm-overview__banner-icon { color: #b45309; box-shadow: 0 1px 2px rgba(15, 23, 42, .04), 0 6px 14px rgba(245, 158, 11, .18); }
.comm-overview__banner-body { flex: 1 1 auto; min-width: 0; }
.comm-overview__banner-title {
    font-size: 1rem;
    font-weight: 700;
    color: #0f172a;
    line-height: 1.25;
}
.comm-overview__banner-desc {
    font-size: .85rem;
    color: #475569;
    margin-top: .15rem;
}
.comm-overview__banner-meta {
    flex: 0 0 auto;
    text-align: right;
    padding-left: 1rem;
    border-left: 1px solid rgba(15, 23, 42, .08);
}
.comm-overview__count {
    display: block;
    font-size: 1.5rem;
    font-weight: 800;
    color: #0f172a;
    line-height: 1;
    letter-spacing: -.02em;
}
.comm-overview__count span {
    font-size: .9rem;
    font-weight: 600;
    color: #94a3b8;
}
.comm-overview__count-label {
    display: block;
    font-size: .68rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: #64748b;
    margin-top: .15rem;
}

.comm-overview__channels {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
    gap: 1rem;
}

.comm-channel {
    display: flex;
    flex-direction: column;
    gap: .85rem;
    padding: 1.1rem 1.15rem 1rem;
    background: #fff;
    border: 1px solid var(--co-border, #eef0f3);
    border-radius: 18px;
    box-shadow: 0 1px 2px rgba(15, 23, 42, .03);
    position: relative;
    overflow: hidden;
}
.comm-channel::before {
    content: '';
    position: absolute;
    inset: 0 0 auto 0;
    height: 3px;
    background: linear-gradient(90deg, transparent, rgba(99, 102, 241, .6), transparent);
    opacity: .55;
}
.comm-channel--sms::before { background: linear-gradient(90deg, transparent, rgba(14, 165, 233, .7), transparent); }
.comm-channel--email::before { background: linear-gradient(90deg, transparent, rgba(139, 92, 246, .7), transparent); }

.comm-channel__head {
    display: flex;
    align-items: center;
    gap: .75rem;
}
.comm-channel__icon {
    flex: 0 0 auto;
    width: 40px;
    height: 40px;
    border-radius: 12px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.1rem;
}
.comm-channel__icon--sms {
    background: rgba(14, 165, 233, .12);
    color: #0284c7;
}
.comm-channel__icon--email {
    background: rgba(139, 92, 246, .12);
    color: #7c3aed;
}
.comm-channel__head-text { flex: 1 1 auto; min-width: 0; }
.comm-channel__name {
    font-size: .98rem;
    font-weight: 700;
    color: #0f172a;
    line-height: 1.2;
}
.comm-channel__sub {
    font-size: .76rem;
    color: #64748b;
    margin-top: .1rem;
}

.comm-channel__pill {
    flex: 0 0 auto;
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    padding: .25rem .65rem;
    border-radius: 999px;
    font-size: .72rem;
    font-weight: 700;
    line-height: 1;
    background: rgba(15, 23, 42, .06);
    color: #334155;
    white-space: nowrap;
}
.comm-channel__pill-dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: currentColor;
    opacity: .85;
}
.comm-channel__pill--success { background: rgba(16, 185, 129, .14); color: #047857; }
.comm-channel__pill--warning { background: rgba(245, 158, 11, .16); color: #b45309; }
.comm-channel__pill--danger { background: rgba(239, 68, 68, .14); color: #b91c1c; }
.comm-channel__pill--info { background: rgba(59, 130, 246, .14); color: #1d4ed8; }
.comm-channel__pill--muted { background: rgba(148, 163, 184, .16); color: #475569; }

.comm-channel__rows {
    margin: 0;
    display: grid;
    gap: .55rem;
    padding: .75rem 0 .15rem;
    border-top: 1px dashed rgba(15, 23, 42, .08);
}
.comm-channel__row {
    display: grid;
    grid-template-columns: 11rem 1fr;
    gap: .65rem;
    align-items: center;
    min-height: 1.6rem;
}
.comm-channel__label {
    margin: 0;
    font-size: .72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .04em;
    color: #64748b;
    display: inline-flex;
    align-items: center;
    gap: .35rem;
}
.comm-channel__label i { font-size: .85rem; color: #94a3b8; }
.comm-channel__value {
    margin: 0;
    font-size: .85rem;
    color: #0f172a;
    display: inline-flex;
    flex-wrap: wrap;
    align-items: center;
    gap: .4rem;
    min-width: 0;
    word-break: break-word;
}
.comm-channel__value-icon {
    color: #4f46e5;
    font-size: .95rem;
}
.comm-channel__sender { font-weight: 600; color: #0f172a; }
.comm-channel__code {
    font-family: 'JetBrains Mono', ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
    font-size: .78rem;
    background: rgba(15, 23, 42, .05);
    color: #0f172a;
    border-radius: 6px;
    padding: .12rem .45rem;
}
.comm-channel__muted { color: #94a3b8; font-style: italic; }
.comm-channel__verified {
    display: inline-flex;
    align-items: center;
    gap: .3rem;
    color: #047857;
    font-weight: 600;
    font-size: .82rem;
}
.comm-channel__tag {
    display: inline-flex;
    align-items: center;
    gap: .2rem;
    font-size: .68rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .04em;
    padding: .12rem .5rem;
    border-radius: 999px;
    background: rgba(15, 23, 42, .06);
    color: #475569;
}
.comm-channel__tag--success { background: rgba(16, 185, 129, .14); color: #047857; }
.comm-channel__tag--warning { background: rgba(245, 158, 11, .18); color: #b45309; }
.comm-channel__tag--muted { background: rgba(148, 163, 184, .18); color: #475569; }

.comm-channel__error {
    display: flex;
    align-items: flex-start;
    gap: .5rem;
    padding: .55rem .75rem;
    border-radius: 10px;
    background: rgba(239, 68, 68, .08);
    color: #b91c1c;
    font-size: .78rem;
    line-height: 1.4;
}
.comm-channel__error i { font-size: .95rem; margin-top: .05rem; }

.comm-channel__actions {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
    padding-top: .15rem;
    border-top: 1px solid rgba(15, 23, 42, .06);
    padding-top: .8rem;
    margin-top: .15rem;
}

.comm-overview__flow {
    background: #fff;
    border: 1px solid var(--co-border, #eef0f3);
    border-radius: 18px;
    padding: 1rem 1.15rem 1.1rem;
}
.comm-overview__flow-head {
    display: flex;
    align-items: center;
    gap: .75rem;
    margin-bottom: .9rem;
}
.comm-overview__flow-icon {
    width: 36px;
    height: 36px;
    border-radius: 11px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(99, 102, 241, .12);
    color: #4f46e5;
    font-size: 1rem;
}
.comm-overview__flow-title {
    font-size: .92rem;
    font-weight: 700;
    color: #0f172a;
    line-height: 1.2;
}
.comm-overview__flow-sub {
    font-size: .78rem;
    color: #64748b;
    margin-top: .1rem;
}
.comm-overview__flow-steps {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
    gap: .65rem;
    position: relative;
}
.comm-overview__flow-step {
    display: flex;
    align-items: flex-start;
    gap: .65rem;
    padding: .65rem .8rem;
    background: rgba(15, 23, 42, .025);
    border-radius: 12px;
    border: 1px solid rgba(15, 23, 42, .04);
}
.comm-overview__flow-num {
    flex: 0 0 auto;
    width: 22px;
    height: 22px;
    border-radius: 50%;
    background: #4f46e5;
    color: #fff;
    font-size: .72rem;
    font-weight: 700;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-top: .1rem;
}
.comm-overview__flow-step-title {
    font-size: .82rem;
    font-weight: 700;
    color: #0f172a;
    line-height: 1.2;
}
.comm-overview__flow-step-desc {
    font-size: .76rem;
    color: #475569;
    margin-top: .15rem;
    line-height: 1.45;
}

/* ── Responsive ── */
@media (max-width: 640px) {
    .comm-overview__banner { flex-wrap: wrap; }
    .comm-overview__banner-meta {
        padding-left: 0;
        border-left: 0;
        text-align: left;
        width: 100%;
        padding-top: .5rem;
        border-top: 1px solid rgba(15, 23, 42, .08);
    }
    .comm-channel__row { grid-template-columns: 1fr; gap: .15rem; }
    .comm-channel__head { flex-wrap: wrap; }
    .comm-channel__pill { order: 3; margin-top: .25rem; }
}

/* ── Dark theme ── */
[data-theme="dark"] .comm-overview__banner {
    background: linear-gradient(135deg, rgba(99, 102, 241, .14), rgba(99, 102, 241, .04));
    border-color: rgba(129, 140, 248, .25);
}
[data-theme="dark"] .comm-overview__banner--success {
    background: linear-gradient(135deg, rgba(16, 185, 129, .14), rgba(16, 185, 129, .04));
    border-color: rgba(52, 211, 153, .28);
}
[data-theme="dark"] .comm-overview__banner--warning {
    background: linear-gradient(135deg, rgba(245, 158, 11, .16), rgba(245, 158, 11, .04));
    border-color: rgba(251, 191, 36, .3);
}
[data-theme="dark"] .comm-overview__banner-icon {
    background: var(--dark-bg-elevated);
    color: #a5b4fc;
    box-shadow: 0 1px 2px rgba(0, 0, 0, .25), 0 6px 14px rgba(99, 102, 241, .25);
}
[data-theme="dark"] .comm-overview__banner-title { color: var(--dark-text-primary); }
[data-theme="dark"] .comm-overview__banner-desc { color: var(--dark-text-secondary); }
[data-theme="dark"] .comm-overview__banner-meta { border-color: rgba(255, 255, 255, .1); }
[data-theme="dark"] .comm-overview__count { color: var(--dark-text-primary); }
[data-theme="dark"] .comm-overview__count span { color: var(--dark-text-secondary); }
[data-theme="dark"] .comm-overview__count-label { color: var(--dark-text-secondary); }
[data-theme="dark"] .comm-channel,
[data-theme="dark"] .comm-overview__flow {
    background: var(--dark-bg-elevated);
    border-color: var(--dark-border);
}
[data-theme="dark"] .comm-channel__name,
[data-theme="dark"] .comm-channel__value,
[data-theme="dark"] .comm-overview__flow-title,
[data-theme="dark"] .comm-overview__flow-step-title { color: var(--dark-text-primary); }
[data-theme="dark"] .comm-channel__sub,
[data-theme="dark"] .comm-channel__label,
[data-theme="dark"] .comm-overview__flow-sub,
[data-theme="dark"] .comm-overview__flow-step-desc { color: var(--dark-text-secondary); }
[data-theme="dark"] .comm-channel__rows { border-color: rgba(255, 255, 255, .08); }
[data-theme="dark"] .comm-channel__actions { border-color: rgba(255, 255, 255, .06); }
[data-theme="dark"] .comm-channel__code {
    background: rgba(255, 255, 255, .06);
    color: var(--dark-text-primary);
}
[data-theme="dark"] .comm-overview__flow-step {
    background: rgba(255, 255, 255, .03);
    border-color: rgba(255, 255, 255, .06);
}
