:root {
      --bg: #f6f8fb;
      --panel: #ffffff;
      --text: #1f2937;
      --muted: #6b7280;
      --line: #e5e7eb;
      --blue: #2563eb;
      --blue-dark: #1d4ed8;
      --green: #2fa66a;
      --yellow: #facc15;
      --red: #dc2626;
      --orange: #f97316;
      --purple: #8b5cf6;
      --purple-bg: #ede9fe;
      --purple-border: #c4b5fd;
      --shadow: 0 10px 30px rgba(15, 23, 42, 0.08);
      --radius: 18px;
      --cell-height: 64px;
      --calendar-bg: #ffffff;
      --calendar-cell: #ffffff;
      --calendar-header: rgba(248,250,252,.928);
      --calendar-time: rgba(248,250,252,.928);
      --calendar-hover: #fffbeb;
    }


    @media (hover: none), (pointer: coarse) {
      html,
      body,
      #root,
      .app-shell,
      .calendar,
      .calendar-scroll,
      .calendar-grid,
      .room-cell,
      .booking {
        touch-action: pan-y;
      }

      button,
      a,
      input,
      select,
      textarea,
      [role="button"],
      [data-action],
      .tab,
      .nav-item,
      .booking {
        touch-action: manipulation;
      }
    }

    html.touch-zoom-disabled,
    html.touch-zoom-disabled body {
      -webkit-text-size-adjust: 100%;
    }

    body.dark-theme {
      --bg: #111827;
      --panel: #1f2937;
      --text: #f3f4f6;
      --muted: #9ca3af;
      --line: #374151;
      --blue: #60a5fa;
      --blue-dark: #3b82f6;
      --green: #5ee0a0;
      --yellow: #eab308;
      --red: #f87171;
      --orange: #fb923c;
      --purple: #c4b5fd;
      --purple-bg: rgba(167, 139, 250, .16);
      --purple-border: rgba(167, 139, 250, .32);
      --shadow: 0 14px 34px rgba(0, 0, 0, 0.38);
      --calendar-bg: #111827;
      --calendar-cell: #182235;
      --calendar-header: rgba(21, 31, 49, .91);
      --calendar-time: rgba(21, 31, 49, .91);
      --calendar-hover: #202d44;
    }

    * { box-sizing: border-box; }

    html {
      width: 100%;
      min-height: 100%;
      overflow-x: hidden;
      -webkit-text-size-adjust: 100%;
    }

    body {
      margin: 0;
      min-height: 100dvh;
      font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
      background: var(--bg);
      color: var(--text);
      overflow: hidden;
      overscroll-behavior: none;
    }

    button, input, select, textarea { font: inherit; }

    button, input, select, textarea, .nav button, .booking, .room-cell {
      -webkit-tap-highlight-color: transparent;
    }

    button, input, select, textarea {
      min-height: 44px;
    }

    button {
      border: 0;
      border-radius: 999px;
      padding: 10px 16px;
      cursor: pointer;
      background: var(--blue);
      color: white;
      font-weight: 700;
    }

    button:hover { background: var(--blue-dark); }
    button.secondary { background: #eef2ff; color: #1e40af; border: 2px solid transparent; }
    button.secondary:hover { background: #dbeafe; }

    body.dark-theme button.secondary {
      background: #273449;
      color: #dbeafe;
      border-color: transparent;
    }

    body.dark-theme button.secondary:hover { background: #314158; }
    button.danger { background: var(--red); }
    button.small { padding: 7px 11px; font-size: 13px; }
    button.today-active {
      background: transparent;
      color: var(--blue);
      border-color: var(--blue);
      box-shadow: 0 0 0 3px rgba(37,99,235,.12);
    }
    button.today-active:hover {
      background: #eef2ff;
      color: var(--blue-dark);
      border-color: var(--blue-dark);
    }

    body.dark-theme button.today-active {
      background: transparent;
      color: #dbeafe;
      border-color: var(--blue);
      box-shadow: 0 0 0 3px rgba(96,165,250,.16);
    }

    body.dark-theme button.today-active:hover {
      background: rgba(96,165,250,.14);
      color: #ffffff;
    }
    button.icon-button {
      width: 42px;
      height: 42px;
      padding: 0;
      display: inline-grid;
      place-items: center;
      font-size: 20px;
      line-height: 1;
    }
    button:disabled { opacity: .5; cursor: not-allowed; }

    input, select, textarea {
      width: 100%;
      border: 1px solid var(--line);
      border-radius: 12px;
      padding: 10px 12px;
      background: var(--panel);
      color: var(--text);
      color-scheme: light;
    }

    textarea {
      min-height: 92px;
      resize: vertical;
      line-height: 1.45;
    }

    textarea.compact-textarea {
      min-height: 42px;
      height: 42px;
    }

    input::placeholder,
    textarea::placeholder {
      color: var(--muted);
      opacity: .54;
      font-style: italic;
      font-weight: 500;
    }

    .required-marker {
      color: var(--red);
      font-weight: 950;
      margin-left: 2px;
    }

    .required-field {
      border-color: color-mix(in srgb, var(--line) 72%, var(--red));
    }

    .required-field:focus {
      outline: 0;
      border-color: var(--blue);
      box-shadow: 0 0 0 3px rgba(37,99,235,.12);
    }

    .note-field { grid-column: 1 / -1; }

    .booking-note-line {
      margin-top: 3px;
      font-size: 11px;
      font-weight: 800;
      line-height: 1.25;
      opacity: .86;
      display: -webkit-box;
      -webkit-line-clamp: 2;
      -webkit-box-orient: vertical;
      overflow: hidden;
    }

    .booking-note-line::before { content: "Note: "; opacity: .72; }

    .booking-note-preview {
      font-size: 12px;
      color: var(--muted);
      line-height: 1.35;
      display: -webkit-box;
      -webkit-line-clamp: 2;
      -webkit-box-orient: vertical;
      overflow: hidden;
    }

    .booking-note-card {
      box-shadow: none;
      background: var(--bg);
      padding: 13px;
      gap: 7px;
    }

    .booking-note-label {
      font-size: 12px;
      font-weight: 950;
      text-transform: uppercase;
      letter-spacing: .06em;
      color: var(--muted);
    }

    .booking-note-text {
      white-space: pre-wrap;
      line-height: 1.45;
      font-weight: 750;
    }

    input:disabled,
    select:disabled,
    input[readonly].locked-field {
      background: #f3f4f6;
      color: var(--muted);
      border-color: #e5e7eb;
      cursor: not-allowed;
      opacity: .85;
    }

    body.dark-theme input:disabled,
    body.dark-theme select:disabled,
    body.dark-theme input[readonly].locked-field {
      background: #182235;
      color: #7f8da3;
      border-color: #2b374c;
    }

    select {
      appearance: none;
      -webkit-appearance: none;
      padding-right: 34px;
      background-image: linear-gradient(45deg, transparent 50%, var(--muted) 50%), linear-gradient(135deg, var(--muted) 50%, transparent 50%);
      background-position: calc(100% - 21px) 50%, calc(100% - 16px) 50%;
      background-size: 5px 5px, 5px 5px;
      background-repeat: no-repeat;
    }

    .booking-rule-boolean-select {
      min-width: 76px;
      width: 100%;
      padding-left: 12px;
      padding-right: 32px;
      text-align: left;
    }

    .admin-booking-rules-table th:nth-child(2),
    .admin-booking-rules-table td:nth-child(2) {
      min-width: 132px;
    }

    .admin-booking-rules-table th:nth-child(3),
    .admin-booking-rules-table td:nth-child(3),
    .admin-booking-rules-table th:nth-child(4),
    .admin-booking-rules-table td:nth-child(4) {
      min-width: 150px;
    }

    .rule-unit-field {
      position: relative;
      display: block;
      width: 100%;
    }

    .rule-unit-field input {
      min-width: 132px;
      padding-right: 58px;
    }

    .rule-unit-field input:placeholder-shown {
      padding-right: 26px;
    }

    .rule-unit-field input[type="number"]::-webkit-outer-spin-button,
    .rule-unit-field input[type="number"]::-webkit-inner-spin-button {
      margin-left: 12px;
      margin-right: -10px;
    }

    .rule-unit-field .rule-unit-suffix {
      position: absolute;
      right: 12px;
      top: 50%;
      transform: translateY(-50%);
      color: var(--muted);
      font-size: 13px;
      font-weight: 800;
      pointer-events: none;
      white-space: nowrap;
    }

    .rule-unit-field input:placeholder-shown + .rule-unit-suffix {
      display: none;
    }

    .rule-unit-field.rule-unit-field-wide input {
      padding-right: 78px;
    }

    .rule-unit-field.rule-unit-field-wide input:placeholder-shown {
      padding-right: 26px;
    }

    .booking-rule-disabled-cell {
      opacity: .58;
    }

    .booking-rule-disabled-cell input,
    .rule-unit-field.rule-field-disabled input {
      background: #f3f4f6 !important;
      color: var(--muted) !important;
      border-color: #e5e7eb !important;
      cursor: not-allowed !important;
    }

    body.dark-theme .booking-rule-disabled-cell input,
    body.dark-theme .rule-unit-field.rule-field-disabled input {
      background: #182235 !important;
      color: #7f8da3 !important;
      border-color: #2b374c !important;
    }

    .rule-unit-field.rule-field-disabled .rule-unit-suffix {
      color: var(--muted);
      opacity: .7;
    }

    .member-rule-dependent-field.member-rule-field-disabled {
      opacity: .58;
    }

    .member-rule-dependent-field.member-rule-field-disabled input,
    .member-rule-dependent-field.member-rule-field-disabled select {
      background: #f3f4f6 !important;
      color: var(--muted) !important;
      border-color: #e5e7eb !important;
      cursor: not-allowed !important;
    }

    body.dark-theme .member-rule-dependent-field.member-rule-field-disabled input,
    body.dark-theme .member-rule-dependent-field.member-rule-field-disabled select {
      background: #182235 !important;
      color: #7f8da3 !important;
      border-color: #2b374c !important;
    }

    .member-rule-field-row {
      align-items: end;
    }

    .member-rule-field-row select {
      min-width: 0;
    }


    .member-rule-effective-card {
      border: 1px solid var(--line);
      border-radius: 14px;
      background: rgba(249,250,251,.74);
      padding: 10px 12px;
      display: grid;
      gap: 8px;
    }

    body.dark-theme .member-rule-effective-card {
      background: rgba(24,34,53,.72);
    }

    .member-rule-effective-card.is-preview {
      border-color: rgba(37,99,235,.32);
      background: rgba(37,99,235,.06);
    }

    body.dark-theme .member-rule-effective-card.is-preview {
      background: rgba(59,130,246,.10);
      border-color: rgba(96,165,250,.32);
    }

    .member-rule-effective-heading {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 8px;
      min-width: 0;
    }

    #member-rule-effective-title {
      color: var(--text);
      font-size: 13px;
      line-height: 1.2;
      font-weight: 850;
    }

    .member-rule-effective-summary {
      display: flex;
      flex-wrap: wrap;
      align-items: center;
      gap: 6px;
      min-width: 0;
    }

    .member-rule-chip {
      display: inline-flex;
      align-items: baseline;
      gap: 4px;
      max-width: 100%;
      padding: 4px 8px;
      border: 1px solid var(--line);
      border-radius: 999px;
      background: var(--bg);
      color: var(--text);
      font-size: 12px;
      line-height: 1.2;
      font-weight: 800;
      white-space: nowrap;
    }

    body.dark-theme .member-rule-chip {
      background: rgba(15,23,42,.84);
    }

    .member-rule-chip-label {
      color: var(--muted);
      font-weight: 750;
    }

    .member-rule-chip-value {
      color: var(--text);
      font-weight: 800;
    }

    .member-rule-chip-negative {
      color: var(--text);
    }

    .member-role-change-note {
      margin-top: 6px;
      color: var(--muted);
      font-size: 12px;
      line-height: 1.25;
      font-weight: 750;
    }

    .member-role-change-note strong {
      color: var(--text);
      font-weight: 850;
    }


    body.dark-theme input,
    body.dark-theme select,
    body.dark-theme textarea { color-scheme: dark; }

    .custom-date-field {
      position: relative;
      width: 178px;
    }

    .custom-date-field.weekday-date-field {
      width: 100%;
      min-width: 250px;
    }

    .custom-date-field input[type="text"] {
      width: 100%;
      padding-right: 42px;
    }

    .native-date-picker {
      position: absolute;
      inset: 0;
      width: 100%;
      height: 100%;
      opacity: 0;
      pointer-events: none;
    }

    .date-picker-button {
      position: absolute;
      right: 6px;
      top: 50%;
      transform: translateY(-50%);
      width: 30px;
      height: 30px;
      padding: 0;
      display: inline-grid;
      place-items: center;
      border-radius: 9px;
      font-size: 0;
      background: transparent;
      color: var(--muted);
    }

    .date-picker-button::before {
      content: "";
      width: 17px;
      height: 17px;
      background: currentColor;
      -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='4' width='18' height='18' rx='2' ry='2'/%3E%3Cline x1='16' y1='2' x2='16' y2='6'/%3E%3Cline x1='8' y1='2' x2='8' y2='6'/%3E%3Cline x1='3' y1='10' x2='21' y2='10'/%3E%3C/svg%3E") center / contain no-repeat;
      mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='4' width='18' height='18' rx='2' ry='2'/%3E%3Cline x1='16' y1='2' x2='16' y2='6'/%3E%3Cline x1='8' y1='2' x2='8' y2='6'/%3E%3Cline x1='3' y1='10' x2='21' y2='10'/%3E%3C/svg%3E") center / contain no-repeat;
    }

    .date-picker-button:hover {
      background: rgba(37, 99, 235, .10);
    }

    .date-popover {
      position: fixed;
      top: var(--date-popover-top, 0px);
      left: var(--date-popover-left, 0px);
      right: auto;
      width: 280px;
      background: var(--panel);
      border: 1px solid var(--line);
      border-radius: 16px;
      box-shadow: 0 18px 48px rgba(15, 23, 42, .22);
      padding: 12px;
      z-index: 2000;
      display: none;
    }

    .date-popover.open { display: grid; gap:10px; margin-top:0; }

    .date-popover-head {
      display: flex;
      justify-content: space-between;
      align-items: center;
      gap: 8px;
      font-weight: 900;
    }

    .date-popover-head button {
      width: 34px;
      height: 34px;
      padding: 0;
      display: inline-grid;
      place-items: center;
    }

    .date-grid {
      display: grid;
      grid-template-columns: repeat(7, 1fr);
      gap: 4px;
    }

    .date-grid-label,
    .date-day {
      height: 32px;
      display: grid;
      place-items: center;
      border-radius: 10px;
      font-size: 12px;
      font-weight: 800;
    }

    .date-grid-label {
      color: var(--muted);
      font-size: 11px;
    }

    .date-day {
      background: transparent;
      color: var(--text);
      padding: 0;
    }

    .date-day:hover {
      background: #eef2ff;
      color: #1d4ed8;
    }

    .date-day.selected {
      background: var(--blue);
      color: #fff;
    }

    .date-day.today {
      box-shadow: inset 0 0 0 2px var(--blue);
      font-weight: 950;
    }

    .date-day.today.selected {
      box-shadow: inset 0 0 0 2px rgba(255,255,255,.75);
    }

    .date-popover-footer {
      display: flex;
      justify-content: center;
      padding-top: 2px;
    }

    .date-day.muted-day {
      opacity: .35;
    }

    .date-day.disabled-day,
    .date-day.disabled-day:hover {
      background: transparent;
      color: var(--muted);
      cursor: not-allowed;
      opacity: .35;
    }

    body.dark-theme .date-day:hover {
      background: rgba(96,165,250,.16);
      color: #dbeafe;
    }

    body.dark-theme .date-picker-button {
      color: #ffffff;
    }

    body.dark-theme .date-picker-button:hover {
      background: rgba(255,255,255,.10);
    }

    label {
      display: grid;
      gap: 6px;
      font-size: 13px;
      font-weight: 700;
      color: var(--text);
    }

    .field-label-row {
      display: flex;
      align-items: center;
      justify-content: flex-start;
      gap: 6px;
      min-width: 0;
    }

    .field-label-row .status-chip,
    .field-label-row .status-with-closure {
      flex: 0 0 auto;
      margin-left: 0;
    }

    .app-shell {
      height: 100dvh;
      display: grid;
      grid-template-columns: 280px 1fr;
      overflow: hidden;
    }

    aside {
      background: var(--panel);
      border-right: 1px solid var(--line);
      padding: 22px;
      display: flex;
      flex-direction: column;
      gap: 16px;
      height: 100dvh;
      overflow: hidden;
    }

    main {
      padding: 22px;
      overflow: auto;
      height: 100dvh;
      overscroll-behavior: contain;
    }

    main.admin-main {
      padding-top: 0;
    }

    main.my-main {
      display: flex;
      flex-direction: column;
      overflow: hidden;
      min-height: 100dvh;
    }

    main.my-main > .toolbar {
      flex: 0 0 auto;
      margin-bottom: 14px;
    }

    .my-bookings-section {
      flex: 1 1 auto;
      min-height: 0;
      display: flex;
      flex-direction: column;
      overflow: hidden;
    }

    .my-bookings-section .section-header {
      position: relative;
      top: auto;
      flex: 0 0 auto;
    }

    .my-bookings-section .my-section-header {
      display: grid;
      align-items: stretch;
      gap: 14px;
    }

    .my-section-top {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 14px;
      min-width: 0;
    }

    .my-filter-actions {
      margin-left: auto;
    }

    .my-bookings-head-table,
    .my-bookings-table {
      table-layout: fixed;
    }

    .my-bookings-head-table {
      box-shadow: none;
      background: transparent;
      border-radius: 0;
      overflow: visible;
    }

    .my-bookings-head-table th {
      background: rgba(249,250,251,.54);
      border-bottom: 0;
    }

    body.dark-theme .my-bookings-head-table th {
      background: rgba(21, 31, 49, .54);
    }

    .my-bookings-section .section-content {
      padding-top: 0;
      flex: 1 1 auto;
      min-height: 0;
      overflow: auto;
      overscroll-behavior: contain;
    }

    .my-bookings-section .section-content table {
      border-radius: 0 0 16px 16px;
    }

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

    .brand {
      display: flex;
      align-items: center;
      gap: 12px;
      font-size: 20px;
      font-weight: 900;
      letter-spacing: -.01em;
      min-width: 0;
    }

    .brand-theme-button {
      width: 40px;
      height: 40px;
      min-width: 40px;
      min-height: 40px;
      max-width: 40px;
      max-height: 40px;
      aspect-ratio: 1 / 1;
      padding: 0;
      flex: 0 0 40px;
      display: inline-grid;
      place-items: center;
      font-size: 17px;
      line-height: 1;
      border-radius: 50%;
      overflow: hidden;
    }

    .brand-mark {
      width: 40px;
      height: 40px;
      border-radius: 13px;
      display: grid;
      place-items: center;
      background: linear-gradient(135deg, #1d4ed8, #2563eb);
      color: #fff;
      font-size: 13px;
      box-shadow: 0 6px 18px rgba(37, 99, 235, .22);
      overflow: hidden;
      flex: 0 0 40px;
    }

    .brand-mark.logo-mark {
      background: #fff7ed;
    }

    .brand-mark.logo-mark img {
      width: 100%;
      height: 100%;
      display: block;
      object-fit: cover;
      object-position: center;
      padding: 0;
      border-radius: inherit;
    }

    .brand-title { display: grid; gap: 2px; line-height: 1.05; }

    .brand-subtitle {
      font-size: 12px;
      font-weight: 800;
      color: var(--muted);
      letter-spacing: 0;
    }

    .card {
      background: var(--panel);
      border: 1px solid var(--line);
      border-radius: var(--radius);
      box-shadow: var(--shadow);
      padding: 18px;
    }

    .login-wrap {
      min-height: 100dvh;
      display: grid;
      place-items: center;
      padding: 20px;
    }

    .login-card {
      width: min(557px, 100%);
      display: grid;
      gap: 20px;
      padding: 22px;
    }

    .remember-row {
      display: inline-flex;
      align-items: center;
      gap: 10px;
      width: fit-content;
      max-width: 100%;
      color: var(--text);
      font-weight: 700;
      line-height: 1.2;
      cursor: pointer;
      user-select: none;
      -webkit-user-select: none;
    }

    .remember-row input {
      width: 18px;
      height: 18px;
      min-height: 18px;
      accent-color: var(--blue);
      flex: 0 0 auto;
    }

    .remember-row span {
      font-size: 14px;
    }

    .stack { display: grid; gap: 14px; }
    #member-rule-override-fields[hidden] { display: none !important; }
    .row { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; }
    .space-between { justify-content: space-between; }
    .muted { color: var(--muted); }
    .error { color: var(--red); font-weight: 700; }
    .success { color: var(--green); font-weight: 700; }

    .password-requirements {
      border: 1px solid var(--line);
      border-radius: 12px;
      padding: 10px 12px;
      background: rgba(15, 23, 42, 0.025);
      color: var(--muted);
      font-size: 13px;
      line-height: 1.35;
    }

    body.dark-theme .password-requirements {
      background: rgba(255, 255, 255, 0.035);
    }

    .password-requirements-title {
      color: var(--text);
      font-weight: 800;
      margin-bottom: 4px;
    }

    .password-requirements-help {
      margin-bottom: 8px;
    }

    .password-requirements ul {
      display: grid;
      gap: 4px;
      margin: 0;
      padding-left: 0;
      list-style: none;
    }

    .password-requirements li {
      display: flex;
      justify-content: space-between;
      align-items: center;
      gap: 10px;
      border-radius: 9px;
      padding: 4px 6px;
      background: rgba(148, 163, 184, 0.10);
    }

    .password-requirement-label {
      min-width: 0;
    }

    .password-requirement-state {
      flex: 0 0 auto;
      border-radius: 999px;
      padding: 2px 7px;
      background: rgba(148, 163, 184, 0.15);
      color: var(--muted);
      font-size: 11px;
      font-weight: 900;
      text-transform: uppercase;
      letter-spacing: .03em;
    }

    .password-requirements li.is-ok {
      color: var(--green);
      font-weight: 700;
    }

    .password-requirements li.is-ok .password-requirement-state {
      background: rgba(34, 197, 94, 0.14);
      color: var(--green);
    }

    .password-requirements li.is-missing {
      color: var(--red);
      font-weight: 800;
    }

    .password-requirements li.is-missing .password-requirement-state {
      background: rgba(239, 68, 68, 0.13);
      color: var(--red);
    }

    .password-requirements-feedback {
      margin-top: 8px;
      font-weight: 800;
    }

    .password-requirements-feedback.is-neutral {
      color: var(--muted);
      font-weight: 700;
    }

    .password-requirements-feedback.is-ok {
      color: var(--green);
    }

    .password-requirements-feedback.is-missing {
      color: var(--red);
    }

    .user-card {
      display: grid;
      gap: 12px;
      box-shadow: none;
      background: #f9fafb;
      padding: 13px;
      margin-top: auto;
      margin-bottom: 0;
      border-radius: 16px;
      border: 1px solid var(--line);
    }

    body.dark-theme .user-card {
      background: #182235;
    }

    .user-card-head {
      display: flex;
      align-items: center;
      gap: 11px;
      min-width: 0;
      min-height: 38px;
    }

    .user-avatar {
      width: 36px;
      height: 36px;
      border-radius: 12px;
      display: grid;
      place-items: center;
      background: #eef0f3;
      color: var(--text);
      font-weight: 900;
      font-size: 14px;
      flex: 0 0 36px;
      margin-left: auto;
      border: 1px solid var(--line);
    }

    body.dark-theme .user-avatar {
      background: #111827;
    }

    .user-meta {
      display: grid;
      align-content: center;
      gap: 2px;
      min-width: 0;
      flex: 1;
      padding-top: 1px;
    }

    .user-name {
      font-size: 14px;
      font-weight: 900;
      color: var(--text);
      white-space: nowrap;
      overflow: hidden;
      text-overflow: ellipsis;
      line-height: 1.2;
    }


    .role-badge {
      display: inline-flex;
      align-items: center;
      width: fit-content;
      min-height: 20px;
      border-radius: 999px;
      padding: 2px 7px;
      font-size: 11px;
      font-weight: 800;
      line-height: 1;
      background: #eef0f3;
      border: 1px solid var(--line);
      color: var(--muted);
      margin-top: 1px;
      margin-left: -7px;
    }

    .user-card-footer {
      padding-top: 12px;
      border-top: 1px solid var(--line);
    }

    .nav { gap: 7px; margin-top: 12px; }

    .nav button {
      width: 100%;
      min-height: 48px;
      text-align: left;
      background: transparent;
      color: var(--text);
      border-radius: 15px;
      font-weight: 850;
      font-size: 15px;
      display: flex;
      align-items: center;
      gap: 11px;
      padding: 12px 13px;
      transition: background .14s ease, color .14s ease, transform .14s ease;
    }

    .nav button::before {
      content: attr(data-icon);
      width: 29px;
      height: 29px;
      display: inline-grid;
      place-items: center;
      font-size: 16px;
      opacity: .82;
      flex: 0 0 29px;
    }

    .nav button.active,
    .nav button:hover {
      background: #eef2ff;
      color: #1d4ed8;
    }

    body.dark-theme .nav button.active,
    body.dark-theme .nav button:hover {
      background: rgba(96,165,250,.16);
      color: #dbeafe;
    }

    .nav button.active { box-shadow: inset 4px 0 0 #2563eb; }

    .nav button:hover {
      transform: translateX(1px);
    }

    .sidebar-bottom {
      margin-top: 0;
      display: grid;
      gap: 10px;
    }

    .sidebar-note {
      padding: 12px;
      border-radius: 14px;
      background: #f9fafb;
      border: 1px solid var(--line);
      color: var(--muted);
      font-size: 12px;
      line-height: 1.45;
    }

    .logout-button {
      width: 100%;
      height: 34px;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      margin-top: 0;
      padding: 0 12px;
      border-radius: 11px;
      font-size: 13px;
      font-weight: 800;
      background: transparent;
      color: var(--muted);
      border: 1px solid var(--line);
    }

    .logout-button:hover {
      background: #f9fafb;
      color: var(--text);
    }

    body.dark-theme .logout-button {
      background: transparent;
      color: var(--muted);
    }

    body.dark-theme .logout-button:hover {
      background: #182235;
      color: var(--text);
    }
    .theme-toggle {
      display: none;
    }

    .history-controls {
      display: inline-flex;
      align-items: center;
      gap: 0;
      padding: 3px;
      width: fit-content;
      background: rgba(248, 250, 252, .76);
      border: 1px solid var(--line);
      border-radius: 999px;
      box-shadow: 0 8px 22px rgba(15, 23, 42, .06);
      overflow: hidden;
    }

    .sidebar-history { display: none; }

    .title-row {
      display: flex;
      align-items: center;
      gap: 18px;
      flex-wrap: wrap;
      margin-bottom: 8px;
    }

    .title-row .history-controls {
      margin-left: 10px;
    }

    body.dark-theme .history-controls {
      background: rgba(15, 23, 42, .54);
      border-color: rgba(148, 163, 184, .26);
      box-shadow: 0 10px 26px rgba(2, 6, 23, .28);
    }

    .history-button {
      width: 38px;
      height: 34px;
      min-width: 38px;
      min-height: 34px;
      padding: 0;
      display: inline-grid;
      place-items: center;
      border-radius: 999px;
      background: transparent;
      color: var(--muted);
      border: 1px solid transparent;
      line-height: 1;
      box-shadow: none;
      transition: background .16s ease, color .16s ease, transform .16s ease;
    }

    .history-button + .history-button {
      border-left: 1px solid rgba(148, 163, 184, .28);
      border-top-left-radius: 0;
      border-bottom-left-radius: 0;
    }

    .history-button:first-of-type {
      border-top-right-radius: 0;
      border-bottom-right-radius: 0;
    }

    .history-button:hover {
      background: rgba(37, 99, 235, .08);
      color: var(--blue);
      transform: translateY(-1px);
    }

    body.dark-theme .history-button {
      background: transparent;
      color: #cbd5e1;
      border-color: transparent;
    }

    body.dark-theme .history-button + .history-button {
      border-left-color: rgba(148, 163, 184, .22);
    }

    body.dark-theme .history-button:hover {
      background: rgba(96, 165, 250, .13);
      color: #eff6ff;
    }

    .history-button:disabled,
    .history-button:disabled:hover {
      opacity: .34;
      background: transparent;
      color: var(--muted);
      transform: none;
    }

    .history-icon {
      width: 17px;
      height: 17px;
      display: block;
      fill: none;
      stroke: currentColor;
      stroke-width: 2;
      stroke-linecap: round;
      stroke-linejoin: round;
    }

    .legend {
      display: grid;
      gap: 8px;
      font-size: 14px;
      box-shadow: none;
      padding: 14px;
    }

    .calendar-legend {
      margin-top: 12px;
      display: flex;
      align-items: center;
      gap: 18px;
      flex-wrap: wrap;
      box-shadow: none;
      padding: 12px 14px;
    }

    .install-prompt-backdrop {
      position: fixed;
      inset: 0;
      z-index: 80;
      display: flex;
      align-items: flex-end;
      justify-content: center;
      padding: max(16px, env(safe-area-inset-top)) max(14px, env(safe-area-inset-right)) max(16px, env(safe-area-inset-bottom)) max(14px, env(safe-area-inset-left));
      pointer-events: none;
      background: linear-gradient(180deg, rgba(15, 23, 42, 0), rgba(15, 23, 42, .14));
    }

    @media (min-width: 760px) {
      .install-prompt-backdrop {
        align-items: center;
        background: radial-gradient(circle at center, rgba(15, 23, 42, .18), rgba(15, 23, 42, .04) 58%, rgba(15, 23, 42, 0));
      }
    }

    .install-prompt {
      position: relative;
      width: min(430px, 100%);
      pointer-events: auto;
      display: grid;
      gap: 13px;
      padding: 14px 14px 16px;
      border-radius: 30px;
      background: rgba(255, 255, 255, .96);
      border: 1px solid rgba(226, 232, 240, .92);
      box-shadow: 0 24px 70px rgba(15, 23, 42, .26);
      backdrop-filter: blur(24px) saturate(1.08);
      -webkit-backdrop-filter: blur(24px) saturate(1.08);
      animation: installPromptIn .20s ease-out both;
      overflow: hidden;
    }

    .install-prompt::before {
      content: "";
      position: absolute;
      inset: 0 0 auto 0;
      height: 80px;
      background: linear-gradient(135deg, rgba(239, 68, 68, .12), rgba(37, 99, 235, .08));
      pointer-events: none;
    }

    .install-prompt-handle {
      position: relative;
      z-index: 1;
      width: 38px;
      height: 4px;
      border-radius: 999px;
      background: rgba(100, 116, 139, .28);
      margin: 0 auto 1px;
    }

    @keyframes installPromptIn {
      from { opacity: 0; transform: translateY(14px) scale(.985); }
      to { opacity: 1; transform: translateY(0) scale(1); }
    }

    body.dark-theme .install-prompt {
      background: rgba(17, 24, 39, .96);
      border-color: rgba(75, 85, 99, .78);
      box-shadow: 0 28px 80px rgba(0, 0, 0, .54);
    }

    body.dark-theme .install-prompt::before {
      background: linear-gradient(135deg, rgba(239, 68, 68, .12), rgba(96, 165, 250, .10));
    }

    .install-prompt-main {
      position: relative;
      z-index: 1;
      display: grid;
      grid-template-columns: 58px minmax(0, 1fr);
      gap: 13px;
      align-items: center;
      padding-right: 34px;
    }

    .install-prompt-logo {
      width: 58px;
      height: 58px;
      border-radius: 18px;
      overflow: hidden;
      background: #fff7ed;
      box-shadow: 0 12px 26px rgba(15, 23, 42, .15);
      border: 1px solid rgba(255, 255, 255, .76);
    }

    .install-prompt-logo img {
      width: 100%;
      height: 100%;
      display: block;
      object-fit: cover;
      object-position: center;
    }

    .install-prompt-text {
      display: grid;
      gap: 5px;
      min-width: 0;
    }

    .install-prompt-kicker {
      width: fit-content;
      padding: 4px 8px;
      border-radius: 999px;
      background: rgba(37, 99, 235, .10);
      color: var(--blue);
      font-size: 10px;
      font-weight: 950;
      letter-spacing: .09em;
      text-transform: uppercase;
    }

    .install-prompt-title {
      font-size: 20px;
      font-weight: 950;
      color: var(--text);
      line-height: 1.08;
      letter-spacing: -.03em;
    }

    .install-prompt-copy {
      color: var(--muted);
      font-size: 13px;
      font-weight: 720;
      line-height: 1.42;
    }

    .install-prompt-steps,
    .install-prompt-benefits {
      position: relative;
      z-index: 1;
      display: grid;
      gap: 7px;
    }

    .install-step {
      display: grid;
      grid-template-columns: 28px minmax(0, 1fr);
      gap: 9px;
      align-items: center;
      min-width: 0;
      padding: 8px 9px;
      border-radius: 16px;
      border: 1px solid rgba(148, 163, 184, .20);
      background: rgba(255, 255, 255, .66);
      color: var(--text);
      font-size: 12px;
      font-weight: 820;
      line-height: 1.25;
    }

    body.dark-theme .install-step {
      background: rgba(15, 23, 42, .34);
      border-color: rgba(148, 163, 184, .18);
    }

    .install-step b {
      display: inline-grid;
      place-items: center;
      width: 26px;
      height: 26px;
      border-radius: 999px;
      background: rgba(37, 99, 235, .12);
      color: var(--blue);
      font-size: 11px;
      font-weight: 950;
    }

    .install-prompt-benefits {
      grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .install-prompt-benefits span {
      display: flex;
      align-items: center;
      gap: 8px;
      min-width: 0;
      padding: 9px 10px;
      border-radius: 16px;
      border: 1px solid rgba(148, 163, 184, .20);
      background: rgba(255, 255, 255, .64);
      color: var(--text);
      font-size: 12px;
      font-weight: 820;
      line-height: 1.25;
    }

    body.dark-theme .install-prompt-benefits span {
      background: rgba(15, 23, 42, .34);
      border-color: rgba(148, 163, 184, .18);
    }

    .install-prompt-benefits span::before {
      content: "";
      width: 8px;
      height: 8px;
      border-radius: 999px;
      background: var(--blue);
      flex: 0 0 auto;
      opacity: .72;
    }

    .install-prompt-actions {
      position: relative;
      z-index: 1;
      display: grid;
      grid-template-columns: minmax(0, 1fr) auto;
      align-items: center;
      gap: 9px;
    }

    .install-prompt-actions button {
      min-height: 44px;
      padding: 11px 15px;
      white-space: nowrap;
    }

    .install-prompt-actions button.secondary {
      background: transparent;
      color: var(--muted);
    }

    .install-prompt-close {
      position: absolute;
      top: 12px;
      right: 12px;
      width: 34px;
      height: 34px;
      min-width: 34px;
      min-height: 34px;
      padding: 0;
      display: inline-grid;
      place-items: center;
      border-radius: 999px;
      background: rgba(148, 163, 184, .12);
      color: var(--muted);
      font-size: 22px;
      line-height: 1;
      box-shadow: none;
      z-index: 2;
    }

    .install-prompt-close:hover {
      background: rgba(148, 163, 184, .20);
      color: var(--text);
    }

    .install-steps {
      margin: 0;
      padding-left: 21px;
      color: var(--text);
      font-weight: 750;
      line-height: 1.5;
    }

    .calendar-legend strong { margin-right: 4px; }

    .legend-item { display: flex; gap: 8px; align-items: center; font-weight: 700; color: #4b5563; }
    .dot { width: 14px; height: 14px; border-radius: 99px; }
    .dot.green { background: var(--green); }
    .dot.yellow { background: var(--yellow); }
    .dot.purple { background: var(--purple); }

    .toolbar {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 12px;
      margin-bottom: 14px;
    }

    .toolbar > div:first-child {
      display: grid;
      gap: 6px;
      min-width: 0;
    }

    main > .toolbar {
      margin-top: 0;
      min-height: 66px;
    }

    .calendar-toolbar {
      align-items: flex-start;
    }

    .calendar-toolbar-heading {
      display: grid;
      gap: 6px;
      min-width: 0;
      flex: 1 1 280px;
    }

    .calendar-toolbar-actions {
      justify-content: flex-end;
      flex: 0 1 auto;
    }

    .title-row {
      margin-bottom: 0;
      min-height: 38px;
      align-items: center;
    }

    .title-row h1,
    .section-title-row h1 {
      margin: 0;
      font-size: 30px;
      line-height: 1.08;
      font-weight: 950;
      letter-spacing: -.045em;
    }

    .toolbar > div:first-child > .muted,
    .section-subtitle {
      color: var(--muted);
      font-size: 14px;
      line-height: 1.35;
      font-weight: 800;
    }

    .calendar-day-badge {
      margin-top: 3px;
      margin-left: 10px;
      display: inline-flex;
      align-items: center;
      gap: 8px;
      color: var(--muted);
      font-size: 14px;
      font-weight: 800;
      line-height: 1.35;
    }

    .calendar-day-badge::before {
      content: "";
      width: 7px;
      height: 7px;
      border-radius: 999px;
      background: var(--blue);
      opacity: .75;
      flex: 0 0 auto;
    }

    .calendar-day-title {
      color: var(--text);
      font-weight: 900;
    }

    .calendar-day-today {
      display: inline-flex;
      align-items: center;
      margin-left: 2px;
      padding: 2px 7px;
      border-radius: 999px;
      background: rgba(37, 99, 235, .08);
      color: var(--blue);
      font-size: 11px;
      font-weight: 900;
    }

    body.dark-theme .calendar-day-today {
      background: rgba(96,165,250,.14);
      color: #dbeafe;
    }

    .calendar {
      width: 100%;
      max-width: 100%;
      min-width: 0;
      background: var(--calendar-bg);
      border: 1px solid var(--line);
      border-radius: var(--radius);
      overflow: hidden;
      box-shadow: var(--shadow);
      user-select: none;
      -webkit-user-select: none;
      -webkit-touch-callout: none;
      -webkit-tap-highlight-color: transparent;
      position: relative;
    }

    .calendar,
    .calendar *,
    .calendar-scroll,
    .calendar-scroll *,
    .room-cell,
    .booking,
    .drag-preview,
    .booking-resize-handle {
      -webkit-user-select: none;
      user-select: none;
      -webkit-touch-callout: none;
      -webkit-tap-highlight-color: transparent;
    }

    .calendar img,
    .calendar svg,
    .booking {
      -webkit-user-drag: none;
    }

    .calendar-scroll {
      max-height: min(78vh, calc(100dvh - 190px));
      min-height: min(620px, calc(100dvh - 260px));
      overflow: auto;
      overscroll-behavior: contain;
      -webkit-overflow-scrolling: touch;
      scrollbar-width: thin;
    }

    .calendar-more-indicator {
      position: absolute;
      left: 50%;
      bottom: 12px;
      transform: translateX(-50%) translateY(4px);
      z-index: 8;
      display: inline-flex;
      align-items: center;
      gap: 8px;
      padding: 8px 13px;
      border-radius: 999px;
      background: rgba(17, 24, 39, .86);
      color: white;
      font-size: 13px;
      font-weight: 900;
      box-shadow: 0 10px 24px rgba(15, 23, 42, .25);
      pointer-events: none;
      opacity: 0;
      visibility: hidden;
      transition: opacity .34s ease, transform .34s ease, visibility 0s linear .34s;
    }

    .calendar-more-indicator.visible {
      opacity: 1;
      visibility: visible;
      transform: translateX(-50%) translateY(0);
      transition: opacity .34s ease, transform .34s ease, visibility 0s;
    }

    .calendar-more-indicator .arrow {
      font-size: 18px;
      line-height: 1;
      animation: bounceDown 1.2s ease-in-out infinite;
    }

    .calendar-date-edge-cue {
      position: absolute;
      top: 96px;
      bottom: 18px;
      width: 112px;
      z-index: 9;
      display: flex;
      align-items: center;
      justify-content: center;
      pointer-events: none;
      opacity: 0;
      visibility: hidden;
      transition: opacity .16s ease, visibility .16s ease;
    }

    .calendar-date-edge-cue.left { left: 0; background: linear-gradient(to right, rgba(37,99,235,.16), rgba(37,99,235,0)); }
    .calendar-date-edge-cue.right { right: 0; background: linear-gradient(to left, rgba(37,99,235,.16), rgba(37,99,235,0)); }
    .calendar-date-edge-cue.left.blocked { background: linear-gradient(to right, rgba(220,38,38,.18), rgba(220,38,38,0)); }
    .calendar-date-edge-cue.right.blocked { background: linear-gradient(to left, rgba(220,38,38,.18), rgba(220,38,38,0)); }

    .calendar-date-edge-cue.visible {
      opacity: 1;
      visibility: visible;
    }

    .date-edge-cue-card {
      display: grid;
      gap: 6px;
      justify-items: center;
      min-width: 78px;
      padding: 10px 11px;
      border-radius: 16px;
      background: rgba(255,255,255,.88);
      backdrop-filter: blur(10px) saturate(1.04);
      -webkit-backdrop-filter: blur(10px) saturate(1.04);
      border: 1px solid rgba(37,99,235,.16);
      box-shadow: 0 10px 24px rgba(15, 23, 42, .12);
      color: var(--blue);
      transform: scale(.98);
      transition: transform .16s ease;
      font-size: 11px;
      font-weight: 950;
      text-align: center;
    }

    .calendar-date-edge-cue.visible .date-edge-cue-card {
      transform: scale(1);
    }

    .calendar-date-edge-cue.blocked .date-edge-cue-card {
      border-color: rgba(220,38,38,.22);
      color: var(--red);
    }

    .date-edge-cue-arrow {
      font-size: 22px;
      line-height: 1;
    }

    .date-edge-cue-progress {
      width: 50px;
      height: 4px;
      border-radius: 999px;
      background: rgba(37,99,235,.14);
      overflow: hidden;
    }

    .date-edge-cue-progress span {
      display: block;
      height: 100%;
      width: calc(var(--edge-progress, 0) * 100%);
      border-radius: inherit;
      background: var(--blue);
      transition: width .06s linear;
    }

    .calendar-date-edge-cue.blocked .date-edge-cue-progress {
      background: rgba(220,38,38,.14);
    }

    .calendar-date-edge-cue.blocked .date-edge-cue-progress span {
      background: var(--red);
    }

    body.dark-theme .calendar-date-edge-cue.left { background: linear-gradient(to right, rgba(96,165,250,.16), rgba(96,165,250,0)); }
    body.dark-theme .calendar-date-edge-cue.right { background: linear-gradient(to left, rgba(96,165,250,.16), rgba(96,165,250,0)); }
    body.dark-theme .calendar-date-edge-cue.left.blocked { background: linear-gradient(to right, rgba(248,113,113,.18), rgba(248,113,113,0)); }
    body.dark-theme .calendar-date-edge-cue.right.blocked { background: linear-gradient(to left, rgba(248,113,113,.18), rgba(248,113,113,0)); }

    body.dark-theme .date-edge-cue-card {
      background: rgba(17,24,39,.86);
      border-color: rgba(96,165,250,.20);
      box-shadow: 0 10px 24px rgba(0,0,0,.28);
      color: #dbeafe;
    }

    @keyframes bounceDown {
      0%, 100% { transform: translateY(-1px); }
      50% { transform: translateY(3px); }
    }

    .calendar::after {
      content: "";
      position: absolute;
      left: 0;
      right: 0;
      bottom: 0;
      height: 72px;
      pointer-events: none;
      background: linear-gradient(to bottom, rgba(246,248,251,0), rgba(246,248,251,.94));
      opacity: 0;
      transition: none;
      z-index: 7;
    }

    body.dark-theme .calendar::after {
      background: linear-gradient(to bottom, rgba(17,24,39,0), rgba(17,24,39,.96));
    }

    body.dark-theme .modal { background: var(--panel); color: var(--text); }

    body.dark-theme .sidebar-note,
    body.dark-theme .toggle-group,
    body.dark-theme tr.past-booking td { background: #182235; }

    body.dark-theme th { background: #151f31; }

    body.dark-theme .toggle-group button.active {
      background: #22304a;
      color: #dbeafe;
    }

    body.dark-theme .legend-item,
    body.dark-theme .role-badge { color: var(--muted); }

    body.dark-theme .role-badge { background: #111827; }

    .calendar.has-more::after { opacity: 1; }



    .calendar-now-line {
      position: absolute;
      height: 2px;
      background: #ef4444;
      border-radius: 999px;
      z-index: 5;
      pointer-events: none;
      transform: translateY(-50%);
      box-shadow: 0 1px 5px rgba(239, 68, 68, .35);
    }

    .calendar-now-line::before {
      content: none;
    }

    .calendar-now-time-label {
      position: absolute;
      right: calc(100% - 4px);
      top: 50%;
      transform: translateY(-50%);
      display: inline-flex;
      align-items: center;
      justify-content: center;
      min-height: 26px;
      padding: 5px 10px;
      border-radius: 999px;
      background: #ef4444;
      color: white;
      font-size: 13px;
      font-weight: 950;
      line-height: 1;
      white-space: nowrap;
      letter-spacing: .01em;
      box-shadow: 0 4px 10px rgba(239, 68, 68, .24);
    }

    .calendar-now-time-label.edge-clamped {
      right: auto;
      left: var(--calendar-now-label-left, 0px);
    }

    @media (max-width: 560px) and (pointer: coarse) {
      .calendar-now-time-label {
        min-height: 24px;
        padding: 4px 8px;
        font-size: 12px;
      }
    }

    body.dark-theme .calendar-now-line,
    body.dark-theme .calendar-now-line::before,
    body.dark-theme .calendar-now-time-label {
      background: #f87171;
      box-shadow: 0 1px 7px rgba(248, 113, 113, .36);
    }

    .calendar-grid {
      display: grid;
      grid-template-columns: 88px repeat(4, 1fr);
      position: relative;
      transform-origin: center center;
      will-change: transform, opacity;
    }

    .calendar-grid.calendar-swipe-exit-next {
      animation: calendarSwipeOutNext .32s cubic-bezier(.2, .82, .18, 1) forwards;
    }

    .calendar-grid.calendar-swipe-exit-prev {
      animation: calendarSwipeOutPrev .32s cubic-bezier(.2, .82, .18, 1) forwards;
    }

    .calendar-grid.calendar-swipe-enter-next {
      animation: calendarSwipeInNext .32s cubic-bezier(.16, .9, .22, 1) both;
    }

    .calendar-grid.calendar-swipe-enter-prev {
      animation: calendarSwipeInPrev .32s cubic-bezier(.16, .9, .22, 1) both;
    }

    @keyframes calendarSwipeOutNext {
      0% { transform: translate3d(0, 0, 0) scale(1); opacity: 1; }
      100% { transform: translate3d(-88px, 0, 0) scale(.985); opacity: .18; }
    }

    @keyframes calendarSwipeOutPrev {
      0% { transform: translate3d(0, 0, 0) scale(1); opacity: 1; }
      100% { transform: translate3d(88px, 0, 0) scale(.985); opacity: .18; }
    }

    @keyframes calendarSwipeInNext {
      0% { transform: translate3d(88px, 0, 0) scale(.985); opacity: .18; }
      62% { opacity: 1; }
      100% { transform: translate3d(0, 0, 0) scale(1); opacity: 1; }
    }

    @keyframes calendarSwipeInPrev {
      0% { transform: translate3d(-88px, 0, 0) scale(.985); opacity: .18; }
      62% { opacity: 1; }
      100% { transform: translate3d(0, 0, 0) scale(1); opacity: 1; }
    }

    .calendar-swipe-feedback {
      position: absolute;
      top: 92px;
      left: 16px;
      right: 16px;
      z-index: 25;
      display: flex;
      justify-content: space-between;
      pointer-events: none;
      opacity: 0;
      transform: translateY(-6px);
      transition: opacity .18s ease, transform .18s ease;
    }

    .calendar-swipe-pill {
      display: inline-flex;
      align-items: center;
      gap: 7px;
      min-height: 34px;
      padding: 7px 11px;
      border-radius: 999px;
      background: rgba(255, 255, 255, .86);
      border: 1px solid rgba(148, 163, 184, .44);
      color: var(--text);
      font-size: 12px;
      font-weight: 900;
      letter-spacing: .01em;
      box-shadow: 0 14px 28px rgba(15, 23, 42, .13);
      backdrop-filter: blur(14px);
      -webkit-backdrop-filter: blur(14px);
      opacity: .42;
      transform: scale(.96);
      transition: opacity .18s ease, transform .18s ease;
    }

    .calendar-swipe-pill .swipe-arrow {
      font-size: 19px;
      line-height: 1;
      margin-top: -1px;
    }

    body.calendar-touch-swiping .calendar-swipe-feedback {
      opacity: 1;
      transform: translateY(0);
    }

    body.calendar-touch-swiping.calendar-swipe-prev .calendar-swipe-prev,
    body.calendar-touch-swiping.calendar-swipe-next .calendar-swipe-next {
      opacity: 1;
      transform: scale(1);
    }

    body.dark-theme .calendar-swipe-pill {
      background: rgba(15, 23, 42, .78);
      border-color: rgba(148, 163, 184, .34);
      color: #f8fafc;
      box-shadow: 0 16px 32px rgba(2, 6, 23, .42);
    }

    .calendar-grid.dynamic-rooms {
      grid-template-columns: 88px repeat(var(--room-count, 4), minmax(160px, 1fr));
      min-width: max(720px, calc(88px + (var(--room-count, 4) * 160px)));
    }

    .cal-cell {
      border-right: 1px solid var(--line);
      border-bottom: 1px solid var(--line);
      min-height: var(--cell-height);
      padding: 7px;
      position: relative;
      background: var(--calendar-cell);
    }

    .room-cell {
      overflow: visible;
      touch-action: pan-y;
    }

    body.calendar-touch-holding .calendar {
      cursor: progress;
    }

    body.calendar-touch-dragging,
    body.calendar-touch-dragging .calendar,
    body.calendar-touch-dragging .calendar-scroll,
    body.calendar-touch-dragging .room-cell,
    body.calendar-touch-dragging .booking {
      touch-action: none;
      overscroll-behavior: contain;
    }

    body.calendar-touch-swiping,
    body.calendar-touch-swiping .calendar,
    body.calendar-touch-swiping .calendar-scroll,
    body.calendar-touch-swiping .calendar-grid {
      touch-action: none;
      overscroll-behavior: contain;
    }

    body.calendar-touch-swiping .calendar-grid {
      transition: none;
    }

    .touch-hold-pending {
      box-shadow: none;
    }

    body.dark-theme .touch-hold-pending {
      box-shadow: none;
    }

    body.dark-theme .room-cell:hover { background: var(--calendar-hover); }
    .cal-cell:nth-child(5n) { border-right: 0; }

    .cal-head {
      background: var(--calendar-header);
      backdrop-filter: blur(10px) saturate(1.04);
      -webkit-backdrop-filter: blur(10px) saturate(1.04);
      box-shadow: inset 0 1px 0 rgba(255,255,255,.48), inset 0 -1px 0 rgba(148,163,184,.22), 0 8px 16px rgba(15, 23, 42, .077);
      font-weight: 900;
      min-height: 78px;
      padding: 4px 7px 7px;
      display: flex;
      align-items: flex-start;
      justify-content: center;
      text-align: center;
      position: sticky;
      top: 0;
      z-index: 6;
    }

    body.dark-theme .cal-head {
      box-shadow: inset 0 1px 0 rgba(255,255,255,.08), inset 0 -1px 0 rgba(148,163,184,.14), 0 8px 16px rgba(0, 0, 0, .208);
    }

    .time-head {
      align-items: flex-end;
      padding-top: 4px;
      padding-bottom: 10px;
    }

    .time-cell {
      background: var(--calendar-time);
      color: var(--muted);
      font-size: 13px;
      font-weight: 800;
      display: flex;
      align-items: flex-start;
      justify-content: center;
      text-align: center;
    }

    .booking {
      touch-action: pan-y;
      border-radius: 12px;
      padding: 7px 8px;
      font-size: 13px;
      font-weight: 950;
      line-height: 1.28;
      letter-spacing: .005em;
      color: #111827;
      text-shadow: 0 1px 2px rgba(0,0,0,.22);
      box-shadow: 0 4px 10px rgba(0,0,0,.08);
      cursor: pointer;
      position: absolute;
      transition: transform .12s ease, box-shadow .12s ease, opacity .12s ease;
      left: 6px;
      right: 6px;
      top: 0;
      z-index: 2;
      overflow: hidden;
      user-select: none;
    }

    .booking.can-move { cursor: grab; }
    .booking.can-move:hover { transform: translateY(-1px); box-shadow: 0 8px 18px rgba(0,0,0,.14); }
    .booking.can-move:active { cursor: grabbing; }
    .booking.moving,
    .booking.resizing {
      opacity: .28;
      transform: scale(.985);
      z-index: 90 !important;
    }

    .booking-resize-handle {
      position: absolute;
      left: 0;
      right: 0;
      bottom: 0;
      height: 18px;
      cursor: ns-resize;
      opacity: 1;
      z-index: 5;
    }

    .booking-resize-handle::after {
      content: "";
      position: absolute;
      left: 10px;
      right: 10px;
      bottom: 3px;
      height: 10px;
      border-radius: 999px;
      background: rgba(17, 24, 39, .22);
      opacity: 0;
      transition: opacity .12s ease, background .12s ease;
    }

    .booking.can-resize:hover .booking-resize-handle::after,
    .booking-resize-handle:hover::after {
      opacity: .72;
    }

    body.dark-theme .booking-resize-handle::after {
      background: rgba(255, 255, 255, .35);
    }

    .booking.fixed-cancelled .booking-resize-handle::after {
      background: rgba(17, 24, 39, .38);
      opacity: 0;
    }

    .booking.fixed-cancelled.can-resize:hover .booking-resize-handle::after,
    .booking.fixed-cancelled .booking-resize-handle:hover::after {
      background: rgba(17, 24, 39, .66);
      opacity: .86;
    }

    body.dark-theme .booking.fixed-cancelled .booking-resize-handle::after {
      background: rgba(255, 255, 255, .48);
      opacity: 0;
    }

    body.dark-theme .booking.fixed-cancelled.can-resize:hover .booking-resize-handle::after,
    body.dark-theme .booking.fixed-cancelled .booking-resize-handle:hover::after {
      background: rgba(255, 255, 255, .78);
      opacity: .86;
    }
    .booking.fixed { background: var(--green); color: white; }
    .booking.flex {
      background: var(--yellow);
      color: white;
      text-shadow:
        0 1px 1px rgba(17, 24, 39, .36),
        0 0 1px rgba(17, 24, 39, .42);
    }

    .booking.admin-assigned-flex {
      /* Ingen særskilt kant: admin-oprettede egne bookinger beholder den normale “Din booking”-kant. */
    }

    .booking-admin-assigned-label-wrap {
      position: absolute;
      left: 8px;
      right: 8px;
      top: 77%;
      transform: translateY(-50%);
      z-index: 6;
      display: flex;
      justify-content: center;
      align-items: center;
      pointer-events: none;
    }

    .booking-admin-assigned-label {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      width: fit-content;
      max-width: 100%;
      padding: 3px 7px;
      border-radius: 999px;
      background: rgba(255, 255, 255, .20);
      color: inherit;
      font-size: 10.5px;
      font-weight: 950;
      line-height: 1.15;
      text-align: center;
      text-transform: uppercase;
      letter-spacing: .04em;
      text-decoration: none;
      text-shadow: none;
      white-space: nowrap;
      overflow: hidden;
      text-overflow: ellipsis;
      box-shadow: inset 0 0 0 1px rgba(255, 255, 255, .18), 0 6px 14px rgba(88, 28, 135, .14);
    }

    .booking-admin-assigned-table-badge {
      display: inline-flex;
      align-items: center;
      width: fit-content;
      max-width: 100%;
      margin-top: 3px;
      padding: 2px 6px;
      border-radius: 999px;
      background: rgba(254, 242, 242, .94);
      color: #b91c1c;
      border: 1px solid rgba(248, 113, 113, .7);
      font-size: 10px;
      font-weight: 950;
      line-height: 1.15;
      text-shadow: none;
      white-space: nowrap;
      overflow: hidden;
      text-overflow: ellipsis;
    }

    body.dark-theme .booking-admin-assigned-table-badge {
      background: rgba(127, 29, 29, .72);
      color: #fecaca;
      border-color: rgba(248, 113, 113, .45);
    }
    .booking-content-lines {
      display: grid;
      gap: 2px;
      min-width: 0;
    }

    .booking-main-line {
      display: flex;
      align-items: baseline;
      gap: 6px;
      min-width: 0;
      max-width: 100%;
    }

    .booking-calendar-title {
      min-width: 0;
      overflow: hidden;
      text-overflow: ellipsis;
      white-space: nowrap;
    }

    .booking-calendar-time {
      flex: 0 0 auto;
      font-size: .88em;
      font-weight: 900;
      opacity: .92;
      white-space: nowrap;
    }

    .booking-calendar-owner {
      min-width: 0;
      overflow: hidden;
      text-overflow: ellipsis;
      white-space: nowrap;
      opacity: .94;
    }

    .booking.booking-short {
      padding: 3px 7px;
      border-radius: 9px;
      display: flex;
      align-items: center;
      min-height: 0;
    }

    .booking.booking-short .booking-content-lines {
      width: 100%;
      gap: 0;
    }

    .booking.booking-short .booking-main-line {
      line-height: 1.08;
    }

    .booking.booking-short .booking-calendar-owner,
    .booking.booking-short .booking-note-line,
    .booking.booking-short .booking-admin-assigned-label-wrap,
    .booking.booking-short .booking-cancelled-label-wrap {
      display: none;
    }

    .booking.booking-short .booking-resize-handle {
      height: 10px;
    }

    .booking:not(.cancelled) { z-index: 4; }
    .booking.cancelled { opacity: .19; z-index: 2; }
    .booking.cancelled .booking-content-lines { text-decoration: line-through; }
    .booking.fixed-cancelled {
      background: var(--purple);
      color: #fff;
      opacity: .34;
    }

    .booking.fixed-cancelled.moving,
    .booking.fixed-cancelled.resizing {
      opacity: .14;
      transform: scale(.985);
      z-index: 90 !important;
    }

    .booking-cancelled-label-wrap {
      position: absolute;
      left: 8px;
      right: 8px;
      top: 77%;
      transform: translateY(-50%);
      z-index: 6;
      display: flex;
      justify-content: center;
      align-items: center;
      pointer-events: none;
    }

    .booking-cancelled-label {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      width: fit-content;
      max-width: 100%;
      padding: 3px 7px;
      border-radius: 999px;
      background: rgba(255, 255, 255, .20);
      color: inherit;
      font-size: 10.5px;
      font-weight: 950;
      line-height: 1.15;
      text-align: center;
      text-transform: uppercase;
      letter-spacing: .04em;
      text-decoration: none;
      box-shadow: inset 0 0 0 1px rgba(255, 255, 255, .18), 0 6px 14px rgba(88, 28, 135, .14);
    }

    .booking.fixed-cancelled .booking-cancelled-label {
      background: rgba(255, 255, 255, .24);
    }
    .booking.past-calendar-booking {
      opacity: .42;
      filter: grayscale(.45);
      box-shadow: none;
    }

    .booking.own-booking {
      border: 4px solid rgba(37, 99, 235, .95);
      box-shadow: 0 0 0 2px rgba(255,255,255,.85), 0 8px 18px rgba(37,99,235,.22);
    }

    body.dark-theme .booking.own-booking {
      border-color: #7cb8ff;
      border-width: 4px;
      box-shadow: 0 0 0 1px rgba(255,255,255,.18), 0 0 0 2px rgba(124,184,255,.24), 0 8px 18px rgba(37,99,235,.12);
    }

    .booking-owner-indicator {
      position: absolute;
      right: 7px;
      bottom: 6px;
      width: 10px;
      height: 10px;
      border-radius: 999px;
      background: rgba(255,255,255,.95);
      box-shadow: 0 0 0 2px rgba(37,99,235,.9);
      pointer-events: none;
    }

    body.dark-theme .booking-owner-indicator {
      background: #ffffff;
      box-shadow: 0 0 0 2px #7cb8ff;
    }

    .drag-preview,
    .move-preview,
    .resize-preview {
      position: absolute;
      left: 7px;
      right: 7px;
      border-radius: 12px;
      z-index: 80;
      pointer-events: none;
      display: grid;
      place-items: center;
      font-size: 13px;
      font-weight: 950;
      line-height: 1.28;
      letter-spacing: .005em;
      text-align: center;
      padding: 6px;
    }

    .drag-preview {
      border: 2px dashed #92400e;
      background: rgba(242, 201, 76, .30);
      color: #78350f;
    }

    .move-preview,
    .resize-preview {
      border: 2px solid #1e40af;
      background: rgba(37, 99, 235, .18);
      color: #1e3a8a;
      box-shadow: 0 10px 24px rgba(30, 64, 175, .18);
      transition: none;
      will-change: top, height;
    }

    .drag-preview.invalid,
    .move-preview.invalid,
    .resize-preview.invalid {
      border-color: #dc2626;
      background: rgba(220, 38, 38, .16);
      color: #991b1b;
    }

    .drag-preview.past-drop,
    .move-preview.past-drop,
    .resize-preview.past-drop,
    .drag-preview.closed-drop,
    .move-preview.closed-drop,
    .resize-preview.closed-drop,
    .drag-preview.overlap-drop,
    .move-preview.overlap-drop,
    .resize-preview.overlap-drop {
      border-style: dashed;
      border-color: #dc2626;
      background: rgba(220,38,38,.20);
      color: #7f1d1d;
      box-shadow: 0 0 0 3px rgba(220,38,38,.10), 0 10px 24px rgba(127,29,29,.18);
    }

    .drag-warning {
      margin-top: 3px;
      padding: 3px 7px;
      border-radius: 999px;
      background: rgba(220,38,38,.14);
      color: inherit;
      font-size: 10.5px;
      font-weight: 950;
      line-height: 1.15;
      text-transform: uppercase;
      letter-spacing: .04em;
    }

    .room-cell.selecting { background: var(--calendar-hover); }

    body.dark-theme .drag-preview {
      border-color: #f5d76e;
      background: rgba(245, 215, 110, .16);
      color: #fef3c7;
    }

    body.dark-theme .move-preview,
    body.dark-theme .resize-preview {
      border-color: #93c5fd;
      background: rgba(96, 165, 250, .18);
      color: #dbeafe;
    }

    body.dark-theme .drag-preview.invalid,
    body.dark-theme .move-preview.invalid,
    body.dark-theme .resize-preview.invalid {
      border-color: #f87171;
      background: rgba(248, 113, 113, .16);
      color: #fecaca;
    }

    body.dark-theme .drag-preview.past-drop,
    body.dark-theme .move-preview.past-drop,
    body.dark-theme .resize-preview.past-drop,
    body.dark-theme .drag-preview.closed-drop,
    body.dark-theme .move-preview.closed-drop,
    body.dark-theme .resize-preview.closed-drop,
    body.dark-theme .drag-preview.overlap-drop,
    body.dark-theme .move-preview.overlap-drop,
    body.dark-theme .resize-preview.overlap-drop {
      border-color: #f87171;
      background: rgba(248,113,113,.22);
      color: #fee2e2;
      box-shadow: 0 0 0 3px rgba(248,113,113,.12), 0 10px 24px rgba(0,0,0,.22);
    }

    body.dark-theme .drag-warning {
      background: rgba(248,113,113,.16);
    }

    .grid-2 { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; }
    .grid-3 { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 12px; }

    .modal-backdrop {
      position: fixed;
      inset: 0;
      background: rgba(17, 24, 39, .45);
      display: none;
      justify-content: center;
      align-items: flex-start;
      padding: 24px 20px;
      z-index: 50;
      overflow-y: auto;
      overscroll-behavior: contain;
    }

    .modal-backdrop.open { display: flex; }

    .modal {
      width: min(620px, 100%);
      max-height: calc(100vh - 48px);
      overflow-y: auto;
      overflow-x: hidden;
      background: white;
      border-radius: 22px;
      padding: 20px;
      box-shadow: 0 30px 80px rgba(0,0,0,.25);
      position: relative;
      margin: auto 0;
      overscroll-behavior: contain;
      scrollbar-width: thin;
    }

    .modal > .stack > .row.space-between:first-child {
      position: sticky;
      top: -20px;
      z-index: 6;
      background: white;
      padding: 4px 0 14px;
      margin-bottom: 2px;
    }

    .modal > .stack > .row:last-child:not(.space-between) {
      position: sticky;
      bottom: -20px;
      z-index: 5;
      background: linear-gradient(to top, white 78%, rgba(255,255,255,.86));
      padding: 14px 0 4px;
      margin-top: 2px;
    }

    body.dark-theme .modal > .stack > .row.space-between:first-child {
      background: var(--panel);
    }

    body.dark-theme .modal > .stack > .row:last-child:not(.space-between) {
      background: linear-gradient(to top, var(--panel) 78%, rgba(31,41,55,.86));
    }


    .modal-close-button {
      width: 38px;
      height: 38px;
      min-width: 38px;
      min-height: 38px;
      flex: 0 0 38px;
      padding: 0;
      display: inline-grid;
      place-items: center;
      border-radius: 999px;
      background: rgba(15, 23, 42, .06);
      color: var(--muted);
      border: 1px solid rgba(148, 163, 184, .32);
      box-shadow: none;
      line-height: 1;
      transition: background .16s ease, color .16s ease, border-color .16s ease, transform .16s ease;
    }

    .modal-close-button:hover {
      background: rgba(37, 99, 235, .10);
      color: var(--blue);
      border-color: rgba(37, 99, 235, .18);
      transform: translateY(-1px);
    }

    .modal-close-button svg {
      width: 18px;
      height: 18px;
      display: block;
      fill: none;
      stroke: currentColor;
      stroke-width: 2.2;
      stroke-linecap: round;
      stroke-linejoin: round;
    }

    body.dark-theme .modal-close-button {
      background: rgba(148, 163, 184, .10);
      color: #cbd5e1;
      border-color: rgba(148, 163, 184, .24);
    }

    body.dark-theme .modal-close-button:hover {
      background: rgba(96, 165, 250, .14);
      color: #eff6ff;
      border-color: rgba(96, 165, 250, .22);
    }

    table {
      width: 100%;
      border-collapse: collapse;
      background: var(--panel);
      border-radius: 16px;
      overflow: hidden;
    }

    th, td {
      text-align: left;
      padding: 12px;
      border-bottom: 1px solid var(--line);
      font-size: 14px;
    }

    th { background: rgba(249,250,251,.72); font-size: 12px; text-transform: uppercase; color: var(--muted); }

    .pill {
      display: inline-flex;
      border-radius: 999px;
      padding: 4px 9px;
      font-size: 12px;
      font-weight: 900;
      background: #eef2ff;
      color: #1e40af;
    }

    .pill.fixed { background: #dcfce7; color: #166534; }
    .pill.flex { background: #fef3c7; color: #92400e; }

    .booking-title-cell { display: grid; gap: 5px; }

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

    td.actions-cell .row {
      justify-content: flex-end;
      flex-wrap: nowrap;
      margin: 0;
    }
    .booking-title-main { font-weight: 900; color: var(--text); }
    .booking-title-sub { font-size: 12px; color: var(--muted); line-height: 1.35; }

    .deleted-member-name {
      text-decoration: line-through;
      text-decoration-thickness: 2px;
      text-decoration-color: var(--red);
      text-underline-offset: 2px;
    }

    .deleted-member-note {
      display: inline-block;
      margin-left: 6px;
      font-size: 12px;
      color: var(--muted);
      white-space: nowrap;
    }

    .small-badge {
      display: inline-flex;
      width: fit-content;
      border-radius: 999px;
      padding: 3px 8px;
      font-size: 11px;
      font-weight: 900;
      background: #f3f4f6;
      color: #4b5563;
      border: 1px solid var(--line);
    }

    .small-badge.warning {
      background: var(--purple-bg);
      color: var(--purple);
      border-color: var(--purple-border);
    }

    body.dark-theme .small-badge { background: #182235; color: var(--muted); }

    body.dark-theme .small-badge.warning {
      background: var(--purple-bg);
      color: #ddd6fe;
      border-color: var(--purple-border);
    }

    .booking-rule-individual-label {
      display: inline-flex;
      align-items: baseline;
      gap: 2px;
      white-space: nowrap;
    }

    .booking-rule-individual-star {
      color: #dc2626;
      font-weight: 950;
      line-height: 1;
    }

    .cancellation-card {
      box-shadow: none;
      padding: 0;
      overflow: hidden;
      border-color: color-mix(in srgb, var(--purple-border) 44%, var(--line));
      background: var(--panel);
    }

    .cancellation-header {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 10px;
      padding: 9px 11px;
      border-bottom: 1px solid color-mix(in srgb, var(--purple-border) 34%, var(--line));
      background: color-mix(in srgb, var(--purple-bg) 32%, var(--panel));
    }

    body.dark-theme .cancellation-header {
      background: color-mix(in srgb, var(--purple-bg) 34%, var(--panel));
    }

    .cancellation-title-row {
      display: flex;
      align-items: center;
      gap: 8px;
      min-width: 0;
    }

    .cancellation-title-icon {
      width: 18px;
      height: 18px;
      border-radius: 999px;
      display: inline-grid;
      place-items: center;
      background: color-mix(in srgb, var(--purple-bg) 68%, var(--panel));
      border: 1px solid color-mix(in srgb, var(--purple-border) 60%, var(--line));
      color: var(--purple);
      font-size: 14px;
      line-height: 1;
      font-weight: 950;
      flex: 0 0 18px;
    }

    .cancellation-title-text {
      display: grid;
      gap: 0;
      min-width: 0;
    }

    .cancellation-title-text h3 {
      margin: 0;
      line-height: 1.15;
      font-size: 14px;
      color: var(--text);
    }

    .cancellation-subtitle {
      color: var(--muted);
      font-size: 11px;
      font-weight: 700;
      line-height: 1.2;
    }

    .cancellation-header-actions {
      display: inline-flex;
      align-items: center;
      gap: 7px;
      flex: 0 0 auto;
    }

    .cancellation-count {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      min-width: 22px;
      height: 20px;
      padding: 0 7px;
      border-radius: 999px;
      background: color-mix(in srgb, var(--panel) 82%, var(--purple-bg));
      border: 1px solid color-mix(in srgb, var(--purple-border) 55%, var(--line));
      color: var(--purple);
      font-size: 10px;
      font-weight: 950;
      white-space: nowrap;
    }

    .cancellation-toggle {
      width: 26px;
      height: 26px;
      padding: 0;
      border-radius: 999px;
      display: inline-grid;
      place-items: center;
      background: transparent;
      border: 1px solid color-mix(in srgb, var(--purple-border) 38%, var(--line));
      color: var(--muted);
      font-size: 14px;
      line-height: 1;
      transition: background .14s ease, color .14s ease, transform .14s ease;
    }

    .cancellation-toggle:hover {
      background: color-mix(in srgb, var(--purple-bg) 48%, var(--panel));
      color: var(--purple);
    }

    .cancellation-card.open .cancellation-toggle {
      color: var(--purple);
      transform: rotate(180deg);
    }

    #booking-cancellations-card:not(.open) .cancellation-header {
      border-bottom: 0;
      border-radius: calc(var(--radius) - 1px);
    }

    .cancellation-empty {
      margin: 8px 10px 10px;
      padding: 8px 10px;
      border-radius: 10px;
      border: 1px dashed color-mix(in srgb, var(--purple-border) 45%, var(--line));
      background: color-mix(in srgb, var(--bg) 78%, var(--panel));
      display: flex;
      align-items: center;
      gap: 8px;
      font-size: 12px;
    }

    .cancellation-empty-icon {
      width: 18px;
      height: 18px;
      border-radius: 999px;
      display: inline-grid;
      place-items: center;
      background: color-mix(in srgb, var(--purple-bg) 60%, var(--panel));
      color: var(--purple);
      font-size: 11px;
      font-weight: 950;
      flex: 0 0 18px;
    }

    .cancellation-list-wrap {
      max-height: 0;
      overflow: hidden;
      transition: max-height .18s ease;
    }

    .cancellation-card.open .cancellation-list-wrap {
      max-height: 240px;
      overflow-y: auto;
      scrollbar-width: thin;
    }

    .cancellation-list {
      display: grid;
      gap: 0;
      padding: 2px 10px 8px;
      margin: 0;
      list-style: none;
    }

    .cancellation-list li {
      display: grid;
      grid-template-columns: minmax(0, 1fr) auto;
      align-items: center;
      gap: 10px;
      padding: 7px 0;
      border-bottom: 1px solid color-mix(in srgb, var(--line) 76%, var(--purple-border));
      background: transparent;
      font-size: 12px;
      font-weight: 800;
    }

    .cancellation-list li:last-child {
      border-bottom: 0;
    }

    .cancellation-main {
      display: grid;
      gap: 2px;
      min-width: 0;
    }

    .cancellation-date-line {
      display: flex;
      align-items: center;
      gap: 6px;
      flex-wrap: wrap;
    }

    .cancellation-date {
      color: var(--text);
      font-size: 12px;
      font-weight: 900;
      line-height: 1.2;
    }

    .cancellation-reason {
      display: block;
      padding: 0;
      border: 0;
      background: transparent;
      color: var(--muted);
      line-height: 1.24;
      font-size: 11px;
      font-weight: 700;
      white-space: nowrap;
      overflow: hidden;
      text-overflow: ellipsis;
    }

    .cancellation-reason-label {
      display: none;
    }

    .cancellation-meta {
      display: flex;
      align-items: center;
      justify-content: flex-end;
      gap: 6px;
      text-align: right;
      align-self: center;
      min-width: 138px;
      max-width: 210px;
    }

    .cancellation-meta .small-badge {
      padding: 2px 6px;
      font-size: 10px;
      flex: 0 0 auto;
    }

    .cancellation-meta-line {
      color: var(--muted);
      font-size: 10.5px;
      font-weight: 750;
      line-height: 1.2;
      white-space: nowrap;
    }

    @media (max-width: 560px) {
      .cancellation-header {
        align-items: center;
      }

      .cancellation-card.open .cancellation-list-wrap {
        max-height: 260px;
      }

      .cancellation-list li {
        grid-template-columns: 1fr;
        align-items: start;
        gap: 5px;
      }

      .cancellation-meta {
        justify-content: space-between;
        text-align: left;
        min-width: 0;
        max-width: none;
        width: 100%;
      }
    }

    .meta-card {
      box-shadow: none;
      background: var(--bg);
      padding: 13px;
      gap: 8px;
    }

    .meta-card-title {
      font-size: 12px;
      font-weight: 950;
      text-transform: uppercase;
      letter-spacing: .06em;
      color: var(--muted);
    }

    .confirm-card {
      box-shadow: none;
      border-color: rgba(220, 38, 38, .35);
      background: rgba(220, 38, 38, .06);
    }

    .toast {
      position: fixed;
      left: 50%;
      bottom: 22px;
      transform: translate(-50%, 22px);
      opacity: 0;
      z-index: 90;
      background: rgba(17, 24, 39, .92);
      color: white;
      border-radius: 999px;
      padding: 11px 16px;
      font-size: 14px;
      font-weight: 850;
      box-shadow: 0 16px 36px rgba(15, 23, 42, .28);
      pointer-events: none;
      transition: transform .22s ease, opacity .22s ease;
    }

    .toast.show {
      transform: translate(-50%, 0);
      opacity: 1;
    }

    body.dark-theme .toast {
      background: rgba(243, 244, 246, .94);
      color: #111827;
    }

    .collapsible-section {
      padding: 0;
      overflow: visible;
    }

    .section-header {
      position: sticky;
      top: 0;
      z-index: 12;
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 14px;
      padding: 18px;
      border-bottom: 1px solid var(--line);
      border-radius: calc(var(--radius) - 1px) calc(var(--radius) - 1px) 0 0;
      background: var(--calendar-header);
      backdrop-filter: blur(10px) saturate(1.04);
      -webkit-backdrop-filter: blur(10px) saturate(1.04);
      box-shadow: inset 0 1px 0 rgba(255,255,255,.48), inset 0 -1px 0 rgba(148,163,184,.22), 0 8px 16px rgba(15, 23, 42, .077);
    }


    body.dark-theme .section-header {
      background: var(--calendar-header);
      box-shadow: inset 0 1px 0 rgba(255,255,255,.08), inset 0 -1px 0 rgba(148,163,184,.14), 0 8px 16px rgba(0, 0, 0, .208);
    }

    .admin-toolbar {
      position: sticky;
      top: 0;
      z-index: 30;
      margin: 0 -22px 14px;
      padding: 22px 22px 16px;
      background: rgba(246, 248, 251, .995);
      backdrop-filter: blur(12px) saturate(1.08);
      -webkit-backdrop-filter: blur(12px) saturate(1.08);
      border-bottom: 1px solid rgba(229, 231, 235, .78);
      box-shadow: 0 8px 18px rgba(15, 23, 42, .04);
    }

    .admin-toolbar::after {
      content: "";
      position: absolute;
      left: 0;
      right: 0;
      bottom: -14px;
      height: 14px;
      background: var(--bg);
      pointer-events: none;
    }

    body.dark-theme .admin-toolbar {
      background: rgba(17, 24, 39, .995);
      border-bottom-color: rgba(55, 65, 81, .78);
      box-shadow: 0 8px 18px rgba(0, 0, 0, .18);
    }

    .admin-panel-stack .collapsible-section {
      overflow: clip;
      overflow-clip-margin: 0;
      isolation: isolate;
    }

    .admin-panel-stack .section-header {
      top: 110px;
      background: var(--panel);
      backdrop-filter: none;
      -webkit-backdrop-filter: none;
      box-shadow: inset 0 1px 0 rgba(255,255,255,.55), inset 0 -1px 0 rgba(148,163,184,.22), 0 8px 16px rgba(15, 23, 42, .077);
    }

    body.dark-theme .admin-panel-stack .section-header {
      background: var(--panel);
      box-shadow: inset 0 1px 0 rgba(255,255,255,.08), inset 0 -1px 0 rgba(148,163,184,.14), 0 8px 16px rgba(0, 0, 0, .208);
    }

    .collapsible-section.collapsed .section-header {
      border-bottom: 0;
    }

    .section-title-block {
      display: grid;
      gap: 3px;
      min-width: 0;
    }

    .section-title-row {
      display: flex;
      align-items: center;
      gap: 10px;
    }

    .section-title-row h2 {
      margin: 0;
    }

    .section-count {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      min-width: 26px;
      height: 24px;
      padding: 0 8px;
      border-radius: 999px;
      background: #eef2ff;
      color: #1d4ed8;
      font-size: 12px;
      font-weight: 950;
    }

    body.dark-theme .section-count {
      background: #273449;
      color: #dbeafe;
    }

    .section-subtitle {
      color: var(--muted);
      font-size: 14px;
      line-height: 1.35;
      font-weight: 800;
    }

    .section-actions {
      display: flex;
      align-items: center;
      gap: 10px;
      flex-wrap: wrap;
      justify-content: flex-end;
    }

    .collapse-button {
      width: 26px;
      height: 26px;
      padding: 0;
      border-radius: 8px;
      display: inline-grid;
      place-items: center;
      background: transparent;
      color: var(--muted);
      font-size: 15px;
      line-height: 1;
      flex: 0 0 auto;
      transition: background .14s ease, color .14s ease, transform .14s ease;
    }

    .collapse-button:hover {
      background: rgba(37, 99, 235, .08);
      color: #1d4ed8;
    }

    body.dark-theme .collapse-button {
      background: transparent;
      color: var(--muted);
    }

    body.dark-theme .collapse-button:hover {
      background: rgba(96,165,250,.12);
      color: #dbeafe;
    }

    .section-content {
      padding: 0 18px 18px;
      overflow: hidden;
      border-radius: 0 0 calc(var(--radius) - 1px) calc(var(--radius) - 1px);
    }

    .section-content table {
      margin-top: 0;
    }

    .toggle-group {
      display: inline-flex;
      gap: 6px;
      padding: 5px;
      background: #f3f4f6;
      border: 1px solid var(--line);
      border-radius: 999px;
      width: fit-content;
    }

    .toggle-group button {
      background: transparent;
      color: var(--muted);
      padding: 8px 13px;
      font-size: 13px;
      font-weight: 900;
    }

    .toggle-group button:hover {
      background: #e5e7eb;
      color: var(--text);
    }

    .toggle-group button.active {
      background: white;
      color: #1d4ed8;
      box-shadow: 0 3px 10px rgba(15, 23, 42, .08);
    }

    .filter-count {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      min-width: 20px;
      height: 18px;
      margin-left: 6px;
      padding: 0 6px;
      border-radius: 999px;
      background: rgba(37,99,235,.10);
      color: var(--blue);
      font-size: 11px;
      font-weight: 950;
      line-height: 1;
    }

    .toggle-group button.active .filter-count {
      background: #eef2ff;
      color: #1d4ed8;
    }

    body.dark-theme .filter-count {
      background: rgba(96,165,250,.14);
      color: #dbeafe;
    }

    body.dark-theme .toggle-group button.active .filter-count {
      background: rgba(96,165,250,.18);
      color: #dbeafe;
    }

    .toggle-divider {
      width: 2px;
      align-self: stretch;
      background: rgba(148, 163, 184, .55);
      margin: 3px 6px;
      border-radius: 999px;
    }

    body.dark-theme .toggle-divider {
      background: rgba(148, 163, 184, .36);
    }

    tr.past-booking {
      opacity: .46;
      filter: grayscale(.35);
    }

    tr.past-booking td { background: #f3f4f6; }
    tr.past-booking .pill { opacity: .72; }

    .room-head-content {
      display: grid;
      grid-template-rows: 22px auto;
      align-content: start;
      justify-items: center;
      gap: 8px;
      min-width: 0;
      width: 100%;
      min-height: 66px;
      padding-top: 3px;
    }

    .room-head-title {
      display: grid;
      grid-template-columns: 1fr auto 1fr;
      align-items: center;
      justify-items: center;
      column-gap: 6px;
      min-width: 0;
      width: 100%;
      max-width: 100%;
      line-height: 18px;
    }

    .room-head-title .room-head-name {
      grid-column: 2;
    }

    .room-head-title .status-chip {
      grid-column: 3;
      justify-self: start;
    }

    .room-head-name {
      line-height: 18px;
      white-space: nowrap;
      overflow: hidden;
      text-overflow: ellipsis;
      max-width: 100%;
      min-width: 0;
    }

    .facility-badges {
      display: flex;
      gap: 5px;
      flex-wrap: wrap;
      align-items: center;
    }

    .room-head-facilities {
      position: relative;
      justify-content: center;
      align-content: start;
      width: 100%;
      min-height: 22px;
      margin-top: 3px;
      overflow: visible;
    }

    .room-facility-shell {
      position: relative;
      display: inline-flex;
      justify-content: center;
      width: 100%;
      max-width: 100%;
    }

    .room-facility-trigger {
      display: inline-flex;
      align-items: center;
      gap: 3px;
      min-width: 0;
      max-width: 100%;
      padding: 4px 7px;
      border-radius: 999px;
      border: 2px solid transparent;
      background: #eef2ff;
      color: #1e40af;
      box-shadow: none;
      font-size: 10px;
      font-weight: 700;
      line-height: 1;
      cursor: pointer;
      transition: background .18s ease, color .18s ease;
    }

    .room-facility-trigger:hover {
      background: #dbeafe;
      color: #1e40af;
      box-shadow: none;
      transform: none;
    }

    .room-facility-trigger:focus-visible {
      outline: 2px solid rgba(37, 99, 235, .28);
      outline-offset: 2px;
    }

    .room-facility-trigger-label {
      display: inline-flex;
      align-items: center;
      gap: 6px;
      min-width: 0;
    }

    .room-facility-glyph {
      display: inline-flex;
      align-items: center;
      gap: 2px;
      flex: 0 0 auto;
    }

    .room-facility-glyph span {
      width: 4px;
      height: 4px;
      border-radius: 999px;
      background: linear-gradient(180deg, rgba(124, 58, 237, .92), rgba(99, 102, 241, .92));
      box-shadow: 0 0 0 1px rgba(255,255,255,.4);
    }

    .room-facility-trigger-text {
      white-space: nowrap;
      letter-spacing: .01em;
      color: inherit;
    }

    .room-facility-count {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      min-width: 13px;
      height: 13px;
      padding: 0 3px;
      border-radius: 999px;
      background: rgba(30, 64, 175, .10);
      color: inherit;
      font-size: 10px;
      font-weight: 900;
      line-height: 1;
      flex: 0 0 auto;
    }


    .room-facility-panel {
      position: absolute;
      top: calc(100% + 8px);
      left: 50%;
      transform: translateX(-50%);
      z-index: 18;
      width: max-content;
      min-width: 160px;
      max-width: min(220px, calc(100vw - 24px));
      padding: 8px;
      border-radius: 14px;
      border: 1px solid rgba(148, 163, 184, .25);
      background: rgba(255,255,255,.97);
      box-shadow: 0 18px 40px rgba(15, 23, 42, .16);
      backdrop-filter: blur(16px);
      -webkit-backdrop-filter: blur(16px);
    }

    .room-facility-panel::before {
      content: "";
      position: absolute;
      top: -6px;
      left: 50%;
      width: 12px;
      height: 12px;
      transform: translateX(-50%) rotate(45deg);
      background: rgba(255,255,255,.97);
      border-left: 1px solid rgba(148, 163, 184, .18);
      border-top: 1px solid rgba(148, 163, 184, .18);
    }

    .room-facility-panel .facility-badges {
      gap: 6px;
      justify-content: center;
    }

    .room-facility-panel .facility-chip {
      background: linear-gradient(180deg, rgba(248, 250, 252, .98), rgba(241, 245, 249, .95));
      border-color: rgba(148, 163, 184, .3);
      color: var(--text);
      box-shadow: 0 1px 0 rgba(255,255,255,.75) inset;
      font-size: 10px;
      padding: 4px 8px;
    }

    .room-facility-panel .muted {
      display: block;
      padding: 4px 6px;
      font-size: 11px;
      text-align: center;
    }

    .mobile-room-facilities-sheet .room-facilities-header {
      display: flex;
      align-items: center;
      gap: 10px;
      min-width: 0;
    }

    .mobile-room-facilities-sheet .room-facilities-icon {
      width: 34px;
      height: 34px;
      border-radius: 13px;
      display: inline-grid;
      place-items: center;
      background: #eef2ff;
      color: #1e40af;
      font-weight: 900;
      flex: 0 0 auto;
    }

    .mobile-room-facilities-sheet .room-facilities-heading {
      min-width: 0;
      display: grid;
      gap: 2px;
    }

    .mobile-room-facilities-sheet .room-facilities-heading h2 {
      margin: 0;
      font-size: 19px;
      line-height: 1.15;
    }

    .mobile-room-facilities-sheet .room-facilities-heading .muted {
      font-size: 12px;
      line-height: 1.25;
    }

    .mobile-room-facilities-sheet .facility-badges {
      display: grid;
      grid-template-columns: repeat(auto-fit, minmax(112px, 1fr));
      gap: 8px;
      align-items: stretch;
    }

    .mobile-room-facilities-sheet .facility-chip {
      width: 100%;
      justify-content: center;
      text-align: center;
      white-space: normal;
      line-height: 1.15;
      padding: 9px 10px;
      border-radius: 14px;
    }

    body.dark-theme .mobile-room-facilities-sheet .room-facilities-icon {
      background: rgba(96, 165, 250, .16);
      color: #dbeafe;
    }

    .facility-chip {
      display: inline-flex;
      align-items: center;
      width: fit-content;
      border-radius: 999px;
      padding: 3px 7px;
      background: #f3f4f6;
      border: 1px solid var(--line);
      color: var(--muted);
      font-size: 10px;
      font-weight: 850;
      line-height: 1;
      white-space: nowrap;
    }

    .cal-head .facility-chip {
      background: rgba(255,255,255,.62);
      font-size: 9px;
      padding: 2px 6px;
      max-width: 92px;
      overflow: hidden;
      text-overflow: ellipsis;
    }

    body.dark-theme .facility-chip {
      background: #182235;
    }

    body.dark-theme .room-facility-trigger {
      background: #273449;
      border-color: transparent;
      color: #dbeafe;
      box-shadow: none;
    }

    body.dark-theme .room-facility-trigger:hover {
      background: #314158;
      color: #dbeafe;
    }

    body.dark-theme .room-facility-trigger-text {
      color: inherit;
    }

    body.dark-theme .room-facility-count {
      background: rgba(219, 234, 254, .12);
      color: inherit;
    }

    body.dark-theme .room-facility-panel {
      background: linear-gradient(180deg, rgba(31, 41, 55, .98), rgba(17, 24, 39, .98));
      border-color: rgba(96, 165, 250, .28);
      box-shadow: 0 18px 44px rgba(0, 0, 0, .45);
    }

    body.dark-theme .room-facility-panel::before {
      background: #1f2937;
      border-left-color: rgba(96, 165, 250, .24);
      border-top-color: rgba(96, 165, 250, .24);
    }

    body.dark-theme .room-facility-panel .facility-chip {
      background: rgba(39, 52, 73, .96);
      border-color: rgba(96, 165, 250, .24);
      color: #dbeafe;
      box-shadow: none;
    }

    body.dark-theme .room-facility-panel .muted {
      color: #cbd5e1;
    }

    body.dark-theme .cal-head .facility-chip {
      background: rgba(17,24,39,.54);
    }

    .cal-head .status-chip {
      font-size: 9px;
      padding: 2px 6px;
      flex: 0 0 auto;
    }

    .status-chip {
      display: inline-flex;
      align-items: center;
      width: fit-content;
      border-radius: 999px;
      padding: 3px 7px;
      background: #f3f4f6;
      border: 1px solid var(--line);
      color: var(--muted);
      font-size: 10px;
      font-weight: 900;
      line-height: 1;
      white-space: nowrap;
    }

    .status-chip.open { background: #dcfce7; color: #166534; border-color: #bbf7d0; }
    .status-chip.closed { background: #fee2e2; color: #991b1b; border-color: #fecaca; }

    .status-with-closure {
      display: inline-flex;
      align-items: center;
      gap: 6px;
      min-width: 0;
      white-space: nowrap;
    }

    .status-closure-text {
      color: var(--muted);
      font-size: 11px;
      font-weight: 850;
      line-height: 1;
    }

    body.dark-theme .status-chip { background: #182235; color: var(--muted); }
    body.dark-theme .status-chip.open { background: rgba(74,222,128,.14); color: #bbf7d0; border-color: rgba(74,222,128,.24); }
    body.dark-theme .status-chip.closed { background: rgba(248,113,113,.14); color: #fecaca; border-color: rgba(248,113,113,.24); }

    .room-cell.unavailable-room {
      cursor: not-allowed;
    }

    .room-closure-block {
      position: absolute;
      z-index: 1;
      pointer-events: none;
      border-radius: 0;
      background-image: repeating-linear-gradient(135deg, transparent 0, transparent 10px, rgba(220,38,38,.105) 10px, rgba(220,38,38,.105) 20px);
      background-position: 0 0;
      box-shadow: inset 0 0 0 1px rgba(220,38,38,.12);
    }

    body.dark-theme .room-closure-block {
      background-image: repeating-linear-gradient(135deg, transparent 0, transparent 10px, rgba(248,113,113,.12) 10px, rgba(248,113,113,.12) 20px);
      box-shadow: inset 0 0 0 1px rgba(248,113,113,.14);
    }

    .room-cell.unavailable-room.admin-can-book {
      cursor: crosshair;
    }

    .room-cell.unavailable-room::after {
      content: "";
      display: none;
    }

    .rules-grid {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 14px;
    }

    .rules-guide-grid {
      align-items: stretch;
      grid-auto-flow: row dense;
    }

    .rule-card {
      box-shadow: none;
      display: grid;
      gap: 11px;
      align-content: start;
      min-width: 0;
      overflow: hidden;
      border-radius: 22px;
      border-color: rgba(148,163,184,.20);
      background: linear-gradient(180deg, rgba(255,255,255,.94), rgba(248,250,252,.76));
    }

    body.dark-theme .rule-card {
      border-color: rgba(148,163,184,.15);
      background: linear-gradient(180deg, rgba(30,41,59,.80), rgba(15,23,42,.72));
    }

    .rule-card-top {
      display: grid;
      grid-template-columns: auto minmax(0, 1fr);
      gap: 10px;
      align-items: start;
      min-width: 0;
    }

    .rule-card-icon {
      width: 30px;
      height: 30px;
      border-radius: 12px;
      display: inline-grid;
      place-items: center;
      flex: 0 0 auto;
      background: rgba(37,99,235,.08);
      border: 1px solid rgba(37,99,235,.12);
      color: var(--text);
      font-size: 15px;
      line-height: 1;
    }

    body.dark-theme .rule-card-icon {
      background: rgba(59,130,246,.13);
      border-color: rgba(96,165,250,.18);
    }

    .rule-card-title-block {
      display: grid;
      gap: 3px;
      min-width: 0;
    }

    .rule-card h2,
    .rule-card h3 { margin: 0; }

    .rule-card h2 {
      min-width: 0;
      font-size: 16px;
      line-height: 1.16;
      letter-spacing: -.01em;
    }

    .rule-card-subtitle {
      color: var(--muted);
      font-size: 12px;
      line-height: 1.28;
      font-weight: 800;
    }

    .rule-card > .muted {
      margin-top: -4px;
      font-size: 12px;
      line-height: 1.28;
      font-weight: 800;
    }

    .rule-list {
      margin: 0;
      padding-left: 18px;
      color: var(--muted);
      line-height: 1.45;
      font-size: 14px;
      font-weight: 650;
      list-style: disc;
      display: grid;
      gap: 7px;
    }

    .rule-list li {
      padding-left: 2px;
      min-width: 0;
    }

    .rule-list li::marker {
      color: var(--muted);
      font-size: .92em;
    }

    @media (min-width: 1101px) {
      .rules-guide-grid {
        grid-template-columns: repeat(12, minmax(0, 1fr));
        gap: 16px;
      }

      .rules-guide-grid .rule-card {
        grid-column: span 6;
      }

      .rules-guide-grid .rule-card-wide {
        grid-column: span 7;
      }

      .rules-guide-grid .rule-card-compact {
        grid-column: span 5;
      }
    }

    .rule-hero-card {
      grid-column: 1 / -1 !important;
      border-color: rgba(37,99,235,.20);
      background:
        radial-gradient(circle at 14px 14px, rgba(37,99,235,.10), transparent 35%),
        linear-gradient(135deg, rgba(37,99,235,.075), rgba(249,250,251,.90));
    }

    body.dark-theme .rule-hero-card {
      border-color: rgba(96,165,250,.25);
      background:
        radial-gradient(circle at 14px 14px, rgba(96,165,250,.18), transparent 35%),
        linear-gradient(135deg, rgba(59,130,246,.14), rgba(15,23,42,.84));
    }

    .rule-hero-card .rule-card-icon {
      width: 36px;
      height: 36px;
      border-radius: 15px;
      font-size: 18px;
      background: rgba(37,99,235,.11);
    }

    .rule-hero-card h2 {
      font-size: 20px;
      letter-spacing: -.02em;
    }

    @media (min-width: 1101px) {
      .rule-hero-card {
        grid-template-columns: minmax(0, 1fr);
        column-gap: 20px;
        row-gap: 10px;
        align-items: start;
      }

      .rule-hero-card .rule-card-top,
      .rule-hero-card > .rules-guide-note,
      .rule-hero-card > .member-rule-effective-summary,
      .rule-hero-card > .rule-list {
        grid-column: 1 / -1;
        grid-row: auto;
      }

      .rule-hero-card > .rules-guide-note {
        justify-self: start;
        align-self: start;
        margin-top: 0;
      }
    }

    .rules-guide-chip-row {
      margin-top: 0;
      padding: 10px;
      border: 1px solid rgba(148,163,184,.18);
      border-radius: 17px;
      background: rgba(255,255,255,.66);
      flex-wrap: nowrap;
      overflow-x: auto;
      overflow-y: hidden;
      -webkit-overflow-scrolling: touch;
      scrollbar-width: thin;
    }

    .rules-guide-chip-row .member-rule-chip {
      flex: 0 0 auto;
    }

    body.dark-theme .rules-guide-chip-row {
      background: rgba(15,23,42,.52);
      border-color: rgba(148,163,184,.15);
    }

    .rules-guide-chip-row .member-rule-chip {
      background: rgba(255,255,255,.86);
    }

    body.dark-theme .rules-guide-chip-row .member-rule-chip {
      background: rgba(15,23,42,.86);
    }

    .rules-guide-note {
      display: inline-flex;
      align-items: center;
      width: fit-content;
      max-width: 100%;
      margin-top: -1px;
      padding: 5px 8px;
      border-radius: 999px;
      border: 1px solid rgba(37,99,235,.16);
      background: rgba(37,99,235,.06);
      color: var(--text);
      font-size: 12px;
      font-weight: 850;
    }

    body.dark-theme .rules-guide-note {
      border-color: rgba(96,165,250,.22);
      background: rgba(59,130,246,.12);
    }

    .rule-card .rules-guide-note + .member-rule-effective-summary {
      margin-top: 2px;
    }

    .booking-confirm-grid {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 10px;
    }

    .booking-confirm-item {
      padding: 11px 12px;
      border-radius: 14px;
      background: var(--bg);
      border: 1px solid var(--line);
      display: grid;
      gap: 3px;
    }

    .booking-confirm-label {
      color: var(--muted);
      font-size: 11px;
      font-weight: 950;
      text-transform: uppercase;
      letter-spacing: .06em;
    }

    .booking-confirm-value {
      font-weight: 900;
      color: var(--text);
    }

    .room-facilities-preview {
      grid-column: 1 / -1;
      display: grid;
      gap: 7px;
      padding: 11px 12px;
      border-radius: 14px;
      background: var(--bg);
      border: 1px solid var(--line);
    }

    .room-closure-settings {
      grid-column: 1 / -1;
      display: grid;
      gap: 12px;
    }

    .room-closure-settings.hidden {
      display: none !important;
    }

    .room-facilities-title {
      color: var(--muted);
      font-size: 12px;
      font-weight: 900;
    }

    .stats-grid {
      display: grid;
      grid-template-columns: repeat(4, minmax(0, 1fr));
      gap: 12px;
    }

    .stat-card {
      box-shadow: none;
      padding: 16px;
      display: grid;
      gap: 6px;
    }

    .stat-value {
      font-size: 28px;
      font-weight: 950;
      line-height: 1;
      letter-spacing: -.03em;
    }

    .stat-label {
      color: var(--muted);
      font-size: 13px;
      font-weight: 800;
    }

    .stat-grid-2 {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 14px;
    }

    .stat-bars {
      display: grid;
      gap: 11px;
    }

    .stat-bar-row {
      display: grid;
      gap: 6px;
    }

    .stat-bar-head {
      display: flex;
      justify-content: space-between;
      gap: 12px;
      color: var(--text);
      font-size: 13px;
      font-weight: 850;
    }

    .stat-bar-track {
      height: 9px;
      border-radius: 999px;
      background: #eef0f3;
      overflow: hidden;
    }

    .stat-bar-fill {
      height: 100%;
      border-radius: inherit;
      background: var(--blue);
      min-width: 4px;
    }

    body.dark-theme .stat-bar-track { background: #111827; }


    @media (pointer: coarse) and (orientation: portrait) and (max-width: 1180px) {
      html,
      body,
      #root {
        width: 100%;
        max-width: 100vw;
        overflow-x: hidden;
      }

      .app-shell {
        width: 100%;
        max-width: 100vw;
        grid-template-columns: 1fr;
        overflow-x: clip;
      }

      aside,
      main {
        width: 100%;
        max-width: 100vw;
        min-width: 0;
      }

      main {
        overflow-x: clip;
      }

      .toolbar,
      .card,
      .section,
      .collapsible-section,
      .admin-panel-stack,
      .admin-panel-stack .section-content,
      .admin-panel-stack table,
      .admin-panel-stack tr,
      .admin-panel-stack td {
        max-width: 100%;
        min-width: 0;
      }

      .admin-panel-stack .collapsible-section {
        overflow: visible;
      }
    }

    @media (max-width: 1100px) {
      .stats-grid,
      .stat-grid-2,
      .rules-grid { grid-template-columns: 1fr; }

      .app-shell {
        grid-template-columns: 240px 1fr;
      }

      aside,
      main {
        padding: 18px;
      }

      .admin-toolbar {
        margin-left: -18px;
        margin-right: -18px;
        padding-left: 18px;
        padding-right: 18px;
      }
    }

    @media (max-width: 860px) {
      body {
        overflow: auto;
        overscroll-behavior-y: auto;
      }

      .app-shell {
        width: 100%;
        min-height: 100dvh;
        height: auto;
        grid-template-columns: 1fr;
        overflow: visible;
      }

      aside {
        position: relative;
        z-index: 20;
        height: auto;
        overflow: visible;
        border-right: 0;
        border-bottom: 1px solid var(--line);
        padding: 14px;
        gap: 12px;
      }

      main {
        height: auto;
        min-height: 0;
        overflow: visible;
        padding: 14px;
      }

      main.admin-main {
        padding-top: 0;
      }

      main.my-main {
        min-height: auto;
        overflow: visible;
        display: block;
      }

      .brand-row,
      .brand {
        align-items: center;
      }

      .brand-title {
        min-width: 0;
      }

      .nav {
        display: flex;
        gap: 8px;
        margin-top: 0;
        padding-bottom: 4px;
        overflow-x: auto;
        overscroll-behavior-x: contain;
        -webkit-overflow-scrolling: touch;
      }

      .nav button {
        width: auto;
        min-width: max-content;
        min-height: 44px;
        flex: 0 0 auto;
        border-radius: 999px;
        padding: 10px 13px;
        font-size: 14px;
      }

      .nav button::before {
        width: 23px;
        height: 23px;
        flex-basis: 23px;
      }

      .nav button.active {
        box-shadow: inset 0 -3px 0 #2563eb;
      }

      .nav button:hover {
        transform: none;
      }

      .sidebar-note {
        display: none;
      }

      .user-card {
        margin-top: 0;
      }

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

      .calendar-toolbar {
        gap: 12px;
      }

      .calendar-toolbar-heading {
        flex-basis: auto;
      }

      .calendar-toolbar-actions {
        display: grid;
        grid-template-columns: minmax(74px, auto) 44px minmax(176px, 1fr) 44px minmax(118px, auto);
        gap: 8px;
        align-items: center;
        width: 100%;
      }

      .calendar-toolbar-actions button,
      .calendar-toolbar-actions .custom-date-field {
        min-height: 44px;
      }

      .calendar-toolbar-actions .custom-date-field {
        width: 100%;
      }

      .calendar-toolbar-actions .icon-button {
        width: 44px;
        padding-left: 0;
        padding-right: 0;
      }

      .toolbar > .row,
      .title-row {
        width: 100%;
      }

      .title-row h1,
      .section-title-row h1 {
        font-size: 26px;
      }

      .custom-date-field {
        max-width: 100%;
      }

      .calendar {
        border-radius: 16px;
      }

      .calendar-scroll {
        max-height: 68dvh;
        min-height: min(560px, 68dvh);
      }

      .calendar-grid.dynamic-rooms {
        min-width: max(680px, calc(82px + (var(--room-count, 4) * 150px)));
        grid-template-columns: 82px repeat(var(--room-count, 4), minmax(150px, 1fr));
      }

      .cal-head {
        min-height: 74px;
      }

      .calendar-date-edge-cue {
        top: 80px;
        width: 88px;
      }

      .my-bookings-section {
        max-height: none;
        overflow: visible;
        display: block;
      }

      .my-bookings-section .section-content,
      .section-content {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
      }

      .my-bookings-section .section-content {
        overflow-y: visible;
      }

      table {
        min-width: 720px;
      }

      .grid-2,
      .grid-3,
      .booking-confirm-grid {
        grid-template-columns: 1fr;
      }

      .admin-toolbar {
        margin-left: -14px;
        margin-right: -14px;
        padding: 14px;
      }

      .admin-panel-stack .section-header {
        top: 0;
      }

      .section-header {
        align-items: flex-start;
        flex-direction: column;
      }

      .section-actions {
        width: 100%;
        justify-content: flex-start;
        min-width: 0;
        max-width: 100%;
      }

      .section-actions .toggle-group {
        max-width: 100%;
        overflow-x: auto;
        overscroll-behavior-x: contain;
        -webkit-overflow-scrolling: touch;
      }

      main.admin-main,
      .admin-panel-stack,
      .admin-panel-stack .collapsible-section,
      .admin-panel-stack .section-header,
      .admin-panel-stack .section-content {
        min-width: 0;
        max-width: 100%;
      }

      .admin-panel-stack .collapsible-section {
        overflow: visible;
      }

      .admin-panel-stack .section-content {
        overflow: visible;
        padding-left: 14px;
        padding-right: 14px;
      }

      .admin-panel-stack table {
        display: block;
        width: 100%;
        min-width: 0;
        background: transparent;
        border-radius: 0;
        overflow: visible;
      }

      .admin-panel-stack thead {
        display: none;
      }

      .admin-panel-stack tbody,
      .admin-panel-stack tr,
      .admin-panel-stack td {
        display: block;
        width: 100%;
        min-width: 0;
      }

      .admin-panel-stack tr {
        margin: 0 0 10px;
        padding: 12px;
        border: 1px solid var(--line);
        border-radius: 16px;
        background: var(--panel);
        box-shadow: none;
      }

      .admin-panel-stack td {
        padding: 7px 0;
        border-bottom: 0;
        white-space: normal;
        overflow-wrap: anywhere;
      }

      .admin-panel-stack td[data-label]:not(.actions-cell) {
        display: grid;
        grid-template-columns: minmax(86px, 30%) minmax(0, 1fr);
        gap: 10px;
        align-items: start;
      }

      .admin-panel-stack td[data-label]::before {
        content: attr(data-label);
        color: var(--muted);
        font-size: 11px;
        font-weight: 950;
        letter-spacing: .05em;
        text-transform: uppercase;
        line-height: 1.35;
      }

      .admin-panel-stack td.actions-cell {
        padding-top: 10px;
        width: 100%;
      }

      .admin-panel-stack td.actions-cell::before {
        display: block;
        margin-bottom: 7px;
      }

      .admin-panel-stack td.actions-cell .row {
        width: 100%;
        justify-content: flex-start;
        flex-wrap: wrap;
        gap: 8px;
      }

      .admin-panel-stack td.actions-cell button {
        flex: 0 1 auto;
      }
    }


    @media (max-width: 1024px) and (pointer: coarse) {
      body {
        overflow-x: hidden;
      }

      main.admin-main {
        width: 100%;
        max-width: 100vw;
        overflow-x: clip;
      }

      .admin-toolbar {
        max-width: 100vw;
      }

      .admin-panel-stack .section-content {
        overflow: visible;
        padding-left: 14px;
        padding-right: 14px;
      }

      .admin-panel-stack table {
        display: block;
        width: 100%;
        min-width: 0;
        background: transparent;
        border-radius: 0;
        overflow: visible;
      }

      .admin-panel-stack thead {
        display: none;
      }

      .admin-panel-stack tbody,
      .admin-panel-stack tr,
      .admin-panel-stack td {
        display: block;
        width: 100%;
        min-width: 0;
        max-width: 100%;
      }

      .admin-panel-stack tr {
        margin: 0 0 10px;
        padding: 12px;
        border: 1px solid var(--line);
        border-radius: 16px;
        background: var(--panel);
        box-shadow: none;
        overflow: clip;
      }

      .admin-panel-stack td {
        padding: 7px 0;
        border-bottom: 0;
        white-space: normal;
        overflow-wrap: anywhere;
      }

      .admin-panel-stack td[data-label]:not(.actions-cell) {
        display: grid;
        grid-template-columns: minmax(82px, 28%) minmax(0, 1fr);
        gap: 10px;
        align-items: start;
      }

      .admin-panel-stack td[data-label]::before {
        content: attr(data-label);
        color: var(--muted);
        font-size: 11px;
        font-weight: 950;
        letter-spacing: .05em;
        text-transform: uppercase;
        line-height: 1.35;
      }

      .admin-panel-stack td.actions-cell {
        padding-top: 10px;
        width: 100%;
      }

      .admin-panel-stack td.actions-cell::before {
        display: block;
        margin-bottom: 7px;
      }

      .admin-panel-stack td.actions-cell .row {
        width: 100%;
        justify-content: flex-start;
        flex-wrap: wrap;
        gap: 8px;
      }

      .admin-panel-stack td.actions-cell button {
        flex: 1 1 96px;
        max-width: 100%;
      }
    }

    @media (max-width: 640px) {
      aside,
      main {
        padding: 12px;
      }

      main.admin-main {
        padding-top: 0;
      }

      .brand {
        font-size: 18px;
      }

      .brand-mark {
        width: 36px;
        height: 36px;
        flex-basis: 36px;
        border-radius: 12px;
      }

      .brand-subtitle,
      .toolbar > div:first-child > .muted,
      .section-subtitle {
        font-size: 12px;
      }

      .title-row h1,
      .section-title-row h1 {
        font-size: 24px;
      }

      .row {
        gap: 8px;
      }

      .toolbar .row button,
      .toolbar .row .custom-date-field {
        flex: 1 1 auto;
      }

      .toolbar .row .icon-button {
        flex: 0 0 44px;
      }

      .calendar-toolbar-actions {
        grid-template-columns: minmax(68px, 1fr) 44px minmax(132px, 1.35fr) 44px;
      }

      .calendar-toolbar-actions [data-action="open-create-booking"] {
        grid-column: 1 / -1;
      }

      .install-prompt-backdrop {
        align-items: flex-end;
        padding: 18px max(12px, env(safe-area-inset-right)) max(12px, env(safe-area-inset-bottom)) max(12px, env(safe-area-inset-left));
      }

      .install-prompt {
        gap: 13px;
        padding: 15px;
        border-radius: 25px;
      }

      .install-prompt-main {
        grid-template-columns: 52px 1fr;
        gap: 12px;
        padding-right: 30px;
      }

      .install-prompt-logo {
        width: 52px;
        height: 52px;
        border-radius: 16px;
      }

      .install-prompt-title {
        font-size: 18px;
      }

      .install-prompt-actions {
        grid-template-columns: 1fr 1fr;
      }

      .install-prompt-actions button {
        width: 100%;
      }

      .install-prompt-benefits {
        grid-template-columns: 1fr;
      }

      .custom-date-field.weekday-date-field {
        min-width: 0;
      }

      .calendar-scroll {
        max-height: 64dvh;
        min-height: min(520px, 64dvh);
      }

      .calendar-grid.dynamic-rooms {
        min-width: max(620px, calc(74px + (var(--room-count, 4) * 136px)));
        grid-template-columns: 74px repeat(var(--room-count, 4), minmax(136px, 1fr));
      }

      .cal-cell {
        padding: 5px;
      }

      .time-cell {
        font-size: 12px;
      }

      .booking {
        left: 4px;
        right: 4px;
        padding: 6px 7px;
        font-size: 12px;
        border-radius: 10px;
      }

      .calendar-legend {
        gap: 10px;
        font-size: 12px;
      }

      .calendar-more-indicator {
        max-width: calc(100vw - 40px);
        white-space: nowrap;
        font-size: 12px;
      }

      .modal-backdrop {
        padding: 10px;
        align-items: stretch;
      }

      .modal {
        width: 100%;
        max-height: calc(100dvh - 20px);
        border-radius: 18px;
        padding: 16px;
        margin: 0;
      }

      .modal > .stack > .row.space-between:first-child {
        top: -16px;
      }

      .modal > .stack > .row:last-child:not(.space-between) {
        bottom: -16px;
      }
    }


    /* v60: ekstra robust Kontrolpanel-layout til iPad/tablet i portrait-mode */
    @media (pointer: coarse) and (orientation: portrait) and (max-width: 1180px) {
      html,
      body,
      #root,
      .app-shell {
        width: 100%;
        max-width: 100dvw;
      }

      body {
        overflow-x: hidden;
      }

      .app-shell,
      aside,
      main,
      main.admin-main,
      .toolbar,
      .admin-toolbar,
      .admin-panel-stack,
      .admin-panel-stack > *,
      .admin-panel-stack .collapsible-section,
      .admin-panel-stack .section-header,
      .admin-panel-stack .section-content,
      .admin-panel-stack table,
      .admin-panel-stack tbody,
      .admin-panel-stack tr,
      .admin-panel-stack td {
        box-sizing: border-box;
        min-width: 0 !important;
        max-width: 100% !important;
      }

      main.admin-main {
        width: 100%;
        padding-left: max(14px, env(safe-area-inset-left));
        padding-right: max(14px, env(safe-area-inset-right));
        overflow-x: visible;
      }

      .admin-toolbar {
        width: auto;
        margin-left: calc(-1 * max(14px, env(safe-area-inset-left)));
        margin-right: calc(-1 * max(14px, env(safe-area-inset-right)));
        padding-left: max(14px, env(safe-area-inset-left));
        padding-right: max(14px, env(safe-area-inset-right));
      }

      .admin-panel-stack .collapsible-section {
        width: 100%;
        overflow: visible !important;
      }

      .admin-panel-stack .section-header {
        position: relative;
        top: auto;
        width: 100%;
      }

      .admin-panel-stack .section-content {
        width: 100%;
        overflow-x: visible !important;
      }

      .section-title-row,
      .section-title-row > *,
      .section-actions,
      .section-actions > *,
      .toggle-group,
      .row,
      .custom-date-field,
      .custom-date-field.weekday-date-field {
        min-width: 0 !important;
        max-width: 100% !important;
      }

      .custom-date-field.weekday-date-field {
        width: 100% !important;
      }

      .admin-panel-stack table,
      .admin-panel-stack tbody,
      .admin-panel-stack tr,
      .admin-panel-stack td {
        width: 100% !important;
      }

      .admin-panel-stack tr {
        overflow: visible !important;
      }

      .admin-panel-stack td[data-label]:not(.actions-cell) {
        grid-template-columns: minmax(0, 1fr);
        gap: 4px;
      }

      .admin-panel-stack td.actions-cell .row {
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(96px, 1fr));
        width: 100%;
        gap: 8px;
      }

      .admin-panel-stack td.actions-cell button,
      .admin-panel-stack td.actions-cell .secondary,
      .admin-panel-stack td.actions-cell .danger {
        width: 100%;
        min-width: 0 !important;
        max-width: 100% !important;
        justify-content: center;
      }
    }


    /* v63: på touch-devices må kalenderens indre scroll-vindue ikke kunne trækkes vandret rundt.
       Én finger scroller stadig op/ned, mens vandret bevægelse bruges til dato-swipe. */
    @media (hover: none), (pointer: coarse) {
      .calendar,
      .calendar-scroll,
      .calendar-grid,
      .room-cell,
      .booking,
      .booking-resize-handle {
        touch-action: pan-y;
      }

      .calendar-scroll {
        overflow-x: hidden;
        overscroll-behavior-x: none;
        overscroll-behavior-y: contain;
        -webkit-overflow-scrolling: touch;
      }

      .calendar-grid.dynamic-rooms {
        width: 100%;
        min-width: 100%;
        grid-template-columns: clamp(58px, 11vw, 88px) repeat(var(--room-count, 4), minmax(0, 1fr));
      }

      .cal-cell,
      .cal-head,
      .booking {
        min-width: 0;
      }
    }




    /* v69: Mobil-hamburger/menu drawer. Skjult på desktop/tablet. */
    .mobile-menu-button,
    .mobile-menu-panel-head,
    .mobile-menu-backdrop {
      display: none;
    }

    .mobile-menu-panel {
      display: contents;
    }

    /* v67: Mobiltelefon-layout. Kun små touch-skærme, så desktop og tablet/iPad bevares. */
    @media (max-width: 560px) and (pointer: coarse) {
      :root {
        --radius: 16px;
      }

      html,
      body,
      #root {
        width: 100%;
        max-width: 100vw;
        min-height: 100dvh;
        overflow-x: hidden;
      }

      body {
        background: var(--bg);
      }

      .app-shell {
        display: block;
        width: 100%;
        min-height: 100dvh;
        height: auto;
        overflow: visible;
      }

      aside {
        position: sticky;
        top: 0;
        z-index: 70;
        width: 100%;
        height: auto;
        min-height: 0;
        padding: max(8px, env(safe-area-inset-top)) max(10px, env(safe-area-inset-right)) 8px max(10px, env(safe-area-inset-left));
        gap: 8px;
        overflow: visible;
        border-right: 0;
        border-bottom: 1px solid rgba(226, 232, 240, .82);
        background: rgba(255, 255, 255, .94);
        backdrop-filter: blur(18px) saturate(1.08);
        -webkit-backdrop-filter: blur(18px) saturate(1.08);
        box-shadow: 0 10px 24px rgba(15, 23, 42, .08);
      }

      body.dark-theme aside {
        background: rgba(31, 41, 55, .94);
        border-bottom-color: rgba(55, 65, 81, .82);
        box-shadow: 0 10px 26px rgba(0, 0, 0, .28);
      }

      .brand-row {
        align-items: center;
        gap: 8px;
      }

      .brand {
        gap: 9px;
        font-size: 17px;
        min-width: 0;
      }

      .brand-mark {
        width: 34px;
        height: 34px;
        flex-basis: 34px;
        border-radius: 12px;
      }

      .brand-title > div:first-child {
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
      }

      .brand-subtitle {
        display: none;
      }

      .brand-theme-button {
        width: 36px;
        height: 36px;
        min-width: 36px;
        min-height: 36px;
        max-width: 36px;
        max-height: 36px;
        border-radius: 999px;
      }

      .sidebar-bottom,
      .sidebar-note {
        display: none !important;
      }

      .user-card {
        margin: 0;
        padding: 7px 8px;
        border-radius: 999px;
        display: flex;
        align-items: center;
        gap: 8px;
        background: rgba(248, 250, 252, .72);
        box-shadow: none;
      }

      body.dark-theme .user-card {
        background: rgba(17, 24, 39, .48);
      }

      .user-card-head {
        flex: 1 1 auto;
        min-width: 0;
        min-height: 0;
        gap: 7px;
      }

      .user-meta {
        min-width: 0;
        display: flex;
        align-items: center;
        gap: 7px;
      }

      .user-name {
        max-width: 52vw;
        overflow: hidden;
        white-space: nowrap;
        text-overflow: ellipsis;
        font-size: 13px;
        line-height: 1.1;
      }

      .role-badge {
        min-height: 18px;
        padding: 2px 7px;
        margin: 0;
        font-size: 10px;
        white-space: nowrap;
      }

      .user-avatar {
        display: none;
      }

      .user-card-footer {
        padding: 0;
        border-top: 0;
        flex: 0 0 auto;
      }

      .logout-button {
        width: auto;
        height: 32px;
        min-height: 32px;
        padding: 0 11px;
        border-radius: 999px;
        font-size: 12px;
      }

      .nav {
        position: fixed;
        left: 0;
        right: 0;
        bottom: 0;
        z-index: 90;
        display: flex;
        gap: 6px;
        margin: 0;
        padding: 7px max(9px, env(safe-area-inset-right)) calc(7px + env(safe-area-inset-bottom)) max(9px, env(safe-area-inset-left));
        overflow-x: auto;
        overscroll-behavior-x: contain;
        scrollbar-width: none;
        background: rgba(255, 255, 255, .95);
        border-top: 1px solid rgba(226, 232, 240, .92);
        box-shadow: 0 -14px 32px rgba(15, 23, 42, .12);
        backdrop-filter: blur(20px) saturate(1.1);
        -webkit-backdrop-filter: blur(20px) saturate(1.1);
      }

      .nav::-webkit-scrollbar {
        display: none;
      }

      body.dark-theme .nav {
        background: rgba(31, 41, 55, .96);
        border-top-color: rgba(55, 65, 81, .92);
        box-shadow: 0 -16px 36px rgba(0, 0, 0, .34);
      }

      .nav button {
        flex: 0 0 72px;
        width: 72px;
        min-width: 72px;
        min-height: 54px;
        height: 54px;
        border-radius: 16px;
        padding: 6px 5px 5px;
        flex-direction: column;
        justify-content: center;
        gap: 3px;
        font-size: 11px;
        line-height: 1.08;
        text-align: center;
        white-space: normal;
      }

      .nav button::before {
        width: auto;
        height: 21px;
        flex: 0 0 21px;
        font-size: 18px;
      }

      .nav button.active {
        box-shadow: none;
        background: #eef2ff;
      }

      body.dark-theme .nav button.active {
        background: rgba(96, 165, 250, .16);
      }

      main {
        width: 100%;
        height: auto;
        min-height: calc(100dvh - 124px);
        padding: 10px max(10px, env(safe-area-inset-right)) calc(86px + env(safe-area-inset-bottom)) max(10px, env(safe-area-inset-left));
        overflow: visible;
      }

      main.my-main {
        display: block;
        min-height: calc(100dvh - 124px);
        overflow: visible;
      }

      main.admin-main {
        padding-top: 0;
      }

      main > .toolbar,
      .toolbar {
        min-height: 0;
        margin-bottom: 10px;
        gap: 9px;
      }

      .toolbar > div:first-child > .muted,
      .section-subtitle {
        font-size: 12px;
        line-height: 1.25;
      }

      .title-row {
        min-height: 0;
        gap: 9px;
        align-items: center;
      }

      .title-row .history-controls {
        margin-left: 0;
      }

      .title-row h1,
      .section-title-row h1 {
        font-size: 22px;
        letter-spacing: -.035em;
      }

      .history-controls {
        transform: scale(.9);
        transform-origin: left center;
      }

      .card {
        padding: 13px;
        border-radius: 16px;
      }

      .calendar-toolbar {
        gap: 9px;
      }

      .calendar-title-row {
        justify-content: space-between;
      }

      .calendar-day-badge {
        margin-left: 0;
        margin-top: 0;
        font-size: 12px;
        gap: 6px;
      }

      .calendar-toolbar-actions {
        grid-template-columns: minmax(0, 1fr) 42px minmax(128px, 1.25fr) 42px;
        gap: 7px;
      }

      .calendar-toolbar-actions [data-action="open-create-booking"] {
        grid-column: 1 / -1;
        min-height: 42px;
      }

      .calendar-toolbar-actions button,
      .calendar-toolbar-actions .custom-date-field,
      .calendar-toolbar-actions input {
        min-height: 42px;
        font-size: 13px;
      }

      .calendar-toolbar-actions .icon-button {
        width: 42px;
        min-width: 42px;
        height: 42px;
      }

      .custom-date-field {
        border-radius: 999px;
      }

      .custom-date-field input {
        padding-left: 10px;
        padding-right: 30px;
      }

      .calendar {
        border-radius: 16px;
        box-shadow: 0 10px 26px rgba(15, 23, 42, .08);
      }

      .calendar-scroll {
        max-height: 61dvh;
        min-height: min(500px, 61dvh);
        scrollbar-width: none;
      }

      .calendar-scroll::-webkit-scrollbar {
        display: none;
      }

      .calendar-grid.dynamic-rooms {
        width: 100%;
        min-width: 100%;
        grid-template-columns: clamp(48px, 13vw, 54px) repeat(var(--room-count, 4), minmax(0, 1fr));
      }

      .cal-head {
        min-height: 62px;
        padding: 4px 4px 6px;
        font-size: 11.5px;
        line-height: 1.12;
      }

      .time-head {
        padding-bottom: 7px;
      }

      .time-cell {
        font-size: 11px;
        padding: 5px 3px;
      }

      .cal-cell {
        padding: 4px;
      }

      .booking {
        left: 3px;
        right: 3px;
        padding: 5px 5px;
        border-radius: 9px;
        font-size: 10.8px;
        line-height: 1.14;
        letter-spacing: 0;
        box-shadow: 0 3px 9px rgba(0,0,0,.10);
      }

      .booking-content-lines {
        gap: 1px;
      }

      .booking-main-line {
        gap: 4px;
      }

      .booking-calendar-time {
        font-size: .86em;
      }

      .booking.booking-short {
        padding: 2px 5px;
        border-radius: 8px;
      }

      .booking.booking-short .booking-calendar-time {
        display: none;
      }

      .booking.booking-short .booking-calendar-title {
        flex: 1 1 auto;
        max-width: 100%;
      }

      .booking-note-line {
        display: none;
      }

      .booking-cancelled-label {
        font-size: 9px;
        padding: 2px 5px;
      }

      .room-closure-block {
        left: 3px;
        right: 3px;
        padding: 4px;
        border-radius: 9px;
        font-size: 10px;
      }

      .calendar-swipe-feedback {
        top: 70px;
        left: 8px;
        right: 8px;
      }

      .calendar-swipe-pill {
        padding: 7px 9px;
        font-size: 12px;
      }

      .calendar-date-edge-cue {
        top: 68px;
        width: 58px;
      }

      .calendar-date-edge-cue-card {
        padding: 8px 6px;
        min-width: 52px;
      }

      .date-edge-cue-label {
        display: none;
      }

      .calendar-more-indicator {
        bottom: 9px;
        max-width: calc(100vw - 36px);
        padding: 7px 10px;
        font-size: 11px;
      }

      .calendar-legend {
        margin-top: 10px;
        gap: 8px;
        padding: 10px;
        font-size: 11.5px;
        border-radius: 15px;
      }

      .legend-item {
        gap: 5px;
      }

      .dot {
        width: 10px;
        height: 10px;
      }

      .my-bookings-section {
        max-height: none;
        overflow: visible;
        display: block;
      }

      .my-bookings-section .section-header {
        padding: 12px;
        border-radius: 15px 15px 0 0;
      }

      .my-section-header {
        gap: 10px;
      }

      .my-section-top,
      .my-filter-actions,
      .section-actions {
        width: 100%;
        min-width: 0;
      }

      .my-filter-actions {
        display: grid;
        gap: 8px;
      }

      .my-filter-actions > button {
        width: 100%;
      }

      .toggle-group {
        width: 100%;
        overflow-x: auto;
        scrollbar-width: none;
      }

      .toggle-group::-webkit-scrollbar {
        display: none;
      }

      .toggle-group button {
        min-height: 36px;
        padding: 8px 10px;
        font-size: 12px;
      }

      .my-bookings-head-table {
        display: none;
      }

      .my-bookings-section .section-content {
        overflow: visible;
        padding: 10px;
      }

      .my-bookings-table,
      .my-bookings-table tbody,
      .my-bookings-table tr,
      .my-bookings-table td {
        display: block;
        width: 100%;
        min-width: 0;
      }

      .my-bookings-table {
        min-width: 0;
        background: transparent;
        border-radius: 0;
        overflow: visible;
      }

      .my-bookings-table tr {
        margin: 0 0 10px;
        padding: 11px;
        border: 1px solid var(--line);
        border-radius: 15px;
        background: var(--panel);
      }

      .my-bookings-table td {
        padding: 5px 0;
        border: 0;
        white-space: normal;
        overflow-wrap: anywhere;
      }

      .my-bookings-table td[data-label]:not(.actions-cell) {
        display: grid;
        grid-template-columns: minmax(82px, 34%) minmax(0, 1fr);
        gap: 8px;
        align-items: start;
      }

      .my-bookings-table td[data-label]::before {
        content: attr(data-label);
        color: var(--muted);
        font-size: 10px;
        font-weight: 950;
        letter-spacing: .05em;
        text-transform: uppercase;
        line-height: 1.35;
      }

      .my-bookings-table td.actions-cell .row {
        display: grid;
        grid-template-columns: 1fr;
        gap: 7px;
        width: 100%;
      }

      .my-bookings-table td.actions-cell button {
        width: 100%;
      }

      .admin-toolbar {
        margin-left: calc(-1 * max(10px, env(safe-area-inset-left)));
        margin-right: calc(-1 * max(10px, env(safe-area-inset-right)));
        padding: 12px max(10px, env(safe-area-inset-right)) 10px max(10px, env(safe-area-inset-left));
      }

      .admin-toolbar .row {
        display: grid;
        grid-template-columns: 1fr;
        width: 100%;
        gap: 8px;
      }

      .admin-toolbar .row button {
        width: 100%;
      }

      .admin-panel-stack {
        gap: 10px;
      }

      .admin-panel-stack .section-header {
        padding: 12px;
        border-radius: 15px 15px 0 0;
      }

      .section-title-row {
        gap: 7px;
      }

      .section-title-row h2 {
        font-size: 18px;
      }

      .collapse-button {
        width: 34px;
        height: 34px;
        min-width: 34px;
        min-height: 34px;
      }

      .admin-panel-stack .section-content {
        padding: 10px;
      }

      .admin-panel-stack tr {
        padding: 11px;
        border-radius: 15px;
      }

      .admin-panel-stack td[data-label]:not(.actions-cell) {
        grid-template-columns: minmax(0, 1fr);
        gap: 3px;
      }

      .admin-panel-stack td.actions-cell .row {
        grid-template-columns: 1fr;
      }

      .admin-panel-stack td.actions-cell button,
      .admin-panel-stack td.actions-cell .secondary,
      .admin-panel-stack td.actions-cell .danger {
        width: 100%;
      }

      .rules-grid,
      .stats-grid,
      .stat-grid-2,
      .grid-2,
      .grid-3,
      .booking-confirm-grid {
        grid-template-columns: 1fr;
      }

      .rule-card,
      .stat-card {
        padding: 13px;
      }

      .rule-list {
        font-size: 13px;
        line-height: 1.42;
      }

      .stat-value {
        font-size: 24px;
      }

      .profile-section,
      main > .card {
        max-width: 100% !important;
      }

      input,
      select,
      textarea {
        font-size: 16px;
        border-radius: 12px;
      }

      label {
        font-size: 13px;
      }

      .modal-backdrop {
        padding: max(8px, env(safe-area-inset-top)) max(8px, env(safe-area-inset-right)) max(8px, env(safe-area-inset-bottom)) max(8px, env(safe-area-inset-left));
        align-items: stretch;
      }

      .modal {
        width: 100%;
        max-height: calc(100dvh - 16px);
        padding: 14px;
        border-radius: 18px;
      }

      .modal > .stack > .row.space-between:first-child {
        top: -14px;
        margin-left: -14px;
        margin-right: -14px;
        padding-left: 14px;
        padding-right: 14px;
      }

      .modal > .stack > .row:last-child:not(.space-between) {
        bottom: -14px;
        margin-left: -14px;
        margin-right: -14px;
        padding-left: 14px;
        padding-right: 14px;
      }

      .install-prompt {
        border-radius: 23px;
        padding: 13px;
      }

      .install-prompt-main {
        grid-template-columns: 48px 1fr;
        gap: 10px;
        padding-right: 26px;
      }

      .install-prompt-logo {
        width: 48px;
        height: 48px;
        border-radius: 15px;
      }

      .install-prompt-title {
        font-size: 17px;
      }

      .install-prompt-actions {
        grid-template-columns: 1fr;
      }
    }

    @media (max-width: 380px) and (pointer: coarse) {
      .nav button {
        flex-basis: 66px;
        width: 66px;
        min-width: 66px;
        font-size: 10.5px;
      }

      .calendar-toolbar-actions {
        grid-template-columns: minmax(0, 1fr) 40px minmax(112px, 1fr) 40px;
        gap: 6px;
      }

      .calendar-grid.dynamic-rooms {
        grid-template-columns: 46px repeat(var(--room-count, 4), minmax(0, 1fr));
      }

      .booking {
        font-size: 10px;
        padding: 4px;
      }

      .time-cell {
        font-size: 10px;
      }
    }



    /* v69: Mobiltelefon-navigation som hamburger-drawer i stedet for bundbar */
    @media (max-width: 560px) and (pointer: coarse) {
      aside {
        min-height: 0;
        display: block;
      }

      .brand-row {
        display: grid;
        grid-template-columns: auto minmax(0, 1fr) auto auto;
        gap: 8px;
        align-items: center;
      }

      .brand-row .brand {
        grid-column: 1 / span 2;
      }

      .mobile-menu-button {
        display: inline-flex;
        width: 38px;
        height: 38px;
        min-width: 38px;
        min-height: 38px;
        align-items: center;
        justify-content: center;
        border-radius: 999px;
        padding: 0;
        background: rgba(248, 250, 252, .92);
        border: 1px solid var(--line);
        color: var(--text);
        box-shadow: 0 8px 20px rgba(15, 23, 42, .08);
      }

      .mobile-menu-button svg {
        width: 20px;
        height: 20px;
        stroke: currentColor;
        stroke-width: 2.2;
        stroke-linecap: round;
      }

      body.dark-theme .mobile-menu-button {
        background: rgba(17, 24, 39, .72);
        border-color: rgba(148, 163, 184, .28);
      }

      .brand-theme-button {
        grid-column: 4;
      }

      aside.mobile-menu-open {
        z-index: 180;
      }

      .mobile-menu-panel {
        display: grid;
        grid-template-rows: auto auto minmax(0, 1fr) auto;
        gap: 12px;
        position: fixed;
        z-index: 190;
        top: 0;
        left: 0;
        bottom: 0;
        width: min(340px, 88vw);
        max-width: calc(100vw - 26px);
        padding: max(14px, env(safe-area-inset-top)) 14px max(14px, env(safe-area-inset-bottom)) max(14px, env(safe-area-inset-left));
        background: rgba(255, 255, 255, .98);
        border-right: 1px solid rgba(226, 232, 240, .92);
        box-shadow: 22px 0 44px rgba(15, 23, 42, .18);
        backdrop-filter: blur(22px) saturate(1.12);
        -webkit-backdrop-filter: blur(22px) saturate(1.12);
        transform: translate3d(calc(-100% - 28px), 0, 0);
        transition: transform .28s cubic-bezier(.2, .8, .2, 1);
        overflow-y: auto;
        overscroll-behavior: contain;
      }

      body.dark-theme .mobile-menu-panel {
        background: rgba(31, 41, 55, .98);
        border-right-color: rgba(55, 65, 81, .92);
        box-shadow: 24px 0 48px rgba(0, 0, 0, .36);
      }

      aside.mobile-menu-open .mobile-menu-panel,
      body.mobile-menu-lock .mobile-menu-panel {
        transform: translate3d(0, 0, 0);
      }

      .mobile-menu-panel-head {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 12px;
        padding-bottom: 4px;
      }

      .mobile-menu-panel-brand {
        display: inline-flex;
        align-items: center;
        gap: 9px;
        min-width: 0;
        font-weight: 900;
      }

      .mobile-menu-panel-brand img {
        width: 34px;
        height: 34px;
        border-radius: 12px;
        object-fit: cover;
        display: block;
      }

      .mobile-menu-panel-brand span {
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
      }

      .mobile-menu-close {
        width: 36px;
        height: 36px;
        min-width: 36px;
        min-height: 36px;
        border-radius: 999px;
        padding: 0;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        background: rgba(248, 250, 252, .8);
        border: 1px solid var(--line);
        color: var(--text);
      }

      body.dark-theme .mobile-menu-close {
        background: rgba(17, 24, 39, .6);
        border-color: rgba(148, 163, 184, .26);
      }

      .mobile-menu-close svg {
        width: 19px;
        height: 19px;
        stroke: currentColor;
        stroke-width: 2.2;
        stroke-linecap: round;
      }

      .mobile-menu-backdrop {
        display: block;
        position: fixed;
        inset: 0;
        z-index: 125;
        background: rgba(15, 23, 42, .30);
        opacity: 0;
        pointer-events: none;
        transition: opacity .22s ease;
        backdrop-filter: blur(2px);
        -webkit-backdrop-filter: blur(2px);
      }

      .mobile-menu-backdrop.open {
        opacity: 1;
        pointer-events: auto;
      }

      .nav {
        position: static;
        left: auto;
        right: auto;
        bottom: auto;
        z-index: auto;
        display: grid;
        gap: 7px;
        margin: 0;
        padding: 0;
        overflow: visible;
        background: transparent;
        border-top: 0;
        box-shadow: none;
        backdrop-filter: none;
        -webkit-backdrop-filter: none;
      }

      body.dark-theme .nav {
        background: transparent;
        border-top: 0;
        box-shadow: none;
      }

      .nav button {
        width: 100%;
        min-width: 0;
        min-height: 48px;
        height: auto;
        flex: initial;
        border-radius: 16px;
        padding: 11px 12px;
        flex-direction: row;
        justify-content: flex-start;
        gap: 10px;
        font-size: 14px;
        line-height: 1.15;
        text-align: left;
        white-space: nowrap;
      }

      .nav button::before {
        width: 28px;
        height: 28px;
        flex: 0 0 28px;
        font-size: 16px;
      }

      .nav button.active {
        box-shadow: inset 4px 0 0 #2563eb;
      }

      .nav button:hover {
        transform: none;
      }

      .mobile-menu-panel .user-card {
        margin-top: 2px;
        display: grid;
        gap: 10px;
        padding: 12px;
        border-radius: 18px;
      }

      .mobile-menu-panel .user-card-head {
        min-height: 36px;
      }

      .mobile-menu-panel .user-meta {
        display: grid;
        align-content: center;
        gap: 3px;
      }

      .mobile-menu-panel .user-name {
        max-width: 100%;
        font-size: 14px;
      }

      .mobile-menu-panel .role-badge {
        width: fit-content;
        margin: 0;
      }

      .mobile-menu-panel .user-avatar {
        display: grid;
      }

      .mobile-menu-panel .user-card-footer {
        padding-top: 10px;
        border-top: 1px solid var(--line);
      }

      .mobile-menu-panel .logout-button {
        width: 100%;
        min-height: 40px;
        height: 40px;
        font-size: 13px;
      }

      .mobile-menu-panel .sidebar-bottom,
      .mobile-menu-panel .sidebar-note {
        display: grid !important;
      }

      main {
        padding-bottom: max(14px, env(safe-area-inset-bottom));
      }

      body.mobile-menu-lock,
      body.mobile-menu-lock .app-shell {
        overflow: hidden;
      }
    }


    /* v71: Mobilmenuen samles som én app-bar/drawer-enhed, så panelet ikke kan ende bag sløringen. */
    @media (max-width: 560px) and (pointer: coarse) {
      .brand-row {
        display: grid !important;
        grid-template-columns: minmax(0, 1fr) 42px 42px !important;
        align-items: center !important;
        gap: 8px !important;
        min-height: 50px;
      }

      .brand-row .brand {
        grid-column: 1 !important;
        min-width: 0;
      }

      .brand-row .brand-title {
        min-width: 0;
      }

      .brand-row .brand-title > div:first-child,
      .brand-row .brand-subtitle {
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
      }

      .brand-row .mobile-menu-button {
        grid-column: 2 !important;
        grid-row: 1 !important;
      }

      .brand-row > .brand-theme-button:not(.mobile-menu-theme) {
        grid-column: 3 !important;
        grid-row: 1 !important;
      }

      aside.mobile-menu-open {
        position: fixed !important;
        inset: 0 !important;
        z-index: 260 !important;
        width: 100vw !important;
        max-width: 100vw !important;
        height: 100dvh !important;
        min-height: 100dvh !important;
        padding: 0 !important;
        border: 0 !important;
        background: transparent !important;
        box-shadow: none !important;
        overflow: hidden !important;
        backdrop-filter: none !important;
        -webkit-backdrop-filter: none !important;
      }

      aside.mobile-menu-open > .brand-row {
        display: none !important;
      }

      .mobile-menu-backdrop {
        z-index: 230 !important;
      }

      .mobile-menu-panel {
        position: fixed !important;
        top: 0 !important;
        left: 0 !important;
        bottom: 0 !important;
        z-index: 270 !important;
        width: min(360px, 92vw) !important;
        max-width: none !important;
        height: 100dvh !important;
        max-height: 100dvh !important;
        display: grid !important;
        grid-template-rows: auto auto minmax(0, 1fr) auto !important;
        gap: 12px !important;
        padding: max(12px, env(safe-area-inset-top)) 12px max(14px, env(safe-area-inset-bottom)) max(12px, env(safe-area-inset-left)) !important;
        overflow-y: auto !important;
        overflow-x: hidden !important;
        overscroll-behavior: contain !important;
        transform: translate3d(calc(-100% - 18px), 0, 0) !important;
        transition: transform .30s cubic-bezier(.2, .8, .2, 1) !important;
        background: rgba(255, 255, 255, .985) !important;
        border-right: 1px solid rgba(226, 232, 240, .96) !important;
        box-shadow: 24px 0 54px rgba(15, 23, 42, .22) !important;
        backdrop-filter: blur(24px) saturate(1.12) !important;
        -webkit-backdrop-filter: blur(24px) saturate(1.12) !important;
      }

      body.dark-theme .mobile-menu-panel {
        background: rgba(17, 24, 39, .985) !important;
        border-right-color: rgba(71, 85, 105, .72) !important;
        box-shadow: 26px 0 56px rgba(0, 0, 0, .42) !important;
      }

      aside.mobile-menu-open .mobile-menu-panel,
      body.mobile-menu-lock .mobile-menu-panel {
        transform: translate3d(0, 0, 0) !important;
      }

      .mobile-menu-panel-head {
        display: grid !important;
        grid-template-columns: minmax(0, 1fr) 42px 42px !important;
        align-items: center !important;
        gap: 8px !important;
        min-height: 52px;
        padding: 6px 0 8px !important;
        border-bottom: 1px solid rgba(226, 232, 240, .78);
      }

      body.dark-theme .mobile-menu-panel-head {
        border-bottom-color: rgba(71, 85, 105, .68);
      }

      .mobile-menu-panel-brand {
        min-width: 0;
      }

      .mobile-menu-panel-brand img {
        width: 38px !important;
        height: 38px !important;
        border-radius: 13px !important;
        flex: 0 0 38px;
      }

      .mobile-menu-panel-brand span {
        font-size: 21px;
        line-height: 1;
      }

      .mobile-menu-theme,
      .mobile-menu-close {
        grid-column: auto !important;
        width: 42px !important;
        height: 42px !important;
        min-width: 42px !important;
        min-height: 42px !important;
        border-radius: 999px !important;
        padding: 0 !important;
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
      }

      .mobile-menu-theme {
        font-size: 20px !important;
      }

      .mobile-menu-panel .nav {
        position: static !important;
        inset: auto !important;
        z-index: auto !important;
        display: grid !important;
        grid-template-columns: 1fr !important;
        gap: 8px !important;
        margin: 0 !important;
        padding: 0 !important;
        width: 100% !important;
        overflow: visible !important;
        background: transparent !important;
        border: 0 !important;
        box-shadow: none !important;
        backdrop-filter: none !important;
        -webkit-backdrop-filter: none !important;
      }

      .mobile-menu-panel .nav button {
        width: 100% !important;
        min-width: 0 !important;
        height: auto !important;
        min-height: 50px !important;
        flex: initial !important;
        border-radius: 16px !important;
        padding: 11px 12px !important;
        display: flex !important;
        flex-direction: row !important;
        align-items: center !important;
        justify-content: flex-start !important;
        gap: 10px !important;
        text-align: left !important;
        white-space: nowrap !important;
        font-size: 14px !important;
        line-height: 1.15 !important;
      }

      .mobile-menu-panel .nav button::before {
        width: 28px !important;
        height: 28px !important;
        flex: 0 0 28px !important;
        font-size: 16px !important;
      }

      .mobile-menu-panel .nav button.active {
        box-shadow: inset 4px 0 0 #2563eb !important;
      }

      body.mobile-menu-lock {
        overflow: hidden !important;
        touch-action: none;
      }

      body.mobile-menu-lock .mobile-menu-panel,
      body.mobile-menu-lock .mobile-menu-backdrop {
        touch-action: pan-y;
      }
    }



    /* v71: Finjusteret mobilmenu-top og kompakt brugerfelt */
    @media (max-width: 560px) and (pointer: coarse) {
      aside:not(.mobile-menu-open) .brand-row {
        min-height: 50px !important;
      }

      aside:not(.mobile-menu-open) .brand-mark,
      aside:not(.mobile-menu-open) .brand-mark img {
        width: 34px !important;
        height: 34px !important;
        flex-basis: 34px !important;
        border-radius: 12px !important;
      }

      aside:not(.mobile-menu-open) .mobile-menu-button,
      aside:not(.mobile-menu-open) .brand-theme-button {
        width: 38px !important;
        height: 38px !important;
        min-width: 38px !important;
        min-height: 38px !important;
        max-width: 38px !important;
        max-height: 38px !important;
      }

      aside.mobile-menu-open .mobile-menu-panel {
        grid-template-rows: 50px auto minmax(0, 1fr) auto !important;
        gap: 10px !important;
        padding-top: max(8px, env(safe-area-inset-top)) !important;
        padding-right: 10px !important;
        padding-left: max(10px, env(safe-area-inset-left)) !important;
      }

      aside.mobile-menu-open .mobile-menu-panel-head {
        min-height: 50px !important;
        height: 50px !important;
        padding: 0 !important;
        display: grid !important;
        grid-template-columns: minmax(0, 1fr) 38px 38px !important;
        gap: 8px !important;
        align-items: center !important;
        border-bottom: 1px solid rgba(226, 232, 240, .70) !important;
      }

      aside.mobile-menu-open .mobile-menu-panel-brand {
        gap: 9px !important;
        min-width: 0 !important;
        height: 50px !important;
        align-items: center !important;
      }

      aside.mobile-menu-open .mobile-menu-panel-brand img {
        width: 34px !important;
        height: 34px !important;
        min-width: 34px !important;
        min-height: 34px !important;
        flex: 0 0 34px !important;
        border-radius: 12px !important;
      }

      aside.mobile-menu-open .mobile-menu-panel-brand span {
        font-size: 19px !important;
        line-height: 1 !important;
        letter-spacing: -.03em !important;
      }

      aside.mobile-menu-open .mobile-menu-theme,
      aside.mobile-menu-open .mobile-menu-close {
        width: 38px !important;
        height: 38px !important;
        min-width: 38px !important;
        min-height: 38px !important;
        max-width: 38px !important;
        max-height: 38px !important;
        font-size: 18px !important;
      }

      aside.mobile-menu-open .mobile-menu-close svg {
        width: 18px !important;
        height: 18px !important;
      }

      aside.mobile-menu-open .mobile-menu-panel .nav {
        gap: 7px !important;
      }

      aside.mobile-menu-open .mobile-menu-panel .nav button {
        min-height: 46px !important;
        padding: 10px 11px !important;
        border-radius: 15px !important;
        font-size: 13.5px !important;
      }

      aside.mobile-menu-open .mobile-menu-panel .nav button::before {
        width: 26px !important;
        height: 26px !important;
        flex-basis: 26px !important;
        font-size: 15px !important;
      }

      aside.mobile-menu-open .mobile-menu-panel .user-card {
        margin-top: 0 !important;
        padding: 8px 9px !important;
        border-radius: 16px !important;
        display: grid !important;
        grid-template-columns: minmax(0, 1fr) auto !important;
        gap: 8px !important;
        align-items: center !important;
      }

      aside.mobile-menu-open .mobile-menu-panel .user-card-head {
        min-height: 0 !important;
        gap: 0 !important;
        min-width: 0 !important;
      }

      aside.mobile-menu-open .mobile-menu-panel .user-meta {
        gap: 3px !important;
        min-width: 0 !important;
      }

      aside.mobile-menu-open .mobile-menu-panel .user-name {
        max-width: 100% !important;
        font-size: 13px !important;
        line-height: 1.05 !important;
      }

      aside.mobile-menu-open .mobile-menu-panel .role-badge {
        min-height: 17px !important;
        padding: 2px 7px !important;
        font-size: 9.5px !important;
        line-height: 1 !important;
      }

      aside.mobile-menu-open .mobile-menu-panel .user-avatar {
        display: none !important;
      }

      aside.mobile-menu-open .mobile-menu-panel .user-card-footer {
        padding: 0 !important;
        border-top: 0 !important;
        min-width: max-content !important;
      }

      aside.mobile-menu-open .mobile-menu-panel .logout-button {
        width: auto !important;
        min-width: 0 !important;
        height: 32px !important;
        min-height: 32px !important;
        padding: 0 11px !important;
        border-radius: 999px !important;
        font-size: 12px !important;
        line-height: 1 !important;
      }
    }



    /* v72: Mobilmenu-top matcher topbjælken, og bruger/log ud-feltet er kompakt. */
    @media (max-width: 560px) and (pointer: coarse) {
      :root {
        --mobile-bar-height: 50px;
        --mobile-bar-icon: 38px;
        --mobile-logo-size: 34px;
      }

      aside:not(.mobile-menu-open) .brand-row {
        min-height: var(--mobile-bar-height) !important;
        height: var(--mobile-bar-height) !important;
      }

      aside.mobile-menu-open .mobile-menu-panel {
        grid-template-rows: var(--mobile-bar-height) auto auto !important;
        align-content: start !important;
        align-items: start !important;
        row-gap: 8px !important;
        padding: 0 max(10px, env(safe-area-inset-right)) max(10px, env(safe-area-inset-bottom)) max(10px, env(safe-area-inset-left)) !important;
        overflow-y: auto !important;
      }

      aside.mobile-menu-open .mobile-menu-panel-head {
        box-sizing: border-box !important;
        height: var(--mobile-bar-height) !important;
        min-height: var(--mobile-bar-height) !important;
        max-height: var(--mobile-bar-height) !important;
        padding: 0 !important;
        margin: 0 !important;
        display: grid !important;
        grid-template-columns: minmax(0, 1fr) var(--mobile-bar-icon) var(--mobile-bar-icon) !important;
        align-items: center !important;
        gap: 8px !important;
        border-bottom: 1px solid rgba(226, 232, 240, .70) !important;
      }

      body.dark-theme aside.mobile-menu-open .mobile-menu-panel-head {
        border-bottom-color: rgba(71, 85, 105, .68) !important;
      }

      aside.mobile-menu-open .mobile-menu-panel-brand {
        height: var(--mobile-bar-height) !important;
        min-height: 0 !important;
        display: inline-flex !important;
        align-items: center !important;
        gap: 9px !important;
        min-width: 0 !important;
      }

      aside.mobile-menu-open .mobile-menu-panel-brand img,
      aside:not(.mobile-menu-open) .brand-mark,
      aside:not(.mobile-menu-open) .brand-mark img {
        width: var(--mobile-logo-size) !important;
        height: var(--mobile-logo-size) !important;
        min-width: var(--mobile-logo-size) !important;
        min-height: var(--mobile-logo-size) !important;
        max-width: var(--mobile-logo-size) !important;
        max-height: var(--mobile-logo-size) !important;
        flex: 0 0 var(--mobile-logo-size) !important;
        border-radius: 12px !important;
      }

      aside.mobile-menu-open .mobile-menu-panel-brand span {
        font-size: 19px !important;
        line-height: 1 !important;
        letter-spacing: -.03em !important;
      }

      aside.mobile-menu-open .mobile-menu-theme,
      aside.mobile-menu-open .mobile-menu-close,
      aside:not(.mobile-menu-open) .mobile-menu-button,
      aside:not(.mobile-menu-open) .brand-theme-button {
        width: var(--mobile-bar-icon) !important;
        height: var(--mobile-bar-icon) !important;
        min-width: var(--mobile-bar-icon) !important;
        min-height: var(--mobile-bar-icon) !important;
        max-width: var(--mobile-bar-icon) !important;
        max-height: var(--mobile-bar-icon) !important;
        padding: 0 !important;
      }

      aside.mobile-menu-open .mobile-menu-close svg {
        width: 18px !important;
        height: 18px !important;
      }

      aside.mobile-menu-open .mobile-menu-panel .nav {
        align-self: start !important;
        gap: 7px !important;
        margin-top: 4px !important;
      }

      aside.mobile-menu-open .mobile-menu-panel .nav button {
        min-height: 44px !important;
        padding: 9px 11px !important;
        border-radius: 14px !important;
        font-size: 13.5px !important;
      }

      aside.mobile-menu-open .mobile-menu-panel .nav button::before {
        width: 25px !important;
        height: 25px !important;
        flex-basis: 25px !important;
        font-size: 15px !important;
      }

      aside.mobile-menu-open .mobile-menu-panel .user-card {
        grid-row: auto !important;
        align-self: start !important;
        justify-self: stretch !important;
        margin: 4px 0 0 !important;
        padding: 8px 10px !important;
        width: 100% !important;
        min-height: 0 !important;
        height: auto !important;
        max-height: none !important;
        display: grid !important;
        grid-template-columns: minmax(0, 1fr) auto !important;
        align-items: center !important;
        gap: 8px !important;
        border-radius: 15px !important;
      }

      aside.mobile-menu-open .mobile-menu-panel .user-card-head {
        min-height: 0 !important;
        height: auto !important;
        gap: 0 !important;
        display: block !important;
        min-width: 0 !important;
      }

      aside.mobile-menu-open .mobile-menu-panel .user-meta {
        display: grid !important;
        gap: 3px !important;
        min-width: 0 !important;
      }

      aside.mobile-menu-open .mobile-menu-panel .user-name {
        font-size: 13px !important;
        line-height: 1.05 !important;
        max-width: 100% !important;
      }

      aside.mobile-menu-open .mobile-menu-panel .role-badge {
        min-height: 16px !important;
        padding: 2px 7px !important;
        font-size: 9.5px !important;
        line-height: 1 !important;
        margin: 0 !important;
      }

      aside.mobile-menu-open .mobile-menu-panel .user-avatar {
        display: none !important;
      }

      aside.mobile-menu-open .mobile-menu-panel .user-card-footer {
        padding: 0 !important;
        border-top: 0 !important;
        min-width: max-content !important;
      }

      aside.mobile-menu-open .mobile-menu-panel .logout-button {
        width: auto !important;
        height: 32px !important;
        min-height: 32px !important;
        padding: 0 11px !important;
        border-radius: 999px !important;
        font-size: 12px !important;
        line-height: 1 !important;
      }

      aside.mobile-menu-open .mobile-menu-panel .sidebar-bottom,
      aside.mobile-menu-open .mobile-menu-panel .sidebar-note {
        display: none !important;
      }
    }


    /* v75: Mobilmenu fast bundbruger, lavere menu-top og mere læsbar mobilkalender. */
    @media (max-width: 560px) and (pointer: coarse) {
      :root {
        --mobile-open-menu-bar-height: 54px;
      }

      aside.mobile-menu-open .mobile-menu-panel {
        display: flex !important;
        flex-direction: column !important;
        grid-template-rows: none !important;
        gap: 8px !important;
        padding: 0 max(10px, env(safe-area-inset-right)) max(10px, env(safe-area-inset-bottom)) max(10px, env(safe-area-inset-left)) !important;
        height: 100dvh !important;
        max-height: 100dvh !important;
        overflow: hidden !important;
      }

      aside.mobile-menu-open .mobile-menu-panel-head {
        flex: 0 0 var(--mobile-open-menu-bar-height) !important;
        height: var(--mobile-open-menu-bar-height) !important;
        min-height: var(--mobile-open-menu-bar-height) !important;
        max-height: var(--mobile-open-menu-bar-height) !important;
        box-sizing: border-box !important;
        margin: 0 calc(-1 * max(10px, env(safe-area-inset-right))) 2px calc(-1 * max(10px, env(safe-area-inset-left))) !important;
        padding: 0 max(10px, env(safe-area-inset-right)) 0 max(10px, env(safe-area-inset-left)) !important;
        display: grid !important;
        grid-template-columns: minmax(0, 1fr) 38px 38px !important;
        align-items: center !important;
        gap: 8px !important;
        border-bottom: 1px solid rgba(226, 232, 240, .70) !important;
      }

      aside.mobile-menu-open .mobile-menu-panel-brand {
        height: var(--mobile-open-menu-bar-height) !important;
        min-height: 0 !important;
        display: flex !important;
        align-items: center !important;
        gap: 9px !important;
      }

      aside.mobile-menu-open .mobile-menu-panel-brand img {
        width: 34px !important;
        height: 34px !important;
        min-width: 34px !important;
        min-height: 34px !important;
        max-width: 34px !important;
        max-height: 34px !important;
        flex: 0 0 34px !important;
        border-radius: 12px !important;
      }

      aside.mobile-menu-open .mobile-menu-panel-brand span {
        font-size: 18px !important;
        line-height: 1 !important;
      }

      aside.mobile-menu-open .mobile-menu-theme,
      aside.mobile-menu-open .mobile-menu-close {
        width: 38px !important;
        height: 38px !important;
        min-width: 38px !important;
        min-height: 38px !important;
        max-width: 38px !important;
        max-height: 38px !important;
        padding: 0 !important;
        font-size: 18px !important;
      }

      aside.mobile-menu-open .mobile-menu-close svg {
        width: 18px !important;
        height: 18px !important;
      }

      aside.mobile-menu-open .mobile-menu-panel .nav {
        flex: 0 1 auto !important;
        min-height: 0 !important;
        overflow-y: auto !important;
        overscroll-behavior: contain !important;
        gap: 7px !important;
        padding: 0 0 6px !important;
        scrollbar-width: none !important;
      }

      aside.mobile-menu-open .mobile-menu-panel .nav::-webkit-scrollbar {
        display: none !important;
      }

      aside.mobile-menu-open .mobile-menu-panel .user-card {
        flex: 0 0 auto !important;
        margin: auto 0 0 !important;
        padding: 8px 9px !important;
        border-radius: 16px !important;
        display: grid !important;
        grid-template-columns: minmax(0, 1fr) auto !important;
        align-items: center !important;
        gap: 8px !important;
        width: 100% !important;
        min-height: 0 !important;
        height: auto !important;
        max-height: none !important;
      }

      .calendar {
        overflow: visible !important;
      }

      .calendar-scroll {
        max-height: calc(100dvh - 258px) !important;
        min-height: min(430px, calc(100dvh - 258px)) !important;
      }

      .calendar-grid.dynamic-rooms {
        grid-template-columns: clamp(42px, 11vw, 50px) repeat(var(--room-count, 4), minmax(0, 1fr)) !important;
      }

      .cal-head {
        min-height: 58px !important;
        padding: 3px 3px 5px !important;
        align-items: center !important;
        justify-content: center !important;
      }

      .room-head-content {
        min-height: 50px !important;
        grid-template-rows: minmax(18px, auto) auto !important;
        align-content: center !important;
        justify-items: center !important;
        gap: 4px !important;
        padding-top: 0 !important;
      }

      .room-head-title {
        display: grid !important;
        grid-template-columns: minmax(0, 1fr) !important;
        justify-items: center !important;
        align-items: center !important;
        width: 100% !important;
        line-height: 1.05 !important;
      }

      .room-head-title .room-head-name {
        grid-column: 1 !important;
        justify-self: center !important;
        text-align: center !important;
        max-width: 100% !important;
        font-size: 11px !important;
        line-height: 1.08 !important;
      }

      .room-head-title .status-chip {
        grid-column: 1 !important;
        justify-self: center !important;
        margin-top: 2px !important;
        font-size: 8px !important;
        padding: 1px 5px !important;
      }

      .room-head-facilities {
        min-height: 18px !important;
        margin-top: 0 !important;
      }

      .room-facility-trigger {
        min-height: 22px !important;
        padding: 3px 6px !important;
        gap: 2px !important;
        font-size: 9.5px !important;
        border-width: 1px !important;
        max-width: 100% !important;
      }

      .room-facility-trigger-text {
        font-size: 0 !important;
      }

      .room-facility-trigger-text::after {
        content: "Udstyr";
        font-size: 9.5px !important;
        line-height: 1 !important;
        letter-spacing: 0 !important;
      }

      .room-facility-count {
        display: none !important;
      }

      .room-facility-panel {
        max-width: min(230px, calc(100vw - 20px)) !important;
      }

      .calendar-legend {
        position: sticky !important;
        bottom: max(7px, env(safe-area-inset-bottom)) !important;
        z-index: 28 !important;
        display: grid !important;
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        gap: 6px 8px !important;
        width: 100% !important;
        margin-top: 8px !important;
        padding: 8px 9px !important;
        border-radius: 15px !important;
        background: rgba(255, 255, 255, .94) !important;
        border: 1px solid rgba(226, 232, 240, .92) !important;
        box-shadow: 0 10px 26px rgba(15, 23, 42, .13) !important;
        backdrop-filter: blur(16px) saturate(1.05) !important;
        -webkit-backdrop-filter: blur(16px) saturate(1.05) !important;
        font-size: 10.5px !important;
      }

      body.dark-theme .calendar-legend {
        background: rgba(17, 24, 39, .92) !important;
        border-color: rgba(71, 85, 105, .84) !important;
        box-shadow: 0 12px 28px rgba(0, 0, 0, .34) !important;
      }

      .calendar-legend .legend-item {
        gap: 5px !important;
        min-width: 0 !important;
        white-space: nowrap !important;
      }
    }

    /* v75: Fjern “Handlinger”-overskrift i Mine bookinger på mobil og tablet i portrait. */
    @media (max-width: 560px) and (pointer: coarse), (max-width: 920px) and (orientation: portrait) and (pointer: coarse) {
      .my-bookings-table td.actions-cell {
        padding-top: 6px !important;
      }

      .my-bookings-table td.actions-cell::before {
        content: none !important;
        display: none !important;
      }

      .my-bookings-table td.actions-cell .row {
        margin-top: 0 !important;
      }
    }


    /* v75: Rul mobilmenuens top tilbage til den mere luftige version og flyt menupunkterne lidt ned. */
    @media (max-width: 560px) and (pointer: coarse) {
      aside.mobile-menu-open .mobile-menu-panel {
        display: flex !important;
        flex-direction: column !important;
        gap: 10px !important;
        padding: max(12px, env(safe-area-inset-top)) 12px max(14px, env(safe-area-inset-bottom)) max(12px, env(safe-area-inset-left)) !important;
        height: 100dvh !important;
        max-height: 100dvh !important;
        overflow: hidden !important;
      }

      aside.mobile-menu-open .mobile-menu-panel-head {
        flex: 0 0 auto !important;
        height: auto !important;
        min-height: 52px !important;
        max-height: none !important;
        box-sizing: border-box !important;
        margin: 0 0 8px 0 !important;
        padding: 6px 0 8px !important;
        display: grid !important;
        grid-template-columns: minmax(0, 1fr) 42px 42px !important;
        align-items: center !important;
        gap: 8px !important;
        border-bottom: 1px solid rgba(226, 232, 240, .78) !important;
      }

      body.dark-theme aside.mobile-menu-open .mobile-menu-panel-head {
        border-bottom-color: rgba(71, 85, 105, .68) !important;
      }

      aside.mobile-menu-open .mobile-menu-panel-brand {
        height: auto !important;
        min-height: 52px !important;
        display: flex !important;
        align-items: center !important;
        gap: 10px !important;
        min-width: 0 !important;
      }

      aside.mobile-menu-open .mobile-menu-panel-brand img {
        width: 38px !important;
        height: 38px !important;
        min-width: 38px !important;
        min-height: 38px !important;
        max-width: 38px !important;
        max-height: 38px !important;
        flex: 0 0 38px !important;
        border-radius: 13px !important;
      }

      aside.mobile-menu-open .mobile-menu-panel-brand span {
        font-size: 21px !important;
        line-height: 1 !important;
        letter-spacing: -.03em !important;
      }

      aside.mobile-menu-open .mobile-menu-theme,
      aside.mobile-menu-open .mobile-menu-close {
        width: 42px !important;
        height: 42px !important;
        min-width: 42px !important;
        min-height: 42px !important;
        max-width: 42px !important;
        max-height: 42px !important;
        padding: 0 !important;
        font-size: 20px !important;
      }

      aside.mobile-menu-open .mobile-menu-close svg {
        width: 20px !important;
        height: 20px !important;
      }

      aside.mobile-menu-open .mobile-menu-panel .nav {
        margin-top: 10px !important;
        padding-top: 0 !important;
      }

      aside.mobile-menu-open .mobile-menu-panel .user-card {
        margin-top: auto !important;
      }
    }



    /* v75: Sørg for at den åbne mobilmenus topbjælke bruger hele menuens bredde,
       så tema-vælger og luk-knap ligger længere mod højre med mere luft. */
    @media (max-width: 560px) and (pointer: coarse) {
      aside.mobile-menu-open .mobile-menu-panel {
        align-items: stretch !important;
      }

      aside.mobile-menu-open .mobile-menu-panel-head {
        width: 100% !important;
        max-width: 100% !important;
        justify-self: stretch !important;
        align-self: stretch !important;
        grid-template-columns: minmax(0, 1fr) 38px 38px !important;
        column-gap: 10px !important;
      }

      aside.mobile-menu-open .mobile-menu-panel-brand {
        min-width: 0 !important;
        max-width: 100% !important;
      }
    }



    /* v76: Kalenderforklaring på mobil skal altid være synlig i bunden af skærmen,
       også når browserens topbjælke stadig er synlig. */
    @media (max-width: 560px) and (pointer: coarse) {
      main.calendar-main {
        padding-bottom: calc(82px + env(safe-area-inset-bottom)) !important;
      }

      main.calendar-main .calendar {
        padding-bottom: 8px !important;
        margin-bottom: calc(58px + env(safe-area-inset-bottom)) !important;
      }

      main.calendar-main .calendar-scroll {
        height: clamp(300px, calc(100dvh - 322px), 430px) !important;
        max-height: clamp(300px, calc(100dvh - 322px), 430px) !important;
        min-height: 300px !important;
      }

      main.calendar-main .calendar-legend {
        position: fixed !important;
        left: max(10px, env(safe-area-inset-left)) !important;
        right: max(10px, env(safe-area-inset-right)) !important;
        bottom: max(8px, env(safe-area-inset-bottom)) !important;
        z-index: 42 !important;
        width: auto !important;
        max-width: none !important;
        margin: 0 !important;
        display: grid !important;
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        gap: 6px 8px !important;
        padding: 8px 10px !important;
        border-radius: 16px !important;
        background: rgba(255, 255, 255, .96) !important;
        border: 1px solid rgba(226, 232, 240, .95) !important;
        box-shadow: 0 12px 30px rgba(15, 23, 42, .18) !important;
        backdrop-filter: blur(18px) saturate(1.08) !important;
        -webkit-backdrop-filter: blur(18px) saturate(1.08) !important;
        font-size: 10.5px !important;
      }

      body.dark-theme main.calendar-main .calendar-legend {
        background: rgba(17, 24, 39, .95) !important;
        border-color: rgba(71, 85, 105, .86) !important;
        box-shadow: 0 14px 32px rgba(0, 0, 0, .38) !important;
      }

      main.calendar-main .calendar-legend .legend-item {
        min-width: 0 !important;
        gap: 5px !important;
        white-space: nowrap !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
      }

      main.calendar-main .calendar-legend .dot,
      main.calendar-main .calendar-legend .legend-item > span[style*="border"] {
        width: 10px !important;
        height: 10px !important;
        min-width: 10px !important;
        min-height: 10px !important;
        flex: 0 0 10px !important;
      }

      main.calendar-main .calendar-more-indicator {
        bottom: calc(68px + env(safe-area-inset-bottom)) !important;
      }

      body.mobile-menu-lock main.calendar-main .calendar-legend {
        display: none !important;
      }
    }


    /* v77: Små mobil-/tabletjusteringer af menu, Mine bookinger og handlinger. */
    @media (max-width: 560px) and (pointer: coarse) {
      aside.mobile-menu-open .mobile-menu-panel-head {
        column-gap: 14px !important;
        grid-template-columns: minmax(0, 1fr) 42px 42px !important;
      }

      aside.mobile-menu-open .mobile-menu-panel .user-card {
        margin: auto 0 calc(10px + env(safe-area-inset-bottom)) 0 !important;
      }

      .my-filter-actions {
        display: grid !important;
        gap: 8px !important;
      }

      .my-filter-actions > button[data-action="open-create-booking"] {
        order: 1 !important;
        width: 100% !important;
      }

      .my-filter-actions > .toggle-group {
        order: 2 !important;
      }
    }

    @media (max-width: 1024px) and (orientation: portrait) {
      .my-bookings-table td.actions-cell,
      .admin-panel-stack td.actions-cell {
        padding-top: 6px !important;
      }

      .my-bookings-table td.actions-cell::before,
      .admin-panel-stack td.actions-cell::before {
        content: none !important;
        display: none !important;
      }

      .my-bookings-table td.actions-cell .row,
      .admin-panel-stack td.actions-cell .row {
        margin-top: 0 !important;
      }
    }


    /* v80: Cloudflare-safe ZIP; bevarer v78 mobiljusteringer. */
    .mobile-top-history {
      display: none !important;
    }

    @media (max-width: 560px) and (pointer: coarse) {
      aside:not(.mobile-menu-open) .brand-row {
        grid-template-columns: minmax(0, 1fr) auto 40px 40px !important;
        gap: 6px !important;
      }

      aside:not(.mobile-menu-open) .brand-row .mobile-top-history {
        grid-column: 2 !important;
        grid-row: 1 !important;
        display: inline-flex !important;
        align-self: center !important;
        margin-left: 0 !important;
        transform: none !important;
      }

      aside:not(.mobile-menu-open) .brand-row > .brand-theme-button:not(.mobile-menu-theme) {
        grid-column: 3 !important;
        grid-row: 1 !important;
      }

      aside:not(.mobile-menu-open) .brand-row .mobile-menu-button {
        grid-column: 4 !important;
        grid-row: 1 !important;
      }

      aside:not(.mobile-menu-open) .mobile-top-history {
        padding: 2px !important;
        gap: 2px !important;
        border-radius: 999px !important;
        background: rgba(248, 250, 252, .72) !important;
        border: 1px solid rgba(203, 213, 225, .72) !important;
        box-shadow: none !important;
      }

      body.dark-theme aside:not(.mobile-menu-open) .mobile-top-history {
        background: rgba(30, 41, 59, .64) !important;
        border-color: rgba(71, 85, 105, .78) !important;
      }

      aside:not(.mobile-menu-open) .mobile-top-history .history-button {
        width: 28px !important;
        height: 28px !important;
        min-width: 28px !important;
        min-height: 28px !important;
      }

      aside:not(.mobile-menu-open) .mobile-top-history .history-icon {
        width: 15px !important;
        height: 15px !important;
      }

      main.calendar-main .title-row .history-controls:not(.mobile-top-history),
      main:not(.calendar-main) .title-row .history-controls:not(.mobile-top-history) {
        display: none !important;
      }

      main.calendar-main .room-facility-panel {
        position: fixed !important;
        left: max(12px, env(safe-area-inset-left)) !important;
        right: max(12px, env(safe-area-inset-right)) !important;
        bottom: calc(76px + env(safe-area-inset-bottom)) !important;
        top: auto !important;
        z-index: 92 !important;
        width: auto !important;
        min-width: 0 !important;
        max-width: none !important;
        max-height: min(42dvh, 320px) !important;
        overflow-y: auto !important;
        -webkit-overflow-scrolling: touch !important;
        transform: none !important;
        padding: 12px !important;
        border-radius: 18px !important;
        box-shadow: 0 18px 42px rgba(15, 23, 42, .24) !important;
      }

      main.calendar-main .room-facility-panel::before {
        display: none !important;
      }

      main.calendar-main .room-facility-panel .facility-badges {
        justify-content: flex-start !important;
        align-content: start !important;
        gap: 7px !important;
        max-height: none !important;
      }

      main.calendar-main .room-facility-panel .facility-chip {
        font-size: 11px !important;
        padding: 6px 9px !important;
        white-space: normal !important;
        line-height: 1.15 !important;
      }
    }


    /* v82: Fast topbjælke på mobil + udstyrspanel rykket ned under topbjælken. */
    @media (max-width: 560px) and (pointer: coarse) {
      :root {
        --mobile-fixed-topbar-height: 58px;
      }

      body:not(.mobile-menu-lock) .app-shell {
        padding-top: calc(var(--mobile-fixed-topbar-height) + env(safe-area-inset-top)) !important;
      }

      body:not(.mobile-menu-lock) aside:not(.mobile-menu-open) {
        position: fixed !important;
        top: 0 !important;
        left: 0 !important;
        right: 0 !important;
        z-index: 155 !important;
        height: calc(var(--mobile-fixed-topbar-height) + env(safe-area-inset-top)) !important;
        min-height: calc(var(--mobile-fixed-topbar-height) + env(safe-area-inset-top)) !important;
        max-height: calc(var(--mobile-fixed-topbar-height) + env(safe-area-inset-top)) !important;
        padding: env(safe-area-inset-top) max(10px, env(safe-area-inset-right)) 7px max(10px, env(safe-area-inset-left)) !important;
        display: flex !important;
        align-items: stretch !important;
        overflow: visible !important;
        box-sizing: border-box !important;
      }

      body:not(.mobile-menu-lock) aside:not(.mobile-menu-open) .brand-row {
        min-height: calc(var(--mobile-fixed-topbar-height) - 7px) !important;
        height: calc(var(--mobile-fixed-topbar-height) - 7px) !important;
        width: 100% !important;
        align-content: center !important;
      }

      body.mobile-menu-lock .app-shell {
        padding-top: 0 !important;
      }

      body.mobile-menu-lock aside.mobile-menu-open {
        top: 0 !important;
      }

      main.calendar-main .room-facility-panel {
        top: calc(var(--mobile-fixed-topbar-height) + env(safe-area-inset-top) + 10px) !important;
        bottom: calc(78px + env(safe-area-inset-bottom)) !important;
        max-height: calc(100dvh - var(--mobile-fixed-topbar-height) - 100px - env(safe-area-inset-top) - env(safe-area-inset-bottom)) !important;
        z-index: 96 !important;
      }

      main.calendar-main .room-facility-panel .facility-badges {
        max-height: none !important;
      }
    }


    /* v82: Mobile pop-ups/modals stay below the fixed mobile top bar. */
    @media (max-width: 560px) and (pointer: coarse) {
      body:not(.mobile-menu-lock) .modal-backdrop.open {
        z-index: 240 !important;
        align-items: flex-start !important;
        padding-top: calc(var(--mobile-fixed-topbar-height, 58px) + env(safe-area-inset-top) + 10px) !important;
        padding-right: max(10px, env(safe-area-inset-right)) !important;
        padding-bottom: max(12px, env(safe-area-inset-bottom)) !important;
        padding-left: max(10px, env(safe-area-inset-left)) !important;
      }

      body:not(.mobile-menu-lock) .modal {
        margin: 0 !important;
        width: 100% !important;
        max-height: calc(100dvh - var(--mobile-fixed-topbar-height, 58px) - env(safe-area-inset-top) - env(safe-area-inset-bottom) - 24px) !important;
        box-sizing: border-box !important;
      }

      body:not(.mobile-menu-lock) .modal > .stack > .row.space-between:first-child {
        top: -16px !important;
      }

      body:not(.mobile-menu-lock) main.calendar-main .room-facility-panel {
        top: calc(var(--mobile-fixed-topbar-height, 58px) + env(safe-area-inset-top) + 14px) !important;
        max-height: calc(100dvh - var(--mobile-fixed-topbar-height, 58px) - env(safe-area-inset-top) - env(safe-area-inset-bottom) - 104px) !important;
      }

      body.mobile-menu-lock .modal-backdrop.open {
        z-index: 240 !important;
      }
    }



    /* v84: Mobilkalenderen udnytter nu hele pladsen ned til Forklaringer. */
    @media (max-width: 560px) and (pointer: coarse) {
      body:not(.mobile-menu-lock) main.calendar-main {
        display: flex !important;
        flex-direction: column !important;
        height: calc(100dvh - var(--mobile-fixed-topbar-height, 58px) - env(safe-area-inset-top)) !important;
        min-height: 0 !important;
        overflow: hidden !important;
        padding-bottom: calc(66px + env(safe-area-inset-bottom)) !important;
      }

      body:not(.mobile-menu-lock) main.calendar-main > .calendar-toolbar {
        flex: 0 0 auto !important;
        margin-bottom: 8px !important;
      }

      body:not(.mobile-menu-lock) main.calendar-main > .calendar {
        flex: 1 1 auto !important;
        min-height: 0 !important;
        display: flex !important;
        flex-direction: column !important;
        margin-bottom: 0 !important;
      }

      body:not(.mobile-menu-lock) main.calendar-main .calendar-scroll {
        flex: 1 1 auto !important;
        height: auto !important;
        min-height: 0 !important;
        max-height: none !important;
      }

      body:not(.mobile-menu-lock) main.calendar-main .calendar-grid {
        min-height: 100% !important;
      }

      body:not(.mobile-menu-lock) main.calendar-main .calendar-more-indicator {
        bottom: calc(66px + env(safe-area-inset-bottom)) !important;
      }
    }



    /* v84: Kompakt profilside på mobiltelefoner, så hele siden typisk kan ses uden scroll. */
    @media (max-width: 560px) and (pointer: coarse) {
      .profile-toolbar {
        margin: 0 0 7px !important;
        padding: 8px 10px !important;
        border-radius: 16px !important;
      }

      .profile-toolbar .title-row {
        margin: 0 !important;
      }

      .profile-toolbar h1 {
        font-size: 21px !important;
        line-height: 1.05 !important;
      }

      .profile-toolbar .muted {
        display: none !important;
      }

      .profile-card {
        width: 100% !important;
        max-width: 100% !important;
        padding: 11px !important;
        gap: 8px !important;
        border-radius: 18px !important;
      }

      .profile-card label {
        gap: 4px !important;
        font-size: 11.5px !important;
        line-height: 1.1 !important;
      }

      .profile-card input {
        height: 37px !important;
        min-height: 37px !important;
        padding: 7px 10px !important;
        border-radius: 11px !important;
        font-size: 15px !important;
      }

      .profile-identity-grid {
        grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) !important;
        gap: 7px !important;
      }

      .profile-identity-grid label[style*="grid-column"] {
        grid-column: 1 / -1 !important;
      }

      .profile-divider {
        margin: 1px 0 !important;
      }

      .profile-password-title {
        font-size: 15px !important;
        line-height: 1.1 !important;
      }

      .profile-password-grid {
        grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) !important;
        gap: 7px !important;
      }

      .profile-password-grid label:first-child {
        grid-column: 1 / -1 !important;
      }

      #profile-message {
        min-height: 0 !important;
        font-size: 12px !important;
        line-height: 1.25 !important;
      }

      .profile-save-button {
        height: 39px !important;
        min-height: 39px !important;
        padding: 0 12px !important;
        border-radius: 12px !important;
        font-size: 14px !important;
      }
    }

    @media (max-width: 560px) and (pointer: coarse) and (max-height: 720px) {
      .profile-toolbar {
        padding: 7px 9px !important;
        margin-bottom: 6px !important;
      }

      .profile-toolbar h1 {
        font-size: 20px !important;
      }

      .profile-card {
        padding: 9px !important;
        gap: 6px !important;
      }

      .profile-card input {
        height: 34px !important;
        min-height: 34px !important;
        padding: 6px 9px !important;
      }

      .profile-identity-grid,
      .profile-password-grid {
        gap: 6px !important;
      }

      .profile-password-title {
        font-size: 14px !important;
      }

      .profile-save-button {
        height: 36px !important;
        min-height: 36px !important;
      }
    }


    /* v85: Mobil topbjælke/menu finjusteringer. */
    @media (max-width: 560px) and (pointer: coarse) {
      :root {
        --mobile-topbar-icon: 40px;
      }

      body:not(.mobile-menu-lock) aside:not(.mobile-menu-open) {
        background: rgba(255, 255, 255, .89) !important;
        border-bottom-color: rgba(226, 232, 240, .72) !important;
        backdrop-filter: blur(18px) saturate(1.08) !important;
        -webkit-backdrop-filter: blur(18px) saturate(1.08) !important;
      }

      body.dark-theme:not(.mobile-menu-lock) aside:not(.mobile-menu-open) {
        background: rgba(31, 41, 55, .94) !important;
      }

      body:not(.mobile-menu-lock) aside:not(.mobile-menu-open) .brand-row {
        grid-template-columns: minmax(0, 1fr) auto var(--mobile-topbar-icon) !important;
        align-items: center !important;
        align-content: center !important;
        gap: 8px !important;
      }

      aside:not(.mobile-menu-open) .brand-row .brand {
        align-self: center !important;
        display: flex !important;
        align-items: center !important;
        min-width: 0 !important;
      }

      aside:not(.mobile-menu-open) .brand-row .brand-title {
        align-self: center !important;
        transform: translateY(-1px) !important;
      }

      aside:not(.mobile-menu-open) .brand-row > .brand-theme-button:not(.mobile-menu-theme) {
        display: none !important;
      }

      aside:not(.mobile-menu-open) .brand-row .mobile-top-history {
        grid-column: 2 !important;
        justify-self: end !important;
        align-self: center !important;
        margin: 0 !important;
      }

      aside:not(.mobile-menu-open) .brand-row .mobile-menu-button {
        grid-column: 3 !important;
        justify-self: end !important;
        align-self: center !important;
        width: var(--mobile-topbar-icon) !important;
        height: var(--mobile-topbar-icon) !important;
        min-width: var(--mobile-topbar-icon) !important;
        min-height: var(--mobile-topbar-icon) !important;
      }

      aside:not(.mobile-menu-open) .mobile-top-history .history-button {
        width: 30px !important;
        height: 30px !important;
        min-width: 30px !important;
        min-height: 30px !important;
      }

      aside.mobile-menu-open .mobile-menu-panel .nav button {
        min-height: 48px !important;
        padding: 10px 12px !important;
        border-radius: 15px !important;
        font-size: 14.9px !important;
        line-height: 1.12 !important;
      }

      aside.mobile-menu-open .mobile-menu-panel .nav button::before {
        width: 28px !important;
        height: 28px !important;
        flex-basis: 28px !important;
        font-size: 16.5px !important;
      }
    }


    /* v86: Mobil topbjælke centreret på ny, mere translucency i lyst tema og 10% større bruger/log ud i menuen. */
    @media (max-width: 560px) and (pointer: coarse) {
      body:not(.mobile-menu-lock) aside:not(.mobile-menu-open) {
        padding: calc(env(safe-area-inset-top) + 6px) max(11px, env(safe-area-inset-right)) 6px max(11px, env(safe-area-inset-left)) !important;
        background: rgba(255, 255, 255, .74) !important;
        border-bottom-color: rgba(226, 232, 240, .54) !important;
        box-shadow: 0 8px 24px rgba(15, 23, 42, .055) !important;
        backdrop-filter: blur(22px) saturate(1.12) !important;
        -webkit-backdrop-filter: blur(22px) saturate(1.12) !important;
      }

      body.dark-theme:not(.mobile-menu-lock) aside:not(.mobile-menu-open) {
        background: rgba(31, 41, 55, .94) !important;
        border-bottom-color: rgba(71, 85, 105, .52) !important;
      }

      body:not(.mobile-menu-lock) aside:not(.mobile-menu-open) .brand-row {
        display: grid !important;
        grid-template-columns: minmax(0, 1fr) auto var(--mobile-topbar-icon, 40px) !important;
        gap: 7px !important;
        width: 100% !important;
        height: calc(var(--mobile-fixed-topbar-height, 58px) - 12px) !important;
        min-height: calc(var(--mobile-fixed-topbar-height, 58px) - 12px) !important;
        max-height: calc(var(--mobile-fixed-topbar-height, 58px) - 12px) !important;
        align-items: center !important;
        align-content: center !important;
        justify-items: stretch !important;
        padding: 0 !important;
        line-height: 1 !important;
      }

      body:not(.mobile-menu-lock) aside:not(.mobile-menu-open) .brand-row > * {
        align-self: center !important;
        margin-top: 0 !important;
        margin-bottom: 0 !important;
      }

      body:not(.mobile-menu-lock) aside:not(.mobile-menu-open) .brand-row .brand {
        height: 40px !important;
        min-height: 40px !important;
        align-items: center !important;
        align-self: center !important;
        overflow: hidden !important;
      }

      body:not(.mobile-menu-lock) aside:not(.mobile-menu-open) .brand-row .brand-mark,
      body:not(.mobile-menu-lock) aside:not(.mobile-menu-open) .brand-row .brand-mark img {
        width: 40px !important;
        height: 40px !important;
        min-width: 40px !important;
        min-height: 40px !important;
      }

      body:not(.mobile-menu-lock) aside:not(.mobile-menu-open) .brand-row .brand-title {
        align-self: center !important;
        transform: none !important;
        line-height: 1.04 !important;
      }

      body:not(.mobile-menu-lock) aside:not(.mobile-menu-open) .brand-row .mobile-top-history {
        grid-column: 2 !important;
        height: 36px !important;
        min-height: 36px !important;
        align-self: center !important;
        justify-self: end !important;
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        padding: 2px !important;
      }

      body:not(.mobile-menu-lock) aside:not(.mobile-menu-open) .brand-row .mobile-menu-button {
        grid-column: 3 !important;
        align-self: center !important;
        justify-self: end !important;
        display: inline-grid !important;
        place-items: center !important;
        width: var(--mobile-topbar-icon, 40px) !important;
        height: var(--mobile-topbar-icon, 40px) !important;
        min-width: var(--mobile-topbar-icon, 40px) !important;
        min-height: var(--mobile-topbar-icon, 40px) !important;
        max-width: var(--mobile-topbar-icon, 40px) !important;
        max-height: var(--mobile-topbar-icon, 40px) !important;
        padding: 0 !important;
        transform: none !important;
      }

      body:not(.mobile-menu-lock) aside:not(.mobile-menu-open) .mobile-top-history .history-button {
        width: 30px !important;
        height: 30px !important;
        min-width: 30px !important;
        min-height: 30px !important;
      }

      aside.mobile-menu-open .mobile-menu-panel .user-card {
        padding: 9px 11px !important;
        gap: 9px !important;
        border-radius: 17px !important;
      }

      aside.mobile-menu-open .mobile-menu-panel .user-name {
        font-size: 14.3px !important;
        line-height: 1.08 !important;
      }

      aside.mobile-menu-open .mobile-menu-panel .role-badge {
        min-height: 18px !important;
        padding: 3px 8px !important;
        font-size: 10.5px !important;
      }

      aside.mobile-menu-open .mobile-menu-panel .logout-button {
        height: 35px !important;
        min-height: 35px !important;
        padding: 0 13px !important;
        font-size: 13.2px !important;
      }
    }



    /* v87: Mobilmenu bruger/log ud 10% større og mobilkalender-toolbar omlagt. */
    .mobile-calendar-create-inline,
    .mobile-calendar-day-strip {
      display: none;
    }

    @media (max-width: 560px) and (pointer: coarse) {
      aside.mobile-menu-open .mobile-menu-panel .user-card {
        padding: 10px 12px !important;
        gap: 10px !important;
        border-radius: 19px !important;
      }

      aside.mobile-menu-open .mobile-menu-panel .user-name {
        font-size: 15.7px !important;
        line-height: 1.08 !important;
      }

      aside.mobile-menu-open .mobile-menu-panel .role-badge {
        min-height: 20px !important;
        padding: 3px 9px !important;
        font-size: 11.6px !important;
      }

      aside.mobile-menu-open .mobile-menu-panel .logout-button {
        height: 39px !important;
        min-height: 39px !important;
        padding: 0 15px !important;
        font-size: 14.5px !important;
      }

      body:not(.mobile-menu-lock) main.calendar-main > .calendar-toolbar {
        display: grid !important;
        grid-template-columns: minmax(0, 1fr) !important;
        align-items: stretch !important;
        gap: 8px !important;
      }

      .calendar-toolbar-heading {
        display: grid !important;
        grid-template-columns: minmax(0, 1fr) !important;
        gap: 0 !important;
      }

      .calendar-title-row {
        display: grid !important;
        grid-template-columns: minmax(0, 1fr) auto !important;
        align-items: center !important;
        gap: 10px !important;
        width: 100% !important;
        margin: 0 !important;
        min-height: 42px !important;
      }

      .calendar-title-row h1 {
        min-width: 0 !important;
      }

      .calendar-title-row .history-controls {
        display: none !important;
      }

      .mobile-calendar-create-inline {
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        grid-column: 2 !important;
        min-height: 40px !important;
        height: 40px !important;
        padding: 0 13px !important;
        border-radius: 999px !important;
        font-size: 13px !important;
        white-space: nowrap !important;
        box-shadow: 0 8px 18px rgba(37, 99, 235, .16) !important;
      }

      .calendar-toolbar-heading > .calendar-day-badge {
        display: none !important;
      }

      .calendar-toolbar-actions {
        grid-template-columns: minmax(68px, .9fr) 42px minmax(130px, 1.3fr) 42px !important;
        gap: 7px !important;
        align-items: center !important;
        width: 100% !important;
      }

      .calendar-toolbar-actions [data-action="open-create-booking"] {
        display: none !important;
      }

      .mobile-calendar-day-strip {
        display: block !important;
        margin: 0 0 6px !important;
      }

      .mobile-calendar-day-strip .calendar-day-badge {
        display: flex !important;
        justify-content: center !important;
        width: 100% !important;
        margin: 0 !important;
        padding: 7px 10px !important;
        border-radius: 14px !important;
        font-size: 12px !important;
        gap: 6px !important;
        background: rgba(248, 250, 252, .78) !important;
        border: 1px solid rgba(226, 232, 240, .82) !important;
      }

      body.dark-theme .mobile-calendar-day-strip .calendar-day-badge {
        background: rgba(15, 23, 42, .42) !important;
        border-color: rgba(71, 85, 105, .70) !important;
      }

      body:not(.mobile-menu-lock) main.calendar-main > .calendar-toolbar {
        margin-bottom: 6px !important;
      }

      body:not(.mobile-menu-lock) main.calendar-main > .calendar {
        margin-top: 0 !important;
      }
    }


    /* v88: Mobilkalender-dagtekst uden boks, lavere scrollindikator og centreret mobilmenu-top. */
    @media (max-width: 560px) and (pointer: coarse) {
      .mobile-calendar-day-strip {
        display: block !important;
        margin: -1px 0 4px !important;
        padding: 0 2px !important;
        text-align: left !important;
      }

      .mobile-calendar-day-strip .calendar-day-badge {
        display: inline-flex !important;
        justify-content: flex-start !important;
        align-items: center !important;
        width: auto !important;
        max-width: 100% !important;
        margin: 0 !important;
        padding: 0 !important;
        border: 0 !important;
        border-radius: 0 !important;
        background: transparent !important;
        box-shadow: none !important;
        color: var(--muted) !important;
        font-size: 12.5px !important;
        line-height: 1.1 !important;
        letter-spacing: .01em !important;
      }

      .mobile-calendar-day-strip .calendar-day-title {
        font-weight: 750 !important;
      }

      .mobile-calendar-day-strip .calendar-day-today {
        margin-left: 6px !important;
        padding: 2px 6px !important;
        border-radius: 999px !important;
        font-size: 10px !important;
      }

      body:not(.mobile-menu-lock) main.calendar-main > .calendar-toolbar {
        margin-bottom: 4px !important;
      }

      body:not(.mobile-menu-lock) main.calendar-main > .calendar {
        margin-top: 0 !important;
      }

      body:not(.mobile-menu-lock) main.calendar-main .calendar-more-indicator {
        bottom: calc(60px + env(safe-area-inset-bottom)) !important;
      }

      aside.mobile-menu-open .mobile-menu-panel-head {
        align-items: center !important;
        align-content: center !important;
        padding-top: 6px !important;
        padding-bottom: 6px !important;
      }

      aside.mobile-menu-open .mobile-menu-panel-brand,
      aside.mobile-menu-open .mobile-menu-theme,
      aside.mobile-menu-open .mobile-menu-close {
        align-self: center !important;
        justify-self: center !important;
        margin-top: 0 !important;
        margin-bottom: 0 !important;
      }

      aside.mobile-menu-open .mobile-menu-panel-brand {
        justify-self: stretch !important;
        min-height: 42px !important;
        height: 42px !important;
        line-height: 1 !important;
      }

      aside.mobile-menu-open .mobile-menu-panel-brand img {
        align-self: center !important;
      }

      aside.mobile-menu-open .mobile-menu-panel-brand span {
        display: inline-flex !important;
        align-items: center !important;
        height: 42px !important;
        line-height: 1 !important;
      }
    }


    /* v90: Mobil-polish: lavere scroll-indikator, bedre menu-top og fast X-placering i modalvinduer. */
    .modal > .stack > .row.space-between:first-child {
      padding-right: 54px !important;
      min-height: 42px !important;
      align-items: flex-start !important;
    }

    .modal > .stack > .row.space-between:first-child .modal-close-button {
      position: absolute !important;
      top: 1px !important;
      right: -3px !important;
      margin: 0 !important;
      z-index: 8 !important;
    }

    @media (max-width: 560px) and (pointer: coarse) {
      body:not(.mobile-menu-lock) main.calendar-main .calendar-more-indicator {
        bottom: calc(20px + env(safe-area-inset-bottom)) !important;
      }

      aside.mobile-menu-open .mobile-menu-panel-head {
        display: grid !important;
        grid-template-columns: minmax(0, 1fr) 42px 42px !important;
        column-gap: 12px !important;
        align-items: center !important;
        align-content: center !important;
        min-height: 62px !important;
        height: 62px !important;
        padding: 8px 0 10px !important;
        margin: 0 0 8px 0 !important;
        box-sizing: border-box !important;
      }

      aside.mobile-menu-open .mobile-menu-panel-brand {
        height: 42px !important;
        min-height: 42px !important;
        display: flex !important;
        align-items: center !important;
        justify-content: flex-start !important;
        gap: 10px !important;
        line-height: 1 !important;
        margin: 0 !important;
        align-self: center !important;
        justify-self: stretch !important;
      }

      aside.mobile-menu-open .mobile-menu-panel-brand img {
        width: 38px !important;
        height: 38px !important;
        min-width: 38px !important;
        min-height: 38px !important;
        max-width: 38px !important;
        max-height: 38px !important;
        align-self: center !important;
      }

      aside.mobile-menu-open .mobile-menu-panel-brand span {
        display: inline-flex !important;
        align-items: center !important;
        height: 42px !important;
        line-height: 1 !important;
        margin: 0 !important;
      }

      aside.mobile-menu-open .mobile-menu-theme,
      aside.mobile-menu-open .mobile-menu-close {
        width: 42px !important;
        height: 42px !important;
        min-width: 42px !important;
        min-height: 42px !important;
        max-width: 42px !important;
        max-height: 42px !important;
        display: inline-grid !important;
        place-items: center !important;
        align-self: center !important;
        justify-self: center !important;
        margin: 0 !important;
        padding: 0 !important;
        line-height: 1 !important;
        transform: none !important;
      }

      .modal > .stack > .row.space-between:first-child {
        padding-right: 48px !important;
      }

      .modal > .stack > .row.space-between:first-child .modal-close-button {
        top: 0 !important;
        right: -2px !important;
      }
    }



    /* v91: Prevent accidental text selection / Google touch-search on touch devices. */
    @media (pointer: coarse) {
      html,
      body,
      #root,
      .app-shell,
      main,
      aside,
      .card,
      .panel,
      .section,
      .calendar,
      .calendar *,
      .modal,
      .modal *,
      .mobile-menu-panel,
      .mobile-menu-panel *,
      button,
      label,
      a,
      h1,
      h2,
      h3,
      p,
      span,
      div,
      table,
      th,
      td {
        -webkit-user-select: none !important;
        user-select: none !important;
        -webkit-touch-callout: none !important;
        -webkit-tap-highlight-color: transparent !important;
      }

      input,
      textarea,
      select,
      [contenteditable="true"],
      [contenteditable="true"] * {
        -webkit-user-select: text !important;
        user-select: text !important;
        -webkit-touch-callout: default !important;
      }
    }


    /* v164: Prevent accidental text selection in the desktop UI as well. */
    html,
    body,
    #root,
    .app-shell,
    main,
    aside,
    .card,
    .panel,
    .section,
    .calendar,
    .calendar *,
    .modal,
    .modal *,
    .mobile-menu-panel,
    .mobile-menu-panel *,
    button,
    label,
    a,
    h1,
    h2,
    h3,
    p,
    span,
    div,
    table,
    th,
    td {
      -webkit-user-select: none !important;
      user-select: none !important;
      -webkit-touch-callout: none !important;
      -webkit-tap-highlight-color: transparent !important;
    }

    input,
    textarea,
    select,
    [contenteditable="true"],
    [contenteditable="true"] * {
      -webkit-user-select: text !important;
      user-select: text !important;
      -webkit-touch-callout: default !important;
    }



    /* v93: Mobilkalenderens indhold klippes efter sektionens afrundede hjørner. */
    @media (max-width: 560px) and (pointer: coarse) {
      main.calendar-main .calendar {
        border-radius: 18px !important;
        overflow: hidden !important;
        overflow: clip !important;
        isolation: isolate !important;
        contain: paint !important;
        clip-path: inset(0 round 18px) !important;
        -webkit-mask-image: -webkit-radial-gradient(white, black) !important;
        background: var(--calendar-bg) !important;
      }

      main.calendar-main .calendar-scroll {
        border-radius: inherit !important;
        overflow-x: hidden !important;
        overflow-y: auto !important;
        overscroll-behavior: contain !important;
        background: var(--calendar-bg) !important;
      }

      main.calendar-main .calendar-grid {
        border-radius: inherit !important;
        overflow: hidden !important;
        background: var(--calendar-bg) !important;
      }

      main.calendar-main .cal-head:first-child,
      main.calendar-main .time-head {
        border-top-left-radius: 18px !important;
      }

      main.calendar-main .cal-head:last-of-type {
        border-top-right-radius: 18px !important;
      }

      main.calendar-main .calendar::after,
      main.calendar-main .calendar-more-indicator,
      main.calendar-main .calendar-date-edge-cue,
      main.calendar-main .calendar-swipe-feedback {
        clip-path: inset(0 round 18px) !important;
      }
    }


    /* v95: Mobilkalender bund-flush/ekstra højde + portrait-guard markør. */
    @media (max-width: 560px) and (pointer: coarse) {
      body:not(.mobile-menu-lock) main.calendar-main {
        padding-bottom: calc(58px + env(safe-area-inset-bottom)) !important;
      }

      body:not(.mobile-menu-lock) main.calendar-main > .calendar {
        padding-bottom: 0 !important;
        margin-bottom: 0 !important;
      }

      body:not(.mobile-menu-lock) main.calendar-main .calendar-scroll {
        display: flex !important;
        align-items: stretch !important;
        border-radius: inherit !important;
      }

      body:not(.mobile-menu-lock) main.calendar-main .calendar-grid {
        flex: 1 0 auto !important;
        min-height: 100% !important;
        border-bottom-left-radius: 18px !important;
        border-bottom-right-radius: 18px !important;
      }

      body:not(.mobile-menu-lock) main.calendar-main .calendar-more-indicator {
        bottom: calc(18px + env(safe-area-inset-bottom)) !important;
      }
    }


    /* v96: Fastgør mobilkalenderens lokale-/udstyrsrække ved scroll og stram modal-spacing. */
    @media (max-width: 560px) and (pointer: coarse) {
      body:not(.mobile-menu-lock) main.calendar-main .calendar {
        overflow: hidden !important;
        overflow: clip !important;
        clip-path: inset(0 round 18px) !important;
      }

      body:not(.mobile-menu-lock) main.calendar-main .calendar-scroll {
        overflow-x: hidden !important;
        overflow-y: auto !important;
        border-radius: inherit !important;
      }

      body:not(.mobile-menu-lock) main.calendar-main .calendar-grid {
        overflow: visible !important;
        border-radius: 0 !important;
      }

      body:not(.mobile-menu-lock) main.calendar-main .cal-head {
        position: sticky !important;
        top: 0 !important;
        z-index: 36 !important;
        background: var(--calendar-header) !important;
        transform: translateZ(0) !important;
        -webkit-transform: translateZ(0) !important;
      }

      body:not(.mobile-menu-lock) main.calendar-main .time-head {
        z-index: 38 !important;
      }

      body:not(.mobile-menu-lock) main.calendar-main .calendar-grid > .cal-head:first-child {
        border-top-left-radius: 18px !important;
      }

      body:not(.mobile-menu-lock) main.calendar-main .calendar-grid > .cal-head:nth-child(calc(var(--room-count, 4) + 1)) {
        border-top-right-radius: 18px !important;
      }
    }



    /* v104: Stabil mobil-header til kalenderen.
       Vi lader den oprindelige header scrolle normalt og lægger en separat fast overlay-header ovenpå.
       Det undgår native sticky-begrænsningen, hvor headeren slap omkring midten af kalenderen. */
    .mobile-calendar-fixed-head {
      display: none;
    }

    @media (max-width: 560px) and (pointer: coarse) {
      body:not(.mobile-menu-lock) main.calendar-main .calendar {
        --mobile-calendar-fixed-head-height: 58px;
      }

      body:not(.mobile-menu-lock) main.calendar-main .mobile-calendar-fixed-head {
        display: grid;
        grid-template-columns: clamp(42px, 11vw, 50px) repeat(var(--room-count, 4), minmax(0, 1fr));
        position: absolute;
        top: 0;
        left: 0;
        right: 0;
        height: var(--mobile-calendar-fixed-head-height);
        z-index: 60;
        border-top-left-radius: 18px;
        border-top-right-radius: 18px;
        overflow: hidden;
        pointer-events: auto;
        transform: translateZ(0);
        -webkit-transform: translateZ(0);
        will-change: transform;
        box-shadow: 0 8px 18px rgba(15, 23, 42, .10);
      }

      body:not(.mobile-menu-lock) main.calendar-main .mobile-calendar-fixed-head .cal-head {
        position: relative !important;
        top: auto !important;
        z-index: 1 !important;
        height: var(--mobile-calendar-fixed-head-height) !important;
        min-height: var(--mobile-calendar-fixed-head-height) !important;
        max-height: var(--mobile-calendar-fixed-head-height) !important;
        border-radius: 0 !important;
        background: var(--calendar-header) !important;
      }

      body:not(.mobile-menu-lock) main.calendar-main .mobile-calendar-fixed-head .cal-head:first-child {
        border-top-left-radius: 18px !important;
      }

      body:not(.mobile-menu-lock) main.calendar-main .mobile-calendar-fixed-head .cal-head:last-child {
        border-top-right-radius: 18px !important;
      }

      body:not(.mobile-menu-lock) main.calendar-main .calendar-grid > .cal-head {
        position: relative !important;
        top: auto !important;
        z-index: 1 !important;
      }

      body:not(.mobile-menu-lock) main.calendar-main .calendar-scroll {
        scroll-padding-top: var(--mobile-calendar-fixed-head-height);
      }
    }

    .modal > .stack {
      gap: 9px !important;
    }

    .modal > .stack > .row.space-between:first-child {
      padding-bottom: 4px !important;
      margin-bottom: -2px !important;
      min-height: 34px !important;
    }

    .modal > .stack > .row.space-between:first-child h2,
    .modal > .stack > .row.space-between:first-child h3 {
      margin: 0 !important;
      line-height: 1.08 !important;
    }

    @media (max-width: 560px) and (pointer: coarse) {
      .modal > .stack {
        gap: 8px !important;
      }

      .modal > .stack > .row.space-between:first-child {
        padding-bottom: 3px !important;
        margin-bottom: -2px !important;
        min-height: 34px !important;
      }
    }



    /* v104: Stable modal close button position after tighter modal spacing. */
    .modal {
      --modal-close-size: 36px;
      --modal-close-inset: -3px;
    }

    .modal > .stack > .row.space-between:first-child {
      padding-right: calc(var(--modal-close-size) + 14px) !important;
      min-height: calc(var(--modal-close-size) + 2px) !important;
      box-sizing: border-box !important;
    }

    .modal > .stack > .row.space-between:first-child .modal-close-button {
      position: absolute !important;
      top: var(--modal-close-inset) !important;
      right: var(--modal-close-inset) !important;
      width: var(--modal-close-size) !important;
      height: var(--modal-close-size) !important;
      min-width: var(--modal-close-size) !important;
      min-height: var(--modal-close-size) !important;
      flex: 0 0 var(--modal-close-size) !important;
      margin: 0 !important;
      transform: none !important;
      z-index: 12 !important;
    }

    .modal > .stack > .row.space-between:first-child .modal-close-button:hover {
      transform: none !important;
    }

    @media (max-width: 560px) and (pointer: coarse) {
      .modal {
        --modal-close-size: 34px;
        --modal-close-inset: -2px;
      }

      .modal > .stack > .row.space-between:first-child {
        padding-right: calc(var(--modal-close-size) + 12px) !important;
        min-height: calc(var(--modal-close-size) + 2px) !important;
      }
    }


    /* v110: Mobil bookingdetaljer bruger nu samme knapdesign som desktop, blot stakket i mobilvenlig bredde. */
    @media (max-width: 560px) and (pointer: coarse) {
      .booking-detail-actions {
        display: flex !important;
        flex-direction: column !important;
        align-items: stretch !important;
        gap: 8px !important;
        margin-top: 6px !important;
        padding: 0 !important;
        border: 0 !important;
        background: transparent !important;
        box-shadow: none !important;
      }

      .booking-detail-actions button {
        width: 100% !important;
        min-height: 44px !important;
        padding: 10px 16px !important;
        border-radius: 999px !important;
        font-size: 14px !important;
        font-weight: 700 !important;
        line-height: 1.15 !important;
        text-align: center !important;
        justify-content: center !important;
        white-space: normal !important;
      }

      .booking-detail-actions .booking-detail-action-edit {
        background: var(--blue) !important;
        color: white !important;
      }

      .booking-detail-actions .booking-detail-action-edit:hover {
        background: var(--blue-dark) !important;
      }

      .booking-detail-actions .booking-detail-action-delete {
        background: var(--red) !important;
        color: white !important;
      }
    }



    /* v110: Bookingdetaljer-actions fastgjort i bunden, kompakt aflysningspil og tema tilbage på desktop/tablet. */
    .booking-detail-modal-stack {
      min-height: min(560px, calc(100vh - 88px));
      align-content: start;
    }

    .booking-detail-modal-stack .booking-detail-actions {
      position: sticky !important;
      bottom: -20px !important;
      z-index: 7 !important;
      justify-content: center !important;
      align-items: center !important;
      gap: 10px !important;
      margin-top: auto !important;
      padding: 14px 0 4px !important;
      background: linear-gradient(to top, white 80%, rgba(255,255,255,.88)) !important;
      border-top: 1px solid rgba(226, 232, 240, .72) !important;
    }

    body.dark-theme .booking-detail-modal-stack .booking-detail-actions {
      background: linear-gradient(to top, var(--panel) 80%, rgba(31,41,55,.88)) !important;
      border-top-color: rgba(71, 85, 105, .62) !important;
    }

    .booking-detail-modal-stack .booking-detail-actions button {
      margin-left: 0 !important;
      margin-right: 0 !important;
    }

    .cancellation-toggle {
      width: 24px !important;
      height: 24px !important;
      min-width: 24px !important;
      min-height: 24px !important;
      font-size: 0 !important;
    }

    .cancellation-toggle-icon {
      width: 14px;
      height: 14px;
      display: block;
      fill: none;
      stroke: currentColor;
      stroke-width: 2.35;
      stroke-linecap: round;
      stroke-linejoin: round;
    }

    @media (min-width: 561px), (hover: hover), (pointer: fine) {
      aside .brand-row > .brand-theme-button:not(.mobile-menu-theme) {
        display: inline-grid !important;
        visibility: visible !important;
        opacity: 1 !important;
      }
    }

    @media (max-width: 920px) and (orientation: portrait) and (pointer: coarse) and (min-width: 561px) {
      aside .brand-row > .brand-theme-button:not(.mobile-menu-theme) {
        display: inline-grid !important;
        visibility: visible !important;
        opacity: 1 !important;
      }
    }

    @media (max-width: 560px) and (pointer: coarse) {
      .booking-detail-modal-stack {
        min-height: min(520px, calc(100dvh - var(--mobile-fixed-topbar-height, 58px) - env(safe-area-inset-top) - env(safe-area-inset-bottom) - 24px));
      }

      .booking-detail-modal-stack .booking-detail-actions {
        bottom: -20px !important;
        flex-direction: column !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 8px !important;
        padding: 12px 0 2px !important;
      }

      .booking-detail-modal-stack .booking-detail-actions button {
        width: min(100%, 280px) !important;
        min-height: 42px !important;
      }
    }



    /* v110: Bookingdetaljer-knapper uden indre footer-vindue, konsekvent modalstørrelse og tema tilbage i sidebjælken. */
    .modal.booking-details-modal {
      width: min(620px, 100%) !important;
      height: min(620px, calc(100vh - 48px)) !important;
      max-height: calc(100vh - 48px) !important;
      display: block !important;
    }

    .modal.booking-details-modal .booking-detail-modal-stack {
      min-height: 100% !important;
      height: auto !important;
      display: flex !important;
      flex-direction: column !important;
      align-content: stretch !important;
      gap: 9px !important;
    }

    .modal.booking-details-modal .booking-detail-actions,
    .modal.booking-details-modal > .stack > .booking-detail-actions.row:last-child:not(.space-between) {
      position: static !important;
      bottom: auto !important;
      top: auto !important;
      z-index: auto !important;
      width: 100% !important;
      display: flex !important;
      flex-direction: row !important;
      flex-wrap: wrap !important;
      justify-content: center !important;
      align-items: center !important;
      align-self: stretch !important;
      justify-self: center !important;
      gap: 10px !important;
      margin: auto auto 0 !important;
      padding: 10px 0 0 !important;
      border: 0 !important;
      border-top: 0 !important;
      background: transparent !important;
      box-shadow: none !important;
    }

    body.dark-theme .modal.booking-details-modal .booking-detail-actions,
    body.dark-theme .modal.booking-details-modal > .stack > .booking-detail-actions.row:last-child:not(.space-between) {
      background: transparent !important;
      border: 0 !important;
      border-top: 0 !important;
      box-shadow: none !important;
    }

    .modal.booking-details-modal .booking-detail-actions button {
      margin-left: 0 !important;
      margin-right: 0 !important;
      flex: 0 0 auto !important;
    }

    aside .brand-row > .sidebar-theme-button {
      display: inline-grid !important;
      visibility: visible !important;
      opacity: 1 !important;
    }

    @media (max-width: 560px) and (pointer: coarse) {
      .modal.booking-details-modal {
        width: 100% !important;
        height: calc(100dvh - var(--mobile-fixed-topbar-height, 58px) - env(safe-area-inset-top) - env(safe-area-inset-bottom) - 24px) !important;
        max-height: calc(100dvh - var(--mobile-fixed-topbar-height, 58px) - env(safe-area-inset-top) - env(safe-area-inset-bottom) - 24px) !important;
      }

      .modal.booking-details-modal .booking-detail-modal-stack {
        min-height: 100% !important;
      }

      .modal.booking-details-modal .booking-detail-actions,
      .modal.booking-details-modal > .stack > .booking-detail-actions.row:last-child:not(.space-between) {
        flex-direction: column !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 8px !important;
        padding: 10px 0 0 !important;
        margin: auto auto 0 !important;
        background: transparent !important;
        border: 0 !important;
        box-shadow: none !important;
      }

      .modal.booking-details-modal .booking-detail-actions button {
        width: min(100%, 280px) !important;
        min-height: 42px !important;
      }

      aside:not(.mobile-menu-open) .brand-row > .sidebar-theme-button {
        display: none !important;
      }
    }


    /* v110: Fleksible bookingdetaljer bruger kompakt højde, så der ikke opstår stor luft mellem info og handlingsknapper. */
    .modal.booking-details-modal.booking-details-flex {
      height: auto !important;
      min-height: 0 !important;
      max-height: calc(100vh - 48px) !important;
    }

    .modal.booking-details-modal.booking-details-flex .booking-detail-modal-stack {
      min-height: 0 !important;
      height: auto !important;
    }

    .modal.booking-details-modal.booking-details-flex .booking-detail-actions,
    .modal.booking-details-modal.booking-details-flex > .stack > .booking-detail-actions.row:last-child:not(.space-between) {
      margin: 4px auto 0 !important;
      padding-top: 6px !important;
    }

    @media (max-width: 560px) and (pointer: coarse) {
      .modal.booking-details-modal.booking-details-flex {
        height: auto !important;
        min-height: 0 !important;
        max-height: calc(100dvh - var(--mobile-fixed-topbar-height, 58px) - env(safe-area-inset-top) - env(safe-area-inset-bottom) - 24px) !important;
      }

      .modal.booking-details-modal.booking-details-flex .booking-detail-actions,
      .modal.booking-details-modal.booking-details-flex > .stack > .booking-detail-actions.row:last-child:not(.space-between) {
        margin: 6px auto 0 !important;
        padding-top: 6px !important;
      }
    }


    /* v111: Bookingdetaljer for faste bookinger har ikke fastgjort overskrift/kryds. */
    .modal.booking-details-modal.booking-details-fixed > .booking-detail-modal-stack > .row.space-between:first-child,
    .modal.booking-details-modal.booking-details-fixed > .stack > .row.space-between:first-child {
      position: relative !important;
      top: auto !important;
      z-index: 2 !important;
    }

    .modal.booking-details-modal.booking-details-fixed > .booking-detail-modal-stack > .row.space-between:first-child .modal-close-button,
    .modal.booking-details-modal.booking-details-fixed > .stack > .row.space-between:first-child .modal-close-button {
      position: absolute !important;
    }


    /* v131: Medlemsdetaljer har ikke fastgjort overskrift/kryds. */
    .modal.member-details-modal > .member-details-modal-stack > .row.space-between:first-child,
    .modal.member-details-modal > .stack.member-details-modal-stack > .row.space-between:first-child {
      position: relative !important;
      top: auto !important;
      z-index: 2 !important;
    }

    .modal.member-details-modal > .member-details-modal-stack > .row.space-between:first-child .modal-close-button,
    .modal.member-details-modal > .stack.member-details-modal-stack > .row.space-between:first-child .modal-close-button {
      position: absolute !important;
    }




    /* v150: Mobil-Kontrolpanel: centrer top-rammen og handlingsknapperne uden at centrere tekstindholdet. */
    @media (max-width: 560px) and (pointer: coarse) {
      main.admin-main > .admin-toolbar {
        width: 100% !important;
        margin-left: auto !important;
        margin-right: auto !important;
        padding: 12px !important;
        border: 1px solid rgba(229, 231, 235, .78) !important;
        border-radius: 18px !important;
        overflow: clip !important;
        text-align: left !important;
      }

      body.dark-theme main.admin-main > .admin-toolbar {
        border-color: rgba(55, 65, 81, .78) !important;
      }

      main.admin-main > .admin-toolbar::after {
        display: none !important;
      }

      main.admin-main > .admin-toolbar > div:first-child {
        width: 100% !important;
        text-align: left !important;
      }

      main.admin-main > .admin-toolbar .row {
        width: 100% !important;
        max-width: 340px !important;
        margin-left: auto !important;
        margin-right: auto !important;
        justify-items: center !important;
      }

      main.admin-main > .admin-toolbar .row button {
        width: 100% !important;
        justify-self: center !important;
      }
    }


    /* v154: Gør udstyrsknapperne lidt mindre og lokalenavne en anelse større i kalenderen. */
    .room-head-name {
      font-size: 14px !important;
      font-weight: 950 !important;
      line-height: 1.12 !important;
    }

    .room-facility-trigger {
      min-height: 20px !important;
      padding: 3px 6px !important;
      gap: 2px !important;
      font-size: 9.5px !important;
      border-width: 1px !important;
    }

    .room-facility-trigger-label {
      gap: 4px !important;
    }

    .room-facility-count {
      min-width: 12px !important;
      height: 12px !important;
      padding: 0 2px !important;
      font-size: 9px !important;
    }

    @media (min-width: 561px) {
      main.calendar-main .room-head-title .room-head-name,
      main.calendar-main .mobile-calendar-fixed-head .room-head-title .room-head-name {
        font-size: 16px !important;
        line-height: 1.08 !important;
      }
    }

    @media (max-width: 560px) and (pointer: coarse) {
      body:not(.mobile-menu-lock) main.calendar-main .room-head-title .room-head-name,
      body:not(.mobile-menu-lock) main.calendar-main .mobile-calendar-fixed-head .room-head-title .room-head-name {
        font-size: 12px !important;
        line-height: 1.05 !important;
      }

      body:not(.mobile-menu-lock) main.calendar-main .room-facility-trigger,
      body:not(.mobile-menu-lock) main.calendar-main .mobile-calendar-fixed-head .room-facility-trigger {
        min-height: 19px !important;
        padding: 2px 5px !important;
        gap: 1px !important;
        font-size: 9px !important;
      }

      body:not(.mobile-menu-lock) main.calendar-main .room-facility-trigger-text::after,
      body:not(.mobile-menu-lock) main.calendar-main .mobile-calendar-fixed-head .room-facility-trigger-text::after {
        font-size: 9px !important;
      }
    }
