/* ------------------------------------------------------------------ */
/* Accessibility utilities                                              */
/* ------------------------------------------------------------------ */

/* Visually hidden but accessible to screen readers */
.sw-sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0,0,0,0);
    white-space: nowrap;
    border: 0;
}

/* Skip-navigation link — hidden until focused */
.sw-skip-link {
    position: absolute;
    top: -100%;
    left: 8px;
    z-index: 9999;
    padding: 8px 16px;
    background: #222;
    color: #fff;
    font-size: 14px;
    border-radius: 0 0 6px 6px;
    text-decoration: none;
    transition: top 0.15s;
}
.sw-skip-link:focus {
    top: 0;
}

/* Restore visible focus for any interactive element that loses outline.
   This catches buttons, links, and inputs not covered by component rules. */
:focus-visible {
    outline: 2px solid var(--user-accent, #c77d2f);
    outline-offset: 2px;
}

:root {
    color-scheme: light;
    --user-bg: #ffffff;
    --user-surface: #f8f7f3;
    --user-card: #ffffff;
    --user-border: #e9e3d8;
    --user-text: #222222;
    --user-muted: #6c675f;
    --user-accent: #c77d2f;
    --user-accent-strong: #b36e27;
    --user-accent-soft: #fff3e4;
    --user-success-bg: #eef8f0;
    --user-success-text: #2c6a39;
    --user-shadow: 0 10px 30px rgba(43, 34, 17, 0.06);
}

*,
*::before,
*::after {
    box-sizing: border-box;
}

html,
body {
    margin: 0;
    min-height: 100%;
    background: var(--user-bg);
    color: var(--user-text);
    font-family: -apple-system, BlinkMacSystemFont, "Hiragino Sans", "Yu Gothic", sans-serif;
}

body.user-body {
    padding-bottom: 88px;
}

.user-shell {
    min-height: 100vh;
    background:
        radial-gradient(circle at top right, rgba(199, 125, 47, 0.08), transparent 24%),
        linear-gradient(180deg, #fff 0%, #fcfbf8 100%);
}

.user-container {
    --user-header-sticky-offset: 132px;
    width: min(100%, 860px);
    margin: 0 auto;
    padding: 0 16px;
}

.user-header {
    position: sticky;
    top: 0;
    z-index: 30;
    display: grid;
    gap: 14px;
    margin: 0 -16px 0;
    min-height: 132px;
    padding: 18px 20px 14px;
    overflow: hidden;
    background: #c98508;
}

.user-header__top {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 16px;
    min-height: 100%;
    position: relative;
    z-index: 1;
}

.user-brand {
    display: grid;
    gap: 4px;
    max-width: 60%;
}

.user-brand__eyebrow {
    margin: 0;
    color: rgba(255, 255, 255, 0.82);
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.user-brand__title {
    margin: 0;
    color: #fff;
    font-size: 34px;
    line-height: 1.15;
    font-weight: 800;
}

.user-brand__caption {
    margin: 0;
    color: rgba(255, 255, 255, 0.82);
    font-size: 14px;
    line-height: 1.5;
}

.user-brand__caption:empty {
    display: none;
}

.user-header__actions {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.user-header::after {
    content: "";
    position: absolute;
    top: 0;
    right: -10px;
    width: min(44vw, 180px);
    height: min(44vw, 180px);
    background: url("/image/givehan__logo_mark_w.svg") no-repeat top right / contain;
    opacity: 0.18;
    pointer-events: none;
}

.user-chip {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 36px;
    padding: 8px 14px;
    border: 1px solid var(--user-border);
    border-radius: 999px;
    background: #fff;
    color: var(--user-muted);
    text-decoration: none;
    font-size: 13px;
    font-weight: 700;
}

.user-main {
    display: grid;
    gap: 20px;
    padding-bottom: 20px;
}

.user-page-header {
    display: grid;
    gap: 8px;
}

.user-page-header__eyebrow {
    margin: 0;
    color: var(--user-accent);
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.user-page-title {
    margin: 0;
    font-size: 28px;
    line-height: 1.2;
}

.user-page-description {
    margin: 0;
    color: var(--user-muted);
    font-size: 14px;
    line-height: 1.6;
}

.user-back-link {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: var(--user-muted);
    text-decoration: none;
    font-size: 14px;
    font-weight: 600;
}

.user-back-link--spaced {
    margin-top: 20px;
}

.user-flash {
    margin-top: 20px;
    padding: 14px 16px;
    border-radius: 16px;
    background: var(--user-success-bg);
    color: var(--user-success-text);
    font-size: 14px;
    line-height: 1.6;
}

.user-surface,
.user-card,
.user-empty,
.user-search,
.user-detail-section,
.user-summary-card {
    border: 1px solid var(--user-border);
    border-radius: 22px;
    background: var(--user-card);
    box-shadow: var(--user-shadow);
}

.user-card,
.user-search,
.user-detail-section,
.user-summary-card {
    padding: 20px;
}

.user-empty {
    padding: 36px 24px;
    text-align: center;
    color: var(--user-muted);
    background: #fbfaf7;
}

.user-stack {
    display: grid;
    gap: 14px;
}

.user-inline {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}

.user-list {
    display: grid;
    gap: 14px;
}

.user-message-list {
    display: grid;
    border-top: 1px solid var(--user-border);
    border-bottom: 1px solid var(--user-border);
    background: #fff;
}

.user-message-row {
    padding: 16px 0;
    border-bottom: 1px solid var(--user-border);
}

.user-message-row:last-child {
    border-bottom: 0;
}

.user-message-row__body {
    display: grid;
    gap: 6px;
}

.user-message-row__header {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 12px;
}

.user-message-row__name,
.user-message-row__job,
.user-message-row__preview {
    margin: 0;
}

.user-message-row__name {
    font-size: 16px;
    line-height: 1.4;
}

.user-message-row__job {
    color: var(--user-text);
    font-size: 14px;
    font-weight: 600;
}

.user-message-row__preview,
.user-message-row__time {
    color: var(--user-muted);
    font-size: 13px;
    line-height: 1.5;
}

.user-profile-summary {
    display: grid;
    gap: 12px;
    padding: 18px 0;
}

.user-settings-section {
    display: grid;
    gap: 10px;
}

.user-settings-list {
    display: grid;
    border-top: 1px solid var(--user-border);
    border-bottom: 1px solid var(--user-border);
    background: #fff;
}

.user-settings-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 16px 0;
    border-bottom: 1px solid var(--user-border);
    color: var(--user-text);
    text-decoration: none;
}

.user-settings-item__meta {
    display: inline-flex;
    align-items: center;
    gap: 10px;
}

.user-settings-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 20px;
    height: 20px;
    padding: 0 6px;
    border-radius: 999px;
    background: #e14b2f;
    color: #fff;
    font-size: 11px;
    font-weight: 700;
    line-height: 1;
}

.user-settings-item:last-child {
    border-bottom: 0;
}

.user-settings-item--static {
    color: var(--user-muted);
}

.user-card {
    display: grid;
    gap: 16px;
}

.user-card__header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 12px;
}

.user-card__eyebrow {
    margin: 0 0 6px;
    color: var(--user-muted);
    font-size: 13px;
}

.user-card__title {
    margin: 0;
    font-size: 20px;
    line-height: 1.4;
}

.user-card__description {
    margin: 0;
    color: var(--user-muted);
    line-height: 1.6;
    font-size: 14px;
}

.user-card__footer {
    display: grid;
    gap: 10px;
}

.user-job-card__summary {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 16px;
    align-items: start;
}

.user-job-card__pay-block {
    display: grid;
    gap: 2px;
    min-width: 96px;
}

.user-job-card__pay-label {
    color: var(--user-accent-strong);
    font-size: 12px;
    font-weight: 700;
}

.user-job-card__pay {
    color: var(--user-accent-strong);
    font-size: 28px;
    line-height: 1;
    font-weight: 800;
}

.user-job-card__body {
    display: grid;
    gap: 4px;
    min-width: 0;
}

.user-job-card__time,
.user-job-card__location {
    margin: 0;
    color: var(--user-text);
    font-size: 15px;
    line-height: 1.5;
}

.user-job-card__location {
    color: var(--user-muted);
}

.user-application-card {
    display: grid;
    gap: 16px;
}

.user-application-card__main,
.user-application-card__details {
    display: grid;
    gap: 6px;
    min-width: 0;
}

.user-application-card__main .user-badge {
    justify-self: start;
}

.user-application-card__created-at {
    margin: 2px 0 0;
    display: grid;
    gap: 2px;
}

.user-application-card__created-label {
    color: rgba(100, 116, 139, 0.72);
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.02em;
}

.user-application-card__created-value {
    color: rgba(100, 116, 139, 0.76);
    font-size: 12px;
}

.user-application-card__detail {
    margin: 0;
    color: var(--user-text);
    font-size: 15px;
    line-height: 1.5;
}

.user-application-card__schedule {
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    gap: 4px 6px;
}

.user-application-card__date {
    font-weight: 700;
}

.user-application-card__time,
.user-application-card__separator {
    color: var(--user-muted);
}

.user-application-card__pay-label {
    margin-right: 6px;
    color: var(--user-accent-strong);
    font-size: 13px;
    font-weight: 700;
}

.user-application-card__pay-value {
    color: var(--user-accent-strong);
    font-size: 28px;
    line-height: 1;
    font-weight: 800;
}

.user-application-card__details .user-pay {
    display: flex;
    align-items: baseline;
    flex-wrap: wrap;
    gap: 4px;
    font-size: 17px;
}

.user-application-card__button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    min-height: 52px;
    padding: 14px 18px;
    border: 1px solid rgba(199, 125, 47, 0.16);
    border-radius: 16px;
    background: var(--user-accent-soft);
    color: var(--user-accent-strong);
    font-weight: 700;
    text-decoration: none;
    box-shadow: none;
}

/* ── Unified list card component ────────────────────────────────── */
.user-work-card {
    display: grid;
    gap: 10px;
}

.user-work-card__badge {
    justify-self: start;
}

.user-work-card__head {
    display: grid;
    gap: 3px;
}

.user-work-card__facility {
    margin: 0;
    font-size: 13px;
    color: var(--user-muted);
}

.user-work-card__title {
    margin: 0;
    font-size: 18px;
    font-weight: 700;
    line-height: 1.4;
}

.user-work-card__title a {
    color: inherit;
    text-decoration: none;
}

.user-work-card__meta {
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    gap: 4px 16px;
}

.user-work-card__schedule {
    font-size: 15px;
    color: var(--user-text);
}

.user-work-card__pay {
    font-size: 22px;
    font-weight: 800;
    line-height: 1;
    color: var(--user-accent-strong);
}

.user-work-card__location {
    font-size: 14px;
    color: var(--user-muted);
}

.user-work-card__note {
    margin: 0;
    font-size: 12px;
    color: var(--user-muted);
}

.user-work-card__sub {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 6px 10px;
}

.user-work-card__sub .user-badge {
    font-size: 11px;
    padding: 4px 10px;
}

.user-work-card__review {
    padding: 12px 14px;
    background: var(--user-surface);
    border-radius: 12px;
    font-size: 13px;
    display: grid;
    gap: 8px;
}

.user-work-card__review-label {
    margin: 0;
    font-size: 13px;
    font-weight: 700;
}

.user-work-card__review-stars {
    margin: 0;
    font-weight: 600;
}

.user-work-card__review-comment {
    margin: 0;
    color: var(--user-muted);
}

.user-work-card__review-stars-input {
    display: flex;
    gap: 4px;
    font-size: 22px;
}

.user-work-card__review-stars-input label {
    cursor: pointer;
    line-height: 1;
}

.user-work-card__review-comment-input {
    width: 100%;
    padding: 8px 10px;
    border: 1px solid var(--user-border);
    border-radius: 10px;
    font: inherit;
    font-size: 13px;
    resize: vertical;
    background: #fff;
    box-sizing: border-box;
}

.user-grid {
    display: grid;
    gap: 12px;
}

.user-grid--two {
    grid-template-columns: 1fr;
}

.user-meta {
    display: grid;
    gap: 12px;
}

.user-meta--identity {
    margin-top: 18px;
}

.user-meta__item {
    padding: 14px 16px;
    border-radius: 16px;
    background: var(--user-surface);
}

.user-meta__item--plain {
    padding: 0;
    border-radius: 0;
    background: transparent;
}

.user-meta__item--inline {
    display: flex;
    align-items: baseline;
    gap: 12px;
    justify-content: flex-start;
    flex-wrap: wrap;
}

.user-meta__item--inline .user-meta__label {
    margin: 0;
    flex: 0 0 72px;
}

.user-meta__item--inline .user-meta__value {
    font-size: 22px;
    line-height: 1.4;
}

.user-meta__label {
    display: block;
    margin-bottom: 6px;
    color: var(--user-muted);
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.user-meta__value {
    display: block;
    font-size: 15px;
    line-height: 1.6;
}

.user-pay {
    color: var(--user-accent-strong);
    font-size: 36px;
    font-weight: 700;
}

.user-meta__item--inline .user-meta__value.user-pay {
    font-size: 44px;
    line-height: 1.1;
}

.user-grid--job-conditions {
    gap: 16px;
}

.user-date-strong {
    font-weight: 700;
}

.user-detail-section__title {
    margin: 0 0 10px;
    font-size: 18px;
}

.user-detail-section__text {
    margin: 0;
    color: var(--user-muted);
    font-size: 14px;
    line-height: 1.7;
    white-space: pre-line;
}

.user-summary-card--plain,
.user-detail-section--plain {
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
    padding: 0 20px;
}

.user-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 7px 12px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 700;
    white-space: nowrap;
    border: 1px solid transparent;
}

.user-badge--pending {
    background: #fff7e6;
    color: #8a6200;
    border-color: #efddb0;
}

.user-badge--reviewing {
    background: #eef4ff;
    color: #2f4f9f;
    border-color: #c8d8ff;
}

.user-badge--approved {
    background: #eef8f0;
    color: #2c6a39;
    border-color: #cde3d0;
}

.user-badge--scheduled {
    background: #f0eefb;
    color: #4a3f9f;
    border-color: #ccc8f0;
}

.user-badge--completed {
    background: #f3f3f3;
    color: #616161;
    border-color: #dfdfdf;
}

/* Tone-based aliases used by StatusBadge helper */
.user-badge--warning {
    background: #fff7e6;
    color: #8a6200;
    border-color: #efddb0;
}

.user-badge--info {
    background: #eef4ff;
    color: #2f4f9f;
    border-color: #c8d8ff;
}

.user-badge--success {
    background: #eef8f0;
    color: #2c6a39;
    border-color: #cde3d0;
}

.user-badge--muted {
    background: #f3f3f3;
    color: #616161;
    border-color: #dfdfdf;
}

.user-badge--danger {
    background: #fef2f2;
    color: #b91c1c;
    border-color: #fca5a5;
}

.user-search {
    width: auto;
    margin-inline: -16px;
    border-radius: 0;
    position: sticky;
    top: var(--user-header-sticky-offset, 132px);
    z-index: 20;
    box-shadow: 0 10px 18px rgba(15, 23, 42, 0.08);
    display: grid;
    gap: 14px;
}

.user-search-panel {
    background: #f3f7f4;
    border-color: #e3ebe5;
    box-shadow: none;
}

.user-search.user-search-panel {
    padding: 14px 16px;
    margin-top: -1px;
    border-top: 0;
}

.user-search--flush-top {
    margin-top: -20px;
}

.user-search__title,
.user-section-title {
    margin: 0;
    font-size: 18px;
}

.user-search__form {
    display: grid;
    gap: 12px;
}

.user-search__row {
    display: grid;
    gap: 10px;
}

.user-search__row--primary {
    grid-template-columns: minmax(124px, auto) minmax(0, 1fr);
    align-items: center;
}

.user-field {
    display: grid;
    gap: 8px;
}

.user-chip--location {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    min-height: 36px;
    padding: 0 12px;
    border: 1px solid rgba(199, 125, 47, 0.35);
    border-radius: 999px;
    background: var(--user-accent-soft, #fdf4ea);
    color: var(--user-accent-strong, #7a4b2a);
    white-space: nowrap;
    font-size: 13px;
    font-weight: 600;
}

.user-chip--location .material-symbols-outlined {
    font-size: 18px;
    line-height: 1;
}

.user-search__row--primary .user-input {
    border-color: rgba(199, 125, 47, 0.22);
    background: var(--user-accent-soft);
    color: var(--user-accent-strong);
}

.user-search__row--primary .user-input::placeholder {
    color: rgba(143, 99, 32, 0.75);
}

.user-search-input-group {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
}

.user-search-input-group .user-input {
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
}

.user-search-submit {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 48px;
    min-height: 44px;
    padding: 0 14px;
    border: 1px solid var(--user-accent);
    border-left: 0;
    border-radius: 0 16px 16px 0;
    background: var(--user-accent);
    color: #fff;
    cursor: pointer;
}

.user-search-submit .material-symbols-outlined {
    font-size: 20px;
    line-height: 1;
}

.user-label {
    font-size: 14px;
    font-weight: 700;
}

.user-input,
.user-select,
.user-textarea {
    width: 100%;
    min-height: 50px;
    padding: 12px 14px;
    border: 1px solid var(--user-border);
    border-radius: 16px;
    background: #fff;
    color: var(--user-text);
    font: inherit;
    appearance: none;
}

.user-search .user-input,
.user-search .user-select {
    min-height: 44px;
    padding-top: 10px;
    padding-bottom: 10px;
}

.user-input:focus,
.user-select:focus,
.user-textarea:focus {
    /* box-shadow provides visual indicator; transparent outline preserves
       visibility in Windows High Contrast Mode */
    outline: 2px solid transparent;
    outline-offset: 1px;
    border-color: var(--user-accent);
    box-shadow: 0 0 0 4px rgba(199, 125, 47, 0.14);
}

.user-select {
    background-image:
        linear-gradient(45deg, transparent 50%, #8f775c 50%),
        linear-gradient(135deg, #8f775c 50%, transparent 50%);
    background-position:
        calc(100% - 22px) calc(50% - 2px),
        calc(100% - 16px) calc(50% - 2px);
    background-size: 6px 6px, 6px 6px;
    background-repeat: no-repeat;
    padding-right: 44px;
}

.user-textarea {
    min-height: 160px;
    resize: vertical;
}

.user-actions {
    display: grid;
    gap: 10px;
}

.user-actions--single {
    grid-template-columns: 1fr;
}

.user-button,
.user-button-secondary {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    min-height: 52px;
    padding: 14px 18px;
    border-radius: 16px;
    font-weight: 700;
    text-decoration: none;
    cursor: pointer;
    border: 1px solid transparent;
}

.user-button {
    background: var(--user-accent);
    color: #fff;
}

.user-button-secondary {
    background: var(--user-accent-soft);
    color: var(--user-accent-strong);
    border-color: rgba(199, 125, 47, 0.2);
}

.user-link-card {
    display: inline-flex;
    width: 100%;
    color: inherit;
    text-decoration: none;
}

.user-link-card > * {
    width: 100%;
}

.user-status-panel {
    display: grid;
    gap: 10px;
    padding: 16px;
    border-radius: 18px;
    background: var(--user-surface);
}

.user-cta-panel {
    display: grid;
    gap: 12px;
}

.user-note {
    margin: 0;
    color: var(--user-muted);
    font-size: 14px;
    line-height: 1.6;
}

.user-form {
    display: grid;
    gap: 18px;
}

.user-form__grid {
    display: grid;
    gap: 16px;
}

.user-form__field {
    display: grid;
    gap: 8px;
}

.user-form__error {
    margin: 0;
    color: #b42318;
    font-size: 13px;
    line-height: 1.5;
}

.user-card--qualification {
    grid-template-columns: 1fr;
    align-items: stretch;
}

.user-qualification-meta {
    display: grid;
    gap: 10px;
}

.user-qualification-actions {
    margin: 0;
}

.user-confirm-message {
    padding: 16px 18px;
    border: 1px solid rgba(199, 125, 47, 0.22);
    border-radius: 18px;
    background: var(--user-accent-soft);
}

.user-confirm-message--spaced {
    margin-top: 20px;
}

.user-confirm-message__text {
    margin: 0;
    color: var(--user-accent-strong);
    font-size: 16px;
    font-weight: 700;
    line-height: 1.5;
}

.user-hero {
    display: grid;
    gap: 16px;
    padding: 24px 20px;
}

.user-hero__actions {
    display: grid;
    gap: 10px;
}

.user-hero__panel {
    padding: 18px;
    border-radius: 18px;
    background: var(--user-accent-soft);
}

.user-hero__panel-title {
    margin: 0 0 8px;
    font-size: 16px;
}

.user-tabs {
    display: flex;
    gap: 8px;
    overflow-x: auto;
    padding: 4px;
    margin-top: 20px;
    border-radius: 18px;
    background: var(--user-surface);
}

.user-tab {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 1 0 auto;
    min-height: 42px;
    padding: 8px 16px;
    border-radius: 14px;
    background: transparent;
    color: var(--user-muted);
    font-size: 13px;
    font-weight: 700;
    text-decoration: none;
    white-space: nowrap;
}

.user-tab.is-active {
    background: var(--user-accent);
    color: #fff;
}

.user-bottom-nav {
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 50;
    width: 100%;
    padding: 0 0 env(safe-area-inset-bottom);
    background: #ffffff;
    border-top: 1px solid #e5e7eb;
    backdrop-filter: blur(12px);
}

.user-bottom-nav__inner {
    width: min(100%, 960px);
    margin: 0 auto;
    padding: 0 16px;
    display: flex;
    justify-content: space-between;
}

.user-bottom-nav a {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 8px 0;
    font-size: 12px;
    color: #4b5563;
}

.user-bottom-nav__item {
    display: flex;
    flex: 1 1 25%;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 4px;
    text-decoration: none;
    color: var(--user-muted);
    font-size: 11px;
    font-weight: 700;
}

.user-bottom-nav__icon-wrap {
    position: relative;
    display: inline-flex;
}

.user-bottom-nav__badge {
    position: absolute;
    top: -6px;
    right: -12px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 18px;
    height: 18px;
    padding: 0 5px;
    border: 2px solid #fff;
    border-radius: 999px;
    background: #e14b2f;
    color: #fff;
    font-size: 10px;
    font-weight: 700;
    line-height: 1;
}

.user-bottom-nav .material-symbols-outlined {
    font-size: 24px;
    line-height: 1;
    color: inherit;
}

.user-bottom-nav a.is-active {
    background: #d1fae5;
    color: #16a34a;
    font-weight: 600;
}

.nav-label {
    margin-top: 2px;
}

.user-bottom-nav__icon {
    width: 24px;
    height: 24px;
}

.user-bottom-nav__item.is-active .user-bottom-nav__icon {
    color: #16a34a;
}

.user-bottom-nav__item.is-active {
    color: #16a34a;
}

.user-bottom-nav a.is-active .material-symbols-outlined {
    color: #16a34a;
}

@media (min-width: 390px) {
    .user-search__row--secondary {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (min-width: 768px) {
    body.user-body {
        padding-bottom: 110px;
    }

    .user-container {
        --user-header-sticky-offset: 120px;
        padding: 0 24px;
    }

    .user-search {
        margin-inline: -24px;
    }

    .user-search.user-search-panel {
        padding: 20px;
    }

    .user-header {
        margin-left: -24px;
        margin-right: -24px;
        min-height: 120px;
        padding: 16px 28px 12px;
    }

    .user-header::after {
        top: 0;
        right: 8px;
        width: min(30vw, 220px);
        height: min(30vw, 220px);
    }

    .user-search .user-input,
    .user-search .user-select {
        min-height: 50px;
        padding-top: 12px;
        padding-bottom: 12px;
    }

    .user-brand__title {
        font-size: 30px;
    }

    .user-page-title {
        font-size: 34px;
    }

    .user-grid--two {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .user-actions {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .user-form__grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .user-card {
        grid-template-columns: auto minmax(0, 1fr) auto;
        align-items: center;
        gap: 20px;
    }

    .user-card--application {
        grid-template-columns: 1fr;
        align-items: stretch;
        gap: 16px;
    }

    .user-job-card__summary {
        grid-column: 1 / 3;
        grid-template-columns: auto minmax(0, 1fr);
        align-items: center;
    }

    .user-card__footer {
        align-self: center;
    }

    .user-card__footer .user-button-secondary {
        width: auto;
        justify-self: end;
        white-space: nowrap;
    }

    .user-application-card {
        grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr) auto;
        align-items: center;
        gap: 20px;
    }

    .user-application-card__button {
        min-height: 100%;
        padding-inline: 22px;
        border-radius: 0 16px 16px 0;
    }

    .user-application-card .user-card__footer {
        align-self: stretch;
        justify-self: stretch;
        margin: -20px -20px -20px 0;
    }

    /* Unified work-card responsive layout */
    .user-card:has(.user-work-card) {
        grid-template-columns: 1fr;
    }

    .user-work-card {
        grid-template-columns: 1fr auto;
        column-gap: 24px;
        align-items: start;
    }

    .user-work-card__badge,
    .user-work-card__head,
    .user-work-card__meta,
    .user-work-card__note,
    .user-work-card__sub,
    .user-work-card__review {
        grid-column: 1;
    }

    .user-work-card__footer {
        grid-column: 2;
        grid-row: 1 / -1;
        align-self: center;
    }

    .user-work-card__footer .user-button,
    .user-work-card__footer .user-button-secondary {
        width: auto;
        white-space: nowrap;
        padding-inline: 28px;
    }

    .user-work-card__footer form {
        display: contents;
    }

    .user-hero {
        grid-template-columns: minmax(0, 1.2fr) minmax(260px, 0.8fr);
        align-items: center;
    }

    .user-hero__actions {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .user-bottom-nav__inner {
        padding-inline: 24px;
    }
}

@media (min-width: 1024px) {
    .user-container {
        width: min(100%, 960px);
        padding-left: 32px;
        padding-right: 32px;
    }

    .user-header {
        margin-left: -32px;
        margin-right: -32px;
    }

    .user-search {
        margin-inline: -32px;
    }

    .user-bottom-nav__inner {
        padding-inline: 32px;
    }
}

/* T525 loading / pending / skeleton states */
form.is-pending {
    cursor: progress;
}

form[aria-busy="true"] .user-button,
form[aria-busy="true"] .user-button-secondary,
.user-button[aria-disabled="true"],
.user-button-secondary[aria-disabled="true"] {
    opacity: .72;
    cursor: wait;
}

.sw-loading-label {
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

.sw-skeleton {
    position: relative;
    overflow: hidden;
    min-height: 1em;
    border-radius: 8px;
    background: #ece7df;
    color: transparent;
}

.sw-skeleton::after {
    content: "";
    position: absolute;
    inset: 0;
    transform: translateX(-100%);
    background: linear-gradient(90deg, transparent, rgba(255,255,255,.62), transparent);
    animation: sw-skeleton-shimmer 1.4s ease-in-out infinite;
}

.sw-skeleton-card {
    min-height: 112px;
}

.sw-skeleton-row {
    height: 42px;
}

@keyframes sw-skeleton-shimmer {
    100% {
        transform: translateX(100%);
    }
}

/* ── Job search 2-row layout ──────────────────────────────────────── */

/* Row 1: location button + keyword */
.user-search__top-row {
    display: flex;
    gap: 8px;
    align-items: center;
}
.user-search__top-row__location {
    flex: 0 0 auto;
}
.user-search__top-row__keyword {
    flex: 1 1 auto;
    min-width: 0;
}

@media (max-width: 480px) {
    .user-search__top-row {
        flex-wrap: wrap;
    }
    .user-search__top-row__location {
        flex: 1 1 100%;
    }
}

/* Row 2: filters + nearby button */
.user-search__filter-row {
    display: flex;
    width: 100%;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
}
.user-search__filter-row__select {
    flex: 1 1 0;
    min-width: 0;
    max-width: none;
    min-height: 44px;
}
/* Override user-button's width:100% inside the filter row */
.user-search__filter-row__cta {
    flex: 0 0 auto;
    width: auto;
    min-height: 44px;
    padding: 0 16px;
    white-space: nowrap;
    display: inline-flex;
    align-items: center;
    gap: 5px;
    font-size: 14px;
    text-decoration: none;
}

@media (max-width: 480px) {
    .user-search__filter-row__select {
        flex: 1 1 calc(50% - 4px);
    }
    .user-search__filter-row__cta {
        flex: 1 1 100%;
        justify-content: center;
    }
}

/* ── CTA solo (single centered button) ───────────────────────────── */
.user-cta-solo {
    display: flex;
    justify-content: center;
}
.user-cta-solo .user-button {
    max-width: 360px;
    width: 100%;
    text-align: center;
}

/* ── Favorite icon button ─────────────────────────────────────────── */
.user-icon-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    border: 1px solid #d1d5db;
    background: #fff;
    color: #6b7280;
    cursor: pointer;
    flex-shrink: 0;
    padding: 0;
}
.user-icon-btn .material-symbols-outlined {
    font-size: 20px;
}
.user-icon-btn--active {
    background: #f4ebe4;
    border-color: #c9a98a;
    color: #7a4b2a;
}

/* ── Chat bubbles ────────────────────────────────────────────────── */
.user-chat-history {
    display: grid;
    gap: 10px;
    padding: 8px 0 16px;
}
.user-chat-bubble {
    max-width: 80%;
    display: flex;
    flex-direction: column;
    gap: 3px;
}
.user-chat-bubble__body {
    margin: 0;
    padding: 10px 14px;
    border-radius: 16px;
    font-size: 14px;
    line-height: 1.65;
    white-space: pre-wrap;
    word-break: break-word;
}
.user-chat-bubble__time {
    font-size: 11px;
    color: var(--user-text-muted, #888);
    padding: 0 4px;
}
.user-chat-bubble--facility {
    align-self: flex-start;
    align-items: flex-start;
}
.user-chat-bubble--facility .user-chat-bubble__body {
    background: #f1f5f9;
    color: #1e293b;
    border-bottom-left-radius: 4px;
}
.user-chat-bubble--user {
    align-self: flex-end;
    align-items: flex-end;
}
.user-chat-bubble--user .user-chat-bubble__body {
    background: var(--user-accent, #c77d2f);
    color: #fff;
    border-bottom-right-radius: 4px;
}
.user-chat-bubble--user .user-chat-bubble__time {
    text-align: right;
}
.user-chat-bubble--system {
    align-self: center;
    align-items: center;
    max-width: 90%;
}
.user-chat-bubble--system .user-chat-bubble__body {
    background: #edf3ff;
    color: #245b9b;
    font-size: 12px;
    text-align: center;
    border-radius: 999px;
    padding: 6px 14px;
}

/* ── Profile summary layout ───────────────────────────────────────── */
.user-profile-summary__header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
}
.user-profile-summary__status {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
}

/* ── Readiness indicator (passive, non-interactive) ──────────────── */
.user-readiness-chip {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 3px 8px 3px 6px;
    border-radius: 999px;
    background: #f3ede6;
    font-size: 12px;
    font-weight: 500;
    color: #7a5c3a;
    white-space: nowrap;
    pointer-events: none;
    user-select: none;
}
.user-readiness-pie {
    display: inline-block;
    width: 16px;
    height: 16px;
    border-radius: 50%;
    flex-shrink: 0;
}

/* ── Notification filter chips ───────────────────────────────────── */
.user-notif-filters {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    align-items: center;
}
.user-notif-filter {
    display: inline-flex;
    align-items: center;
    padding: 5px 12px;
    border-radius: 999px;
    border: 1px solid #d1d5db;
    background: #fff;
    color: var(--user-text, #1e293b);
    font-size: 13px;
    font-weight: 500;
    text-decoration: none;
    white-space: nowrap;
    transition: background .12s, color .12s, border-color .12s;
}
.user-notif-filter:hover {
    border-color: #9ca3af;
    background: #f9fafb;
}
.user-notif-filter.is-active {
    background: #1f2a44;
    color: #fff;
    border-color: #1f2a44;
}

@media (min-width: 600px) {
    .user-notif-filters {
        flex-wrap: nowrap;
        overflow-x: auto;
    }
}
