/**
 * WLC Patient Portal — calm, scheduling-led styles.
 *
 * Design direction: less dashboard, more guided journey.
 * Single-column content. Strong hierarchy. Generous whitespace.
 */

:root {
    --wlc-primary: #1B7A5A;
    --wlc-primary-dark: #145C43;
    --wlc-primary-light: #E8F5EE;
    --wlc-cream: #FAF8F5;
    --wlc-sand: #F3EDE4;
    --wlc-text: #1A1A18;
    --wlc-text-muted: #4A4744;
    --wlc-text-light: #7A7672;
    --wlc-border: #E8E4DF;
    --wlc-white: #FFFFFF;
    --wlc-warn: #B7791F;
    --wlc-warn-light: #FDF6E3;
    --wlc-info: #2563EB;
    --wlc-radius: 12px;
    --wlc-radius-lg: 16px;
    --wlc-radius-xl: 22px;
    --wlc-shadow-sm: 0 1px 3px rgba(0,0,0,0.04);
    --wlc-shadow-md: 0 6px 18px rgba(0,0,0,0.06);
    --wlc-shadow-lg: 0 18px 50px rgba(20, 92, 67, 0.10);
    --wlc-font-body: 'DM Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
    --wlc-font-heading: 'DM Serif Display', Georgia, 'Times New Roman', serif;
    --wlc-transition: 0.25s cubic-bezier(0.4, 0, 0.2, 1);
}

.wlc-portal,
.wlc-entry {
    font-family: var(--wlc-font-body);
    color: var(--wlc-text);
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
    box-sizing: border-box;
}

.wlc-portal *,
.wlc-portal *::before,
.wlc-portal *::after,
.wlc-entry *,
.wlc-entry *::before,
.wlc-entry *::after { box-sizing: border-box; }

.wlc-portal {
    --wlc-topbar-h: 64px;
    --wlc-nav-width: 240px;
    min-height: 100vh;
    width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    overflow-x: hidden;
    background: var(--wlc-cream);
}

.wlc-icon { flex-shrink: 0; vertical-align: middle; }

/* ── Dev notice (admin only) ─────────────────────────────────── */

.wlc-portal__dev-notice {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 20px;
    background: #FFF7E0;
    border-bottom: 1px solid #F0E0A8;
    color: #6B5A1A;
    font-size: 13px;
    line-height: 1.45;
}

.wlc-portal__dev-notice p { margin: 0; }

.wlc-portal__dev-notice-tag {
    flex-shrink: 0;
    display: inline-block;
    padding: 2px 8px;
    border-radius: 999px;
    background: #6B5A1A;
    color: #FFF7E0;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

/* ── Top bar ─────────────────────────────────────────────────── */

.wlc-portal__topbar {
    position: sticky;
    top: 0;
    z-index: 60;
    height: var(--wlc-topbar-h);
    background: rgba(255, 255, 255, 0.92);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border-bottom: 1px solid var(--wlc-border);
}

.wlc-portal__topbar-inner {
    max-width: 1240px;
    margin: 0 auto;
    height: 100%;
    padding: 0 24px;
    display: flex;
    align-items: center;
    gap: 16px;
}

.wlc-portal__nav-toggle {
    display: none;
    width: 40px;
    height: 40px;
    border-radius: 10px;
    border: 1px solid var(--wlc-border);
    background: var(--wlc-white);
    color: var(--wlc-text);
    cursor: pointer;
    align-items: center;
    justify-content: center;
    transition: all var(--wlc-transition);
}

.wlc-portal__nav-toggle:hover { border-color: var(--wlc-primary); color: var(--wlc-primary); }

.wlc-portal__brand {
    display: flex;
    align-items: center;
    gap: 10px;
    font-weight: 600;
}

.wlc-portal__brand-mark {
    width: 30px;
    height: 30px;
    border-radius: 9px;
    background: var(--wlc-primary);
    color: var(--wlc-white);
    display: flex;
    align-items: center;
    justify-content: center;
}

.wlc-portal__brand-name {
    font-size: 14px;
    letter-spacing: -0.005em;
}

.wlc-portal__topbar-right {
    margin-left: auto;
    display: flex;
    align-items: center;
    gap: 12px;
}

.wlc-portal__avatar {
    width: 34px;
    height: 34px;
    border-radius: 50%;
    background: var(--wlc-primary);
    color: var(--wlc-white);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 0.02em;
    text-transform: uppercase;
}

/* ── Body layout ─────────────────────────────────────────────── */

.wlc-portal__body {
    max-width: 1240px;
    margin: 0 auto;
    padding: 40px 24px 80px;
    display: grid;
    grid-template-columns: var(--wlc-nav-width) 1fr;
    gap: 48px;
    align-items: start;
}

/* ── Sidebar nav ─────────────────────────────────────────────── */

.wlc-portal__nav {
    position: sticky;
    top: calc(var(--wlc-topbar-h) + 32px);
}

.wlc-portal__nav-list {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.wlc-portal__nav-link {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 11px 14px;
    border-radius: 10px;
    color: var(--wlc-text-muted);
    text-decoration: none;
    font-size: 14px;
    font-weight: 500;
    transition: all var(--wlc-transition);
}

.wlc-portal__nav-link:hover {
    background: var(--wlc-white);
    color: var(--wlc-text);
}

.wlc-portal__nav-link.is-active {
    background: var(--wlc-white);
    color: var(--wlc-primary-dark);
    font-weight: 600;
    box-shadow: var(--wlc-shadow-sm);
}

.wlc-portal__nav-icon {
    width: 28px;
    height: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--wlc-text-light);
    transition: color var(--wlc-transition);
}

.wlc-portal__nav-link.is-active .wlc-portal__nav-icon,
.wlc-portal__nav-link:hover .wlc-portal__nav-icon {
    color: var(--wlc-primary);
}

/* ── Main content (single column, generous rhythm) ───────────── */

.wlc-portal__main {
    min-width: 0;
    max-width: 680px;
    margin: 0 auto;
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: 40px;
}

/* ── Greeting / section heading ──────────────────────────────── */

.wlc-greet {
    padding-bottom: 8px;
}

.wlc-eyebrow {
    margin: 0 0 8px;
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--wlc-primary-dark);
}

.wlc-h1 {
    font-family: var(--wlc-font-heading);
    font-size: 38px;
    font-weight: 400;
    letter-spacing: -0.02em;
    line-height: 1.15;
    margin: 0 0 14px;
    color: var(--wlc-text);
}

.wlc-lede {
    margin: 0;
    font-size: 16px;
    color: var(--wlc-text-muted);
    line-height: 1.6;
    max-width: 560px;
}

/* ── Pathway dots ────────────────────────────────────────────── */

.wlc-path {
    list-style: none;
    margin: 28px 0 0;
    padding: 0;
    display: flex;
    gap: 0;
    position: relative;
    max-width: 560px;
}

.wlc-path::before {
    content: '';
    position: absolute;
    top: 9px;
    left: 20px;
    right: 20px;
    height: 2px;
    background: var(--wlc-border);
    z-index: 0;
}

.wlc-path__step {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
    position: relative;
    z-index: 1;
}

.wlc-path__dot {
    width: 20px;
    height: 20px;
    border-radius: 50%;
    border: 2px solid var(--wlc-border);
    background: var(--wlc-cream);
    transition: all var(--wlc-transition);
}

.wlc-path__step--done .wlc-path__dot {
    background: var(--wlc-primary);
    border-color: var(--wlc-primary);
}

.wlc-path__step--current .wlc-path__dot {
    border-color: var(--wlc-primary);
    background: var(--wlc-white);
    box-shadow: 0 0 0 5px rgba(27, 122, 90, 0.15);
}

.wlc-path__label {
    font-size: 11px;
    color: var(--wlc-text-light);
    letter-spacing: 0.04em;
    text-transform: uppercase;
    font-weight: 600;
}

.wlc-path__step--current .wlc-path__label {
    color: var(--wlc-primary-dark);
}

.wlc-path__step--done .wlc-path__label {
    color: var(--wlc-text-muted);
}

/* ── Primary action (the dominant block on Home) ─────────────── */

.wlc-action {
    background: linear-gradient(180deg, #FFFFFF 0%, #F4FBF7 100%);
    border: 1px solid rgba(27, 122, 90, 0.2);
    border-radius: var(--wlc-radius-xl);
    padding: 36px;
    box-shadow: var(--wlc-shadow-md);
    display: flex;
    flex-direction: column;
    gap: 12px;
    align-items: flex-start;
}

.wlc-action--compact { padding: 28px; }

.wlc-action__label {
    margin: 0;
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--wlc-primary-dark);
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

.wlc-action__title {
    margin: 4px 0 0;
    font-family: var(--wlc-font-heading);
    font-size: 28px;
    font-weight: 400;
    letter-spacing: -0.01em;
    line-height: 1.2;
    color: var(--wlc-text);
}

.wlc-action__desc {
    margin: 0;
    font-size: 15px;
    color: var(--wlc-text-muted);
    line-height: 1.55;
    max-width: 480px;
}

/* ── Content block (appointment, FAQ, etc) ───────────────────── */

.wlc-block {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.wlc-block__head {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 12px;
    padding-bottom: 8px;
    border-bottom: 1px solid var(--wlc-border);
}

.wlc-block__head h2 {
    margin: 0;
    font-size: 14px;
    font-weight: 600;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--wlc-text-light);
}

/* ── Buttons ─────────────────────────────────────────────────── */

.wlc-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 12px 22px;
    border-radius: 10px;
    font-size: 14px;
    font-weight: 600;
    font-family: var(--wlc-font-body);
    cursor: pointer;
    text-decoration: none;
    border: 1.5px solid transparent;
    transition: all var(--wlc-transition);
    align-self: flex-start;
    white-space: nowrap;
    line-height: 1;
}

.wlc-btn--lg {
    padding: 15px 26px;
    font-size: 15px;
}

.wlc-btn--primary {
    background: var(--wlc-primary);
    color: var(--wlc-white);
    box-shadow: 0 6px 18px rgba(27, 122, 90, 0.24);
}

.wlc-btn--primary:hover {
    background: var(--wlc-primary-dark);
    transform: translateY(-1px);
    box-shadow: 0 8px 22px rgba(27, 122, 90, 0.3);
    color: var(--wlc-white);
}

.wlc-btn--ghost {
    background: transparent;
    color: var(--wlc-primary-dark);
    border-color: var(--wlc-primary);
}

.wlc-btn--ghost:hover {
    background: var(--wlc-primary);
    color: var(--wlc-white);
}

/* ── Links ───────────────────────────────────────────────────── */

.wlc-link {
    font-size: 13px;
    color: var(--wlc-primary);
    font-weight: 600;
    text-decoration: none;
    transition: color var(--wlc-transition);
}

.wlc-link:hover { color: var(--wlc-primary-dark); text-decoration: underline; text-underline-offset: 3px; }

.wlc-link--strong {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 14px;
}

/* ── Appointment card ────────────────────────────────────────── */

.wlc-appt {
    display: flex;
    gap: 22px;
    padding: 22px;
    background: var(--wlc-white);
    border: 1px solid var(--wlc-border);
    border-radius: var(--wlc-radius-lg);
    align-items: flex-start;
}

.wlc-appt__date {
    flex-shrink: 0;
    width: 76px;
    padding: 14px 8px;
    border-radius: var(--wlc-radius);
    background: var(--wlc-primary);
    color: var(--wlc-white);
    text-align: center;
    box-shadow: 0 6px 16px rgba(27, 122, 90, 0.22);
}

.wlc-appt__day {
    display: block;
    font-family: var(--wlc-font-heading);
    font-size: 32px;
    line-height: 1;
}

.wlc-appt__month {
    display: block;
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    margin-top: 4px;
    font-weight: 600;
}

.wlc-appt__meta {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.wlc-appt__title {
    margin: 0;
    font-size: 16px;
    font-weight: 600;
    color: var(--wlc-text);
}

.wlc-appt__when {
    margin: 0;
    font-size: 14px;
    color: var(--wlc-text-muted);
}

.wlc-appt__hint {
    font-size: 13px;
    color: var(--wlc-text-light);
    font-style: italic;
    margin-top: 8px;
}

.wlc-appt--lg {
    padding: 28px;
}

.wlc-appt--lg .wlc-appt__date { width: 88px; padding: 18px 10px; }
.wlc-appt--lg .wlc-appt__day { font-size: 38px; }

/* ── Empty states ────────────────────────────────────────────── */

.wlc-empty {
    padding: 28px;
    background: var(--wlc-white);
    border: 1px dashed var(--wlc-border);
    border-radius: var(--wlc-radius-lg);
    display: flex;
    flex-direction: column;
    gap: 8px;
    align-items: flex-start;
}

.wlc-empty__title {
    margin: 0;
    font-size: 15px;
    font-weight: 600;
    color: var(--wlc-text);
}

.wlc-empty__desc {
    margin: 0;
    font-size: 14px;
    color: var(--wlc-text-muted);
    line-height: 1.55;
    max-width: 520px;
}

.wlc-empty .wlc-btn { margin-top: 8px; }

/* ── Support strip (home) ────────────────────────────────────── */

.wlc-support {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 20px;
    padding: 22px 26px;
    background: var(--wlc-white);
    border: 1px solid var(--wlc-border);
    border-radius: var(--wlc-radius-lg);
}

.wlc-support__title {
    margin: 0 0 2px;
    font-size: 15px;
    font-weight: 600;
    color: var(--wlc-text);
}

.wlc-support__desc {
    margin: 0;
    font-size: 13px;
    color: var(--wlc-text-light);
    line-height: 1.5;
}

/* ── Reschedule strip ────────────────────────────────────────── */

.wlc-strip {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 16px;
    padding: 18px 22px;
    background: var(--wlc-cream);
    border-radius: var(--wlc-radius);
    border: 1px solid var(--wlc-border);
}

.wlc-strip p {
    margin: 0;
    font-size: 14px;
    color: var(--wlc-text-muted);
}

/* ── List (bullets) ──────────────────────────────────────────── */

.wlc-list {
    margin: 0;
    padding: 0;
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.wlc-list li {
    position: relative;
    padding-left: 28px;
    font-size: 15px;
    color: var(--wlc-text-muted);
    line-height: 1.55;
}

.wlc-list li::before {
    content: '';
    position: absolute;
    left: 0;
    top: 8px;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: var(--wlc-primary-light);
    border: 2px solid var(--wlc-primary);
}

/* ── Status chip ─────────────────────────────────────────────── */

.wlc-status {
    display: flex;
    flex-direction: column;
    gap: 12px;
    padding: 20px 22px;
    background: var(--wlc-white);
    border: 1px solid var(--wlc-border);
    border-radius: var(--wlc-radius-lg);
}

.wlc-status__chip {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 6px 14px;
    border-radius: 999px;
    font-size: 13px;
    font-weight: 600;
    align-self: flex-start;
    border: 1px solid transparent;
}

.wlc-status__chip--ok      { background: var(--wlc-primary-light); color: var(--wlc-primary-dark); border-color: rgba(27, 122, 90, 0.2); }
.wlc-status__chip--info    { background: #EAF2FF; color: #1E40AF; border-color: #C5D9FD; }
.wlc-status__chip--warn    { background: var(--wlc-warn-light); color: var(--wlc-warn); border-color: #EDDCA7; }
.wlc-status__chip--neutral { background: #F1EEEA; color: var(--wlc-text-muted); border-color: var(--wlc-border); }

.wlc-status__chip .wlc-dot {
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: currentColor;
    opacity: 0.7;
}

.wlc-status__desc {
    margin: 0;
    font-size: 15px;
    color: var(--wlc-text-muted);
    line-height: 1.5;
}

.wlc-status__meta {
    margin: 0;
    font-size: 13px;
    color: var(--wlc-text-light);
}

/* ── Steps (assessment) ──────────────────────────────────────── */

.wlc-steps {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.wlc-steps__item {
    display: flex;
    gap: 16px;
    padding: 16px 18px;
    background: var(--wlc-white);
    border: 1px solid var(--wlc-border);
    align-items: flex-start;
}

.wlc-steps__item:first-child { border-top-left-radius: var(--wlc-radius-lg); border-top-right-radius: var(--wlc-radius-lg); }
.wlc-steps__item:last-child  { border-bottom-left-radius: var(--wlc-radius-lg); border-bottom-right-radius: var(--wlc-radius-lg); }
.wlc-steps__item + .wlc-steps__item { border-top: 0; }

.wlc-steps__marker {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    border: 2px solid var(--wlc-border);
    background: var(--wlc-cream);
    color: var(--wlc-text-light);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 12px;
    font-weight: 700;
    flex-shrink: 0;
}

.wlc-steps__item--done .wlc-steps__marker {
    background: var(--wlc-primary);
    color: var(--wlc-white);
    border-color: var(--wlc-primary);
}

.wlc-steps__item--current .wlc-steps__marker {
    background: var(--wlc-white);
    border-color: var(--wlc-primary);
    color: var(--wlc-primary-dark);
    box-shadow: 0 0 0 4px rgba(27, 122, 90, 0.12);
}

.wlc-steps__title {
    margin: 2px 0 2px;
    font-size: 15px;
    font-weight: 600;
    color: var(--wlc-text);
}

.wlc-steps__item--done .wlc-steps__title { color: var(--wlc-text-muted); }
.wlc-steps__item--pending .wlc-steps__title { color: var(--wlc-text-light); }

.wlc-steps__desc {
    margin: 0;
    font-size: 13px;
    color: var(--wlc-text-light);
    line-height: 1.5;
}

/* ── FAQ ─────────────────────────────────────────────────────── */

.wlc-faq {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.wlc-faq li {
    padding: 18px 20px;
    background: var(--wlc-white);
    border: 1px solid var(--wlc-border);
    border-radius: var(--wlc-radius);
}

.wlc-faq__q { margin: 0 0 6px; font-size: 15px; font-weight: 600; color: var(--wlc-text); }
.wlc-faq__a { margin: 0; font-size: 14px; color: var(--wlc-text-muted); line-height: 1.55; }

/* ── Thread (recent updates) ─────────────────────────────────── */

.wlc-thread {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.wlc-thread li {
    display: flex;
    gap: 14px;
    padding: 14px 18px;
    background: var(--wlc-white);
    border: 1px solid var(--wlc-border);
    border-radius: var(--wlc-radius);
}

.wlc-thread__dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    flex-shrink: 0;
    margin-top: 6px;
    background: var(--wlc-primary);
}

.wlc-thread__dot--info    { background: var(--wlc-info); }
.wlc-thread__dot--warn    { background: var(--wlc-warn); }
.wlc-thread__dot--neutral { background: var(--wlc-text-light); }
.wlc-thread__dot--ok      { background: var(--wlc-primary); }

.wlc-thread__title { margin: 0; font-size: 14px; font-weight: 600; color: var(--wlc-text); }
.wlc-thread__time  { margin: 2px 0 0; font-size: 12px; color: var(--wlc-text-light); }
.wlc-thread__note  {
    margin: 8px 0 0;
    font-size: 13px;
    color: var(--wlc-text-muted);
    line-height: 1.5;
    padding: 10px 12px;
    background: var(--wlc-cream);
    border-radius: 8px;
}

/* ── Notice (emergency) ──────────────────────────────────────── */

.wlc-notice {
    padding: 18px 20px;
    background: var(--wlc-warn-light);
    border: 1px solid #EDDCA7;
    border-radius: var(--wlc-radius);
    color: #6B4C0F;
}

.wlc-notice p {
    margin: 0;
    font-size: 13px;
    line-height: 1.55;
}

/* ── Key-value list (account) ────────────────────────────────── */

.wlc-kv {
    margin: 0;
    display: flex;
    flex-direction: column;
    padding: 4px 20px;
    background: var(--wlc-white);
    border: 1px solid var(--wlc-border);
    border-radius: var(--wlc-radius-lg);
}

.wlc-kv > div {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 16px;
    padding: 16px 0;
    border-bottom: 1px solid var(--wlc-border);
}

.wlc-kv > div:last-child { border-bottom: 0; }

.wlc-kv dt {
    font-size: 13px;
    color: var(--wlc-text-light);
    margin: 0;
    font-weight: 500;
}

.wlc-kv dd {
    font-size: 14px;
    color: var(--wlc-text);
    margin: 0;
    font-weight: 500;
    text-align: right;
}

/* ══════════════════════════════════════════════════════════════
   PORTAL ENTRY (logged out) — calmer, simpler
   ══════════════════════════════════════════════════════════════ */

.wlc-entry {
    width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    min-height: calc(100vh - var(--wlc-site-header-h, 108px));
    padding: clamp(24px, 4vh, 48px) clamp(16px, 4vw, 32px);
    background:
        radial-gradient(1200px 400px at 15% 0%, rgba(27, 122, 90, 0.06), transparent 60%),
        radial-gradient(900px 500px at 90% 10%, rgba(232, 245, 238, 0.8), transparent 60%),
        var(--wlc-cream);
    display: flex;
    justify-content: center;
    align-items: center;
}

.wlc-entry__shell {
    width: 100%;
    max-width: 900px;
    background: var(--wlc-white);
    border: 1px solid var(--wlc-border);
    border-radius: 22px;
    padding: clamp(28px, 3.4vw, 44px);
    box-shadow: var(--wlc-shadow-lg);
}

.wlc-entry__shell--tight {
    max-width: 520px;
    padding: 40px 36px;
    text-align: center;
}

.wlc-entry__header { text-align: center; margin-bottom: 24px; }

.wlc-entry__badge {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 5px 12px;
    border-radius: 999px;
    background: var(--wlc-primary-light);
    color: var(--wlc-primary-dark);
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 0.04em;
    margin-bottom: 14px;
}

.wlc-entry__title {
    font-family: var(--wlc-font-heading);
    font-size: clamp(28px, 2.4vw, 34px);
    font-weight: 400;
    letter-spacing: -0.02em;
    line-height: 1.15;
    color: var(--wlc-text);
    margin: 0 0 10px;
}

.wlc-entry__lede {
    max-width: 560px;
    margin: 0 auto;
    font-size: 15px;
    color: var(--wlc-text-muted);
    line-height: 1.5;
}

.wlc-entry__grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 18px;
    margin-bottom: 22px;
}

.wlc-entry__card {
    padding: 22px;
    border-radius: var(--wlc-radius-xl);
    border: 1px solid var(--wlc-border);
    background: var(--wlc-white);
    display: flex;
    flex-direction: column;
    min-height: 200px;
    transition: all var(--wlc-transition);
}

.wlc-entry__card--new {
    background: linear-gradient(180deg, #F6FBF8 0%, #E8F5EE 100%);
    border-color: rgba(27, 122, 90, 0.2);
}

.wlc-entry__card:hover {
    box-shadow: var(--wlc-shadow-md);
    transform: translateY(-2px);
}

.wlc-entry__icon {
    width: 40px;
    height: 40px;
    border-radius: 12px;
    background: var(--wlc-primary);
    color: var(--wlc-white);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 12px;
    box-shadow: 0 6px 18px rgba(27, 122, 90, 0.22);
}

.wlc-entry__icon--alert {
    background: #D32F2F;
    box-shadow: 0 8px 22px rgba(211, 47, 47, 0.2);
}

.wlc-entry__card h2 {
    font-family: var(--wlc-font-heading);
    font-size: 19px;
    font-weight: 400;
    letter-spacing: -0.01em;
    margin: 0 0 6px;
    color: var(--wlc-text);
}

.wlc-entry__card p {
    margin: 0 0 14px;
    font-size: 14px;
    color: var(--wlc-text-muted);
    line-height: 1.5;
}

.wlc-entry__btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 18px;
    border-radius: 10px;
    font-size: 14px;
    font-weight: 600;
    text-decoration: none;
    transition: all var(--wlc-transition);
    margin-top: auto;
    align-self: flex-start;
    border: 1.5px solid transparent;
    line-height: 1;
}

.wlc-entry__btn--primary {
    background: var(--wlc-primary);
    color: var(--wlc-white);
    box-shadow: 0 6px 18px rgba(27, 122, 90, 0.22);
}

.wlc-entry__btn--primary:hover {
    background: var(--wlc-primary-dark);
    transform: translateY(-1px);
    box-shadow: 0 8px 22px rgba(27, 122, 90, 0.3);
    color: var(--wlc-white);
}

.wlc-entry__btn--ghost {
    background: transparent;
    color: var(--wlc-primary-dark);
    border-color: var(--wlc-primary);
}

.wlc-entry__btn--ghost:hover {
    background: var(--wlc-primary);
    color: var(--wlc-white);
}

.wlc-entry__footer {
    border-top: 1px solid var(--wlc-border);
    padding-top: 22px;
    display: flex;
    flex-direction: column;
    gap: 14px;
    align-items: center;
}

.wlc-entry__trust {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 22px;
    color: var(--wlc-text-light);
    font-size: 12px;
}

.wlc-entry__trust span {
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

.wlc-entry__trust .wlc-icon { color: var(--wlc-primary); }

.wlc-entry__compliance {
    margin: 0;
    max-width: 560px;
    text-align: center;
    font-size: 13px;
    line-height: 1.55;
    color: var(--wlc-text-muted);
}

.wlc-entry__help {
    margin: 0;
    font-size: 13px;
    color: var(--wlc-text-muted);
}

.wlc-entry__help a {
    color: var(--wlc-primary-dark);
    font-weight: 600;
    text-decoration: underline;
    text-underline-offset: 2px;
}

.wlc-entry--error .wlc-entry__title { font-size: 26px; }

/* ══════════════════════════════════════════════════════════════
   BOOKING + CHECK-IN legacy shortcodes (keep working)
   ══════════════════════════════════════════════════════════════ */

.wlc-booking,
.wlc-checkin {
    max-width: 720px;
    margin: 32px auto;
    padding: 24px;
    font-family: var(--wlc-font-body);
    color: var(--wlc-text);
}

.wlc-booking__header h2,
.wlc-checkin h2,
.wlc-notice h3 {
    font-family: var(--wlc-font-heading);
    font-size: 28px;
    font-weight: 400;
    color: var(--wlc-text);
    margin: 0 0 8px;
}

.wlc-booking__calendly {
    border: 1px solid var(--wlc-border);
    border-radius: var(--wlc-radius-lg);
    overflow: hidden;
    margin-top: 16px;
    background: var(--wlc-white);
}

.wlc-text-muted { color: var(--wlc-text-light); font-size: 14px; }

.wlc-form-group { margin-bottom: 20px; }

.wlc-form-group label {
    display: block;
    font-weight: 600;
    margin-bottom: 8px;
    color: var(--wlc-text);
    font-size: 14px;
}

.wlc-form-group input[type="number"],
.wlc-form-group input[type="text"],
.wlc-form-group textarea {
    width: 100%;
    padding: 12px 14px;
    border: 1.5px solid var(--wlc-border);
    border-radius: 10px;
    font-size: 15px;
    font-family: inherit;
    background: var(--wlc-white);
    box-sizing: border-box;
}

.wlc-form-group input:focus,
.wlc-form-group textarea:focus {
    outline: none;
    border-color: var(--wlc-primary);
    box-shadow: 0 0 0 3px rgba(27, 122, 90, 0.1);
}

.wlc-form-help { font-size: 13px; color: var(--wlc-text-light); margin-top: 4px; }
.required { color: #D32F2F; }

.wlc-status-badge {
    display: inline-block;
    padding: 6px 14px;
    border-radius: 999px;
    font-size: 13px;
    font-weight: 600;
    margin-bottom: 12px;
    background: var(--wlc-primary-light);
    color: var(--wlc-primary-dark);
}

/* ══════════════════════════════════════════════════════════════
   RESPONSIVE
   ══════════════════════════════════════════════════════════════ */

@media (max-width: 900px) {
    .wlc-portal__body {
        grid-template-columns: 1fr;
        gap: 20px;
        padding: 24px 20px 64px;
    }

    .wlc-portal__nav {
        position: fixed;
        top: var(--wlc-topbar-h);
        left: 0;
        bottom: 0;
        width: 280px;
        max-width: 80vw;
        padding: 20px 16px;
        background: var(--wlc-white);
        border-right: 1px solid var(--wlc-border);
        z-index: 50;
        transform: translateX(-100%);
        transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
        overflow-y: auto;
        box-shadow: 0 12px 40px rgba(0, 0, 0, 0.08);
    }

    .wlc-portal[data-nav-open="true"] .wlc-portal__nav {
        transform: translateX(0);
    }

    .wlc-portal__nav-toggle { display: inline-flex; }

    .wlc-portal[data-nav-open="true"]::before {
        content: '';
        position: fixed;
        inset: var(--wlc-topbar-h) 0 0 0;
        background: rgba(0, 0, 0, 0.35);
        z-index: 40;
    }
}

@media (max-width: 640px) {
    .wlc-portal__main { gap: 32px; }

    .wlc-h1 { font-size: 28px; }
    .wlc-lede { font-size: 15px; }

    .wlc-action { padding: 24px; border-radius: var(--wlc-radius-lg); }
    .wlc-action__title { font-size: 22px; }
    .wlc-action__desc { font-size: 14px; }

    .wlc-path { margin-top: 22px; }
    .wlc-path__label { font-size: 10px; }

    .wlc-appt { flex-direction: column; padding: 20px; }
    .wlc-appt__date { width: 72px; }

    .wlc-support { flex-direction: column; align-items: flex-start; gap: 12px; padding: 20px; }
    .wlc-strip { flex-direction: column; align-items: flex-start; padding: 16px 18px; }

    .wlc-entry { padding: 32px 16px; }
    .wlc-entry__shell { padding: 32px 22px; border-radius: 18px; }
    .wlc-entry__title { font-size: 30px; }
    .wlc-entry__grid { grid-template-columns: 1fr; }
    .wlc-entry__card { padding: 22px; }

    .wlc-kv > div { flex-direction: column; align-items: flex-start; gap: 4px; }
    .wlc-kv dd { text-align: left; }
}

@media (max-width: 420px) {
    .wlc-portal__topbar-inner { padding: 0 16px; }
    .wlc-portal__brand-name { display: none; }
}
