@charset "UTF-8";
:root {
  /* Marka (nadpisywane z CMS) — używane głównie do CTA, linków, akcentów. */
  --color-primary: #4b310d;
  /* Drugi ton witryny — ustawiany w CMS (Wygląd); domyślnie złoto #a29061. */
  --color-secondary: #a29061;
  --color-primary-hover: color-mix(in srgb, var(--color-primary) 85%, #000);
  /* Layout „clean”: biel + bardzo lekki szary na kartach / pasach (rozjaśnione tła). */
  --color-bg: #ffffff;
  --color-surface: #ffffff;
  --color-surface-soft: #fafaf8;
  --color-surface-strong: #f1efec;
  --color-border: #ebe8e4;
  --color-text: #1c1917;
  --color-text-muted: #57534e;
  --color-primary-rgb: 75, 49, 13;
  --color-secondary-rgb: 162, 144, 97;
  /* Akcenty UI (rgba(...)) — domyślnie jak secondary; nadpisywane z CMS. */
  --color-accent-rgb: 162, 144, 97;
  --color-shadow-rgb: 28, 25, 23;
  --color-header-bg: #ffffff;
  --color-header-border: #ebe8e4;
  --color-brand-text: #1c1917;
  --color-nav-link: #292524;
  --color-nav-link-hover: var(--color-secondary);
  --color-nav-hamburger: var(--color-nav-link);
  --color-submenu-bg: #ffffff;
  --color-mobile-nav-bg: #ffffff;
  --color-mobile-nav-border: #ebe8e4;
  --color-mobile-nav-link: #292524;
  --color-mobile-nav-link-hover: var(--color-secondary);
  /* Aktywna zakładka — subtelnie (nadpisywalne z motywu CMS). */
  --color-nav-link-active: color-mix(in srgb, var(--color-secondary) 82%, var(--color-nav-link) 18%);
  --color-nav-link-active-bg: color-mix(in srgb, var(--color-secondary) 6%, var(--color-surface));
  --color-nav-link-active-bar: color-mix(in srgb, var(--color-secondary) 42%, var(--color-border) 58%);
  --color-nav-link-hover-bg: color-mix(in srgb, var(--color-secondary) 8%, var(--color-surface));
  --color-nav-link-hover-bg-mobile: color-mix(in srgb, var(--color-secondary) 8%, var(--color-mobile-nav-bg));
  --color-nav-sublink-hover-bg: color-mix(in srgb, var(--color-secondary) 7%, var(--color-submenu-bg));
  --color-nav-sublink-active-bg: color-mix(in srgb, var(--color-secondary) 6%, var(--color-submenu-bg));
  --color-nav-sublink-active-bar: color-mix(in srgb, var(--color-secondary) 38%, var(--color-border) 62%);
  --color-trust-strip-bg: #fdfdfc;
  --color-trust-strip-text: #57534e;
  --color-link: var(--color-secondary);
  --color-link-hover: color-mix(in srgb, var(--color-secondary) 88%, #000);
  --color-on-primary: #fdfdfc;
  /* Tekst / ikony na wypełnionym przycisku secondary (tło = --color-secondary). */
  --color-on-secondary: var(--color-primary);
  --color-heading: #1c1917;
  --color-h1: var(--color-heading);
  --color-h2: var(--color-heading);
  --color-h3: var(--color-heading);
  /* Jasna stopka jak na typowych portalach hotelowych */
  --color-footer-bg: #fdfdfc;
  --color-footer-text: #292524;
  --color-footer-muted: #57534e;
  --color-footer-border: #ebe8e4;
  --color-footer-input-bg: #ffffff;
  /* Ikony / tekst na „kafelkach” w stopce (np. social) — domyślnie jak treść strony, żeby na jasnym tle przycisku było czytelnie przy ciemnym --color-footer-text. */
  --color-footer-social-fg: var(--color-text);
  --font-family-base:
    "Lab Grotesque",
    ui-sans-serif,
    system-ui,
    -apple-system,
    BlinkMacSystemFont,
    "Segoe UI",
    Roboto,
    "Helvetica Neue",
    Arial,
    "Noto Sans",
    sans-serif,
    "Apple Color Emoji",
    "Segoe UI Emoji",
    "Segoe UI Symbol",
    "Noto Color Emoji";
  --font-family-heading: var(--font-family-base);
  /* Bazowy tekst 1rem (16px); lead / h4 lekko większe, żeby zachować hierarchię względem base. */
  --font-size-base: 1rem;
  --font-size-sm: 0.875rem;
  --font-size-lead: 1.0625rem;
  --font-size-h1: clamp(1.85rem, 4vw, 2.5rem);
  --font-size-h2: 1.35rem;
  --font-size-h3: 1.125rem;
  --font-size-h4: 1.0625rem;
  --font-weight-body: 400;
  --font-weight-strong: 600;
  --font-weight-heading: 700;
  --font-weight-bold-max: 700;
  --line-height-body: 1.5;
  --letter-spacing-heading: -0.025em;
  --layout-radius: 0;
}

.ui-input,
.ui-select {
  border: 1px solid var(--color-border);
  border-radius: 8px;
  min-height: 44px;
  background: var(--color-surface);
}

.ui-location-form-panel {
  display: grid;
  gap: 1.25rem;
}

.ui-location-form-panel > .ui-form-section:last-of-type {
  margin-bottom: 0;
}

.ui-field-heading {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem 0.75rem;
  margin-bottom: 0.45rem;
}

.ui-field-heading .ui-label {
  margin-bottom: 0;
}

.ui-location-hero-preview {
  border: 1px solid var(--color-border);
  border-radius: 12px;
  overflow: hidden;
  background: var(--color-dashboard-bg);
  max-width: 22rem;
  margin-bottom: 1rem;
}

.ui-location-hero-preview__img {
  width: 100%;
  height: auto;
  display: block;
  aspect-ratio: 16/10;
  object-fit: cover;
}

.ui-location-remove-wrap {
  padding: 0 0 0.75rem;
}

.ui-location-dropzone {
  border: 2px dashed rgba(120, 113, 108, 0.45);
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.7);
  padding: 1.25rem 1rem;
  text-align: center;
  cursor: pointer;
  transition: border-color 0.2s ease, background 0.2s ease, box-shadow 0.2s ease;
  max-width: 28rem;
}
.ui-location-dropzone:hover, .ui-location-dropzone:focus-within {
  border-color: var(--color-primary);
  background: rgba(var(--color-dashboard-accent-rgb), 0.045);
  box-shadow: 0 0 0 3px rgba(var(--color-admin-tint-rgb), 0.12);
}
.ui-location-dropzone.is-dragover {
  border-color: var(--color-dashboard-accent);
  border-style: solid;
  background: rgba(var(--color-dashboard-accent-rgb), 0.07);
}
.ui-location-dropzone:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}

.ui-location-dropzone__icon {
  font-size: 2rem;
  color: var(--color-primary);
  line-height: 1;
  margin-bottom: 0.35rem;
  display: block;
}

.ui-location-dropzone__title {
  display: block;
  font-weight: 700;
  font-size: 0.95rem;
  color: var(--color-text);
}

.ui-location-dropzone__meta {
  display: block;
  margin-top: 0.35rem;
  font-size: 0.8rem;
  color: var(--color-text-muted);
  line-height: 1.45;
}

.ui-location-dropzone__filename {
  display: block;
  margin-top: 0.5rem;
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--color-dashboard-accent);
  word-break: break-word;
}

.ui-location-sticky-actions {
  position: sticky;
  bottom: 0;
  z-index: 20;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  margin-top: 1.25rem;
  margin-bottom: 0;
  padding: 1rem 0 calc(0.35rem + env(safe-area-inset-bottom, 0));
  background: linear-gradient(180deg, rgba(224, 226, 233, 0) 0%, rgba(224, 226, 233, 0.92) 28%, var(--color-dashboard-bg) 100%);
  border-top: 1px solid var(--color-border);
}

.ui-location-sticky-actions__hint {
  margin: 0;
  font-size: 0.8rem;
  color: var(--color-text-muted);
  max-width: 36ch;
}

.ui-location-faq-card .card-header {
  flex-wrap: wrap;
  gap: 0.5rem;
}

.ui-location-faq-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
}

.ui-location-faq-item {
  border: 1px solid var(--color-border);
  border-radius: 12px;
  padding: 0.85rem 1rem;
  background: #fff;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.ui-location-faq-item:hover {
  border-color: rgba(var(--color-admin-tint-rgb), 0.42);
  box-shadow: 0 4px 14px rgba(0, 0, 0, 0.04);
}

.ui-location-faq-item__q {
  font-weight: 700;
  color: var(--color-text);
  margin: 0 0 0.35rem;
  font-size: 0.95rem;
}

.ui-location-faq-item__a {
  margin: 0;
  font-size: 0.86rem;
  color: var(--color-text-muted);
  line-height: 1.5;
}

.ui-location-faq-item__actions {
  flex-shrink: 0;
}

.ui-location-faq-add {
  border: 1px dashed rgba(var(--color-admin-tint-rgb), 0.35);
  border-radius: 12px;
  padding: 1rem;
  background: rgba(255, 255, 255, 0.6);
  margin-top: 0.5rem;
}

.ui-location-faq-add__title {
  font-size: 0.88rem;
  font-weight: 700;
  color: var(--color-text);
  margin: 0 0 0.75rem;
}

.ui-location-url-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  margin-top: 0.35rem;
  padding: 0.2rem 0.55rem;
  border-radius: 8px;
  background: rgba(var(--color-dashboard-accent-rgb), 0.06);
  border: 1px solid var(--color-border);
  font-size: 0.82rem;
}

.ui-location-url-pill code {
  font-size: 0.8rem;
  color: var(--color-dashboard-accent);
  background: transparent;
}

.seo-page-form-panel {
  display: block;
  max-width: none;
  margin-inline: 0;
}

.seo-page-admin-page .ui-admin-form__lede {
  max-width: min(48rem, 100%);
}
.seo-page-admin-page .ui-admin-form__masthead-secondary {
  flex: 0 1 min(100%, 22rem);
}

.seo-page-form-context .badge {
  font-weight: 600;
}

.seo-admin-heading-level-col {
  min-width: 5.5rem;
}

.seo-page-intro-headings-field .js-seo-heading-row:last-child {
  margin-bottom: 0 !important;
}

.seo-form-quick-nav {
  padding: 0.85rem 1rem;
  margin-bottom: 1.35rem;
  border-radius: 0.85rem;
  background: rgba(255, 255, 255, 0.94);
  border: 1px solid rgba(15, 23, 42, 0.08);
  box-shadow: 0 2px 12px rgba(15, 23, 42, 0.04);
  position: sticky;
  top: 0.65rem;
  z-index: 12;
}

.seo-form-quick-nav__inner {
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
  width: 100%;
}

@media (min-width: 1200px) {
  .seo-form-quick-nav__inner {
    flex-direction: row;
    align-items: flex-end;
    flex-wrap: wrap;
    gap: 1rem 1.5rem;
  }
}
.seo-form-quick-nav__lead {
  flex: 0 0 auto;
  min-width: min(100%, 14rem);
}

.seo-form-quick-nav__hint {
  margin-top: 0.2rem;
  line-height: 1.35;
  max-width: 20rem;
}

.seo-form-quick-nav__groups {
  display: flex;
  flex-wrap: wrap;
  gap: 0.85rem 1.25rem;
  flex: 1 1 auto;
  align-items: flex-end;
}

.seo-form-quick-nav__group {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  padding-left: 0.65rem;
  border-left: 2px solid rgba(15, 23, 42, 0.08);
  min-width: 0;
}

.seo-form-quick-nav__group--all {
  border-left-color: color-mix(in srgb, var(--admin-accent, #206bc4) 35%, transparent);
}

.seo-form-quick-nav__group-label {
  font-size: 0.62rem;
  font-weight: var(--font-weight-bold-max);
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: var(--color-text-muted);
}

.seo-form-quick-nav__group-links {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
}

.seo-form-quick-nav__label {
  font-size: 0.68rem;
  font-weight: var(--font-weight-bold-max);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-text-muted);
  display: block;
}

.seo-form-quick-nav a {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  padding: 0.35rem 0.65rem;
  font-size: 0.8125rem;
  font-weight: 650;
  color: var(--color-text);
  text-decoration: none;
  border-radius: 0.5rem;
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: rgba(248, 250, 252, 0.9);
  transition: border-color 0.15s ease, background 0.15s ease, color 0.15s ease;
}

.seo-form-quick-nav a:hover {
  border-color: color-mix(in srgb, var(--admin-accent, #206bc4) 35%, transparent);
  background: color-mix(in srgb, var(--admin-accent, #206bc4) 8%, #fff);
  color: var(--admin-accent, #206bc4);
}

.seo-form-quick-nav a.is-active {
  border-color: color-mix(in srgb, var(--admin-accent, #206bc4) 55%, transparent);
  background: color-mix(in srgb, var(--admin-accent, #206bc4) 16%, #fff);
  color: var(--admin-accent, #206bc4);
}

.seo-form-panel[id] {
  scroll-margin-top: 6.75rem;
}

.seo-page-form-sticky {
  position: sticky;
  bottom: 0;
  z-index: 15;
  margin-top: 1rem;
  box-shadow: 0 -8px 24px rgba(0, 0, 0, 0.06);
}

.seo-slide-thumb {
  width: 48px;
  height: 48px;
  object-fit: cover;
  display: block;
}

.seo-gallery-thumb {
  height: 100px;
  object-fit: cover;
  width: 100%;
  display: block;
}

.min-h-40 {
  min-height: 2.5rem;
}

.seo-special-offer-uploader__drop {
  cursor: pointer;
  border-radius: 0.5rem;
  padding: 0.75rem;
  transition: background 0.15s ease, border-color 0.15s ease;
  outline: none;
}

.seo-special-offer-uploader__drop:hover,
.seo-special-offer-uploader__drop:focus-visible {
  background: rgba(var(--color-accent-rgb, 32, 107, 196), 0.06);
}

.seo-special-offer-uploader__drop--active {
  background: rgba(var(--color-accent-rgb, 32, 107, 196), 0.1);
}

.seo-special-offer-uploader__thumb {
  object-fit: cover;
  max-width: 100%;
  height: auto;
  max-height: 140px;
}

.seo-listing-filter-box .form-check {
  margin-bottom: 0.15rem;
}

.seo-page-content-source {
  min-height: 18rem;
  line-height: 1.45;
  font-size: 0.8125rem;
  tab-size: 2;
}

.seo-content-mode-switch .btn {
  min-width: 8.5rem;
}

.seo-pages-admin-page.seo-pages-admin-full {
  max-width: none;
}

.seo-pages-filter-fab {
  position: fixed;
  right: 1.15rem;
  bottom: 1.15rem;
  z-index: 1040;
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.7rem 1.2rem;
  border-radius: 999px;
  font-weight: 600;
  box-shadow: 0 4px 22px rgba(15, 23, 42, 0.18) !important;
}

.seo-pages-filter-fab--active {
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--color-primary, #206bc4) 45%, #fff), 0 4px 22px rgba(15, 23, 42, 0.18) !important;
}

.seo-pages-filter-fab__dot {
  position: absolute;
  top: 0.4rem;
  right: 0.55rem;
  width: 0.5rem;
  height: 0.5rem;
  border-radius: 50%;
  background: #fbbf24;
  border: 2px solid var(--color-primary, #206bc4);
}

.seo-pages-admin .seo-pages-hero {
  margin-bottom: 1rem;
}
.seo-pages-admin .seo-pages-tools,
.seo-pages-admin .seo-pages-legend,
.seo-pages-admin .seo-pages-filters,
.seo-pages-admin .seo-pages-quick-bar,
.seo-pages-admin .seo-pages-bulk-bar,
.seo-pages-admin .seo-pages-table-card,
.seo-pages-admin .seo-pages-search-spotlight {
  border-radius: 0.65rem;
  box-shadow: 0 2px 10px rgba(15, 23, 42, 0.05);
}
.seo-pages-admin .seo-pages-home-badge {
  max-width: 14rem;
  font-weight: 600;
  font-size: 0.8rem;
}
.seo-pages-admin .seo-pages-filters .card-header {
  background: linear-gradient(180deg, rgba(248, 250, 252, 0.95) 0%, rgba(255, 255, 255, 0.85) 100%);
  border-bottom: 1px solid rgba(15, 23, 42, 0.06);
}
.seo-pages-admin .seo-pages-search-compact .input-group-text {
  padding: 0.25rem 0.5rem;
}
.seo-pages-admin .seo-list-badge {
  font-size: 0.68rem;
  font-weight: 650;
  padding: 0.2rem 0.5rem;
  border-radius: 0.35rem;
  line-height: 1.2;
  letter-spacing: 0.01em;
}
.seo-pages-admin .seo-list-badge--auto {
  background: color-mix(in srgb, #f59e0b 18%, #fff);
  color: #92400e;
  border: 1px solid color-mix(in srgb, #f59e0b 35%, transparent);
}
.seo-pages-admin .seo-list-badge--cms {
  background: color-mix(in srgb, var(--color-primary, #206bc4) 14%, #fff);
  color: var(--color-primary, #206bc4);
  border: 1px solid color-mix(in srgb, var(--color-primary, #206bc4) 28%, transparent);
}
.seo-pages-admin .seo-list-badge--module {
  background: rgba(15, 23, 42, 0.06);
  color: #334155;
  border: 1px solid rgba(15, 23, 42, 0.08);
  font-weight: 600;
}
.seo-pages-admin .seo-list-badge--tile {
  background: color-mix(in srgb, #0d9488 14%, #fff);
  color: #0f766e;
  border: 1px solid color-mix(in srgb, #0d9488 28%, transparent);
}
.seo-pages-admin .seo-list-badge--offer {
  background: color-mix(in srgb, #db2777 12%, #fff);
  color: #9d174d;
  border: 1px solid color-mix(in srgb, #db2777 25%, transparent);
}
.seo-pages-admin .seo-list-badge--yes {
  background: color-mix(in srgb, #16a34a 14%, #fff);
  color: #166534;
  border: 1px solid color-mix(in srgb, #16a34a 28%, transparent);
}
.seo-pages-admin .seo-list-badge--no {
  background: rgba(100, 116, 139, 0.12);
  color: #475569;
  border: 1px solid rgba(100, 116, 139, 0.2);
}
.seo-pages-admin .seo-list-badge--muted {
  background: rgba(15, 23, 42, 0.06);
  color: #475569;
  font-weight: 600;
  font-size: 0.75rem;
}
.seo-pages-admin .seo-row-name {
  font-weight: 600;
  font-size: 0.875rem;
  line-height: 1.35;
}
.seo-pages-admin .seo-row-actions .btn {
  min-width: 1.75rem;
  min-height: 1.6rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.seo-pages-admin .seo-pages-table th,
.seo-pages-admin .seo-pages-table td {
  vertical-align: middle;
  padding: 0.9rem 1rem;
}
.seo-pages-admin .seo-pages-table thead th {
  padding-top: 0.85rem;
  padding-bottom: 0.85rem;
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--color-text-muted, #64748b);
}
.seo-pages-admin .seo-row-meta-title {
  max-width: min(36rem, 52vw);
  line-height: 1.35;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.seo-pages-admin .seo-pages-search-spotlight.card {
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: linear-gradient(135deg, color-mix(in srgb, var(--color-primary, #206bc4) 9%, var(--color-surface, #fff)) 0%, var(--color-surface, #fff) 55%);
}
.seo-pages-admin .seo-pages-search-spotlight .input-group-text {
  background: color-mix(in srgb, var(--color-primary, #206bc4) 15%, #fff);
  border-color: color-mix(in srgb, var(--color-primary, #206bc4) 30%, #dee2e6);
  color: var(--color-primary, #206bc4);
}
.seo-pages-admin .seo-pages-search-spotlight .form-control {
  border-color: color-mix(in srgb, var(--color-primary, #206bc4) 20%, #dee2e6);
}
.seo-pages-admin .seo-pages-bulk-bar {
  position: sticky;
  top: 0.75rem;
  z-index: 8;
}
.seo-pages-admin .seo-pages-table-card th {
  white-space: nowrap;
}

.ui-admin-preloader {
  position: fixed;
  inset: 0;
  z-index: 10800;
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.22s ease, visibility 0.22s ease;
}

.ui-admin-preloader.is-visible {
  pointer-events: auto;
  opacity: 1;
  visibility: visible;
}

.ui-admin-preloader__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(15, 12, 10, 0.45);
  backdrop-filter: blur(3px);
}

.ui-admin-preloader__panel {
  position: relative;
  z-index: 1;
  min-width: min(320px, 92vw);
  padding: 1.75rem 2rem;
  border-radius: 16px;
  background: var(--color-surface, #fff);
  border: 1px solid var(--color-border, #d6d3d1);
  box-shadow: 0 24px 64px rgba(0, 0, 0, 0.18);
  text-align: center;
}

.ui-admin-preloader__spinner {
  width: 2.75rem;
  height: 2.75rem;
  margin: 0 auto 1rem;
  border-radius: 50%;
  border: 3px solid rgba(var(--color-accent-rgb, 111, 90, 73), 0.2);
  border-top-color: var(--color-primary, #78716c);
  animation: ui-admin-preloader-spin 0.75s linear infinite;
}

.ui-admin-preloader__text {
  margin: 0;
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--color-text, #1c1917);
}

@keyframes ui-admin-preloader-spin {
  to {
    transform: rotate(360deg);
  }
}
html.ui-admin-preloader-lock,
html.ui-admin-preloader-lock body {
  overflow: hidden;
}

.ui-faq-admin {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
}

.ui-faq-admin__toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.65rem 1rem;
  padding: 1rem 1.15rem;
  border-radius: 14px;
  background: var(--color-surface-soft, #f5f5f4);
  border: 1px solid var(--color-border, #d6d3d1);
}

.ui-faq-admin__toolbar .btn {
  flex-shrink: 0;
}

.ui-faq-admin__list {
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
}

.ui-faq-admin__empty {
  margin: 0;
  padding: 1.5rem 1.25rem;
  text-align: center;
  color: var(--color-text-muted, #57534e);
  font-size: 0.95rem;
  border: 1px dashed var(--color-border, #d6d3d1);
  border-radius: 14px;
  background: var(--color-surface, #fff);
}

.ui-faq-admin-card {
  border: 1px solid var(--color-border);
  border-radius: 14px;
  background: var(--color-surface, #fff);
  padding: 0;
  border: 1px solid var(--color-border, #d6d3d1);
  overflow: hidden;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.ui-faq-admin-card:hover {
  border-color: rgba(var(--color-accent-rgb, 111, 90, 73), 0.35);
  box-shadow: 0 6px 22px rgba(0, 0, 0, 0.06);
}

.ui-faq-admin-card.is-preview .ui-faq-admin-card__preview {
  display: block;
}

.ui-faq-admin-card.is-editing .ui-faq-admin-card__view {
  display: none;
}

.ui-faq-admin-card.is-editing .ui-faq-admin-card__edit {
  display: block;
}

.ui-faq-admin-card__view {
  padding: 1rem 1.15rem;
}

.ui-faq-admin-card__question {
  margin: 0 0 0.5rem;
  font-size: 1.02rem;
  font-weight: 700;
  color: var(--color-text, #1c1917);
  line-height: 1.35;
  word-break: break-word;
}

.ui-faq-admin-card__snippet {
  margin: 0;
  font-size: 0.875rem;
  color: var(--color-text-muted, #57534e);
  line-height: 1.45;
  word-break: break-word;
}

.ui-faq-admin-card__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  margin-top: 0.85rem;
  padding-top: 0.85rem;
  border-top: 1px solid var(--color-border, #e7e5e4);
}

.ui-faq-admin-card__actions .btn {
  font-size: 0.8125rem;
  padding: 0.35rem 0.65rem;
}

.ui-faq-admin-card__preview {
  display: none;
  padding: 0.85rem 1.15rem 1.1rem;
  background: var(--color-surface-soft, #fafaf9);
  border-top: 1px solid var(--color-border, #e7e5e4);
}

.ui-faq-admin-card__preview-label {
  margin: 0 0 0.35rem;
  font-size: 0.68rem;
  font-weight: var(--font-weight-bold-max);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-text-muted, #78716c);
}

.ui-faq-admin-card__preview-body {
  margin: 0;
  font-size: 0.9rem;
  line-height: 1.55;
  color: var(--color-text, #292524);
  white-space: pre-wrap;
  word-break: break-word;
}

.ui-faq-admin-card__preview-close {
  margin-top: 0.75rem;
}

.ui-faq-admin-card__edit {
  display: none;
  padding: 1rem 1.15rem 1.15rem;
  background: linear-gradient(180deg, rgba(var(--color-accent-rgb, 111, 90, 73), 0.04) 0%, var(--color-surface, #fff) 100%);
  border-top: 1px solid var(--color-border, #e7e5e4);
}

.ui-faq-admin-card__edit .ui-label {
  margin-bottom: 0.35rem;
}

.ui-faq-admin-card__edit-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-top: 0.85rem;
}

.ui-faq-admin-compose {
  border: 1px solid var(--color-border);
  border-radius: 14px;
  background: var(--color-surface, #fff);
  padding: 1.1rem 1.15rem 1.2rem;
  border: 1px solid var(--color-border, #d6d3d1);
}

.ui-faq-admin-compose__title {
  margin: 0 0 0.85rem;
  font-size: 0.95rem;
  font-weight: var(--font-weight-bold-max);
  color: var(--color-text, #1c1917);
  display: flex;
  align-items: center;
  gap: 0.4rem;
}

.ui-faq-admin-compose__actions {
  margin-top: 0.85rem;
}

.ui-faq-admin-bulk {
  margin-top: 0.5rem;
}

@media (max-width: 576px) {
  .ui-faq-admin-card__actions {
    flex-direction: column;
    align-items: stretch;
  }
  .ui-faq-admin-card__actions .btn {
    width: 100%;
    justify-content: center;
  }
}
.site-settings-hub__nav {
  position: sticky;
  top: 1rem;
  z-index: 2;
}

.site-settings-hub__list {
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
}

.site-settings-hub__link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  padding: 0.55rem 0.75rem;
  border-radius: 10px;
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--color-text);
  text-decoration: none;
  transition: background 0.15s ease, color 0.15s ease;
}

.site-settings-hub__link:hover {
  background: rgba(var(--color-admin-tint-rgb), 0.08);
  color: var(--color-primary-hover);
}

.site-settings-hub__link.is-active {
  background: rgba(var(--color-dashboard-accent-rgb), 0.12);
  color: var(--color-dashboard-accent);
  box-shadow: inset 0 0 0 1px rgba(var(--color-dashboard-accent-rgb), 0.2);
}

.site-settings-hub__link.is-invalid {
  box-shadow: inset 0 0 0 1px rgba(185, 28, 28, 0.35);
}

.site-settings-hub__badge {
  flex-shrink: 0;
  min-width: 1.25rem;
  height: 1.25rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  font-size: 0.7rem;
  font-weight: var(--font-weight-bold-max);
  background: #b91c1c;
  color: #fff;
}

.site-settings-hub__panel {
  scroll-margin-top: 5.5rem;
  border: 1px solid var(--color-border);
  transition: box-shadow 0.2s ease, border-color 0.2s ease;
}

.site-settings-hub__panel--active {
  border-color: rgba(var(--color-dashboard-accent-rgb), 0.35);
  box-shadow: 0 8px 28px rgba(15, 15, 20, 0.06);
}

.site-settings-hub__aside {
  position: sticky;
  top: 1rem;
}

.site-settings-hub__form .invalid-feedback,
.site-settings-hub__form .form-error-message {
  display: block;
  margin-top: 0.25rem;
}

@media (max-width: 991px) {
  .site-settings-hub__nav {
    position: static;
  }
  .site-settings-hub__list {
    flex-direction: row;
    flex-wrap: wrap;
    gap: 0.35rem;
  }
  .site-settings-hub__link {
    padding: 0.4rem 0.65rem;
    font-size: 0.82rem;
  }
  .site-settings-hub__aside {
    position: static;
  }
}
body.admin-app .page {
  --admin-shell-radius: 1rem;
  --admin-shell-radius-lg: 1.25rem;
  --admin-shell-shadow: 0 1px 2px rgba(15, 23, 42, 0.04), 0 12px 32px -8px rgba(15, 23, 42, 0.12);
  --admin-shell-shadow-soft: 0 8px 24px rgba(15, 23, 42, 0.06);
  background: radial-gradient(1200px 480px at 12% -8%, color-mix(in srgb, var(--admin-accent, #206bc4) 10%, transparent), transparent 55%), radial-gradient(900px 400px at 88% 0%, color-mix(in srgb, var(--admin-accent, #206bc4) 8%, transparent), transparent 50%), var(--color-dashboard-bg);
}

body.admin-app .page-wrapper {
  min-height: 100vh;
}

body.admin-app .admin-sidebar {
  background: rgba(255, 255, 255, 0.92);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-right: 1px solid rgba(15, 23, 42, 0.06);
  box-shadow: 4px 0 32px rgba(15, 23, 42, 0.06);
}

body.admin-app .admin-topbar {
  background: rgba(255, 255, 255, 0.88);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(15, 23, 42, 0.06);
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.8) inset;
}

body.admin-app .ui-page {
  padding-bottom: 2.5rem;
}

body.admin-app .ui-card {
  border-radius: var(--admin-shell-radius-lg);
  border: 1px solid rgba(15, 23, 42, 0.07);
  box-shadow: var(--admin-shell-shadow-soft);
  background: rgba(255, 255, 255, 0.96);
  overflow: hidden;
}

body.admin-app .ui-header {
  margin-bottom: 1.5rem;
}

body.admin-app .ui-btn-primary {
  border-radius: 0.65rem;
  font-weight: 650;
  padding: 0.5rem 1.1rem;
  background: var(--admin-accent, #206bc4);
  border-color: var(--admin-accent, #206bc4);
  color: #fff;
  box-shadow: 0 2px 12px color-mix(in srgb, var(--admin-accent, #206bc4) 28%, transparent);
}

body.admin-app .ui-btn-primary:hover {
  background: color-mix(in srgb, var(--admin-accent, #206bc4) 88%, #0f172a);
  border-color: color-mix(in srgb, var(--admin-accent, #206bc4) 88%, #0f172a);
  color: #fff;
}

body.admin-app .btn.btn-primary:not(.ui-btn-outline) {
  --bs-btn-bg: var(--admin-accent, #206bc4);
  --bs-btn-border-color: var(--admin-accent, #206bc4);
  --bs-btn-hover-bg: color-mix(in srgb, var(--admin-accent, #206bc4) 88%, #0f172a);
  --bs-btn-hover-border-color: color-mix(in srgb, var(--admin-accent, #206bc4) 88%, #0f172a);
  --bs-btn-active-bg: color-mix(in srgb, var(--admin-accent, #206bc4) 82%, #0f172a);
  --bs-btn-active-border-color: color-mix(in srgb, var(--admin-accent, #206bc4) 82%, #0f172a);
  --bs-btn-focus-shadow-rgb: var(--color-dashboard-accent-rgb, 32, 107, 196);
  background-color: var(--admin-accent, #206bc4);
  border-color: var(--admin-accent, #206bc4);
  color: #fff;
}

body.admin-app .btn.btn-primary:not(.ui-btn-outline):hover,
body.admin-app .btn.btn-primary:not(.ui-btn-outline):focus-visible {
  background-color: color-mix(in srgb, var(--admin-accent, #206bc4) 88%, #0f172a);
  border-color: color-mix(in srgb, var(--admin-accent, #206bc4) 88%, #0f172a);
  color: #fff;
}

body.admin-app .ui-btn-outline {
  border-radius: 0.65rem;
  font-weight: 600;
}

body.admin-app .form-control,
body.admin-app .form-select {
  border-radius: 0.6rem;
  border-color: rgba(15, 23, 42, 0.1);
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

body.admin-app .form-control:focus,
body.admin-app .form-select:focus {
  border-color: color-mix(in srgb, var(--admin-accent, #206bc4) 45%, var(--color-border));
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--admin-accent, #206bc4) 18%, transparent);
}

body.admin-app .badge {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  font-size: 0.72rem;
  font-weight: 650;
  line-height: 1.2;
  letter-spacing: 0.02em;
  padding: 0.32rem 0.62rem;
  border-radius: 0.45rem;
  border: 1px solid transparent;
  vertical-align: middle;
  white-space: nowrap;
}
body.admin-app .admin-badge--neutral, body.admin-app .badge.ui-role-badge {
  color: #1e293b;
  background: rgba(148, 163, 184, 0.22);
  border-color: rgba(100, 116, 139, 0.28);
}
body.admin-app .admin-badge--primary, body.admin-app .badge.bg-primary {
  color: #fff;
  background: linear-gradient(145deg, #4f46e5 0%, #4338ca 100%);
  border-color: rgba(67, 56, 202, 0.45);
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.08);
}
body.admin-app .admin-badge--header {
  color: #0f172a;
  background: rgba(99, 102, 241, 0.16);
  border-color: rgba(79, 70, 229, 0.28);
}
body.admin-app .admin-badge--footer {
  color: #334155;
  background: rgba(148, 163, 184, 0.28);
  border-color: rgba(100, 116, 139, 0.32);
}
body.admin-app .admin-badge--floating {
  color: #0c4a6e;
  background: rgba(14, 165, 233, 0.2);
  border-color: rgba(2, 132, 199, 0.35);
}
body.admin-app .admin-badge--success, body.admin-app .badge.bg-success {
  color: #14532d;
  background: #bbf7d0;
  border-color: rgba(22, 163, 74, 0.4);
}
body.admin-app .admin-badge--muted, body.admin-app .badge.bg-secondary {
  color: #475569;
  background: #f1f5f9;
  border-color: #cbd5e1;
}
body.admin-app .admin-badge--warning, body.admin-app .badge.bg-warning,
body.admin-app .badge.bg-warning.text-dark {
  color: #78350f;
  background: #fde68a;
  border-color: rgba(217, 119, 6, 0.45);
}
body.admin-app .admin-badge--danger, body.admin-app .badge.bg-danger {
  color: #7f1d1d;
  background: #fecaca;
  border-color: rgba(220, 38, 38, 0.35);
}
body.admin-app .admin-badge--info, body.admin-app .badge.bg-azure, body.admin-app .badge.bg-info,
body.admin-app .badge.bg-info.text-dark {
  color: #0c4a6e;
  background: #bae6fd;
  border-color: rgba(14, 165, 233, 0.4);
}
body.admin-app .admin-badge--route {
  color: #5b21b6;
  background: #ede9fe;
  border-color: rgba(124, 58, 237, 0.3);
}
body.admin-app .admin-badge--seo {
  color: #134e4a;
  background: #ccfbf1;
  border-color: rgba(13, 148, 136, 0.35);
}
body.admin-app .admin-badge--url {
  color: #9a3412;
  background: #ffedd5;
  border-color: rgba(234, 88, 12, 0.35);
}
.ui-admin-form {
  max-width: 1120px;
  margin: 0 auto;
}

.ui-admin-form__masthead {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1.25rem 2rem;
  margin-bottom: 1.75rem;
  padding: 1.35rem 1.5rem;
  border-radius: var(--admin-shell-radius-lg, 1.25rem);
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.98) 0%, rgba(248, 250, 252, 0.95) 100%);
  border: 1px solid rgba(15, 23, 42, 0.07);
  box-shadow: var(--admin-shell-shadow-soft, 0 8px 24px rgba(15, 23, 42, 0.06));
}

.ui-admin-form__masthead-main {
  min-width: 0;
  flex: 1 1 16rem;
}

.ui-admin-form__masthead-secondary {
  flex: 0 1 min(100%, 320px);
  min-width: 0;
}

.ui-admin-form__masthead-aside {
  flex: 1 1 100%;
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: flex-end;
  gap: 0.5rem;
}

@media (min-width: 768px) {
  .ui-admin-form__masthead-aside {
    flex: 0 1 auto;
    justify-content: flex-end;
  }
}
.ui-admin-form__back {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--color-text-muted);
  margin-bottom: 0.65rem;
  text-decoration: none;
  transition: color 0.15s ease;
}

.ui-admin-form__back:hover {
  color: var(--color-primary);
}

.ui-admin-form__title {
  margin: 0;
  font-size: clamp(1.35rem, 2.5vw, 1.65rem);
  font-weight: var(--font-weight-bold-max);
  letter-spacing: -0.03em;
  color: var(--color-dashboard-accent);
  display: flex;
  align-items: center;
  gap: 0.55rem;
  flex-wrap: wrap;
}

.ui-admin-form__title .ti {
  font-size: 1.35rem;
  opacity: 0.85;
  color: var(--color-primary);
}

.ui-admin-form__lede {
  margin: 0.5rem 0 0;
  max-width: 42rem;
  font-size: 0.9375rem;
  line-height: 1.55;
  color: var(--color-text-muted);
}

.ui-admin-form__lede a {
  font-weight: 600;
}

.ui-admin-form__preview {
  flex: 0 1 min(100%, 320px);
  padding: 0.85rem 1rem;
  border-radius: 0.75rem;
  background: rgba(15, 23, 42, 0.04);
  border: 1px dashed rgba(15, 23, 42, 0.12);
}

.ui-admin-form__preview-label {
  display: block;
  font-size: 0.65rem;
  font-weight: var(--font-weight-bold-max);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-text-muted);
  margin-bottom: 0.35rem;
}

.ui-admin-form__preview code {
  font-size: 0.8125rem;
  word-break: break-all;
  color: var(--color-text);
  background: transparent;
}

.ui-admin-form__preview-link {
  display: block;
  font-size: 0.8125rem;
  font-weight: 650;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
  word-break: break-all;
  color: var(--color-primary);
  text-decoration: none;
}

.ui-admin-form__preview-link:hover {
  color: var(--color-primary-hover);
  text-decoration: underline;
}

.ui-admin-form__preview--empty {
  border-style: solid;
  background: rgba(245, 158, 11, 0.06);
  border-color: rgba(245, 158, 11, 0.25);
  color: #92400e;
  font-size: 0.875rem;
  line-height: 1.45;
}

.ui-admin-form__sheet {
  margin-bottom: 0.5rem;
}

.ui-admin-form__sheet > .card.ui-card {
  border-radius: var(--admin-shell-radius-lg, 1.25rem);
  border: 1px solid rgba(15, 23, 42, 0.07);
  box-shadow: var(--admin-shell-shadow-soft, 0 8px 24px rgba(15, 23, 42, 0.06));
  overflow: hidden;
  background: rgba(255, 255, 255, 0.98);
}

.ui-admin-form__sheet > .card.ui-card > .card-header {
  background: linear-gradient(180deg, rgba(248, 250, 252, 0.95) 0%, rgba(255, 255, 255, 0.6) 100%);
  border-bottom: 1px solid rgba(15, 23, 42, 0.06);
}

.ui-admin-form .ui-form-section {
  margin-bottom: 1.35rem;
  padding: 1.15rem 1.25rem;
  border-radius: var(--admin-shell-radius-lg, 1.15rem);
  border: 1px solid rgba(15, 23, 42, 0.07);
  background: rgba(255, 255, 255, 0.96);
  box-shadow: 0 4px 18px rgba(15, 23, 42, 0.04);
}

.ui-admin-form .ui-form-section:last-child {
  margin-bottom: 0;
}

.ui-admin-form .ui-form-section-title {
  margin-top: 0;
  margin-bottom: 0.65rem;
  font-size: 1rem;
  font-weight: 750;
  color: var(--color-dashboard-accent);
}

.ui-admin-form .ui-form-section > .ui-form-hint:first-of-type {
  margin-top: 0;
}

.ui-admin-form .seo-page-form-sticky {
  margin-top: 1.25rem;
  border-radius: var(--admin-shell-radius-lg, 1.25rem);
  border: 1px solid rgba(15, 23, 42, 0.08);
  box-shadow: 0 -4px 24px rgba(15, 23, 42, 0.06);
  position: sticky;
  bottom: 0.75rem;
  z-index: 8;
  background: rgba(255, 255, 255, 0.98);
}

.ui-surface-panel {
  border-radius: var(--admin-shell-radius-lg, 1.25rem);
  background: rgba(255, 255, 255, 0.96);
  border: 1px solid rgba(15, 23, 42, 0.07);
  box-shadow: var(--admin-shell-shadow-soft, 0 8px 24px rgba(15, 23, 42, 0.06));
  overflow: hidden;
  display: flex;
  flex-direction: column;
  min-height: 0;
  align-self: stretch;
}

.ui-surface-panel__head {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  padding: 1rem 1.25rem;
  border-bottom: 1px solid rgba(15, 23, 42, 0.06);
  background: linear-gradient(180deg, rgba(248, 250, 252, 0.9) 0%, rgba(255, 255, 255, 0.5) 100%);
}

.ui-surface-panel__icon {
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 0.65rem;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  background: linear-gradient(145deg, rgba(99, 102, 241, 0.12), rgba(14, 165, 233, 0.1));
  color: #4338ca;
  font-size: 1.25rem;
}

.ui-surface-panel__head-text {
  min-width: 0;
}

.ui-surface-panel__title {
  margin: 0;
  font-size: 1rem;
  font-weight: 750;
  color: var(--color-dashboard-accent);
}

.ui-surface-panel__meta {
  margin: 0.2rem 0 0;
  font-size: 0.8125rem;
  line-height: 1.45;
  color: var(--color-text-muted);
}

.ui-surface-panel__body {
  padding: 1.25rem;
  flex: 0 1 auto;
}

.ui-chip-group {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
}

.ui-chip {
  position: relative;
  cursor: pointer;
  margin: 0;
}

.ui-chip__input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.ui-chip__body {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.15rem;
  min-width: 8.5rem;
  padding: 0.75rem 1rem;
  border-radius: 0.75rem;
  border: 2px solid rgba(15, 23, 42, 0.08);
  background: rgba(255, 255, 255, 0.9);
  transition: border-color 0.15s ease, background 0.15s ease, box-shadow 0.15s ease;
}

.ui-chip:hover .ui-chip__body {
  border-color: rgba(99, 102, 241, 0.25);
  background: rgba(99, 102, 241, 0.03);
}

.ui-chip__input:focus-visible + .ui-chip__body {
  outline: 2px solid rgba(99, 102, 241, 0.5);
  outline-offset: 2px;
}

.ui-chip__input:checked + .ui-chip__body {
  border-color: rgba(99, 102, 241, 0.55);
  background: linear-gradient(145deg, rgba(99, 102, 241, 0.1), rgba(14, 165, 233, 0.06));
  box-shadow: 0 0 0 1px rgba(99, 102, 241, 0.15);
}

.ui-chip__icon {
  font-size: 1.15rem;
  color: var(--color-primary);
  margin-bottom: 0.15rem;
}

.ui-chip__title {
  font-size: 0.875rem;
  font-weight: 700;
  color: var(--color-text);
}

.ui-chip__desc {
  font-size: 0.75rem;
  color: var(--color-text-muted);
  line-height: 1.35;
}

.ui-admin-field-label,
.ui-admin-form__field-label {
  display: block;
  font-size: 0.78rem;
  font-weight: 750;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--color-text-muted);
  margin-bottom: 0.4rem;
}

.ui-admin-form__hint {
  font-size: 0.8125rem;
  color: var(--color-text-muted);
  line-height: 1.5;
  margin-top: 0.5rem;
}

.ui-admin-form__hint a {
  font-weight: 600;
}

.ui-admin-seo-results {
  --ui-seo-results-bg: #fff;
  --ui-seo-results-border: rgba(15, 23, 42, 0.12);
  --ui-seo-results-text: var(--color-text, #14141a);
  --ui-seo-results-muted: var(--color-text-muted, #5c5d68);
  max-height: 220px;
  overflow-y: auto;
  position: relative;
  z-index: 5;
  border-radius: 0.65rem;
  border: 1px solid var(--ui-seo-results-border);
  box-shadow: 0 8px 24px rgba(15, 23, 42, 0.12);
  background: var(--ui-seo-results-bg);
}
.ui-admin-seo-results .list-group-item,
.ui-admin-seo-results .list-group-item-action {
  background-color: var(--ui-seo-results-bg);
  color: var(--ui-seo-results-text);
  border-color: rgba(15, 23, 42, 0.1);
}
.ui-admin-seo-results button.list-group-item,
.ui-admin-seo-results button.list-group-item-action {
  width: 100%;
  font: inherit;
  line-height: 1.45;
  text-align: left;
  cursor: pointer;
}
.ui-admin-seo-results .list-group-item-action:hover,
.ui-admin-seo-results .list-group-item-action:focus {
  background-color: rgba(15, 15, 20, 0.07);
  color: var(--ui-seo-results-text);
}
.ui-admin-seo-results .list-group-item-action:focus-visible {
  outline: 2px solid rgba(63, 64, 76, 0.45);
  outline-offset: -2px;
}
.ui-admin-seo-results .list-group-item-secondary {
  background-color: #f1f2f5 !important;
  color: var(--ui-seo-results-muted) !important;
}
.ui-admin-seo-results .list-group-item-danger {
  background-color: #fef2f2 !important;
  color: #991b1b !important;
}
.ui-admin-seo-results code {
  color: #4338ca;
  background: rgba(67, 56, 202, 0.08);
  padding: 0.1rem 0.35rem;
  border-radius: 0.25rem;
}

.ui-admin-form__divider {
  height: 1px;
  margin: 1.25rem 0;
  background: linear-gradient(90deg, transparent, rgba(15, 23, 42, 0.08), transparent);
  border: 0;
}

.ui-admin-form__floating {
  border-radius: 0.85rem;
  border: 1px solid rgba(14, 165, 233, 0.2);
  background: linear-gradient(160deg, rgba(14, 165, 233, 0.06), rgba(99, 102, 241, 0.04));
  padding: 1rem 1.15rem;
}

.ui-admin-form__floating-title {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-weight: 750;
  font-size: 0.9375rem;
  margin: 0 0 0.35rem;
  color: var(--color-dashboard-accent);
}

.ui-admin-form__link-type {
  width: 100%;
  font-weight: 600;
}

.ui-admin-form__actions-lead {
  min-width: min(100%, 12rem);
}

.ui-admin-form__actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.65rem 1rem;
  margin-top: 1.75rem;
  padding: 1.1rem 1.25rem;
  border-radius: var(--admin-shell-radius-lg, 1.25rem);
  background: rgba(255, 255, 255, 0.95);
  border: 1px solid rgba(15, 23, 42, 0.08);
  box-shadow: 0 -4px 24px rgba(15, 23, 42, 0.06);
  position: sticky;
  bottom: 0.75rem;
  z-index: 10;
}

.seo-page-form-panel .ui-admin-form__actions {
  position: sticky;
  bottom: 0.65rem;
  z-index: 18;
  margin-top: 1.5rem;
  box-shadow: 0 4px 24px rgba(15, 23, 42, 0.08);
  background: rgba(255, 255, 255, 0.94);
  backdrop-filter: blur(10px);
}

.ui-admin-form .form-switch .form-check-input {
  width: 2.35rem;
  height: 1.2rem;
  cursor: pointer;
}

.ui-admin-form .form-switch .form-check-label {
  cursor: pointer;
  font-weight: 600;
  padding-top: 0.1rem;
}

@media (max-width: 767.98px) {
  .ui-admin-form__masthead {
    padding: 1rem 1.1rem;
  }
  .ui-admin-form__masthead-aside {
    justify-content: flex-start;
    width: 100%;
  }
  .ui-chip__body {
    min-width: 100%;
    width: 100%;
  }
}
.ui-quill-wrap.ui-quill-fullscreen {
  position: fixed;
  inset: 0;
  z-index: 1040;
  background: #fff;
  display: flex;
  flex-direction: column;
  padding: 0.5rem;
  box-shadow: 0 0 0 1px rgba(15, 23, 42, 0.08);
}

.ui-quill-wrap.ui-quill-fullscreen .ql-toolbar {
  position: sticky;
  top: 0;
  z-index: 2;
  background: #fff;
  border-radius: 0.5rem 0.5rem 0 0;
}

.ui-quill-wrap.ui-quill-fullscreen .ui-quill-editor {
  flex: 1;
  min-height: 0;
  overflow: auto;
  border-radius: 0 0 0.5rem 0.5rem;
}

.ui-quill-wrap .ql-toolbar.ql-snow {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.35rem 0.5rem;
  padding: 0.45rem 0.5rem;
  border-radius: 0.5rem 0.5rem 0 0;
}

.ui-quill-wrap .ql-toolbar.ql-snow.ui-quill-toolbar-combined {
  align-items: flex-start;
}

@media (min-width: 768px) {
  .ui-quill-wrap .ql-toolbar.ql-snow.ui-quill-toolbar-combined {
    flex-wrap: nowrap;
    align-items: center;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
}
.ui-quill-wrap .ql-toolbar.ql-snow .ql-formats {
  margin-right: 0 !important;
  display: inline-flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 2px;
  vertical-align: middle;
}

.ui-quill-toolbar-extras {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.35rem 0.5rem;
  width: 100%;
  padding-bottom: 0.35rem;
  margin-bottom: 0.25rem;
  border-bottom: 1px solid rgba(15, 23, 42, 0.08);
}

@media (min-width: 768px) {
  .ui-quill-toolbar-extras {
    width: auto;
    flex: 0 0 auto;
    padding-bottom: 0;
    margin-bottom: 0;
    border-bottom: none;
    border-right: 1px solid rgba(15, 23, 42, 0.08);
    padding-right: 0.5rem;
    margin-right: 0.25rem;
  }
}
.ui-quill-toolbar-extras .ql-formats {
  margin-right: 0 !important;
  display: inline-flex;
  flex-wrap: nowrap;
  align-items: stretch;
  gap: 4px;
}

.ui-quill-toolbar-extras .ql-formats button {
  min-width: 2.25rem;
  min-height: 2rem;
  padding: 0.2rem 0.45rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.35rem;
  line-height: 1.2;
  white-space: nowrap;
}

.ui-quill-toolbar-extras .ql-formats button .ti {
  font-size: 1.05rem;
  flex-shrink: 0;
}

.ui-quill-toolbar-extras .ui-quill-tb-text {
  font-size: 0.72rem;
  font-weight: 600;
  max-width: 5.5rem;
  overflow: hidden;
  text-overflow: ellipsis;
}

@media (max-width: 575.98px) {
  .ui-quill-toolbar-extras .ui-quill-tb-text {
    display: none;
  }
  .ui-quill-toolbar-extras .ql-formats button {
    min-width: 2.5rem;
    padding: 0.35rem;
  }
}
.ui-quill-wrap .ql-raw-html-embed {
  margin: 0.5rem 0;
  padding: 0.5rem 0.65rem;
  border: 1px dashed rgba(245, 158, 11, 0.45);
  border-radius: 0.4rem;
  background: rgba(245, 158, 11, 0.06);
  font-size: 0.75rem;
  max-height: 8rem;
  overflow: auto;
}

.ui-quill-wrap .ql-raw-html-embed::before {
  content: "RAW (HTML / JS / CSS)";
  display: block;
  font-weight: 700;
  font-size: 0.65rem;
  letter-spacing: 0.06em;
  color: #92400e;
  margin-bottom: 0.35rem;
}

.admin-quill-media-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
  gap: 0.65rem;
  max-height: 55vh;
  overflow: auto;
}

@media (max-width: 575.98px) {
  .admin-quill-media-grid {
    grid-template-columns: repeat(2, 1fr);
    max-height: 60vh;
  }
}
.admin-quill-media-tile {
  border: 1px solid rgba(15, 23, 42, 0.1);
  border-radius: 0.5rem;
  overflow: hidden;
  cursor: pointer;
  background: #f8fafc;
  text-align: left;
  padding: 0;
}

.admin-quill-media-tile img {
  width: 100%;
  aspect-ratio: 4/3;
  object-fit: cover;
  display: block;
}

.admin-quill-media-tile span {
  display: block;
  padding: 0.25rem 0.35rem;
  font-size: 0.65rem;
  word-break: break-all;
}

.media-library-page--fullwidth {
  max-width: none;
  width: 100%;
}

/* Układ: wąski panel folderów, maksymalna przestrzeń na zdjęcia (siatka) */
.media-lib-layout--grid {
  display: grid;
  gap: 1rem;
  width: 100%;
  max-width: 100%;
}
@media (max-width: 1199.98px) {
  .media-lib-layout--grid {
    grid-template-columns: minmax(0, 1fr);
  }
}
@media (min-width: 1200px) {
  .media-lib-layout--grid {
    grid-template-columns: min(12.5rem, 17vw) minmax(0, 1fr);
    gap: 1.25rem;
    align-items: start;
  }
}
@media (min-width: 1600px) {
  .media-lib-layout--grid {
    grid-template-columns: min(13.5rem, 15vw) minmax(0, 1fr);
    gap: 1.5rem;
  }
}

.media-lib-layout__sidebar {
  min-width: 0;
}

.media-lib-layout__main {
  min-width: 0;
  width: 100%;
}

.media-lib-context-bar {
  padding: 0.5rem 0.75rem;
  border-radius: 0.65rem;
  background: color-mix(in srgb, var(--color-primary, #206bc4) 6%, var(--color-surface, #fff));
  border: 1px solid color-mix(in srgb, var(--color-primary, #206bc4) 12%, transparent);
}

.media-lib-sidebar--compact .media-lib-sidebar__head {
  min-height: 0;
}
.media-lib-sidebar--compact .media-lib-sidebar__body {
  max-height: min(48vh, 380px);
  overflow-x: hidden;
  overflow-y: auto;
  scrollbar-gutter: stable;
}
@media (min-width: 1200px) {
  .media-lib-sidebar--compact .media-lib-sidebar__body {
    max-height: min(58vh, 480px);
  }
}
.media-lib-sidebar--compact .media-lib-folder-row {
  font-size: 0.8125rem;
  line-height: 1.25;
}
.media-lib-sidebar--compact .media-lib-folder-row a {
  min-width: 0;
}
.media-lib-sidebar--compact .media-lib-folder-row .btn-group .btn {
  padding: 0.12rem 0.28rem;
  font-size: 0.65rem;
}
.media-lib-sidebar--compact .media-lib-folder-tree--nested {
  margin-left: 0.2rem !important;
  padding-left: 0.45rem !important;
}
.media-lib-sidebar--compact hr {
  margin: 0.5rem 0;
  opacity: 0.55;
}
.media-lib-sidebar--compact .form-label.small {
  font-size: 0.7rem;
}

.media-lib-folder-tree--nested {
  margin-top: 0.15rem;
}

.media-lib-folder-row {
  transition: background-color 0.15s ease;
}
.media-lib-folder-row:hover {
  background-color: color-mix(in srgb, var(--color-primary, #206bc4) 6%, transparent);
}
.media-lib-folder-row--active {
  background-color: color-mix(in srgb, var(--color-primary, #206bc4) 10%, transparent);
}

.media-lib-preset-card .media-lib-preset-card__actions {
  flex-wrap: wrap;
}

/* Siatka zdjęć — priorytet: większe karty, więcej kolumn na szerokim ekranie */
.media-lib-visual-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(176px, 1fr));
  gap: 1.2rem;
}
@media (min-width: 768px) {
  .media-lib-visual-grid {
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 1.35rem;
  }
}
@media (min-width: 1200px) {
  .media-lib-visual-grid {
    grid-template-columns: repeat(auto-fill, minmax(210px, 1fr));
    gap: 1.45rem;
  }
}
@media (min-width: 1400px) {
  .media-lib-visual-grid {
    grid-template-columns: repeat(auto-fill, minmax(232px, 1fr));
    gap: 1.5rem;
  }
}
@media (min-width: 1800px) {
  .media-lib-visual-grid {
    grid-template-columns: repeat(auto-fill, minmax(248px, 1fr));
  }
}
.media-lib-visual-grid .media-lib-grid-empty {
  grid-column: 1/-1;
}

.media-lib-card-v2 {
  border: 1px solid color-mix(in srgb, var(--color-border, #e2e5eb) 88%, transparent);
  border-radius: 0.85rem;
  overflow: hidden;
  box-shadow: 0 6px 28px rgba(15, 23, 42, 0.07);
  transition: transform 0.18s ease, box-shadow 0.18s ease;
}
.media-lib-card-v2:hover {
  transform: translateY(-4px);
  box-shadow: 0 14px 44px rgba(15, 23, 42, 0.12);
}
.media-lib-card-v2 .media-lib-card-v2__media {
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--color-border, #e2e5eb) 55%, transparent);
}
.media-lib-card-v2 .media-lib-thumb-btn:focus-visible {
  outline: 3px solid color-mix(in srgb, var(--color-primary, #206bc4) 45%, transparent);
  outline-offset: -2px;
}
.media-lib-card-v2 .card-body {
  background: linear-gradient(180deg, var(--color-surface, #fff) 0%, color-mix(in srgb, var(--color-surface, #fff) 92%, var(--color-border, #e2e5eb)) 100%);
}

.media-library-page .media-lib-layout__main {
  background: linear-gradient(180deg, color-mix(in srgb, var(--color-primary, #206bc4) 5%, transparent) 0%, transparent 32%);
  border-radius: 0.85rem;
  padding: 0.35rem 0.15rem;
}
@media (min-width: 992px) {
  .media-library-page .media-lib-layout__main {
    padding: 0.5rem 0.25rem;
  }
}
@media (min-width: 1200px) {
  .media-library-page .media-lib-layout__main {
    padding: 0.65rem 0.35rem 0.85rem;
  }
}

.media-lib-bulk-toolbar {
  position: sticky;
  top: 0;
  z-index: 100;
  box-shadow: 0 4px 18px rgba(15, 23, 42, 0.08);
}

@media (min-width: 1200px) {
  .media-lib-sidebar {
    position: sticky;
    top: 4.25rem;
    align-self: start;
  }
}

.media-lib-thumb-btn {
  display: block;
  cursor: zoom-in;
}

.media-lib-thumb-btn:focus-visible {
  outline: 2px solid var(--color-primary, #206bc4);
  outline-offset: 2px;
}

.media-library-page .media-lib-search-card {
  border-radius: 0.65rem;
  box-shadow: 0 2px 10px rgba(15, 23, 42, 0.06);
  border: 1px solid color-mix(in srgb, var(--color-border, #e2e5eb) 70%, transparent);
}
.media-library-page .media-lib-upload-card {
  overflow: hidden;
  border-radius: 0.65rem;
  box-shadow: 0 2px 12px rgba(15, 23, 42, 0.07);
}
.media-library-page .media-lib-upload-card .card-header {
  background: linear-gradient(135deg, color-mix(in srgb, var(--color-primary, #206bc4) 10%, var(--color-surface, #fff)) 0%, var(--color-surface, #fff) 48%);
}
.media-library-page .media-lib-upload-card__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.75rem;
  height: 2.75rem;
  border-radius: 0.5rem;
  background: color-mix(in srgb, var(--color-primary, #206bc4) 16%, transparent);
  color: var(--color-primary, #206bc4);
  font-size: 1.35rem;
  flex-shrink: 0;
}
.media-library-page .media-lib-upload-zone {
  border: 2px dashed var(--color-border, #e2e5eb);
  border-radius: 0.65rem;
  padding: 0;
  background: var(--color-surface, #fff);
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
  overflow: hidden;
}
.media-library-page .media-lib-upload-zone__inner {
  padding: 1.25rem 1.25rem 1rem;
}
.media-library-page .media-lib-upload-zone__hint {
  font-size: 0.9rem;
  line-height: 1.45;
  color: var(--color-text-muted, #5a6578);
}
.media-library-page .media-lib-upload-zone.is-dragover {
  border-color: var(--color-primary, #206bc4);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-primary, #206bc4) 22%, transparent);
}
.media-library-page .media-lib-upload-zone.is-dragover .media-lib-upload-zone__hint strong {
  color: var(--color-primary, #206bc4);
}
.media-library-page .media-lib-progress-panel {
  padding: 0.85rem 1.25rem 1.1rem;
  border-top: 1px solid var(--color-border, #e2e5eb);
  background: color-mix(in srgb, var(--color-surface, #fff) 92%, var(--color-primary, #206bc4));
}
.media-library-page .media-lib-upload-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
  align-items: stretch;
}
.media-library-page .media-lib-upload-actions .form-control[type=file] {
  flex: 1 1 220px;
  min-width: 0;
}
.media-library-page .media-lib-upload-actions .btn {
  flex: 0 0 auto;
  white-space: nowrap;
}
.media-library-page .media-lib-progress {
  min-height: 0.65rem;
  border-radius: 999px;
  overflow: hidden;
  background: color-mix(in srgb, var(--color-border, #e2e5eb) 85%, transparent);
  box-shadow: inset 0 1px 2px rgba(15, 23, 42, 0.06);
}
.media-library-page .media-lib-progress__bar {
  height: 0.65rem;
  width: 0%;
  border-radius: 999px;
  background: linear-gradient(90deg, color-mix(in srgb, var(--color-primary, #206bc4) 88%, #fff), var(--color-primary, #206bc4));
  transition: width 0.18s ease-out;
}
.media-library-page .media-lib-folder-row {
  gap: 0.25rem;
}
.media-library-page .media-lib-folder-row .btn-group .btn {
  font-size: 0.7rem;
}
.media-library-page .media-lib-crop-breakpoints .nav-link {
  cursor: pointer;
  padding: 0.35rem 0.75rem;
  font-size: 0.875rem;
}
.media-library-page .media-lib-crop-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
  margin-bottom: 0.75rem;
  align-items: center;
}
.media-library-page .media-lib-crop-toolbar .btn {
  flex: 0 1 auto;
  min-width: 0;
}
.media-library-page .media-lib-crop-wrap {
  max-height: min(70vh, 520px);
  touch-action: none;
}
.media-library-page .media-lib-crop-wrap img {
  display: block;
  max-width: 100%;
}
.media-library-page .media-lib-card-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
}
.media-library-page .media-lib-card-actions .btn {
  flex: 1 1 calc(50% - 0.2rem);
  min-width: 0;
}
@media (min-width: 400px) {
  .media-library-page .media-lib-card-actions .btn {
    flex: 0 1 auto;
  }
}

@media (max-width: 767.98px) {
  #mediaLibCropModal .modal-dialog {
    margin: 0;
    max-width: none;
    min-height: 100%;
  }
  #mediaLibCropModal .modal-content {
    min-height: 100vh;
    border-radius: 0;
  }
  #mediaLibCropModal .media-lib-crop-wrap {
    max-height: calc(100vh - 220px);
  }
}

.ui-admin-map-shell {
  position: relative;
  border-radius: 0.75rem;
  overflow: hidden;
  border: 1px solid rgba(15, 23, 42, 0.1);
  background: rgba(15, 23, 42, 0.04);
}

.ui-admin-map-toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem 1rem;
  padding: 0.5rem 0.75rem;
  background: rgba(15, 23, 42, 0.035);
  border-bottom: 1px solid rgba(15, 23, 42, 0.08);
}

.ui-admin-map-toolbar__hint {
  flex: 1 1 12rem;
  margin: 0;
  font-size: 0.8125rem;
  line-height: 1.45;
  color: var(--color-text-muted);
}

.ui-admin-map-shell:fullscreen {
  display: flex;
  flex-direction: column;
  max-height: 100vh;
  border-radius: 0;
  background: #fff;
}

.ui-admin-map-shell:fullscreen .ui-admin-map-toolbar {
  flex-shrink: 0;
}

.ui-admin-map-shell:fullscreen .ui-attraction-admin-map {
  flex: 1 1 auto;
  min-height: 0;
  border-radius: 0;
  border: 0;
}

.ui-admin-map-shell:fullscreen .ui-attraction-admin-map .leaflet-container {
  min-height: calc(100vh - 3.5rem);
  height: 100%;
}

.ui-attraction-admin-map {
  width: 100%;
  min-height: 30rem;
  border-radius: 0 0 0.75rem 0.75rem;
  overflow: hidden;
  border: 0;
  background: rgba(15, 23, 42, 0.04);
  z-index: 0;
}
.ui-attraction-admin-map .leaflet-container {
  min-height: 30rem;
  font-family: inherit;
  z-index: 1;
}
.ui-attraction-admin-map .leaflet-control-layers {
  font-size: 0.875rem;
}
.ui-attraction-admin-map .leaflet-control-layers-expanded {
  max-width: min(100%, 14rem);
  padding: 0.35rem 0.5rem;
}

.ui-admin-map-shell:not(:fullscreen) .ui-attraction-admin-map {
  border-radius: 0 0 0.75rem 0.75rem;
}

.ui-attraction-bulk-toolbar-card .btn:disabled {
  opacity: 0.55;
}

tr.ui-attraction-row--inactive td:not(:first-child) {
  opacity: 0.72;
}

.ui-attraction-form__panel .ui-form-grid {
  gap: 1rem 1.25rem;
}

.ui-attraction-form__geo-hint {
  display: flex;
  align-items: flex-start;
  gap: 0.65rem;
  padding: 0.85rem 1rem;
  border-radius: 0.75rem;
  font-size: 0.875rem;
  line-height: 1.5;
  color: var(--color-text-muted);
  background: rgba(var(--color-admin-tint-rgb), 0.06);
  border: 1px solid rgba(var(--color-admin-tint-rgb), 0.14);
}
.ui-attraction-form__geo-hint .ui-icon {
  flex-shrink: 0;
  margin-top: 0.1rem;
  color: var(--color-primary);
}
.ui-attraction-form__geo-hint a {
  font-weight: 600;
}

.ui-attraction-form__field-head {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem 1rem;
}

.ui-attraction-form__roomtypes-filter {
  max-width: 28rem;
}

.ui-attraction-form__roomtypes-select {
  min-height: 14rem;
  max-height: min(50vh, 22rem);
  padding: 0.5rem 0.65rem;
  line-height: 1.45;
  border-radius: 0.65rem;
  font-size: 0.9375rem;
}
.ui-attraction-form__roomtypes-select option {
  padding: 0.35rem 0.5rem;
  border-radius: 0.35rem;
}
.ui-attraction-form__roomtypes-select option:checked {
  background: linear-gradient(135deg, rgba(var(--color-admin-tint-rgb), 0.22), rgba(var(--color-admin-tint-rgb), 0.1));
  color: var(--color-text);
}

.ui-kbd {
  display: inline-block;
  padding: 0.12rem 0.4rem;
  font-size: 0.72rem;
  font-weight: 650;
  font-family: ui-monospace, monospace;
  line-height: 1.2;
  color: var(--color-text-muted);
  background: rgba(15, 23, 42, 0.06);
  border: 1px solid rgba(15, 23, 42, 0.1);
  border-radius: 0.35rem;
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.8);
}

@media (max-width: 575.98px) {
  .ui-attraction-form__field-head {
    align-items: flex-start;
    flex-direction: column;
  }
  .ui-attraction-form__roomtypes-filter {
    max-width: none;
  }
}
.admin-blog-page {
  max-width: 72rem;
  margin-inline: auto;
}

.admin-blog-panel {
  border: 1px solid rgba(15, 23, 42, 0.08);
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
  overflow: hidden;
}

.admin-blog-panel__search {
  padding: 1rem 1.25rem 1.25rem;
  background: linear-gradient(180deg, rgba(var(--color-dashboard-accent-rgb, 32, 107, 196), 0.05) 0%, transparent 100%);
  border-bottom: 1px solid rgba(15, 23, 42, 0.06);
}

.admin-blog-panel__search-label {
  display: block;
  font-size: 0.75rem;
  font-weight: 650;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--color-text-muted);
  margin-bottom: 0.5rem;
}

.admin-blog-list-wrap {
  padding: 0.75rem;
  background: rgba(15, 23, 42, 0.025);
}

.admin-blog-list {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.admin-blog-list-item {
  display: grid;
  grid-template-columns: 10.5rem minmax(0, 1fr) auto;
  gap: 1rem 1.35rem;
  align-items: stretch;
  padding: 1rem 1.15rem;
  border-radius: 0.85rem;
  border: 1px solid rgba(15, 23, 42, 0.07);
  background: var(--color-surface, #fff);
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.05);
  transition: border-color 0.18s ease, box-shadow 0.18s ease, transform 0.18s ease;
}
.admin-blog-list-item:hover {
  border-color: rgba(var(--color-dashboard-accent-rgb, 32, 107, 196), 0.28);
  box-shadow: 0 4px 14px rgba(15, 23, 42, 0.07), 0 0 0 1px rgba(var(--color-dashboard-accent-rgb, 32, 107, 196), 0.06);
  transform: translateY(-1px);
}

.admin-blog-list-item__thumb {
  width: 100%;
  max-width: 10.5rem;
  aspect-ratio: 16/10;
  border-radius: 0.7rem;
  overflow: hidden;
  background: linear-gradient(145deg, rgba(15, 23, 42, 0.07), rgba(15, 23, 42, 0.03));
  border: 1px solid rgba(15, 23, 42, 0.08);
  flex-shrink: 0;
  align-self: center;
}

.admin-blog-list-item__img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.admin-blog-list-item__placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  min-height: 6.25rem;
  color: var(--color-text-muted);
  font-size: 2rem;
  opacity: 0.65;
}

.admin-blog-list-item__main {
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-width: 0;
  gap: 0.5rem;
}

.admin-blog-list-item__title {
  margin: 0;
  font-size: 1.0625rem;
  font-weight: 650;
  line-height: 1.35;
  letter-spacing: -0.01em;
}
.admin-blog-list-item__title a {
  color: inherit;
  text-decoration: none;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.admin-blog-list-item__title a:hover {
  color: var(--color-primary, var(--admin-accent));
}

.admin-blog-list-item__meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.4rem 0.65rem;
  font-size: 0.8125rem;
  line-height: 1.45;
  color: var(--color-text-muted);
}
.admin-blog-list-item__meta .ti {
  opacity: 0.8;
  vertical-align: -0.12em;
}

.admin-blog-list-item__id {
  font-family: ui-monospace, monospace;
  font-size: 0.75rem;
  opacity: 0.85;
}

.admin-blog-list-item__dot {
  opacity: 0.35;
  user-select: none;
}

.admin-blog-list-item__badges {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
  align-items: center;
}

.admin-blog-list-item__badge {
  font-size: 0.7rem;
  font-weight: 650;
  letter-spacing: 0.02em;
  padding: 0.2rem 0.55rem;
  border-radius: 0.35rem;
}

.admin-blog-list-item__badge--pub {
  background: rgba(25, 135, 84, 0.12);
  color: #146c43;
  border: 1px solid rgba(25, 135, 84, 0.25);
}

.admin-blog-list-item__badge--draft {
  background: rgba(108, 117, 125, 0.12);
  color: #495057;
  border: 1px solid rgba(108, 117, 125, 0.22);
}

.admin-blog-list-item__badge--cat {
  background: rgba(var(--color-dashboard-accent-rgb, 32, 107, 196), 0.1);
  color: var(--color-primary, var(--admin-accent));
  border: 1px solid rgba(var(--color-dashboard-accent-rgb, 32, 107, 196), 0.2);
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.admin-blog-list-item__actions {
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  gap: 0.4rem;
  justify-content: center;
  align-items: stretch;
  min-width: 7.5rem;
}

@media (max-width: 991.98px) {
  .admin-blog-list-item {
    grid-template-columns: 8.5rem minmax(0, 1fr);
    grid-template-rows: auto auto;
  }
  .admin-blog-list-item__thumb {
    grid-column: 1;
    grid-row: 1/span 2;
    max-width: 8.5rem;
    align-self: start;
  }
  .admin-blog-list-item__main {
    grid-column: 2;
    grid-row: 1;
  }
  .admin-blog-list-item__actions {
    grid-column: 2;
    grid-row: 2;
    flex-direction: row;
    justify-content: flex-start;
    min-width: 0;
  }
}
@media (max-width: 575.98px) {
  .admin-blog-list-item {
    grid-template-columns: 1fr;
  }
  .admin-blog-list-item__thumb {
    max-width: none;
    aspect-ratio: 16/9;
    grid-row: auto;
  }
  .admin-blog-list-item__actions {
    grid-column: auto;
  }
}
.admin-blog-list--empty {
  text-align: center;
  padding: 3rem 1.5rem;
  color: var(--color-text-muted);
  font-size: 0.9375rem;
  margin: 0;
}

.admin-blog-list--empty .ti {
  display: block;
  font-size: 2.5rem;
  margin-bottom: 0.75rem;
  opacity: 0.35;
}

.ui-menu-items-toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  gap: 0.75rem 1rem;
  margin-bottom: 1.25rem;
  padding: 1rem 1.15rem;
  border-radius: var(--admin-shell-radius-lg, 1.25rem);
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid rgba(15, 23, 42, 0.07);
  box-shadow: var(--admin-shell-shadow-soft, 0 8px 24px rgba(15, 23, 42, 0.06));
}

.ui-menu-items-toolbar__field {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  min-width: 0;
}

.ui-menu-items-toolbar__field--grow {
  flex: 1 1 12rem;
}

.ui-menu-items-toolbar__field--sm {
  flex: 0 1 8.5rem;
}

.ui-menu-items-toolbar__label {
  font-size: 0.68rem;
  font-weight: 750;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-text-muted);
}

.ui-menu-items-toolbar__actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem;
  margin-left: auto;
}

.ui-menu-items-meta {
  font-size: 0.875rem;
  color: var(--color-text-muted);
  margin-bottom: 0.75rem;
}

.ui-menu-items-meta strong {
  color: var(--color-text);
}

.ui-menu-items-table-wrap {
  border-radius: var(--admin-shell-radius-lg, 1.25rem);
  border: 1px solid rgba(15, 23, 42, 0.07);
  overflow: hidden;
  background: rgba(255, 255, 255, 0.98);
  box-shadow: var(--admin-shell-shadow-soft, 0 8px 24px rgba(15, 23, 42, 0.06));
}

.ui-menu-items-table-wrap .table {
  margin-bottom: 0;
}

.ui-menu-items-table-wrap .ui-table thead th {
  background: linear-gradient(180deg, rgba(248, 250, 252, 0.95) 0%, rgba(241, 245, 249, 0.85) 100%);
  border-bottom: 1px solid rgba(15, 23, 42, 0.08);
  padding-top: 0.85rem;
  padding-bottom: 0.85rem;
  font-weight: 750;
}

.ui-menu-items-table-wrap th.ui-menu-col--pos {
  width: 4.5rem;
}

.ui-menu-items-table-wrap th.ui-menu-col--reorder,
.ui-menu-items-table-wrap td.ui-menu-col--reorder {
  width: 5.25rem;
  padding-left: 0.35rem;
  padding-right: 0.35rem;
}

.ui-menu-reorder {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  gap: 0.2rem;
  vertical-align: middle;
}

.ui-menu-drag-handle {
  cursor: grab;
  color: var(--color-text-muted, #64748b);
  padding: 0.15rem 0.25rem;
  margin-bottom: 0.1rem;
  border-radius: 0.35rem;
  line-height: 1;
  user-select: none;
}
.ui-menu-drag-handle:hover {
  color: var(--color-text, #0f172a);
  background: rgba(15, 23, 42, 0.06);
}
.ui-menu-drag-handle:active {
  cursor: grabbing;
}
.ui-menu-drag-handle .ti {
  font-size: 1.1rem;
}

.ui-menu-items-table-wrap tr.ui-menu-row--dragging {
  opacity: 0.72;
  background: rgba(99, 102, 241, 0.06) !important;
}

.ui-menu-reorder__form {
  margin: 0;
  line-height: 0;
}

.ui-menu-reorder__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 2rem;
  padding: 0.2rem 0.35rem;
  line-height: 1;
  border-radius: 0.35rem;
  border: 1px solid rgba(15, 23, 42, 0.14);
  background: rgba(255, 255, 255, 0.95);
  color: var(--color-text, #0f172a);
}
.ui-menu-reorder__btn:hover:not(:disabled) {
  background: rgba(99, 102, 241, 0.12);
  border-color: rgba(99, 102, 241, 0.35);
  color: var(--color-text, #0f172a);
}
.ui-menu-reorder__btn:disabled {
  opacity: 0.38;
  cursor: not-allowed;
}
.ui-menu-reorder__btn .ti {
  font-size: 1rem;
}

.ui-menu-items-table-wrap th.ui-menu-col--active {
  width: 6.5rem;
}

.ui-menu-items-table-wrap th.ui-menu-col--actions {
  width: 1%;
  white-space: nowrap;
}

.ui-menu-items-table-wrap .ui-table tbody td {
  padding-top: 0.75rem;
  padding-bottom: 0.75rem;
  vertical-align: middle;
  border-color: rgba(15, 23, 42, 0.06);
}

.ui-menu-items-table-wrap .ui-table tbody tr:last-child td {
  border-bottom: 0;
}

.ui-menu-items-table-wrap tr.ui-menu-row--child td {
  background: rgba(99, 102, 241, 0.03);
}

.ui-menu-items-table-wrap tr.ui-menu-row--child td:first-child {
  box-shadow: inset 3px 0 0 rgba(99, 102, 241, 0.35);
}

.ui-menu-target-cell {
  font-size: 0.875rem;
  line-height: 1.45;
  color: var(--color-text);
}

.ui-menu-target-cell .ui-menu-target-type {
  display: inline-block;
  margin-bottom: 0.15rem;
}

.ui-menu-href-cell code {
  font-size: 0.78rem;
  word-break: break-all;
  color: var(--color-text);
  background: rgba(15, 23, 42, 0.05);
  padding: 0.2rem 0.45rem;
  border-radius: 0.35rem;
}

.ui-menu-href-cell--warn {
  font-size: 0.8125rem;
  color: #9a3412;
  font-weight: 600;
}

.ui-menu-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
  justify-content: flex-end;
}

@media (max-width: 991.98px) {
  .ui-menu-items-toolbar__actions {
    margin-left: 0;
    width: 100%;
  }
}
.ui-nav-hub {
  border-radius: var(--admin-shell-radius-lg, 1.25rem);
  border: 1px solid rgba(15, 23, 42, 0.07);
  box-shadow: var(--admin-shell-shadow-soft, 0 4px 16px rgba(15, 23, 42, 0.05));
}

.ui-nav-hub .card-body {
  row-gap: 0.35rem;
}

.ui-nav-tree-card .card-header {
  background: rgba(var(--color-admin-tint-rgb), 0.06);
  border-bottom: 1px solid rgba(15, 23, 42, 0.08);
}

.ui-nav-tree__row {
  border: 1px solid rgba(15, 23, 42, 0.06);
}

body.admin-app .ui-dash-hero {
  border-radius: var(--admin-shell-radius-lg, 1.25rem);
  border: 1px solid rgba(15, 23, 42, 0.06);
  background: linear-gradient(135deg, color-mix(in srgb, var(--admin-accent, #206bc4) 12%, #ffffff) 0%, #ffffff 48%, color-mix(in srgb, var(--admin-accent, #206bc4) 6%, #ffffff) 100%);
  box-shadow: var(--admin-shell-shadow-soft, 0 8px 24px rgba(15, 23, 42, 0.06));
  padding: 1.5rem 1.75rem;
  margin-bottom: 1.75rem;
}

body.admin-app .ui-dash-hero__title {
  margin: 0 0 0.35rem;
  font-size: clamp(1.25rem, 2.5vw, 1.5rem);
  font-weight: var(--font-weight-bold-max);
  color: var(--color-text);
}

body.admin-app .ui-dash-hero__lead {
  margin: 0;
  font-size: 0.95rem;
  color: var(--color-text-muted);
  max-width: 62ch;
  line-height: 1.55;
}

body.admin-app .ui-dash-stat {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.65rem;
  height: 100%;
  padding: 1.15rem 1.2rem;
  border-radius: var(--admin-shell-radius, 1rem);
  border: 1px solid rgba(15, 23, 42, 0.07);
  background: rgba(255, 255, 255, 0.98);
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.04);
  text-decoration: none;
  color: inherit;
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}

body.admin-app .ui-dash-stat:hover {
  transform: translateY(-3px);
  box-shadow: 0 14px 36px rgba(15, 23, 42, 0.1);
  border-color: color-mix(in srgb, var(--admin-accent, #206bc4) 28%, transparent);
  color: inherit;
}

body.admin-app .ui-dash-stat__icon {
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 0.65rem;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.35rem;
  color: #fff;
  background: var(--admin-accent, #206bc4);
  box-shadow: 0 4px 14px color-mix(in srgb, var(--admin-accent, #206bc4) 35%, transparent);
}

body.admin-app .ui-dash-stat__value {
  font-size: clamp(1.5rem, 2.8vw, 1.85rem);
  font-weight: var(--font-weight-bold-max);
  letter-spacing: -0.03em;
  line-height: 1.15;
  color: var(--color-text);
}

body.admin-app .ui-dash-stat__label {
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--color-text-muted);
  line-height: 1.35;
}

body.admin-app .ui-dash-stat__meta {
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--color-text-muted);
  margin-top: auto;
  padding-top: 0.25rem;
}

body.admin-app .ui-dash-section-title {
  font-size: 0.72rem;
  font-weight: var(--font-weight-bold-max);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-text-muted);
  margin: 0 0 0.75rem;
}

body.admin-app .ui-dash-pill {
  display: inline-flex;
  align-items: center;
  padding: 0.2rem 0.55rem;
  border-radius: 999px;
  font-size: 0.72rem;
  font-weight: 700;
  background: color-mix(in srgb, var(--admin-accent, #206bc4) 14%, transparent);
  color: color-mix(in srgb, var(--admin-accent, #206bc4) 55%, #0f172a);
}

body.admin-app .page input[type=checkbox]:not(.ui-pictogram-checkbox):not(.ui-chip__input):not(.form-switch .form-check-input),
body.ui-login-wrap .page input[type=checkbox]:not(.ui-pictogram-checkbox):not(.ui-chip__input):not(.form-switch .form-check-input) {
  width: var(--admin-checkbox-size, 1.25rem);
  height: var(--admin-checkbox-size, 1.25rem);
  margin: 0;
  flex-shrink: 0;
  border: 2px solid var(--color-border);
  border-radius: 6px;
  background-color: #fff;
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
  transition: border-color 0.2s ease, background-color 0.2s ease, box-shadow 0.2s ease;
}
body.admin-app .page input[type=checkbox]:not(.ui-pictogram-checkbox):not(.ui-chip__input):not(.form-switch .form-check-input):checked,
body.ui-login-wrap .page input[type=checkbox]:not(.ui-pictogram-checkbox):not(.ui-chip__input):not(.form-switch .form-check-input):checked {
  background-color: var(--color-primary);
  border-color: var(--color-primary);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='11' viewBox='0 0 12 10' fill='none' stroke='%23fff' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M1 5l3 3 7-7'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: center;
  background-size: 68% 68%;
}
body.admin-app .page input[type=checkbox]:not(.ui-pictogram-checkbox):not(.ui-chip__input):not(.form-switch .form-check-input):focus,
body.ui-login-wrap .page input[type=checkbox]:not(.ui-pictogram-checkbox):not(.ui-chip__input):not(.form-switch .form-check-input):focus {
  box-shadow: 0 0 0 3px rgba(var(--color-accent-rgb), 0.22);
  outline: none;
}
body.admin-app .page input[type=checkbox]:not(.ui-pictogram-checkbox):not(.ui-chip__input):not(.form-switch .form-check-input):focus-visible,
body.ui-login-wrap .page input[type=checkbox]:not(.ui-pictogram-checkbox):not(.ui-chip__input):not(.form-switch .form-check-input):focus-visible {
  outline: none;
}
body.admin-app .page input[type=checkbox]:not(.ui-pictogram-checkbox):not(.ui-chip__input):not(.form-switch .form-check-input):hover:not(:disabled),
body.ui-login-wrap .page input[type=checkbox]:not(.ui-pictogram-checkbox):not(.ui-chip__input):not(.form-switch .form-check-input):hover:not(:disabled) {
  border-color: var(--color-primary);
}
body.admin-app .page input[type=checkbox]:not(.ui-pictogram-checkbox):not(.ui-chip__input):not(.form-switch .form-check-input):disabled,
body.ui-login-wrap .page input[type=checkbox]:not(.ui-pictogram-checkbox):not(.ui-chip__input):not(.form-switch .form-check-input):disabled {
  opacity: 0.55;
  cursor: not-allowed;
}
body.admin-app .page,
body.ui-login-wrap .page {
  /* W tabelach na desktopzie nieco zwarte — na mobile i tak nadpisujemy touch target */
}
@media (min-width: 992px) {
  body.admin-app .page .table input[type=checkbox]:not(.ui-pictogram-checkbox):not(.ui-chip__input):not(.form-switch .form-check-input),
  body.ui-login-wrap .page .table input[type=checkbox]:not(.ui-pictogram-checkbox):not(.ui-chip__input):not(.form-switch .form-check-input) {
    width: 1.15rem;
    height: 1.15rem;
  }
}
body.admin-app .page .form-check:not(.form-switch),
body.ui-login-wrap .page .form-check:not(.form-switch) {
  display: flex;
  align-items: flex-start;
  gap: 0.65rem;
  padding: 0.35rem 0;
  margin-bottom: 0;
  cursor: pointer;
  user-select: none;
}
body.admin-app .page .form-check:not(.form-switch) .form-check-label,
body.ui-login-wrap .page .form-check:not(.form-switch) .form-check-label {
  cursor: pointer;
  font-size: 0.95rem;
  color: var(--color-text);
  flex: 1;
  line-height: 1.45;
  padding-top: 0.08rem;
}

/* Mobile / tablet: duży obszar dotyku (≥ ~44px przy bazie 18px na html) */
@media (max-width: 991.98px) {
  body.admin-app .page,
  body.ui-login-wrap .page {
    --admin-checkbox-size: 2.75rem;
  }
  body.admin-app .page input[type=checkbox]:not(.ui-pictogram-checkbox):not(.ui-chip__input):not(.form-switch .form-check-input),
  body.ui-login-wrap .page input[type=checkbox]:not(.ui-pictogram-checkbox):not(.ui-chip__input):not(.form-switch .form-check-input) {
    border-radius: 8px;
    border-width: 2px;
  }
  body.admin-app .page input[type=checkbox]:not(.ui-pictogram-checkbox):not(.ui-chip__input):not(.form-switch .form-check-input):checked,
  body.ui-login-wrap .page input[type=checkbox]:not(.ui-pictogram-checkbox):not(.ui-chip__input):not(.form-switch .form-check-input):checked {
    background-size: 58% 58%;
  }
  body.admin-app .page,
  body.ui-login-wrap .page {
    /* Cały rząd etykiety + checkbox — łatwiej trafić palcem */
  }
  body.admin-app .page .form-check:not(.form-switch),
  body.ui-login-wrap .page .form-check:not(.form-switch) {
    gap: 0.75rem;
    padding: 0.55rem 0;
    min-height: 2.75rem;
    align-items: center;
  }
  body.admin-app .page .form-check:not(.form-switch) .form-check-label,
  body.ui-login-wrap .page .form-check:not(.form-switch) .form-check-label {
    font-size: 1rem;
    padding-top: 0;
  }
  body.admin-app .page,
  body.ui-login-wrap .page {
    /* Komórki tabeli z samym checkboxem — wyśrodkowany duży cel */
  }
  body.admin-app .page .table td .form-check:not(.form-switch),
  body.admin-app .page .table th .form-check:not(.form-switch),
  body.ui-login-wrap .page .table td .form-check:not(.form-switch),
  body.ui-login-wrap .page .table th .form-check:not(.form-switch) {
    justify-content: center;
    min-height: 0;
    padding: 0.35rem 0;
  }
  body.admin-app .page .table-responsive .table td:first-child,
  body.admin-app .page .table-responsive .table th:first-child,
  body.ui-login-wrap .page .table-responsive .table td:first-child,
  body.ui-login-wrap .page .table-responsive .table th:first-child {
    vertical-align: middle;
  }
}
.ui-help-page {
  max-width: 1200px;
  margin: 0 auto;
}

.ui-help-hero {
  padding: 1.5rem 1.62rem;
  border-radius: var(--admin-shell-radius-lg, 1.25rem);
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: linear-gradient(135deg, rgba(var(--color-dashboard-accent-rgb, 32, 107, 196), 0.07), rgba(255, 255, 255, 0.96));
  margin-bottom: 2.1rem;
}

.ui-help-hero__title {
  margin: 0 0 0.6rem;
  font-size: clamp(1.62rem, 2.5vw, 2.1rem);
  font-weight: 800;
  color: var(--color-text);
  display: flex;
  align-items: center;
  gap: 0.6rem;
}

.ui-help-hero__lead {
  margin: 0;
  color: var(--color-text-muted);
  font-size: 1.2rem;
  line-height: 1.6;
  max-width: 65ch;
}

.ui-help-hero__hint {
  font-size: 1.05rem;
  line-height: 1.5;
  max-width: 70ch;
}

.ui-help-quickstart {
  padding: 0.9rem 1.08rem;
  border-radius: 0.75rem;
  border: 1px solid rgba(15, 23, 42, 0.1);
  background: rgba(255, 255, 255, 0.7);
  box-shadow: 0 1px 8px rgba(15, 23, 42, 0.06);
}

.ui-help-quickstart__label {
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-text-muted);
  margin-bottom: 0.5rem;
}

/* Pływająca nawigacja: sticky + przewijanie całego menu gdy jest wyższe niż okno */
.ui-help-toc-wrap {
  position: sticky;
  top: 0.85rem;
  z-index: 16;
  max-height: calc(100vh - 1.25rem);
  display: flex;
  flex-direction: column;
  min-height: 0;
}

.ui-help-toc-wrap .ui-help-toc.card {
  overflow: hidden;
  display: flex;
  flex-direction: column;
  min-height: 0;
  flex: 1 1 auto;
  max-height: 100%;
}

.ui-help-toc-wrap .ui-help-toc .card-body {
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
  flex: 1 1 auto;
  min-height: 0;
  /* Cienka podpowiedź, że lista się przewija */
  scrollbar-gutter: stable;
}

.ui-help-toc .list-group-item {
  border-radius: 0.5rem !important;
  margin-bottom: 0.2rem;
  padding: 0.54rem 0.78rem;
  font-size: 1.05rem;
}

.ui-help-toc .list-group-item a {
  color: inherit;
  text-decoration: none;
  display: block;
}

.ui-help-toc .list-group-item a:hover {
  color: var(--color-primary);
}

.ui-help-toc__label {
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-text-muted);
  padding: 0.42rem 0.78rem 0.18rem;
}

.ui-help-toc-wrap .small.text-secondary {
  font-size: 0.975rem !important;
}

.ui-help-section {
  scroll-margin-top: 6.6rem;
  margin-bottom: 2.7rem;
}

.ui-help-section h2 {
  font-size: 1.5rem;
  font-weight: 800;
  margin: 0 0 1.02rem;
  padding-bottom: 0.6rem;
  border-bottom: 2px solid rgba(var(--color-dashboard-accent-rgb, 32, 107, 196), 0.2);
  color: var(--color-text);
}

.ui-help-section h3 {
  font-size: 1.26rem;
  font-weight: 700;
  margin: 1.62rem 0 0.78rem;
  color: var(--color-text);
}

.ui-help-section h4 {
  font-size: 1.125rem;
}

/* Nagłówki Bootstrap (.h5 / .h6) w rozbudowanych podrozdziałach — ta sama skala +20% */
.ui-help-page .h5 {
  font-size: 1.5rem;
}

.ui-help-page .h6 {
  font-size: 1.2rem;
}

.ui-help-section p,
.ui-help-section li {
  font-size: 1.14rem;
  line-height: 1.65;
  color: var(--color-text);
}

.ui-help-section .text-secondary {
  font-size: 1.104rem;
}

.ui-help-card {
  border: 1px solid var(--color-border);
  border-radius: 0.85rem;
  background: var(--color-surface);
  padding: 1.32rem 1.44rem 1.38rem;
  margin-bottom: 1.2rem;
  box-shadow: 0 2px 10px rgba(15, 23, 42, 0.04);
}

.ui-help-card__head {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.78rem;
  margin-bottom: 0.78rem;
}

.ui-help-card__title {
  margin: 0;
  font-size: 1.2rem;
  font-weight: 700;
}

.ui-help-panel-link {
  display: inline-flex;
  align-items: center;
  gap: 0.42rem;
  font-weight: 600;
  white-space: nowrap;
  font-size: 1.125rem;
}

.ui-help-panel-link .ti-external-link {
  font-size: 0.85em;
  opacity: 0.75;
}

.ui-help-tips {
  display: grid;
  gap: 0.78rem;
  margin-top: 0.9rem;
}

@media (min-width: 768px) {
  .ui-help-tips {
    grid-template-columns: repeat(3, 1fr);
  }
}
.ui-help-tip {
  border-radius: 0.65rem;
  padding: 0.78rem 0.9rem;
  font-size: 0.975rem;
  line-height: 1.5;
}

.ui-help-tip strong {
  display: block;
  font-size: 0.864rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  margin-bottom: 0.42rem;
}

.ui-help-tip--do {
  background: rgba(25, 135, 84, 0.1);
  border: 1px solid rgba(25, 135, 84, 0.25);
  color: #0f5132;
}

.ui-help-tip--dont {
  background: rgba(214, 57, 57, 0.08);
  border: 1px solid rgba(214, 57, 57, 0.22);
  color: #842029;
}

.ui-help-tip--key {
  background: rgba(var(--color-dashboard-accent-rgb, 32, 107, 196), 0.1);
  border: 1px solid rgba(var(--color-dashboard-accent-rgb, 32, 107, 196), 0.28);
  color: var(--color-text);
}

.ui-help-steps {
  counter-reset: helpstep;
  list-style: none;
  padding: 0;
  margin: 0;
}

.ui-help-steps > li {
  position: relative;
  padding: 0.78rem 0 0.78rem 3.3rem;
  border-bottom: 1px dashed rgba(15, 23, 42, 0.1);
}

.ui-help-steps > li:last-child {
  border-bottom: 0;
}

.ui-help-steps > li::before {
  counter-increment: helpstep;
  content: counter(helpstep);
  position: absolute;
  left: 0;
  top: 0.66rem;
  width: 2.4rem;
  height: 2.4rem;
  border-radius: 50%;
  background: rgba(var(--color-dashboard-accent-rgb, 32, 107, 196), 0.15);
  color: var(--color-primary);
  font-weight: 800;
  font-size: 1.08rem;
  display: flex;
  align-items: center;
  justify-content: center;
}

.ui-help-callout {
  border-left: 4px solid rgba(var(--color-dashboard-accent-rgb, 32, 107, 196), 0.55);
  padding: 0.78rem 1.02rem;
  background: rgba(var(--color-dashboard-accent-rgb, 32, 107, 196), 0.06);
  border-radius: 0 0.5rem 0.5rem 0;
  font-size: 1.08rem;
  margin: 0.9rem 0;
}

.ui-help-callout a {
  font-size: inherit;
}

.ui-help-muted-box {
  font-size: 1.056rem;
  color: var(--color-text-muted);
  padding: 0.6rem 0.78rem;
  background: rgba(15, 23, 42, 0.04);
  border-radius: 0.5rem;
  margin-top: 0.6rem;
}

.ui-help-kbd {
  display: inline-block;
  padding: 0.144rem 0.48rem;
  font-size: 0.936rem;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
  border: 1px solid var(--color-border);
  border-radius: 0.35rem;
  background: rgba(15, 23, 42, 0.05);
}

/* Mobile / tablet: pod przyklejonym paskiem admina; pełna szerokość kolumny */
@media (max-width: 991.98px) {
  .ui-help-toc-wrap {
    top: 4rem;
    max-height: calc(100vh - 4.25rem);
    z-index: 15;
  }
}
html {
  font-size: 18px;
}

:root {
  --admin-accent: #206bc4;
  --color-dashboard-accent-rgb: 32, 107, 196;
  --color-admin-tint-rgb: 32, 107, 196;
  --color-accent-rgb: 32, 107, 196;
  --tblr-font-sans-serif: BlinkMacSystemFont, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
}

body.admin-app {
  font-size: 1rem;
  --admin-sidebar-width: 19rem;
  --color-bg: #fafbfc;
  --color-text: #14141a;
  --color-text-muted: #5c5d68;
  --color-primary: var(--admin-accent);
  --color-primary-hover: color-mix(in srgb, var(--admin-accent) 82%, #0f172a);
  --color-border: #e2e5eb;
  --color-surface: #ffffff;
  --color-dashboard-bg: #f4f6fa;
  --color-dashboard-accent: var(--admin-accent);
  background: var(--color-dashboard-bg);
  color: var(--color-text);
  line-height: 1.8;
}

body:not(.admin-app) {
  font-size: 1rem;
  --color-bg: #e8eaef;
  --color-text: #14141a;
  --color-text-muted: #5c5d68;
  --color-primary: #3f404c;
  --color-primary-hover: #282830;
  --color-border: #c0c2ce;
  --color-surface: #f7f7f9;
  --color-dashboard-bg: #e0e2e9;
  --color-dashboard-accent: #0f0f14;
  --color-dashboard-accent-rgb: 15, 15, 20;
  --color-admin-tint-rgb: 63, 64, 76;
  --color-accent-rgb: 40, 41, 50;
  background: var(--color-dashboard-bg);
  color: var(--color-text);
}

.page a {
  text-decoration: none;
}

.page a:hover {
  text-decoration: none;
}

.page {
  background-color: var(--color-dashboard-bg);
}
.page input,
.page select,
.page textarea,
.page button,
.page .form-control,
.page .form-select,
.page .form-label,
.page .ui-input,
.page .ui-select,
.page .ui-label,
.page .ui-form-hint,
.page .ui-table thead th,
.page .ui-table tbody td,
.page .nav-link,
.page .btn,
.page .card-title,
.page .ui-subtitle,
.page .ui-section-title,
.page .form-check-label,
.page .ui-card .form-label,
.page .ui-select-search-wrap .ui-select-search,
.page .ui-select-search-wrap select,
.page .ui-errors,
.page .ui-kv-item span,
.page .ui-kv-item strong,
.page .ui-block-title,
.page .ui-json,
.page .ui-room-header h4,
.page .ui-facility-pill span,
.page .ui-facility-pill code,
.page .ui-marketing-list li,
.page .ui-form-nav .btn-sm,
.page .ui-form-tabs .nav-link,
.page .ui-toast-message,
.page .ui-mobile-list-top h3,
.page .ui-mobile-list-meta,
.page .ui-mobile-list-message,
.page .ui-queue-item,
.page .ui-gallery-ghost-meta,
.page .ui-gallery-upload-progress-text,
.page .ui-gallery-admin-actions .btn,
.page .ui-hotres-stat-card span,
.page .ui-hotres-stat-card strong,
.page .ui-secret-code,
.page .ui-ajax-text,
.page .ui-page-search-item strong,
.page .ui-page-search-item small,
.page .ui-pictogram-group-title,
.page .ui-pictogram-box span,
.page .ui-gallery-droparea-title,
.page .ui-gallery-droparea-text,
.page .ui-gallery-empty-text,
.page .ui-single-image-empty,
.page .ui-gallery-regenerate-btn,
.page .badge,
.page .ui-badge-count,
.page .ui-faq-badge,
.page .ui-status-badge,
.page .ui-gallery-droparea .ui-gallery-upload-btn,
.page code {
  font-size: 1rem;
}
.page .btn-sm {
  font-size: 1rem;
}
.page textarea.form-control,
.page .ui-card textarea.form-control {
  font-size: 1rem;
  line-height: 1.5;
}
.page .ui-quill-wrap .ql-container.ql-snow,
.page .ui-quill-wrap .ql-editor {
  font-size: 1rem;
}

.ui-icon-text {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
}

.ui-icon {
  font-size: 1.05rem;
  line-height: 1;
}

.ui-nav-link {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
}

.ui-nav-link .ui-icon {
  color: var(--color-primary);
}

.ui-btn-icon {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
}

.ui-roomtypes-total-pill {
  display: inline-flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.35rem 0.55rem;
  padding: 0.45rem 1rem 0.5rem;
  border-radius: 999px;
  background: linear-gradient(135deg, rgba(var(--color-admin-tint-rgb), 0.14), rgba(var(--color-admin-tint-rgb), 0.05));
  border: 1px solid rgba(var(--color-admin-tint-rgb), 0.22);
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.06);
  line-height: 1.2;
}

.ui-roomtypes-total-pill__icon {
  font-size: 1.2rem;
  color: var(--color-primary);
}

.ui-roomtypes-total-pill__label {
  color: var(--color-text-muted);
  font-size: 0.8125rem;
  font-weight: 500;
}

.ui-roomtypes-total-pill__num {
  font-size: 1.4rem;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  color: var(--color-primary);
  line-height: 1;
}

.ui-roomtypes-total-pill__unit {
  font-size: 0.75rem;
  color: var(--color-text-muted);
  font-weight: 500;
}

.ui-select-roomtypes-bulk {
  max-width: 22rem;
}

/* Pasek akcji masowych — zawsze pod ręką przy długiej liście (sticky) */
/* Uwaga: body.admin-app .ui-card { overflow: hidden } (admin-shell-modern) — wtedy sticky
   działa tylko wewnątrz karty i „pływa” razem z całą kartą. Ta karta musi mieć overflow: visible. */
body.admin-app #roomtypes-list-app.ui-card {
  overflow: visible;
}

#roomtypes-list-app > .card-header.roomtypes-bulk-bar {
  position: sticky;
  z-index: 19;
  top: 0;
  /* Nieco mocniej niż .ui-card .card-header — treść pod spodem nie prześwieca przy scrollu */
  background: #f2f2f2;
  box-shadow: 0 6px 16px -12px rgba(15, 23, 42, 0.35);
}

@media (max-width: 991.98px) {
  /* Pod sticky .admin-topbar (z-index 20), żeby pasek nie chował się pod belką */
  body.admin-app #roomtypes-list-app > .card-header.roomtypes-bulk-bar {
    top: 3.5rem;
  }
}
.ui-roomtypes-table-wrap {
  width: 100%;
  overflow: visible;
}

.ui-col-listing-badges,
.ui-cell-listing-badges {
  min-width: 9.5rem;
  max-width: 11rem;
  vertical-align: middle;
}

.ui-col-home-pins,
.ui-cell-home-pins {
  min-width: 13.5rem;
  max-width: 15rem;
  vertical-align: middle;
}

.ui-col-home-tile,
.ui-cell-home-tile {
  min-width: 7.5rem;
  vertical-align: middle;
}

.ui-home-pins-stack {
  display: flex;
  flex-direction: column;
  gap: 0.12rem;
}

.ui-home-pin-label {
  display: block;
  margin: 0;
  font-size: 0.78rem;
  line-height: 1.35;
  white-space: normal;
  cursor: pointer;
}

.ui-mobile-list-home-pins {
  margin-top: 0.35rem;
  padding-top: 0.45rem;
  border-top: 1px dashed rgba(28, 25, 23, 0.12);
}

.ui-mobile-list-listing-badges {
  margin-top: 0.35rem;
  padding-top: 0.45rem;
  border-top: 1px dashed rgba(28, 25, 23, 0.12);
}

.ui-table-roomtypes {
  width: 100%;
  table-layout: auto;
}

.ui-col-roomtype-merged,
.ui-cell-roomtype-main {
  min-width: 14rem;
  max-width: 28rem;
}

.ui-col-roomtype-status,
.ui-cell-roomtype-status {
  min-width: 13.25rem;
  max-width: 17rem;
  vertical-align: top;
}

/* Treść / SEO — czytelna lista etykieta + wartość (lista obiektów) */
.ui-roomtype-seo-block {
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
  padding: 0.1rem 0 0.15rem;
  min-width: 0;
}

.ui-roomtype-seo-row {
  display: grid;
  grid-template-columns: 4.25rem minmax(0, 1fr);
  gap: 0.35rem 0.5rem;
  align-items: center;
}

.ui-roomtype-seo-key {
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: rgba(28, 25, 23, 0.52);
  line-height: 1.2;
}

.ui-roomtype-seo-val {
  display: inline-flex;
  align-items: center;
  gap: 0.28rem;
  padding: 0.22rem 0.5rem;
  border-radius: 0.45rem;
  font-size: 0.8125rem;
  font-weight: 600;
  line-height: 1.25;
  color: rgba(28, 25, 23, 0.78);
  background: rgba(28, 25, 23, 0.055);
  border: 1px solid rgba(28, 25, 23, 0.1);
  width: fit-content;
  max-width: 100%;
}

.ui-roomtype-seo-val.is-ok {
  color: #0f5132;
  background: rgba(25, 135, 84, 0.12);
  border-color: rgba(25, 135, 84, 0.28);
}

.ui-roomtype-seo-val.is-warn {
  color: #664d03;
  background: rgba(255, 193, 7, 0.14);
  border-color: rgba(234, 179, 8, 0.35);
}

.ui-roomtype-seo-val.is-missing {
  color: rgba(28, 25, 23, 0.55);
  background: rgba(28, 25, 23, 0.04);
  border-style: dashed;
}

.ui-roomtype-seo-val .ti {
  font-size: 0.95rem;
  opacity: 0.92;
  flex-shrink: 0;
}

a.ui-roomtype-seo-link.ui-roomtype-seo-val {
  text-decoration: none;
  transition: background 0.15s ease, border-color 0.15s ease;
}

a.ui-roomtype-seo-link.ui-roomtype-seo-val:hover {
  background: rgba(25, 135, 84, 0.2);
  border-color: rgba(25, 135, 84, 0.45);
}

.ui-roomtype-seo-meta-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 0.28rem;
  align-items: center;
}

.ui-roomtype-seo-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.18rem 0.42rem;
  border-radius: 0.4rem;
  font-size: 0.75rem;
  font-weight: 700;
  line-height: 1.2;
  border: 1px solid rgba(28, 25, 23, 0.12);
  background: rgba(28, 25, 23, 0.04);
  color: rgba(28, 25, 23, 0.55);
}

.ui-roomtype-seo-pill.is-ok {
  color: #0f5132;
  background: rgba(25, 135, 84, 0.12);
  border-color: rgba(25, 135, 84, 0.3);
}

.ui-roomtype-seo-pill.is-missing {
  border-style: dashed;
  color: rgba(28, 25, 23, 0.48);
}

/* Bootstrap tooltip: pełny meta title + opis (lista obiektów) */
.ui-roomtype-seo-row--meta.js-roomtype-seo-meta-tooltip {
  cursor: help;
}

.tooltip.ui-roomtype-seo-meta-bs-tooltip .tooltip-inner {
  max-width: min(32rem, 94vw);
  text-align: left;
}

.ui-mobile-list-meta .js-roomtype-seo-meta-tooltip {
  cursor: help;
}

.ui-roomtype-main {
  display: flex;
  align-items: flex-start;
  gap: 0.65rem;
}

.ui-roomtype-main__thumb {
  flex: 0 0 auto;
}

.ui-list-thumb--compact {
  width: 3.35rem;
  height: 3.35rem;
  object-fit: cover;
  border-radius: 0.5rem;
}

.ui-roomtype-main__thumb .ui-list-thumb-placeholder {
  width: 3.35rem;
  height: 3.35rem;
  border-radius: 0.5rem;
}

.ui-roomtype-main__body {
  min-width: 0;
  flex: 1 1 auto;
}

.ui-roomtype-main__line {
  line-height: 1.35;
  margin-top: 0.12rem;
}

.ui-roomtype-guest-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 2rem;
  padding: 0.2rem 0.45rem;
  border-radius: 0.5rem;
  font-weight: 700;
  font-size: 0.875rem;
  background: rgba(28, 25, 23, 0.06);
  border: 1px solid rgba(28, 25, 23, 0.1);
}

.ui-rabat-badge--inline {
  display: inline-block;
  margin-top: 0.25rem;
  font-size: 0.65rem;
}

.ui-home-pins-stack--compact {
  gap: 0.06rem;
}

.ui-home-pins-stack--compact .ui-home-pin-label {
  font-size: 0.68rem;
}

.ui-col-roomtype-actions,
.ui-cell-roomtype-actions {
  min-width: 5.5rem;
  width: 1%;
  white-space: nowrap;
}

.ui-cell-roomtype-actions {
  vertical-align: middle;
}

.ui-roomtype-actions-dropdown {
  position: relative;
  display: inline-block;
  text-align: start;
}

.ui-roomtype-actions-summary {
  display: inline-flex !important;
  align-items: center;
  gap: 0.25rem;
  list-style: none;
  user-select: none;
}

.ui-roomtype-actions-summary::-webkit-details-marker {
  display: none;
}

.ui-roomtype-actions-summary__txt {
  font-size: 0.78rem;
  font-weight: 600;
}

.ui-roomtype-actions-menu {
  position: absolute;
  right: 0;
  top: calc(100% + 4px);
  z-index: 50;
  min-width: 12.5rem;
  max-width: min(18rem, 92vw);
  padding: 0.35rem;
  background: var(--tblr-bg-surface, #fff);
  border: 1px solid rgba(28, 25, 23, 0.12);
  border-radius: 0.5rem;
  box-shadow: 0 8px 28px rgba(0, 0, 0, 0.12);
}

.ui-roomtype-actions-menu .btn {
  margin-bottom: 0.2rem;
}

.ui-roomtype-actions-menu .btn:last-child {
  margin-bottom: 0;
}

.ui-roomtype-actions-menu__row {
  display: flex;
  gap: 0.25rem;
  margin-bottom: 0.25rem;
}

.ui-roomtype-actions-dropdown--block {
  display: block;
  width: 100%;
}

.ui-roomtype-actions-menu--mobile {
  position: static;
  width: 100%;
  max-width: none;
  margin-top: 0.35rem;
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.08);
}

.ui-roomtype-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem 0.65rem;
  width: 100%;
  max-width: 100%;
}

.ui-roomtype-actions__group {
  display: inline-flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.2rem;
  padding: 0.28rem 0.5rem;
  border-radius: 0.5rem;
  background: rgba(28, 25, 23, 0.045);
  border: 1px solid rgba(28, 25, 23, 0.09);
}

.ui-roomtype-actions__group--danger {
  background: rgba(185, 28, 28, 0.07);
  border-color: rgba(185, 28, 28, 0.14);
}

.ui-roomtype-actions__form {
  display: inline-flex;
  margin: 0;
}

.ui-roomtype-actions .btn.ui-roomtype-labeled-btn {
  padding: 0.3rem 0.55rem;
  min-width: auto;
  min-height: auto;
  justify-content: center;
  align-items: center;
  border-radius: 0.4rem;
  line-height: 1.25;
  gap: 0.35rem;
  font-size: 0.78rem;
  font-weight: 600;
  white-space: nowrap;
}

.ui-roomtype-actions .btn.ui-roomtype-labeled-btn .ui-icon {
  font-size: 1rem;
  flex-shrink: 0;
}

.ui-roomtype-actions--mobile {
  gap: 0.45rem;
  justify-content: flex-start;
}

.ui-roomtype-actions--mobile .btn.ui-roomtype-labeled-btn {
  flex: 1 1 calc(50% - 0.35rem);
  min-width: 8.5rem;
  justify-content: center;
}

.ui-section-title {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
}

.ui-section-title .ui-icon {
  color: var(--color-primary);
}

.ui-roomtype-edit-quicknav {
  position: sticky;
  z-index: 30;
  top: 0.65rem;
  margin-bottom: 1rem;
  padding: 0;
  border-radius: var(--admin-shell-radius, 12px);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  box-shadow: 0 1px 0 rgba(15, 23, 42, 0.04), 0 8px 28px rgba(15, 23, 42, 0.08);
}

@media (max-width: 991.98px) {
  .ui-roomtype-edit-quicknav {
    top: 3.65rem;
  }
}
.ui-roomtype-edit-quicknav__inner {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.55rem 0.75rem;
  padding: 0.55rem 0.75rem 0.6rem;
}

.ui-roomtype-edit-quicknav__title {
  flex: 0 0 auto;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-text-muted);
  margin: 0;
}

.ui-roomtype-edit-quicknav__links {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.35rem;
  flex: 1 1 auto;
  min-width: 0;
}

.ui-roomtype-edit-quicknav__link {
  display: inline-flex;
  align-items: center;
  font-size: 0.78rem;
  font-weight: 600;
  line-height: 1.2;
  color: var(--color-text);
  text-decoration: none;
  padding: 0.32rem 0.65rem;
  border-radius: 999px;
  background: rgba(var(--color-dashboard-accent-rgb), 0.08);
  border: 1px solid rgba(var(--color-dashboard-accent-rgb), 0.18);
  transition: background 0.15s ease, border-color 0.15s ease, color 0.15s ease;
}

.ui-roomtype-edit-quicknav__link:hover {
  color: var(--color-text);
  background: rgba(var(--color-dashboard-accent-rgb), 0.14);
  border-color: rgba(var(--color-dashboard-accent-rgb), 0.28);
  text-decoration: none;
}

.ui-roomtype-edit-quicknav__link:focus-visible {
  outline: 2px solid rgba(var(--color-dashboard-accent-rgb), 0.45);
  outline-offset: 2px;
}

.ui-roomtype-edit-quicknav__link--save {
  background: rgba(var(--color-admin-tint-rgb), 0.16);
  border-color: rgba(var(--color-admin-tint-rgb), 0.35);
  color: var(--color-text);
}

.ui-roomtype-edit-quicknav__link--save:hover {
  background: rgba(var(--color-admin-tint-rgb), 0.24);
  border-color: rgba(var(--color-admin-tint-rgb), 0.45);
}

.ui-roomtype-edit-quicknav__actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.45rem;
  flex: 0 0 auto;
  margin-left: auto;
}

.ui-roomtype-edit-quicknav__btn-download {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  font-weight: 600;
  white-space: nowrap;
}

.ui-roomtype-edit-quicknav__btn-download .ti {
  font-size: 1rem;
  opacity: 0.9;
}

@media (max-width: 767.98px) {
  .ui-roomtype-edit-quicknav__inner {
    flex-direction: column;
    align-items: stretch;
  }
  .ui-roomtype-edit-quicknav__actions {
    margin-left: 0;
    justify-content: flex-start;
  }
  .ui-roomtype-edit-quicknav__btn-download span {
    font-size: 0.8rem;
  }
}
.ui-roomtype-form-section {
  padding: 1.25rem 1.1rem;
  margin-bottom: 1rem;
  border-radius: var(--admin-shell-radius, 12px);
  background: rgba(255, 255, 255, 0.65);
  border: 1px solid rgba(15, 23, 42, 0.06);
}

body.admin-app .ui-roomtype-save-bar {
  position: sticky;
  bottom: 0;
  z-index: 15;
  margin-top: 1.5rem;
  padding-top: 1rem;
  padding-bottom: 1rem;
  background: linear-gradient(180deg, rgba(244, 246, 250, 0) 0%, var(--color-dashboard-bg) 28%);
  border-top: 1px solid var(--color-border);
  box-shadow: 0 -8px 24px rgba(15, 23, 42, 0.04);
}

.admin-sidebar {
  background: var(--color-surface);
  border-right: 1px solid var(--color-border);
  box-shadow: 4px 0 20px rgba(0, 0, 0, 0.05);
}

.admin-sidebar > .container-fluid {
  padding-left: 1rem;
  padding-right: 1rem;
}

@media (min-width: 992px) {
  .admin-sidebar > .container-fluid {
    padding-left: 1.125rem;
    padding-right: 1.125rem;
  }
  body.admin-app .admin-sidebar.navbar-vertical.navbar-expand-lg {
    width: var(--admin-sidebar-width);
  }
  body.admin-app .navbar-expand-lg.navbar-vertical ~ .navbar,
  body.admin-app .navbar-expand-lg.navbar-vertical ~ .page-wrapper {
    margin-left: var(--admin-sidebar-width);
  }
  body.admin-app .navbar-expand-lg.navbar-vertical.navbar-end ~ .navbar,
  body.admin-app .navbar-expand-lg.navbar-vertical.navbar-end ~ .page-wrapper,
  body.admin-app .navbar-expand-lg.navbar-vertical.navbar-right ~ .navbar,
  body.admin-app .navbar-expand-lg.navbar-vertical.navbar-right ~ .page-wrapper {
    margin-left: 0;
    margin-right: var(--admin-sidebar-width);
  }
}
.admin-sidebar .navbar-brand {
  padding: 1rem 0.5rem;
  border-bottom: 1px solid var(--color-border);
}

.admin-sidebar .navbar-brand a {
  color: var(--color-dashboard-accent);
  text-decoration: none;
  font-weight: var(--font-weight-bold-max);
  font-size: 1.05rem;
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
}

.admin-sidebar .navbar-brand .ui-icon {
  color: var(--color-primary);
  font-size: 1.35rem;
}

.admin-menu-group-title {
  margin: 1.15rem 0 0.35rem;
  padding: 0 1rem;
  font-size: 0.65rem;
  font-weight: var(--font-weight-bold-max);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-text-muted);
  opacity: 0.92;
}

.admin-sidebar .admin-menu-group-title:first-child {
  margin-top: 0.25rem;
}

.admin-menu-group-hint {
  margin: -0.15rem 0 0.5rem;
  max-width: min(22rem, 100%);
  line-height: 1.35;
}

.admin-sidebar .nav-link {
  border-radius: 12px;
  color: var(--color-text-muted);
  font-weight: 600;
  margin-bottom: 0.25rem;
  padding: 0.6rem 1rem;
  transition: background 0.2s ease, color 0.2s ease;
}

.admin-sidebar .nav-link:hover,
.admin-sidebar .nav-link.active {
  background: rgba(var(--color-admin-tint-rgb), 0.12);
  color: var(--color-dashboard-accent);
}

.admin-sidebar .admin-cache-clear-form {
  margin: 0;
}

.admin-sidebar .admin-cache-clear-form button.nav-link {
  cursor: pointer;
}

.admin-topbar {
  background: var(--color-surface);
  border-bottom: 1px solid var(--color-border);
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.04);
}

.page-title {
  color: var(--color-text);
  font-weight: 700;
  font-size: clamp(1.15rem, 2.5vw, 1.5rem);
  word-wrap: break-word;
  overflow-wrap: break-word;
}

.ui-page {
  padding-top: 1.25rem;
  padding-bottom: 2rem;
}

.ui-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 1rem;
  gap: 0.9rem;
  flex-wrap: wrap;
}

.ui-subtitle {
  color: var(--color-text-muted);
  margin-top: 0.35rem;
}

.ui-card {
  border: 1px solid var(--color-border);
  border-radius: 16px;
  background: var(--color-surface);
  box-shadow: 0 12px 28px rgba(var(--color-shadow-rgb), 0.08);
}

.ui-card .card-header {
  border-bottom: 1px solid var(--color-border);
  background: rgba(var(--color-dashboard-accent-rgb), 0.04);
}

.ui-card .card-title {
  margin: 0;
  color: var(--color-text);
}

/* ========== Dashboard ========== */
.page-body {
  background: var(--color-dashboard-bg);
}

.ui-page .ui-header {
  margin-bottom: 1.5rem;
  padding-bottom: 1rem;
}

.ui-page .page-title {
  font-size: clamp(1.35rem, 2.8vw, 1.75rem);
  font-weight: var(--font-weight-bold-max);
  color: var(--color-text);
}

.ui-page .ui-header .ui-subtitle {
  font-size: 0.98rem;
  line-height: 1.5;
  margin-top: 0.4rem;
  max-width: 52ch;
}

.ui-stat-card {
  display: block;
  border: 1px solid var(--color-border);
  border-radius: 16px;
  background: var(--color-surface);
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.04);
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
  text-decoration: none;
  color: inherit;
  height: 100%;
}

.ui-stat-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.08);
  border-color: rgba(var(--color-dashboard-accent-rgb), 0.22);
  color: inherit;
}

.ui-stat-card .card-body {
  padding: 1.35rem 1.25rem;
  text-align: center;
}

.ui-stat-value {
  font-size: clamp(1.75rem, 3vw, 2.25rem);
  font-weight: var(--font-weight-bold-max);
  color: var(--color-dashboard-accent);
  letter-spacing: -0.03em;
  line-height: 1.2;
}

.ui-stat-card:hover .ui-stat-value {
  color: var(--color-primary-hover);
}

.ui-stat-label {
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--color-text-muted);
  margin-top: 0.35rem;
  letter-spacing: 0.01em;
}

.ui-stat-card .text-muted {
  color: var(--color-text-muted);
  font-weight: 600;
}

.row-cards .ui-card {
  border-radius: 16px;
  overflow: hidden;
}

.ui-card .card-header {
  padding: 1rem 1.25rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.ui-card .card-header .card-title {
  font-size: 1rem;
  font-weight: 700;
}

.ui-card .card-header .btn {
  border-radius: 10px;
  font-weight: 600;
}

.list-group-hoverable .list-group-item {
  padding: 0.9rem 1.25rem;
  border-color: var(--color-border);
  transition: background 0.15s ease;
}

.list-group-hoverable .list-group-item:hover {
  background: rgba(var(--color-dashboard-accent-rgb), 0.05);
}

.list-group-hoverable .list-group-item .badge.ui-role-badge {
  font-size: 0.75rem;
  padding: 0.3rem 0.6rem;
  border-radius: 8px;
  font-weight: 600;
}

.ui-card .list-group-item-action {
  padding: 0.85rem 1.25rem;
  border-color: var(--color-border);
  color: var(--color-text);
  transition: background 0.15s ease, border-color 0.15s ease;
}

.ui-card .list-group-item-action:hover {
  background: rgba(var(--color-dashboard-accent-rgb), 0.045);
  border-left-color: var(--color-primary);
}

.ui-card .card-body .d-flex.flex-wrap.gap-2 .btn {
  border-radius: 12px;
  padding: 0.5rem 1rem;
  font-weight: 600;
  transition: background 0.2s ease, border-color 0.2s ease, transform 0.15s ease;
}

.ui-card .card-body .d-flex.flex-wrap.gap-2 .btn:hover {
  transform: translateY(-1px);
}

.ui-page section .ui-section-title {
  font-size: 1rem;
  font-weight: 700;
  color: var(--color-text);
  margin-bottom: 0.5rem;
}

.ui-page .list-group-item.text-center.text-muted {
  padding: 1.5rem 1.25rem;
  font-size: 0.95rem;
}

.ui-btn-primary {
  background: var(--color-primary);
  border-color: var(--color-primary);
  color: #fff;
  font-weight: 600;
}

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

.ui-btn-outline {
  border-color: var(--color-border);
  color: var(--color-primary);
  font-weight: 600;
}

.ui-btn-outline:hover {
  border-color: var(--color-primary);
  background: rgba(var(--color-admin-tint-rgb), 0.09);
  color: var(--color-primary-hover);
}

.ui-table thead th {
  color: var(--color-text-muted);
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.ui-table tbody tr:hover {
  background: rgba(var(--color-dashboard-accent-rgb), 0.04);
}

.ui-form-grid {
  display: grid;
  gap: 1rem;
  grid-template-columns: repeat(12, 1fr);
}

.ui-field {
  grid-column: span 6;
}

.ui-field-full {
  grid-column: span 12;
}

.ui-field-address-street {
  grid-column: span 8;
}

.ui-field-postal-code {
  grid-column: span 4;
}

@media (max-width: 991px) {
  .ui-field,
  .ui-field-full,
  .ui-field-address-street,
  .ui-field-postal-code {
    grid-column: span 12;
  }
}
.ui-label {
  display: block;
  margin-bottom: 0.45rem;
  font-size: 0.86rem;
  font-weight: 700;
  color: var(--color-text);
}

.ui-form-section-title {
  color: var(--color-text);
}

.ui-input:focus,
.ui-select:focus {
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(var(--color-accent-rgb), 0.18);
}

.ui-errors {
  margin-top: 0.4rem;
  color: #b23939;
  font-size: 0.82rem;
}

.ui-login-wrap {
  min-height: 100vh;
  background: linear-gradient(155deg, #eef0f4 0%, #dde1e8 100%);
}

.ui-login-card {
  border-radius: 16px;
  border: 1px solid var(--color-border);
  box-shadow: 0 20px 42px rgba(15, 15, 24, 0.12);
}

.ui-kv-list {
  display: grid;
  gap: 0.6rem;
}

.ui-kv-item {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  padding: 0.65rem 0.75rem;
  border: 1px solid rgba(var(--color-admin-tint-rgb), 0.15);
  border-radius: 10px;
  background: #fff;
}

.ui-kv-item span {
  color: var(--color-text-muted);
  font-size: 0.9rem;
}

.ui-kv-item strong {
  color: var(--color-text);
  text-align: right;
}

.ui-block-title {
  font-size: 0.95rem;
  font-weight: 700;
  margin-bottom: 0.5rem;
  color: var(--color-text-muted);
}

.ui-html-preview {
  border: 1px solid var(--color-border);
  border-radius: 12px;
  background: #fff;
  padding: 0.9rem;
  min-height: 150px;
}

.ui-gallery-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(172px, 1fr));
  gap: 1rem;
}

.ui-gallery-item {
  position: relative;
  display: block;
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid var(--color-border);
  background: #fff;
}

.ui-gallery-item img {
  width: 100%;
  height: 130px;
  object-fit: cover;
  display: block;
}

.ui-gallery-item span {
  position: absolute;
  left: 0.45rem;
  bottom: 0.45rem;
  background: rgba(63, 42, 29, 0.82);
  color: #fff;
  font-size: 0.72rem;
  padding: 0.2rem 0.45rem;
  border-radius: 999px;
}

.ui-json {
  background: #1f1b17;
  color: #f6e8d9;
  border-radius: 12px;
  padding: 0.9rem;
  max-height: 420px;
  overflow: auto;
  font-size: 0.82rem;
  line-height: 1.5;
}

.ui-room-card {
  border: 1px solid var(--color-border);
  border-radius: 14px;
  background: #fff;
  padding: 0.9rem;
  height: 100%;
}

.ui-room-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
}

.ui-room-header h4 {
  margin: 0;
  font-size: 1rem;
  color: var(--color-text);
}

.ui-details-summary {
  cursor: pointer;
  color: var(--color-primary);
  font-weight: 600;
}

.ui-facility-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(210px, 1fr));
  gap: 0.6rem;
}

.ui-facility-pill {
  display: flex;
  align-items: center;
  gap: 0.55rem;
  border: 1px solid var(--color-border);
  background: #fff;
  border-radius: 999px;
  padding: 0.4rem 0.65rem;
}

.ui-facility-pill img {
  width: 18px;
  height: 18px;
  object-fit: contain;
}

.ui-facility-pill span {
  color: var(--color-text);
  font-size: 0.84rem;
  font-weight: 600;
  flex: 1;
}

.ui-facility-pill code {
  font-size: 0.72rem;
  color: var(--color-text-muted);
}

.ui-logo-preview {
  max-width: 240px;
  max-height: 90px;
  width: auto;
  border: 1px solid var(--color-border);
  border-radius: 10px;
  background: #fff;
  padding: 0.45rem;
}

.ui-og-preview {
  display: block;
  width: 100%;
  max-width: 520px;
  height: auto;
  aspect-ratio: 1200/630;
  object-fit: cover;
  border: 1px solid var(--color-border);
  border-radius: 10px;
  background: var(--color-surface-soft, #f1f5f9);
}

.ui-favicon-preview {
  display: block;
  width: 32px;
  height: 32px;
  object-fit: contain;
  border: 1px solid var(--color-border);
  border-radius: 4px;
  background: var(--color-surface-soft, #f1f5f9);
  padding: 2px;
}

.ui-marketing-list {
  margin: 0;
  padding-left: 1.15rem;
  display: grid;
  gap: 0.55rem;
}

.ui-marketing-list li {
  color: var(--color-text);
  font-size: 0.9rem;
}

.ui-form-panel {
  display: grid;
  gap: 1rem;
}

.ui-form-section {
  border: 1px solid var(--color-border);
  border-radius: 12px;
  padding: 1rem;
  background: #fff;
}

.ui-form-section-title {
  margin-bottom: 0.8rem;
}

.ui-form-section.mt-4 {
  margin-top: 1.25rem;
}

.ui-form-actions-bar {
  padding: 0.75rem 0;
  border-bottom: 1px solid var(--color-border);
}

.ui-form-tabs {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.35rem;
  margin: 0 0 1rem;
  padding: 0.45rem;
  list-style: none;
  background: color-mix(in srgb, var(--color-border) 28%, var(--color-surface));
  border: 1px solid var(--color-border);
  border-radius: var(--admin-shell-radius, 12px);
}
.ui-form-tabs .nav-item {
  margin: 0;
}
.ui-form-tabs .nav-link {
  margin: 0;
  border: 1px solid transparent;
  border-radius: max(var(--admin-shell-radius, 12px) - 4px, 8px);
  padding: 0.5rem 0.95rem;
  color: var(--color-text-muted);
  font-weight: 600;
  font-size: 0.875rem;
  line-height: 1.25;
  background: transparent;
  cursor: pointer;
  transition: color 0.15s ease, background 0.15s ease, border-color 0.15s ease, box-shadow 0.15s ease;
}
.ui-form-tabs .nav-link:hover {
  color: var(--color-text);
  background: color-mix(in srgb, var(--color-surface) 88%, var(--color-border));
  border-color: color-mix(in srgb, var(--color-border) 70%, transparent);
}
.ui-form-tabs .nav-link:focus-visible {
  outline: 2px solid rgba(var(--color-dashboard-accent-rgb), 0.45);
  outline-offset: 2px;
}
.ui-form-tabs .nav-link.active {
  color: var(--color-text);
  font-weight: 700;
  background: var(--color-surface);
  border-color: color-mix(in srgb, rgb(var(--color-dashboard-accent-rgb)) 38%, var(--color-border));
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.07), 0 0 0 1px rgba(var(--color-dashboard-accent-rgb), 0.12);
}
.ui-form-tabs .nav-link.active:hover {
  color: var(--color-text);
  background: var(--color-surface);
  border-color: color-mix(in srgb, rgb(var(--color-dashboard-accent-rgb)) 48%, var(--color-border));
}

.ui-form-tab-content {
  padding-top: 1rem;
  min-height: 280px;
}

.ui-form-tab-pane {
  display: none;
}
.ui-form-tab-pane.active {
  display: block;
}

.ui-form-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  align-items: center;
}

.ui-form-nav .btn-sm {
  padding: 0.35rem 0.65rem;
  font-size: 0.85rem;
}

.ui-form-hint {
  margin: 0 0 0.75rem;
  color: var(--color-text-muted);
  font-size: 0.86rem;
}

.ui-form-panel .help-text {
  margin: 0.35rem 0 0.75rem;
  color: var(--color-text-muted);
  font-size: 0.86rem;
  line-height: 1.45;
  max-width: 48rem;
}

.homepage-sections-card .card-header {
  background: rgba(var(--color-admin-tint-rgb), 0.06);
  border-bottom: 1px solid var(--color-border);
}

.homepage-sections-table tbody tr.homepage-sections-row {
  transition: background-color 0.12s ease;
}

.homepage-sections-table tbody tr.homepage-sections-row:hover {
  background: rgba(var(--color-admin-tint-rgb), 0.05);
}

/* Lista sekcji strony głównej — kroki, legenda, panel techniczny (pełna szerokość kontenera) */
.homepage-sections-page {
  max-width: none;
}

.homepage-sections-step__icon {
  font-size: 1.75rem;
  line-height: 1;
  margin-bottom: 0.35rem;
  opacity: 0.92;
}

.homepage-sections-legend-card .card-body {
  background: linear-gradient(180deg, rgba(var(--color-admin-tint-rgb), 0.05), rgba(var(--color-admin-tint-rgb), 0.02));
}

.homepage-sections-legend-item {
  padding: 0.65rem 0.75rem;
  border-radius: 0.65rem;
  background: var(--color-surface, #fff);
  border: 1px solid var(--color-border);
  height: 100%;
  border-left-width: 4px;
  border-left-style: solid;
}

.homepage-sections-legend-item--layout {
  border-left-color: var(--tblr-primary, #206bc4);
}

.homepage-sections-legend-item--cms {
  border-left-color: var(--tblr-info, #4299e1);
}

.homepage-sections-legend-item--title {
  border-left-color: var(--tblr-secondary, #6c757d);
}

.homepage-sections-legend-item--muted {
  border-left-color: rgba(108, 117, 125, 0.45);
}

.homepage-sections-tech summary {
  list-style: none;
}

.homepage-sections-tech summary::-webkit-details-marker {
  display: none;
}

.homepage-sections-tech .card-header.cursor-pointer:hover {
  background: rgba(var(--color-admin-tint-rgb), 0.06);
}

.homepage-sections-json-hint code {
  font-size: 0.78rem;
  word-break: break-word;
}

.homepage-sections-guide .card-body {
  background: rgba(var(--color-admin-tint-rgb), 0.04);
}

.homepage-sections-drag {
  cursor: grab;
  user-select: none;
  width: 2.5rem;
  vertical-align: middle;
}

.homepage-sections-drag:active {
  cursor: grabbing;
}

.homepage-sections-table tbody tr.homepage-sections-row--layout {
  border-left: 4px solid var(--tblr-primary, #206bc4);
}

.homepage-sections-table tbody tr.homepage-sections-row--cms {
  border-left: 4px solid var(--tblr-info, #4299e1);
}

.homepage-sections-table tbody tr.homepage-sections-row--title {
  border-left: 4px solid var(--tblr-secondary, #6c757d);
}

.homepage-sections-table tbody tr.homepage-sections-row--other {
  border-left: 4px solid rgba(108, 117, 125, 0.45);
}

.homepage-sections-table tbody tr.homepage-sections-row--disabled {
  opacity: 0.58;
}

.homepage-sections-table tbody tr.homepage-sections-row--disabled .homepage-sections-title {
  text-decoration: line-through;
  text-decoration-color: rgba(0, 0, 0, 0.22);
}

.homepage-sections-table tbody tr.homepage-sections-row--dragging {
  opacity: 0.55;
  background: rgba(var(--color-admin-tint-rgb), 0.12) !important;
}

.homepage-sections-type {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
  align-items: flex-start;
}

.homepage-sections-type-label {
  font-weight: 600;
  color: var(--color-text);
  line-height: 1.3;
}

.homepage-sections-type-code {
  font-size: 0.72rem;
  font-weight: 400;
  color: var(--color-text-muted);
  background: rgba(var(--color-admin-tint-rgb), 0.08);
  padding: 0.1rem 0.35rem;
  border-radius: 4px;
}

.homepage-sections-title {
  display: inline-block;
  max-width: min(36rem, 52vw);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  vertical-align: bottom;
}

.homepage-sections-status {
  font-weight: 600;
  font-size: 0.75rem;
  padding: 0.35em 0.65em;
}

.homepage-sections-move-btns .btn:disabled {
  opacity: 0.35;
}

.homepage-sections-empty-icon .ti {
  font-size: 2.5rem;
  line-height: 1;
  opacity: 0.45;
}

.homepage-section-page-links .homepage-section-page-link-row .card-body {
  background: rgba(var(--color-admin-tint-rgb), 0.03);
}

.homepage-section-page-link-row .js-homepage-page-link-remove .ti {
  vertical-align: -0.1em;
}

.ui-admin-map {
  height: 320px;
  width: 100%;
  border: 1px solid var(--color-border);
  border-radius: 10px;
  overflow: hidden;
  background: var(--color-bg);
}

.residence-address-search-input {
  min-width: min(100%, 220px);
}

.residence-geocode-results {
  list-style: none;
  margin: 0.5rem 0 0;
  padding: 0;
  max-height: 240px;
  overflow-y: auto;
  border: 1px solid var(--color-border);
  border-radius: 10px;
  background: #fff;
  box-shadow: 0 4px 14px rgba(0, 0, 0, 0.06);
}

.residence-geocode-results__item {
  margin: 0;
  border-bottom: 1px solid var(--color-border);
}

.residence-geocode-results__item:last-child {
  border-bottom: none;
}

.residence-geocode-results__btn {
  display: block;
  width: 100%;
  text-align: left;
  padding: 0.55rem 0.85rem;
  border: none;
  background: transparent;
  font: inherit;
  font-size: 0.88rem;
  line-height: 1.35;
  color: var(--color-text);
  cursor: pointer;
  transition: background 0.15s ease;
}

.residence-geocode-results__btn:hover {
  background: rgba(var(--color-accent-rgb), 0.08);
}

.residence-geocode-results__empty {
  margin: 0;
  padding: 0.75rem 0.85rem;
  font-size: 0.88rem;
  color: var(--color-text-muted);
}

.ui-select-search-wrap {
  border: 1px solid var(--color-border);
  border-radius: 12px;
  background: #fff;
  overflow: hidden;
}
.ui-select-search-wrap > .ui-select-search {
  display: block;
  width: 100%;
  box-sizing: border-box;
  border: none;
  border-bottom: 1px solid var(--color-border);
  border-radius: 0;
  padding: 0.55rem 0.75rem 0.55rem 2.25rem;
  font-size: 0.9rem;
  background-color: rgba(var(--color-admin-tint-rgb), 0.04);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%235c5d68' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cpath d='m21 21-4.3-4.3'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: 0.6rem center;
}
.ui-select-search-wrap > .ui-select-search::placeholder {
  color: var(--color-text-muted);
}
.ui-select-search-wrap > .ui-select-search:focus {
  outline: none;
  background-color: #fff;
  box-shadow: 0 2px 0 0 var(--color-primary);
}
.ui-select-search-wrap > select {
  min-height: 8rem;
  max-height: 14rem;
  width: 100%;
  border: none;
  border-radius: 0;
  padding: 0.5rem 0.75rem;
  font-size: 0.9rem;
  background: #fff;
  cursor: pointer;
}
.ui-select-search-wrap > select option {
  padding: 0.4rem 0.5rem;
}
.ui-select-search-wrap > select option:checked {
  background: rgba(var(--color-admin-tint-rgb), 0.12);
}

.ui-roomtypes-picker {
  border: 1px solid var(--color-border);
  border-radius: 12px;
  background: #fff;
  overflow: hidden;
}

.ui-roomtypes-picker--split {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(240px, 32%);
  gap: 0;
  align-items: stretch;
}
@media (max-width: 900px) {
  .ui-roomtypes-picker--split {
    grid-template-columns: 1fr;
  }
}

.ui-roomtypes-picker__main {
  display: flex;
  flex-direction: column;
  min-width: 0;
  border-right: 1px solid var(--color-border);
}
@media (max-width: 900px) {
  .ui-roomtypes-picker__main {
    border-right: none;
    border-bottom: 1px solid var(--color-border);
  }
}

.ui-roomtypes-picker__lead {
  font-size: 0.86rem;
  line-height: 1.45;
  color: var(--color-text-muted);
  padding: 0.65rem 0.75rem 0;
  margin: 0;
}

.ui-roomtypes-picker__search {
  display: block;
  width: 100%;
  box-sizing: border-box;
  border: none;
  border-bottom: 1px solid var(--color-border);
  border-radius: 0;
  padding: 0.55rem 0.75rem 0.55rem 2.25rem;
  font-size: 0.9rem;
  background-color: rgba(var(--color-admin-tint-rgb), 0.04);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%235c5d68' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cpath d='m21 21-4.3-4.3'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: 0.6rem center;
}
.ui-roomtypes-picker__search::placeholder {
  color: var(--color-text-muted);
}
.ui-roomtypes-picker__search:focus {
  outline: none;
  background-color: #fff;
  box-shadow: 0 2px 0 0 var(--color-primary);
}

.ui-roomtypes-picker__list-wrap {
  position: relative;
  flex: 1;
  min-height: 10rem;
  display: flex;
  flex-direction: column;
}

.ui-roomtypes-picker__list {
  flex: 1;
  max-height: 18rem;
  overflow-y: auto;
  padding: 0.5rem 0.65rem 0.65rem;
  -webkit-overflow-scrolling: touch;
}
.ui-roomtypes-picker__list .ui-roomtypes-checkbox-choices {
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
}
.ui-roomtypes-picker__list .ui-roomtypes-picker__item {
  display: flex;
  align-items: flex-start;
  gap: 0.65rem;
  margin: 0;
  padding: 0.65rem 0.8rem;
  border: 1px solid var(--color-border);
  border-radius: 10px;
  background: var(--color-surface-soft);
  cursor: pointer;
  transition: border-color 0.15s ease, background 0.15s ease, box-shadow 0.15s ease;
}
.ui-roomtypes-picker__list .ui-roomtypes-picker__item:hover {
  border-color: rgba(var(--color-accent-rgb), 0.45);
  background: #fff;
  box-shadow: 0 2px 8px rgba(var(--color-shadow-rgb), 0.07);
}
.ui-roomtypes-picker__list .ui-roomtypes-picker__item:focus-within {
  border-color: color-mix(in srgb, var(--color-primary) 40%, var(--color-border));
  box-shadow: 0 0 0 2px rgba(var(--color-accent-rgb), 0.12);
}
.ui-roomtypes-picker__list .ui-roomtypes-picker__item:has(.form-check-input:checked) {
  border-color: color-mix(in srgb, var(--color-primary) 45%, var(--color-border));
  background: rgba(var(--color-admin-tint-rgb), 0.1);
  box-shadow: inset 0 0 0 1px rgba(var(--color-accent-rgb), 0.1);
}
.ui-roomtypes-picker__list .form-check {
  display: flex;
  align-items: flex-start;
  gap: 0.55rem;
  margin: 0 0 0.45rem;
  padding: 0.6rem 0.75rem;
  border: 1px solid var(--color-border);
  border-radius: 10px;
  background: var(--color-surface-soft);
  cursor: pointer;
  transition: border-color 0.15s ease, background 0.15s ease, box-shadow 0.15s ease;
}
.ui-roomtypes-picker__list .form-check:last-child {
  margin-bottom: 0;
}
.ui-roomtypes-picker__list .form-check:hover {
  border-color: rgba(var(--color-accent-rgb), 0.4);
  background: #fff;
  box-shadow: 0 1px 4px rgba(var(--color-shadow-rgb), 0.06);
}
.ui-roomtypes-picker__list .form-check:has(.form-check-input:checked) {
  border-color: color-mix(in srgb, var(--color-primary) 45%, var(--color-border));
  background: rgba(var(--color-admin-tint-rgb), 0.08);
  box-shadow: 0 0 0 1px rgba(var(--color-accent-rgb), 0.12);
}
.ui-roomtypes-picker__list .form-check-input {
  cursor: pointer;
  width: 1.1rem;
  height: 1.1rem;
  margin-top: 0.12rem;
  flex-shrink: 0;
  accent-color: var(--color-primary);
}
.ui-roomtypes-picker__list .form-check-label {
  cursor: pointer;
  flex: 1;
  min-width: 0;
  font-size: 0.88rem;
  font-weight: 600;
  line-height: 1.35;
  color: var(--color-text);
}
.ui-roomtypes-picker__list .ui-roomtypes-picker__item .form-check-label {
  display: block;
  padding-top: 0.02rem;
}

.ui-roomtypes-picker__empty {
  margin: 0;
  padding: 1rem 0.85rem;
  font-size: 0.86rem;
  color: var(--color-text-muted);
  line-height: 1.45;
  text-align: center;
  border-top: 1px dashed var(--color-border);
  background: rgba(var(--color-admin-tint-rgb), 0.04);
}

.ui-roomtypes-picker__selected {
  display: flex;
  flex-direction: column;
  min-width: 0;
  background: linear-gradient(180deg, rgba(var(--color-admin-tint-rgb), 0.07) 0%, #fff 48%);
}

.ui-roomtypes-picker__selected-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  padding: 0.55rem 0.75rem;
  border-bottom: 1px solid var(--color-border);
  background: rgba(var(--color-admin-tint-rgb), 0.05);
}

.ui-roomtypes-picker__selected-title {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  font-size: 0.82rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--color-text-muted);
}

.ui-roomtypes-picker__selected-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.65rem;
  height: 1.65rem;
  padding: 0 0.4rem;
  border-radius: 999px;
  font-size: 0.8rem;
  font-weight: 700;
  color: #fff;
  background: var(--color-primary);
}

.ui-roomtypes-picker__selected .ui-multi-select-tags {
  flex: 1;
  min-height: 8rem;
  max-height: 22rem;
  overflow-y: auto;
  border-top: none;
  align-content: flex-start;
  background: transparent;
}

.ui-multi-select-tags {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: 0.45rem 0.5rem;
  padding: 0.65rem 0.75rem 0.75rem;
  border-top: 1px solid var(--color-border);
  background: linear-gradient(180deg, rgba(var(--color-admin-tint-rgb), 0.06) 0%, #fff 100%);
  min-height: 2.75rem;
}

.ui-multi-select-tags__placeholder {
  margin: 0;
  font-size: 0.84rem;
  color: var(--color-text-muted);
  line-height: 1.45;
}

.ui-multi-select-tag {
  display: inline-flex;
  align-items: stretch;
  max-width: 100%;
  border-radius: 10px;
  border: 1px solid color-mix(in srgb, var(--color-primary) 28%, var(--color-border));
  background: #fff;
  box-shadow: 0 1px 3px rgba(var(--color-shadow-rgb), 0.06);
  overflow: hidden;
}

.ui-multi-select-tag__body {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  gap: 0.08rem;
  padding: 0.45rem 0.55rem 0.45rem 0.65rem;
  min-width: 0;
}

.ui-multi-select-tag__title {
  display: block;
  font-size: 0.86rem;
  font-weight: 700;
  line-height: 1.25;
  color: var(--color-text);
  max-width: 22rem;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.ui-multi-select-tag__sub {
  display: block;
  font-size: 0.72rem;
  font-weight: 600;
  font-family: ui-monospace, monospace;
  color: var(--color-text-muted);
  max-width: 22rem;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.ui-multi-select-tag__remove {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  margin: 0;
  padding: 0;
  border: none;
  border-left: 1px solid var(--color-border);
  background: rgba(var(--color-admin-tint-rgb), 0.06);
  color: var(--color-text-muted);
  cursor: pointer;
  transition: background 0.15s ease, color 0.15s ease;
}
.ui-multi-select-tag__remove .ti {
  font-size: 1rem;
}
.ui-multi-select-tag__remove:hover {
  background: rgba(220, 53, 69, 0.1);
  color: #b91c1c;
}

.ui-roomtype-meta {
  margin-top: 0.45rem;
  display: flex;
  gap: 0.35rem;
  flex-wrap: wrap;
}

.ui-logo-box {
  border: 1px dashed var(--color-border);
  border-radius: 12px;
  padding: 0.8rem;
  background: #fff;
}

.ui-card .form-label {
  display: block;
  margin-bottom: 0.45rem;
  font-size: 0.86rem;
  font-weight: 700;
  color: var(--color-text);
}

.ui-card .form-control,
.ui-card .form-select,
.ui-card textarea.form-control {
  border: 1px solid var(--color-border);
  border-radius: 12px;
  background: #fff;
  min-height: 44px;
}

.ui-card .form-select {
  padding: 0.5rem 2.25rem 0.5rem 0.85rem;
  font-size: 0.95rem;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%235c5d68' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 0.75rem center;
  cursor: pointer;
}
.ui-card .form-select option {
  padding: 0.4rem 0.5rem;
}

.ui-card textarea.form-control {
  min-height: 110px;
}

.ui-card .form-control:focus,
.ui-card .form-select:focus,
.ui-card textarea.form-control:focus {
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(var(--color-admin-tint-rgb), 0.18);
}

.ui-filter-card {
  border-style: dashed;
}

.ui-filter-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr auto;
  gap: 0.85rem;
  align-items: end;
}

.ui-filter-item {
  min-width: 0;
}

.ui-filter-item-wide {
  grid-column: span 1;
}

.ui-filter-actions {
  display: flex;
  gap: 0.5rem;
  justify-content: flex-end;
  flex-wrap: wrap;
}

.ui-mobile-list-card {
  border: 1px solid var(--color-border);
  background: #fff;
  border-radius: 12px;
  padding: 0.75rem;
  margin-bottom: 0.75rem;
}

.ui-mobile-list-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.6rem;
  margin-bottom: 0.45rem;
}

.ui-mobile-list-top--hotres {
  flex-wrap: wrap;
  align-items: flex-start;
}

.ui-mobile-list-top--hotres h3 {
  flex: 1 1 12rem;
  min-width: 0;
}

.ui-mobile-list-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
  justify-content: flex-end;
  flex-shrink: 0;
}

.ui-mobile-list-active {
  margin-bottom: 0.55rem;
}

.ui-mobile-list-active .ui-hotres-toggle {
  white-space: normal;
  text-align: center;
  min-height: 2.5rem;
}

.ui-mobile-list-top h3 {
  margin: 0;
  font-size: 1rem;
}

.ui-mobile-list-meta {
  display: grid;
  gap: 0.2rem;
  font-size: 0.82rem;
}

.ui-mobile-list-meta span {
  color: var(--color-text-muted);
}

.ui-mobile-list-message {
  margin-top: 0.45rem;
  font-size: 0.8rem;
}

.ui-mobile-list-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
  margin-top: 0.6rem;
}

.ui-gallery-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
}

#roomtype-gallery-app {
  padding: 0;
}

.ui-gallery-regenerate-btn {
  font-size: 0.88rem;
  font-weight: 600;
}

.ui-gallery-upload-zone {
  margin-bottom: 1.25rem;
}

.ui-gallery-file-input {
  position: absolute;
  width: 0.1px;
  height: 0.1px;
  opacity: 0;
  overflow: hidden;
  z-index: -1;
  clip: rect(0, 0, 0, 0);
  clip-path: inset(50%);
}

.ui-gallery-droparea {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 200px;
  border: 2px dashed var(--color-border);
  border-radius: 16px;
  background: linear-gradient(180deg, #faf9f7 0%, var(--color-surface-soft) 100%);
  padding: 2.5rem 2rem;
  cursor: pointer;
  transition: border-color 0.22s ease, background 0.22s ease, box-shadow 0.22s ease;
  text-align: center;
}
.ui-gallery-droparea::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 14px;
  margin: 4px;
  border: 1px dashed rgba(var(--color-admin-tint-rgb), 0.2);
  pointer-events: none;
}
.ui-gallery-droparea:hover {
  border-color: var(--color-primary);
  background: linear-gradient(180deg, #fff 0%, #faf9f7 100%);
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.06);
}
.ui-gallery-droparea.is-dragover {
  border-color: var(--color-primary);
  border-style: solid;
  border-width: 2px;
  background: #fff;
  box-shadow: 0 0 0 4px rgba(var(--color-admin-tint-rgb), 0.15);
}
.ui-gallery-droparea:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px rgba(var(--color-admin-tint-rgb), 0.35);
}
.ui-gallery-droparea .ui-gallery-droparea-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  position: relative;
  z-index: 1;
  text-align: center;
  max-width: 360px;
}
.ui-gallery-droparea .ui-gallery-droparea-icon-wrap,
.ui-gallery-droparea .ui-gallery-droparea-title,
.ui-gallery-droparea .ui-gallery-droparea-text {
  pointer-events: none;
}
.ui-gallery-droparea .ui-gallery-droparea-icon-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 4.5rem;
  height: 4.5rem;
  border-radius: 50%;
  background: rgba(var(--color-admin-tint-rgb), 0.1);
  color: var(--color-primary);
  transition: background 0.2s ease, transform 0.2s ease;
}
.ui-gallery-droparea:hover .ui-gallery-droparea-icon-wrap, .ui-gallery-droparea.is-dragover .ui-gallery-droparea-icon-wrap {
  background: rgba(var(--color-admin-tint-rgb), 0.16);
}
.ui-gallery-droparea .ui-gallery-droparea-icon {
  font-size: 2.25rem;
}
.ui-gallery-droparea .ui-gallery-droparea-title {
  margin: 0;
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--color-text);
  letter-spacing: 0.02em;
  line-height: 1.3;
}
.ui-gallery-droparea .ui-gallery-droparea-text {
  margin: 0;
  font-size: 0.9rem;
  color: var(--color-text-muted);
  line-height: 1.5;
}
.ui-gallery-droparea .ui-gallery-upload-btn {
  pointer-events: auto;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.65rem 1.35rem;
  font-size: 0.95rem;
  font-weight: 600;
  color: #fff;
  background: var(--color-primary);
  border: none;
  border-radius: 12px;
  box-shadow: 0 2px 8px rgba(var(--color-admin-tint-rgb), 0.25);
  transition: background 0.2s ease, transform 0.15s ease, box-shadow 0.2s ease;
}
.ui-gallery-droparea .ui-gallery-upload-btn:hover {
  background: var(--color-primary-hover);
  transform: translateY(-2px);
  box-shadow: 0 4px 14px rgba(var(--color-admin-tint-rgb), 0.3);
}
.ui-gallery-droparea .ui-gallery-upload-btn:active {
  transform: translateY(0);
  box-shadow: 0 1px 4px rgba(var(--color-admin-tint-rgb), 0.25);
}
.ui-gallery-droparea .ui-gallery-upload-btn .ui-icon {
  font-size: 1.1rem;
}

.ui-gallery-grid {
  margin-top: 0.5rem;
}

.ui-gallery-empty {
  grid-column: 1/-1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
  padding: 2rem 1.5rem;
  border: 1px dashed var(--color-border);
  border-radius: 12px;
  background: var(--color-surface-soft);
  color: var(--color-text-muted);
  text-align: center;
}

.ui-gallery-empty-icon {
  font-size: 2rem;
  opacity: 0.5;
  color: var(--color-primary);
}

.ui-gallery-empty-text {
  margin: 0;
  font-size: 0.875rem;
  max-width: 28rem;
  line-height: 1.5;
}

.ui-upload-queue {
  display: grid;
  gap: 0.45rem;
}

.ui-queue-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.6rem;
  border: 1px solid var(--color-border);
  border-radius: 10px;
  padding: 0.45rem 0.65rem;
  background: #fff;
  font-size: 0.84rem;
}

.ui-queue-item em {
  color: var(--color-text-muted);
  font-style: normal;
}

.ui-gallery-admin-item {
  border: 1px solid var(--color-border);
  border-radius: 12px;
  background: #fff;
  overflow: hidden;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.06);
  transition: box-shadow 0.2s ease, border-color 0.2s ease;
}
.ui-gallery-admin-item:hover {
  border-color: var(--color-primary);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
}

.ui-gallery-admin-item.is-dragging {
  opacity: 0.85;
  border-color: var(--color-primary);
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.12);
}

.ui-gallery-ghost-item {
  border-style: dashed;
  border-color: var(--color-border);
  opacity: 1;
}

.ui-gallery-ghost-item.is-error {
  border-color: rgba(225, 81, 81, 0.65);
}

.ui-gallery-ghost-thumb {
  position: relative;
}

.ui-gallery-ghost-placeholder {
  height: 180px;
  display: grid;
  place-items: center;
  color: var(--color-text-muted);
  font-weight: 600;
}

.ui-gallery-ghost-badge {
  position: absolute;
  left: 0.5rem;
  top: 0.5rem;
  background: var(--color-primary);
  color: #fff;
  font-size: 0.7rem;
  padding: 0.2rem 0.5rem;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
}

.ui-gallery-ghost-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.6rem;
  margin-bottom: 0.4rem;
  font-size: 0.84rem;
}

.ui-gallery-ghost-meta strong {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.ui-gallery-ghost-meta span {
  color: var(--color-text-muted);
}

.ui-gallery-upload-progress {
  width: 100%;
  height: 8px;
  background: rgba(var(--color-admin-tint-rgb), 0.2);
  border-radius: 999px;
  overflow: hidden;
}

.ui-gallery-upload-progress-bar {
  height: 100%;
  width: 0;
  min-width: 0;
  background: var(--color-primary);
  border-radius: 999px;
  transition: width 0.35s cubic-bezier(0.4, 0, 0.2, 1);
}

.ui-gallery-ghost-item .ui-gallery-upload-progress-text {
  font-weight: 600;
  color: var(--color-primary);
}

.ui-gallery-upload-progress-text {
  margin-top: 0.35rem;
  font-size: 0.76rem;
  color: var(--color-text-muted);
}

.ui-location-image-progress {
  max-width: 28rem;
}

.ui-gallery-admin-thumb {
  position: relative;
}

.ui-gallery-admin-thumb img {
  width: 100%;
  height: 180px;
  object-fit: cover;
  display: block;
  background: var(--color-surface-soft);
}

.ui-gallery-drag-handle {
  position: absolute;
  right: 0.5rem;
  top: 0.5rem;
  background: rgba(20, 16, 12, 0.72);
  color: #fff;
  font-size: 0.72rem;
  padding: 0.2rem 0.45rem;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  gap: 0.2rem;
}

.ui-gallery-main-badge {
  position: absolute;
  top: 0.5rem;
  left: 0.5rem;
  background: var(--color-primary);
  color: #fff;
  padding: 0.2rem 0.5rem;
  border-radius: 999px;
  font-size: 0.7rem;
  font-weight: 600;
}

.ui-gallery-admin-body {
  padding: 0.7rem 0.75rem;
  border-top: 1px solid var(--color-border);
}

.ui-gallery-admin-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
  margin-top: 0.5rem;
}

.ui-gallery-admin-actions .btn {
  border-radius: 8px;
  font-size: 0.82rem;
}

.ui-list-thumb-link {
  display: inline-block;
  line-height: 0;
  border-radius: 8px;
  transition: box-shadow 0.15s ease, transform 0.12s ease;
}
.ui-list-thumb-link:hover {
  box-shadow: 0 0 0 2px rgba(var(--color-admin-tint-rgb), 0.35);
}
.ui-list-thumb-link:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}

.ui-roomtype-title-link {
  color: inherit;
}
.ui-roomtype-title-link:hover {
  color: var(--color-primary);
  text-decoration: underline !important;
}
.ui-roomtype-title-link:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
  border-radius: 2px;
}

.ui-list-thumb {
  width: 64px;
  height: 48px;
  object-fit: cover;
  border-radius: 8px;
  border: 1px solid var(--color-border);
  background: var(--color-bg);
  display: block;
}

.ui-list-thumb-placeholder {
  width: 64px;
  height: 48px;
  border-radius: 8px;
  border: 1px dashed var(--color-border);
  background: var(--color-bg);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-text-muted);
  font-size: 1.25rem;
}

.ui-cell-thumb {
  width: 1%;
  white-space: nowrap;
  vertical-align: middle;
}

.ui-col-thumb {
  width: 1%;
}

.ui-badge-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.75rem;
  padding: 0.2rem 0.5rem;
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--color-primary);
  background: rgba(var(--color-admin-tint-rgb), 0.1);
  border-radius: 6px;
}

.ui-photo-count-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  padding: 0.3rem 0.65rem;
  border-radius: 999px;
  background: var(--color-surface);
  border: 1px solid rgba(var(--color-admin-tint-rgb), 0.22);
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.08);
  font-weight: 600;
  white-space: nowrap;
  color: var(--color-text);
}
.ui-photo-count-pill .ti {
  font-size: 1rem;
  color: var(--color-primary);
  opacity: 0.9;
}

.ui-photo-count-pill__num {
  font-size: 1rem;
  font-variant-numeric: tabular-nums;
  color: var(--color-primary);
}

.ui-photo-count-pill__txt {
  font-size: 0.72rem;
  font-weight: 600;
  text-transform: lowercase;
  color: var(--color-text-muted);
}

.ui-photo-count-pill--overlay {
  position: absolute;
  top: 0.5rem;
  left: 0.5rem;
  z-index: 2;
  pointer-events: none;
  backdrop-filter: blur(6px);
}

.ui-faq-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.25rem 0.5rem;
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--color-primary);
  background: rgba(46, 180, 100, 0.12);
  border: 1px solid rgba(46, 180, 100, 0.25);
  border-radius: 6px;
  text-decoration: none;
  transition: background 0.15s, border-color 0.15s;
}
.ui-faq-badge:hover {
  background: rgba(46, 180, 100, 0.2);
  border-color: rgba(46, 180, 100, 0.4);
  color: var(--color-primary);
}
.ui-faq-badge.is-empty {
  background: rgba(0, 0, 0, 0.05);
  border-color: var(--color-border);
  color: var(--color-text-muted);
}

.ui-mobile-card-preview {
  position: relative;
  margin-bottom: 0.75rem;
}
.ui-mobile-card-preview .ui-mobile-card-preview-link {
  display: block;
  line-height: 0;
  border-radius: 10px;
  overflow: hidden;
  transition: box-shadow 0.15s ease;
}
.ui-mobile-card-preview .ui-mobile-card-preview-link:hover {
  box-shadow: 0 0 0 2px rgba(var(--color-admin-tint-rgb), 0.35);
}
.ui-mobile-card-preview .ui-mobile-card-preview-link:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}
.ui-mobile-card-preview .ui-list-thumb {
  width: 100%;
  height: 140px;
  border-radius: 10px;
}
.ui-mobile-card-preview .ui-list-thumb-placeholder {
  width: 100%;
  height: 100px;
}
.ui-mobile-card-preview .ui-photo-count-pill--overlay {
  font-size: 0.75rem;
}
.ui-mobile-card-preview .ui-faq-badge {
  position: absolute;
  top: 0.5rem;
  right: 0.5rem;
  font-size: 0.75rem;
  z-index: 2;
}
.ui-mobile-card-preview .ui-rabat-badge-card {
  position: absolute;
  z-index: 3;
  bottom: 0.45rem;
  left: 0.45rem;
  right: auto;
  top: auto;
  margin-top: 0;
  max-width: calc(100% - 0.9rem);
  pointer-events: none;
}

.ui-admin-thumb-stack {
  position: relative;
  width: 64px;
  max-width: 100%;
}

.admin-attraction-list-thumb {
  width: 5.5rem;
  vertical-align: middle;
}

.admin-attraction-list-thumb__img {
  display: block;
  width: 80px;
  height: 60px;
  object-fit: cover;
  border-radius: 0.35rem;
  border: 1px solid var(--color-border, #e2e5eb);
  background: var(--color-surface, #fff);
}

.admin-attraction-list-thumb__placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 80px;
  height: 60px;
  border-radius: 0.35rem;
  border: 1px dashed var(--color-border, #e2e5eb);
  color: var(--color-text-muted, #5c5d68);
  font-size: 1.35rem;
  background: color-mix(in srgb, var(--color-border, #e2e5eb) 35%, transparent);
}

.ui-rabat-badge--thumb-overlay {
  position: absolute;
  z-index: 3;
  bottom: 0.2rem;
  left: 0.2rem;
  right: 0.2rem;
  margin-top: 0;
  font-size: 0.62rem;
  padding: 0.12rem 0.28rem;
  text-align: center;
  text-overflow: ellipsis;
  overflow: hidden;
  pointer-events: none;
}

.ui-admin-thumb-stack.has-gradient-ribbon .ui-rabat-badge--thumb-overlay {
  bottom: 1.35rem;
}

.ui-list-thumb-link--gradient-tile {
  overflow: hidden;
}

.ui-list-thumb-link--gradient-tile,
.ui-mobile-card-preview-link--gradient-tile {
  position: relative;
}
.ui-list-thumb-link--gradient-tile::after,
.ui-mobile-card-preview-link--gradient-tile::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
  background: linear-gradient(165deg, rgba(20, 24, 32, 0) 35%, rgba(20, 24, 32, 0.42) 100%);
  opacity: 0.9;
}

.ui-admin-tile-gradient-ribbon {
  position: absolute;
  z-index: 2;
  left: 0;
  right: 0;
  bottom: 0;
  padding: 0.2rem 0.35rem;
  font-size: 0.58rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  text-align: center;
  color: #fff;
  background: linear-gradient(90deg, rgba(var(--color-primary-rgb), 0.92), rgba(var(--color-accent-rgb, 111, 90, 73), 0.88));
  border-radius: 0 0 6px 6px;
  pointer-events: none;
  line-height: 1.2;
}

.ui-admin-thumb-stack .ui-admin-tile-gradient-ribbon {
  font-size: 0.5rem;
  padding: 0.12rem 0.2rem;
  border-radius: 0 0 6px 6px;
}

.ui-admin-tile-gradient-ribbon--card {
  border-radius: 0 0 10px 10px;
  font-size: 0.62rem;
  padding: 0.25rem 0.4rem;
}

.ui-mobile-card-preview.has-gradient-ribbon .ui-rabat-badge-card {
  bottom: 1.75rem;
}

.ui-rabat-badge.is-muted {
  background: rgba(var(--color-shadow-rgb), 0.55);
  color: #fff;
  border: 1px dashed rgba(255, 255, 255, 0.6);
}

.ui-rabat-badge {
  display: inline-block;
  margin-top: 0.25rem;
  padding: 0.2rem 0.45rem;
  font-size: 0.7rem;
  font-weight: 600;
  color: #fff;
  background: var(--color-primary);
  border-radius: 4px;
  white-space: nowrap;
}

.ui-hotres-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0.75rem;
}

.ui-hotres-stat-card {
  border: 1px solid var(--color-border);
  border-radius: 12px;
  background: #fff;
  padding: 0.7rem 0.8rem;
  display: grid;
  gap: 0.25rem;
}

.ui-hotres-stat-card span {
  font-size: 0.8rem;
  color: var(--color-text-muted);
}

.ui-hotres-stat-card strong {
  font-size: 1.1rem;
  color: var(--color-text);
}

.ui-hotres-stat-card.is-success {
  border-color: rgba(46, 180, 100, 0.35);
}

.ui-hotres-stat-card.is-danger {
  border-color: rgba(225, 81, 81, 0.35);
}

.ui-hotres-stat-card.is-muted {
  border-style: dashed;
}

.ui-secret-code {
  font-size: 0.78rem;
}

.ui-status-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
}

.ui-hotres-actions .btn {
  min-width: 112px;
}

.ui-hotres-table-wrap {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  width: 100%;
}

.ui-hotres-accounts-table {
  width: 100%;
  min-width: 0;
  table-layout: fixed;
}

.ui-hotres-accounts-table .ui-hotres-col-name {
  width: 13%;
}

.ui-hotres-accounts-table .ui-hotres-col-active {
  width: 10%;
  vertical-align: middle;
}

.ui-hotres-accounts-table .ui-hotres-col-sync {
  width: 7%;
}

.ui-hotres-accounts-table .ui-hotres-col-time {
  width: 11%;
}

.ui-hotres-accounts-table .ui-hotres-col-msg {
  width: 21%;
  word-break: break-word;
  line-height: 1.35;
}

.ui-hotres-accounts-table .ui-hotres-col-webhook {
  width: 26%;
  min-width: 0;
}

.ui-hotres-accounts-table .ui-hotres-col-actions {
  width: 12%;
  vertical-align: middle;
}

.ui-hotres-active-form {
  margin: 0;
  width: 100%;
}

.ui-hotres-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.35rem;
  width: 100%;
  max-width: 100%;
  padding: 0.4rem 0.55rem;
  font-size: 0.78rem;
  font-weight: 600;
  line-height: 1.2;
  border-radius: 8px;
  white-space: nowrap;
  border-width: 1px;
}

.ui-hotres-toggle .ti {
  font-size: 1rem;
  flex-shrink: 0;
}

.ui-hotres-toggle--on {
  color: #0f5132;
  background: rgba(25, 135, 84, 0.12);
  border-color: rgba(25, 135, 84, 0.45);
}

.ui-hotres-toggle--on:hover {
  color: #0a3622;
  background: rgba(25, 135, 84, 0.2);
  border-color: rgba(25, 135, 84, 0.65);
}

.ui-hotres-toggle--off {
  color: var(--color-text-muted);
  background: var(--color-bg-muted, #f1f5f9);
  border-color: var(--color-border);
}

.ui-hotres-toggle--off:hover {
  color: var(--color-text);
  background: #e9eef5;
  border-color: color-mix(in srgb, var(--color-border) 70%, var(--color-text-muted));
}

.ui-hotres-actions-compact {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: 0.25rem;
}

.ui-hotres-actions-compact .btn {
  min-width: 0;
  line-height: 1.2;
}

.ui-mobile-list-actions.ui-hotres-actions-compact {
  margin-top: 0.65rem;
}

.ui-hotres-webhook-input {
  width: 100%;
  min-width: 0;
}

.ui-hotres-webhook-input .form-control {
  font-size: 0.72rem;
  min-width: 0;
  flex: 1 1 auto;
}

.ui-hotres-webhook-hint {
  font-size: 0.7rem;
}

.ui-hotres-webhook-input .btn {
  flex-shrink: 0;
}

.ui-hotres-actions-stack .btn {
  min-width: 0;
}

.ui-hotres-completed-table {
  width: 100%;
  min-width: 72rem;
  font-size: 0.8125rem;
  border-collapse: separate;
  border-spacing: 0;
}

.ui-hotres-completed-table thead th {
  position: sticky;
  top: 0;
  z-index: 2;
  background: var(--tblr-bg-surface, #fff);
  box-shadow: 0 1px 0 var(--tblr-border-color, rgba(4, 32, 69, 0.1));
  font-weight: 600;
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.02em;
  color: var(--tblr-secondary, #667382);
  white-space: nowrap;
}

.ui-hotres-completed-table tbody td {
  vertical-align: middle;
}

.ui-hotres-source-icon {
  display: block;
  width: 28px;
  height: 28px;
  border-radius: 6px;
  object-fit: contain;
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.12);
}

.ui-hotres-preview-tabs {
  border-bottom: 1px solid var(--tblr-border-color, #e6e8eb);
}

.ui-hotres-preview-tabs .nav-link {
  white-space: nowrap;
  font-size: 0.875rem;
}

.ui-html-preview--bounded {
  max-height: 22rem;
  overflow: auto;
  padding: 0.75rem;
  border: 1px solid var(--tblr-border-color, #e6e8eb);
  border-radius: 8px;
  background: var(--tblr-bg-surface-secondary, #f8fafc);
}

.ui-json--tall {
  max-height: min(80vh, 48rem);
  overflow: auto;
}

.ui-json-pre {
  /* Jawny kontrast — bez var(--color-*) z motywu, które mogły dawać kolor tekstu ≈ tłu */
  background: #0f172a;
  color: #e2e8f0;
  border-top: 1px solid rgba(15, 23, 42, 0.35);
  max-height: 70vh;
  overflow: auto;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  font-size: 0.8125rem;
  line-height: 1.55;
  white-space: pre-wrap;
  word-break: break-word;
}

.ui-roomtypes-filter-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0.75rem;
  align-items: end;
}

.ui-roomtypes-filter-grid.is-loading {
  opacity: 0.68;
  pointer-events: none;
}

.ui-relative {
  position: relative;
}

/* Pełnoekranowa blokada podczas akcji masowych (lista obiektów) */
.roomtypes-mass-ops-lock {
  position: fixed;
  inset: 0;
  z-index: 20050;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1.25rem;
  box-sizing: border-box;
}

.roomtypes-mass-ops-lock__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(15, 23, 42, 0.48);
  backdrop-filter: blur(6px);
}

.roomtypes-mass-ops-lock__panel {
  position: relative;
  z-index: 1;
  width: min(32rem, 100%);
  max-height: min(90vh, 40rem);
  overflow: auto;
  padding: 1.35rem 1.4rem 1.15rem;
  border-radius: 0.75rem;
  border: 1px solid var(--color-border);
  background: var(--color-surface);
  box-shadow: 0 24px 64px rgba(0, 0, 0, 0.2);
  pointer-events: auto;
}

.roomtypes-mass-ops-lock__main-title {
  margin: 0 0 0.85rem;
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--color-text);
  line-height: 1.25;
}

.roomtypes-mass-ops-lock__hint {
  margin: 0.9rem 0 0;
  font-size: 0.78rem;
  line-height: 1.45;
  color: var(--color-text-muted);
}

body.roomtypes-mass-op-active {
  overflow: hidden !important;
}

.roomtypes-sync-panel.roomtypes-sync-panel--in-lock {
  margin: 0;
  padding: 1rem 1.05rem 1.05rem;
}

.roomtypes-sync-panel__track.roomtypes-sync-panel__track--indeterminate .roomtypes-sync-panel__bar {
  width: 44% !important;
  animation: roomtypes-mass-op-pulse 1s ease-in-out infinite;
}

@keyframes roomtypes-mass-op-pulse {
  0%, 100% {
    opacity: 0.55;
  }
  50% {
    opacity: 1;
  }
}
.ui-ajax-overlay {
  position: absolute;
  inset: 0;
  z-index: 10;
  display: none;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
  background: rgba(255, 255, 255, 0.85);
  border-radius: inherit;
}

.ui-ajax-overlay.is-visible {
  display: flex;
}

.ui-ajax-spinner {
  width: 40px;
  height: 40px;
  border: 3px solid var(--color-border);
  border-top-color: var(--color-primary);
  border-radius: 50%;
  animation: ui-spin 0.8s linear infinite;
}

@keyframes ui-spin {
  to {
    transform: rotate(360deg);
  }
}
.ui-ajax-text {
  font-size: 0.9rem;
  color: var(--color-text-muted);
}

.ui-error-box {
  margin: 0;
  border-radius: 0;
  border-left: none;
  border-right: none;
}
.ui-error-box pre {
  white-space: pre-wrap;
  word-break: break-word;
  max-height: 12rem;
  overflow-y: auto;
}

/* Synchronizacja galerii HOTRES — panel nad listą obiektów */
.roomtypes-sync-panel {
  margin: 0 1rem 0.85rem;
  padding: 1rem 1.1rem 1.05rem;
  border-radius: 0.65rem;
  border: 1px solid color-mix(in srgb, var(--color-primary) 22%, var(--color-border));
  background: linear-gradient(145deg, color-mix(in srgb, var(--color-primary) 7%, var(--color-surface)) 0%, var(--color-surface-soft) 100%);
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.06);
}

@media (max-width: 575.98px) {
  .roomtypes-sync-panel {
    margin-inline: 0.65rem;
  }
}
/* Pełna szerokość między kartami — nad overlay listy */
.roomtypes-sync-panel.roomtypes-sync-panel--floating {
  margin: 0 0 1rem;
  position: relative;
  z-index: 20;
}

@media (max-width: 575.98px) {
  .roomtypes-sync-panel.roomtypes-sync-panel--floating {
    margin-inline: 0;
  }
}
.roomtypes-sync-panel__top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 0.65rem;
}

.roomtypes-sync-panel__brand {
  display: flex;
  gap: 0.65rem;
  min-width: 0;
}

.roomtypes-sync-panel__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 0.55rem;
  background: color-mix(in srgb, var(--color-primary) 14%, transparent);
  color: var(--color-primary);
  font-size: 1.35rem;
  flex-shrink: 0;
}

.roomtypes-sync-panel__titles {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
  min-width: 0;
}

.roomtypes-sync-panel__title {
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--color-text-muted);
}

.roomtypes-sync-panel__phase {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--color-text);
  line-height: 1.28;
  word-break: break-word;
}

.roomtypes-sync-panel__pct {
  font-size: 1.3rem;
  font-weight: 800;
  font-variant-numeric: tabular-nums;
  color: var(--color-primary);
  flex-shrink: 0;
  line-height: 1;
}

.roomtypes-sync-panel__track {
  height: 0.55rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--color-text) 9%, var(--color-surface));
  overflow: hidden;
  margin-bottom: 0.55rem;
}

.roomtypes-sync-panel--running .roomtypes-sync-panel__bar {
  min-width: 3%;
}

.roomtypes-sync-panel__bar {
  height: 100%;
  width: 0%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--color-primary), color-mix(in srgb, var(--color-primary) 72%, #fff 28%));
  transition: width 0.38s ease;
  position: relative;
  overflow: hidden;
}

.roomtypes-sync-panel--running .roomtypes-sync-panel__bar::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.3), transparent);
  animation: roomtypes-sync-shimmer 1.35s ease-in-out infinite;
}

@keyframes roomtypes-sync-shimmer {
  0% {
    transform: translateX(-100%);
  }
  100% {
    transform: translateX(100%);
  }
}
.roomtypes-sync-panel__detail {
  font-size: 0.84rem;
  color: var(--color-text);
  line-height: 1.45;
}

.roomtypes-sync-panel__meta {
  font-size: 0.75rem;
  color: var(--color-text-muted);
  margin-top: 0.35rem !important;
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.01em;
}

.ui-admin-drawer {
  width: min(760px, 96vw) !important;
  background: var(--color-surface);
  border-left: 1px solid var(--color-border);
}

.ui-admin-drawer .offcanvas-header {
  border-bottom: 1px solid var(--color-border);
  background: rgba(var(--color-dashboard-accent-rgb), 0.05);
}

.ui-admin-drawer .offcanvas-body {
  padding: 1rem;
}

.ui-single-image-field {
  border: 1px dashed var(--color-border);
  border-radius: 12px;
  padding: 0.75rem;
  background: #fff;
}

.ui-single-image-preview-wrap {
  border: 1px solid var(--color-border);
  border-radius: 10px;
  overflow: hidden;
  background: #faf6f2;
  min-height: 180px;
  display: grid;
  place-items: center;
}

.ui-single-image-preview {
  width: 100%;
  max-height: 280px;
  object-fit: cover;
  display: block;
}

.ui-single-image-empty {
  color: var(--color-text-muted);
  font-size: 0.9rem;
}

.ui-pictogram-icon-preview {
  width: 20px;
  height: 20px;
  object-fit: contain;
  vertical-align: middle;
  margin-right: 0.4rem;
}

.ui-pictogram-icon-preview-lg {
  width: 28px;
  height: 28px;
  margin-right: 0;
}

.ui-pictogram-list-th {
  min-width: 200px;
}

.ui-pictogram-list-cell {
  vertical-align: middle;
}

.ui-pictogram-list-row {
  display: flex;
  align-items: center;
  gap: 0.85rem;
  flex-wrap: wrap;
}

.ui-pictogram-list-thumb {
  flex-shrink: 0;
  width: 64px;
  height: 64px;
  border-radius: 12px;
  border: 1px solid var(--color-border);
  background: linear-gradient(145deg, #fff 0%, var(--color-surface-soft, #fafaf9) 100%);
  display: grid;
  place-items: center;
  padding: 6px;
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.05);
}

.ui-pictogram-list-thumb-img {
  width: 52px;
  height: 52px;
  object-fit: contain;
  display: block;
  margin: 0;
}

.ui-pictogram-list-thumb--font {
  border-color: rgba(var(--color-accent-rgb), 0.32);
  background: linear-gradient(145deg, rgba(var(--color-accent-rgb), 0.07) 0%, #fff 100%);
}
.ui-pictogram-list-thumb--font i {
  font-size: 2rem;
  line-height: 1;
  color: var(--color-primary);
}

.ui-pictogram-list-meta {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.35rem;
  min-width: 0;
}

.ui-pictogram-type-badge {
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  padding: 0.35rem 0.55rem;
  border-radius: 8px;
}

.ui-pictogram-type-badge--svg {
  color: #0f766e;
  background: rgba(13, 148, 136, 0.14);
  border: 1px solid rgba(13, 148, 136, 0.35);
}

.ui-pictogram-type-badge--font {
  color: #5b21b6;
  background: rgba(124, 58, 237, 0.1);
  border: 1px solid rgba(124, 58, 237, 0.28);
}

.ui-pictogram-file-link {
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--color-primary);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
}

.ui-pictogram-file-link:hover {
  color: var(--color-primary-hover);
  text-decoration: underline;
  text-underline-offset: 0.12em;
}

.ui-pictogram-font-class {
  font-size: 0.75rem;
  color: var(--color-text-muted);
  font-family: ui-monospace, monospace;
  word-break: break-all;
  max-width: 220px;
}

.page .ui-pictogram-type-badge {
  font-size: 0.68rem;
}

.page .ui-pictogram-font-class {
  font-size: 0.75rem;
}

.page .ui-pictogram-file-link {
  font-size: 0.8125rem;
}

.ui-pictogram-picker {
  display: grid;
  gap: 1rem;
}

.ui-pictogram-group {
  border: 1px solid var(--color-border);
  border-radius: 12px;
  padding: 0.85rem 1rem;
  background: var(--color-surface-soft, #fcfaf7);
}

.ui-pictogram-group-title {
  margin: 0 0 0.65rem;
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--color-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.ui-pictogram-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: 0.5rem;
}

.ui-pictogram-tile {
  margin: 0;
  cursor: pointer;
  position: relative;
}
.ui-pictogram-tile:hover .ui-pictogram-box {
  border-color: var(--color-primary);
  background: rgba(var(--color-accent-rgb), 0.06);
}

.ui-pictogram-checkbox {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.ui-pictogram-box {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  border: 2px solid var(--color-border);
  border-radius: 10px;
  background: #fff;
  padding: 0.55rem 0.75rem;
  min-height: 48px;
  transition: border-color 0.2s ease, box-shadow 0.2s ease, background-color 0.2s ease;
  position: relative;
}

.ui-pictogram-box .ui-pictogram-icon-preview,
.ui-pictogram-box .ui-pictogram-icon-preview-lg,
.ui-pictogram-box i,
.ui-pictogram-box img {
  width: 24px;
  height: 24px;
  flex-shrink: 0;
  object-fit: contain;
}

.ui-pictogram-box i {
  font-size: 1.25rem;
  color: var(--color-primary);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.ui-pictogram-box span {
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--color-text);
  line-height: 1.3;
  flex: 1;
  min-width: 0;
}

.ui-pictogram-checkbox:checked + .ui-pictogram-box {
  border-color: var(--color-primary);
  background: rgba(var(--color-accent-rgb), 0.11);
  box-shadow: 0 0 0 3px rgba(var(--color-accent-rgb), 0.22);
}

.ui-pictogram-checkbox:checked + .ui-pictogram-box::after {
  content: "";
  position: absolute;
  top: 0.5rem;
  right: 0.5rem;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: var(--color-primary);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'%3E%3C/polyline%3E%3C/svg%3E");
  background-size: 10px 10px;
  background-repeat: no-repeat;
  background-position: center;
  flex-shrink: 0;
}

.ui-pictogram-checkbox:checked + .ui-pictogram-box i,
.ui-pictogram-checkbox:checked + .ui-pictogram-box .ui-pictogram-icon-preview,
.ui-pictogram-checkbox:checked + .ui-pictogram-box .ui-pictogram-icon-preview-lg {
  color: var(--color-primary);
  opacity: 1;
}

.ui-pictogram-picker--square-tiles .ui-pictogram-grid {
  grid-template-columns: repeat(auto-fill, minmax(108px, 1fr));
  gap: 0.65rem;
}
.ui-pictogram-picker--square-tiles .ui-pictogram-tile {
  display: block;
}
.ui-pictogram-picker--square-tiles .ui-pictogram-box {
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  aspect-ratio: 1;
  min-height: 0;
  width: 100%;
  padding: 0.7rem 0.45rem;
  gap: 0.4rem;
  border-radius: 14px;
  box-shadow: 0 1px 0 rgba(0, 0, 0, 0.04);
}
.ui-pictogram-picker--square-tiles .ui-pictogram-box .ui-pictogram-icon-preview,
.ui-pictogram-picker--square-tiles .ui-pictogram-box .ui-pictogram-icon-preview-lg,
.ui-pictogram-picker--square-tiles .ui-pictogram-box img {
  width: 36px;
  height: 36px;
}
.ui-pictogram-picker--square-tiles .ui-pictogram-box i {
  width: 36px;
  height: 36px;
  font-size: 1.65rem;
}
.ui-pictogram-picker--square-tiles .ui-pictogram-box span {
  font-size: 0.6875rem;
  font-weight: 600;
  line-height: 1.25;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-align: center;
  word-break: break-word;
  hyphens: auto;
}
.ui-pictogram-picker--square-tiles .ui-pictogram-checkbox:checked + .ui-pictogram-box::after {
  top: 0.4rem;
  right: 0.4rem;
}

.ui-pictogram-picker--square-tiles.ui-pictogram-picker--residence-lg .ui-pictogram-grid {
  grid-template-columns: repeat(auto-fill, minmax(148px, 1fr));
  gap: 0.85rem;
}
.ui-pictogram-picker--square-tiles.ui-pictogram-picker--residence-lg .ui-pictogram-group {
  padding: 1rem 1.15rem;
}
.ui-pictogram-picker--square-tiles.ui-pictogram-picker--residence-lg .ui-pictogram-group-title {
  font-size: 0.85rem;
  margin-bottom: 0.75rem;
}
.ui-pictogram-picker--square-tiles.ui-pictogram-picker--residence-lg .ui-pictogram-box {
  padding: 0.95rem 0.55rem;
  gap: 0.55rem;
  border-radius: 16px;
}
.ui-pictogram-picker--square-tiles.ui-pictogram-picker--residence-lg .ui-pictogram-box .ui-pictogram-icon-preview,
.ui-pictogram-picker--square-tiles.ui-pictogram-picker--residence-lg .ui-pictogram-box .ui-pictogram-icon-preview-lg,
.ui-pictogram-picker--square-tiles.ui-pictogram-picker--residence-lg .ui-pictogram-box img {
  width: 52px;
  height: 52px;
}
.ui-pictogram-picker--square-tiles.ui-pictogram-picker--residence-lg .ui-pictogram-box i {
  width: 52px;
  height: 52px;
  font-size: 2.15rem;
}
.ui-pictogram-picker--square-tiles.ui-pictogram-picker--residence-lg .ui-pictogram-box span {
  font-size: 0.8125rem;
  font-weight: 600;
  line-height: 1.35;
  -webkit-line-clamp: 4;
}
.ui-pictogram-picker--square-tiles.ui-pictogram-picker--residence-lg .ui-pictogram-checkbox:checked + .ui-pictogram-box::after {
  top: 0.5rem;
  right: 0.5rem;
  width: 16px;
  height: 16px;
  background-size: 11px 11px;
}

.ui-quill-wrap {
  border: 1px solid var(--color-border);
  border-radius: 12px;
  overflow: hidden;
  background: #fff;
}

.ui-quill-wrap .ql-toolbar.ql-snow {
  border: 0;
  border-bottom: 1px solid var(--color-border);
  background: rgba(var(--color-dashboard-accent-rgb), 0.04);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.2rem 0.35rem;
  padding: 0.45rem 0.55rem;
  max-width: 100%;
}

.ui-quill-wrap .ql-toolbar .ql-formats {
  display: inline-flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.1rem;
  margin-right: 0.35rem;
}

.ui-quill-wrap .ql-toolbar button.ql-insertHtml {
  width: fit-content;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  padding: 0.15rem 0.45rem;
  color: var(--color-primary, #2563eb);
}

.ui-quill-wrap .ql-toolbar .ql-picker.ql-expanded {
  z-index: 5;
}

.ui-quill-wrap .ql-container.ql-snow {
  border: 0;
  min-height: 170px;
  font-size: 0.95rem;
}

.ui-quill-wrap .ql-editor {
  min-height: 160px;
  color: var(--color-text);
}
.ui-quill-wrap .ql-editor img,
.ui-quill-wrap .ql-editor video {
  max-width: 100%;
  height: auto;
}

.ui-quill-wrap .ql-editor.ql-blank::before {
  color: var(--color-text-muted);
  font-style: normal;
}

.ui-osm-map {
  width: 100%;
  height: 340px;
  border: 1px solid var(--color-border);
  border-radius: 12px;
  overflow: hidden;
  background: #e8eaef;
}

.ui-pages-search-results {
  display: grid;
  gap: 0.45rem;
  max-height: 260px;
  overflow: auto;
  border: 1px solid var(--color-border);
  border-radius: 12px;
  background: #fff;
  padding: 0.55rem;
}

.ui-page-search-item {
  margin: 0;
  display: flex;
  align-items: center;
  gap: 0.55rem;
  border: 1px solid var(--color-border);
  border-radius: 10px;
  padding: 0.45rem 0.6rem;
  background: var(--color-surface);
  cursor: pointer;
}

.ui-page-search-item span {
  display: grid;
  gap: 0.08rem;
}

.ui-page-search-item strong {
  font-size: 0.88rem;
  color: var(--color-text);
}

.ui-page-search-item small {
  color: var(--color-text-muted);
}

.ui-pages-selected {
  display: grid;
  gap: 0.45rem;
}

.ui-page-chip {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.65rem;
  border: 1px solid var(--color-border);
  border-radius: 10px;
  padding: 0.45rem 0.6rem;
  background: #fff;
}

.ui-page-chip span {
  display: grid;
  gap: 0.08rem;
}

.ui-page-chip small {
  color: var(--color-text-muted);
}

@media (max-width: 991px) {
  .admin-sidebar {
    box-shadow: none;
  }
  .admin-topbar {
    position: sticky;
    top: 0;
    z-index: 20;
  }
  .ui-filter-grid {
    grid-template-columns: 1fr;
  }
  .ui-filter-actions {
    justify-content: flex-start;
  }
  .ui-page {
    padding-top: 0.85rem;
    padding-bottom: 1.5rem;
  }
  .btn-list {
    gap: 0.4rem;
  }
  .ui-hotres-stats {
    grid-template-columns: 1fr 1fr;
  }
  .ui-roomtypes-filter-grid {
    grid-template-columns: 1fr;
  }
}
.ui-toast-container {
  position: fixed;
  top: 1rem;
  right: 1rem;
  z-index: 1090;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  max-width: min(34rem, 94vw);
  pointer-events: none;
}

.ui-toast {
  pointer-events: auto;
  display: flex;
  align-items: flex-start;
  gap: 0.6rem;
  padding: 0.75rem 1rem;
  border-radius: 12px;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  box-shadow: 0 10px 40px rgba(47, 41, 36, 0.15);
  opacity: 0;
  transform: translateX(100%);
  transition: opacity 0.28s ease, transform 0.28s ease;
}
.ui-toast.ui-toast--visible {
  opacity: 1;
  transform: translateX(0);
}
.ui-toast .ui-toast-icon {
  flex-shrink: 0;
  width: 1.5rem;
  height: 1.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.25rem;
}
.ui-toast .ui-toast-message {
  flex: 1;
  font-size: 0.9rem;
  line-height: 1.4;
  color: var(--color-text);
}
.ui-toast .ui-toast-message .ui-toast-link {
  color: var(--color-primary, #206bc4);
  font-weight: 650;
  word-break: break-all;
}
.ui-toast .ui-toast-close {
  flex-shrink: 0;
  padding: 0.2rem;
  border: none;
  background: transparent;
  color: var(--color-text-muted);
  cursor: pointer;
  border-radius: 6px;
  line-height: 1;
}
.ui-toast .ui-toast-close:hover {
  color: var(--color-text);
  background: rgba(var(--color-admin-tint-rgb), 0.08);
}
.ui-toast.ui-toast--success {
  border-color: rgba(34, 139, 34, 0.4);
}
.ui-toast.ui-toast--success .ui-toast-icon {
  color: #228b22;
}
.ui-toast.ui-toast--danger {
  border-color: rgba(185, 28, 28, 0.4);
}
.ui-toast.ui-toast--danger .ui-toast-icon {
  color: #b91c1c;
}
.ui-toast.ui-toast--warning {
  border-color: rgba(180, 83, 9, 0.4);
}
.ui-toast.ui-toast--warning .ui-toast-icon {
  color: #b45309;
}
.ui-toast.ui-toast--info {
  border-color: rgba(37, 99, 235, 0.4);
}
.ui-toast.ui-toast--info .ui-toast-icon {
  color: #2563eb;
}

.ui-theme-colors--panel {
  padding: 1.35rem 1.2rem 1.55rem;
  border-radius: 16px;
  border: 1px solid var(--color-border);
  background: linear-gradient(165deg, rgba(var(--color-admin-tint-rgb), 0.04), var(--color-surface));
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.65) inset;
}

.ui-theme-colors__hint {
  max-width: 72ch;
  line-height: 1.55;
}

.ui-theme-colors .ui-theme-grid {
  grid-template-columns: repeat(auto-fill, minmax(min(100%, 300px), 1fr));
  gap: 0.85rem;
}

.ui-theme-colors .ui-theme-grid--stacked {
  grid-template-columns: minmax(0, 1fr);
}

.ui-theme-field {
  padding: 0.8rem 0.9rem;
  border-radius: 12px;
  border: 1px solid var(--color-border);
  background: #fff;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
.ui-theme-field:focus-within {
  border-color: color-mix(in srgb, var(--color-primary) 42%, var(--color-border));
  box-shadow: 0 0 0 2px rgba(var(--color-admin-tint-rgb), 0.12);
}

.ui-theme-row {
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
}

.ui-theme-row .ui-label {
  margin-bottom: 0;
  font-size: 0.82rem;
  color: var(--color-text);
}

.ui-theme-inputs {
  display: flex;
  align-items: center;
  gap: 0.55rem;
}

.ui-theme-color-picker {
  width: 2.875rem;
  height: 2.625rem;
  padding: 2px;
  border: 1px solid var(--color-border);
  border-radius: 10px;
  background: #fff;
  cursor: pointer;
  flex-shrink: 0;
  transition: transform 0.15s ease, border-color 0.2s ease;
}
.ui-theme-color-picker:hover {
  transform: scale(1.04);
  border-color: color-mix(in srgb, var(--color-primary) 35%, var(--color-border));
}

.ui-theme-inputs .form-control.ui-input {
  flex: 1;
  min-width: 0;
  font-variant-numeric: tabular-nums;
}

.ui-form-grid .ts-wrapper {
  width: 100%;
  max-width: 100%;
}

.ui-form-grid .ts-wrapper .ts-control {
  min-height: 2.5rem;
  border-radius: 10px;
  border-color: var(--color-border);
}

.ui-form-grid .ts-wrapper.focus .ts-control {
  border-color: var(--color-primary);
  box-shadow: 0 0 0 0.2rem rgba(var(--color-admin-tint-rgb), 0.14);
}

.ui-form-grid .ts-dropdown {
  border-radius: 10px;
}

.seo-page-drawer.offcanvas-end {
  width: min(520px, 100vw);
}

#seo-page-drawer.offcanvas:not(.show) {
  pointer-events: none;
}

#seo-page-drawer.offcanvas.show {
  pointer-events: auto;
}

.seo-row-address {
  max-width: 14rem;
}

.seo-row-address-label {
  min-width: 0;
  font-size: 0.8125rem;
  color: var(--color-text-muted);
}

.seo-row-external {
  flex-shrink: 0;
}

.seo-page-drawer__form {
  flex: 1 1 auto;
  min-height: 0;
  display: flex;
  flex-direction: column;
}

.seo-page-drawer__body {
  flex: 1 1 auto;
  min-height: 0;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}

.seo-page-drawer__footer {
  flex-shrink: 0;
}

.seo-drawer-section__title {
  letter-spacing: 0.04em;
}

.min-h-40 {
  min-height: 2.5rem;
}

.seo-slide-thumb {
  width: 40px;
  height: 32px;
  object-fit: cover;
}

#seo-pages-rows.seo-pages-rows--loading {
  opacity: 0.55;
  transition: opacity 0.15s ease;
}

#residences-rows.residences-rows--loading {
  opacity: 0.55;
  transition: opacity 0.15s ease;
}

.slide-crop-host {
  width: 100%;
  min-height: 280px;
  max-height: min(78vh, 800px);
  overflow: auto;
  -webkit-overflow-scrolling: touch;
}
.slide-crop-host .slide-crop-img {
  display: block;
  max-width: 100%;
  height: auto;
}
.slide-crop-host .cropper-container,
.slide-crop-host .cropper-wrap-box {
  max-width: 100%;
}

#slide-crop-modal .modal-dialog {
  max-width: min(96vw, 1180px);
}

.ui-site-theme-front-preview {
  margin-top: 1.25rem;
  border-radius: 14px;
  border: 1px solid var(--color-border);
  background: var(--color-surface);
  overflow: hidden;
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.65) inset;
}

.ui-site-theme-front-preview__bar {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.35rem 1rem;
  padding: 0.65rem 1rem;
  font-size: 0.78rem;
  border-bottom: 1px solid var(--color-border);
  background: linear-gradient(165deg, rgb(var(--color-admin-tint-rgb), 0.05), var(--color-surface));
}

.ui-site-theme-front-preview__bar-title {
  font-weight: 700;
  color: var(--color-text);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.ui-site-theme-front-preview__bar-hint {
  color: var(--color-text-muted);
  font-weight: 500;
  max-width: 42ch;
  line-height: 1.35;
}

.ui-site-theme-front-preview__canvas {
  padding: 1.1rem 1rem 1.25rem;
  background: var(--color-bg, #f8fafc);
}

.ui-site-theme-front-preview__card {
  max-width: 22rem;
  padding: 1rem 1.05rem 1.05rem;
  background: var(--color-surface, #fff);
  border: 1px solid var(--color-border, #e7e5e4);
  border-radius: var(--layout-radius, 8px);
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.05);
}

.ui-site-theme-front-preview__lead {
  margin: 0 0 0.35rem;
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--color-text, #1c1917);
  letter-spacing: -0.02em;
}

.ui-site-theme-front-preview__muted {
  margin: 0 0 0.85rem;
  font-size: 0.82rem;
  line-height: 1.45;
  color: var(--color-text-muted, #57534e);
}

.ui-site-theme-front-preview__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.ui-site-theme-front-preview__btn-primary,
.ui-site-theme-front-preview__btn-ghost {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.4rem;
  padding: 0.55rem 1rem;
  font-size: 0.82rem;
  font-weight: 700;
  border-radius: var(--layout-radius, 8px);
  letter-spacing: 0.03em;
}

.ui-site-theme-front-preview__btn-primary {
  color: var(--color-on-primary, #fafaf9);
  background: var(--color-primary, #4b310d);
  border: 0;
}

.ui-site-theme-front-preview__btn-ghost {
  color: var(--color-primary, #4b310d);
  background: var(--color-surface-soft, #f5f5f4);
  border: 1px solid var(--color-border, #e7e5e4);
}

/* Room type edit — FAQ (single-save payload, clearer cards) */
.roomtype-faq-list {
  max-width: 56rem;
}

.roomtype-faq-item {
  border: 1px solid var(--color-border, #e2e8f0);
  border-radius: var(--layout-radius, 10px);
  background: var(--color-surface, #fff);
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
}

.roomtype-faq-item__inner {
  display: flex;
  gap: 0.75rem;
  align-items: flex-start;
}

.roomtype-faq-item__fields {
  flex: 1;
  min-width: 0;
}

.roomtype-faq-item__actions {
  flex-shrink: 0;
  padding-top: 1.5rem;
}

.roomtype-faq-handles.vertical {
  flex-direction: column;
  padding-top: 1.5rem;
}

.roomtype-faq-handles.vertical .btn {
  min-width: 2.25rem;
}

/* Raporty zrealizowanych rezerwacji — wielokrotny wybór apartamentów (lista pozostaje otwarta) */
.hotres-lodging-report-suggest-rows {
  max-height: min(55vh, 28rem);
  overflow: auto;
}

.hotres-lodging-report-suggest .hotres-lodging-report-suggest-row {
  cursor: pointer;
  border-bottom: 1px solid var(--tblr-border-color, #e6e7e9);
}
.hotres-lodging-report-suggest .hotres-lodging-report-suggest-row:last-child {
  border-bottom: none;
}
.hotres-lodging-report-suggest .hotres-lodging-report-suggest-row--in-selection {
  background: rgba(25, 135, 84, 0.08);
}

/* Raporty HOTRES — filtry + wynik (bez sticky/backdrop — płynniejszy rendering) */
body.admin-app .hotres-lodging-report-filters .card-body {
  padding: 1.15rem 1.25rem;
}

body.admin-app .hotres-lodging-report-picker {
  background: color-mix(in srgb, var(--admin-accent, #206bc4) 4%, var(--color-body-bg, #f8fafc));
  border-color: rgba(15, 23, 42, 0.08) !important;
}

body.admin-app .hotres-lodging-report-suggest {
  border-color: rgba(15, 23, 42, 0.1) !important;
}

/* Wynik raportu — pełna szerokość tabeli, lekki nagłówek grupy */
body.admin-app .hotres-lodging-report-result__header {
  border-bottom: 1px solid rgba(15, 23, 42, 0.08);
}

body.admin-app .hotres-lodging-report-result__body {
  background: #fff;
}

body.admin-app .hotres-lodging-report-group__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  flex-wrap: wrap;
  padding: 0.6rem 1rem;
  background: #f1f5f9;
  border-left: 3px solid var(--admin-accent, #206bc4);
}

body.admin-app .hotres-lodging-report-group__name {
  font-weight: 650;
  font-size: 0.9375rem;
  color: var(--color-heading, #1e293b);
  min-width: 0;
}

body.admin-app .hotres-lodging-report-group__count {
  font-weight: 650;
  font-variant-numeric: tabular-nums;
}

body.admin-app .hotres-lodging-report-table {
  font-size: 0.875rem;
}

body.admin-app .hotres-lodging-report-table thead th {
  padding: 0.5rem 0.75rem;
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  font-weight: 650;
  color: var(--color-secondary, #64748b);
  background: #f8fafc;
  border-bottom: 1px solid rgba(15, 23, 42, 0.08);
  white-space: nowrap;
}

body.admin-app .hotres-lodging-report-table tbody td {
  padding: 0.45rem 0.75rem;
  vertical-align: middle;
}

body.admin-app .hotres-lodging-report-table__num a:hover {
  text-decoration: underline !important;
}

body.admin-app .hotres-lodging-report-table__numcol {
  font-variant-numeric: tabular-nums;
}

body.admin-app .hotres-lodging-report-summary__tile {
  border-radius: var(--admin-shell-radius, 0.75rem);
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: rgba(255, 255, 255, 0.92);
  padding: 0.75rem 1rem;
  height: 100%;
}

body.admin-app .hotres-lodging-report-summary__tile--accent {
  border-color: color-mix(in srgb, var(--admin-accent, #206bc4) 28%, transparent);
  background: color-mix(in srgb, var(--admin-accent, #206bc4) 9%, #fff);
}

body.admin-app .hotres-lodging-report-summary__label {
  display: block;
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-secondary, #64748b);
  margin-bottom: 0.2rem;
}

body.admin-app .hotres-lodging-report-summary__value {
  font-size: 1.15rem;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  color: var(--color-heading, #1e293b);
}

body.admin-app .hotres-lodging-report-summary__tile--accent .hotres-lodging-report-summary__value {
  color: var(--admin-accent, #206bc4);
}

/* Szczegóły rezerwacji HOTRES — karty + drzewo JSON */
body.admin-app .hotres-booking-card__head {
  font-weight: 650;
  background: color-mix(in srgb, var(--admin-accent, #206bc4) 6%, transparent);
  border-bottom: 1px solid rgba(15, 23, 42, 0.07);
}

body.admin-app .hotres-booking-dl {
  --hl-dt-w: min(42%, 11rem);
  font-size: 0.875rem;
}

body.admin-app .hotres-booking-dl dt {
  width: var(--hl-dt-w);
  float: left;
  clear: left;
  margin: 0;
  padding: 0.35rem 0.75rem 0.35rem 0;
  color: var(--color-secondary, #64748b);
  font-weight: 500;
}

body.admin-app .hotres-booking-dl dd {
  margin-left: var(--hl-dt-w);
  padding: 0.35rem 0;
  min-height: 1.85rem;
  border-bottom: 1px solid rgba(15, 23, 42, 0.06);
}

body.admin-app .hotres-booking-dl dd:last-of-type,
body.admin-app .hotres-booking-dl dt:last-of-type + dd {
  border-bottom: none;
}

@media (max-width: 575.98px) {
  body.admin-app .hotres-booking-dl dt {
    float: none;
    width: 100%;
    padding-bottom: 0;
  }
  body.admin-app .hotres-booking-dl dd {
    margin-left: 0;
    padding-top: 0;
  }
}
body.admin-app .hotres-kpi-label {
  display: block;
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-secondary, #64748b);
  margin-bottom: 0.15rem;
}

body.admin-app .hotres-kpi-value {
  font-size: 1.05rem;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
}

body.admin-app .hotres-payload-card .nav-tabs-card {
  border-bottom: none;
  padding: 0.25rem 0.5rem 0;
  gap: 0.25rem;
}

body.admin-app .hotres-payload-card .nav-tabs-card .nav-link {
  border-radius: 0.5rem 0.5rem 0 0;
  font-weight: 600;
  font-size: 0.875rem;
}

body.admin-app .hotres-payload-toolbar {
  background: rgba(248, 250, 252, 0.9);
}

body.admin-app .hotres-payload-tree {
  background: #fff;
  font-size: 0.875rem;
}

body.admin-app .hotres-json-root-label {
  font-weight: 650;
  color: var(--color-heading, #1e293b);
}

body.admin-app .hotres-json-badge {
  display: inline-flex;
  align-items: center;
  margin-left: 0.35rem;
  padding: 0.12rem 0.45rem;
  font-size: 0.65rem;
  font-weight: 650;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  border-radius: 0.35rem;
  background: rgba(15, 23, 42, 0.06);
  color: var(--color-secondary, #64748b);
}

body.admin-app .hotres-json-details {
  border-radius: 0.35rem;
  margin-bottom: 0.15rem;
}

body.admin-app .hotres-json-summary {
  cursor: pointer;
  list-style: none;
  padding: 0.35rem 0.5rem;
  border-radius: 0.35rem;
  background: #f8fafc;
  border: 1px solid rgba(15, 23, 42, 0.07);
  user-select: none;
}

body.admin-app .hotres-json-summary::-webkit-details-marker {
  display: none;
}

body.admin-app .hotres-json-summary::before {
  content: "";
  display: inline-block;
  width: 0.45rem;
  height: 0.45rem;
  margin-right: 0.45rem;
  border-right: 2px solid var(--admin-accent, #206bc4);
  border-bottom: 2px solid var(--admin-accent, #206bc4);
  transform: rotate(-45deg);
  vertical-align: 0.15rem;
  transition: transform 0.15s ease;
}

body.admin-app .hotres-json-details[open] > .hotres-json-summary::before {
  transform: rotate(45deg);
  vertical-align: 0.05rem;
}

body.admin-app .hotres-json-summary:hover {
  background: color-mix(in srgb, var(--admin-accent, #206bc4) 7%, #fff);
  border-color: color-mix(in srgb, var(--admin-accent, #206bc4) 22%, transparent);
}

body.admin-app .hotres-json-children {
  margin: 0.35rem 0 0.5rem 0.65rem;
  padding-left: 0.85rem;
  border-left: 2px solid color-mix(in srgb, var(--admin-accent, #206bc4) 35%, #e2e8f0);
}

body.admin-app .hotres-json-line {
  padding: 0.3rem 0.25rem;
  border-bottom: 1px solid rgba(15, 23, 42, 0.05);
}

body.admin-app .hotres-json-line:last-child {
  border-bottom: none;
}

body.admin-app .hotres-json-key {
  font-size: 0.8rem;
  font-weight: 650;
  color: #7c3aed;
  background: rgba(124, 58, 237, 0.07);
  padding: 0.1rem 0.35rem;
  border-radius: 0.25rem;
}

body.admin-app .hotres-json-str {
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  font-size: 0.8125rem;
  color: #0f172a;
}

body.admin-app .hotres-json-link {
  font-size: 0.8125rem;
  font-weight: 500;
}

body.admin-app .hotres-json-empty {
  font-family: ui-monospace, monospace;
  color: var(--color-secondary, #64748b);
}

body.admin-app .hotres-json-atom--null {
  font-style: italic;
  color: var(--color-secondary, #94a3b8);
}

body.admin-app .hotres-json-atom--bool {
  display: inline-block;
  padding: 0.08rem 0.4rem;
  font-size: 0.72rem;
  font-weight: 650;
  border-radius: 0.3rem;
}

body.admin-app .hotres-json-atom--true {
  background: rgba(25, 135, 84, 0.14);
  color: #146c43;
}

body.admin-app .hotres-json-atom--false {
  background: rgba(108, 117, 125, 0.16);
  color: #495057;
}

/* Lista kompleksów: wyróżnienie wierszy przypiętych do slidera strony głównej */
body.admin-app tr.admin-residence-row--home-slider > td {
  background: color-mix(in srgb, var(--admin-accent, #206bc4) 7%, #fff);
  box-shadow: inset 3px 0 0 0 var(--admin-accent, #206bc4);
}

/*# sourceMappingURL=admin.css.map */
