/* =========================================================
   app-extras.css — komponenty platformowe spoza designu QAH
   oraz mappingi starych klas (z dynamicznego JS) na wygląd QAH
   ========================================================= */

/* ─── Mode switch — segmented control (Email vs SMS+MMS+RCS teaser) ─── */
.mode-switch {
    display: inline-flex;
    gap: 2px;
    padding: 3px;
    background: var(--neutral-100);
    border-radius: 999px;
}

.mode-switch__btn {
    position: relative;
    appearance: none;
    border: 0;
    background: transparent;
    font: 500 12.5px/1 var(--font-sans);
    letter-spacing: -0.1px;
    color: var(--fg-2);
    padding: 7px 14px;
    border-radius: 999px;
    cursor: pointer;
    transition: color 120ms ease, background 120ms ease;
    white-space: nowrap;
}

.mode-switch__btn:hover { color: var(--fg-1); }

.mode-switch__btn--active {
    background: #fff;
    color: var(--fg-1);
    box-shadow: var(--shadow-xs);
    cursor: default;
}

.mode-switch__btn--active:hover { color: var(--fg-1); }

.mode-switch__tip {
    display: none;
    position: absolute;
    top: calc(100% + 8px);
    left: 50%;
    transform: translateX(-50%);
    background: var(--neutral-800);
    color: #fff;
    padding: 6px 10px;
    border-radius: var(--radius-md);
    font: 500 12px/1.2 var(--font-sans);
    white-space: nowrap;
    z-index: 200;
    box-shadow: var(--shadow-md);
    pointer-events: none;
}

.mode-switch__tip::before {
    content: "";
    position: absolute;
    bottom: 100%;
    left: 50%;
    transform: translateX(-50%);
    border: 5px solid transparent;
    border-bottom-color: var(--neutral-800);
}

.mode-switch__tip.is-visible { display: block; }

/* ─── Flash messages ─── */
.flash {
    padding: 12px 16px;
    border-radius: var(--radius-md);
    margin-bottom: 20px;
    font: 500 13.5px/1.4 var(--font-sans);
    border: 1px solid transparent;
}

.flash--error {
    background: color-mix(in oklab, var(--error) 8%, white);
    border-color: color-mix(in oklab, var(--error) 20%, transparent);
    color: color-mix(in oklab, var(--error) 75%, black);
}

.flash--success {
    background: color-mix(in oklab, var(--success) 10%, white);
    border-color: color-mix(in oklab, var(--success) 25%, transparent);
    color: color-mix(in oklab, var(--success) 75%, black);
}

.nav__logout-form {
    display: inline;
    margin: 0;
}

/* ─── Animowane orby na ekranie logowania (hero column) ─── */
/* Nadpisuje statyczny radial-gradient z qah-app.css o dwa dryfujące, oddychające orby */
.login-hero-col::before {
    content: "";
    position: absolute;
    width: 90%;
    height: 90%;
    top: -15%;
    left: -15%;
    background: radial-gradient(circle, color-mix(in oklab, var(--accent) 55%, transparent) 0%, transparent 60%);
    filter: blur(30px);
    animation: orbDriftA 20s ease-in-out infinite alternate, orbBreath 7s ease-in-out infinite;
    pointer-events: none;
    will-change: transform, opacity;
}

.login-hero-col::after {
    content: "";
    position: absolute;
    width: 60%;
    height: 60%;
    bottom: -20%;
    right: -15%;
    background: radial-gradient(circle, color-mix(in oklab, var(--accent) 35%, transparent) 0%, transparent 65%);
    filter: blur(50px);
    animation: orbDriftB 26s ease-in-out infinite alternate, orbBreath 9s ease-in-out -2.5s infinite;
    pointer-events: none;
    will-change: transform, opacity;
}

@keyframes orbDriftA {
    0%   { transform: translate(0, 0) scale(1); }
    50%  { transform: translate(18%, 12%) scale(1.08); }
    100% { transform: translate(35%, 28%) scale(1.18); }
}

@keyframes orbDriftB {
    0%   { transform: translate(0, 0) scale(1); }
    50%  { transform: translate(-14%, -10%) scale(0.92); }
    100% { transform: translate(-28%, -22%) scale(1.12); }
}

@keyframes orbBreath {
    0%, 100% { opacity: 0.65; }
    50%      { opacity: 1; }
}

/* ─── Login hero: canvas particle network ─── */
#login-particles {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    mix-blend-mode: screen;
    pointer-events: none;
    z-index: 1;
}

/* ─── Login hero: orbit decoration (3 pierścienie z kropkami) ─── */
.orbit-decoration {
    position: absolute;
    right: -80px;
    top: 8%;
    width: 340px;
    height: 340px;
    pointer-events: none;
    z-index: 1;
}

.orbit-decoration__ring {
    position: absolute;
    border-radius: 50%;
    will-change: transform;
}

.orbit-decoration__ring--outer {
    inset: 0;
    border: 1px dashed rgba(243, 89, 38, 0.3);
    animation: spinSlow 30s linear infinite;
}

.orbit-decoration__ring--middle {
    inset: 40px;
    border: 1px dashed rgba(247, 113, 59, 0.25);
    animation: spinSlow 22s linear infinite reverse;
}

.orbit-decoration__ring--inner {
    inset: 90px;
    border: 1px solid rgba(243, 89, 38, 0.15);
    animation: spinSlow 40s linear infinite;
}

.orbit-decoration__dot {
    position: absolute;
    border-radius: 50%;
}

.orbit-decoration__dot--top {
    top: -4px;
    left: 50%;
    width: 8px;
    height: 8px;
    background: var(--brand-500);
    box-shadow: 0 0 16px var(--brand-500);
    transform: translateX(-50%);
}

.orbit-decoration__dot--bottom {
    bottom: -3px;
    left: 30%;
    width: 6px;
    height: 6px;
    background: #FF8F66;
    box-shadow: 0 0 12px #FF8F66;
}

@keyframes spinSlow {
    to { transform: rotate(360deg); }
}

/* Treść hero ponad canvasem i orbitami */
.login-hero-inner {
    position: relative;
    z-index: 2;
}

/* Tytuł hero na biało (nadpisuje globalne h2 color z qah-tokens.css) */
.login-hero__title {
    color: #fff;
}

/* Gradient highlight w tytule hero (źródło: Login.jsx z QAH Hub) */
.login-hero__title-highlight {
    background: linear-gradient(90deg, #F35926, #FF8F66);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
}

/* Dostępność: nie animuj jeśli użytkownik woli zredukowany ruch */
@media (prefers-reduced-motion: reduce) {
    .login-hero-col::before,
    .login-hero-col::after,
    .orbit-decoration__ring--outer,
    .orbit-decoration__ring--middle,
    .orbit-decoration__ring--inner {
        animation: none;
    }
}

/* ─── Picker miesiąca w nagłówku tygodnia (Skocz do miesiąca) ─── */
.calendar__month-picker {
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

.calendar__month-picker-label {
    font: 500 12.5px/1 var(--font-sans);
    color: var(--fg-2);
    letter-spacing: -0.1px;
}

#week-month-picker {
    min-width: 200px;
}

/* ─── Searchable select (custom dropdown z wyszukiwarką) — adaptacja do QAH ─── */
.searchable-select {
    position: relative;
}

.searchable-select__input {
    width: 100%;
    font: 400 14px/1.3 var(--font-sans);
    padding: 10px 14px;
    border: 1px solid var(--border-2);
    border-radius: var(--radius-md);
    background: #fff;
    color: var(--fg-1);
    transition: border-color 120ms ease, box-shadow 120ms ease;
}

.searchable-select__input:focus {
    outline: none;
    border-color: var(--accent);
    box-shadow: 0 0 0 3px color-mix(in oklab, var(--accent) 18%, transparent);
}

.searchable-select__dropdown {
    display: none;
    position: absolute;
    top: calc(100% + 4px);
    left: 0;
    right: 0;
    max-height: 240px;
    overflow-y: auto;
    background: #fff;
    border: 1px solid var(--border-1);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-md);
    z-index: 300;
}

.searchable-select__dropdown--open {
    display: block;
}

.searchable-select__option {
    padding: 8px 14px;
    font: 400 13.5px/1.3 var(--font-sans);
    color: var(--fg-1);
    cursor: pointer;
    transition: background 100ms ease;
}

.searchable-select__option:hover,
.searchable-select__option--highlighted {
    background: var(--accent-tint);
    color: var(--accent-tint-fg);
}

.searchable-select__empty {
    padding: 10px 14px;
    font: 400 13px/1.3 var(--font-sans);
    color: var(--fg-3);
    font-style: italic;
}

/* ─── Panel "Dostępne terminy" — mapping na wygląd .available z QAH ─── */
.available-dates {
    background: #fff;
    border: 1px solid var(--border-1);
    border-radius: var(--radius-xl);
    overflow: hidden;
    margin-bottom: 24px;
}

.available-dates__toggle {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 20px;
    background: transparent;
    border: 0;
    font: 500 14px/1.2 var(--font-sans);
    color: var(--fg-1);
    cursor: pointer;
    text-align: left;
    transition: background 120ms ease;
}

.available-dates__toggle:hover { background: var(--neutral-50); }

.available-dates__icon {
    font-size: 16px;
    margin-right: 8px;
}

.available-dates__caret {
    color: var(--fg-3);
    font-size: 12px;
}

.available-dates__panel {
    border-top: 1px solid var(--border-1);
    padding: 18px 20px 20px;
    background: var(--neutral-50);
}

.available-dates__row {
    display: grid;
    grid-template-columns: 180px 1fr 32px;
    gap: 16px;
    padding: 10px 0;
    align-items: center;
    border-bottom: 1px dashed var(--border-1);
}

.available-dates__row:last-child { border-bottom: 0; }

.available-dates__row--adder {
    grid-template-columns: 180px 1fr;
}

.available-dates__label {
    font: 500 13px/1.2 var(--font-sans);
    color: var(--fg-1);
}

.available-dates__pills {
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
}

.available-dates__status {
    font: 400 12px/1.4 var(--font-sans);
    color: var(--fg-3);
    font-style: italic;
}

.available-dates__status--empty { color: var(--fg-3); }

.available-dates__add {
    appearance: none;
    border: 1px solid var(--border-2);
    background: #fff;
    color: var(--fg-1);
    font: 500 12.5px/1 var(--font-sans);
    padding: 7px 14px;
    border-radius: 999px;
    cursor: pointer;
    transition: all 120ms ease;
}

.available-dates__add:hover {
    border-color: var(--accent);
    color: var(--accent);
    background: var(--accent-tint);
}

.available-dates__remove {
    appearance: none;
    border: 0;
    background: transparent;
    color: var(--fg-3);
    width: 28px;
    height: 28px;
    border-radius: 999px;
    font-size: 16px;
    cursor: pointer;
    transition: all 120ms ease;
}

.available-dates__remove:hover {
    color: var(--error);
    background: color-mix(in oklab, var(--error) 8%, white);
}

.available-dates__specialist-picker {
    grid-column: 2 / 3;
    margin-top: 8px;
}

.available-dates__note {
    font: 400 12px/1.4 var(--font-sans);
    color: var(--fg-3);
    margin-top: 12px;
    font-style: italic;
}

/* Date suggestion button (używana w panel dostępnych terminów + popover move) */
.button--date-suggestion {
    appearance: none;
    border: 1px solid var(--border-2);
    background: #fff;
    color: var(--fg-1);
    font: 500 12px/1 var(--font-sans);
    padding: 6px 10px;
    border-radius: 999px;
    cursor: pointer;
    transition: all 120ms ease;
}

.button--date-suggestion:hover {
    border-color: var(--accent);
    color: var(--accent);
    background: var(--accent-tint);
}

/* ─── Move popover (przeniesienie wysyłki) — mapping na .popover z QAH ─── */
.move-popover {
    position: absolute;
    top: calc(100% + 6px);
    right: 8px;
    background: #fff;
    border: 1px solid var(--border-1);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-lg);
    padding: 14px;
    min-width: 240px;
    max-width: 280px;
    z-index: 30;
    animation: popIn 180ms ease;
}

.move-popover__header {
    font: 500 12px/1 var(--font-sans);
    letter-spacing: 0.4px;
    text-transform: uppercase;
    color: var(--fg-3);
    margin-bottom: 10px;
}

.move-popover__content {
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
    min-height: 32px;
}

.move-popover__loading,
.move-popover__empty {
    font: 400 12.5px/1.4 var(--font-sans);
    color: var(--fg-3);
    font-style: italic;
}

.move-popover__close {
    appearance: none;
    margin-top: 10px;
    width: 100%;
    background: transparent;
    border: 0;
    font: 500 12.5px/1 var(--font-sans);
    color: var(--fg-2);
    padding: 8px;
    border-radius: var(--radius-md);
    cursor: pointer;
    transition: all 120ms ease;
}

.move-popover__close:hover { background: var(--neutral-50); color: var(--fg-1); }

/* ─── History modal (timeline) — mapping na .overlay + .modal--wide + .timeline ─── */
.history-modal {
    position: fixed;
    inset: 0;
    z-index: 100;
    background: rgba(0, 0, 0, 0.35);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 40px 20px;
    animation: fadeIn 180ms ease;
}

.history-modal__content {
    background: #fff;
    border-radius: var(--radius-2xl);
    box-shadow: var(--shadow-xl);
    width: 100%;
    max-width: 720px;
    max-height: calc(100vh - 80px);
    display: flex;
    flex-direction: column;
    animation: popIn 240ms cubic-bezier(.2, .8, .2, 1);
    overflow: hidden;
}

.history-modal__header {
    padding: 22px 28px 14px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    border-bottom: 1px solid var(--border-1);
}

.history-modal__title {
    font: 600 20px/1.2 var(--font-sans);
    letter-spacing: -0.5px;
    color: var(--fg-1);
    margin: 0;
}

.history-modal__close {
    appearance: none;
    width: 32px;
    height: 32px;
    border-radius: 999px;
    background: transparent;
    border: 0;
    color: var(--fg-3);
    font-size: 20px;
    line-height: 1;
    display: grid;
    place-items: center;
    cursor: pointer;
    transition: all 120ms ease;
}

.history-modal__close:hover {
    background: var(--neutral-100);
    color: var(--fg-1);
}

.history-modal__meta {
    padding: 18px 28px;
    font: 400 13.5px/1.5 var(--font-sans);
    color: var(--fg-2);
}

.history-modal__meta-accent {
    display: inline-block;
    margin-top: 6px;
    color: var(--fg-1);
    font-weight: 500;
}

.history-modal__separator {
    height: 1px;
    background: var(--border-1);
}

.history-modal__timeline {
    padding: 24px 28px;
    overflow-y: auto;
    flex: 1;
    display: flex;
    flex-direction: column;
}

.history-modal__loading,
.history-modal__empty {
    font: 400 13px/1.4 var(--font-sans);
    color: var(--fg-3);
    font-style: italic;
}

.history-modal__entry {
    display: grid;
    grid-template-columns: 24px 1fr;
    gap: 14px;
}

.history-modal__dot-col {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding-top: 4px;
}

.history-modal__dot {
    width: 10px;
    height: 10px;
    border-radius: 999px;
    background: var(--accent);
    flex-shrink: 0;
}

.history-modal__line {
    flex: 1;
    width: 1px;
    background: var(--border-1);
    margin-top: 6px;
    min-height: 16px;
}

.history-modal__entry-content {
    padding-bottom: 20px;
}

.history-modal__action {
    font: 500 14px/1.3 var(--font-sans);
    color: var(--fg-1);
    letter-spacing: -0.1px;
}

.history-modal__entry-meta {
    font: 500 12px/1.3 var(--font-sans);
    color: var(--fg-3);
    margin-top: 2px;
}

.history-modal__detail {
    margin-top: 6px;
    padding: 8px 12px;
    background: var(--neutral-50);
    border-radius: var(--radius-md);
    font: 400 12.5px/1.5 var(--font-sans);
    color: var(--fg-2);
}

.history-modal__footer {
    padding: 18px 28px 22px;
    display: flex;
    justify-content: flex-end;
    gap: 10px;
    border-top: 1px solid var(--border-1);
}

.history-modal__btn {
    appearance: none;
    border: 1px solid var(--border-2);
    background: transparent;
    color: var(--fg-1);
    font: 500 14px/1 var(--font-sans);
    letter-spacing: -0.1px;
    padding: 10px 18px;
    border-radius: 999px;
    cursor: pointer;
    transition: all 120ms ease;
}

.history-modal__btn:hover {
    background: var(--neutral-50);
    border-color: var(--neutral-400);
}

/* ─── Confirm modal (Tak/Nie dialog) — mapping na .overlay + .modal ─── */
.confirm-modal {
    position: fixed;
    inset: 0;
    z-index: 110;
    background: rgba(0, 0, 0, 0.35);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 40px 20px;
    animation: fadeIn 180ms ease;
}

.confirm-modal__content {
    background: #fff;
    border-radius: var(--radius-2xl);
    box-shadow: var(--shadow-xl);
    width: 100%;
    max-width: 420px;
    display: flex;
    flex-direction: column;
    animation: popIn 240ms cubic-bezier(.2, .8, .2, 1);
    overflow: hidden;
}

.confirm-modal__header {
    padding: 22px 28px 8px;
}

.confirm-modal__title {
    font: 600 18px/1.2 var(--font-sans);
    letter-spacing: -0.4px;
    color: var(--fg-1);
    margin: 0;
}

.confirm-modal__body {
    padding: 12px 28px 24px;
    font: 400 14px/1.5 var(--font-sans);
    color: var(--fg-2);
}

.confirm-modal__footer {
    padding: 14px 24px 18px;
    display: flex;
    justify-content: flex-end;
    gap: 10px;
}

.confirm-modal__btn {
    appearance: none;
    border: 0;
    font: 500 14px/1 var(--font-sans);
    letter-spacing: -0.1px;
    padding: 10px 18px;
    border-radius: 999px;
    cursor: pointer;
    transition: all 120ms ease;
}

.confirm-modal__btn--secondary {
    background: transparent;
    color: var(--fg-1);
    border: 1px solid var(--border-2);
}

.confirm-modal__btn--secondary:hover {
    background: var(--neutral-50);
    border-color: var(--neutral-400);
}

.confirm-modal__btn--danger {
    background: var(--error);
    color: #fff;
    box-shadow: 0 4px 12px -2px color-mix(in oklab, var(--error) 40%, transparent);
}

.confirm-modal__btn--danger:hover {
    background: color-mix(in oklab, var(--error) 90%, black);
}

/* ─── Dispatch form modal (overlay z modal--wide w środku) ─── */
.dispatch-form-overlay {
    position: fixed;
    inset: 0;
    z-index: 100;
    background: rgba(0, 0, 0, 0.35);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
    align-items: center;
    justify-content: center;
    padding: 40px 20px;
    animation: fadeIn 180ms ease;
    display: none;
}

.dispatch-form-overlay.is-open {
    display: flex;
}


/* ─── Wysyłka — projektowa karta nad result-list w kroku 2 (info banner) ─── */
.confirm-banner {
    margin-bottom: 20px;
    padding: 12px 16px;
    background: var(--accent-tint);
    border-radius: var(--radius-md);
    color: var(--accent-tint-fg);
    font: 400 13.5px/1.5 var(--font-sans);
}

.confirm-banner strong { color: var(--accent-tint-fg); font-weight: 600; }

/* ─── Empty day cell w widoku tygodniowym (zachowanie naszej logiki) ─── */
.wk-day__empty-msg {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 60px;
    border: 1px dashed var(--border-2);
    border-radius: var(--radius-md);
    font: 500 12px/1 var(--font-sans);
    color: var(--fg-3);
    margin-top: auto;
}

/* ─── Monthly calendar tooltip (widok "Moje wysyłki") ─── */
/* Tooltip musi wyjść poza kafelek i poza grid — nadpisujemy overflow:hidden z qah-app */
.mn-grid {
    overflow: visible !important;
}

.mn-cell__item--has-tip {
    position: relative;
    overflow: visible !important;
}

/* Label projektu z ellipsis (osobny span — żeby tooltip mógł wyjść poza item) */
.mn-cell__item-label {
    display: block;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.mn-cell__item .monthly-calendar__tip,
.mn-cell__item--has-tip .monthly-calendar__tip {
    display: none;
    position: absolute;
    z-index: 50;
    bottom: calc(100% + 6px);
    left: 0;
    min-width: 220px;
    max-width: 320px;
    padding: 12px 14px;
    background: var(--neutral-800);
    color: #fff;
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-lg);
    font: 400 12px/1.5 var(--font-sans);
    white-space: normal;
    text-overflow: clip;
    pointer-events: none;
}

.mn-cell__item:hover .monthly-calendar__tip,
.mn-cell__item--has-tip:hover .monthly-calendar__tip {
    display: block;
}

.mn-cell__item .monthly-calendar__tip strong { color: #fff; font-weight: 600; }

.mn-cell__item small {
    font: 600 9px/1 var(--font-sans);
    letter-spacing: 0.5px;
    text-transform: uppercase;
    margin-left: 4px;
    padding: 1px 4px;
    background: var(--accent);
    color: #fff;
    border-radius: 3px;
}

/* ─── Admin: dropdown wyszukiwarka specjalizacji w widoku projektów ─── */
.admin-panel__spec-picker {
    position: relative;
    flex: 1;
    max-width: 280px;
}

.admin-panel__spec-dropdown {
    display: none;
    position: absolute;
    top: calc(100% + 4px);
    left: 0;
    right: 0;
    max-height: 220px;
    overflow-y: auto;
    background: #fff;
    border: 1px solid var(--border-1);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-md);
    z-index: 100;
}

.admin-panel__spec-dropdown--open { display: block; }

.admin-panel__spec-option {
    padding: 8px 14px;
    font: 400 13px/1.3 var(--font-sans);
    cursor: pointer;
    color: var(--fg-1);
    transition: background 100ms ease;
}

.admin-panel__spec-option:hover {
    background: var(--accent-tint);
    color: var(--accent-tint-fg);
}

/* ─── Tag specjalizacji (chip) na liście projektu ─── */
.spec-tag {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 4px 10px;
    font: 500 11.5px/1 var(--font-sans);
    border-radius: 999px;
    background: var(--bg-subtle);
    color: var(--fg-1);
    border: 1px solid var(--border-1);
}

.spec-tag--deleted {
    background: var(--neutral-100);
    color: var(--fg-3);
    text-decoration: line-through;
    border-color: transparent;
}

.spec-tag__delete {
    appearance: none;
    border: 0;
    background: transparent;
    color: var(--fg-3);
    cursor: pointer;
    font-size: 14px;
    line-height: 1;
    padding: 0 0 0 4px;
    transition: color 120ms ease;
}

.spec-tag__delete:hover { color: var(--error); }

/* Legenda statusów pod kalendarzem miesięcznym */
.mn-legend {
    margin-top: 20px;
    display: flex;
    gap: 14px;
    flex-wrap: wrap;
    font: 400 12px/1 var(--font-sans);
    color: var(--fg-2);
}

.mn-legend__chip {
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

.mn-legend__swatch {
    width: 10px;
    height: 10px;
    border-radius: 2px;
    display: inline-block;
}

/* ─── Deploy metadata footer (spec: docs/integrations/satellite-deploy.md §11) ───
   Pokazuje `rev <sha7>` + tooltip `<branch> @ <date>` żeby operator i user widzieli
   ktora wersja kodu chodzi na serwerze. Muted (~50% kontrastu) — nie odciaga uwagi
   od UI aplikacji. Renderowane PO `</main>` w views/layouts/main.php. */
.app-footer {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 8px;
    padding: 16px var(--page-gutter-sm);
    margin-top: var(--space-7);
    border-top: 1px solid var(--border-1);
    font: 400 11px/1.4 var(--font-sans);
    color: var(--fg-3);
}

.app-footer__sep {
    opacity: 0.6;
}

.app-footer__rev {
    font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
    font-variant-numeric: tabular-nums;
    cursor: help;
}

/* QAH Hub link w footerze — spójne z elo.qah.pl .sidebar-footer-brand
   (brand color + font-weight 700, external link icon obok tekstu). */
.app-footer__hub-link {
    display: inline-flex;
    align-items: center;
    gap: 3px;
    color: var(--brand-500);
    font-weight: 700;
    text-decoration: none;
    transition: color 0.15s ease;
}
.app-footer__hub-link:hover {
    color: var(--brand-600);
    text-decoration: underline;
}
.app-footer__hub-icon {
    opacity: 0.7;
    margin-left: 1px;
    transition: opacity 0.15s ease;
}
.app-footer__hub-link:hover .app-footer__hub-icon {
    opacity: 1;
}

/* ============================================================
   Login hub link — pill button "Zaloguj przez QAH Hub"
   Spójne z elo.qah.pl/public/admin/login.php (.login-hub-link).
   ============================================================ */
.login-hub-link {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    margin: 14px 0 24px;
    padding: 6px 14px;
    background: var(--neutral-0);
    border: 1px solid var(--border-1);
    border-radius: var(--radius-pill);
    font: 500 12px/1.2 var(--font-sans);
    color: var(--fg-2);
    text-decoration: none;
    transition: border-color 0.15s ease, color 0.15s ease, transform 0.15s ease;
}
.login-hub-link:hover {
    border-color: var(--brand-500);
    color: var(--brand-500);
    transform: translateY(-1px);
}
.login-hub-link:active {
    transform: translateY(0);
}
.login-hub-link__icon {
    opacity: 0.7;
    flex-shrink: 0;
}
.login-hub-link:hover .login-hub-link__icon {
    opacity: 1;
}
