:root {
  --aqqo-bg: #f5f7fb;
  --aqqo-surface: #ffffff;
  --aqqo-surface-2: #f8fafc;
  --aqqo-text: #0f172a;
  --aqqo-muted: #475569;
  --aqqo-line: #dbe3f0;
  --aqqo-brand: #0f766e;
  --aqqo-brand-2: #14b8a6;
  --aqqo-accent: #2563eb;
  --aqqo-danger: #dc2626;
  --aqqo-warning: #f59e0b;
  --aqqo-success: #059669;
  --aqqo-shadow: 0 20px 60px rgba(15, 23, 42, 0.08);
  --aqqo-radius: 24px;
}

* { box-sizing: border-box; }
html, body { min-height: 100%; }
body {
  margin: 0;
  font-family: 'Inter', system-ui, sans-serif;
  color: var(--aqqo-text);
  background:
    radial-gradient(circle at top left, rgba(20,184,166,.10), transparent 22%),
    radial-gradient(circle at top right, rgba(37,99,235,.08), transparent 24%),
    var(--aqqo-bg);
}

img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }

.aqqo-navbar {
  background: rgba(255,255,255,0.88);
  backdrop-filter: blur(16px);
  border-bottom: 1px solid rgba(219,227,240,0.85);
}
.aqqo-navbar .navbar-brand {
  color: var(--aqqo-text);
  font-weight: 800;
}
.aqqo-navbar .navbar-brand small {
  display: block;
  color: var(--aqqo-muted);
  font-size: .73rem;
  font-weight: 500;
}
.brand-mark {
  width: 42px;
  height: 42px;
  border-radius: 14px;
  background: linear-gradient(135deg, var(--aqqo-brand), var(--aqqo-accent));
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  box-shadow: 0 12px 24px rgba(15, 118, 110, 0.25);
}
.aqqo-navbar .nav-link {
  color: var(--aqqo-muted);
  font-weight: 600;
}
.aqqo-navbar .nav-link.active,
.aqqo-navbar .nav-link:hover {
  color: var(--aqqo-text);
}
.user-pill {
  display: inline-flex;
  flex-direction: column;
  padding: .5rem .85rem;
  border: 1px solid var(--aqqo-line);
  border-radius: 999px;
  background: #fff;
  line-height: 1.1;
}
.user-pill__name { font-size: .9rem; font-weight: 700; }
.user-pill small { color: var(--aqqo-muted); }

.page-shell {
  padding: 36px 0 64px;
}

.hero-card {
  background: linear-gradient(135deg, rgba(15,118,110,.96), rgba(15,23,42,.96));
  color: #fff;
  border-radius: 32px;
  padding: 42px;
  box-shadow: var(--aqqo-shadow);
  overflow: hidden;
  position: relative;
}
.hero-card::after {
  content: '';
  position: absolute;
  inset: auto -60px -90px auto;
  width: 260px;
  height: 260px;
  background: radial-gradient(circle, rgba(255,255,255,.22), rgba(255,255,255,0));
  border-radius: 50%;
}
.hero-kicker {
  display: inline-flex;
  align-items: center;
  gap: .55rem;
  padding: .5rem .85rem;
  border-radius: 999px;
  background: rgba(255,255,255,.12);
  font-weight: 600;
  letter-spacing: .02em;
  margin-bottom: 1rem;
}
.hero-card h1,
.hero-card h2 {
  font-size: clamp(2rem, 3.4vw, 4rem);
  line-height: 1.02;
  font-weight: 800;
  margin-bottom: 1rem;
}
.hero-card p {
  color: rgba(255,255,255,.84);
  font-size: 1.05rem;
  max-width: 760px;
}
.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  margin-top: 1.6rem;
}
.hero-stat-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 1rem;
  margin-top: 1.8rem;
}
.hero-stat {
  background: rgba(255,255,255,.1);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 20px;
  padding: 1rem 1.1rem;
}
.hero-stat strong {
  display: block;
  font-size: 1.4rem;
  font-weight: 800;
}
.hero-stat span {
  color: rgba(255,255,255,.72);
  font-size: .92rem;
}

.section-head {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 1rem;
  margin: 2.25rem 0 1rem;
}
.section-head h2 {
  margin: 0;
  font-size: clamp(1.4rem, 2vw, 2rem);
  font-weight: 800;
}
.section-head p {
  margin: .35rem 0 0;
  color: var(--aqqo-muted);
}

.resource-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 1.35rem;
}
.resource-card {
  background: var(--aqqo-surface);
  border: 1px solid rgba(219,227,240,.85);
  border-radius: 26px;
  overflow: hidden;
  box-shadow: 0 14px 40px rgba(15, 23, 42, 0.05);
  transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
  display: flex;
  flex-direction: column;
  height: 100%;
}
.resource-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 22px 50px rgba(15, 23, 42, 0.10);
  border-color: rgba(15,118,110,.22);
}
.resource-card__media {
  aspect-ratio: 16/10;
  background: #cbd5e1 center/cover no-repeat;
  position: relative;
}
.resource-card__media::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(15,23,42,.30), transparent 45%);
}
.resource-card__badge {
  position: absolute;
  left: 1rem;
  top: 1rem;
  z-index: 1;
  background: rgba(255,255,255,.92);
  color: var(--aqqo-text);
  padding: .42rem .7rem;
  border-radius: 999px;
  font-size: .78rem;
  font-weight: 700;
}
.resource-card__body {
  padding: 1.2rem 1.2rem 1.1rem;
  display: flex;
  flex: 1;
  flex-direction: column;
  gap: .85rem;
}
.resource-card__title {
  font-size: 1.28rem;
  line-height: 1.15;
  font-weight: 800;
  margin: 0;
}
.resource-card__desc {
  color: var(--aqqo-muted);
  margin: 0;
  min-height: 4.4rem;
}
.resource-card__meta,
.detail-meta,
.pill-row {
  display: flex;
  flex-wrap: wrap;
  gap: .55rem;
}
.meta-pill {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  padding: .48rem .7rem;
  border-radius: 999px;
  background: var(--aqqo-surface-2);
  color: var(--aqqo-text);
  font-size: .82rem;
  font-weight: 600;
  border: 1px solid var(--aqqo-line);
}
.resource-card__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .75rem;
  margin-top: auto;
}
.resource-card__footer small { color: var(--aqqo-muted); }

.page-card {
  background: var(--aqqo-surface);
  border: 1px solid rgba(219,227,240,.85);
  border-radius: var(--aqqo-radius);
  box-shadow: 0 14px 40px rgba(15, 23, 42, 0.05);
}
.page-card__body { padding: 1.4rem; }

.resource-detail-hero {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(360px, .9fr);
  gap: 1.5rem;
}
.resource-visual {
  min-height: 360px;
  border-radius: 28px;
  overflow: hidden;
  background: #dbe7ff center/cover no-repeat;
  position: relative;
  box-shadow: var(--aqqo-shadow);
}
.resource-visual::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(15, 23, 42, 0.35), transparent 55%);
}
.resource-visual__content {
  position: absolute;
  left: 1.4rem;
  right: 1.4rem;
  bottom: 1.4rem;
  z-index: 1;
  color: #fff;
}
.resource-side {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.resource-side .page-card,
.resource-main .page-card {
  height: 100%;
}
.resource-side .page-card__body,
.resource-main .page-card__body {
  padding: 1.35rem;
}
.resource-page .container-xxl {
  max-width: min(1700px, calc(100vw - 24px));
}
.resource-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.12fr) minmax(340px, .58fr);
  grid-template-areas:
    'overview sidebar'
    'calendar calendar';
  gap: 1.5rem;
  margin-top: 1.5rem;
  align-items: start;
}
.resource-sidebar {
  grid-area: sidebar;
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
  min-width: 0;
}
#overview-card {
  grid-area: overview;
}
#calendar-card {
  grid-area: calendar;
  min-width: 0;
}

.calendar-shell {
  padding: clamp(1rem, 1.35vw, 1.35rem);
  border-radius: 28px;
  background: linear-gradient(180deg, #fff, #f8fbff);
  box-shadow: inset 0 0 0 1px rgba(219, 227, 240, .75);
}
#calendar-card .page-card__body {
  padding: clamp(1.15rem, 1.35vw, 1.7rem);
}
#calendar {
  min-height: clamp(720px, 74vh, 980px);
  width: 100%;
}
.fc .fc-toolbar-title {
  font-size: 1.15rem;
  font-weight: 800;
}
.fc .fc-button {
  background: var(--aqqo-text);
  border-color: var(--aqqo-text);
  border-radius: 12px;
  box-shadow: none !important;
}
.fc .fc-button:hover,
.fc .fc-button.fc-button-active {
  background: var(--aqqo-brand);
  border-color: var(--aqqo-brand);
}
.fc .fc-toolbar {
  gap: .8rem;
  flex-wrap: wrap;
}
.fc .fc-toolbar-chunk {
  display: inline-flex;
  align-items: center;
  gap: .55rem;
  flex-wrap: wrap;
}
.fc .fc-scrollgrid {
  border-radius: 20px;
  overflow: hidden;
}
.fc .fc-view-harness {
  min-height: inherit;
}
.fc .fc-button-group {
  display: inline-flex;
  flex-wrap: wrap;
  gap: .45rem;
}
.fc .fc-button-group > .fc-button {
  margin: 0 !important;
}
.fc-theme-standard td,
.fc-theme-standard th,
.fc-theme-standard .fc-scrollgrid {
  border-color: #e8eef7;
}
.fc .fc-event {
  border-radius: 12px;
  border: 0;
  padding: 1px 4px;
  font-weight: 600;
}
.fc .fc-bg-event {
  opacity: .55;
}
.fc .fc-daygrid-event-dot { display: none; }

.info-list,
.side-list {
  display: grid;
  gap: .85rem;
}
.info-item,
.side-item {
  padding: .9rem 1rem;
  border-radius: 18px;
  border: 1px solid var(--aqqo-line);
  background: var(--aqqo-surface-2);
}
.info-item small,
.side-item small {
  display: block;
  color: var(--aqqo-muted);
  margin-bottom: .2rem;
}
.info-item strong,
.side-item strong {
  font-size: 1rem;
}

.empty-state {
  padding: 1.2rem;
  border-radius: 20px;
  border: 1px dashed var(--aqqo-line);
  background: var(--aqqo-surface-2);
  color: var(--aqqo-muted);
  text-align: center;
}

.metric-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 1rem;
}
.metric-card {
  padding: 1rem 1.1rem;
  border-radius: 22px;
  background: var(--aqqo-surface);
  border: 1px solid var(--aqqo-line);
  box-shadow: 0 12px 28px rgba(15, 23, 42, 0.04);
}
.metric-card strong {
  display: block;
  font-size: 1.55rem;
  font-weight: 800;
}
.metric-card span {
  color: var(--aqqo-muted);
}

.admin-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: .75rem;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 1.2rem;
}
.admin-grid {
  display: grid;
  grid-template-columns: minmax(320px, .9fr) minmax(0, 1.3fr);
  gap: 1.5rem;
}
.rooms-admin-page .admin-grid {
  grid-template-columns: minmax(640px, 1.08fr) minmax(440px, .92fr);
  align-items: start;
}
.rooms-admin-page .form-card,
.rooms-admin-page .table-card {
  min-width: 0;
}
.rooms-admin-page .table-card {
  position: sticky;
  top: 18px;
  align-self: start;
}
.rooms-admin-page .form-card__body,
.rooms-admin-page .table-card__body {
  padding: 1.45rem;
}
.rooms-admin-page #resourceForm .form-text,
.rooms-admin-page #resourceForm .small.text-secondary {
  line-height: 1.45;
}
.resource-form-divider {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  justify-content: space-between;
  gap: .5rem .9rem;
  padding-bottom: .7rem;
  margin-top: .2rem;
  border-bottom: 1px solid rgba(148, 163, 184, .22);
}
.resource-form-divider span {
  font-size: .98rem;
  font-weight: 800;
  color: #0f172a;
}
.resource-form-divider small {
  color: #64748b;
}
.inline-help-card {
  border: 1px solid rgba(148, 163, 184, .2);
  border-radius: 16px;
  padding: .78rem .9rem;
  background: linear-gradient(180deg, rgba(248,250,252,.92), rgba(255,255,255,.9));
  color: #475569;
  font-size: .92rem;
}
.form-card,
.table-card {
  background: var(--aqqo-surface);
  border-radius: 26px;
  border: 1px solid var(--aqqo-line);
  box-shadow: 0 14px 40px rgba(15, 23, 42, 0.05);
}
.form-card__body,
.table-card__body {
  padding: 1.35rem;
}
.table thead th {
  font-size: .82rem;
  text-transform: uppercase;
  color: var(--aqqo-muted);
  letter-spacing: .03em;
  border-bottom-width: 1px;
}
.table tbody td { vertical-align: middle; }
.table-row-muted { color: var(--aqqo-muted); }
.preview-card {
  border-radius: 22px;
  overflow: hidden;
  border: 1px solid var(--aqqo-line);
  background: var(--aqqo-surface-2);
}
.preview-card__image {
  aspect-ratio: 16/9;
  background: #cbd5e1 center/cover no-repeat;
}
.preview-card__body { padding: 1rem; }

.modal-content {
  border: 0;
  border-radius: 24px;
  overflow: hidden;
  box-shadow: 0 28px 100px rgba(15, 23, 42, 0.25);
}
.modal-header,
.modal-footer {
  border-color: #eef3fb;
}
.modal-title { font-weight: 800; }
.form-control,
.form-select,
.select2-selection {
  border-radius: 14px !important;
  border-color: #d6deea !important;
  min-height: 46px;
}
textarea.form-control { min-height: 140px; }
.form-label {
  font-weight: 700;
  color: var(--aqqo-text);
}
.btn {
  border-radius: 14px;
  font-weight: 700;
}
.btn-brand {
  background: linear-gradient(135deg, var(--aqqo-brand), var(--aqqo-accent));
  color: #fff;
  border: none;
}
.btn-brand:hover { color: #fff; opacity: .95; }
.btn-ghost {
  background: #fff;
  border: 1px solid var(--aqqo-line);
}
.badge-soft {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  padding: .45rem .7rem;
  border-radius: 999px;
  background: rgba(37,99,235,.08);
  color: var(--aqqo-accent);
  font-weight: 700;
}
.badge-soft.success {
  background: rgba(5,150,105,.1);
  color: var(--aqqo-success);
}
.badge-soft.warning {
  background: rgba(245,158,11,.16);
  color: #a16207;
}
.badge-soft.dark {
  background: rgba(15,23,42,.08);
  color: var(--aqqo-text);
}

.alert {
  border-radius: 18px;
}

@media (max-width: 1500px) {
  .rooms-admin-page .admin-grid {
    grid-template-columns: 1fr;
  }

  .rooms-admin-page .table-card {
    position: static;
  }
}

@media (max-width: 1200px) {
  .resource-grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .resource-detail-hero,
  .admin-grid {
    grid-template-columns: 1fr;
  }
  .resource-layout {
    grid-template-columns: 1fr;
    grid-template-areas:
      'overview'
      'calendar'
      'sidebar';
  }
}

@media (max-width: 768px) {
  .page-shell { padding-top: 24px; }
  .hero-card { padding: 28px; border-radius: 26px; }
  .hero-stat-grid,
  .metric-grid,
  .resource-grid { grid-template-columns: 1fr; }
  .resource-card__desc { min-height: auto; }
  .section-head { flex-direction: column; align-items: start; }
  .resource-visual { min-height: 280px; }
  .resource-page .container-xxl { max-width: calc(100vw - 12px); }
  .calendar-shell { padding: .8rem; border-radius: 22px; }
  #calendar-card .page-card__body { padding: 1rem; }
  #calendar { min-height: 560px; }
  .fc .fc-toolbar-title { font-size: 1rem; }
  .fc .fc-toolbar-chunk { width: 100%; justify-content: flex-start; }
  .fc .fc-button-group { width: 100%; }
  .calendar-utility-group { width: 100%; align-items: flex-start; }
}


/* sprint 2 / commerce */
.commerce-summary {
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 16px;
}
.commerce-summary__item {
  border: 1px solid var(--aqqo-line);
  border-radius: 18px;
  padding: 18px 20px;
  background: var(--aqqo-surface-2);
}
.commerce-summary__item small,
.stat-card small,
.summary-box__line span {
  display: block;
  color: var(--aqqo-muted);
  margin-bottom: 6px;
}
.commerce-summary__item strong,
.stat-card strong {
  font-size: 1.1rem;
}
.summary-box {
  border: 1px solid var(--aqqo-line);
  background: var(--aqqo-surface-2);
  border-radius: 18px;
  padding: 18px 20px;
}
.summary-box__title {
  font-weight: 800;
  margin-bottom: 12px;
}
.summary-box__line {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 8px 0;
  border-top: 1px dashed rgba(148,163,184,.35);
}
.summary-box__line:first-of-type {
  border-top: none;
  padding-top: 0;
}
.stats-row {
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 16px;
}
.stat-card {
  background: #fff;
  border: 1px solid var(--aqqo-line);
  border-radius: 20px;
  padding: 18px 20px;
  box-shadow: var(--aqqo-shadow);
}
.booking-list {
  display: grid;
  gap: 16px;
}
.booking-card {
  border: 1px solid var(--aqqo-line);
  border-radius: 22px;
  background: #fff;
  padding: 20px;
}
.booking-card__head {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: start;
  margin-bottom: 14px;
}
.booking-card__head h3 {
  margin: 0 0 4px;
  font-size: 1.1rem;
  font-weight: 800;
}
.booking-card__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 14px;
}
.badge-soft.danger {
  background: rgba(220,38,38,.12);
  color: var(--aqqo-danger);
}
@media (max-width: 992px) {
  .commerce-summary,
  .stats-row {
    grid-template-columns: 1fr;
  }
  .booking-card__head {
    flex-direction: column;
  }
}

/* =========================
   Aqqo-like back-office shell
   ========================= */
.admin-shell {
  display: grid;
  grid-template-columns: 312px minmax(0, 1fr);
  min-height: 100vh;
}
.admin-sidebar {
  padding: 22px 18px;
  background: rgba(255,255,255,0.86);
  backdrop-filter: blur(16px);
  border-right: 1px solid rgba(219,227,240,0.9);
  position: sticky;
  top: 0;
  height: 100vh;
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.admin-brand {
  display: grid;
  gap: 10px;
}
.admin-brand__link {
  display: flex;
  align-items: center;
  gap: 10px;
}
.admin-brand__text strong {
  display: block;
  font-weight: 900;
}
.admin-brand__text small {
  display: block;
  color: var(--aqqo-muted);
  font-weight: 600;
  font-size: .78rem;
}
.admin-menu {
  display: grid;
  gap: 8px;
}
.admin-menu__item {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 12px 12px;
  border-radius: 16px;
  border: 1px solid transparent;
  color: var(--aqqo-muted);
  font-weight: 700;
  line-height: 1.35;
  white-space: normal;
}
.admin-menu__item i { width: 18px; text-align: center; }
.admin-menu__item:hover {
  background: rgba(37,99,235,.06);
  border-color: rgba(37,99,235,.12);
  color: var(--aqqo-text);
}
.admin-menu__item.active {
  background: linear-gradient(135deg, rgba(15,118,110,.12), rgba(37,99,235,.10));
  border-color: rgba(15,118,110,.22);
  color: var(--aqqo-text);
}
.admin-sidebar__footer {
  margin-top: auto;
}
.admin-content {
  padding: 28px 0 72px;
}

/* =========================
   Auth (login) screen
   ========================= */
.auth-shell {
  min-height: calc(100vh - 0px);
  display: grid;
  place-items: center;
  padding: 44px 16px;
}
.auth-card {
  width: 100%;
  max-width: 520px;
  background: rgba(255,255,255,0.92);
  border: 1px solid rgba(219,227,240,0.9);
  border-radius: 28px;
  box-shadow: var(--aqqo-shadow);
  overflow: hidden;
}
.auth-card__head {
  padding: 22px 22px 0;
}
.auth-card__body {
  padding: 22px;
}
.auth-title {
  font-weight: 900;
  font-size: 1.6rem;
  margin: 10px 0 6px;
}
.auth-subtitle {
  color: var(--aqqo-muted);
  margin: 0;
}

/* =========================
   Availability search strip (Aqqo-stiil)
   ========================= */
.availability-card .page-card__body {
  padding: 1rem;
}

/* New compact strip */
.availability-strip {
  display: grid;
  grid-template-columns: 1.6fr 1fr 1.2fr .8fr auto auto;
  gap: 10px;
  align-items: center;
}
.availability-strip .form-control,
.availability-strip .form-select {
  min-height: 42px;
  border-radius: 14px;
}
.availability-strip .btn {
  min-height: 42px;
  border-radius: 14px;
  white-space: nowrap;
}
.availability-hint { margin-left: 2px; }

/* Backwards compatible old class name */
.availability-bar { display: block; }

@media (max-width: 992px) {
  .admin-shell { grid-template-columns: 1fr; }
  .admin-sidebar { position: relative; height: auto; }
  .admin-content { padding: 18px 0 60px; }

  .availability-strip {
    grid-template-columns: 1fr;
  }
  .availability-strip .btn,
  .availability-strip a.btn {
    width: 100%;
  }
}

/* Aqqo polish: sticky booking sidebar */
.booking-sticky {
  position: sticky;
  top: 18px;
}

@media (max-width: 992px) {
  .booking-sticky { position: static; }
}

/* Availability chips (cards + sidebar) */
.chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.availability-chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: .45rem .75rem;
  border-radius: 999px;
  border: 1px solid rgba(37, 99, 235, .18);
  background: rgba(255, 255, 255, .96);
  color: var(--aqqo-text);
  text-decoration: none;
  font-weight: 650;
  font-size: .92rem;
  transition: transform .12s ease, box-shadow .12s ease;
  box-shadow: var(--aqqo-shadow-soft);
}

.availability-chip:hover {
  transform: translateY(-1px);
  box-shadow: var(--aqqo-shadow);
}

.availability-chip:active {
  transform: translateY(0);
}

button.availability-chip {
  cursor: pointer;
}

/* Resource gallery */
.resource-gallery .gallery-grid {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 12px;
}

@media (max-width: 1200px) {
  .resource-gallery .gallery-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); }
}

@media (max-width: 768px) {
  .resource-gallery .gallery-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

.gallery-thumb-link {
  display: block;
  position: relative;
  border-radius: 18px;
  overflow: hidden;
  aspect-ratio: 4 / 3;
  border: 1px solid rgba(148, 163, 184, .28);
  background: rgba(255, 255, 255, .8);
}

.gallery-thumb-img {
  display: block;
  width: 100%;
  height: 100%;
  background: #e9eefb center/cover no-repeat;
  transition: transform .18s ease;
}

.gallery-thumb-link:hover .gallery-thumb-img {
  transform: scale(1.02);
}

.gallery-cover-badge {
  position: absolute;
  top: .6rem;
  left: .6rem;
  padding: .25rem .55rem;
  border-radius: 999px;
  background: rgba(15, 23, 42, .7);
  color: #fff;
  font-weight: 700;
  font-size: .75rem;
  letter-spacing: .02em;
}

/* Admin gallery management */
.gallery-admin-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}

@media (max-width: 1200px) {
  .gallery-admin-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}

@media (max-width: 768px) {
  .gallery-admin-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

.gallery-admin-item {
  position: relative;
  border-radius: 20px;
  overflow: hidden;
  border: 1px solid rgba(148, 163, 184, .32);
  background: rgba(255, 255, 255, .96);
  box-shadow: var(--aqqo-shadow-soft);
}

.gallery-admin-item.is-dragging {
  opacity: .65;
}

.gallery-admin-thumb {
  height: 148px;
  background: #e9eefb center/cover no-repeat;
}

.gallery-admin-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 10px 12px 0;
}

.gallery-admin-actions {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  padding: 10px 12px 12px;
}

.gallery-admin-handle {
  position: absolute;
  top: 10px;
  right: 10px;
  width: 36px;
  height: 36px;
  border-radius: 14px;
  display: grid;
  place-items: center;
  background: rgba(255, 255, 255, .86);
  border: 1px solid rgba(148, 163, 184, .35);
  cursor: grab;
}

.gallery-admin-handle:active {
  cursor: grabbing;
}

/* Sidebar-first booking + lightbox polish */
.booking-inline-summary {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}
.booking-inline-summary > div,
.booking-selection-card {
  border: 1px solid rgba(148, 163, 184, .22);
  border-radius: 18px;
  padding: 14px 16px;
  background: rgba(255,255,255,.78);
}
.booking-inline-summary small,
.booking-selection-card small {
  display: block;
  color: #64748b;
  margin-bottom: 4px;
}
.sidebar-booking-form .form-label {
  font-weight: 700;
  font-size: .88rem;
  margin-bottom: .35rem;
}
.sidebar-booking-form .form-control,
.sidebar-booking-form .form-select {
  border-radius: 14px;
  min-height: 46px;
}
.sidebar-booking-form textarea.form-control {
  min-height: 96px;
}
.booking-price-panel {
  border-radius: 20px;
  padding: 16px;
  background: linear-gradient(180deg, rgba(37,99,235,.06), rgba(15,23,42,.02));
  border: 1px solid rgba(59,130,246,.14);
}
.booking-price-row {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  padding: 6px 0;
  color: #334155;
}
.booking-price-row.total {
  border-top: 1px dashed rgba(148,163,184,.5);
  margin-top: 6px;
  padding-top: 12px;
  font-size: 1.05rem;
}
.booking-price-row strong {
  font-weight: 800;
}
.booking-form-status.alert {
  border-radius: 16px;
  margin-bottom: 0;
}

.booking-feedback__title {
  font-weight: 800;
  color: #0f172a;
}
.booking-feedback__body {
  margin-top: .35rem;
  color: #334155;
}
.booking-feedback__hint {
  margin-top: .55rem;
  font-size: .84rem;
  color: #475569;
}
.booking-followup-actions {
  display: flex;
  flex-wrap: wrap;
  gap: .75rem;
  align-items: center;
}
.booking-followup-actions > a,
.booking-followup-actions > .btn,
.booking-followup-actions > form {
  flex: 0 0 auto;
}
.ops-section-head {
  padding-bottom: .9rem;
  border-bottom: 1px dashed rgba(148,163,184,.4);
}
.ops-section-head .badge-soft {
  flex-shrink: 0;
}
.ops-secondary-panel {
  border: 1px solid rgba(148,163,184,.24);
  border-radius: 18px;
  padding: .95rem 1rem;
  background: linear-gradient(180deg, rgba(255,255,255,.98), rgba(248,250,252,.9));
}
.ops-secondary-panel summary {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  align-items: flex-start;
  cursor: pointer;
  list-style: none;
  color: #0f172a;
  font-weight: 800;
}
.ops-secondary-panel summary::-webkit-details-marker {
  display: none;
}
.ops-secondary-panel summary span {
  display: inline-flex;
  align-items: center;
  gap: .55rem;
}
.ops-secondary-panel summary small {
  display: block;
  color: #64748b;
  font-weight: 500;
}
.ops-secondary-panel[open] summary {
  margin-bottom: .85rem;
}
.checkout-journey {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .85rem;
}
.checkout-journey__step {
  border: 1px solid rgba(148,163,184,.18);
  border-radius: 18px;
  padding: .9rem 1rem;
  background: linear-gradient(180deg, rgba(255,255,255,.98), rgba(248,250,252,.92));
}
.checkout-journey__step small {
  display: block;
  color: #64748b;
  margin-bottom: .25rem;
}
.checkout-journey__step strong {
  display: block;
  font-weight: 800;
  color: #0f172a;
}
.checkout-journey__step span {
  display: block;
  margin-top: .2rem;
  color: #475569;
  font-size: .88rem;
}
.checkout-journey__step.is-done {
  border-color: rgba(34,197,94,.28);
  background: linear-gradient(180deg, rgba(240,253,244,.96), rgba(255,255,255,.96));
}
.checkout-journey__step.is-active {
  border-color: rgba(37,99,235,.22);
  background: linear-gradient(180deg, rgba(239,246,255,.98), rgba(255,255,255,.96));
}
@media (max-width: 768px) {
  .checkout-journey {
    grid-template-columns: 1fr;
  }
}
.gallery-lightbox-modal {
  border-radius: 28px;
  overflow: hidden;
  background: #0f172a;
  color: #fff;
}
.gallery-lightbox-stage {
  min-height: 70vh;
  display: grid;
  place-items: center;
}
.gallery-lightbox-stage img {
  max-width: 100%;
  max-height: 70vh;
  border-radius: 22px;
  object-fit: contain;
  box-shadow: 0 20px 50px rgba(0,0,0,.35);
}
@media (max-width: 992px) {
  .booking-inline-summary {
    grid-template-columns: 1fr;
  }
}

/* Scheduler / split-resource calendar polish */
.resource-page .fc {
    --fc-border-color: rgba(15, 23, 42, 0.08);
    --fc-page-bg-color: #ffffff;
    --fc-neutral-bg-color: #f8fafc;
    --fc-list-event-hover-bg-color: #eef2ff;
}

.resource-page .fc .fc-toolbar {
    gap: 0.75rem;
    align-items: center;
    flex-wrap: wrap;
}

.resource-page .fc .fc-toolbar-title {
    font-size: 1.15rem;
    font-weight: 800;
    color: #0f172a;
}

.resource-page .fc .fc-button {
    border-radius: 999px;
    padding: 0.45rem 0.85rem;
    box-shadow: none !important;
}

.resource-page .fc .fc-scrollgrid,
.resource-page .fc .fc-theme-standard td,
.resource-page .fc .fc-theme-standard th {
    border-color: rgba(15, 23, 42, 0.08);
}

.resource-page .fc .fc-scrollgrid {
    border-radius: 18px;
    overflow: hidden;
}

.resource-page .fc .fc-resourcecell,
.resource-page .fc .fc-datagrid-cell-main {
    font-weight: 700;
    color: #0f172a;
}

.resource-page .fc .fc-col-header-cell-cushion,
.resource-page .fc .fc-timegrid-slot-label-cushion,
.resource-page .fc .fc-list-day-text,
.resource-page .fc .fc-list-day-side-text {
    color: #334155;
    font-weight: 600;
}

.resource-page .fc .fc-day-today {
    background: rgba(37, 99, 235, 0.06) !important;
}

.resource-page .fc .fc-event {
    border-radius: 12px;
    padding: 0.1rem 0.15rem;
}

.resource-page .fc .fc-event-main {
    font-weight: 600;
}

.resource-page .fc .fc-bg-event {
    opacity: 0.75;
}

.resource-page .fc .fc-timegrid-slot,
.resource-page .fc .fc-timegrid-slot-label {
    height: 2.75rem;
}

.resource-page .fc .fc-daygrid-day-frame {
    min-height: 7rem;
}

/* Superwow: rule banners, toast feedback and richer booking state */
.booking-inline-summary {
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
}

.booking-selection-card {
  transition: border-color .18s ease, box-shadow .18s ease, transform .18s ease, background-color .18s ease;
}

.booking-selection-card.is-active {
  border-color: rgba(37, 99, 235, .30);
  box-shadow: 0 18px 44px rgba(37, 99, 235, .16);
  transform: translateY(-1px);
  background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(239,246,255,.82));
}

.availability-mode-banner {
  border: 1px solid rgba(59, 130, 246, .16);
  border-radius: 18px;
  padding: 12px 14px;
  background: linear-gradient(180deg, rgba(241,245,249,.96), rgba(255,255,255,.92));
  color: #334155;
  font-weight: 650;
  box-shadow: 0 12px 28px rgba(15, 23, 42, .05);
}

.aqqo-toast-stack {
  position: fixed;
  right: 18px;
  bottom: 18px;
  z-index: 3000;
  display: flex;
  flex-direction: column;
  gap: 10px;
  pointer-events: none;
}

.aqqo-toast {
  min-width: 260px;
  max-width: min(92vw, 360px);
  padding: 12px 14px;
  border-radius: 16px;
  background: rgba(255,255,255,.97);
  color: #0f172a;
  border: 1px solid rgba(148, 163, 184, .28);
  box-shadow: 0 18px 42px rgba(15, 23, 42, .18);
  font-weight: 650;
  line-height: 1.45;
  opacity: 0;
  transform: translateY(10px) scale(.98);
  transition: opacity .16s ease, transform .16s ease;
}

.aqqo-toast.is-visible {
  opacity: 1;
  transform: translateY(0) scale(1);
}

.aqqo-toast--success {
  border-color: rgba(16, 185, 129, .28);
  background: linear-gradient(180deg, rgba(236,253,245,.98), rgba(255,255,255,.96));
}

.aqqo-toast--warning {
  border-color: rgba(245, 158, 11, .32);
  background: linear-gradient(180deg, rgba(255,251,235,.98), rgba(255,255,255,.96));
}

.aqqo-toast--danger {
  border-color: rgba(239, 68, 68, .28);
  background: linear-gradient(180deg, rgba(254,242,242,.98), rgba(255,255,255,.96));
}

.aqqo-toast--info {
  border-color: rgba(59, 130, 246, .22);
  background: linear-gradient(180deg, rgba(239,246,255,.98), rgba(255,255,255,.96));
}

.resource-page .fc .fc-toolbar-chunk {
  display: flex;
  gap: .45rem;
  align-items: center;
  flex-wrap: wrap;
}

.resource-page .fc .fc-button {
  transition: transform .12s ease, box-shadow .12s ease, opacity .12s ease;
}

.resource-page .fc .fc-button:hover {
  transform: translateY(-1px);
}

.resource-page .fc .fc-resourcecell:hover,
.resource-page .fc .fc-datagrid-cell:hover {
  background: rgba(37, 99, 235, .03);
}

.resource-page .fc .fc-bg-event {
  border-radius: 12px;
}

.resource-page .fc .fc-list-event-dot {
  border-width: 6px;
}

.resource-page .fc .fc-aqqo-event-host {
  overflow: hidden;
}

.resource-page .fc .fc-aqqo-event {
  display: grid;
  gap: .18rem;
  min-width: 0;
}

.resource-page .fc .fc-aqqo-event__title {
  font-weight: 750;
  line-height: 1.15;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.resource-page .fc .fc-aqqo-event__meta {
  display: flex;
  flex-wrap: wrap;
  gap: .3rem;
  align-items: center;
  min-width: 0;
}

.resource-page .fc .fc-aqqo-event__meta span {
  display: inline-flex;
  align-items: center;
  max-width: 100%;
  padding: .1rem .4rem;
  border-radius: 999px;
  background: rgba(255,255,255,.18);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  font-size: .72rem;
  line-height: 1.2;
}

.resource-page .fc .fc-timeline-event .fc-aqqo-event,
.resource-page .fc .fc-timegrid-event .fc-aqqo-event {
  gap: .12rem;
}

.resource-page .fc .fc-timeline-event .fc-aqqo-event__title,
.resource-page .fc .fc-timegrid-event .fc-aqqo-event__title {
  font-size: .77rem;
}

.resource-page .fc .fc-timeline-event .fc-aqqo-event__meta,
.resource-page .fc .fc-timegrid-event .fc-aqqo-event__meta {
  gap: .22rem;
}

.resource-page .fc .fc-timeline-event .fc-aqqo-event__meta span,
.resource-page .fc .fc-timegrid-event .fc-aqqo-event__meta span {
  font-size: .68rem;
  padding: .08rem .34rem;
}

.resource-page .fc .fc-list-event .fc-aqqo-event__title {
  white-space: normal;
  overflow: visible;
}

.resource-page .fc .fc-list-event .fc-aqqo-event__meta span {
  background: rgba(15, 23, 42, .06);
  color: #334155;
}

.resource-page .fc .fc-timeline-slot-cushion,
.resource-page .fc .fc-datagrid-cell-cushion,
.resource-page .fc .fc-timeline-header-row-chrono .fc-timeline-slot-cushion {
  font-weight: 700;
}

.priority-override-card {
  border: 1px solid rgba(245, 158, 11, .24);
  border-radius: 20px;
  background: linear-gradient(180deg, rgba(255,251,235,.95), rgba(255,255,255,.94));
  box-shadow: 0 16px 30px rgba(15, 23, 42, .05);
}

.priority-override-card__header {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  padding: 1rem 1rem .85rem;
  align-items: flex-start;
}

.priority-override-card__title {
  font-weight: 850;
  color: #92400e;
}

.priority-override-card__hint {
  margin-top: .2rem;
  color: #7c5e10;
  line-height: 1.45;
}

.priority-override-card__body {
  padding: 0 1rem 1rem;
  border-top: 1px solid rgba(245, 158, 11, .18);
}

.priority-override-card__body.is-readonly {
  opacity: .88;
}

.priority-override-preview {
  border: 1px solid rgba(148, 163, 184, .2);
  border-radius: 18px;
  background: rgba(255,255,255,.85);
  padding: .9rem 1rem;
}

.priority-override-preview__title {
  font-weight: 800;
  color: #0f172a;
}

.priority-override-preview__summary {
  color: #475569;
  margin-top: .25rem;
  line-height: 1.5;
}

.priority-override-preview__list {
  display: grid;
  gap: .55rem;
  margin-top: .85rem;
}

.priority-override-preview__item {
  display: grid;
  gap: .15rem;
  padding: .7rem .8rem;
  border-radius: 14px;
  border: 1px solid rgba(148, 163, 184, .16);
  background: rgba(248,250,252,.92);
}

.priority-override-preview__item span {
  display: inline-flex;
  width: fit-content;
  padding: .1rem .45rem;
  border-radius: 999px;
  background: rgba(245, 158, 11, .12);
  color: #92400e;
  font-size: .72rem;
  font-weight: 700;
}

.priority-override-preview__item small,
.priority-override-preview__more {
  color: #64748b;
}

@media (max-width: 768px) {
  .priority-override-card__header {
    flex-direction: column;
  }

  .resource-page .fc .fc-aqqo-event__meta span {
    max-width: 100%;
  }
}

@media (max-width: 768px) {
  .aqqo-toast-stack {
    left: 12px;
    right: 12px;
    bottom: 12px;
  }

  .aqqo-toast {
    min-width: 0;
    width: 100%;
    max-width: none;
  }
}

/* Aqqo admin polish: system status, opening hours and draggable resource list */
.system-health-card {
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(280px, .85fr);
  gap: 1rem;
  padding: 1.15rem 1.2rem;
  border-radius: 26px;
  border: 1px solid rgba(148, 163, 184, .22);
  background: linear-gradient(180deg, rgba(255,255,255,.98), rgba(248,250,252,.94));
  box-shadow: 0 20px 44px rgba(15, 23, 42, .06);
  align-items: start;
}

.system-health-actions {
  display: flex;
  flex-direction: column;
  gap: .7rem;
  align-items: flex-start;
}

.system-health-list {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: .75rem;
}

.system-health-item {
  display: flex;
  align-items: center;
  gap: .65rem;
  padding: .8rem .95rem;
  border-radius: 18px;
  border: 1px solid rgba(148, 163, 184, .18);
  background: rgba(255,255,255,.78);
  color: #0f172a;
  font-weight: 650;
}

.system-health-item i {
  font-size: 1rem;
}

.system-health-item.is-ok {
  border-color: rgba(16, 185, 129, .18);
  background: linear-gradient(180deg, rgba(236,253,245,.95), rgba(255,255,255,.9));
}

.system-health-item.is-ok i {
  color: #059669;
}

.system-health-item.is-missing {
  border-color: rgba(245, 158, 11, .22);
  background: linear-gradient(180deg, rgba(255,251,235,.95), rgba(255,255,255,.9));
}

.system-health-item.is-missing i {
  color: #d97706;
}

.opening-hours-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: .55rem;
}

.opening-hours-card {
  border: 1px solid rgba(148, 163, 184, .18);
  border-radius: 22px;
  padding: 1rem;
  background: linear-gradient(180deg, rgba(255,255,255,.98), rgba(248,250,252,.9));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.7);
}

.opening-hours-table th {
  font-size: .88rem;
  color: #64748b;
  text-transform: uppercase;
  letter-spacing: .04em;
}

.opening-hours-row {
  transition: background-color .16s ease, opacity .16s ease, transform .16s ease;
}

.opening-hours-row.is-disabled {
  opacity: .56;
}

.opening-hours-row.is-all-day {
  background: rgba(37, 99, 235, .045);
}

.opening-hours-row.is-closed {
  background: rgba(239, 68, 68, .05);
}

.resource-row-handle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 12px;
  color: #64748b;
  background: rgba(241,245,249,.92);
  border: 1px dashed rgba(148, 163, 184, .45);
  margin-bottom: .5rem;
  cursor: grab;
}

.resource-row-handle:active {
  cursor: grabbing;
}

.resource-admin-row {
  transition: background-color .14s ease, box-shadow .14s ease, opacity .14s ease;
}

.resource-admin-row:hover {
  background: rgba(248, 250, 252, .88);
}

.resource-admin-row.is-dragging {
  opacity: .55;
}

#resourceAdminTable tbody tr.resource-admin-row td {
  vertical-align: middle;
}

@media (max-width: 992px) {
  .system-health-card {
    grid-template-columns: 1fr;
  }
}

.resource-page .fc .fc-event.can-admin-edit {
  box-shadow: 0 10px 22px rgba(15, 23, 42, .14);
}

.resource-page .fc .fc-event.can-inline-edit {
  cursor: move;
}

.resource-page .fc .fc-event.can-inline-edit:hover {
  transform: translateY(-1px);
  box-shadow: 0 16px 28px rgba(15, 23, 42, .18);
}

/* Frontend polish: anchor nav, target pills and collapsible request panels */
.resource-anchor-nav {
  position: sticky;
  top: 84px;
  z-index: 20;
  display: flex;
  flex-wrap: wrap;
  gap: .7rem;
  padding: .9rem 1rem;
  border-radius: 22px;
  background: rgba(255,255,255,.9);
  border: 1px solid rgba(148, 163, 184, .18);
  box-shadow: 0 14px 32px rgba(15, 23, 42, .08);
  backdrop-filter: blur(16px);
}

.resource-anchor-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: .55rem .95rem;
  border-radius: 999px;
  border: 1px solid rgba(148, 163, 184, .2);
  background: rgba(248,250,252,.92);
  color: #334155;
  font-weight: 700;
  text-decoration: none;
  transition: transform .18s ease, box-shadow .18s ease, background-color .18s ease, color .18s ease, border-color .18s ease;
}

.resource-anchor-link:hover,
.resource-anchor-link.is-active {
  color: #0f172a;
  background: linear-gradient(180deg, rgba(219,234,254,.95), rgba(255,255,255,.96));
  border-color: rgba(59,130,246,.28);
  box-shadow: 0 12px 28px rgba(37, 99, 235, .12);
  transform: translateY(-1px);
}

.resource-target-strip {
  display: flex;
  flex-wrap: wrap;
  gap: .75rem;
}

.resource-target-pill {
  display: inline-flex;
  align-items: center;
  gap: .8rem;
  min-width: min(100%, 240px);
  padding: .8rem .95rem;
  border-radius: 18px;
  border: 1px solid rgba(148, 163, 184, .18);
  background: rgba(255,255,255,.96);
  box-shadow: 0 10px 24px rgba(15, 23, 42, .05);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease, background-color .18s ease;
}

.resource-target-pill:hover,
.resource-target-pill.is-active {
  transform: translateY(-1px);
  border-color: rgba(59,130,246,.28);
  box-shadow: 0 16px 34px rgba(37, 99, 235, .13);
  background: linear-gradient(180deg, rgba(239,246,255,.96), rgba(255,255,255,.98));
}

.resource-target-pill__swatch {
  width: 14px;
  height: 14px;
  border-radius: 999px;
  box-shadow: 0 0 0 5px rgba(148,163,184,.12);
  flex: 0 0 auto;
}

.resource-target-pill__body {
  display: flex;
  flex-direction: column;
  gap: .15rem;
  text-align: left;
}

.resource-target-pill__body strong {
  color: #0f172a;
  font-size: .95rem;
}

.resource-target-pill__body small {
  color: #64748b;
}

.calendar-legend {
  display: flex;
  flex-wrap: wrap;
  gap: .65rem;
}

.legend-pill {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  padding: .48rem .8rem;
  border-radius: 999px;
  font-size: .82rem;
  font-weight: 700;
  border: 1px solid rgba(148, 163, 184, .18);
  background: rgba(248,250,252,.92);
  color: #334155;
}

.legend-pill.allowed { background: rgba(22, 163, 74, .09); color: #166534; border-color: rgba(22, 163, 74, .16); }
.legend-pill.blocked { background: rgba(239, 68, 68, .09); color: #b91c1c; border-color: rgba(239, 68, 68, .16); }
.legend-pill.booking { background: rgba(37, 99, 235, .09); color: #1d4ed8; border-color: rgba(37, 99, 235, .16); }
.legend-pill.pending { background: rgba(245, 158, 11, .12); color: #b45309; border-color: rgba(245, 158, 11, .18); }
.legend-pill.training { background: rgba(20, 184, 166, .12); color: #0f766e; border-color: rgba(20, 184, 166, .18); }

.booking-disclosure-card,
.quote-context-banner {
  border: 1px solid rgba(148, 163, 184, .18);
  border-radius: 20px;
  padding: .95rem 1rem;
  background: linear-gradient(180deg, rgba(255,255,255,.98), rgba(248,250,252,.92));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.68);
}

.booking-disclosure-card__head {
  display: flex;
  flex-wrap: wrap;
  gap: .75rem 1rem;
  align-items: center;
  justify-content: space-between;
}

.booking-disclosure-card small,
.quote-context-banner small {
  display: block;
  color: #64748b;
  margin-bottom: .2rem;
}

.booking-disclosure-card strong,
.quote-context-banner strong {
  color: #0f172a;
  font-size: .96rem;
}

.toggle-radio-group {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  padding: .25rem;
  border-radius: 999px;
  background: rgba(241,245,249,.92);
  border: 1px solid rgba(148, 163, 184, .22);
}

.toggle-radio-option {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 76px;
  min-height: 38px;
  padding: .4rem .78rem;
  border-radius: 999px;
  color: #475569;
  font-weight: 700;
  cursor: pointer;
  transition: background-color .18s ease, color .18s ease, box-shadow .18s ease, transform .18s ease;
}

.toggle-radio-option input {
  position: absolute;
  inset: 0;
  opacity: 0;
  pointer-events: none;
}

.toggle-radio-option.is-active {
  color: #0f172a;
  background: #fff;
  box-shadow: 0 10px 22px rgba(15, 23, 42, .10);
  transform: translateY(-1px);
}

.aqqo-collapsible {
  display: grid;
  grid-template-rows: 0fr;
  opacity: 0;
  overflow: hidden;
  transition: grid-template-rows .24s ease, opacity .2s ease;
}

.aqqo-collapsible.is-open {
  grid-template-rows: 1fr;
  opacity: 1;
}

.aqqo-collapsible__inner {
  min-height: 0;
  overflow: hidden;
}

.booking-helper-panel {
  padding: 2px;
}

.quote-context-banner {
  margin-bottom: 1rem;
}

#quoteCardWrap {
  margin-top: 1rem;
}

@media (max-width: 992px) {
  .resource-anchor-nav {
    top: 74px;
  }

  .booking-disclosure-card__head {
    align-items: flex-start;
  }
}

@media (max-width: 768px) {
  .toggle-radio-group {
    width: 100%;
    justify-content: stretch;
  }

  .toggle-radio-option {
    flex: 1 1 auto;
  }

  .resource-target-pill {
    width: 100%;
  }
}

/* =========================
   Supercharge polish: admin cockpit + split child cards + richer resource UX
   ========================= */
.admin-shell {
  grid-template-columns: 328px minmax(0, 1fr);
}

.admin-sidebar {
  padding: 24px 20px;
}

.admin-menu {
  gap: 10px;
}

.admin-menu__item {
  padding: 13px 14px;
  gap: 12px;
}

.rooms-admin-page .admin-grid {
  grid-template-columns: minmax(0, 1.18fr) minmax(360px, .82fr);
  gap: 1.35rem;
}

.rooms-admin-page .form-card__body,
.rooms-admin-page .table-card__body {
  padding: 1.5rem;
}

.resource-cockpit-card {
  border: 1px solid rgba(148, 163, 184, .2);
  border-radius: 24px;
  padding: 1.1rem 1.1rem 1.05rem;
  background: linear-gradient(180deg, rgba(255,255,255,.98), rgba(241,245,249,.94));
  box-shadow: 0 18px 40px rgba(15, 23, 42, .06);
}

.resource-cockpit__head {
  display: flex;
  flex-wrap: wrap;
  gap: .9rem;
  align-items: flex-start;
  justify-content: space-between;
  margin-bottom: .95rem;
}

.resource-cockpit__head h4 {
  margin: 0;
  font-size: 1.08rem;
  font-weight: 850;
}

.resource-cockpit-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
  gap: .8rem;
}

.resource-cockpit-item {
  border-radius: 18px;
  border: 1px solid rgba(148, 163, 184, .16);
  padding: .82rem .9rem;
  background: rgba(255,255,255,.86);
  min-width: 0;
}

.resource-cockpit-item small {
  display: block;
  color: #64748b;
  margin-bottom: .35rem;
  font-weight: 650;
}

.resource-cockpit-item strong {
  display: block;
  color: #0f172a;
  font-weight: 800;
  line-height: 1.35;
}

.structure-preset-bar {
  display: flex;
  flex-wrap: wrap;
  gap: .55rem;
  margin-top: .15rem;
}

.structure-preset-chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 40px;
  padding: .5rem .85rem;
  border-radius: 999px;
  border: 1px solid rgba(148, 163, 184, .2);
  background: rgba(248,250,252,.96);
  color: #334155;
  font-weight: 750;
  cursor: pointer;
  transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease, background-color .16s ease;
}

.structure-preset-chip:hover,
.structure-preset-chip.is-active {
  transform: translateY(-1px);
  border-color: rgba(59,130,246,.28);
  background: linear-gradient(180deg, rgba(219,234,254,.96), rgba(255,255,255,.98));
  box-shadow: 0 14px 26px rgba(37, 99, 235, .14);
  color: #0f172a;
}

.children-sync-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: .55rem;
}

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

.child-inline-card {
  border-radius: 24px;
  border: 1px solid rgba(148, 163, 184, .18);
  background: linear-gradient(180deg, rgba(255,255,255,.99), rgba(248,250,252,.94));
  box-shadow: 0 16px 36px rgba(15, 23, 42, .06);
  padding: 1rem;
}

.child-inline-card__head {
  display: flex;
  flex-wrap: wrap;
  gap: .75rem;
  align-items: flex-start;
  justify-content: space-between;
  margin-bottom: .7rem;
}

.child-inline-card__head small {
  display: block;
  color: #64748b;
  margin-bottom: .18rem;
}

.child-inline-card__head h4 {
  margin: 0;
  font-size: 1.02rem;
  font-weight: 850;
  color: #0f172a;
}

.child-inline-card__meta {
  display: flex;
  flex-wrap: wrap;
  gap: .45rem;
  margin-bottom: .55rem;
}

.meta-pill {
  display: inline-flex;
  align-items: center;
  gap: .38rem;
  padding: .38rem .62rem;
  border-radius: 999px;
  background: rgba(241,245,249,.92);
  border: 1px solid rgba(148, 163, 184, .16);
  color: #475569;
  font-size: .8rem;
  font-weight: 700;
}

.child-inline-card__toggles {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .55rem .75rem;
  padding-top: .2rem;
}

.child-inline-card__toggle {
  display: flex;
  align-items: center;
  gap: .55rem;
  min-width: 0;
  color: #334155;
  font-weight: 650;
}

.child-inline-card__toggle input {
  margin-top: 0;
}

.child-inline-card__actions {
  display: flex;
  flex-wrap: wrap;
  gap: .55rem;
  margin-top: .9rem;
}

.input-group-compact {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 96px;
  gap: .5rem;
}

.calendar-utility-bar {
  display: flex;
  flex-wrap: wrap;
  gap: .85rem 1rem;
  align-items: center;
  justify-content: space-between;
  padding: .95rem 1rem;
  border-radius: 22px;
  border: 1px solid rgba(148, 163, 184, .18);
  background: linear-gradient(180deg, rgba(255,255,255,.98), rgba(248,250,252,.92));
  box-shadow: 0 14px 32px rgba(15, 23, 42, .06);
}

.calendar-utility-group {
  display: flex;
  flex-wrap: wrap;
  gap: .6rem;
  align-items: center;
}

.calendar-utility-group > strong {
  color: #0f172a;
  font-size: .9rem;
  font-weight: 850;
}

.calendar-utility-pills {
  display: flex;
  flex-wrap: wrap;
  gap: .45rem;
}

.calendar-utility-pill,
.calendar-filter-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  padding: .45rem .8rem;
  border-radius: 999px;
  border: 1px solid rgba(148, 163, 184, .18);
  background: rgba(255,255,255,.96);
  color: #334155;
  font-weight: 750;
  cursor: pointer;
  transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease, background-color .16s ease, opacity .16s ease;
}

.calendar-utility-pill:hover,
.calendar-filter-pill:hover,
.calendar-filter-pill.is-active {
  transform: translateY(-1px);
  border-color: rgba(59,130,246,.26);
  box-shadow: 0 12px 26px rgba(37, 99, 235, .12);
}

.calendar-filter-pill:not(.is-active) {
  opacity: .58;
  background: rgba(241,245,249,.82);
}

.booking-progress-card,
.booking-duration-card {
  border: 1px solid rgba(148, 163, 184, .18);
  border-radius: 22px;
  padding: 1rem;
  background: linear-gradient(180deg, rgba(255,255,255,.99), rgba(248,250,252,.92));
  box-shadow: 0 16px 32px rgba(15, 23, 42, .06);
}

.booking-progress-steps {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: .65rem;
}

.booking-progress-step {
  display: grid;
  gap: .18rem;
  padding: .78rem .82rem;
  border-radius: 18px;
  border: 1px solid rgba(148, 163, 184, .18);
  background: rgba(255,255,255,.82);
  color: #64748b;
  min-width: 0;
}

.booking-progress-step small {
  font-size: .74rem;
  font-weight: 750;
  text-transform: uppercase;
  letter-spacing: .04em;
}

.booking-progress-step strong {
  font-size: .92rem;
  color: inherit;
  line-height: 1.35;
}

.booking-progress-step.is-current {
  border-color: rgba(59,130,246,.24);
  background: linear-gradient(180deg, rgba(239,246,255,.96), rgba(255,255,255,.96));
  color: #1d4ed8;
}

.booking-progress-step.is-complete {
  border-color: rgba(16,185,129,.22);
  background: linear-gradient(180deg, rgba(236,253,245,.96), rgba(255,255,255,.96));
  color: #047857;
}

.booking-duration-card__head {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem .85rem;
  align-items: center;
  justify-content: space-between;
}

.booking-duration-card__head h5 {
  margin: 0;
  font-size: 1rem;
  font-weight: 850;
  color: #0f172a;
}

.booking-duration-card__head p {
  margin: 0;
  color: #64748b;
}

.availability-chip--duration {
  border-color: rgba(15,118,110,.18);
  background: linear-gradient(180deg, rgba(240,253,250,.96), rgba(255,255,255,.96));
}

.availability-chip--duration.is-active {
  color: #0f172a;
  border-color: rgba(15,118,110,.28);
  box-shadow: 0 14px 26px rgba(15, 118, 110, .14);
  background: linear-gradient(180deg, rgba(204,251,241,.98), rgba(255,255,255,.98));
}

@media (max-width: 1400px) {
  .rooms-admin-page .admin-grid {
    grid-template-columns: 1fr;
  }

  .rooms-admin-page .table-card {
    position: static;
  }
}

@media (max-width: 992px) {
  .resource-cockpit-grid,
  .booking-progress-steps,
  .child-inline-card__toggles {
    grid-template-columns: 1fr 1fr;
  }

  .calendar-utility-bar,
  .booking-duration-card__head {
    align-items: flex-start;
  }
}

@media (max-width: 768px) {
  .resource-cockpit-grid,
  .booking-progress-steps,
  .child-inline-card__toggles,
  .input-group-compact,
  .child-inline-grid {
    grid-template-columns: 1fr;
  }

  .calendar-utility-bar,
  .calendar-utility-group,
  .calendar-utility-pills,
  .children-sync-toolbar,
  .child-inline-card__actions {
    width: 100%;
  }

  .calendar-utility-pill,
  .calendar-filter-pill,
  .structure-preset-chip,
  .child-inline-card__actions .btn,
  .children-sync-toolbar .btn {
    width: 100%;
    justify-content: center;
  }
}

/* =========================
   Homepage slider module + auto-filter polish
   ========================= */
.hero-card--slider {
  isolation: isolate;
  min-height: clamp(380px, 40vw, 520px);
}

.hero-card--slider .hero-card__inner {
  position: relative;
  z-index: 1;
  min-height: clamp(320px, 32vw, 430px);
}

.hero-slider__stage {
  position: absolute;
  inset: 0;
  z-index: 0;
  overflow: hidden;
  border-radius: inherit;
}

.hero-slider__image {
  position: absolute;
  inset: 0;
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  z-index: 0;
  transform: scale(1.04);
  transition: opacity .42s ease, transform 1.2s ease, visibility 0s linear .42s;
  will-change: opacity, transform;
}

.hero-slider__image.is-active {
  opacity: 1;
  visibility: visible;
  z-index: 1;
  transform: scale(1);
  transition-delay: 0s;
}

.hero-slider__veil {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(90deg, rgba(15, 23, 42, .76) 0%, rgba(15, 23, 42, .52) 40%, rgba(15, 23, 42, .34) 100%),
    radial-gradient(circle at top right, rgba(37, 99, 235, .22), transparent 36%),
    linear-gradient(135deg, rgba(15,118,110,.86), rgba(15,23,42,.94));
}

.hero-copy-slider {
  position: relative;
  display: grid;
  align-items: end;
  min-height: clamp(240px, 26vw, 320px);
}

.hero-copy-slide {
  position: absolute;
  inset: 0;
  width: min(100%, 72ch);
  opacity: 0;
  visibility: hidden;
  z-index: 0;
  transform: translateY(12px);
  pointer-events: none;
  transition: opacity .28s ease, transform .28s ease, visibility 0s linear .28s;
}

.hero-copy-slide.is-active {
  opacity: 1;
  visibility: visible;
  z-index: 2;
  transform: translateY(0);
  pointer-events: auto;
  transition-delay: 0s;
}

.hero-kicker--slider {
  margin-bottom: 1.1rem;
}

.hero-slider__dots {
  display: inline-flex;
  align-items: center;
  gap: .55rem;
  margin-top: 1rem;
}

.hero-slider__dot {
  width: 12px;
  height: 12px;
  padding: 0;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.34);
  background: rgba(255,255,255,.32);
  transition: transform .16s ease, background-color .16s ease, border-color .16s ease;
}

.hero-slider__dot.is-active {
  background: #fff;
  border-color: #fff;
  transform: scale(1.08);
}

.hero-slider__dot:hover {
  transform: translateY(-1px);
}

.availability-strip {
  grid-template-columns: 1.5fr minmax(150px, .9fr) minmax(170px, 1fr) minmax(190px, 1fr) minmax(120px, .8fr) auto;
}

.availability-field--wide {
  min-width: 0;
}

.availability-actions {
  display: inline-flex;
  align-items: center;
  gap: 10px;
}

.availability-actions .btn {
  min-width: 126px;
}

.homepage-hero-admin-grid {
  grid-template-columns: minmax(0, 1.08fr) minmax(360px, .92fr);
}

.homepage-hero-switches {
  padding: .9rem 1rem;
  border-radius: 18px;
  border: 1px solid rgba(148, 163, 184, .18);
  background: rgba(248,250,252,.88);
}

.homepage-hero-preview {
  position: relative;
  min-height: 380px;
  border-radius: 28px;
  overflow: hidden;
  background: #dbe7ff center/cover no-repeat;
  box-shadow: 0 20px 48px rgba(15, 23, 42, .12);
}

.homepage-hero-preview__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(15, 23, 42, .20), rgba(15, 23, 42, .74));
}

.homepage-hero-preview__content {
  position: absolute;
  inset: auto 1.3rem 1.3rem 1.3rem;
  z-index: 1;
  color: #fff;
}

.homepage-hero-preview__content h3 {
  font-size: clamp(1.6rem, 3vw, 2.4rem);
  font-weight: 900;
  margin: 0 0 .85rem;
}

.homepage-hero-preview__content p {
  color: rgba(255,255,255,.84);
  max-width: 70ch;
  margin: 0;
}

.homepage-hero-preview__stats {
  display: flex;
  flex-wrap: wrap;
  gap: .85rem;
  margin-top: 1.15rem;
}

.homepage-hero-preview__stats .hero-stat {
  min-width: 180px;
  max-width: 100%;
}

.homepage-hero-slide-list {
  display: grid;
  gap: 1rem;
}

.homepage-slide-card {
  display: grid;
  grid-template-columns: minmax(160px, 220px) minmax(0, 1fr);
  gap: 1rem;
  border: 1px solid rgba(148, 163, 184, .18);
  border-radius: 24px;
  padding: 1rem;
  background: linear-gradient(180deg, rgba(255,255,255,.98), rgba(248,250,252,.94));
  box-shadow: 0 14px 34px rgba(15, 23, 42, .06);
}

.homepage-slide-card.is-selected {
  border-color: rgba(59,130,246,.28);
  box-shadow: 0 18px 38px rgba(37, 99, 235, .12);
}

.homepage-slide-card__media {
  min-height: 160px;
  border-radius: 18px;
  background: #dbe7ff center/cover no-repeat;
}

.homepage-slide-card__body {
  min-width: 0;
}

.homepage-slide-card__meta {
  display: flex;
  flex-wrap: wrap;
  gap: .55rem;
  margin-bottom: .65rem;
}

.homepage-slide-card__body h4 {
  margin: 0 0 .55rem;
  font-size: 1.08rem;
  font-weight: 850;
  color: #0f172a;
}

.homepage-slide-card__body p {
  margin: 0 0 .55rem;
  color: #475569;
}

@media (max-width: 1400px) {
  .availability-strip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .availability-actions {
    grid-column: 1 / -1;
    justify-content: flex-start;
  }
}

@media (max-width: 1200px) {
  .homepage-hero-admin-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 992px) {
  .hero-card--slider {
    padding: 32px 24px;
    min-height: 420px;
  }

  .hero-card--slider .hero-card__inner {
    min-height: 340px;
  }

  .hero-copy-slider {
    min-height: 280px;
  }

  .resource-card__footer {
    align-items: flex-start;
    gap: .85rem;
  }

  .resource-sidebar {
    order: -1;
  }
}

@media (max-width: 768px) {
  .hero-card--slider {
    padding: 28px 18px;
    border-radius: 24px;
    min-height: 0;
  }

  .hero-card--slider .hero-card__inner {
    min-height: 0;
  }

  .hero-copy-slider {
    min-height: 0;
  }

  .hero-copy-slide {
    position: relative;
    inset: auto;
    width: 100%;
    display: none;
  }

  .hero-copy-slide.is-active {
    display: block;
  }

  .hero-actions {
    width: 100%;
  }

  .hero-actions .btn {
    width: 100%;
    justify-content: center;
  }

  .hero-stat-grid {
    grid-template-columns: 1fr;
  }

  .availability-strip {
    grid-template-columns: 1fr;
  }

  .availability-actions,
  .availability-actions .btn {
    width: 100%;
  }

  .availability-actions {
    flex-direction: column;
    align-items: stretch;
  }

  .resource-card__footer {
    flex-direction: column;
  }

  .resource-card__footer > div:last-child,
  .resource-card__footer .btn {
    width: 100%;
  }

  .resource-target-strip,
  .calendar-utility-pills,
  .calendar-legend {
    flex-wrap: nowrap;
    overflow-x: auto;
    padding-bottom: 4px;
    scrollbar-width: thin;
  }

  .resource-target-pill,
  .calendar-utility-pill,
  .calendar-filter-pill,
  .legend-pill {
    width: auto;
    flex: 0 0 auto;
  }

  .resource-target-pill {
    min-width: 240px;
  }

  .calendar-utility-bar {
    overflow: hidden;
  }

  .homepage-hero-preview {
    min-height: 320px;
  }

  .homepage-hero-preview__content {
    inset: auto 1rem 1rem 1rem;
  }

  .homepage-slide-card {
    grid-template-columns: 1fr;
  }

  .homepage-slide-card__media {
    min-height: 190px;
  }
}


/* =========================
   Production hardening – 2026-03-16
   ========================= */
.hero-card::after {
  z-index: 0;
  pointer-events: none;
}

.hero-card--slider {
  position: relative;
}

.hero-slider__stage,
.hero-slider__veil {
  pointer-events: none;
}

.hero-slider__controls {
  display: inline-flex;
  align-items: center;
  gap: .55rem;
  margin-top: 1rem;
}

.hero-slider__control {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.24);
  background: rgba(255,255,255,.14);
  color: #fff;
  box-shadow: 0 10px 28px rgba(15, 23, 42, .16);
  backdrop-filter: blur(10px);
  transition: transform .18s ease, background-color .18s ease, border-color .18s ease;
}

.hero-slider__control:hover:not(:disabled),
.hero-slider__control:focus-visible:not(:disabled) {
  transform: translateY(-1px);
  background: rgba(255,255,255,.22);
  border-color: rgba(255,255,255,.38);
}

.hero-slider__control:disabled {
  opacity: .45;
  cursor: default;
}

.hero-slider__dot {
  box-shadow: 0 8px 24px rgba(15, 23, 42, .16);
}

.hero-slider__image {
  backface-visibility: hidden;
}

.hero-copy-slide {
  will-change: opacity, transform;
}

.resource-layout {
  grid-template-columns: minmax(0, 1fr) minmax(360px, 420px);
  gap: clamp(1.25rem, 1.6vw, 1.75rem);
}

.resource-layout > .page-card,
.resource-sidebar .page-card {
  height: 100%;
}

.resource-layout > .page-card > .page-card__body,
.resource-sidebar .page-card__body {
  padding: 1.35rem;
}

.calendar-shell {
  overflow: hidden;
}

#calendar-card {
  overflow: hidden;
}

#calendar {
  min-height: clamp(760px, 76vh, 1040px);
}

#calendar.calendar-fallback {
  min-height: auto;
}

.calendar-fallback__card {
  min-height: 260px;
  display: grid;
  place-items: center;
  gap: .5rem;
}

.fc .fc-toolbar {
  gap: .85rem;
}

.fc .fc-toolbar-chunk {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: .6rem;
}

.fc .fc-toolbar-title {
  line-height: 1.15;
}

.fc .fc-button-group {
  flex-wrap: wrap;
}

.fc .fc-scrollgrid,
.fc .fc-theme-standard td,
.fc .fc-theme-standard th {
  border-color: rgba(148, 163, 184, .22);
}

.fc .fc-scrollgrid {
  border-radius: 18px;
  overflow: hidden;
}

.fc .fc-scroller {
  overscroll-behavior: contain;
}

.fc .fc-view-harness {
  min-height: clamp(620px, 66vh, 920px);
}

@media (max-width: 1200px) {
  .resource-layout {
    grid-template-columns: 1fr;
    grid-template-areas:
      'overview'
      'calendar'
      'sidebar';
  }
}

@media (max-width: 992px) {
  .resource-sidebar {
    order: initial;
  }

  #calendar {
    min-height: 640px;
  }
}

@media (max-width: 768px) {
  .hero-slider__controls,
  .hero-slider__dots {
    width: 100%;
    justify-content: flex-start;
  }

  .resource-layout > .page-card > .page-card__body,
  .resource-sidebar .page-card__body {
    padding: 1rem;
  }

  .calendar-shell {
    padding: .75rem;
  }

  #calendar {
    min-height: 560px;
  }

  .fc .fc-toolbar {
    flex-direction: column;
    align-items: stretch;
  }

  .fc .fc-toolbar-chunk,
  .fc .fc-button-group {
    width: 100%;
    justify-content: flex-start;
  }

  .fc .fc-button {
    min-height: 40px;
  }
}

.resource-cockpit {
  background: #fff;
  border: 1px solid rgba(15, 23, 42, 0.08);
  border-radius: 1rem;
  padding: 1rem 1.05rem;
  box-shadow: 0 14px 34px rgba(15, 23, 42, 0.06);
}

.resource-cockpit.is-highlighted {
  border-color: rgba(37, 99, 235, 0.35);
  box-shadow: 0 16px 40px rgba(37, 99, 235, 0.14);
}

.worldclass-selection-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 0.85rem;
}

.worldclass-selection-pill {
  display: flex;
  gap: 0.75rem;
  align-items: flex-start;
  padding: 0.85rem 0.95rem;
  border-radius: 0.95rem;
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: linear-gradient(180deg, rgba(255,255,255,0.98), rgba(248,250,252,0.96));
  min-height: 100%;
}

.worldclass-selection-pill input {
  margin-top: 0.2rem;
}

.worldclass-selection-pill span {
  display: grid;
  gap: 0.15rem;
}

.worldclass-selection-pill strong {
  font-size: 0.96rem;
}

.worldclass-selection-pill small {
  color: #64748b;
  line-height: 1.35;
}

.empty-state-card {
  background: linear-gradient(180deg, rgba(255,255,255,0.98), rgba(248,250,252,0.98));
  border: 1px dashed rgba(100, 116, 139, 0.35);
  border-radius: 1rem;
  padding: 1.2rem 1.1rem;
}

.empty-state-card h3 {
  font-size: 1rem;
  margin-bottom: 0.35rem;
}

.empty-state-card p {
  margin: 0;
  color: #64748b;
}

@media (max-width: 767.98px) {
  .worldclass-selection-grid {
    grid-template-columns: 1fr;
  }
}

.upcoming-class-strip {
  border-top: 1px solid rgba(15, 23, 42, 0.08);
  padding-top: 1.25rem;
}

.session-teaser-card {
  background: linear-gradient(180deg, rgba(248, 250, 252, 0.92), rgba(255, 255, 255, 0.98));
  border: 1px solid rgba(15, 23, 42, 0.08);
  border-radius: 1rem;
  padding: 1rem 1.05rem;
}

.session-teaser-card__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem 1rem;
  color: #64748b;
  font-size: 0.92rem;
}

.session-teaser-card__meta span {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
}

.session-teaser-card h4 {
  margin: 0;
  font-size: 1rem;
}

.session-teaser-card p {
  margin: 0.35rem 0 0;
  color: #64748b;
  line-height: 1.5;
}

/* Worldclass classes / trainers polish */
.public-class-feature__grid {
  display: grid;
  grid-template-columns: minmax(0, 1.6fr) minmax(260px, 0.9fr);
  gap: 1.25rem;
}

.public-class-feature__image,
.public-class-feature__placeholder {
  min-height: 240px;
  border-radius: 1.25rem;
  border: 1px solid rgba(15, 23, 42, 0.08);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

.public-class-feature__placeholder {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
  background: linear-gradient(135deg, rgba(37, 99, 235, 0.08), rgba(20, 184, 166, 0.1));
  color: #0f172a;
  font-weight: 700;
}

.public-class-feature__placeholder i {
  font-size: 2rem;
}

.public-class-help {
  padding-left: 1.15rem;
}

.public-class-help li + li {
  margin-top: 0.55rem;
}

.public-classes-page .resource-cockpit.is-highlighted,
.class-manage-page .resource-cockpit.is-highlighted,
.classes-page .resource-cockpit.is-highlighted {
  border-color: rgba(37, 99, 235, 0.28);
  box-shadow: 0 14px 34px rgba(15, 23, 42, 0.08);
}

.trainers-page #trainer-hours .form-control[type="time"],
.trainers-page #trainer-exceptions .form-control[type="time"] {
  min-width: 8rem;
}

.trainers-page .table td,
.trainers-page .table th {
  vertical-align: middle;
}

@media (max-width: 991.98px) {
  .public-class-feature__grid {
    grid-template-columns: 1fr;
  }

  .public-class-feature__image,
  .public-class-feature__placeholder {
    min-height: 200px;
  }
}

@media (max-width: 575.98px) {
  .public-class-feature__image,
  .public-class-feature__placeholder {
    min-height: 180px;
  }

  .public-classes-page .booking-card__head,
  .public-classes-page .booking-card__meta,
  .class-manage-page .booking-card__head,
  .class-manage-page .booking-card__meta {
    gap: 0.5rem;
  }
}

.booking-card__actions {
  justify-content: space-between;
}

.class-qr-panel {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 0.85rem;
  align-items: center;
  padding: 0.85rem 1rem;
  border-radius: 1rem;
  background: rgba(15, 23, 42, 0.04);
  border: 1px solid rgba(15, 23, 42, 0.08);
  min-width: min(100%, 20rem);
}

.class-qr-panel__code {
  width: 108px;
  min-width: 108px;
  min-height: 108px;
  padding: 0.3rem;
  border-radius: 0.85rem;
  background: #fff;
  border: 1px solid rgba(15, 23, 42, 0.08);
}

.class-qr-panel__code img,
.class-qr-panel__code canvas {
  display: block;
  width: 100% !important;
  height: auto !important;
}

.trainer-dashboard-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

.kiosk-shell {
  padding-block: 1.5rem 2.5rem;
}

.kiosk-header-card,
.kiosk-panel {
  border-radius: 1.4rem;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(248, 250, 252, 0.98));
  border: 1px solid rgba(148, 163, 184, 0.22);
  box-shadow: 0 18px 42px rgba(15, 23, 42, 0.08);
}

.kiosk-header-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 15rem;
  gap: 1rem;
  padding: 1.25rem 1.35rem;
  align-items: start;
}

.kiosk-header-card h1 {
  margin: 0;
  font-size: clamp(1.45rem, 2vw, 2.1rem);
}

.kiosk-date-form {
  padding: 1rem;
  border-radius: 1.15rem;
  background: rgba(15, 23, 42, 0.04);
  border: 1px solid rgba(15, 23, 42, 0.06);
}

.kiosk-grid {
  display: grid;
  grid-template-columns: minmax(18rem, 25rem) minmax(0, 1fr);
  gap: 1.2rem;
  align-items: start;
}

.kiosk-session-list,
.kiosk-selected-panel {
  min-width: 0;
}

.kiosk-session-card {
  display: block;
  padding: 1rem;
  border-radius: 1.1rem;
  border: 1px solid rgba(148, 163, 184, 0.24);
  background: #fff;
  color: inherit;
  text-decoration: none;
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.04);
  transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}

.kiosk-session-card:hover {
  transform: translateY(-1px);
  box-shadow: 0 14px 28px rgba(15, 23, 42, 0.08);
}

.kiosk-session-card.is-active {
  border-color: rgba(37, 99, 235, 0.34);
  box-shadow: 0 16px 32px rgba(37, 99, 235, 0.12);
}

.kiosk-selected-panel {
  min-width: 0;
}

.kiosk-panel {
  padding: 1.25rem 1.35rem;
}

.kiosk-subgrid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

.kiosk-scanner {
  margin-top: 1rem;
  padding-top: 1rem;
  border-top: 1px dashed rgba(148, 163, 184, 0.4);
}

#kioskQrScannerRegion {
  min-height: 240px;
  overflow: hidden;
  border-radius: 1rem;
  background: rgba(15, 23, 42, 0.04);
}

#kioskQrScannerRegion video {
  border-radius: 1rem;
}

.kiosk-panel .resource-cockpit {
  border-radius: 1rem;
}

.kiosk-admin-page .resource-cockpit .text-break {
  overflow-wrap: anywhere;
}

@media (max-width: 1199.98px) {
  .kiosk-grid {
    grid-template-columns: 1fr;
  }

  .kiosk-header-card {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 991.98px) {
  .trainer-dashboard-grid,
  .kiosk-subgrid {
    grid-template-columns: 1fr;
  }

  .class-qr-panel {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 575.98px) {
  .kiosk-panel,
  .kiosk-header-card {
    padding: 1rem;
  }

  .class-qr-panel__code {
    width: 96px;
    min-width: 96px;
    min-height: 96px;
  }
}


/* =========================
   2026-03-19 mobile funnel + admin cleanup
   ========================= */
.availability-preset-strip {
  display: flex;
  flex-wrap: wrap;
  gap: .65rem;
}

.availability-preset-chip {
  border: 1px solid rgba(37, 99, 235, .14);
  background: rgba(248, 250, 252, .96);
  color: #0f172a;
  border-radius: 999px;
  padding: .55rem .9rem;
  font-weight: 700;
  box-shadow: var(--aqqo-shadow-soft);
}

.availability-preset-chip:hover,
.availability-preset-chip:focus-visible {
  transform: translateY(-1px);
  box-shadow: var(--aqqo-shadow);
}

.availability-active-filters {
  display: flex;
  flex-wrap: wrap;
  gap: .55rem;
}

.public-funnel-note {
  display: flex;
  flex-wrap: wrap;
  gap: .55rem;
}

.booking-optional-details {
  border: 1px solid rgba(148, 163, 184, .18);
  border-radius: 20px;
  background: linear-gradient(180deg, rgba(255,255,255,.98), rgba(248,250,252,.92));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.66);
}

.booking-optional-details summary {
  list-style: none;
  cursor: pointer;
  padding: .9rem 1rem;
  font-weight: 800;
  color: #0f172a;
}

.booking-optional-details summary::-webkit-details-marker {
  display: none;
}

.booking-optional-details summary::after {
  content: '\f107';
  font-family: 'Font Awesome 6 Free';
  font-weight: 900;
  float: right;
  color: #64748b;
  transition: transform .18s ease;
}

.booking-optional-details[open] summary::after {
  transform: rotate(180deg);
}

.booking-optional-details__body {
  padding: 0 1rem 1rem;
}

.public-mobile-bookbar {
  position: fixed;
  left: 12px;
  right: 12px;
  bottom: max(12px, env(safe-area-inset-bottom));
  z-index: 1050;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .9rem;
  padding: .8rem .9rem;
  border-radius: 20px;
  background: rgba(15, 23, 42, .92);
  color: #fff;
  box-shadow: 0 18px 44px rgba(15, 23, 42, .32);
  backdrop-filter: blur(12px);
}

.public-mobile-bookbar__summary {
  min-width: 0;
}

.public-mobile-bookbar__summary small {
  display: block;
  color: rgba(255,255,255,.72);
}

.public-mobile-bookbar__summary strong {
  display: block;
  font-size: .95rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.public-mobile-bookbar__button {
  flex: 0 0 auto;
  white-space: nowrap;
}

.public-mobile-bookbar.has-selection {
  background: rgba(37, 99, 235, .95);
}

@media (min-width: 769px) {
  .public-mobile-bookbar {
    display: none;
  }
}

.widget-summary-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .75rem;
}

.widget-summary-card {
  border: 1px solid rgba(148, 163, 184, .18);
  border-radius: 18px;
  padding: .85rem .95rem;
  background: linear-gradient(180deg, rgba(255,255,255,.98), rgba(248,250,252,.92));
}

.widget-summary-card small {
  display: block;
  color: #64748b;
  margin-bottom: .2rem;
}

.widget-summary-card strong {
  color: #0f172a;
}

.widget-steps {
  display: flex;
  flex-wrap: wrap;
  gap: .55rem;
}

.admin-quicknav {
  display: flex;
  flex-wrap: nowrap;
  gap: .6rem;
  overflow-x: auto;
  padding: .35rem 0 1rem;
  margin-bottom: .35rem;
  scrollbar-width: thin;
}

.admin-quicknav__item {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  padding: .7rem .95rem;
  border-radius: 999px;
  background: rgba(255,255,255,.88);
  border: 1px solid rgba(148, 163, 184, .2);
  color: #334155;
  text-decoration: none;
  font-weight: 700;
  white-space: nowrap;
  box-shadow: var(--aqqo-shadow-soft);
}

.admin-quicknav__item.is-active {
  background: rgba(37, 99, 235, .1);
  border-color: rgba(37, 99, 235, .2);
  color: #1d4ed8;
}

@media (max-width: 992px) {
  .table-mobile-cards thead {
    display: none;
  }

  .table-mobile-cards,
  .table-mobile-cards tbody,
  .table-mobile-cards tr,
  .table-mobile-cards td {
    display: block;
    width: 100%;
  }

  .table-mobile-cards tbody {
    display: grid;
    gap: .9rem;
  }

  .table-mobile-cards tr {
    border: 1px solid rgba(148, 163, 184, .18);
    border-radius: 20px;
    background: rgba(255,255,255,.96);
    padding: .8rem .95rem;
    box-shadow: var(--aqqo-shadow-soft);
  }

  .table-mobile-cards td {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: .85rem;
    padding: .45rem 0;
    border: 0;
    text-align: left !important;
  }

  .table-mobile-cards td::before {
    content: attr(data-label);
    flex: 0 0 42%;
    max-width: 42%;
    color: #64748b;
    font-weight: 800;
  }

  .table-mobile-cards td.table-mobile-actions {
    display: block;
    padding-top: .8rem;
    margin-top: .35rem;
    border-top: 1px solid rgba(226, 232, 240, .9);
  }

  .table-mobile-cards td.table-mobile-actions::before {
    display: block;
    margin-bottom: .45rem;
  }

  .table-mobile-cards td.table-mobile-actions > * {
    width: 100%;
  }

  .table-mobile-cards td.table-mobile-actions .btn,
  .table-mobile-cards td.table-mobile-actions form {
    width: 100%;
  }

  .widget-summary-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 768px) {
  body.resource-page {
    padding-bottom: calc(96px + env(safe-area-inset-bottom));
  }

  .availability-preset-strip,
  .availability-active-filters,
  .widget-steps,
  .public-funnel-note {
    flex-wrap: nowrap;
    overflow-x: auto;
    padding-bottom: 4px;
    scrollbar-width: thin;
  }

  .availability-preset-chip,
  .public-funnel-note .meta-pill,
  .widget-steps .meta-pill {
    flex: 0 0 auto;
  }
}


@media (max-width: 768px) {
  .booking-followup-actions {
    flex-direction: column;
    align-items: stretch;
  }
  .booking-followup-actions > a,
  .booking-followup-actions > .btn,
  .booking-followup-actions > form,
  .booking-followup-actions > form .btn {
    width: 100%;
  }
  .ops-section-head {
    align-items: flex-start !important;
  }
  .ops-secondary-panel summary {
    flex-direction: column;
  }
}

/* payment timeline / observability */
.timeline-list {
  display: grid;
  gap: 14px;
}

.timeline-list--compact {
  gap: 12px;
}

.timeline-entry {
  border: 1px solid var(--aqqo-line);
  border-radius: 20px;
  background: #fff;
  padding: 16px 18px;
  box-shadow: 0 10px 28px rgba(15, 23, 42, 0.04);
}

.timeline-entry--full {
  padding: 18px 20px;
}

.timeline-entry__meta {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
  margin-bottom: 10px;
}

.timeline-entry__meta small {
  color: var(--aqqo-muted);
  font-weight: 600;
}

.timeline-entry__title {
  margin: 0;
  font-size: 1.04rem;
  font-weight: 800;
}

.timeline-entry__subtext {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 12px;
  margin-top: 8px;
  color: var(--aqqo-muted);
  font-size: .92rem;
}

.timeline-entry__details {
  border-top: 1px dashed rgba(148,163,184,.35);
  padding-top: 12px;
}

.timeline-entry__details summary {
  cursor: pointer;
  font-weight: 700;
}

.timeline-entry__details pre {
  margin: 12px 0 0;
  padding: 14px 16px;
  border-radius: 16px;
  background: #0f172a;
  color: #e2e8f0;
  overflow: auto;
  font-size: .85rem;
  line-height: 1.45;
}

@media (max-width: 768px) {
  .timeline-entry__meta {
    flex-direction: column;
  }
}
